Refactor avatar upload control flow

This commit is contained in:
ekzyis 2023-11-01 18:36:01 +01:00
parent ecd1dca361
commit f523c9b55d

View File

@ -21,30 +21,38 @@ export default {
throw new GraphQLError(`image must be less than ${IMAGE_PIXELS_MAX} pixels`, { extensions: { code: 'BAD_INPUT' } }) throw new GraphQLError(`image must be less than ${IMAGE_PIXELS_MAX} pixels`, { extensions: { code: 'BAD_INPUT' } })
} }
const { photoId } = me ? await models.user.findUnique({ where: { id: me.id } }) : {} const imgParams = {
const data = {
type, type,
size, size,
width, width,
height, height,
userId: me?.id || ANON_USER_ID, userId: me?.id || ANON_USER_ID
// avatar uploads are always free
paid: avatar && !!me ? undefined : false
} }
let uploadId if (avatar) {
// avatar uploads overwrite the previous avatar if (!me) throw new GraphQLError('you must be logged in', { extensions: { code: 'FORBIDDEN' } })
if (avatar && photoId) uploadId = photoId return avatarGetSignedPOST({ me, models, imgParams })
if (uploadId) {
await models.upload.update({ data, where: { id: uploadId } })
} else {
const upload = await models.upload.create({ data })
uploadId = upload.id
} }
// get presigned POST url const upload = await models.upload.create({ data: { ...imgParams, paid: false } })
return createPresignedPost({ key: String(uploadId), type, size }) return createPresignedPost({ key: String(upload.id), type, size })
} }
} }
} }
async function avatarGetSignedPOST ({ me, models, imgParams }) {
// avatar uploads are always free
imgParams.paid = undefined
const { photoId } = await models.user.findUnique({ where: { id: me.id } })
let uploadId
if (photoId) {
await models.upload.update({ data: imgParams, where: { id: photoId } })
uploadId = photoId
} else {
const upload = await models.upload.create({ data: imgParams })
uploadId = upload.id
}
return createPresignedPost({ key: String(uploadId), type: imgParams.type, size: imgParams.size })
}