Skip to content

Commit

Permalink
web-fix: Uploading big files like an objects, closes #125
Browse files Browse the repository at this point in the history
Signed-off-by: Mikhail Petrov <[email protected]>
  • Loading branch information
mike-petrov committed Feb 1, 2024
1 parent b6499d1 commit 7b17981
Show file tree
Hide file tree
Showing 2 changed files with 28 additions and 37 deletions.
59 changes: 23 additions & 36 deletions src/App.js
Original file line number Diff line number Diff line change
Expand Up @@ -52,7 +52,7 @@ export const App = () => {
});
const [objectForm, setObjectForm] = useState({
name: '',
base64file: '',
file: '',
loading: false,
});
const [presets] = useState({
Expand Down Expand Up @@ -372,31 +372,18 @@ export const App = () => {
};

const onHandleObject = (e) => {
setObjectForm({
name: '',
base64file: '',
loading: true,
});
const file = e.target.files;
if (file.length > 0) {
const reader = new FileReader();
reader.readAsDataURL(file[0]);
reader.onload = () => {
const base64file = reader.result;
setObjectForm({
name: file[0].name,
base64file,
loading: false,
});
};
reader.onerror = (error) => {
onModal('failed', error);
document.getElementById('upload').value = '';
};
if (file.length > 0) {
setObjectForm({
name: file[0].name,
file: e.target.files[0],
loading: false,
});
} else {
document.getElementById('upload').value = '';
setObjectForm({
name: '',
base64file: '',
file: '',
loading: false,
});
}
Expand All @@ -407,17 +394,17 @@ export const App = () => {
if (attributes.every((attribute) => attribute.key.length > 0 && attribute.value.length > 0)) {
setError({ active: false, type: [], text: '' });
setLoadingForm(true);
api('PUT', '/objects?walletConnect=true', {
"containerId": containerId,
"fileName": objectForm.name,
"payload": objectForm.base64file.split('base64,')[1],
"attributes": attributes,
}, {
[ContentTypeHeader]: "application/json",
[AuthorizationHeader]: `Bearer ${walletData.tokens.object.PUT.token}`,
[BearerOwnerIdHeader]: walletData.account,
[BearerSignatureHeader]: walletData.tokens.object.PUT.signature,
[BearerSignatureKeyHeader]: walletData.publicKey,

let formdata = new FormData();
formdata.append('data', objectForm.file);
formdata.append('name', objectForm.name);

const attributesHeaders = {};
attributes.map((attribute) => attributesHeaders[`X-Attribute-${attribute.key}`] = attribute.value);
api('POST', `/upload/${containerId}`, formdata, {
'Content-Type': "multipart/form-data",
[AuthorizationHeader]: `Bearer ${walletData.tokens.object.PUT.bearer}`,
...attributesHeaders,
}).then((e) => {
setLoadingForm(false);
if (e.message && e.message.indexOf('access to object operation denied') !== -1) {
Expand All @@ -430,7 +417,7 @@ export const App = () => {
setAttributes([]);
setObjectForm({
name: '',
base64file: '',
file: '',
loading: false,
});
}
Expand Down Expand Up @@ -1060,7 +1047,7 @@ export const App = () => {
setError({ active: false, type: [], text: '' });
setObjectForm({
name: '',
base64file: '',
file: '',
loading: false,
});
}}
Expand All @@ -1075,7 +1062,7 @@ export const App = () => {
setError({ active: false, type: [], text: '' });
setObjectForm({
name: '',
base64file: '',
file: '',
loading: false,
});
}}
Expand Down
6 changes: 5 additions & 1 deletion src/api.js
Original file line number Diff line number Diff line change
Expand Up @@ -6,8 +6,12 @@ async function serverRequest(method, url, params, headers) {
method,
headers,
}
if (Object.keys(params).length > 0) {
if (json['headers']['Content-Type'] === 'multipart/form-data') {
json['body'] = params;
delete json['headers']['Content-Type'];
} else if (Object.keys(params).length > 0) {
json['body'] = JSON.stringify(params);
json['headers']['Content-Type'] = 'application/json';
}
let activeUrl = `${rest_gw}${url}`;
if (url.indexOf('http') !== -1) {
Expand Down

0 comments on commit 7b17981

Please sign in to comment.