|
| 1 | +-- CreateTable |
| 2 | +CREATE TABLE "User" ( |
| 3 | + "id" TEXT NOT NULL PRIMARY KEY, |
| 4 | + "username" TEXT NOT NULL, |
| 5 | + "passwordHash" TEXT NOT NULL, |
| 6 | + "displayName" TEXT, |
| 7 | + "role" TEXT NOT NULL DEFAULT 'USER', |
| 8 | + "isActive" BOOLEAN NOT NULL DEFAULT true, |
| 9 | + "mustChangePassword" BOOLEAN NOT NULL DEFAULT false, |
| 10 | + "createdAt" DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP, |
| 11 | + "updatedAt" DATETIME NOT NULL |
| 12 | +); |
| 13 | + |
| 14 | +-- CreateTable |
| 15 | +CREATE TABLE "Session" ( |
| 16 | + "id" TEXT NOT NULL PRIMARY KEY, |
| 17 | + "userId" TEXT NOT NULL, |
| 18 | + "token" TEXT NOT NULL, |
| 19 | + "expiresAt" DATETIME NOT NULL, |
| 20 | + "userAgent" TEXT, |
| 21 | + "ipAddress" TEXT, |
| 22 | + "createdAt" DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP, |
| 23 | + CONSTRAINT "Session_userId_fkey" FOREIGN KEY ("userId") REFERENCES "User" ("id") ON DELETE CASCADE ON UPDATE CASCADE |
| 24 | +); |
| 25 | + |
| 26 | +-- CreateTable |
| 27 | +CREATE TABLE "UserPermission" ( |
| 28 | + "id" TEXT NOT NULL PRIMARY KEY, |
| 29 | + "userId" TEXT NOT NULL, |
| 30 | + "dockerAccess" BOOLEAN NOT NULL DEFAULT false, |
| 31 | + "dockerViewAll" BOOLEAN NOT NULL DEFAULT false, |
| 32 | + "dockerImages" BOOLEAN NOT NULL DEFAULT false, |
| 33 | + "dockerVolumes" BOOLEAN NOT NULL DEFAULT false, |
| 34 | + "dockerNetworks" BOOLEAN NOT NULL DEFAULT false, |
| 35 | + "dockerCreate" BOOLEAN NOT NULL DEFAULT false, |
| 36 | + "dockerDelete" BOOLEAN NOT NULL DEFAULT false, |
| 37 | + "fsAccess" BOOLEAN NOT NULL DEFAULT false, |
| 38 | + "terminalAccess" BOOLEAN NOT NULL DEFAULT false, |
| 39 | + "terminalReadOnly" BOOLEAN NOT NULL DEFAULT true, |
| 40 | + "terminalMaxSessions" INTEGER NOT NULL DEFAULT 1, |
| 41 | + CONSTRAINT "UserPermission_userId_fkey" FOREIGN KEY ("userId") REFERENCES "User" ("id") ON DELETE CASCADE ON UPDATE CASCADE |
| 42 | +); |
| 43 | + |
| 44 | +-- CreateTable |
| 45 | +CREATE TABLE "ContainerPermission" ( |
| 46 | + "id" TEXT NOT NULL PRIMARY KEY, |
| 47 | + "permissionId" TEXT NOT NULL, |
| 48 | + "containerId" TEXT NOT NULL, |
| 49 | + "containerName" TEXT NOT NULL, |
| 50 | + "canView" BOOLEAN NOT NULL DEFAULT true, |
| 51 | + "canStart" BOOLEAN NOT NULL DEFAULT false, |
| 52 | + "canStop" BOOLEAN NOT NULL DEFAULT false, |
| 53 | + "canRestart" BOOLEAN NOT NULL DEFAULT false, |
| 54 | + "canDelete" BOOLEAN NOT NULL DEFAULT false, |
| 55 | + "canLogs" BOOLEAN NOT NULL DEFAULT false, |
| 56 | + "canExec" BOOLEAN NOT NULL DEFAULT false, |
| 57 | + "canInspect" BOOLEAN NOT NULL DEFAULT false, |
| 58 | + "createdAt" DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP, |
| 59 | + "updatedAt" DATETIME NOT NULL, |
| 60 | + CONSTRAINT "ContainerPermission_permissionId_fkey" FOREIGN KEY ("permissionId") REFERENCES "UserPermission" ("id") ON DELETE CASCADE ON UPDATE CASCADE |
| 61 | +); |
| 62 | + |
| 63 | +-- CreateTable |
| 64 | +CREATE TABLE "FsPathPermission" ( |
| 65 | + "id" TEXT NOT NULL PRIMARY KEY, |
| 66 | + "permissionId" TEXT NOT NULL, |
| 67 | + "path" TEXT NOT NULL, |
| 68 | + "readOnly" BOOLEAN NOT NULL DEFAULT true, |
| 69 | + "canCreate" BOOLEAN NOT NULL DEFAULT false, |
| 70 | + "canDelete" BOOLEAN NOT NULL DEFAULT false, |
| 71 | + "createdAt" DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP, |
| 72 | + CONSTRAINT "FsPathPermission_permissionId_fkey" FOREIGN KEY ("permissionId") REFERENCES "UserPermission" ("id") ON DELETE CASCADE ON UPDATE CASCADE |
| 73 | +); |
| 74 | + |
| 75 | +-- CreateTable |
| 76 | +CREATE TABLE "AuditLog" ( |
| 77 | + "id" TEXT NOT NULL PRIMARY KEY, |
| 78 | + "userId" TEXT, |
| 79 | + "username" TEXT NOT NULL, |
| 80 | + "action" TEXT NOT NULL, |
| 81 | + "resource" TEXT NOT NULL, |
| 82 | + "detail" TEXT, |
| 83 | + "ipAddress" TEXT, |
| 84 | + "success" BOOLEAN NOT NULL DEFAULT true, |
| 85 | + "createdAt" DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP, |
| 86 | + CONSTRAINT "AuditLog_userId_fkey" FOREIGN KEY ("userId") REFERENCES "User" ("id") ON DELETE SET NULL ON UPDATE CASCADE |
| 87 | +); |
| 88 | + |
| 89 | +-- CreateIndex |
| 90 | +CREATE UNIQUE INDEX "User_username_key" ON "User"("username"); |
| 91 | + |
| 92 | +-- CreateIndex |
| 93 | +CREATE UNIQUE INDEX "Session_token_key" ON "Session"("token"); |
| 94 | + |
| 95 | +-- CreateIndex |
| 96 | +CREATE INDEX "Session_token_idx" ON "Session"("token"); |
| 97 | + |
| 98 | +-- CreateIndex |
| 99 | +CREATE INDEX "Session_userId_idx" ON "Session"("userId"); |
| 100 | + |
| 101 | +-- CreateIndex |
| 102 | +CREATE UNIQUE INDEX "UserPermission_userId_key" ON "UserPermission"("userId"); |
| 103 | + |
| 104 | +-- CreateIndex |
| 105 | +CREATE INDEX "ContainerPermission_permissionId_idx" ON "ContainerPermission"("permissionId"); |
| 106 | + |
| 107 | +-- CreateIndex |
| 108 | +CREATE INDEX "ContainerPermission_containerId_idx" ON "ContainerPermission"("containerId"); |
| 109 | + |
| 110 | +-- CreateIndex |
| 111 | +CREATE UNIQUE INDEX "ContainerPermission_permissionId_containerId_key" ON "ContainerPermission"("permissionId", "containerId"); |
| 112 | + |
| 113 | +-- CreateIndex |
| 114 | +CREATE INDEX "FsPathPermission_permissionId_idx" ON "FsPathPermission"("permissionId"); |
| 115 | + |
| 116 | +-- CreateIndex |
| 117 | +CREATE UNIQUE INDEX "FsPathPermission_permissionId_path_key" ON "FsPathPermission"("permissionId", "path"); |
| 118 | + |
| 119 | +-- CreateIndex |
| 120 | +CREATE INDEX "AuditLog_userId_idx" ON "AuditLog"("userId"); |
| 121 | + |
| 122 | +-- CreateIndex |
| 123 | +CREATE INDEX "AuditLog_createdAt_idx" ON "AuditLog"("createdAt"); |
| 124 | + |
| 125 | +-- CreateIndex |
| 126 | +CREATE INDEX "AuditLog_resource_idx" ON "AuditLog"("resource"); |
0 commit comments