48 lines
1.3 KiB
JavaScript
48 lines
1.3 KiB
JavaScript
import uuid from 'uuid';
|
|
import Router from 'koa-router';
|
|
|
|
import { makePolicy, signPolicy } from '../utils/s3';
|
|
import auth from './middlewares/authentication';
|
|
import { presentUser } from '../presenters';
|
|
|
|
const router = new Router();
|
|
|
|
router.post('user.info', auth(), async ctx => {
|
|
ctx.body = { data: await presentUser(ctx, ctx.state.user) };
|
|
});
|
|
|
|
router.post('user.s3Upload', auth(), async ctx => {
|
|
const { filename, kind, size } = ctx.body;
|
|
ctx.assertPresent(filename, 'filename is required');
|
|
ctx.assertPresent(kind, 'kind is required');
|
|
ctx.assertPresent(size, 'size is required');
|
|
|
|
const s3Key = uuid.v4();
|
|
const key = `${s3Key}/${filename}`;
|
|
const policy = makePolicy();
|
|
|
|
ctx.body = {
|
|
data: {
|
|
maxUploadSize: process.env.AWS_S3_UPLOAD_MAX_SIZE,
|
|
uploadUrl: process.env.AWS_S3_UPLOAD_BUCKET_URL,
|
|
form: {
|
|
AWSAccessKeyId: process.env.AWS_ACCESS_KEY_ID,
|
|
'Cache-Control': 'max-age=31557600',
|
|
'Content-Type': kind,
|
|
key,
|
|
acl: 'public-read',
|
|
signature: signPolicy(policy),
|
|
policy,
|
|
},
|
|
asset: {
|
|
contentType: kind,
|
|
url: `${process.env.AWS_S3_UPLOAD_BUCKET_URL}${s3Key}/${filename}`,
|
|
name: filename,
|
|
size,
|
|
},
|
|
},
|
|
};
|
|
});
|
|
|
|
export default router;
|