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

@@ -1,7 +1,7 @@
import { useToast } from '@/hooks/useToast' import { useToast } from '@/hooks/useToast'
import { Button, ButtonProps, chakra } from '@chakra-ui/react' import { Button, ButtonProps, chakra } from '@chakra-ui/react'
import { ChangeEvent, useState } from 'react' import { ChangeEvent, useState } from 'react'
import { uploadFiles } from '@typebot.io/lib/uploadFiles' import { uploadFiles } from '@typebot.io/lib/s3/uploadFiles'
import { compressFile } from '@/helpers/compressFile' import { compressFile } from '@/helpers/compressFile'
type UploadButtonProps = { type UploadButtonProps = {

View File

@@ -2,10 +2,10 @@ import { NextApiRequest, NextApiResponse } from 'next'
import { getAuthenticatedUser } from '@/features/auth/helpers/getAuthenticatedUser' import { getAuthenticatedUser } from '@/features/auth/helpers/getAuthenticatedUser'
import { import {
badRequest, badRequest,
generatePresignedUrl,
methodNotAllowed, methodNotAllowed,
notAuthenticated, notAuthenticated,
} from '@typebot.io/lib/api' } from '@typebot.io/lib/api'
import { generatePresignedUrl } from '@typebot.io/lib/s3/generatePresignedUrl'
import { env } from '@typebot.io/env' import { env } from '@typebot.io/env'
const handler = async ( const handler = async (

View File

@@ -10,7 +10,7 @@ import {
} from '@typebot.io/schemas' } from '@typebot.io/schemas'
import { byId, isDefined } from '@typebot.io/lib' import { byId, isDefined } from '@typebot.io/lib'
import { z } from 'zod' import { z } from 'zod'
import { generatePresignedUrl } from '@typebot.io/lib/api/generatePresignedUrl' import { generatePresignedUrl } from '@typebot.io/lib/s3/generatePresignedUrl'
import { env } from '@typebot.io/env' import { env } from '@typebot.io/env'
export const getUploadUrl = publicProcedure export const getUploadUrl = publicProcedure

View File

@@ -1,6 +1,6 @@
import got from 'got' import got from 'got'
import { TRPCError } from '@trpc/server' import { TRPCError } from '@trpc/server'
import { uploadFileToBucket } from '@typebot.io/lib/api/uploadFileToBucket' import { uploadFileToBucket } from '@typebot.io/lib/s3/uploadFileToBucket'
type Props = { type Props = {
mediaId: string mediaId: string

View File

@@ -4,7 +4,7 @@ import { useTypebot } from '@/providers/TypebotProvider'
import { InputSubmitContent } from '@/types' import { InputSubmitContent } from '@/types'
import { defaultFileInputOptions, FileInputBlock } from '@typebot.io/schemas' import { defaultFileInputOptions, FileInputBlock } from '@typebot.io/schemas'
import React, { ChangeEvent, FormEvent, useState, DragEvent } from 'react' 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 = { type Props = {
block: FileInputBlock block: FileInputBlock

View File

@@ -4,7 +4,7 @@ import { guessApiHost } from '@/utils/guessApiHost'
import { FileInputBlock } from '@typebot.io/schemas' import { FileInputBlock } from '@typebot.io/schemas'
import { defaultFileInputOptions } from '@typebot.io/schemas/features/blocks/inputs/file' import { defaultFileInputOptions } from '@typebot.io/schemas/features/blocks/inputs/file'
import { createSignal, Match, Show, Switch } from 'solid-js' 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 { Button } from '@/components/Button'
import { Spinner } from '@/components/Spinner' 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 { Prisma, PrismaClient } from '@typebot.io/prisma'
import { InputBlockType, Typebot } from '@typebot.io/schemas' import { InputBlockType, Typebot } from '@typebot.io/schemas'
import { Client } from 'minio' import { deleteFilesFromBucket } from '../../s3/deleteFilesFromBucket'
type ArchiveResultsProps = { type ArchiveResultsProps = {
typebot: Pick<Typebot, 'groups'> typebot: Pick<Typebot, 'groups'>
@@ -90,32 +89,3 @@ export const archiveResults =
return { success: true } 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 './utils'
export * from './generatePresignedUrl'
export * from './encryption' export * from './encryption'

View File

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

View File

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