@paperclipai/server 0.2.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 (317) hide show
  1. package/dist/adapters/codex-models.d.ts +4 -0
  2. package/dist/adapters/codex-models.d.ts.map +1 -0
  3. package/dist/adapters/codex-models.js +98 -0
  4. package/dist/adapters/codex-models.js.map +1 -0
  5. package/dist/adapters/http/execute.d.ts +3 -0
  6. package/dist/adapters/http/execute.d.ts.map +1 -0
  7. package/dist/adapters/http/execute.js +39 -0
  8. package/dist/adapters/http/execute.js.map +1 -0
  9. package/dist/adapters/http/index.d.ts +3 -0
  10. package/dist/adapters/http/index.d.ts.map +1 -0
  11. package/dist/adapters/http/index.js +20 -0
  12. package/dist/adapters/http/index.js.map +1 -0
  13. package/dist/adapters/http/test.d.ts +3 -0
  14. package/dist/adapters/http/test.d.ts.map +1 -0
  15. package/dist/adapters/http/test.js +106 -0
  16. package/dist/adapters/http/test.js.map +1 -0
  17. package/dist/adapters/index.d.ts +4 -0
  18. package/dist/adapters/index.d.ts.map +1 -0
  19. package/dist/adapters/index.js +3 -0
  20. package/dist/adapters/index.js.map +1 -0
  21. package/dist/adapters/process/execute.d.ts +3 -0
  22. package/dist/adapters/process/execute.d.ts.map +1 -0
  23. package/dist/adapters/process/execute.js +63 -0
  24. package/dist/adapters/process/execute.js.map +1 -0
  25. package/dist/adapters/process/index.d.ts +3 -0
  26. package/dist/adapters/process/index.d.ts.map +1 -0
  27. package/dist/adapters/process/index.js +23 -0
  28. package/dist/adapters/process/index.js.map +1 -0
  29. package/dist/adapters/process/test.d.ts +3 -0
  30. package/dist/adapters/process/test.d.ts.map +1 -0
  31. package/dist/adapters/process/test.js +77 -0
  32. package/dist/adapters/process/test.js.map +1 -0
  33. package/dist/adapters/registry.d.ts +9 -0
  34. package/dist/adapters/registry.d.ts.map +1 -0
  35. package/dist/adapters/registry.js +63 -0
  36. package/dist/adapters/registry.js.map +1 -0
  37. package/dist/adapters/types.d.ts +2 -0
  38. package/dist/adapters/types.d.ts.map +1 -0
  39. package/dist/adapters/types.js +2 -0
  40. package/dist/adapters/types.js.map +1 -0
  41. package/dist/adapters/utils.d.ts +10 -0
  42. package/dist/adapters/utils.d.ts.map +1 -0
  43. package/dist/adapters/utils.js +14 -0
  44. package/dist/adapters/utils.js.map +1 -0
  45. package/dist/agent-auth-jwt.d.ts +14 -0
  46. package/dist/agent-auth-jwt.d.ts.map +1 -0
  47. package/dist/agent-auth-jwt.js +117 -0
  48. package/dist/agent-auth-jwt.js.map +1 -0
  49. package/dist/app.d.ts +20 -0
  50. package/dist/app.d.ts.map +1 -0
  51. package/dist/app.js +127 -0
  52. package/dist/app.js.map +1 -0
  53. package/dist/auth/better-auth.d.ts +23 -0
  54. package/dist/auth/better-auth.d.ts.map +1 -0
  55. package/dist/auth/better-auth.js +80 -0
  56. package/dist/auth/better-auth.js.map +1 -0
  57. package/dist/board-claim.d.ts +23 -0
  58. package/dist/board-claim.d.ts.map +1 -0
  59. package/dist/board-claim.js +115 -0
  60. package/dist/board-claim.js.map +1 -0
  61. package/dist/config-file.d.ts +3 -0
  62. package/dist/config-file.d.ts.map +1 -0
  63. package/dist/config-file.js +16 -0
  64. package/dist/config-file.js.map +1 -0
  65. package/dist/config.d.ts +33 -0
  66. package/dist/config.d.ts.map +1 -0
  67. package/dist/config.js +114 -0
  68. package/dist/config.js.map +1 -0
  69. package/dist/errors.d.ts +12 -0
  70. package/dist/errors.d.ts.map +1 -0
  71. package/dist/errors.js +28 -0
  72. package/dist/errors.js.map +1 -0
  73. package/dist/home-paths.d.ts +11 -0
  74. package/dist/home-paths.d.ts.map +1 -0
  75. package/dist/home-paths.js +54 -0
  76. package/dist/home-paths.js.map +1 -0
  77. package/dist/index.d.ts +2 -0
  78. package/dist/index.d.ts.map +1 -0
  79. package/dist/index.js +439 -0
  80. package/dist/index.js.map +1 -0
  81. package/dist/middleware/auth.d.ts +12 -0
  82. package/dist/middleware/auth.d.ts.map +1 -0
  83. package/dist/middleware/auth.js +124 -0
  84. package/dist/middleware/auth.js.map +1 -0
  85. package/dist/middleware/board-mutation-guard.d.ts +3 -0
  86. package/dist/middleware/board-mutation-guard.d.ts.map +1 -0
  87. package/dist/middleware/board-mutation-guard.js +60 -0
  88. package/dist/middleware/board-mutation-guard.js.map +1 -0
  89. package/dist/middleware/error-handler.d.ts +3 -0
  90. package/dist/middleware/error-handler.d.ts.map +1 -0
  91. package/dist/middleware/error-handler.js +22 -0
  92. package/dist/middleware/error-handler.js.map +1 -0
  93. package/dist/middleware/index.d.ts +4 -0
  94. package/dist/middleware/index.d.ts.map +1 -0
  95. package/dist/middleware/index.js +4 -0
  96. package/dist/middleware/index.js.map +1 -0
  97. package/dist/middleware/logger.d.ts +4 -0
  98. package/dist/middleware/logger.d.ts.map +1 -0
  99. package/dist/middleware/logger.js +37 -0
  100. package/dist/middleware/logger.js.map +1 -0
  101. package/dist/middleware/private-hostname-guard.d.ts +11 -0
  102. package/dist/middleware/private-hostname-guard.d.ts.map +1 -0
  103. package/dist/middleware/private-hostname-guard.js +78 -0
  104. package/dist/middleware/private-hostname-guard.js.map +1 -0
  105. package/dist/middleware/validate.d.ts +4 -0
  106. package/dist/middleware/validate.d.ts.map +1 -0
  107. package/dist/middleware/validate.js +7 -0
  108. package/dist/middleware/validate.js.map +1 -0
  109. package/dist/paths.d.ts +3 -0
  110. package/dist/paths.d.ts.map +1 -0
  111. package/dist/paths.js +31 -0
  112. package/dist/paths.js.map +1 -0
  113. package/dist/realtime/live-events-ws.d.ts +10 -0
  114. package/dist/realtime/live-events-ws.d.ts.map +1 -0
  115. package/dist/realtime/live-events-ws.js +185 -0
  116. package/dist/realtime/live-events-ws.js.map +1 -0
  117. package/dist/redaction.d.ts +4 -0
  118. package/dist/redaction.d.ts.map +1 -0
  119. package/dist/redaction.js +63 -0
  120. package/dist/redaction.js.map +1 -0
  121. package/dist/routes/access.d.ts +9 -0
  122. package/dist/routes/access.d.ts.map +1 -0
  123. package/dist/routes/access.js +887 -0
  124. package/dist/routes/access.js.map +1 -0
  125. package/dist/routes/activity.d.ts +3 -0
  126. package/dist/routes/activity.d.ts.map +1 -0
  127. package/dist/routes/activity.js +87 -0
  128. package/dist/routes/activity.js.map +1 -0
  129. package/dist/routes/agents.d.ts +3 -0
  130. package/dist/routes/agents.d.ts.map +1 -0
  131. package/dist/routes/agents.js +1132 -0
  132. package/dist/routes/agents.js.map +1 -0
  133. package/dist/routes/approvals.d.ts +3 -0
  134. package/dist/routes/approvals.d.ts.map +1 -0
  135. package/dist/routes/approvals.js +271 -0
  136. package/dist/routes/approvals.js.map +1 -0
  137. package/dist/routes/assets.d.ts +4 -0
  138. package/dist/routes/assets.d.ts.map +1 -0
  139. package/dist/routes/assets.js +138 -0
  140. package/dist/routes/assets.js.map +1 -0
  141. package/dist/routes/authz.d.ts +15 -0
  142. package/dist/routes/authz.d.ts.map +1 -0
  143. package/dist/routes/authz.js +40 -0
  144. package/dist/routes/authz.js.map +1 -0
  145. package/dist/routes/companies.d.ts +3 -0
  146. package/dist/routes/companies.d.ts.map +1 -0
  147. package/dist/routes/companies.js +159 -0
  148. package/dist/routes/companies.js.map +1 -0
  149. package/dist/routes/costs.d.ts +3 -0
  150. package/dist/routes/costs.d.ts.map +1 -0
  151. package/dist/routes/costs.js +113 -0
  152. package/dist/routes/costs.js.map +1 -0
  153. package/dist/routes/dashboard.d.ts +3 -0
  154. package/dist/routes/dashboard.d.ts.map +1 -0
  155. package/dist/routes/dashboard.js +15 -0
  156. package/dist/routes/dashboard.js.map +1 -0
  157. package/dist/routes/goals.d.ts +3 -0
  158. package/dist/routes/goals.d.ts.map +1 -0
  159. package/dist/routes/goals.js +95 -0
  160. package/dist/routes/goals.js.map +1 -0
  161. package/dist/routes/health.d.ts +9 -0
  162. package/dist/routes/health.d.ts.map +1 -0
  163. package/dist/routes/health.js +38 -0
  164. package/dist/routes/health.js.map +1 -0
  165. package/dist/routes/index.d.ts +15 -0
  166. package/dist/routes/index.d.ts.map +1 -0
  167. package/dist/routes/index.js +15 -0
  168. package/dist/routes/index.js.map +1 -0
  169. package/dist/routes/issues.d.ts +4 -0
  170. package/dist/routes/issues.d.ts.map +1 -0
  171. package/dist/routes/issues.js +973 -0
  172. package/dist/routes/issues.js.map +1 -0
  173. package/dist/routes/llms.d.ts +3 -0
  174. package/dist/routes/llms.d.ts.map +1 -0
  175. package/dist/routes/llms.js +78 -0
  176. package/dist/routes/llms.js.map +1 -0
  177. package/dist/routes/projects.d.ts +3 -0
  178. package/dist/routes/projects.d.ts.map +1 -0
  179. package/dist/routes/projects.js +253 -0
  180. package/dist/routes/projects.js.map +1 -0
  181. package/dist/routes/secrets.d.ts +3 -0
  182. package/dist/routes/secrets.d.ts.map +1 -0
  183. package/dist/routes/secrets.js +128 -0
  184. package/dist/routes/secrets.js.map +1 -0
  185. package/dist/routes/sidebar-badges.d.ts +3 -0
  186. package/dist/routes/sidebar-badges.d.ts.map +1 -0
  187. package/dist/routes/sidebar-badges.js +47 -0
  188. package/dist/routes/sidebar-badges.js.map +1 -0
  189. package/dist/secrets/external-stub-providers.d.ts +5 -0
  190. package/dist/secrets/external-stub-providers.d.ts.map +1 -0
  191. package/dist/secrets/external-stub-providers.js +21 -0
  192. package/dist/secrets/external-stub-providers.js.map +1 -0
  193. package/dist/secrets/local-encrypted-provider.d.ts +3 -0
  194. package/dist/secrets/local-encrypted-provider.d.ts.map +1 -0
  195. package/dist/secrets/local-encrypted-provider.js +116 -0
  196. package/dist/secrets/local-encrypted-provider.js.map +1 -0
  197. package/dist/secrets/provider-registry.d.ts +5 -0
  198. package/dist/secrets/provider-registry.d.ts.map +1 -0
  199. package/dist/secrets/provider-registry.js +20 -0
  200. package/dist/secrets/provider-registry.js.map +1 -0
  201. package/dist/secrets/types.d.ts +21 -0
  202. package/dist/secrets/types.d.ts.map +1 -0
  203. package/dist/secrets/types.js +2 -0
  204. package/dist/secrets/types.js.map +1 -0
  205. package/dist/services/access.d.ts +81 -0
  206. package/dist/services/access.d.ts.map +1 -0
  207. package/dist/services/access.js +187 -0
  208. package/dist/services/access.js.map +1 -0
  209. package/dist/services/activity-log.d.ts +14 -0
  210. package/dist/services/activity-log.d.ts.map +1 -0
  211. package/dist/services/activity-log.js +32 -0
  212. package/dist/services/activity-log.js.map +1 -0
  213. package/dist/services/activity.d.ts +764 -0
  214. package/dist/services/activity.d.ts.map +1 -0
  215. package/dist/services/activity.js +105 -0
  216. package/dist/services/activity.js.map +1 -0
  217. package/dist/services/agent-permissions.d.ts +6 -0
  218. package/dist/services/agent-permissions.d.ts.map +1 -0
  219. package/dist/services/agent-permissions.js +18 -0
  220. package/dist/services/agent-permissions.js.map +1 -0
  221. package/dist/services/agents.d.ts +1494 -0
  222. package/dist/services/agents.d.ts.map +1 -0
  223. package/dist/services/agents.js +454 -0
  224. package/dist/services/agents.js.map +1 -0
  225. package/dist/services/approvals.d.ts +540 -0
  226. package/dist/services/approvals.d.ts.map +1 -0
  227. package/dist/services/approvals.js +173 -0
  228. package/dist/services/approvals.js.map +1 -0
  229. package/dist/services/assets.d.ts +33 -0
  230. package/dist/services/assets.d.ts.map +1 -0
  231. package/dist/services/assets.js +17 -0
  232. package/dist/services/assets.js.map +1 -0
  233. package/dist/services/companies.d.ts +503 -0
  234. package/dist/services/companies.d.ts.map +1 -0
  235. package/dist/services/companies.js +120 -0
  236. package/dist/services/companies.js.map +1 -0
  237. package/dist/services/company-portability.d.ts +8 -0
  238. package/dist/services/company-portability.d.ts.map +1 -0
  239. package/dist/services/company-portability.js +851 -0
  240. package/dist/services/company-portability.js.map +1 -0
  241. package/dist/services/costs.d.ts +50 -0
  242. package/dist/services/costs.d.ts.map +1 -0
  243. package/dist/services/costs.js +166 -0
  244. package/dist/services/costs.js.map +1 -0
  245. package/dist/services/dashboard.d.ts +21 -0
  246. package/dist/services/dashboard.d.ts.map +1 -0
  247. package/dist/services/dashboard.js +96 -0
  248. package/dist/services/dashboard.js.map +1 -0
  249. package/dist/services/goals.d.ts +407 -0
  250. package/dist/services/goals.d.ts.map +1 -0
  251. package/dist/services/goals.js +29 -0
  252. package/dist/services/goals.js.map +1 -0
  253. package/dist/services/heartbeat.d.ts +1666 -0
  254. package/dist/services/heartbeat.d.ts.map +1 -0
  255. package/dist/services/heartbeat.js +1752 -0
  256. package/dist/services/heartbeat.js.map +1 -0
  257. package/dist/services/index.d.ts +20 -0
  258. package/dist/services/index.d.ts.map +1 -0
  259. package/dist/services/index.js +20 -0
  260. package/dist/services/index.js.map +1 -0
  261. package/dist/services/issue-approvals.d.ts +56 -0
  262. package/dist/services/issue-approvals.d.ts.map +1 -0
  263. package/dist/services/issue-approvals.js +153 -0
  264. package/dist/services/issue-approvals.js.map +1 -0
  265. package/dist/services/issues.d.ts +756 -0
  266. package/dist/services/issues.d.ts.map +1 -0
  267. package/dist/services/issues.js +917 -0
  268. package/dist/services/issues.js.map +1 -0
  269. package/dist/services/live-events.d.ts +12 -0
  270. package/dist/services/live-events.d.ts.map +1 -0
  271. package/dist/services/live-events.js +24 -0
  272. package/dist/services/live-events.js.map +1 -0
  273. package/dist/services/projects.d.ts +66 -0
  274. package/dist/services/projects.d.ts.map +1 -0
  275. package/dist/services/projects.js +472 -0
  276. package/dist/services/projects.js.map +1 -0
  277. package/dist/services/run-log-store.d.ts +34 -0
  278. package/dist/services/run-log-store.d.ts.map +1 -0
  279. package/dist/services/run-log-store.js +112 -0
  280. package/dist/services/run-log-store.js.map +1 -0
  281. package/dist/services/secrets.d.ts +506 -0
  282. package/dist/services/secrets.d.ts.map +1 -0
  283. package/dist/services/secrets.js +284 -0
  284. package/dist/services/secrets.js.map +1 -0
  285. package/dist/services/sidebar-badges.d.ts +9 -0
  286. package/dist/services/sidebar-badges.d.ts.map +1 -0
  287. package/dist/services/sidebar-badges.js +33 -0
  288. package/dist/services/sidebar-badges.js.map +1 -0
  289. package/dist/startup-banner.d.ts +27 -0
  290. package/dist/startup-banner.d.ts.map +1 -0
  291. package/dist/startup-banner.js +112 -0
  292. package/dist/startup-banner.js.map +1 -0
  293. package/dist/storage/index.d.ts +6 -0
  294. package/dist/storage/index.d.ts.map +1 -0
  295. package/dist/storage/index.js +29 -0
  296. package/dist/storage/index.js.map +1 -0
  297. package/dist/storage/local-disk-provider.d.ts +3 -0
  298. package/dist/storage/local-disk-provider.d.ts.map +1 -0
  299. package/dist/storage/local-disk-provider.js +79 -0
  300. package/dist/storage/local-disk-provider.js.map +1 -0
  301. package/dist/storage/provider-registry.d.ts +4 -0
  302. package/dist/storage/provider-registry.d.ts.map +1 -0
  303. package/dist/storage/provider-registry.js +15 -0
  304. package/dist/storage/provider-registry.js.map +1 -0
  305. package/dist/storage/s3-provider.d.ts +11 -0
  306. package/dist/storage/s3-provider.d.ts.map +1 -0
  307. package/dist/storage/s3-provider.js +123 -0
  308. package/dist/storage/s3-provider.js.map +1 -0
  309. package/dist/storage/service.d.ts +3 -0
  310. package/dist/storage/service.d.ts.map +1 -0
  311. package/dist/storage/service.js +120 -0
  312. package/dist/storage/service.js.map +1 -0
  313. package/dist/storage/types.d.ts +55 -0
  314. package/dist/storage/types.d.ts.map +1 -0
  315. package/dist/storage/types.js +2 -0
  316. package/dist/storage/types.js.map +1 -0
  317. package/package.json +62 -0
@@ -0,0 +1,756 @@
1
+ import type { Db } from "@paperclipai/db";
2
+ import { issues, labels } from "@paperclipai/db";
3
+ export interface IssueFilters {
4
+ status?: string;
5
+ assigneeAgentId?: string;
6
+ assigneeUserId?: string;
7
+ projectId?: string;
8
+ labelId?: string;
9
+ q?: string;
10
+ }
11
+ type IssueRow = typeof issues.$inferSelect;
12
+ type IssueLabelRow = typeof labels.$inferSelect;
13
+ type IssueActiveRunRow = {
14
+ id: string;
15
+ status: string;
16
+ agentId: string;
17
+ invocationSource: string;
18
+ triggerDetail: string | null;
19
+ startedAt: Date | null;
20
+ finishedAt: Date | null;
21
+ createdAt: Date;
22
+ };
23
+ type IssueWithLabels = IssueRow & {
24
+ labels: IssueLabelRow[];
25
+ labelIds: string[];
26
+ };
27
+ type IssueWithLabelsAndRun = IssueWithLabels & {
28
+ activeRun: IssueActiveRunRow | null;
29
+ };
30
+ export declare function issueService(db: Db): {
31
+ list: (companyId: string, filters?: IssueFilters) => Promise<IssueWithLabelsAndRun[]>;
32
+ getById: (id: string) => Promise<IssueWithLabels | null>;
33
+ getByIdentifier: (identifier: string) => Promise<IssueWithLabels | null>;
34
+ create: (companyId: string, data: Omit<typeof issues.$inferInsert, "companyId"> & {
35
+ labelIds?: string[];
36
+ }) => Promise<IssueWithLabels>;
37
+ update: (id: string, data: Partial<typeof issues.$inferInsert> & {
38
+ labelIds?: string[];
39
+ }) => Promise<IssueWithLabels | null>;
40
+ remove: (id: string) => Promise<IssueWithLabels | null>;
41
+ checkout: (id: string, agentId: string, expectedStatuses: string[], checkoutRunId: string | null) => Promise<{
42
+ id: string;
43
+ companyId: string;
44
+ projectId: string | null;
45
+ goalId: string | null;
46
+ parentId: string | null;
47
+ title: string;
48
+ description: string | null;
49
+ status: string;
50
+ priority: string;
51
+ assigneeAgentId: string | null;
52
+ assigneeUserId: string | null;
53
+ checkoutRunId: string | null;
54
+ executionRunId: string | null;
55
+ executionAgentNameKey: string | null;
56
+ executionLockedAt: Date | null;
57
+ createdByAgentId: string | null;
58
+ createdByUserId: string | null;
59
+ issueNumber: number | null;
60
+ identifier: string | null;
61
+ requestDepth: number;
62
+ billingCode: string | null;
63
+ assigneeAdapterOverrides: Record<string, unknown> | null;
64
+ startedAt: Date | null;
65
+ completedAt: Date | null;
66
+ cancelledAt: Date | null;
67
+ hiddenAt: Date | null;
68
+ createdAt: Date;
69
+ updatedAt: Date;
70
+ }>;
71
+ assertCheckoutOwner: (id: string, actorAgentId: string, actorRunId: string | null) => Promise<{
72
+ adoptedFromRunId: string | null;
73
+ id: string;
74
+ status: string;
75
+ assigneeAgentId: string | null;
76
+ checkoutRunId: string | null;
77
+ } | {
78
+ adoptedFromRunId: string;
79
+ id: string;
80
+ status: string;
81
+ assigneeAgentId: string | null;
82
+ checkoutRunId: string | null;
83
+ executionRunId: string | null;
84
+ }>;
85
+ release: (id: string, actorAgentId?: string, actorRunId?: string | null) => Promise<IssueWithLabels | null>;
86
+ listLabels: (companyId: string) => Omit<import("drizzle-orm/pg-core").PgSelectBase<"labels", {
87
+ id: import("drizzle-orm/pg-core").PgColumn<{
88
+ name: "id";
89
+ tableName: "labels";
90
+ dataType: "string";
91
+ columnType: "PgUUID";
92
+ data: string;
93
+ driverParam: string;
94
+ notNull: true;
95
+ hasDefault: true;
96
+ isPrimaryKey: true;
97
+ isAutoincrement: false;
98
+ hasRuntimeDefault: false;
99
+ enumValues: undefined;
100
+ baseColumn: never;
101
+ identity: undefined;
102
+ generated: undefined;
103
+ }, {}, {}>;
104
+ companyId: import("drizzle-orm/pg-core").PgColumn<{
105
+ name: "company_id";
106
+ tableName: "labels";
107
+ dataType: "string";
108
+ columnType: "PgUUID";
109
+ data: string;
110
+ driverParam: string;
111
+ notNull: true;
112
+ hasDefault: false;
113
+ isPrimaryKey: false;
114
+ isAutoincrement: false;
115
+ hasRuntimeDefault: false;
116
+ enumValues: undefined;
117
+ baseColumn: never;
118
+ identity: undefined;
119
+ generated: undefined;
120
+ }, {}, {}>;
121
+ name: import("drizzle-orm/pg-core").PgColumn<{
122
+ name: "name";
123
+ tableName: "labels";
124
+ dataType: "string";
125
+ columnType: "PgText";
126
+ data: string;
127
+ driverParam: string;
128
+ notNull: true;
129
+ hasDefault: false;
130
+ isPrimaryKey: false;
131
+ isAutoincrement: false;
132
+ hasRuntimeDefault: false;
133
+ enumValues: [string, ...string[]];
134
+ baseColumn: never;
135
+ identity: undefined;
136
+ generated: undefined;
137
+ }, {}, {}>;
138
+ color: import("drizzle-orm/pg-core").PgColumn<{
139
+ name: "color";
140
+ tableName: "labels";
141
+ dataType: "string";
142
+ columnType: "PgText";
143
+ data: string;
144
+ driverParam: string;
145
+ notNull: true;
146
+ hasDefault: false;
147
+ isPrimaryKey: false;
148
+ isAutoincrement: false;
149
+ hasRuntimeDefault: false;
150
+ enumValues: [string, ...string[]];
151
+ baseColumn: never;
152
+ identity: undefined;
153
+ generated: undefined;
154
+ }, {}, {}>;
155
+ createdAt: import("drizzle-orm/pg-core").PgColumn<{
156
+ name: "created_at";
157
+ tableName: "labels";
158
+ dataType: "date";
159
+ columnType: "PgTimestamp";
160
+ data: Date;
161
+ driverParam: string;
162
+ notNull: true;
163
+ hasDefault: true;
164
+ isPrimaryKey: false;
165
+ isAutoincrement: false;
166
+ hasRuntimeDefault: false;
167
+ enumValues: undefined;
168
+ baseColumn: never;
169
+ identity: undefined;
170
+ generated: undefined;
171
+ }, {}, {}>;
172
+ updatedAt: import("drizzle-orm/pg-core").PgColumn<{
173
+ name: "updated_at";
174
+ tableName: "labels";
175
+ dataType: "date";
176
+ columnType: "PgTimestamp";
177
+ data: Date;
178
+ driverParam: string;
179
+ notNull: true;
180
+ hasDefault: true;
181
+ isPrimaryKey: false;
182
+ isAutoincrement: false;
183
+ hasRuntimeDefault: false;
184
+ enumValues: undefined;
185
+ baseColumn: never;
186
+ identity: undefined;
187
+ generated: undefined;
188
+ }, {}, {}>;
189
+ }, "single", Record<"labels", "not-null">, false, "where" | "orderBy", {
190
+ id: string;
191
+ name: string;
192
+ createdAt: Date;
193
+ updatedAt: Date;
194
+ companyId: string;
195
+ color: string;
196
+ }[], {
197
+ id: import("drizzle-orm/pg-core").PgColumn<{
198
+ name: "id";
199
+ tableName: "labels";
200
+ dataType: "string";
201
+ columnType: "PgUUID";
202
+ data: string;
203
+ driverParam: string;
204
+ notNull: true;
205
+ hasDefault: true;
206
+ isPrimaryKey: true;
207
+ isAutoincrement: false;
208
+ hasRuntimeDefault: false;
209
+ enumValues: undefined;
210
+ baseColumn: never;
211
+ identity: undefined;
212
+ generated: undefined;
213
+ }, {}, {}>;
214
+ companyId: import("drizzle-orm/pg-core").PgColumn<{
215
+ name: "company_id";
216
+ tableName: "labels";
217
+ dataType: "string";
218
+ columnType: "PgUUID";
219
+ data: string;
220
+ driverParam: string;
221
+ notNull: true;
222
+ hasDefault: false;
223
+ isPrimaryKey: false;
224
+ isAutoincrement: false;
225
+ hasRuntimeDefault: false;
226
+ enumValues: undefined;
227
+ baseColumn: never;
228
+ identity: undefined;
229
+ generated: undefined;
230
+ }, {}, {}>;
231
+ name: import("drizzle-orm/pg-core").PgColumn<{
232
+ name: "name";
233
+ tableName: "labels";
234
+ dataType: "string";
235
+ columnType: "PgText";
236
+ data: string;
237
+ driverParam: string;
238
+ notNull: true;
239
+ hasDefault: false;
240
+ isPrimaryKey: false;
241
+ isAutoincrement: false;
242
+ hasRuntimeDefault: false;
243
+ enumValues: [string, ...string[]];
244
+ baseColumn: never;
245
+ identity: undefined;
246
+ generated: undefined;
247
+ }, {}, {}>;
248
+ color: import("drizzle-orm/pg-core").PgColumn<{
249
+ name: "color";
250
+ tableName: "labels";
251
+ dataType: "string";
252
+ columnType: "PgText";
253
+ data: string;
254
+ driverParam: string;
255
+ notNull: true;
256
+ hasDefault: false;
257
+ isPrimaryKey: false;
258
+ isAutoincrement: false;
259
+ hasRuntimeDefault: false;
260
+ enumValues: [string, ...string[]];
261
+ baseColumn: never;
262
+ identity: undefined;
263
+ generated: undefined;
264
+ }, {}, {}>;
265
+ createdAt: import("drizzle-orm/pg-core").PgColumn<{
266
+ name: "created_at";
267
+ tableName: "labels";
268
+ dataType: "date";
269
+ columnType: "PgTimestamp";
270
+ data: Date;
271
+ driverParam: string;
272
+ notNull: true;
273
+ hasDefault: true;
274
+ isPrimaryKey: false;
275
+ isAutoincrement: false;
276
+ hasRuntimeDefault: false;
277
+ enumValues: undefined;
278
+ baseColumn: never;
279
+ identity: undefined;
280
+ generated: undefined;
281
+ }, {}, {}>;
282
+ updatedAt: import("drizzle-orm/pg-core").PgColumn<{
283
+ name: "updated_at";
284
+ tableName: "labels";
285
+ dataType: "date";
286
+ columnType: "PgTimestamp";
287
+ data: Date;
288
+ driverParam: string;
289
+ notNull: true;
290
+ hasDefault: true;
291
+ isPrimaryKey: false;
292
+ isAutoincrement: false;
293
+ hasRuntimeDefault: false;
294
+ enumValues: undefined;
295
+ baseColumn: never;
296
+ identity: undefined;
297
+ generated: undefined;
298
+ }, {}, {}>;
299
+ }>, "where" | "orderBy">;
300
+ getLabelById: (id: string) => Promise<{
301
+ id: string;
302
+ name: string;
303
+ createdAt: Date;
304
+ updatedAt: Date;
305
+ companyId: string;
306
+ color: string;
307
+ }>;
308
+ createLabel: (companyId: string, data: Pick<typeof labels.$inferInsert, "name" | "color">) => Promise<{
309
+ id: string;
310
+ name: string;
311
+ createdAt: Date;
312
+ updatedAt: Date;
313
+ companyId: string;
314
+ color: string;
315
+ }>;
316
+ deleteLabel: (id: string) => Promise<{
317
+ id: string;
318
+ name: string;
319
+ createdAt: Date;
320
+ updatedAt: Date;
321
+ companyId: string;
322
+ color: string;
323
+ }>;
324
+ listComments: (issueId: string) => Omit<import("drizzle-orm/pg-core").PgSelectBase<"issue_comments", {
325
+ id: import("drizzle-orm/pg-core").PgColumn<{
326
+ name: "id";
327
+ tableName: "issue_comments";
328
+ dataType: "string";
329
+ columnType: "PgUUID";
330
+ data: string;
331
+ driverParam: string;
332
+ notNull: true;
333
+ hasDefault: true;
334
+ isPrimaryKey: true;
335
+ isAutoincrement: false;
336
+ hasRuntimeDefault: false;
337
+ enumValues: undefined;
338
+ baseColumn: never;
339
+ identity: undefined;
340
+ generated: undefined;
341
+ }, {}, {}>;
342
+ companyId: import("drizzle-orm/pg-core").PgColumn<{
343
+ name: "company_id";
344
+ tableName: "issue_comments";
345
+ dataType: "string";
346
+ columnType: "PgUUID";
347
+ data: string;
348
+ driverParam: string;
349
+ notNull: true;
350
+ hasDefault: false;
351
+ isPrimaryKey: false;
352
+ isAutoincrement: false;
353
+ hasRuntimeDefault: false;
354
+ enumValues: undefined;
355
+ baseColumn: never;
356
+ identity: undefined;
357
+ generated: undefined;
358
+ }, {}, {}>;
359
+ issueId: import("drizzle-orm/pg-core").PgColumn<{
360
+ name: "issue_id";
361
+ tableName: "issue_comments";
362
+ dataType: "string";
363
+ columnType: "PgUUID";
364
+ data: string;
365
+ driverParam: string;
366
+ notNull: true;
367
+ hasDefault: false;
368
+ isPrimaryKey: false;
369
+ isAutoincrement: false;
370
+ hasRuntimeDefault: false;
371
+ enumValues: undefined;
372
+ baseColumn: never;
373
+ identity: undefined;
374
+ generated: undefined;
375
+ }, {}, {}>;
376
+ authorAgentId: import("drizzle-orm/pg-core").PgColumn<{
377
+ name: "author_agent_id";
378
+ tableName: "issue_comments";
379
+ dataType: "string";
380
+ columnType: "PgUUID";
381
+ data: string;
382
+ driverParam: string;
383
+ notNull: false;
384
+ hasDefault: false;
385
+ isPrimaryKey: false;
386
+ isAutoincrement: false;
387
+ hasRuntimeDefault: false;
388
+ enumValues: undefined;
389
+ baseColumn: never;
390
+ identity: undefined;
391
+ generated: undefined;
392
+ }, {}, {}>;
393
+ authorUserId: import("drizzle-orm/pg-core").PgColumn<{
394
+ name: "author_user_id";
395
+ tableName: "issue_comments";
396
+ dataType: "string";
397
+ columnType: "PgText";
398
+ data: string;
399
+ driverParam: string;
400
+ notNull: false;
401
+ hasDefault: false;
402
+ isPrimaryKey: false;
403
+ isAutoincrement: false;
404
+ hasRuntimeDefault: false;
405
+ enumValues: [string, ...string[]];
406
+ baseColumn: never;
407
+ identity: undefined;
408
+ generated: undefined;
409
+ }, {}, {}>;
410
+ body: import("drizzle-orm/pg-core").PgColumn<{
411
+ name: "body";
412
+ tableName: "issue_comments";
413
+ dataType: "string";
414
+ columnType: "PgText";
415
+ data: string;
416
+ driverParam: string;
417
+ notNull: true;
418
+ hasDefault: false;
419
+ isPrimaryKey: false;
420
+ isAutoincrement: false;
421
+ hasRuntimeDefault: false;
422
+ enumValues: [string, ...string[]];
423
+ baseColumn: never;
424
+ identity: undefined;
425
+ generated: undefined;
426
+ }, {}, {}>;
427
+ createdAt: import("drizzle-orm/pg-core").PgColumn<{
428
+ name: "created_at";
429
+ tableName: "issue_comments";
430
+ dataType: "date";
431
+ columnType: "PgTimestamp";
432
+ data: Date;
433
+ driverParam: string;
434
+ notNull: true;
435
+ hasDefault: true;
436
+ isPrimaryKey: false;
437
+ isAutoincrement: false;
438
+ hasRuntimeDefault: false;
439
+ enumValues: undefined;
440
+ baseColumn: never;
441
+ identity: undefined;
442
+ generated: undefined;
443
+ }, {}, {}>;
444
+ updatedAt: import("drizzle-orm/pg-core").PgColumn<{
445
+ name: "updated_at";
446
+ tableName: "issue_comments";
447
+ dataType: "date";
448
+ columnType: "PgTimestamp";
449
+ data: Date;
450
+ driverParam: string;
451
+ notNull: true;
452
+ hasDefault: true;
453
+ isPrimaryKey: false;
454
+ isAutoincrement: false;
455
+ hasRuntimeDefault: false;
456
+ enumValues: undefined;
457
+ baseColumn: never;
458
+ identity: undefined;
459
+ generated: undefined;
460
+ }, {}, {}>;
461
+ }, "single", Record<"issue_comments", "not-null">, false, "where" | "orderBy", {
462
+ id: string;
463
+ createdAt: Date;
464
+ updatedAt: Date;
465
+ companyId: string;
466
+ issueId: string;
467
+ authorAgentId: string | null;
468
+ authorUserId: string | null;
469
+ body: string;
470
+ }[], {
471
+ id: import("drizzle-orm/pg-core").PgColumn<{
472
+ name: "id";
473
+ tableName: "issue_comments";
474
+ dataType: "string";
475
+ columnType: "PgUUID";
476
+ data: string;
477
+ driverParam: string;
478
+ notNull: true;
479
+ hasDefault: true;
480
+ isPrimaryKey: true;
481
+ isAutoincrement: false;
482
+ hasRuntimeDefault: false;
483
+ enumValues: undefined;
484
+ baseColumn: never;
485
+ identity: undefined;
486
+ generated: undefined;
487
+ }, {}, {}>;
488
+ companyId: import("drizzle-orm/pg-core").PgColumn<{
489
+ name: "company_id";
490
+ tableName: "issue_comments";
491
+ dataType: "string";
492
+ columnType: "PgUUID";
493
+ data: string;
494
+ driverParam: string;
495
+ notNull: true;
496
+ hasDefault: false;
497
+ isPrimaryKey: false;
498
+ isAutoincrement: false;
499
+ hasRuntimeDefault: false;
500
+ enumValues: undefined;
501
+ baseColumn: never;
502
+ identity: undefined;
503
+ generated: undefined;
504
+ }, {}, {}>;
505
+ issueId: import("drizzle-orm/pg-core").PgColumn<{
506
+ name: "issue_id";
507
+ tableName: "issue_comments";
508
+ dataType: "string";
509
+ columnType: "PgUUID";
510
+ data: string;
511
+ driverParam: string;
512
+ notNull: true;
513
+ hasDefault: false;
514
+ isPrimaryKey: false;
515
+ isAutoincrement: false;
516
+ hasRuntimeDefault: false;
517
+ enumValues: undefined;
518
+ baseColumn: never;
519
+ identity: undefined;
520
+ generated: undefined;
521
+ }, {}, {}>;
522
+ authorAgentId: import("drizzle-orm/pg-core").PgColumn<{
523
+ name: "author_agent_id";
524
+ tableName: "issue_comments";
525
+ dataType: "string";
526
+ columnType: "PgUUID";
527
+ data: string;
528
+ driverParam: string;
529
+ notNull: false;
530
+ hasDefault: false;
531
+ isPrimaryKey: false;
532
+ isAutoincrement: false;
533
+ hasRuntimeDefault: false;
534
+ enumValues: undefined;
535
+ baseColumn: never;
536
+ identity: undefined;
537
+ generated: undefined;
538
+ }, {}, {}>;
539
+ authorUserId: import("drizzle-orm/pg-core").PgColumn<{
540
+ name: "author_user_id";
541
+ tableName: "issue_comments";
542
+ dataType: "string";
543
+ columnType: "PgText";
544
+ data: string;
545
+ driverParam: string;
546
+ notNull: false;
547
+ hasDefault: false;
548
+ isPrimaryKey: false;
549
+ isAutoincrement: false;
550
+ hasRuntimeDefault: false;
551
+ enumValues: [string, ...string[]];
552
+ baseColumn: never;
553
+ identity: undefined;
554
+ generated: undefined;
555
+ }, {}, {}>;
556
+ body: import("drizzle-orm/pg-core").PgColumn<{
557
+ name: "body";
558
+ tableName: "issue_comments";
559
+ dataType: "string";
560
+ columnType: "PgText";
561
+ data: string;
562
+ driverParam: string;
563
+ notNull: true;
564
+ hasDefault: false;
565
+ isPrimaryKey: false;
566
+ isAutoincrement: false;
567
+ hasRuntimeDefault: false;
568
+ enumValues: [string, ...string[]];
569
+ baseColumn: never;
570
+ identity: undefined;
571
+ generated: undefined;
572
+ }, {}, {}>;
573
+ createdAt: import("drizzle-orm/pg-core").PgColumn<{
574
+ name: "created_at";
575
+ tableName: "issue_comments";
576
+ dataType: "date";
577
+ columnType: "PgTimestamp";
578
+ data: Date;
579
+ driverParam: string;
580
+ notNull: true;
581
+ hasDefault: true;
582
+ isPrimaryKey: false;
583
+ isAutoincrement: false;
584
+ hasRuntimeDefault: false;
585
+ enumValues: undefined;
586
+ baseColumn: never;
587
+ identity: undefined;
588
+ generated: undefined;
589
+ }, {}, {}>;
590
+ updatedAt: import("drizzle-orm/pg-core").PgColumn<{
591
+ name: "updated_at";
592
+ tableName: "issue_comments";
593
+ dataType: "date";
594
+ columnType: "PgTimestamp";
595
+ data: Date;
596
+ driverParam: string;
597
+ notNull: true;
598
+ hasDefault: true;
599
+ isPrimaryKey: false;
600
+ isAutoincrement: false;
601
+ hasRuntimeDefault: false;
602
+ enumValues: undefined;
603
+ baseColumn: never;
604
+ identity: undefined;
605
+ generated: undefined;
606
+ }, {}, {}>;
607
+ }>, "where" | "orderBy">;
608
+ addComment: (issueId: string, body: string, actor: {
609
+ agentId?: string;
610
+ userId?: string;
611
+ }) => Promise<{
612
+ id: string;
613
+ createdAt: Date;
614
+ updatedAt: Date;
615
+ companyId: string;
616
+ issueId: string;
617
+ authorAgentId: string | null;
618
+ authorUserId: string | null;
619
+ body: string;
620
+ }>;
621
+ createAttachment: (input: {
622
+ issueId: string;
623
+ issueCommentId?: string | null;
624
+ provider: string;
625
+ objectKey: string;
626
+ contentType: string;
627
+ byteSize: number;
628
+ sha256: string;
629
+ originalFilename?: string | null;
630
+ createdByAgentId?: string | null;
631
+ createdByUserId?: string | null;
632
+ }) => Promise<{
633
+ id: string;
634
+ companyId: string;
635
+ issueId: string;
636
+ issueCommentId: string | null;
637
+ assetId: string;
638
+ provider: string;
639
+ objectKey: string;
640
+ contentType: string;
641
+ byteSize: number;
642
+ sha256: string;
643
+ originalFilename: string | null;
644
+ createdByAgentId: string | null;
645
+ createdByUserId: string | null;
646
+ createdAt: Date;
647
+ updatedAt: Date;
648
+ }>;
649
+ listAttachments: (issueId: string) => Promise<{
650
+ id: string;
651
+ companyId: string;
652
+ issueId: string;
653
+ issueCommentId: string | null;
654
+ assetId: string;
655
+ provider: string;
656
+ objectKey: string;
657
+ contentType: string;
658
+ byteSize: number;
659
+ sha256: string;
660
+ originalFilename: string | null;
661
+ createdByAgentId: string | null;
662
+ createdByUserId: string | null;
663
+ createdAt: Date;
664
+ updatedAt: Date;
665
+ }[]>;
666
+ getAttachmentById: (id: string) => Promise<{
667
+ id: string;
668
+ companyId: string;
669
+ issueId: string;
670
+ issueCommentId: string | null;
671
+ assetId: string;
672
+ provider: string;
673
+ objectKey: string;
674
+ contentType: string;
675
+ byteSize: number;
676
+ sha256: string;
677
+ originalFilename: string | null;
678
+ createdByAgentId: string | null;
679
+ createdByUserId: string | null;
680
+ createdAt: Date;
681
+ updatedAt: Date;
682
+ }>;
683
+ removeAttachment: (id: string) => Promise<{
684
+ id: string;
685
+ companyId: string;
686
+ issueId: string;
687
+ issueCommentId: string | null;
688
+ assetId: string;
689
+ provider: string;
690
+ objectKey: string;
691
+ contentType: string;
692
+ byteSize: number;
693
+ sha256: string;
694
+ originalFilename: string | null;
695
+ createdByAgentId: string | null;
696
+ createdByUserId: string | null;
697
+ createdAt: Date;
698
+ updatedAt: Date;
699
+ } | null>;
700
+ findMentionedAgents: (companyId: string, body: string) => Promise<string[]>;
701
+ findMentionedProjectIds: (issueId: string) => Promise<string[]>;
702
+ getAncestors: (issueId: string) => Promise<{
703
+ project: {
704
+ id: string;
705
+ name: string;
706
+ description: string | null;
707
+ status: string;
708
+ goalId: string | null;
709
+ workspaces: Array<{
710
+ id: string;
711
+ companyId: string;
712
+ projectId: string;
713
+ name: string;
714
+ cwd: string | null;
715
+ repoUrl: string | null;
716
+ repoRef: string | null;
717
+ metadata: Record<string, unknown> | null;
718
+ isPrimary: boolean;
719
+ createdAt: Date;
720
+ updatedAt: Date;
721
+ }>;
722
+ primaryWorkspace: {
723
+ id: string;
724
+ companyId: string;
725
+ projectId: string;
726
+ name: string;
727
+ cwd: string | null;
728
+ repoUrl: string | null;
729
+ repoRef: string | null;
730
+ metadata: Record<string, unknown> | null;
731
+ isPrimary: boolean;
732
+ createdAt: Date;
733
+ updatedAt: Date;
734
+ } | null;
735
+ } | null;
736
+ goal: {
737
+ id: string;
738
+ title: string;
739
+ description: string | null;
740
+ level: string;
741
+ status: string;
742
+ } | null;
743
+ id: string;
744
+ identifier: string | null;
745
+ title: string;
746
+ description: string | null;
747
+ status: string;
748
+ priority: string;
749
+ assigneeAgentId: string | null;
750
+ projectId: string | null;
751
+ goalId: string | null;
752
+ }[]>;
753
+ staleCount: (companyId: string, minutes?: number) => Promise<number>;
754
+ };
755
+ export {};
756
+ //# sourceMappingURL=issues.d.ts.map