* save images as private and serve via signed url from images.info api * download private images to directory on export * fix lint errors * private s3 default, AWS.s3 module level scope, default s3 url expiry * combine regex to one, and only replace when there are matches * fix lint * code not needed anymore, remove * updates after pulling master * revert the uploadToS3FromUrl url return * use model gettr to compact code, rename to attachments api * basic checking of document read permission to allow attachment viewing * fix: Continue to upload avatars as public fix: Allow redirect for non-private attachments * add support for publicly shared documents * catch errors which crash the app during zip export and user creation * add tests * enable AWS signature v4 for s3 * switch to use factories to build models for testing * add isDocker flag for local serving of attachment redirect url * fix redirect tests Co-authored-by: Tom Moor <tom.moor@gmail.com>
59 lines
1.3 KiB
JavaScript
59 lines
1.3 KiB
JavaScript
// @flow
|
|
import { client } from './ApiClient';
|
|
import invariant from 'invariant';
|
|
|
|
type Options = {
|
|
name?: string,
|
|
documentId?: string,
|
|
public?: boolean,
|
|
};
|
|
|
|
export const uploadFile = async (
|
|
file: File | Blob,
|
|
options?: Options = { name: '' }
|
|
) => {
|
|
const name = file instanceof File ? file.name : options.name;
|
|
const response = await client.post('/users.s3Upload', {
|
|
public: options.public,
|
|
documentId: options.documentId,
|
|
contentType: file.type,
|
|
size: file.size,
|
|
name,
|
|
});
|
|
|
|
invariant(response, 'Response should be available');
|
|
|
|
const data = response.data;
|
|
const asset = data.asset;
|
|
const formData = new FormData();
|
|
|
|
for (const key in data.form) {
|
|
formData.append(key, data.form[key]);
|
|
}
|
|
|
|
// $FlowFixMe
|
|
if (file.blob) {
|
|
// $FlowFixMe
|
|
formData.append('file', file.file);
|
|
} else {
|
|
formData.append('file', file);
|
|
}
|
|
|
|
await fetch(data.uploadUrl, {
|
|
method: 'post',
|
|
body: formData,
|
|
});
|
|
|
|
return asset;
|
|
};
|
|
|
|
export const dataUrlToBlob = (dataURL: string) => {
|
|
var blobBin = atob(dataURL.split(',')[1]);
|
|
var array = [];
|
|
for (var i = 0; i < blobBin.length; i++) {
|
|
array.push(blobBin.charCodeAt(i));
|
|
}
|
|
const file = new Blob([new Uint8Array(array)], { type: 'image/png' });
|
|
return file;
|
|
};
|