2
0

🐛 (fileUpload) Fix files deletion on result delete

This commit is contained in:
Baptiste Arnaud
2024-03-04 11:38:20 +01:00
parent 434b06767d
commit f14eb91d2a
2 changed files with 18 additions and 6 deletions

View File

@ -172,7 +172,7 @@ export const generateUploadUrl = publicProcedure
filePath,
maxFileSize:
fileUploadBlock.options && 'sizeLimit' in fileUploadBlock.options
? fileUploadBlock.options.sizeLimit
? (fileUploadBlock.options.sizeLimit as string)
: env.NEXT_PUBLIC_BOT_FILE_UPLOAD_MAX_SIZE,
})

View File

@ -22,10 +22,22 @@ export const deleteFilesFromBucket = async ({
const bucket = env.S3_BUCKET
return minioClient.removeObjects(
bucket,
urls
.filter((url) => url.includes(env.S3_ENDPOINT as string))
.map((url) => url.split(`/${bucket}/`)[1])
const keys = urls.reduce<string[]>(
(keys, url) => [
...keys,
...addKeyIfIncludesPublicCustomDomain(url),
...addKeyIfIncludesDefaultEndpoint(url, bucket),
],
[]
)
return minioClient.removeObjects(bucket, keys)
}
const addKeyIfIncludesPublicCustomDomain = (url: string) =>
env.S3_PUBLIC_CUSTOM_DOMAIN && url.includes(env.S3_PUBLIC_CUSTOM_DOMAIN)
? [url.split(env.S3_PUBLIC_CUSTOM_DOMAIN + '/')[1]]
: []
const addKeyIfIncludesDefaultEndpoint = (url: string, bucket: string) =>
url.includes(env.S3_ENDPOINT as string) ? [url.split(`/${bucket}/`)[1]] : []