♻️ Move s3-related files to specific lib folder
This commit is contained in:
@ -1,7 +1,7 @@
|
||||
import { useToast } from '@/hooks/useToast'
|
||||
import { Button, ButtonProps, chakra } from '@chakra-ui/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'
|
||||
|
||||
type UploadButtonProps = {
|
||||
|
@ -2,10 +2,10 @@ import { NextApiRequest, NextApiResponse } from 'next'
|
||||
import { getAuthenticatedUser } from '@/features/auth/helpers/getAuthenticatedUser'
|
||||
import {
|
||||
badRequest,
|
||||
generatePresignedUrl,
|
||||
methodNotAllowed,
|
||||
notAuthenticated,
|
||||
} from '@typebot.io/lib/api'
|
||||
import { generatePresignedUrl } from '@typebot.io/lib/s3/generatePresignedUrl'
|
||||
import { env } from '@typebot.io/env'
|
||||
|
||||
const handler = async (
|
||||
|
@ -10,7 +10,7 @@ import {
|
||||
} from '@typebot.io/schemas'
|
||||
import { byId, isDefined } from '@typebot.io/lib'
|
||||
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'
|
||||
|
||||
export const getUploadUrl = publicProcedure
|
||||
|
@ -1,6 +1,6 @@
|
||||
import got from 'got'
|
||||
import { TRPCError } from '@trpc/server'
|
||||
import { uploadFileToBucket } from '@typebot.io/lib/api/uploadFileToBucket'
|
||||
import { uploadFileToBucket } from '@typebot.io/lib/s3/uploadFileToBucket'
|
||||
|
||||
type Props = {
|
||||
mediaId: string
|
||||
|
@ -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
|
||||
|
@ -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'
|
||||
|
||||
|
@ -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])
|
||||
)
|
||||
}
|
||||
|
@ -1,3 +1,2 @@
|
||||
export * from './utils'
|
||||
export * from './generatePresignedUrl'
|
||||
export * from './encryption'
|
||||
|
@ -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,
|
@ -1,4 +1,4 @@
|
||||
import { sendRequest } from './utils'
|
||||
import { sendRequest } from '../utils'
|
||||
|
||||
type UploadFileProps = {
|
||||
basePath?: string
|
Reference in New Issue
Block a user