mirror of
https://github.com/yu-i-i/overleaf-cep.git
synced 2026-05-23 17:19:37 +02:00
Merge pull request #13778 from overleaf/em-fetch-utils-clsi
Use fetch-utils in clsi GitOrigin-RevId: c2ba431b2c6b0fb89f684861f34de40d767cc8cd
This commit is contained in:
6
package-lock.json
generated
6
package-lock.json
generated
@@ -39708,6 +39708,7 @@
|
|||||||
"services/clsi": {
|
"services/clsi": {
|
||||||
"name": "@overleaf/clsi",
|
"name": "@overleaf/clsi",
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
|
"@overleaf/fetch-utils": "*",
|
||||||
"@overleaf/logger": "*",
|
"@overleaf/logger": "*",
|
||||||
"@overleaf/metrics": "*",
|
"@overleaf/metrics": "*",
|
||||||
"@overleaf/o-error": "*",
|
"@overleaf/o-error": "*",
|
||||||
@@ -39721,7 +39722,6 @@
|
|||||||
"fs-extra": "^10.0.0",
|
"fs-extra": "^10.0.0",
|
||||||
"lockfile": "^1.0.4",
|
"lockfile": "^1.0.4",
|
||||||
"lodash": "^4.17.21",
|
"lodash": "^4.17.21",
|
||||||
"node-fetch": "^2.6.7",
|
|
||||||
"p-limit": "^3.1.0",
|
"p-limit": "^3.1.0",
|
||||||
"request": "^2.88.2",
|
"request": "^2.88.2",
|
||||||
"send": "^0.17.1",
|
"send": "^0.17.1",
|
||||||
@@ -39732,6 +39732,7 @@
|
|||||||
"chai-as-promised": "^7.1.1",
|
"chai-as-promised": "^7.1.1",
|
||||||
"mocha": "^10.2.0",
|
"mocha": "^10.2.0",
|
||||||
"mock-fs": "^5.1.2",
|
"mock-fs": "^5.1.2",
|
||||||
|
"node-fetch": "^2.6.7",
|
||||||
"sandboxed-module": "^2.0.4",
|
"sandboxed-module": "^2.0.4",
|
||||||
"sinon": "~9.0.1",
|
"sinon": "~9.0.1",
|
||||||
"sinon-chai": "^3.7.0",
|
"sinon-chai": "^3.7.0",
|
||||||
@@ -40984,6 +40985,7 @@
|
|||||||
"name": "@overleaf/third-party-datastore",
|
"name": "@overleaf/third-party-datastore",
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"@overleaf/access-token-encryptor": "*",
|
"@overleaf/access-token-encryptor": "*",
|
||||||
|
"@overleaf/fetch-utils": "*",
|
||||||
"@overleaf/logger": "*",
|
"@overleaf/logger": "*",
|
||||||
"@overleaf/metrics": "*",
|
"@overleaf/metrics": "*",
|
||||||
"@overleaf/o-error": "*",
|
"@overleaf/o-error": "*",
|
||||||
@@ -48997,6 +48999,7 @@
|
|||||||
"@overleaf/clsi": {
|
"@overleaf/clsi": {
|
||||||
"version": "file:services/clsi",
|
"version": "file:services/clsi",
|
||||||
"requires": {
|
"requires": {
|
||||||
|
"@overleaf/fetch-utils": "*",
|
||||||
"@overleaf/logger": "*",
|
"@overleaf/logger": "*",
|
||||||
"@overleaf/metrics": "*",
|
"@overleaf/metrics": "*",
|
||||||
"@overleaf/o-error": "*",
|
"@overleaf/o-error": "*",
|
||||||
@@ -50163,6 +50166,7 @@
|
|||||||
"version": "file:services/third-party-datastore",
|
"version": "file:services/third-party-datastore",
|
||||||
"requires": {
|
"requires": {
|
||||||
"@overleaf/access-token-encryptor": "*",
|
"@overleaf/access-token-encryptor": "*",
|
||||||
|
"@overleaf/fetch-utils": "*",
|
||||||
"@overleaf/logger": "*",
|
"@overleaf/logger": "*",
|
||||||
"@overleaf/metrics": "*",
|
"@overleaf/metrics": "*",
|
||||||
"@overleaf/o-error": "*",
|
"@overleaf/o-error": "*",
|
||||||
|
|||||||
@@ -1,10 +1,9 @@
|
|||||||
const fs = require('fs')
|
const fs = require('fs')
|
||||||
const logger = require('@overleaf/logger')
|
const logger = require('@overleaf/logger')
|
||||||
const Settings = require('@overleaf/settings')
|
const Settings = require('@overleaf/settings')
|
||||||
|
const { fetchStream } = require('@overleaf/fetch-utils')
|
||||||
const { URL } = require('url')
|
const { URL } = require('url')
|
||||||
const { promisify } = require('util')
|
const { pipeline } = require('stream/promises')
|
||||||
const fetch = require('node-fetch')
|
|
||||||
const pipeline = promisify(require('stream').pipeline)
|
|
||||||
|
|
||||||
async function pipeUrlToFileWithRetry(url, filePath) {
|
async function pipeUrlToFileWithRetry(url, filePath) {
|
||||||
let remainingAttempts = 3
|
let remainingAttempts = 3
|
||||||
@@ -33,14 +32,13 @@ async function pipeUrlToFile(url, filePath) {
|
|||||||
url = `${Settings.filestoreDomainOveride}${u.pathname}${u.search}`
|
url = `${Settings.filestoreDomainOveride}${u.pathname}${u.search}`
|
||||||
}
|
}
|
||||||
|
|
||||||
const res = await fetch(url, { signal: AbortSignal.timeout(60 * 1000) })
|
const stream = await fetchStream(url, {
|
||||||
if (res.status !== 200) {
|
signal: AbortSignal.timeout(60 * 1000),
|
||||||
throw new Error('non success response: ' + res.statusText)
|
})
|
||||||
}
|
|
||||||
|
|
||||||
const atomicWrite = filePath + '~'
|
const atomicWrite = filePath + '~'
|
||||||
try {
|
try {
|
||||||
await pipeline(res.body, fs.createWriteStream(atomicWrite))
|
await pipeline(stream, fs.createWriteStream(atomicWrite))
|
||||||
await fs.promises.rename(atomicWrite, filePath)
|
await fs.promises.rename(atomicWrite, filePath)
|
||||||
} catch (err) {
|
} catch (err) {
|
||||||
try {
|
try {
|
||||||
|
|||||||
@@ -16,6 +16,7 @@
|
|||||||
"lint:fix": "eslint --fix ."
|
"lint:fix": "eslint --fix ."
|
||||||
},
|
},
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
|
"@overleaf/fetch-utils": "*",
|
||||||
"@overleaf/logger": "*",
|
"@overleaf/logger": "*",
|
||||||
"@overleaf/metrics": "*",
|
"@overleaf/metrics": "*",
|
||||||
"@overleaf/o-error": "*",
|
"@overleaf/o-error": "*",
|
||||||
@@ -29,7 +30,6 @@
|
|||||||
"fs-extra": "^10.0.0",
|
"fs-extra": "^10.0.0",
|
||||||
"lockfile": "^1.0.4",
|
"lockfile": "^1.0.4",
|
||||||
"lodash": "^4.17.21",
|
"lodash": "^4.17.21",
|
||||||
"node-fetch": "^2.6.7",
|
|
||||||
"p-limit": "^3.1.0",
|
"p-limit": "^3.1.0",
|
||||||
"request": "^2.88.2",
|
"request": "^2.88.2",
|
||||||
"send": "^0.17.1",
|
"send": "^0.17.1",
|
||||||
@@ -40,6 +40,7 @@
|
|||||||
"chai-as-promised": "^7.1.1",
|
"chai-as-promised": "^7.1.1",
|
||||||
"mocha": "^10.2.0",
|
"mocha": "^10.2.0",
|
||||||
"mock-fs": "^5.1.2",
|
"mock-fs": "^5.1.2",
|
||||||
|
"node-fetch": "^2.6.7",
|
||||||
"sandboxed-module": "^2.0.4",
|
"sandboxed-module": "^2.0.4",
|
||||||
"sinon": "~9.0.1",
|
"sinon": "~9.0.1",
|
||||||
"sinon-chai": "^3.7.0",
|
"sinon-chai": "^3.7.0",
|
||||||
|
|||||||
Reference in New Issue
Block a user