@paperclipai/shared 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 (145) hide show
  1. package/dist/agent-url-key.d.ts +4 -0
  2. package/dist/agent-url-key.d.ts.map +1 -0
  3. package/dist/agent-url-key.js +22 -0
  4. package/dist/agent-url-key.js.map +1 -0
  5. package/dist/api.d.ts +20 -0
  6. package/dist/api.d.ts.map +1 -0
  7. package/dist/api.js +20 -0
  8. package/dist/api.js.map +1 -0
  9. package/dist/config-schema.d.ts +571 -0
  10. package/dist/config-schema.d.ts.map +1 -0
  11. package/dist/config-schema.js +129 -0
  12. package/dist/config-schema.js.map +1 -0
  13. package/dist/constants.d.ts +62 -0
  14. package/dist/constants.d.ts.map +1 -0
  15. package/dist/constants.js +165 -0
  16. package/dist/constants.js.map +1 -0
  17. package/dist/index.d.ts +9 -0
  18. package/dist/index.d.ts.map +1 -0
  19. package/dist/index.js +8 -0
  20. package/dist/index.js.map +1 -0
  21. package/dist/project-mentions.d.ts +9 -0
  22. package/dist/project-mentions.d.ts.map +1 -0
  23. package/dist/project-mentions.js +71 -0
  24. package/dist/project-mentions.js.map +1 -0
  25. package/dist/project-url-key.d.ts +3 -0
  26. package/dist/project-url-key.d.ts.map +1 -0
  27. package/dist/project-url-key.js +16 -0
  28. package/dist/project-url-key.js.map +1 -0
  29. package/dist/types/access.d.ts +67 -0
  30. package/dist/types/access.d.ts.map +1 -0
  31. package/dist/types/access.js +2 -0
  32. package/dist/types/access.js.map +1 -0
  33. package/dist/types/activity.d.ts +14 -0
  34. package/dist/types/activity.d.ts.map +1 -0
  35. package/dist/types/activity.js +2 -0
  36. package/dist/types/activity.js.map +1 -0
  37. package/dist/types/agent.d.ts +61 -0
  38. package/dist/types/agent.d.ts.map +1 -0
  39. package/dist/types/agent.js +2 -0
  40. package/dist/types/agent.js.map +1 -0
  41. package/dist/types/approval.d.ts +26 -0
  42. package/dist/types/approval.d.ts.map +1 -0
  43. package/dist/types/approval.js +2 -0
  44. package/dist/types/approval.js.map +1 -0
  45. package/dist/types/asset.d.ts +16 -0
  46. package/dist/types/asset.d.ts.map +1 -0
  47. package/dist/types/asset.js +2 -0
  48. package/dist/types/asset.js.map +1 -0
  49. package/dist/types/company-portability.d.ts +120 -0
  50. package/dist/types/company-portability.d.ts.map +1 -0
  51. package/dist/types/company-portability.js +2 -0
  52. package/dist/types/company-portability.js.map +1 -0
  53. package/dist/types/company.d.ts +16 -0
  54. package/dist/types/company.d.ts.map +1 -0
  55. package/dist/types/company.js +2 -0
  56. package/dist/types/company.js.map +1 -0
  57. package/dist/types/cost.d.ts +35 -0
  58. package/dist/types/cost.d.ts.map +1 -0
  59. package/dist/types/cost.js +2 -0
  60. package/dist/types/cost.js.map +1 -0
  61. package/dist/types/dashboard.d.ts +23 -0
  62. package/dist/types/dashboard.d.ts.map +1 -0
  63. package/dist/types/dashboard.js +2 -0
  64. package/dist/types/dashboard.js.map +1 -0
  65. package/dist/types/goal.d.ts +14 -0
  66. package/dist/types/goal.d.ts.map +1 -0
  67. package/dist/types/goal.js +2 -0
  68. package/dist/types/goal.js.map +1 -0
  69. package/dist/types/heartbeat.d.ts +98 -0
  70. package/dist/types/heartbeat.d.ts.map +1 -0
  71. package/dist/types/heartbeat.js +2 -0
  72. package/dist/types/heartbeat.js.map +1 -0
  73. package/dist/types/index.d.ts +17 -0
  74. package/dist/types/index.d.ts.map +1 -0
  75. package/dist/types/index.js +2 -0
  76. package/dist/types/index.js.map +1 -0
  77. package/dist/types/issue.d.ts +110 -0
  78. package/dist/types/issue.d.ts.map +1 -0
  79. package/dist/types/issue.js +2 -0
  80. package/dist/types/issue.js.map +1 -0
  81. package/dist/types/live.d.ts +9 -0
  82. package/dist/types/live.d.ts.map +1 -0
  83. package/dist/types/live.js +2 -0
  84. package/dist/types/live.js.map +1 -0
  85. package/dist/types/project.d.ts +39 -0
  86. package/dist/types/project.d.ts.map +1 -0
  87. package/dist/types/project.js +2 -0
  88. package/dist/types/project.js.map +1 -0
  89. package/dist/types/secrets.d.ts +32 -0
  90. package/dist/types/secrets.d.ts.map +1 -0
  91. package/dist/types/secrets.js +2 -0
  92. package/dist/types/secrets.js.map +1 -0
  93. package/dist/types/sidebar-badges.d.ts +7 -0
  94. package/dist/types/sidebar-badges.d.ts.map +1 -0
  95. package/dist/types/sidebar-badges.js +2 -0
  96. package/dist/types/sidebar-badges.js.map +1 -0
  97. package/dist/validators/access.d.ts +86 -0
  98. package/dist/validators/access.d.ts.map +1 -0
  99. package/dist/validators/access.js +31 -0
  100. package/dist/validators/access.js.map +1 -0
  101. package/dist/validators/agent.d.ts +229 -0
  102. package/dist/validators/agent.d.ts.map +1 -0
  103. package/dist/validators/agent.js +69 -0
  104. package/dist/validators/agent.js.map +1 -0
  105. package/dist/validators/approval.d.ts +57 -0
  106. package/dist/validators/approval.d.ts.map +1 -0
  107. package/dist/validators/approval.js +23 -0
  108. package/dist/validators/approval.js.map +1 -0
  109. package/dist/validators/asset.d.ts +10 -0
  110. package/dist/validators/asset.d.ts.map +1 -0
  111. package/dist/validators/asset.js +11 -0
  112. package/dist/validators/asset.js.map +1 -0
  113. package/dist/validators/company-portability.d.ts +1535 -0
  114. package/dist/validators/company-portability.d.ts.map +1 -0
  115. package/dist/validators/company-portability.js +95 -0
  116. package/dist/validators/company-portability.js.map +1 -0
  117. package/dist/validators/company.d.ts +43 -0
  118. package/dist/validators/company.d.ts.map +1 -0
  119. package/dist/validators/company.js +16 -0
  120. package/dist/validators/company.js.map +1 -0
  121. package/dist/validators/cost.d.ts +48 -0
  122. package/dist/validators/cost.d.ts.map +1 -0
  123. package/dist/validators/cost.js +18 -0
  124. package/dist/validators/cost.js.map +1 -0
  125. package/dist/validators/goal.d.ts +48 -0
  126. package/dist/validators/goal.d.ts.map +1 -0
  127. package/dist/validators/goal.js +12 -0
  128. package/dist/validators/goal.js.map +1 -0
  129. package/dist/validators/index.d.ts +12 -0
  130. package/dist/validators/index.d.ts.map +1 -0
  131. package/dist/validators/index.js +12 -0
  132. package/dist/validators/index.js.map +1 -0
  133. package/dist/validators/issue.d.ts +189 -0
  134. package/dist/validators/issue.d.ts.map +1 -0
  135. package/dist/validators/issue.js +47 -0
  136. package/dist/validators/issue.js.map +1 -0
  137. package/dist/validators/project.d.ts +179 -0
  138. package/dist/validators/project.d.ts.map +1 -0
  139. package/dist/validators/project.js +45 -0
  140. package/dist/validators/project.js.map +1 -0
  141. package/dist/validators/secret.d.ts +114 -0
  142. package/dist/validators/secret.d.ts.map +1 -0
  143. package/dist/validators/secret.js +35 -0
  144. package/dist/validators/secret.js.map +1 -0
  145. package/package.json +34 -0
@@ -0,0 +1,4 @@
1
+ export declare function isUuidLike(value: string | null | undefined): boolean;
2
+ export declare function normalizeAgentUrlKey(value: string | null | undefined): string | null;
3
+ export declare function deriveAgentUrlKey(name: string | null | undefined, fallback?: string | null): string;
4
+ //# sourceMappingURL=agent-url-key.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"agent-url-key.d.ts","sourceRoot":"","sources":["../src/agent-url-key.ts"],"names":[],"mappings":"AAIA,wBAAgB,UAAU,CAAC,KAAK,EAAE,MAAM,GAAG,IAAI,GAAG,SAAS,GAAG,OAAO,CAGpE;AAED,wBAAgB,oBAAoB,CAAC,KAAK,EAAE,MAAM,GAAG,IAAI,GAAG,SAAS,GAAG,MAAM,GAAG,IAAI,CAQpF;AAED,wBAAgB,iBAAiB,CAAC,IAAI,EAAE,MAAM,GAAG,IAAI,GAAG,SAAS,EAAE,QAAQ,CAAC,EAAE,MAAM,GAAG,IAAI,GAAG,MAAM,CAEnG"}
@@ -0,0 +1,22 @@
1
+ const AGENT_URL_KEY_DELIM_RE = /[^a-z0-9]+/g;
2
+ const AGENT_URL_KEY_TRIM_RE = /^-+|-+$/g;
3
+ const UUID_RE = /^[0-9a-f]{8}-[0-9a-f]{4}-[1-5][0-9a-f]{3}-[89ab][0-9a-f]{3}-[0-9a-f]{12}$/i;
4
+ export function isUuidLike(value) {
5
+ if (typeof value !== "string")
6
+ return false;
7
+ return UUID_RE.test(value.trim());
8
+ }
9
+ export function normalizeAgentUrlKey(value) {
10
+ if (typeof value !== "string")
11
+ return null;
12
+ const normalized = value
13
+ .trim()
14
+ .toLowerCase()
15
+ .replace(AGENT_URL_KEY_DELIM_RE, "-")
16
+ .replace(AGENT_URL_KEY_TRIM_RE, "");
17
+ return normalized.length > 0 ? normalized : null;
18
+ }
19
+ export function deriveAgentUrlKey(name, fallback) {
20
+ return normalizeAgentUrlKey(name) ?? normalizeAgentUrlKey(fallback) ?? "agent";
21
+ }
22
+ //# sourceMappingURL=agent-url-key.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"agent-url-key.js","sourceRoot":"","sources":["../src/agent-url-key.ts"],"names":[],"mappings":"AAAA,MAAM,sBAAsB,GAAG,aAAa,CAAC;AAC7C,MAAM,qBAAqB,GAAG,UAAU,CAAC;AACzC,MAAM,OAAO,GAAG,4EAA4E,CAAC;AAE7F,MAAM,UAAU,UAAU,CAAC,KAAgC;IACzD,IAAI,OAAO,KAAK,KAAK,QAAQ;QAAE,OAAO,KAAK,CAAC;IAC5C,OAAO,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,EAAE,CAAC,CAAC;AACpC,CAAC;AAED,MAAM,UAAU,oBAAoB,CAAC,KAAgC;IACnE,IAAI,OAAO,KAAK,KAAK,QAAQ;QAAE,OAAO,IAAI,CAAC;IAC3C,MAAM,UAAU,GAAG,KAAK;SACrB,IAAI,EAAE;SACN,WAAW,EAAE;SACb,OAAO,CAAC,sBAAsB,EAAE,GAAG,CAAC;SACpC,OAAO,CAAC,qBAAqB,EAAE,EAAE,CAAC,CAAC;IACtC,OAAO,UAAU,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,IAAI,CAAC;AACnD,CAAC;AAED,MAAM,UAAU,iBAAiB,CAAC,IAA+B,EAAE,QAAwB;IACzF,OAAO,oBAAoB,CAAC,IAAI,CAAC,IAAI,oBAAoB,CAAC,QAAQ,CAAC,IAAI,OAAO,CAAC;AACjF,CAAC"}
package/dist/api.d.ts ADDED
@@ -0,0 +1,20 @@
1
+ export declare const API_PREFIX = "/api";
2
+ export declare const API: {
3
+ readonly health: "/api/health";
4
+ readonly companies: "/api/companies";
5
+ readonly agents: "/api/agents";
6
+ readonly projects: "/api/projects";
7
+ readonly issues: "/api/issues";
8
+ readonly goals: "/api/goals";
9
+ readonly approvals: "/api/approvals";
10
+ readonly secrets: "/api/secrets";
11
+ readonly costs: "/api/costs";
12
+ readonly activity: "/api/activity";
13
+ readonly dashboard: "/api/dashboard";
14
+ readonly sidebarBadges: "/api/sidebar-badges";
15
+ readonly invites: "/api/invites";
16
+ readonly joinRequests: "/api/join-requests";
17
+ readonly members: "/api/members";
18
+ readonly admin: "/api/admin";
19
+ };
20
+ //# sourceMappingURL=api.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"api.d.ts","sourceRoot":"","sources":["../src/api.ts"],"names":[],"mappings":"AAAA,eAAO,MAAM,UAAU,SAAS,CAAC;AAEjC,eAAO,MAAM,GAAG;;;;;;;;;;;;;;;;;CAiBN,CAAC"}
package/dist/api.js ADDED
@@ -0,0 +1,20 @@
1
+ export const API_PREFIX = "/api";
2
+ export const API = {
3
+ health: `${API_PREFIX}/health`,
4
+ companies: `${API_PREFIX}/companies`,
5
+ agents: `${API_PREFIX}/agents`,
6
+ projects: `${API_PREFIX}/projects`,
7
+ issues: `${API_PREFIX}/issues`,
8
+ goals: `${API_PREFIX}/goals`,
9
+ approvals: `${API_PREFIX}/approvals`,
10
+ secrets: `${API_PREFIX}/secrets`,
11
+ costs: `${API_PREFIX}/costs`,
12
+ activity: `${API_PREFIX}/activity`,
13
+ dashboard: `${API_PREFIX}/dashboard`,
14
+ sidebarBadges: `${API_PREFIX}/sidebar-badges`,
15
+ invites: `${API_PREFIX}/invites`,
16
+ joinRequests: `${API_PREFIX}/join-requests`,
17
+ members: `${API_PREFIX}/members`,
18
+ admin: `${API_PREFIX}/admin`,
19
+ };
20
+ //# sourceMappingURL=api.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"api.js","sourceRoot":"","sources":["../src/api.ts"],"names":[],"mappings":"AAAA,MAAM,CAAC,MAAM,UAAU,GAAG,MAAM,CAAC;AAEjC,MAAM,CAAC,MAAM,GAAG,GAAG;IACjB,MAAM,EAAE,GAAG,UAAU,SAAS;IAC9B,SAAS,EAAE,GAAG,UAAU,YAAY;IACpC,MAAM,EAAE,GAAG,UAAU,SAAS;IAC9B,QAAQ,EAAE,GAAG,UAAU,WAAW;IAClC,MAAM,EAAE,GAAG,UAAU,SAAS;IAC9B,KAAK,EAAE,GAAG,UAAU,QAAQ;IAC5B,SAAS,EAAE,GAAG,UAAU,YAAY;IACpC,OAAO,EAAE,GAAG,UAAU,UAAU;IAChC,KAAK,EAAE,GAAG,UAAU,QAAQ;IAC5B,QAAQ,EAAE,GAAG,UAAU,WAAW;IAClC,SAAS,EAAE,GAAG,UAAU,YAAY;IACpC,aAAa,EAAE,GAAG,UAAU,iBAAiB;IAC7C,OAAO,EAAE,GAAG,UAAU,UAAU;IAChC,YAAY,EAAE,GAAG,UAAU,gBAAgB;IAC3C,OAAO,EAAE,GAAG,UAAU,UAAU;IAChC,KAAK,EAAE,GAAG,UAAU,QAAQ;CACpB,CAAC"}
@@ -0,0 +1,571 @@
1
+ import { z } from "zod";
2
+ export declare const configMetaSchema: z.ZodObject<{
3
+ version: z.ZodLiteral<1>;
4
+ updatedAt: z.ZodString;
5
+ source: z.ZodEnum<["onboard", "configure", "doctor"]>;
6
+ }, "strip", z.ZodTypeAny, {
7
+ version: 1;
8
+ updatedAt: string;
9
+ source: "onboard" | "configure" | "doctor";
10
+ }, {
11
+ version: 1;
12
+ updatedAt: string;
13
+ source: "onboard" | "configure" | "doctor";
14
+ }>;
15
+ export declare const llmConfigSchema: z.ZodObject<{
16
+ provider: z.ZodEnum<["claude", "openai"]>;
17
+ apiKey: z.ZodOptional<z.ZodString>;
18
+ }, "strip", z.ZodTypeAny, {
19
+ provider: "claude" | "openai";
20
+ apiKey?: string | undefined;
21
+ }, {
22
+ provider: "claude" | "openai";
23
+ apiKey?: string | undefined;
24
+ }>;
25
+ export declare const databaseConfigSchema: z.ZodObject<{
26
+ mode: z.ZodDefault<z.ZodEnum<["embedded-postgres", "postgres"]>>;
27
+ connectionString: z.ZodOptional<z.ZodString>;
28
+ embeddedPostgresDataDir: z.ZodDefault<z.ZodString>;
29
+ embeddedPostgresPort: z.ZodDefault<z.ZodNumber>;
30
+ }, "strip", z.ZodTypeAny, {
31
+ mode: "embedded-postgres" | "postgres";
32
+ embeddedPostgresDataDir: string;
33
+ embeddedPostgresPort: number;
34
+ connectionString?: string | undefined;
35
+ }, {
36
+ mode?: "embedded-postgres" | "postgres" | undefined;
37
+ connectionString?: string | undefined;
38
+ embeddedPostgresDataDir?: string | undefined;
39
+ embeddedPostgresPort?: number | undefined;
40
+ }>;
41
+ export declare const loggingConfigSchema: z.ZodObject<{
42
+ mode: z.ZodEnum<["file", "cloud"]>;
43
+ logDir: z.ZodDefault<z.ZodString>;
44
+ }, "strip", z.ZodTypeAny, {
45
+ mode: "file" | "cloud";
46
+ logDir: string;
47
+ }, {
48
+ mode: "file" | "cloud";
49
+ logDir?: string | undefined;
50
+ }>;
51
+ export declare const serverConfigSchema: z.ZodObject<{
52
+ deploymentMode: z.ZodDefault<z.ZodEnum<["local_trusted", "authenticated"]>>;
53
+ exposure: z.ZodDefault<z.ZodEnum<["private", "public"]>>;
54
+ host: z.ZodDefault<z.ZodString>;
55
+ port: z.ZodDefault<z.ZodNumber>;
56
+ allowedHostnames: z.ZodDefault<z.ZodArray<z.ZodString, "many">>;
57
+ serveUi: z.ZodDefault<z.ZodBoolean>;
58
+ }, "strip", z.ZodTypeAny, {
59
+ deploymentMode: "local_trusted" | "authenticated";
60
+ exposure: "private" | "public";
61
+ host: string;
62
+ port: number;
63
+ allowedHostnames: string[];
64
+ serveUi: boolean;
65
+ }, {
66
+ deploymentMode?: "local_trusted" | "authenticated" | undefined;
67
+ exposure?: "private" | "public" | undefined;
68
+ host?: string | undefined;
69
+ port?: number | undefined;
70
+ allowedHostnames?: string[] | undefined;
71
+ serveUi?: boolean | undefined;
72
+ }>;
73
+ export declare const authConfigSchema: z.ZodObject<{
74
+ baseUrlMode: z.ZodDefault<z.ZodEnum<["auto", "explicit"]>>;
75
+ publicBaseUrl: z.ZodOptional<z.ZodString>;
76
+ }, "strip", z.ZodTypeAny, {
77
+ baseUrlMode: "auto" | "explicit";
78
+ publicBaseUrl?: string | undefined;
79
+ }, {
80
+ baseUrlMode?: "auto" | "explicit" | undefined;
81
+ publicBaseUrl?: string | undefined;
82
+ }>;
83
+ export declare const storageLocalDiskConfigSchema: z.ZodObject<{
84
+ baseDir: z.ZodDefault<z.ZodString>;
85
+ }, "strip", z.ZodTypeAny, {
86
+ baseDir: string;
87
+ }, {
88
+ baseDir?: string | undefined;
89
+ }>;
90
+ export declare const storageS3ConfigSchema: z.ZodObject<{
91
+ bucket: z.ZodDefault<z.ZodString>;
92
+ region: z.ZodDefault<z.ZodString>;
93
+ endpoint: z.ZodOptional<z.ZodString>;
94
+ prefix: z.ZodDefault<z.ZodString>;
95
+ forcePathStyle: z.ZodDefault<z.ZodBoolean>;
96
+ }, "strip", z.ZodTypeAny, {
97
+ bucket: string;
98
+ region: string;
99
+ prefix: string;
100
+ forcePathStyle: boolean;
101
+ endpoint?: string | undefined;
102
+ }, {
103
+ bucket?: string | undefined;
104
+ region?: string | undefined;
105
+ endpoint?: string | undefined;
106
+ prefix?: string | undefined;
107
+ forcePathStyle?: boolean | undefined;
108
+ }>;
109
+ export declare const storageConfigSchema: z.ZodObject<{
110
+ provider: z.ZodDefault<z.ZodEnum<["local_disk", "s3"]>>;
111
+ localDisk: z.ZodDefault<z.ZodObject<{
112
+ baseDir: z.ZodDefault<z.ZodString>;
113
+ }, "strip", z.ZodTypeAny, {
114
+ baseDir: string;
115
+ }, {
116
+ baseDir?: string | undefined;
117
+ }>>;
118
+ s3: z.ZodDefault<z.ZodObject<{
119
+ bucket: z.ZodDefault<z.ZodString>;
120
+ region: z.ZodDefault<z.ZodString>;
121
+ endpoint: z.ZodOptional<z.ZodString>;
122
+ prefix: z.ZodDefault<z.ZodString>;
123
+ forcePathStyle: z.ZodDefault<z.ZodBoolean>;
124
+ }, "strip", z.ZodTypeAny, {
125
+ bucket: string;
126
+ region: string;
127
+ prefix: string;
128
+ forcePathStyle: boolean;
129
+ endpoint?: string | undefined;
130
+ }, {
131
+ bucket?: string | undefined;
132
+ region?: string | undefined;
133
+ endpoint?: string | undefined;
134
+ prefix?: string | undefined;
135
+ forcePathStyle?: boolean | undefined;
136
+ }>>;
137
+ }, "strip", z.ZodTypeAny, {
138
+ s3: {
139
+ bucket: string;
140
+ region: string;
141
+ prefix: string;
142
+ forcePathStyle: boolean;
143
+ endpoint?: string | undefined;
144
+ };
145
+ provider: "local_disk" | "s3";
146
+ localDisk: {
147
+ baseDir: string;
148
+ };
149
+ }, {
150
+ s3?: {
151
+ bucket?: string | undefined;
152
+ region?: string | undefined;
153
+ endpoint?: string | undefined;
154
+ prefix?: string | undefined;
155
+ forcePathStyle?: boolean | undefined;
156
+ } | undefined;
157
+ provider?: "local_disk" | "s3" | undefined;
158
+ localDisk?: {
159
+ baseDir?: string | undefined;
160
+ } | undefined;
161
+ }>;
162
+ export declare const secretsLocalEncryptedConfigSchema: z.ZodObject<{
163
+ keyFilePath: z.ZodDefault<z.ZodString>;
164
+ }, "strip", z.ZodTypeAny, {
165
+ keyFilePath: string;
166
+ }, {
167
+ keyFilePath?: string | undefined;
168
+ }>;
169
+ export declare const secretsConfigSchema: z.ZodObject<{
170
+ provider: z.ZodDefault<z.ZodEnum<["local_encrypted", "aws_secrets_manager", "gcp_secret_manager", "vault"]>>;
171
+ strictMode: z.ZodDefault<z.ZodBoolean>;
172
+ localEncrypted: z.ZodDefault<z.ZodObject<{
173
+ keyFilePath: z.ZodDefault<z.ZodString>;
174
+ }, "strip", z.ZodTypeAny, {
175
+ keyFilePath: string;
176
+ }, {
177
+ keyFilePath?: string | undefined;
178
+ }>>;
179
+ }, "strip", z.ZodTypeAny, {
180
+ provider: "local_encrypted" | "aws_secrets_manager" | "gcp_secret_manager" | "vault";
181
+ strictMode: boolean;
182
+ localEncrypted: {
183
+ keyFilePath: string;
184
+ };
185
+ }, {
186
+ provider?: "local_encrypted" | "aws_secrets_manager" | "gcp_secret_manager" | "vault" | undefined;
187
+ strictMode?: boolean | undefined;
188
+ localEncrypted?: {
189
+ keyFilePath?: string | undefined;
190
+ } | undefined;
191
+ }>;
192
+ export declare const paperclipConfigSchema: z.ZodEffects<z.ZodObject<{
193
+ $meta: z.ZodObject<{
194
+ version: z.ZodLiteral<1>;
195
+ updatedAt: z.ZodString;
196
+ source: z.ZodEnum<["onboard", "configure", "doctor"]>;
197
+ }, "strip", z.ZodTypeAny, {
198
+ version: 1;
199
+ updatedAt: string;
200
+ source: "onboard" | "configure" | "doctor";
201
+ }, {
202
+ version: 1;
203
+ updatedAt: string;
204
+ source: "onboard" | "configure" | "doctor";
205
+ }>;
206
+ llm: z.ZodOptional<z.ZodObject<{
207
+ provider: z.ZodEnum<["claude", "openai"]>;
208
+ apiKey: z.ZodOptional<z.ZodString>;
209
+ }, "strip", z.ZodTypeAny, {
210
+ provider: "claude" | "openai";
211
+ apiKey?: string | undefined;
212
+ }, {
213
+ provider: "claude" | "openai";
214
+ apiKey?: string | undefined;
215
+ }>>;
216
+ database: z.ZodObject<{
217
+ mode: z.ZodDefault<z.ZodEnum<["embedded-postgres", "postgres"]>>;
218
+ connectionString: z.ZodOptional<z.ZodString>;
219
+ embeddedPostgresDataDir: z.ZodDefault<z.ZodString>;
220
+ embeddedPostgresPort: z.ZodDefault<z.ZodNumber>;
221
+ }, "strip", z.ZodTypeAny, {
222
+ mode: "embedded-postgres" | "postgres";
223
+ embeddedPostgresDataDir: string;
224
+ embeddedPostgresPort: number;
225
+ connectionString?: string | undefined;
226
+ }, {
227
+ mode?: "embedded-postgres" | "postgres" | undefined;
228
+ connectionString?: string | undefined;
229
+ embeddedPostgresDataDir?: string | undefined;
230
+ embeddedPostgresPort?: number | undefined;
231
+ }>;
232
+ logging: z.ZodObject<{
233
+ mode: z.ZodEnum<["file", "cloud"]>;
234
+ logDir: z.ZodDefault<z.ZodString>;
235
+ }, "strip", z.ZodTypeAny, {
236
+ mode: "file" | "cloud";
237
+ logDir: string;
238
+ }, {
239
+ mode: "file" | "cloud";
240
+ logDir?: string | undefined;
241
+ }>;
242
+ server: z.ZodObject<{
243
+ deploymentMode: z.ZodDefault<z.ZodEnum<["local_trusted", "authenticated"]>>;
244
+ exposure: z.ZodDefault<z.ZodEnum<["private", "public"]>>;
245
+ host: z.ZodDefault<z.ZodString>;
246
+ port: z.ZodDefault<z.ZodNumber>;
247
+ allowedHostnames: z.ZodDefault<z.ZodArray<z.ZodString, "many">>;
248
+ serveUi: z.ZodDefault<z.ZodBoolean>;
249
+ }, "strip", z.ZodTypeAny, {
250
+ deploymentMode: "local_trusted" | "authenticated";
251
+ exposure: "private" | "public";
252
+ host: string;
253
+ port: number;
254
+ allowedHostnames: string[];
255
+ serveUi: boolean;
256
+ }, {
257
+ deploymentMode?: "local_trusted" | "authenticated" | undefined;
258
+ exposure?: "private" | "public" | undefined;
259
+ host?: string | undefined;
260
+ port?: number | undefined;
261
+ allowedHostnames?: string[] | undefined;
262
+ serveUi?: boolean | undefined;
263
+ }>;
264
+ auth: z.ZodDefault<z.ZodObject<{
265
+ baseUrlMode: z.ZodDefault<z.ZodEnum<["auto", "explicit"]>>;
266
+ publicBaseUrl: z.ZodOptional<z.ZodString>;
267
+ }, "strip", z.ZodTypeAny, {
268
+ baseUrlMode: "auto" | "explicit";
269
+ publicBaseUrl?: string | undefined;
270
+ }, {
271
+ baseUrlMode?: "auto" | "explicit" | undefined;
272
+ publicBaseUrl?: string | undefined;
273
+ }>>;
274
+ storage: z.ZodDefault<z.ZodObject<{
275
+ provider: z.ZodDefault<z.ZodEnum<["local_disk", "s3"]>>;
276
+ localDisk: z.ZodDefault<z.ZodObject<{
277
+ baseDir: z.ZodDefault<z.ZodString>;
278
+ }, "strip", z.ZodTypeAny, {
279
+ baseDir: string;
280
+ }, {
281
+ baseDir?: string | undefined;
282
+ }>>;
283
+ s3: z.ZodDefault<z.ZodObject<{
284
+ bucket: z.ZodDefault<z.ZodString>;
285
+ region: z.ZodDefault<z.ZodString>;
286
+ endpoint: z.ZodOptional<z.ZodString>;
287
+ prefix: z.ZodDefault<z.ZodString>;
288
+ forcePathStyle: z.ZodDefault<z.ZodBoolean>;
289
+ }, "strip", z.ZodTypeAny, {
290
+ bucket: string;
291
+ region: string;
292
+ prefix: string;
293
+ forcePathStyle: boolean;
294
+ endpoint?: string | undefined;
295
+ }, {
296
+ bucket?: string | undefined;
297
+ region?: string | undefined;
298
+ endpoint?: string | undefined;
299
+ prefix?: string | undefined;
300
+ forcePathStyle?: boolean | undefined;
301
+ }>>;
302
+ }, "strip", z.ZodTypeAny, {
303
+ s3: {
304
+ bucket: string;
305
+ region: string;
306
+ prefix: string;
307
+ forcePathStyle: boolean;
308
+ endpoint?: string | undefined;
309
+ };
310
+ provider: "local_disk" | "s3";
311
+ localDisk: {
312
+ baseDir: string;
313
+ };
314
+ }, {
315
+ s3?: {
316
+ bucket?: string | undefined;
317
+ region?: string | undefined;
318
+ endpoint?: string | undefined;
319
+ prefix?: string | undefined;
320
+ forcePathStyle?: boolean | undefined;
321
+ } | undefined;
322
+ provider?: "local_disk" | "s3" | undefined;
323
+ localDisk?: {
324
+ baseDir?: string | undefined;
325
+ } | undefined;
326
+ }>>;
327
+ secrets: z.ZodDefault<z.ZodObject<{
328
+ provider: z.ZodDefault<z.ZodEnum<["local_encrypted", "aws_secrets_manager", "gcp_secret_manager", "vault"]>>;
329
+ strictMode: z.ZodDefault<z.ZodBoolean>;
330
+ localEncrypted: z.ZodDefault<z.ZodObject<{
331
+ keyFilePath: z.ZodDefault<z.ZodString>;
332
+ }, "strip", z.ZodTypeAny, {
333
+ keyFilePath: string;
334
+ }, {
335
+ keyFilePath?: string | undefined;
336
+ }>>;
337
+ }, "strip", z.ZodTypeAny, {
338
+ provider: "local_encrypted" | "aws_secrets_manager" | "gcp_secret_manager" | "vault";
339
+ strictMode: boolean;
340
+ localEncrypted: {
341
+ keyFilePath: string;
342
+ };
343
+ }, {
344
+ provider?: "local_encrypted" | "aws_secrets_manager" | "gcp_secret_manager" | "vault" | undefined;
345
+ strictMode?: boolean | undefined;
346
+ localEncrypted?: {
347
+ keyFilePath?: string | undefined;
348
+ } | undefined;
349
+ }>>;
350
+ }, "strip", z.ZodTypeAny, {
351
+ database: {
352
+ mode: "embedded-postgres" | "postgres";
353
+ embeddedPostgresDataDir: string;
354
+ embeddedPostgresPort: number;
355
+ connectionString?: string | undefined;
356
+ };
357
+ $meta: {
358
+ version: 1;
359
+ updatedAt: string;
360
+ source: "onboard" | "configure" | "doctor";
361
+ };
362
+ logging: {
363
+ mode: "file" | "cloud";
364
+ logDir: string;
365
+ };
366
+ server: {
367
+ deploymentMode: "local_trusted" | "authenticated";
368
+ exposure: "private" | "public";
369
+ host: string;
370
+ port: number;
371
+ allowedHostnames: string[];
372
+ serveUi: boolean;
373
+ };
374
+ auth: {
375
+ baseUrlMode: "auto" | "explicit";
376
+ publicBaseUrl?: string | undefined;
377
+ };
378
+ storage: {
379
+ s3: {
380
+ bucket: string;
381
+ region: string;
382
+ prefix: string;
383
+ forcePathStyle: boolean;
384
+ endpoint?: string | undefined;
385
+ };
386
+ provider: "local_disk" | "s3";
387
+ localDisk: {
388
+ baseDir: string;
389
+ };
390
+ };
391
+ secrets: {
392
+ provider: "local_encrypted" | "aws_secrets_manager" | "gcp_secret_manager" | "vault";
393
+ strictMode: boolean;
394
+ localEncrypted: {
395
+ keyFilePath: string;
396
+ };
397
+ };
398
+ llm?: {
399
+ provider: "claude" | "openai";
400
+ apiKey?: string | undefined;
401
+ } | undefined;
402
+ }, {
403
+ database: {
404
+ mode?: "embedded-postgres" | "postgres" | undefined;
405
+ connectionString?: string | undefined;
406
+ embeddedPostgresDataDir?: string | undefined;
407
+ embeddedPostgresPort?: number | undefined;
408
+ };
409
+ $meta: {
410
+ version: 1;
411
+ updatedAt: string;
412
+ source: "onboard" | "configure" | "doctor";
413
+ };
414
+ logging: {
415
+ mode: "file" | "cloud";
416
+ logDir?: string | undefined;
417
+ };
418
+ server: {
419
+ deploymentMode?: "local_trusted" | "authenticated" | undefined;
420
+ exposure?: "private" | "public" | undefined;
421
+ host?: string | undefined;
422
+ port?: number | undefined;
423
+ allowedHostnames?: string[] | undefined;
424
+ serveUi?: boolean | undefined;
425
+ };
426
+ llm?: {
427
+ provider: "claude" | "openai";
428
+ apiKey?: string | undefined;
429
+ } | undefined;
430
+ auth?: {
431
+ baseUrlMode?: "auto" | "explicit" | undefined;
432
+ publicBaseUrl?: string | undefined;
433
+ } | undefined;
434
+ storage?: {
435
+ s3?: {
436
+ bucket?: string | undefined;
437
+ region?: string | undefined;
438
+ endpoint?: string | undefined;
439
+ prefix?: string | undefined;
440
+ forcePathStyle?: boolean | undefined;
441
+ } | undefined;
442
+ provider?: "local_disk" | "s3" | undefined;
443
+ localDisk?: {
444
+ baseDir?: string | undefined;
445
+ } | undefined;
446
+ } | undefined;
447
+ secrets?: {
448
+ provider?: "local_encrypted" | "aws_secrets_manager" | "gcp_secret_manager" | "vault" | undefined;
449
+ strictMode?: boolean | undefined;
450
+ localEncrypted?: {
451
+ keyFilePath?: string | undefined;
452
+ } | undefined;
453
+ } | undefined;
454
+ }>, {
455
+ database: {
456
+ mode: "embedded-postgres" | "postgres";
457
+ embeddedPostgresDataDir: string;
458
+ embeddedPostgresPort: number;
459
+ connectionString?: string | undefined;
460
+ };
461
+ $meta: {
462
+ version: 1;
463
+ updatedAt: string;
464
+ source: "onboard" | "configure" | "doctor";
465
+ };
466
+ logging: {
467
+ mode: "file" | "cloud";
468
+ logDir: string;
469
+ };
470
+ server: {
471
+ deploymentMode: "local_trusted" | "authenticated";
472
+ exposure: "private" | "public";
473
+ host: string;
474
+ port: number;
475
+ allowedHostnames: string[];
476
+ serveUi: boolean;
477
+ };
478
+ auth: {
479
+ baseUrlMode: "auto" | "explicit";
480
+ publicBaseUrl?: string | undefined;
481
+ };
482
+ storage: {
483
+ s3: {
484
+ bucket: string;
485
+ region: string;
486
+ prefix: string;
487
+ forcePathStyle: boolean;
488
+ endpoint?: string | undefined;
489
+ };
490
+ provider: "local_disk" | "s3";
491
+ localDisk: {
492
+ baseDir: string;
493
+ };
494
+ };
495
+ secrets: {
496
+ provider: "local_encrypted" | "aws_secrets_manager" | "gcp_secret_manager" | "vault";
497
+ strictMode: boolean;
498
+ localEncrypted: {
499
+ keyFilePath: string;
500
+ };
501
+ };
502
+ llm?: {
503
+ provider: "claude" | "openai";
504
+ apiKey?: string | undefined;
505
+ } | undefined;
506
+ }, {
507
+ database: {
508
+ mode?: "embedded-postgres" | "postgres" | undefined;
509
+ connectionString?: string | undefined;
510
+ embeddedPostgresDataDir?: string | undefined;
511
+ embeddedPostgresPort?: number | undefined;
512
+ };
513
+ $meta: {
514
+ version: 1;
515
+ updatedAt: string;
516
+ source: "onboard" | "configure" | "doctor";
517
+ };
518
+ logging: {
519
+ mode: "file" | "cloud";
520
+ logDir?: string | undefined;
521
+ };
522
+ server: {
523
+ deploymentMode?: "local_trusted" | "authenticated" | undefined;
524
+ exposure?: "private" | "public" | undefined;
525
+ host?: string | undefined;
526
+ port?: number | undefined;
527
+ allowedHostnames?: string[] | undefined;
528
+ serveUi?: boolean | undefined;
529
+ };
530
+ llm?: {
531
+ provider: "claude" | "openai";
532
+ apiKey?: string | undefined;
533
+ } | undefined;
534
+ auth?: {
535
+ baseUrlMode?: "auto" | "explicit" | undefined;
536
+ publicBaseUrl?: string | undefined;
537
+ } | undefined;
538
+ storage?: {
539
+ s3?: {
540
+ bucket?: string | undefined;
541
+ region?: string | undefined;
542
+ endpoint?: string | undefined;
543
+ prefix?: string | undefined;
544
+ forcePathStyle?: boolean | undefined;
545
+ } | undefined;
546
+ provider?: "local_disk" | "s3" | undefined;
547
+ localDisk?: {
548
+ baseDir?: string | undefined;
549
+ } | undefined;
550
+ } | undefined;
551
+ secrets?: {
552
+ provider?: "local_encrypted" | "aws_secrets_manager" | "gcp_secret_manager" | "vault" | undefined;
553
+ strictMode?: boolean | undefined;
554
+ localEncrypted?: {
555
+ keyFilePath?: string | undefined;
556
+ } | undefined;
557
+ } | undefined;
558
+ }>;
559
+ export type PaperclipConfig = z.infer<typeof paperclipConfigSchema>;
560
+ export type LlmConfig = z.infer<typeof llmConfigSchema>;
561
+ export type DatabaseConfig = z.infer<typeof databaseConfigSchema>;
562
+ export type LoggingConfig = z.infer<typeof loggingConfigSchema>;
563
+ export type ServerConfig = z.infer<typeof serverConfigSchema>;
564
+ export type StorageConfig = z.infer<typeof storageConfigSchema>;
565
+ export type StorageLocalDiskConfig = z.infer<typeof storageLocalDiskConfigSchema>;
566
+ export type StorageS3Config = z.infer<typeof storageS3ConfigSchema>;
567
+ export type SecretsConfig = z.infer<typeof secretsConfigSchema>;
568
+ export type SecretsLocalEncryptedConfig = z.infer<typeof secretsLocalEncryptedConfigSchema>;
569
+ export type AuthConfig = z.infer<typeof authConfigSchema>;
570
+ export type ConfigMeta = z.infer<typeof configMetaSchema>;
571
+ //# sourceMappingURL=config-schema.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"config-schema.d.ts","sourceRoot":"","sources":["../src/config-schema.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AASxB,eAAO,MAAM,gBAAgB;;;;;;;;;;;;EAI3B,CAAC;AAEH,eAAO,MAAM,eAAe;;;;;;;;;EAG1B,CAAC;AAEH,eAAO,MAAM,oBAAoB;;;;;;;;;;;;;;;EAK/B,CAAC;AAEH,eAAO,MAAM,mBAAmB;;;;;;;;;EAG9B,CAAC;AAEH,eAAO,MAAM,kBAAkB;;;;;;;;;;;;;;;;;;;;;EAO7B,CAAC;AAEH,eAAO,MAAM,gBAAgB;;;;;;;;;EAG3B,CAAC;AAEH,eAAO,MAAM,4BAA4B;;;;;;EAEvC,CAAC;AAEH,eAAO,MAAM,qBAAqB;;;;;;;;;;;;;;;;;;EAMhC,CAAC;AAEH,eAAO,MAAM,mBAAmB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EAW9B,CAAC;AAEH,eAAO,MAAM,iCAAiC;;;;;;EAE5C,CAAC;AAEH,eAAO,MAAM,mBAAmB;;;;;;;;;;;;;;;;;;;;;;EAM9B,CAAC;AAEH,eAAO,MAAM,qBAAqB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EAiE9B,CAAC;AAEL,MAAM,MAAM,eAAe,GAAG,CAAC,CAAC,KAAK,CAAC,OAAO,qBAAqB,CAAC,CAAC;AACpE,MAAM,MAAM,SAAS,GAAG,CAAC,CAAC,KAAK,CAAC,OAAO,eAAe,CAAC,CAAC;AACxD,MAAM,MAAM,cAAc,GAAG,CAAC,CAAC,KAAK,CAAC,OAAO,oBAAoB,CAAC,CAAC;AAClE,MAAM,MAAM,aAAa,GAAG,CAAC,CAAC,KAAK,CAAC,OAAO,mBAAmB,CAAC,CAAC;AAChE,MAAM,MAAM,YAAY,GAAG,CAAC,CAAC,KAAK,CAAC,OAAO,kBAAkB,CAAC,CAAC;AAC9D,MAAM,MAAM,aAAa,GAAG,CAAC,CAAC,KAAK,CAAC,OAAO,mBAAmB,CAAC,CAAC;AAChE,MAAM,MAAM,sBAAsB,GAAG,CAAC,CAAC,KAAK,CAAC,OAAO,4BAA4B,CAAC,CAAC;AAClF,MAAM,MAAM,eAAe,GAAG,CAAC,CAAC,KAAK,CAAC,OAAO,qBAAqB,CAAC,CAAC;AACpE,MAAM,MAAM,aAAa,GAAG,CAAC,CAAC,KAAK,CAAC,OAAO,mBAAmB,CAAC,CAAC;AAChE,MAAM,MAAM,2BAA2B,GAAG,CAAC,CAAC,KAAK,CAAC,OAAO,iCAAiC,CAAC,CAAC;AAC5F,MAAM,MAAM,UAAU,GAAG,CAAC,CAAC,KAAK,CAAC,OAAO,gBAAgB,CAAC,CAAC;AAC1D,MAAM,MAAM,UAAU,GAAG,CAAC,CAAC,KAAK,CAAC,OAAO,gBAAgB,CAAC,CAAC"}