2
0

♻️ Move s3-related files to specific lib folder

This commit is contained in:
Baptiste Arnaud
2023-08-30 09:36:45 +02:00
parent 9a79bc38ee
commit 23b629f82c
12 changed files with 9 additions and 40 deletions

View File

@@ -4,7 +4,7 @@ import { useTypebot } from '@/providers/TypebotProvider'
import { InputSubmitContent } from '@/types'
import { defaultFileInputOptions, FileInputBlock } from '@typebot.io/schemas'
import React, { ChangeEvent, FormEvent, useState, DragEvent } from 'react'
import { uploadFiles } from '@typebot.io/lib/uploadFiles'
import { uploadFiles } from '@typebot.io/lib/s3/uploadFiles'
type Props = {
block: FileInputBlock

View File

@@ -4,7 +4,7 @@ import { guessApiHost } from '@/utils/guessApiHost'
import { FileInputBlock } from '@typebot.io/schemas'
import { defaultFileInputOptions } from '@typebot.io/schemas/features/blocks/inputs/file'
import { createSignal, Match, Show, Switch } from 'solid-js'
import { uploadFiles } from '@typebot.io/lib/uploadFiles'
import { uploadFiles } from '@typebot.io/lib/s3/uploadFiles'
import { Button } from '@/components/Button'
import { Spinner } from '@/components/Spinner'

View File

@@ -1,7 +1,6 @@
import { env } from '@typebot.io/env'
import { Prisma, PrismaClient } from '@typebot.io/prisma'
import { InputBlockType, Typebot } from '@typebot.io/schemas'
import { Client } from 'minio'
import { deleteFilesFromBucket } from '../../s3/deleteFilesFromBucket'
type ArchiveResultsProps = {
typebot: Pick<Typebot, 'groups'>
@@ -90,32 +89,3 @@ export const archiveResults =
return { success: true }
}
const deleteFilesFromBucket = async ({
urls,
}: {
urls: string[]
}): Promise<void> => {
if (!env.S3_ENDPOINT || !env.S3_ACCESS_KEY || !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 minioClient = new Client({
endPoint: env.S3_ENDPOINT,
port: env.S3_PORT,
useSSL: env.S3_SSL ?? true,
accessKey: env.S3_ACCESS_KEY,
secretKey: env.S3_SECRET_KEY,
region: env.S3_REGION,
})
const bucket = env.S3_BUCKET ?? 'typebot'
return minioClient.removeObjects(
bucket,
urls
.filter((url) => url.includes(env.S3_ENDPOINT as string))
.map((url) => url.split(`/${bucket}/`)[1])
)
}

View File

@@ -1,3 +1,2 @@
export * from './utils'
export * from './generatePresignedUrl'
export * from './encryption'

View File

@@ -20,7 +20,7 @@ export const deleteFilesFromBucket = async ({
region: env.S3_REGION,
})
const bucket = env.S3_BUCKET ?? 'typebot'
const bucket = env.S3_BUCKET
return minioClient.removeObjects(
bucket,

View File

@@ -1,4 +1,4 @@
import { sendRequest } from './utils'
import { sendRequest } from '../utils'
type UploadFileProps = {
basePath?: string