Fix image deletion batch size (#769)

This commit is contained in:
ekzyis 2024-01-28 19:29:56 +01:00 committed by GitHub
parent e4aff5d11b
commit 4bc0a930b3
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
2 changed files with 30 additions and 10 deletions

View File

@ -24,14 +24,29 @@ export function createPresignedPost ({ key, type, size }) {
})
}
export function deleteObjects (keys) {
export async function deleteObjects (keys) {
const s3 = new AWS.S3({ apiVersion: '2006-03-01' })
return new Promise((resolve, reject) => {
s3.deleteObjects({
// max 1000 keys per request
// see https://docs.aws.amazon.com/cli/latest/reference/s3api/delete-objects.html
const batchSize = 1000
const deleted = []
for (let i = 0; i < keys.length; i += batchSize) {
const batch = keys.slice(i, i + batchSize)
await new Promise((resolve, reject) => {
const params = {
Bucket,
Delete: {
Objects: keys.map(key => ({ Key: String(key) }))
Objects: batch.map(key => ({ Key: String(key) }))
}
}, (err, data) => { err ? reject(err) : resolve(keys) })
}
s3.deleteObjects(params, (err, data) => {
if (err) return reject(err)
const deleted = data.Deleted?.map(({ Key }) => parseInt(Key)) || []
resolve(deleted)
})
}).then((deleteConfirmed) => {
deleted.push(...deleteConfirmed)
}).catch(console.error)
}
return deleted
}

View File

@ -17,7 +17,12 @@ export async function deleteUnusedImages ({ models }) {
AND created_at < date_trunc('hour', now() - CASE WHEN "userId" = ${ANON_USER_ID} THEN interval '1 hour' ELSE interval '24 hours' END)`
const s3Keys = unpaidImages.map(({ id }) => id)
console.log('deleting images:', s3Keys)
await deleteObjects(s3Keys)
await models.upload.deleteMany({ where: { id: { in: s3Keys } } })
if (s3Keys.length === 0) {
console.log('no images to delete.')
return
}
console.log('deleting images:', s3Keys)
const deleted = await deleteObjects(s3Keys)
console.log('deleted images:', deleted)
await models.upload.deleteMany({ where: { id: { in: deleted } } })
}