// This is your Prisma schema file, // learn more about it in the docs: https://pris.ly/d/prisma-schema generator client { provider = "prisma-client-js" } datasource db { provider = "postgresql" url = env("DATABASE_URL") } model Taxonomy { id String @id @default(cuid()) name String @unique slug String @unique @map("slug") deletedAt DateTime? @map("deleted_at") createdAt DateTime @default(now()) @map("created_at") terms Term[] objectType String[] @map("object_type") order Float? @map("order") @@index([order, deletedAt]) @@map("taxonomy") } model Term { id String @id @default(cuid()) name String taxonomy Taxonomy? @relation(fields: [taxonomyId], references: [id]) taxonomyId String? @map("taxonomy_id") order Float? @map("order") description String? parentId String? @map("parent_id") parent Term? @relation("ChildParent", fields: [parentId], references: [id], onDelete: Cascade) children Term[] @relation("ChildParent") ancestors TermAncestry[] @relation("DescendantToAncestor") descendants TermAncestry[] @relation("AncestorToDescendant") domainId String? @map("domain_id") domain Department? @relation("TermDom", fields: [domainId], references: [id]) createdAt DateTime @default(now()) @map("created_at") updatedAt DateTime @updatedAt @map("updated_at") deletedAt DateTime? @map("deleted_at") createdBy String? @map("created_by") depts Department[] @relation("department_term") hasChildren Boolean? @default(false) @map("has_children") @@index([name]) // 对name字段建立索引,以加快基于name的查找速度 @@index([parentId]) // 对parentId字段建立索引,以加快基于parentId的查找速度 @@map("term") } model TermAncestry { id String @id @default(cuid()) ancestorId String? @map("ancestor_id") descendantId String @map("descendant_id") relDepth Int @map("rel_depth") ancestor Term? @relation("AncestorToDescendant", fields: [ancestorId], references: [id]) descendant Term @relation("DescendantToAncestor", fields: [descendantId], references: [id]) // 索引建议 @@index([ancestorId]) // 针对祖先的查询 @@index([descendantId]) // 针对后代的查询 @@index([ancestorId, descendantId]) // 组合索引,用于查询特定的祖先-后代关系 @@index([relDepth]) // 根据关系深度的查询 @@map("term_ancestry") } model Staff { id String @id @default(cuid()) showname String? @map("showname") username String @unique @map("username") avatar String? @map("avatar") password String? @map("password") phoneNumber String? @unique @map("phone_number") domainId String? @map("domain_id") deptId String? @map("dept_id") domain Department? @relation("DomainStaff", fields: [domainId], references: [id]) department Department? @relation("DeptStaff", fields: [deptId], references: [id]) order Float? createdAt DateTime @default(now()) @map("created_at") updatedAt DateTime @updatedAt @map("updated_at") enabled Boolean? @default(true) deletedAt DateTime? @map("deleted_at") officerId String? @map("officer_id") registerToken String? ownedResources Resource[] @@index([officerId]) @@index([deptId]) @@index([domainId]) @@index([username]) @@index([order]) @@map("staff") } model Department { id String @id @default(cuid()) name String order Float? deptDevices Device[] @relation("DeptDevice") ancestors DeptAncestry[] @relation("DescendantToAncestor") descendants DeptAncestry[] @relation("AncestorToDescendant") parentId String? @map("parent_id") parent Department? @relation("ChildParent", fields: [parentId], references: [id]) children Department[] @relation("ChildParent") domainId String? @map("domain_id") domainTerms Term[] @relation("TermDom") deletedAt DateTime? @map("deleted_at") isDomain Boolean? @default(false) @map("is_domain") domainStaffs Staff[] @relation("DomainStaff") deptStaffs Staff[] @relation("DeptStaff") terms Term[] @relation("department_term") // watchedPost Post[] @relation("post_watch_dept") hasChildren Boolean? @default(false) @map("has_children") @@index([parentId]) @@index([isDomain]) @@index([name]) @@index([order]) @@map("department") } model DeptAncestry { id String @id @default(cuid()) ancestorId String? @map("ancestor_id") descendantId String @map("descendant_id") relDepth Int @map("rel_depth") ancestor Department? @relation("AncestorToDescendant", fields: [ancestorId], references: [id]) descendant Department @relation("DescendantToAncestor", fields: [descendantId], references: [id]) // 索引建议 @@index([ancestorId]) // 针对祖先的查询 @@index([descendantId]) // 针对后代的查询 @@index([ancestorId, descendantId]) // 组合索引,用于查询特定的祖先-后代关系 @@index([relDepth]) // 根据关系深度的查询 @@map("dept_ancestry") } model RoleMap { id String @id @default(cuid()) objectId String @map("object_id") roleId String @map("role_id") domainId String? @map("domain_id") objectType String @map("object_type") role Role @relation(fields: [roleId], references: [id]) @@index([domainId]) @@index([objectId]) @@map("rolemap") } model Role { id String @id @default(cuid()) name String @unique @map("name") permissions String[] @default([]) @map("permissions") roleMaps RoleMap[] system Boolean? @default(false) @map("system") createdAt DateTime @default(now()) @map("created_at") updatedAt DateTime @updatedAt @map("updated_at") deletedAt DateTime? @map("deleted_at") @@map("role") } model AppConfig { id String @id @default(cuid()) slug String @unique title String? description String? meta Json? @@map("app_config") } model Resource { id String @id @default(cuid()) @map("id") title String? @map("title") description String? @map("description") type String? @map("type") fileId String? @unique url String? // 元数据 meta Json? @map("meta") // 处理状态控制 status String? createdAt DateTime? @default(now()) @map("created_at") updatedAt DateTime? @updatedAt @map("updated_at") createdBy String? @map("created_by") updatedBy String? @map("updated_by") deletedAt DateTime? @map("deleted_at") isPublic Boolean? @default(true) @map("is_public") owner Staff? @relation(fields: [ownerId], references: [id]) ownerId String? @map("owner_id") deviceId String? @map("device_id") device Device? @relation("DeviceResources", fields: [deviceId], references: [id]) // 索引 @@index([type]) @@index([createdAt]) @@map("resource") } model Device { id String @id @default(cuid()) deptId String? @map("dept_id") department Department? @relation("DeptDevice", fields: [deptId], references: [id]) showname String? @map("showname") productType String? @map("product_type") serialNumber String? @map("serial_number") assetId String? @map("asset_id") deviceStatus String? @map("device_status") confidentialLabelId String? @map("confidential_label_id") confidentialityLevel String? @map("confidentiality_level") diskSerialNumber String? @map("disk_serial_number") storageLocation String? @map("storage_location") responsiblePerson String? @map("responsible_person") notes String? @map("notes") systemType String? @map("system_type") deviceType String? @map("device_type") createdAt DateTime @default(now()) @map("created_at") updatedAt DateTime @updatedAt @map("updated_at") deletedAt DateTime? @map("deleted_at") resources Resource[] @relation("DeviceResources") @@index([deptId]) @@index([systemType]) @@index([deviceType]) @@index([responsiblePerson]) @@map("device") }