|
@@ -1,4 +1,4 @@
|
|
|
-const NetworkError = require('@uppy/utils/lib/NetworkError')
|
|
|
+const fetchWithNetworkError = require('@uppy/utils/lib/fetchWithNetworkError')
|
|
|
|
|
|
/**
|
|
|
* A Barebones HTTP API client for Transloadit.
|
|
@@ -40,18 +40,11 @@ module.exports = class Client {
|
|
|
data.append('num_expected_upload_files', expectedFiles)
|
|
|
|
|
|
const url = `${this.opts.service}/assemblies`
|
|
|
- return fetch(url, {
|
|
|
+ return fetchWithNetworkError(url, {
|
|
|
method: 'post',
|
|
|
headers: this._headers,
|
|
|
body: data
|
|
|
})
|
|
|
- .catch((err) => {
|
|
|
- if (err.name === 'AbortError') {
|
|
|
- throw err
|
|
|
- } else {
|
|
|
- throw new NetworkError(err)
|
|
|
- }
|
|
|
- })
|
|
|
.then((response) => response.json()).then((assembly) => {
|
|
|
if (assembly.error) {
|
|
|
const error = new Error(assembly.error)
|
|
@@ -77,14 +70,7 @@ module.exports = class Client {
|
|
|
reserveFile (assembly, file) {
|
|
|
const size = encodeURIComponent(file.size)
|
|
|
const url = `${assembly.assembly_ssl_url}/reserve_file?size=${size}`
|
|
|
- return fetch(url, { method: 'post', headers: this._headers })
|
|
|
- .catch((err) => {
|
|
|
- if (err.name === 'AbortError') {
|
|
|
- throw err
|
|
|
- } else {
|
|
|
- throw new NetworkError(err)
|
|
|
- }
|
|
|
- })
|
|
|
+ return fetchWithNetworkError(url, { method: 'post', headers: this._headers })
|
|
|
.then((response) => response.json())
|
|
|
.catch((err) => this._reportError(err, { assembly, file, url, type: 'API_ERROR' }))
|
|
|
}
|
|
@@ -106,14 +92,7 @@ module.exports = class Client {
|
|
|
|
|
|
const qs = `size=${size}&filename=${filename}&fieldname=${fieldname}&s3Url=${uploadUrl}`
|
|
|
const url = `${assembly.assembly_ssl_url}/add_file?${qs}`
|
|
|
- return fetch(url, { method: 'post', headers: this._headers })
|
|
|
- .catch((err) => {
|
|
|
- if (err.name === 'AbortError') {
|
|
|
- throw err
|
|
|
- } else {
|
|
|
- throw new NetworkError(err)
|
|
|
- }
|
|
|
- })
|
|
|
+ return fetchWithNetworkError(url, { method: 'post', headers: this._headers })
|
|
|
.then((response) => response.json())
|
|
|
.catch((err) => this._reportError(err, { assembly, file, url, type: 'API_ERROR' }))
|
|
|
}
|
|
@@ -125,14 +104,7 @@ module.exports = class Client {
|
|
|
*/
|
|
|
cancelAssembly (assembly) {
|
|
|
const url = assembly.assembly_ssl_url
|
|
|
- return fetch(url, { method: 'delete', headers: this._headers })
|
|
|
- .catch((err) => {
|
|
|
- if (err.name === 'AbortError') {
|
|
|
- throw err
|
|
|
- } else {
|
|
|
- throw new NetworkError(err)
|
|
|
- }
|
|
|
- })
|
|
|
+ return fetchWithNetworkError(url, { method: 'delete', headers: this._headers })
|
|
|
.then((response) => response.json())
|
|
|
.catch((err) => this._reportError(err, { url, type: 'API_ERROR' }))
|
|
|
}
|
|
@@ -143,14 +115,7 @@ module.exports = class Client {
|
|
|
* @param {string} url The status endpoint of the assembly.
|
|
|
*/
|
|
|
getAssemblyStatus (url) {
|
|
|
- return fetch(url, { headers: this._headers })
|
|
|
- .catch((err) => {
|
|
|
- if (err.name === 'AbortError') {
|
|
|
- throw err
|
|
|
- } else {
|
|
|
- throw new NetworkError(err)
|
|
|
- }
|
|
|
- })
|
|
|
+ return fetchWithNetworkError(url, { headers: this._headers })
|
|
|
.then((response) => response.json())
|
|
|
.catch((err) => this._reportError(err, { url, type: 'STATUS_ERROR' }))
|
|
|
}
|
|
@@ -160,7 +125,7 @@ module.exports = class Client {
|
|
|
? `${err.message} (${err.details})`
|
|
|
: err.message
|
|
|
|
|
|
- return fetch('https://status.transloadit.com/client_error', {
|
|
|
+ return fetchWithNetworkError('https://status.transloadit.com/client_error', {
|
|
|
method: 'post',
|
|
|
body: JSON.stringify({
|
|
|
endpoint,
|
|
@@ -171,13 +136,6 @@ module.exports = class Client {
|
|
|
error: message
|
|
|
})
|
|
|
})
|
|
|
- .catch((err) => {
|
|
|
- if (err.name === 'AbortError') {
|
|
|
- throw err
|
|
|
- } else {
|
|
|
- throw new NetworkError(err)
|
|
|
- }
|
|
|
- })
|
|
|
.then((response) => response.json())
|
|
|
}
|
|
|
|