summaryrefslogtreecommitdiff
path: root/db/schema/logs.ts
diff options
context:
space:
mode:
authordujinkim <dujin.kim@dtsolution.co.kr>2025-04-28 02:13:30 +0000
committerdujinkim <dujin.kim@dtsolution.co.kr>2025-04-28 02:13:30 +0000
commitef4c533ebacc2cdc97e518f30e9a9350004fcdfb (patch)
tree345251a3ed0f4429716fa5edaa31024d8f4cb560 /db/schema/logs.ts
parent9ceed79cf32c896f8a998399bf1b296506b2cd4a (diff)
~20250428 작업사항
Diffstat (limited to 'db/schema/logs.ts')
-rw-r--r--db/schema/logs.ts61
1 files changed, 61 insertions, 0 deletions
diff --git a/db/schema/logs.ts b/db/schema/logs.ts
new file mode 100644
index 00000000..1f402e1f
--- /dev/null
+++ b/db/schema/logs.ts
@@ -0,0 +1,61 @@
+
+import { pgTable, serial, varchar, text, timestamp, boolean, integer ,pgView} from "drizzle-orm/pg-core";
+import { items } from "./items";
+import { sql, eq, relations} from "drizzle-orm";
+import { users } from "./users";
+import { vendorCandidates, vendors } from "./vendors";
+
+
+export const vendorCandidateLogs = pgTable("vendor_candidate_logs", {
+ id: serial("id").primaryKey(),
+
+ // 어떤 vendor candidate에 대한 로그인지
+ vendorCandidateId: integer("vendor_candidate_id")
+ .references(() => vendorCandidates.id, { onDelete: "cascade" })
+ .notNull(),
+
+ // 어떤 user가 한 것인지
+ userId: integer("user_id")
+ .references(() => users.id, { onDelete: "cascade" })
+ .notNull(),
+
+ // 액션(행동) 종류 (예: "status_change", "invite_sent" 등)
+ action: varchar("action", { length: 100 }).notNull(),
+
+ // 상태가 바뀌는 로그라면, 이전/이후 상태를 기록
+ oldStatus: varchar("old_status", { length: 30 }),
+ newStatus: varchar("new_status", { length: 30 }),
+
+ // 기타 필요하면 메시지/설명/메타데이터 등에 대한 컬럼 추가
+ comment: text("comment"), // 변경 사유나 코멘트 등
+
+ createdAt: timestamp("created_at").defaultNow().notNull(),
+ });
+
+
+ export const vendorsLogs = pgTable("vendors_logs", {
+ id: serial("id").primaryKey(),
+
+ // 어떤 vendor candidate에 대한 로그인지
+ vendorId: integer("vendor_id")
+ .references(() => vendors.id, { onDelete: "cascade" })
+ .notNull(),
+
+ // 어떤 user가 한 것인지
+ userId: integer("user_id")
+ .references(() => users.id, { onDelete: "cascade" })
+ .notNull(),
+
+ // 액션(행동) 종류 (예: "status_change", "invite_sent" 등)
+ action: varchar("action", { length: 100 }).notNull(),
+
+ // 상태가 바뀌는 로그라면, 이전/이후 상태를 기록
+ oldStatus: varchar("old_status", { length: 30 }),
+ newStatus: varchar("new_status", { length: 30 }),
+
+ // 기타 필요하면 메시지/설명/메타데이터 등에 대한 컬럼 추가
+ comment: text("comment"), // 변경 사유나 코멘트 등
+
+ createdAt: timestamp("created_at").defaultNow().notNull(),
+ });
+ \ No newline at end of file