52 lines
1.3 KiB
TypeScript
52 lines
1.3 KiB
TypeScript
![]() |
import { config, Endpoint, S3 } from 'aws-sdk'
|
||
|
|
||
|
type GeneratePresignedUrlProps = {
|
||
|
filePath: string
|
||
|
fileType: string
|
||
|
}
|
||
|
|
||
|
const tenMB = 10485760
|
||
|
const oneHundredAndTwentySeconds = 120
|
||
|
|
||
|
export const generatePresignedUrl = ({
|
||
|
filePath,
|
||
|
fileType,
|
||
|
}: GeneratePresignedUrlProps): S3.PresignedPost => {
|
||
|
if (
|
||
|
!process.env.S3_ENDPOINT ||
|
||
|
!process.env.S3_ACCESS_KEY ||
|
||
|
!process.env.S3_SECRET_KEY
|
||
|
)
|
||
|
throw new Error(
|
||
|
'S3 not properly configured. Missing one of those variables: S3_ENDPOINT, S3_ACCESS_KEY, S3_SECRET_KEY'
|
||
|
)
|
||
|
|
||
|
const sslEnabled =
|
||
|
process.env.S3_SSL && process.env.S3_SSL === 'false' ? false : true
|
||
|
config.update({
|
||
|
accessKeyId: process.env.S3_ACCESS_KEY,
|
||
|
secretAccessKey: process.env.S3_SECRET_KEY,
|
||
|
region: process.env.S3_REGION,
|
||
|
sslEnabled,
|
||
|
})
|
||
|
const protocol = sslEnabled ? 'https' : 'http'
|
||
|
const s3 = new S3({
|
||
|
endpoint: new Endpoint(
|
||
|
`${protocol}://${process.env.S3_ENDPOINT}${
|
||
|
process.env.S3_PORT ? `:${process.env.S3_PORT}` : ''
|
||
|
}`
|
||
|
),
|
||
|
})
|
||
|
|
||
|
const presignedUrl = s3.createPresignedPost({
|
||
|
Bucket: process.env.S3_BUCKET ?? 'typebot',
|
||
|
Fields: {
|
||
|
key: filePath,
|
||
|
'Content-Type': fileType,
|
||
|
},
|
||
|
Expires: oneHundredAndTwentySeconds,
|
||
|
Conditions: [['content-length-range', 0, tenMB]],
|
||
|
})
|
||
|
return presignedUrl
|
||
|
}
|