mirror of
https://github.com/Dokploy/dokploy.git
synced 2026-06-24 08:35:26 +02:00
- Implemented `HandleSchedules` component for creating and updating schedules with validation. - Added `ShowSchedules` component to display a list of schedules with options to edit and delete. - Created API routes for schedule management including create, update, delete, and list functionalities. - Defined the `schedule` table schema in the database with necessary fields and relationships. - Integrated schedule management into the application service dashboard, allowing users to manage schedules directly from the UI.
39 lines
1.1 KiB
TypeScript
39 lines
1.1 KiB
TypeScript
import { relations } from "drizzle-orm";
|
|
import { pgTable, text } from "drizzle-orm/pg-core";
|
|
import { createInsertSchema } from "drizzle-zod";
|
|
import { nanoid } from "nanoid";
|
|
import { z } from "zod";
|
|
import { applications } from "./application";
|
|
|
|
export const schedules = pgTable("schedule", {
|
|
scheduleId: text("scheduleId")
|
|
.notNull()
|
|
.primaryKey()
|
|
.$defaultFn(() => nanoid()),
|
|
name: text("name").notNull(),
|
|
cronExpression: text("cronExpression").notNull(),
|
|
command: text("command").notNull(),
|
|
applicationId: text("applicationId")
|
|
.notNull()
|
|
.references(() => applications.applicationId, {
|
|
onDelete: "cascade",
|
|
}),
|
|
createdAt: text("createdAt")
|
|
.notNull()
|
|
.$defaultFn(() => new Date().toISOString()),
|
|
});
|
|
|
|
export const schedulesRelations = relations(schedules, ({ one }) => ({
|
|
application: one(applications, {
|
|
fields: [schedules.applicationId],
|
|
references: [applications.applicationId],
|
|
}),
|
|
}));
|
|
|
|
export const createScheduleSchema = createInsertSchema(schedules, {
|
|
name: z.string().min(1),
|
|
cronExpression: z.string().min(1),
|
|
command: z.string().min(1),
|
|
applicationId: z.string().min(1),
|
|
});
|