First stable build with system check
This commit is contained in:
@@ -0,0 +1,121 @@
|
||||
-- CreateTable
|
||||
CREATE TABLE "SystemSetting" (
|
||||
"hashKey" TEXT NOT NULL PRIMARY KEY,
|
||||
"hashValue" TEXT NOT NULL
|
||||
);
|
||||
|
||||
-- CreateTable
|
||||
CREATE TABLE "SystemPostMigration" (
|
||||
"name" TEXT NOT NULL PRIMARY KEY,
|
||||
"createdAt" DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP
|
||||
);
|
||||
|
||||
-- CreateTable
|
||||
CREATE TABLE "IdentityGroup" (
|
||||
"id" INTEGER NOT NULL PRIMARY KEY AUTOINCREMENT,
|
||||
"isAdmin" BOOLEAN NOT NULL DEFAULT false,
|
||||
"name" TEXT
|
||||
);
|
||||
|
||||
-- CreateTable
|
||||
CREATE TABLE "IdentityGroupToIdentityUser" (
|
||||
"groupId" INTEGER NOT NULL,
|
||||
"userId" INTEGER NOT NULL,
|
||||
|
||||
PRIMARY KEY ("groupId", "userId"),
|
||||
CONSTRAINT "IdentityGroupToIdentityUser_groupId_fkey" FOREIGN KEY ("groupId") REFERENCES "IdentityGroup" ("id") ON DELETE RESTRICT ON UPDATE CASCADE,
|
||||
CONSTRAINT "IdentityGroupToIdentityUser_userId_fkey" FOREIGN KEY ("userId") REFERENCES "IdentityUser" ("id") ON DELETE RESTRICT ON UPDATE CASCADE
|
||||
);
|
||||
|
||||
-- CreateTable
|
||||
CREATE TABLE "IdentityUser" (
|
||||
"id" INTEGER NOT NULL PRIMARY KEY AUTOINCREMENT,
|
||||
"externalId" TEXT NOT NULL,
|
||||
"username" TEXT NOT NULL
|
||||
);
|
||||
|
||||
-- CreateTable
|
||||
CREATE TABLE "IdentityProfileNonNormalized" (
|
||||
"userId" INTEGER NOT NULL,
|
||||
"hashKey" TEXT NOT NULL,
|
||||
"hashValue" TEXT NOT NULL,
|
||||
"createdAt" DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP,
|
||||
|
||||
PRIMARY KEY ("userId", "hashKey"),
|
||||
CONSTRAINT "IdentityProfileNonNormalized_userId_fkey" FOREIGN KEY ("userId") REFERENCES "IdentityUser" ("id") ON DELETE RESTRICT ON UPDATE CASCADE
|
||||
);
|
||||
|
||||
-- CreateTable
|
||||
CREATE TABLE "IdentityUserEmails" (
|
||||
"email" TEXT NOT NULL PRIMARY KEY,
|
||||
"userId" INTEGER NOT NULL,
|
||||
"verified" BOOLEAN NOT NULL DEFAULT false,
|
||||
"default" BOOLEAN NOT NULL DEFAULT false,
|
||||
CONSTRAINT "IdentityUserEmails_userId_fkey" FOREIGN KEY ("userId") REFERENCES "IdentityUser" ("id") ON DELETE RESTRICT ON UPDATE CASCADE
|
||||
);
|
||||
|
||||
-- CreateTable
|
||||
CREATE TABLE "EnumIdentityAuthDeviceType" (
|
||||
"enumValue" TEXT NOT NULL PRIMARY KEY
|
||||
);
|
||||
|
||||
-- CreateTable
|
||||
CREATE TABLE "IdentityAuthDevice" (
|
||||
"id" INTEGER NOT NULL PRIMARY KEY AUTOINCREMENT,
|
||||
"userId" INTEGER NOT NULL,
|
||||
"deviceType" TEXT NOT NULL,
|
||||
"createdAt" DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP,
|
||||
CONSTRAINT "IdentityAuthDevice_userId_fkey" FOREIGN KEY ("userId") REFERENCES "IdentityUser" ("id") ON DELETE RESTRICT ON UPDATE CASCADE,
|
||||
CONSTRAINT "IdentityAuthDevice_deviceType_fkey" FOREIGN KEY ("deviceType") REFERENCES "EnumIdentityAuthDeviceType" ("enumValue") ON DELETE RESTRICT ON UPDATE CASCADE
|
||||
);
|
||||
|
||||
-- CreateTable
|
||||
CREATE TABLE "IdentityAuthDeviceNonNormalized" (
|
||||
"authDeviceId" INTEGER NOT NULL,
|
||||
"hashKey" TEXT NOT NULL,
|
||||
"hashValue" TEXT NOT NULL,
|
||||
"createdAt" DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP,
|
||||
|
||||
PRIMARY KEY ("authDeviceId", "hashKey"),
|
||||
CONSTRAINT "IdentityAuthDeviceNonNormalized_authDeviceId_fkey" FOREIGN KEY ("authDeviceId") REFERENCES "IdentityAuthDevice" ("id") ON DELETE RESTRICT ON UPDATE CASCADE
|
||||
);
|
||||
|
||||
-- CreateTable
|
||||
CREATE TABLE "EnumCloudDavResourceType" (
|
||||
"enumValue" TEXT NOT NULL PRIMARY KEY
|
||||
);
|
||||
|
||||
-- CreateTable
|
||||
CREATE TABLE "CloudDavResource" (
|
||||
"id" TEXT NOT NULL PRIMARY KEY,
|
||||
"identityGroupId" INTEGER NOT NULL,
|
||||
"resourceType" TEXT NOT NULL,
|
||||
CONSTRAINT "CloudDavResource_identityGroupId_fkey" FOREIGN KEY ("identityGroupId") REFERENCES "IdentityGroup" ("id") ON DELETE RESTRICT ON UPDATE CASCADE,
|
||||
CONSTRAINT "CloudDavResource_resourceType_fkey" FOREIGN KEY ("resourceType") REFERENCES "EnumCloudDavResourceType" ("enumValue") ON DELETE RESTRICT ON UPDATE CASCADE
|
||||
);
|
||||
|
||||
-- CreateTable
|
||||
CREATE TABLE "CloudDavResourceNonNormalized" (
|
||||
"davResourceId" TEXT NOT NULL,
|
||||
"hashKey" TEXT NOT NULL,
|
||||
"hashValue" TEXT NOT NULL,
|
||||
"createdAt" DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP,
|
||||
|
||||
PRIMARY KEY ("davResourceId", "hashKey"),
|
||||
CONSTRAINT "CloudDavResourceNonNormalized_davResourceId_fkey" FOREIGN KEY ("davResourceId") REFERENCES "CloudDavResource" ("id") ON DELETE RESTRICT ON UPDATE CASCADE
|
||||
);
|
||||
|
||||
-- CreateIndex
|
||||
CREATE UNIQUE INDEX "IdentityUser_externalId_key" ON "IdentityUser"("externalId");
|
||||
|
||||
-- CreateIndex
|
||||
CREATE UNIQUE INDEX "IdentityUser_username_key" ON "IdentityUser"("username");
|
||||
|
||||
-- CreateIndex
|
||||
CREATE INDEX "IdentityAuthDevice_userId_idx" ON "IdentityAuthDevice"("userId");
|
||||
|
||||
-- CreateIndex
|
||||
CREATE INDEX "IdentityAuthDevice_userId_deviceType_idx" ON "IdentityAuthDevice"("userId", "deviceType");
|
||||
|
||||
-- CreateIndex
|
||||
CREATE INDEX "CloudDavResource_identityGroupId_idx" ON "CloudDavResource"("identityGroupId");
|
||||
3
services/core/prisma/migrations/migration_lock.toml
Normal file
3
services/core/prisma/migrations/migration_lock.toml
Normal file
@@ -0,0 +1,3 @@
|
||||
# Please do not edit this file manually
|
||||
# It should be added in your version-control system (i.e. Git)
|
||||
provider = "sqlite"
|
||||
142
services/core/prisma/schema.prisma
Normal file
142
services/core/prisma/schema.prisma
Normal file
@@ -0,0 +1,142 @@
|
||||
generator client {
|
||||
provider = "prisma-client-js"
|
||||
}
|
||||
|
||||
datasource db {
|
||||
provider = "sqlite"
|
||||
url = "file:../../../data/core.db"
|
||||
}
|
||||
|
||||
//
|
||||
// Namespace: System
|
||||
//
|
||||
model SystemSetting {
|
||||
hashKey String @id
|
||||
hashValue String
|
||||
}
|
||||
|
||||
model SystemPostMigration {
|
||||
name String @id
|
||||
createdAt DateTime @default(now())
|
||||
}
|
||||
|
||||
//
|
||||
// Namespace: Identity
|
||||
//
|
||||
model IdentityGroup {
|
||||
id Int @id @default(autoincrement())
|
||||
isAdmin Boolean @default(false)
|
||||
name String?
|
||||
|
||||
users IdentityGroupToIdentityUser[]
|
||||
davResources CloudDavResource[]
|
||||
}
|
||||
|
||||
model IdentityGroupToIdentityUser {
|
||||
groupId Int
|
||||
group IdentityGroup @relation(fields: [groupId], references: [id])
|
||||
userId Int
|
||||
user IdentityUser @relation(fields: [userId], references: [id])
|
||||
|
||||
@@id([groupId, userId])
|
||||
}
|
||||
|
||||
model IdentityUser {
|
||||
id Int @id @default(autoincrement())
|
||||
externalId String @unique @default(uuid())
|
||||
username String @unique
|
||||
|
||||
groups IdentityGroupToIdentityUser[]
|
||||
profileHashMapPairs IdentityProfileNonNormalized[]
|
||||
emails IdentityUserEmails[]
|
||||
authDevices IdentityAuthDevice[]
|
||||
}
|
||||
|
||||
model IdentityProfileNonNormalized {
|
||||
userId Int
|
||||
user IdentityUser @relation(fields: [userId], references: [id])
|
||||
|
||||
hashKey String
|
||||
hashValue String
|
||||
createdAt DateTime @default(now())
|
||||
|
||||
@@id([userId, hashKey])
|
||||
}
|
||||
|
||||
model IdentityUserEmails {
|
||||
email String @id
|
||||
|
||||
userId Int
|
||||
user IdentityUser @relation(fields: [userId], references: [id])
|
||||
|
||||
verified Boolean @default(false)
|
||||
default Boolean @default(false)
|
||||
}
|
||||
|
||||
model EnumIdentityAuthDeviceType {
|
||||
enumValue String @id
|
||||
|
||||
authDevices IdentityAuthDevice[]
|
||||
}
|
||||
|
||||
model IdentityAuthDevice {
|
||||
id Int @id @default(autoincrement())
|
||||
|
||||
userId Int
|
||||
user IdentityUser @relation(fields: [userId], references: [id])
|
||||
|
||||
deviceType String
|
||||
deviceTypeRelation EnumIdentityAuthDeviceType @relation(fields: [deviceType], references: [enumValue])
|
||||
|
||||
createdAt DateTime @default(now())
|
||||
|
||||
hashMapPairs IdentityAuthDeviceNonNormalized[]
|
||||
|
||||
@@index([userId])
|
||||
@@index([userId, deviceType])
|
||||
}
|
||||
|
||||
model IdentityAuthDeviceNonNormalized {
|
||||
authDeviceId Int
|
||||
davResource IdentityAuthDevice @relation(fields: [authDeviceId], references: [id])
|
||||
|
||||
hashKey String
|
||||
hashValue String
|
||||
createdAt DateTime @default(now())
|
||||
|
||||
@@id([authDeviceId, hashKey])
|
||||
}
|
||||
|
||||
//
|
||||
// Namespace: cloud-dav
|
||||
//
|
||||
model EnumCloudDavResourceType {
|
||||
enumValue String @id
|
||||
|
||||
davResources CloudDavResource[]
|
||||
}
|
||||
|
||||
model CloudDavResource {
|
||||
id String @id @default(uuid())
|
||||
|
||||
identityGroupId Int
|
||||
IdentityGroup IdentityGroup @relation(fields: [identityGroupId], references: [id])
|
||||
|
||||
resourceType String
|
||||
resourceTypeRelation EnumCloudDavResourceType @relation(fields: [resourceType], references: [enumValue])
|
||||
|
||||
hashMapPairs CloudDavResourceNonNormalized[]
|
||||
|
||||
@@index([identityGroupId])
|
||||
}
|
||||
|
||||
model CloudDavResourceNonNormalized {
|
||||
davResourceId String
|
||||
davResource CloudDavResource @relation(fields: [davResourceId], references: [id])
|
||||
|
||||
hashKey String
|
||||
hashValue String
|
||||
createdAt DateTime @default(now())
|
||||
|
||||
@@id([davResourceId, hashKey])
|
||||
}
|
||||
Reference in New Issue
Block a user