lbry-desktop/web/setup/publish.js

105 lines
3.3 KiB
JavaScript
Raw Normal View History

2019-02-22 00:01:59 -05:00
// @flow
/*
https://api.na-backend.odysee.com/api/v1/proxy currently expects publish to consist
of a multipart/form-data POST request with:
- 'file' binary
- 'json_payload' collection of publish params to be passed to the server's sdk.
*/
2019-11-07 14:39:22 -05:00
import { X_LBRY_AUTH_TOKEN } from '../../ui/constants/token';
import { doUpdateUploadProgress } from 'lbryinc';
2019-02-22 00:01:59 -05:00
// A modified version of Lbry.apiCall that allows
// to perform calling methods at arbitrary urls
// and pass form file fields
2019-09-30 16:11:45 -04:00
export default function apiPublishCallViaWeb(
2020-04-20 22:41:01 -07:00
apiCall: (any, any, any, any) => any,
2019-02-22 00:01:59 -05:00
connectionString: string,
2019-09-30 16:11:45 -04:00
token: string,
2019-02-22 00:01:59 -05:00
method: string,
2021-03-26 17:03:52 -04:00
params: { file_path: string, preview: boolean, remote_url?: string }, // new param for remoteUrl
2019-02-22 00:01:59 -05:00
resolve: Function,
reject: Function
) {
2021-03-26 17:03:52 -04:00
const { file_path: filePath, preview, remote_url: remoteUrl } = params;
2019-11-04 10:16:56 -05:00
2021-03-26 17:03:52 -04:00
if (!filePath && !remoteUrl) {
2019-11-04 10:16:56 -05:00
return apiCall(method, params, resolve, reject);
}
2019-02-22 00:01:59 -05:00
const counter = new Date().getTime();
let fileField = filePath;
if (preview) {
// Send dummy file for the preview. The tx-fee calculation does not depend on it.
const dummyContent = 'x';
fileField = new File([dummyContent], 'dummy.md', { type: 'text/markdown' });
}
2019-11-04 10:16:56 -05:00
2019-02-22 00:01:59 -05:00
// Putting a dummy value here, the server is going to process the POSTed file
// and set the file_path itself
2021-03-26 17:03:52 -04:00
const body = new FormData();
if (fileField) {
body.append('file', fileField);
params.file_path = '__POST_FILE__';
delete params['remote_url'];
2021-03-26 17:03:52 -04:00
} else if (remoteUrl) {
body.append('remote_url', remoteUrl);
delete params['remote_url'];
2021-03-26 17:03:52 -04:00
}
2019-11-04 10:16:56 -05:00
2019-02-22 00:01:59 -05:00
const jsonPayload = JSON.stringify({
jsonrpc: '2.0',
method,
params,
id: counter,
});
2021-03-26 17:03:52 -04:00
// no fileData? do the livestream remote publish
2019-02-22 00:01:59 -05:00
body.append('json_payload', jsonPayload);
function makeRequest(connectionString, method, token, body, params) {
return new Promise((resolve, reject) => {
let xhr = new XMLHttpRequest();
xhr.open(method, connectionString);
xhr.setRequestHeader(X_LBRY_AUTH_TOKEN, token);
xhr.responseType = 'json';
2021-03-26 17:03:52 -04:00
xhr.upload.onprogress = (e) => {
let percentComplete = Math.ceil((e.loaded / e.total) * 100);
window.store.dispatch(doUpdateUploadProgress(percentComplete, params, xhr));
};
xhr.onload = () => {
window.store.dispatch(doUpdateUploadProgress(undefined, params));
resolve(xhr);
};
xhr.onerror = () => {
window.store.dispatch(doUpdateUploadProgress(undefined, params));
2021-01-08 16:38:01 -05:00
reject(new Error(__('There was a problem with your upload. Please try again.')));
};
xhr.onabort = () => {
window.store.dispatch(doUpdateUploadProgress(undefined, params));
};
xhr.send(body);
});
}
return makeRequest(connectionString, 'POST', token, body, params)
2021-03-26 17:03:52 -04:00
.then((xhr) => {
let error;
if (xhr && xhr.response) {
if (xhr.status >= 200 && xhr.status < 300 && !xhr.response.error) {
return resolve(xhr.response.result);
} else if (xhr.response.error) {
error = new Error(xhr.response.error.message);
} else {
error = new Error(__('Upload likely timed out. Try a smaller file while we work on this.'));
}
}
2019-02-22 00:01:59 -05:00
if (error) {
return Promise.reject(error);
2019-02-22 00:01:59 -05:00
}
})
.catch(reject);
}