This repository has been archived on 2022-08-14. You can view files and clone it, but cannot push or open issues or pull requests.
Files
outline/app/utils/uploadFile.js
Huss 8e2b19dc7a feat: private content (#1137)
* 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>
2020-02-12 19:40:44 -08:00

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;
};