2
0

🗃️ Remove updatedAt field from Result

This commit is contained in:
Baptiste Arnaud
2023-03-07 15:51:44 +01:00
parent b77e2c8d2c
commit 2788d58e50
6 changed files with 41 additions and 8 deletions

View File

@ -1133,10 +1133,6 @@
"type": "string",
"format": "date-time"
},
"updatedAt": {
"type": "string",
"format": "date-time"
},
"typebotId": {
"type": "string"
},
@ -1188,7 +1184,6 @@
"required": [
"id",
"createdAt",
"updatedAt",
"typebotId",
"variables",
"isCompleted",

View File

@ -242,7 +242,6 @@ model PublicTypebot {
model Result {
id String @id @default(cuid())
createdAt DateTime @default(now())
updatedAt DateTime @default(now()) @updatedAt
typebotId String
variables Json
isCompleted Boolean

View File

@ -0,0 +1,2 @@
-- AlterTable
ALTER TABLE "Result" DROP COLUMN "updatedAt";

View File

@ -223,7 +223,6 @@ model PublicTypebot {
model Result {
id String @id @default(cuid())
createdAt DateTime @default(now())
updatedAt DateTime @default(now()) @updatedAt
typebotId String
variables Json
isCompleted Boolean

View File

@ -9,7 +9,6 @@ export const resultSchema = schemaForType<ResultPrisma>()(
z.object({
id: z.string(),
createdAt: z.date(),
updatedAt: z.date(),
typebotId: z.string(),
variables: z.array(variableWithValueSchema),
isCompleted: z.boolean(),

View File

@ -10,9 +10,48 @@ export const cleanDatabase = async () => {
await deleteOldChatSessions()
await deleteExpiredAppSessions()
await deleteExpiredVerificationTokens()
const isFirstOfMonth = new Date().getDate() === 1
if (isFirstOfMonth) {
await deleteArchivedTypebots()
await deleteArchivedResults()
}
console.log('Done!')
}
const deleteArchivedTypebots = async () => {
const lastDayOfPreviousMonth = new Date()
lastDayOfPreviousMonth.setMonth(lastDayOfPreviousMonth.getMonth() - 1)
lastDayOfPreviousMonth.setDate(0)
const { count } = await prisma.typebot.deleteMany({
where: {
updatedAt: {
lte: lastDayOfPreviousMonth,
},
isArchived: true,
},
})
console.log(`Deleted ${count} archived typebots.`)
}
const deleteArchivedResults = async () => {
const lastDayOfPreviousMonth = new Date()
lastDayOfPreviousMonth.setMonth(lastDayOfPreviousMonth.getMonth() - 1)
lastDayOfPreviousMonth.setDate(0)
const { count } = await prisma.result.deleteMany({
where: {
createdAt: {
lte: lastDayOfPreviousMonth,
},
isArchived: true,
},
})
console.log(`Deleted ${count} archived results.`)
}
const deleteOldChatSessions = async () => {
const threeDaysAgo = new Date()
threeDaysAgo.setDate(threeDaysAgo.getDate() - 3)