xedoc-cli 0.1.1 → 0.1.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (42) hide show
  1. package/README.md +3 -4
  2. package/build/client/assets/app-layout-d99dmiup.js +1 -0
  3. package/build/client/assets/app-shell-Dl69tJhv.js +1 -0
  4. package/build/client/assets/chat-B5FboIxH.js +1 -0
  5. package/build/client/assets/{connect-0oYrfAJT.js → connect-CHSFTXwk.js} +1 -1
  6. package/build/client/assets/{document-title-Dn4sU16M.js → document-title-B6Yxyaur.js} +1 -1
  7. package/build/client/assets/{entry.client-CM3vH2bv.js → entry.client-BlQXdBHx.js} +1 -1
  8. package/build/client/assets/home-Bahc85Gk.js +1 -0
  9. package/build/client/assets/{label-FUU4pCWu.js → label-C7i5Qt-O.js} +1 -1
  10. package/build/client/assets/manifest-fe1036ff.js +1 -0
  11. package/build/client/assets/{react-dom-KYDDPtOx.js → react-dom-CMuFyqmq.js} +1 -1
  12. package/build/client/assets/{root-DKEnPIjJ.js → root-feKzGV0p.js} +1 -1
  13. package/build/client/assets/{session-provider-FKGj36EG.js → session-provider-2Ozr-CuV.js} +1 -1
  14. package/build/server/index.js +1 -1
  15. package/package.json +2 -2
  16. package/prisma/schema.prisma +2 -18
  17. package/server/sqlite-setup.mjs +23 -28
  18. package/build/client/assets/api.workspaces.directories-B0tllRDq.js +0 -0
  19. package/build/client/assets/app-layout-Bb7v-3GP.js +0 -1
  20. package/build/client/assets/app-shell-Bn5JIK3M.js +0 -1
  21. package/build/client/assets/chat-BoNZJwBl.js +0 -1
  22. package/build/client/assets/home-DUuienY0.js +0 -1
  23. package/build/client/assets/manifest-9a2680ac.js +0 -1
  24. /package/build/client/assets/{api.accounts-CHoT6sYP.js → api.accounts-x_2c5-qG.js} +0 -0
  25. /package/build/client/assets/{api.accounts._accountId-BixDYyx8.js → api.accounts._accountId-BksU0sQ7.js} +0 -0
  26. /package/build/client/assets/{api.accounts._accountId.authenticate-CLzgv3py.js → api.accounts._accountId.authenticate-Bp51NHGy.js} +0 -0
  27. /package/build/client/assets/{api.accounts._accountId.authenticate.callback-Bqhz8sDl.js → api.accounts._accountId.authenticate.callback-DLgNMRyd.js} +0 -0
  28. /package/build/client/assets/{api.accounts._accountId.models-VIVpVZrj.js → api.accounts._accountId.models-DGbCmT_9.js} +0 -0
  29. /package/build/client/assets/{api.accounts._accountId.rate-limits-C9iUvNFt.js → api.accounts._accountId.rate-limits-DZh4HPLO.js} +0 -0
  30. /package/build/client/assets/{api.accounts._accountId.runtime-settings-6XNKTx--.js → api.accounts._accountId.runtime-settings-ChGZGvfx.js} +0 -0
  31. /package/build/client/assets/{api.accounts.export-romutOT6.js → api.accounts.export-CwjXUcyG.js} +0 -0
  32. /package/build/client/assets/{api.accounts.import-BiWq2jPz.js → api.accounts.import-Km-76sRE.js} +0 -0
  33. /package/build/client/assets/{api.chats-C6-gVaXw.js → api.chats-DZ_6Q7rY.js} +0 -0
  34. /package/build/client/assets/{api.chats._chatId-DaXHa-ln.js → api.chats._chatId-BEX87qHo.js} +0 -0
  35. /package/build/client/assets/{api.chats._chatId.context-DlBgjpCD.js → api.chats._chatId.context-v4G0lNKq.js} +0 -0
  36. /package/build/client/assets/{api.chats._chatId.files-DVZKcoNV.js → api.chats._chatId.files-BrN7O-wM.js} +0 -0
  37. /package/build/client/assets/{api.chats._chatId.git._operation-8Xtyz4hF.js → api.chats._chatId.git._operation-CiUW8Knm.js} +0 -0
  38. /package/build/client/assets/{api.chats._chatId.interrupt-B71lrxkc.js → api.chats._chatId.interrupt-2DlVPDlX.js} +0 -0
  39. /package/build/client/assets/{api.chats._chatId.messages-iVzJcgvw.js → api.chats._chatId.messages-cDawTuvN.js} +0 -0
  40. /package/build/client/assets/{api.chats._chatId.server-requests._requestId.respond-BLhOUK8A.js → api.chats._chatId.server-requests._requestId.respond-CTlCffOk.js} +0 -0
  41. /package/build/client/assets/{api.users-BLvMDkJE.js → api.workspaces.directories-nVoleT74.js} +0 -0
  42. /package/build/client/assets/{jsx-runtime-B9QlDcuB.js → jsx-runtime-Dafdqr5g.js} +0 -0
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "xedoc-cli",
3
- "version": "0.1.1",
3
+ "version": "0.1.2",
4
4
  "description": "Local web UI for Codex account, chat, execution, and workspace management.",
5
5
  "author": "Edward Nguyen <monokaijs@gmail.com>",
6
6
  "type": "module",
@@ -36,7 +36,7 @@
36
36
  "clean:build": "node -e \"import('node:fs/promises').then(({ rm }) => rm('build', { recursive: true, force: true }))\"",
37
37
  "prepublishOnly": "pnpm typecheck",
38
38
  "prepack": "pnpm clean:build && pnpm build",
39
- "publish": "npm publish --access public",
39
+ "publish:npm": "npm publish --access public",
40
40
  "publish:dry-run": "npm publish --access public --dry-run",
41
41
  "prisma:generate": "prisma generate --schema prisma/schema.prisma",
42
42
  "db:setup": "node -e \"import('./server/sqlite-setup.mjs').then((m)=>m.setupSqliteDatabase())\""
@@ -54,16 +54,6 @@ enum RunStatus {
54
54
  CANCELLED
55
55
  }
56
56
 
57
- model User {
58
- id String @id @default(uuid())
59
- externalId String? @unique
60
- name String?
61
- createdAt DateTime @default(now())
62
- updatedAt DateTime @updatedAt
63
- accounts CodexAccount[]
64
- chats Chat[]
65
- }
66
-
67
57
  model ServerAuth {
68
58
  id String @id @default("server")
69
59
  passwordHash String
@@ -74,7 +64,6 @@ model ServerAuth {
74
64
 
75
65
  model CodexAccount {
76
66
  id String @id @default(uuid())
77
- userId String
78
67
  displayName String
79
68
  status AccountStatus @default(DISCONNECTED)
80
69
  command String @default("codex")
@@ -88,16 +77,12 @@ model CodexAccount {
88
77
  lastError String?
89
78
  createdAt DateTime @default(now())
90
79
  updatedAt DateTime @updatedAt
91
- user User @relation(fields: [userId], references: [id], onDelete: Cascade)
92
80
  chats Chat[]
93
81
  runs ChatRun[]
94
-
95
- @@index([userId])
96
82
  }
97
83
 
98
84
  model Chat {
99
85
  id String @id @default(uuid())
100
- userId String
101
86
  accountId String?
102
87
  title String
103
88
  workingDirectory String?
@@ -111,13 +96,12 @@ model Chat {
111
96
  lastActivityAt DateTime @default(now())
112
97
  createdAt DateTime @default(now())
113
98
  updatedAt DateTime @updatedAt
114
- user User @relation(fields: [userId], references: [id], onDelete: Cascade)
115
99
  account CodexAccount? @relation(fields: [accountId], references: [id], onDelete: SetNull)
116
100
  messages ChatMessage[]
117
101
  runs ChatRun[]
118
102
 
119
- @@index([userId, updatedAt])
120
- @@index([userId, lastActivityAt])
103
+ @@index([updatedAt])
104
+ @@index([lastActivityAt])
121
105
  @@index([accountId])
122
106
  }
123
107
 
@@ -57,24 +57,9 @@ function sqliteDatabaseUrl(path) {
57
57
  return `file:${path}?connection_limit=1&pool_timeout=30`
58
58
  }
59
59
 
60
- const schemaStatements = [
61
- `CREATE TABLE IF NOT EXISTS "User" (
60
+ function createCodexAccountTable(tableName) {
61
+ return `CREATE TABLE IF NOT EXISTS "${tableName}" (
62
62
  "id" TEXT NOT NULL PRIMARY KEY,
63
- "externalId" TEXT,
64
- "name" TEXT,
65
- "createdAt" DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP,
66
- "updatedAt" DATETIME NOT NULL
67
- )`,
68
- `CREATE TABLE IF NOT EXISTS "ServerAuth" (
69
- "id" TEXT NOT NULL PRIMARY KEY DEFAULT 'server',
70
- "passwordHash" TEXT NOT NULL,
71
- "tokenSecret" TEXT NOT NULL,
72
- "createdAt" DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP,
73
- "updatedAt" DATETIME NOT NULL
74
- )`,
75
- `CREATE TABLE IF NOT EXISTS "CodexAccount" (
76
- "id" TEXT NOT NULL PRIMARY KEY,
77
- "userId" TEXT NOT NULL,
78
63
  "displayName" TEXT NOT NULL,
79
64
  "status" TEXT NOT NULL DEFAULT 'DISCONNECTED',
80
65
  "command" TEXT NOT NULL DEFAULT 'codex',
@@ -87,12 +72,13 @@ const schemaStatements = [
87
72
  "lastAuthUrl" TEXT,
88
73
  "lastError" TEXT,
89
74
  "createdAt" DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP,
90
- "updatedAt" DATETIME NOT NULL,
91
- CONSTRAINT "CodexAccount_userId_fkey" FOREIGN KEY ("userId") REFERENCES "User" ("id") ON DELETE CASCADE ON UPDATE CASCADE
92
- )`,
93
- `CREATE TABLE IF NOT EXISTS "Chat" (
75
+ "updatedAt" DATETIME NOT NULL
76
+ )`
77
+ }
78
+
79
+ function createChatTable(tableName) {
80
+ return `CREATE TABLE IF NOT EXISTS "${tableName}" (
94
81
  "id" TEXT NOT NULL PRIMARY KEY,
95
- "userId" TEXT NOT NULL,
96
82
  "accountId" TEXT,
97
83
  "title" TEXT NOT NULL,
98
84
  "workingDirectory" TEXT,
@@ -106,9 +92,20 @@ const schemaStatements = [
106
92
  "lastActivityAt" DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP,
107
93
  "createdAt" DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP,
108
94
  "updatedAt" DATETIME NOT NULL,
109
- CONSTRAINT "Chat_userId_fkey" FOREIGN KEY ("userId") REFERENCES "User" ("id") ON DELETE CASCADE ON UPDATE CASCADE,
110
- CONSTRAINT "Chat_accountId_fkey" FOREIGN KEY ("accountId") REFERENCES "CodexAccount" ("id") ON DELETE SET NULL ON UPDATE CASCADE
95
+ CONSTRAINT "${tableName}_accountId_fkey" FOREIGN KEY ("accountId") REFERENCES "CodexAccount" ("id") ON DELETE SET NULL ON UPDATE CASCADE
96
+ )`
97
+ }
98
+
99
+ const schemaStatements = [
100
+ `CREATE TABLE IF NOT EXISTS "ServerAuth" (
101
+ "id" TEXT NOT NULL PRIMARY KEY DEFAULT 'server',
102
+ "passwordHash" TEXT NOT NULL,
103
+ "tokenSecret" TEXT NOT NULL,
104
+ "createdAt" DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP,
105
+ "updatedAt" DATETIME NOT NULL
111
106
  )`,
107
+ createCodexAccountTable("CodexAccount"),
108
+ createChatTable("Chat"),
112
109
  `CREATE TABLE IF NOT EXISTS "ChatMessage" (
113
110
  "id" TEXT NOT NULL PRIMARY KEY,
114
111
  "chatId" TEXT NOT NULL,
@@ -144,14 +141,12 @@ const schemaStatements = [
144
141
  CONSTRAINT "ChatRun_chatId_fkey" FOREIGN KEY ("chatId") REFERENCES "Chat" ("id") ON DELETE CASCADE ON UPDATE CASCADE,
145
142
  CONSTRAINT "ChatRun_accountId_fkey" FOREIGN KEY ("accountId") REFERENCES "CodexAccount" ("id") ON DELETE RESTRICT ON UPDATE CASCADE
146
143
  )`,
147
- 'CREATE UNIQUE INDEX IF NOT EXISTS "User_externalId_key" ON "User"("externalId")',
148
144
  'ALTER TABLE "CodexAccount" ADD COLUMN "defaultModel" TEXT',
149
145
  'ALTER TABLE "CodexAccount" ADD COLUMN "defaultPermissionMode" TEXT',
150
146
  'ALTER TABLE "CodexAccount" ADD COLUMN "defaultReasoningEffort" TEXT',
151
147
  'ALTER TABLE "CodexAccount" ADD COLUMN "defaultServiceTier" TEXT',
152
- 'CREATE INDEX IF NOT EXISTS "CodexAccount_userId_idx" ON "CodexAccount"("userId")',
153
- 'CREATE INDEX IF NOT EXISTS "Chat_userId_updatedAt_idx" ON "Chat"("userId", "updatedAt")',
154
- 'CREATE INDEX IF NOT EXISTS "Chat_userId_lastActivityAt_idx" ON "Chat"("userId", "lastActivityAt")',
148
+ 'CREATE INDEX IF NOT EXISTS "Chat_updatedAt_idx" ON "Chat"("updatedAt")',
149
+ 'CREATE INDEX IF NOT EXISTS "Chat_lastActivityAt_idx" ON "Chat"("lastActivityAt")',
155
150
  'CREATE INDEX IF NOT EXISTS "Chat_accountId_idx" ON "Chat"("accountId")',
156
151
  'CREATE INDEX IF NOT EXISTS "ChatMessage_chatId_sequence_idx" ON "ChatMessage"("chatId", "sequence")',
157
152
  'CREATE INDEX IF NOT EXISTS "ChatMessage_chatId_turnId_idx" ON "ChatMessage"("chatId", "turnId")',
@@ -1 +0,0 @@
1
- import{j as r,t as s}from"./jsx-runtime-B9QlDcuB.js";import{t}from"./app-shell-Bn5JIK3M.js";var a=s(),o=r(function(){return(0,a.jsx)(t,{})});export{o as default};