♻️ Move s3-related files to specific lib folder
This commit is contained in:
@@ -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 = {
|
||||||
|
|||||||
@@ -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 (
|
||||||
|
|||||||
@@ -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
|
||||||
|
|||||||
@@ -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
|
||||||
|
|||||||
@@ -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
|
||||||
|
|||||||
@@ -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'
|
||||||
|
|
||||||
|
|||||||
@@ -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])
|
|
||||||
)
|
|
||||||
}
|
|
||||||
|
|||||||
@@ -1,3 +1,2 @@
|
|||||||
export * from './utils'
|
export * from './utils'
|
||||||
export * from './generatePresignedUrl'
|
|
||||||
export * from './encryption'
|
export * from './encryption'
|
||||||
|
|||||||
@@ -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,
|
||||||
@@ -1,4 +1,4 @@
|
|||||||
import { sendRequest } from './utils'
|
import { sendRequest } from '../utils'
|
||||||
|
|
||||||
type UploadFileProps = {
|
type UploadFileProps = {
|
||||||
basePath?: string
|
basePath?: string
|
||||||
Reference in New Issue
Block a user