@lovinka/deployik-mcp 0.1.0

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 (70) hide show
  1. package/README.md +59 -0
  2. package/dist/client/errors.js +51 -0
  3. package/dist/client/errors.js.map +1 -0
  4. package/dist/client/http.js +106 -0
  5. package/dist/client/http.js.map +1 -0
  6. package/dist/client/types.js +5 -0
  7. package/dist/client/types.js.map +1 -0
  8. package/dist/config/audit.js +43 -0
  9. package/dist/config/audit.js.map +1 -0
  10. package/dist/config/binding.js +44 -0
  11. package/dist/config/binding.js.map +1 -0
  12. package/dist/config/cache.js +44 -0
  13. package/dist/config/cache.js.map +1 -0
  14. package/dist/config/env.js +40 -0
  15. package/dist/config/env.js.map +1 -0
  16. package/dist/index.js +22 -0
  17. package/dist/index.js.map +1 -0
  18. package/dist/knowledge/index.js +116 -0
  19. package/dist/knowledge/index.js.map +1 -0
  20. package/dist/knowledge/prompts.js +20 -0
  21. package/dist/knowledge/prompts.js.map +1 -0
  22. package/dist/knowledge/recipes.generated.js +17 -0
  23. package/dist/knowledge/recipes.generated.js.map +1 -0
  24. package/dist/lib/format.js +96 -0
  25. package/dist/lib/format.js.map +1 -0
  26. package/dist/lib/logs.js +46 -0
  27. package/dist/lib/logs.js.map +1 -0
  28. package/dist/lib/poll.js +20 -0
  29. package/dist/lib/poll.js.map +1 -0
  30. package/dist/lib/safety.js +38 -0
  31. package/dist/lib/safety.js.map +1 -0
  32. package/dist/resolve/project.js +130 -0
  33. package/dist/resolve/project.js.map +1 -0
  34. package/dist/server.js +32 -0
  35. package/dist/server.js.map +1 -0
  36. package/dist/tools/_helpers.js +76 -0
  37. package/dist/tools/_helpers.js.map +1 -0
  38. package/dist/tools/analytics.js +46 -0
  39. package/dist/tools/analytics.js.map +1 -0
  40. package/dist/tools/auto_build.js +84 -0
  41. package/dist/tools/auto_build.js.map +1 -0
  42. package/dist/tools/deployments.js +120 -0
  43. package/dist/tools/deployments.js.map +1 -0
  44. package/dist/tools/domains.js +104 -0
  45. package/dist/tools/domains.js.map +1 -0
  46. package/dist/tools/email.js +90 -0
  47. package/dist/tools/email.js.map +1 -0
  48. package/dist/tools/env.js +116 -0
  49. package/dist/tools/env.js.map +1 -0
  50. package/dist/tools/github.js +59 -0
  51. package/dist/tools/github.js.map +1 -0
  52. package/dist/tools/help.js +34 -0
  53. package/dist/tools/help.js.map +1 -0
  54. package/dist/tools/index.js +33 -0
  55. package/dist/tools/index.js.map +1 -0
  56. package/dist/tools/projects.js +164 -0
  57. package/dist/tools/projects.js.map +1 -0
  58. package/dist/tools/protection.js +88 -0
  59. package/dist/tools/protection.js.map +1 -0
  60. package/dist/tools/secrets.js +115 -0
  61. package/dist/tools/secrets.js.map +1 -0
  62. package/dist/tools/tokens.js +60 -0
  63. package/dist/tools/tokens.js.map +1 -0
  64. package/dist/tools/volumes.js +77 -0
  65. package/dist/tools/volumes.js.map +1 -0
  66. package/dist/tools/workflows.js +350 -0
  67. package/dist/tools/workflows.js.map +1 -0
  68. package/dist/tools/workspaces.js +48 -0
  69. package/dist/tools/workspaces.js.map +1 -0
  70. package/package.json +50 -0
@@ -0,0 +1,350 @@
1
+ import { z } from "zod";
2
+ import { registerTool } from "./_helpers.js";
3
+ import { resolveProject, fetchProjects } from "../resolve/project.js";
4
+ import { checkSafety } from "../lib/safety.js";
5
+ import { pollUntil, sleep } from "../lib/poll.js";
6
+ import { renderDryRun, renderProjectSummary, renderDeploymentSummary, renderDomainsList, renderVolumesList, renderProtection } from "../lib/format.js";
7
+ import { formatLogs } from "../lib/logs.js";
8
+ import { writeBinding, ensureGitignore, readBinding } from "../config/binding.js";
9
+ const ENV = z.enum(["preview", "production"]);
10
+ const VAR_SCOPE = z.enum(["shared", "preview", "production"]);
11
+ const TERMINAL_STATUSES = new Set(["live", "failed", "replaced", "rolled_back"]);
12
+ export function registerWorkflowTools(server, ctx) {
13
+ registerTool(server, ctx, {
14
+ name: "init_in_repo",
15
+ description: "Bootstrap this repo: write `.deployik/binding.json` (project + workspace), append `.deployik/` to .gitignore, and validate the token via whoami. Run this once per repo.",
16
+ inputSchema: {
17
+ project: z.string().optional(),
18
+ project_id: z.string().optional(),
19
+ workspace: z.string().optional(),
20
+ default_environment: ENV.optional(),
21
+ },
22
+ handler: async (args) => {
23
+ const user = await ctx.client.request(`/auth/me`);
24
+ const { project, source } = await resolveProject(ctx, args);
25
+ const binding = {
26
+ project: project.name,
27
+ workspace: project.organization_name ?? project.organization_id,
28
+ defaultEnvironment: args.default_environment,
29
+ };
30
+ writeBinding(ctx.stateDir, binding);
31
+ const gitignoreUpdated = ensureGitignore(ctx.cwd);
32
+ const lines = [
33
+ `Bound this repo to Deployik project '${project.name}' (workspace: ${binding.workspace}).`,
34
+ `Authenticated as ${user.username} (${user.role}).`,
35
+ `Resolution source: ${source}.`,
36
+ gitignoreUpdated ? "Added `.deployik/` to .gitignore." : "`.deployik/` already in .gitignore (or no .gitignore at repo root).",
37
+ `State dir: ${ctx.stateDir}`,
38
+ ];
39
+ return { text: lines.join("\n"), data: { project, binding, gitignoreUpdated } };
40
+ },
41
+ });
42
+ registerTool(server, ctx, {
43
+ name: "setup_project_from_repo",
44
+ description: "End-to-end: inspect the GitHub repo for monorepo/framework, create a Deployik project, optionally enable auto-build + auto-production. Returns the project + initial preview deploy id (if any).",
45
+ inputSchema: {
46
+ owner: z.string(),
47
+ repo: z.string(),
48
+ name: z.string().describe("DNS-safe slug, e.g. 'my-app'."),
49
+ branch: z.string().default("main"),
50
+ framework: z.enum(["nextjs", "vite", "astro", "static"]).optional(),
51
+ package_manager: z.enum(["auto", "bun", "pnpm", "npm", "yarn"]).optional(),
52
+ root_directory: z.string().optional().describe("If the repo is a monorepo, the app subdirectory."),
53
+ organization_id: z.string().optional(),
54
+ auto_build_enabled: z.boolean().default(true),
55
+ auto_production_enabled: z.boolean().default(false),
56
+ },
57
+ handler: async (args) => {
58
+ const inspection = await ctx.client.request(`/github/repos/${encodeURIComponent(args.owner)}/${encodeURIComponent(args.repo)}/inspect`, { query: { branch: args.branch } });
59
+ let detectedApp;
60
+ if (args.root_directory !== undefined) {
61
+ detectedApp = inspection.apps.find((a) => a.path === args.root_directory);
62
+ }
63
+ else if (inspection.apps.length > 0) {
64
+ detectedApp = inspection.apps[0];
65
+ }
66
+ const payload = {
67
+ name: args.name,
68
+ github_owner: args.owner,
69
+ github_repo: args.repo,
70
+ branch: args.branch,
71
+ framework: args.framework ?? detectedApp?.framework ?? "nextjs",
72
+ package_manager: args.package_manager ?? inspection.package_manager ?? "auto",
73
+ root_directory: args.root_directory ?? detectedApp?.path ?? "",
74
+ output_directory: detectedApp?.output_directory ?? "",
75
+ build_command: detectedApp?.suggested_build_command ?? "",
76
+ install_command: "",
77
+ node_version: "22",
78
+ port: 3000,
79
+ auto_build_enabled: args.auto_build_enabled,
80
+ auto_production_enabled: args.auto_production_enabled,
81
+ };
82
+ if (args.organization_id)
83
+ payload.organization_id = args.organization_id;
84
+ const project = await ctx.client.request(`/projects`, { method: "POST", body: payload });
85
+ return {
86
+ text: [
87
+ `Created project '${project.name}' (id: ${project.id}).`,
88
+ inspection.is_monorepo ? `Monorepo detected — picked app at '${payload.root_directory || "/"}'.` : "Single-app repo.",
89
+ `Framework: ${payload.framework} · package manager: ${payload.package_manager}`,
90
+ `Auto-build: ${args.auto_build_enabled ? "enabled" : "disabled"}, auto-production: ${args.auto_production_enabled ? "enabled" : "disabled"}.`,
91
+ `Initial preview deploy is fired automatically by the server. Use list_deployments to watch.`,
92
+ ].join("\n"),
93
+ data: { project, inspection },
94
+ };
95
+ },
96
+ });
97
+ registerTool(server, ctx, {
98
+ name: "deploy_project",
99
+ description: "Trigger a deployment for a project + environment. With `wait:true`, polls until terminal status and returns the final state. Production requires `confirm: true` + `confirm_name`.",
100
+ inputSchema: {
101
+ project_id: z.string().optional(),
102
+ project: z.string().optional(),
103
+ environment: ENV,
104
+ branch: z.string().optional(),
105
+ wait: z.boolean().default(false),
106
+ timeout_ms: z.number().int().positive().max(600_000).default(180_000),
107
+ confirm: z.boolean().optional(),
108
+ confirm_name: z.string().optional(),
109
+ create_tag: z.boolean().default(false),
110
+ tag_name: z.string().optional(),
111
+ },
112
+ audit: true,
113
+ handler: async (args) => {
114
+ const { project } = await resolveProject(ctx, args);
115
+ if (args.environment === "production") {
116
+ const safety = checkSafety({
117
+ toolName: "deploy_project",
118
+ tier: "destructive_production",
119
+ expectedName: project.name,
120
+ impact: { project: project.name, environment: "production", branch: args.branch ?? project.branch, create_tag: args.create_tag },
121
+ }, { confirm: args.confirm, confirm_name: args.confirm_name });
122
+ if (!safety.proceed)
123
+ return { text: renderDryRun(safety.dryRun) };
124
+ }
125
+ const body = { environment: args.environment };
126
+ if (args.branch)
127
+ body.branch = args.branch;
128
+ if (args.create_tag)
129
+ body.create_tag = true;
130
+ if (args.tag_name)
131
+ body.tag_name = args.tag_name;
132
+ const deployment = await ctx.client.request(`/projects/${project.id}/deployments`, { method: "POST", body });
133
+ if (!args.wait) {
134
+ return { text: `Triggered ${args.environment} deploy.\n${renderDeploymentSummary(deployment)}`, data: deployment };
135
+ }
136
+ const final = await pollUntil(() => ctx.client.request(`/projects/${project.id}/deployments/${deployment.id}`), (d) => TERMINAL_STATUSES.has(d.status), { intervalMs: 2000, timeoutMs: args.timeout_ms, initialDelayMs: 1500 });
137
+ const status = final.value;
138
+ const logs = await ctx.client.request(`/deployments/${status.id}/logs`).catch(() => []);
139
+ const formatted = formatLogs(logs, { maxLines: 80, tail: true });
140
+ const header = `Deployment ${status.id} · ${status.status}${final.done ? "" : " (timed out)"}`;
141
+ const tail = status.status === "failed" || !final.done ? `\n\nLog tail:\n${formatted.text}` : "";
142
+ return { text: `${header}\n${renderDeploymentSummary(status)}${tail}`, data: status };
143
+ },
144
+ });
145
+ registerTool(server, ctx, {
146
+ name: "set_secret",
147
+ description: "Set a secret on a project+scope. Auto-resolves project from the .deployik binding if omitted. NEXT_PUBLIC_* keys are rejected by the backend (use set_env_var instead).",
148
+ inputSchema: {
149
+ project_id: z.string().optional(),
150
+ project: z.string().optional(),
151
+ environment: VAR_SCOPE.default("production"),
152
+ key: z.string(),
153
+ value: z.string(),
154
+ },
155
+ handler: async (args) => {
156
+ if (args.key.startsWith("NEXT_PUBLIC_")) {
157
+ return {
158
+ text: `Refusing to set NEXT_PUBLIC_* keys as secrets — they need to be embedded at build time. Use set_env_var instead.`,
159
+ isError: true,
160
+ };
161
+ }
162
+ const { project } = await resolveProject(ctx, args);
163
+ await ctx.client.request(`/projects/${project.id}/secrets`, {
164
+ method: "POST",
165
+ body: { environment: args.environment, key: args.key, value: args.value },
166
+ });
167
+ return { text: `Set secret ${args.key} in ${args.environment} scope of ${project.name}.` };
168
+ },
169
+ });
170
+ registerTool(server, ctx, {
171
+ name: "set_env_var",
172
+ description: "Set an environment variable on a project+scope. Auto-resolves project from the .deployik binding if omitted.",
173
+ inputSchema: {
174
+ project_id: z.string().optional(),
175
+ project: z.string().optional(),
176
+ environment: VAR_SCOPE.default("production"),
177
+ key: z.string(),
178
+ value: z.string(),
179
+ },
180
+ handler: async (args) => {
181
+ const { project } = await resolveProject(ctx, args);
182
+ await ctx.client.request(`/projects/${project.id}/env`, {
183
+ method: "POST",
184
+ body: { environment: args.environment, key: args.key, value: args.value },
185
+ });
186
+ return { text: `Set ${args.key} in ${args.environment} scope of ${project.name}.` };
187
+ },
188
+ });
189
+ registerTool(server, ctx, {
190
+ name: "wait_for_deployment",
191
+ description: "Poll until a deployment reaches a terminal status (live / failed / replaced / rolled_back) or the timeout elapses.",
192
+ inputSchema: {
193
+ project_id: z.string().optional(),
194
+ project: z.string().optional(),
195
+ deployment_id: z.string(),
196
+ timeout_ms: z.number().int().positive().max(600_000).default(180_000),
197
+ },
198
+ handler: async (args) => {
199
+ const { project } = await resolveProject(ctx, args);
200
+ const result = await pollUntil(() => ctx.client.request(`/projects/${project.id}/deployments/${args.deployment_id}`), (d) => TERMINAL_STATUSES.has(d.status), { intervalMs: 2000, timeoutMs: args.timeout_ms });
201
+ return {
202
+ text: result.done
203
+ ? `Deployment ${args.deployment_id} reached '${result.value.status}' in ${result.elapsedMs}ms.\n${renderDeploymentSummary(result.value)}`
204
+ : `Timed out waiting — last status: '${result.value.status}' after ${result.elapsedMs}ms.`,
205
+ data: result.value,
206
+ };
207
+ },
208
+ });
209
+ registerTool(server, ctx, {
210
+ name: "tail_latest_logs",
211
+ description: "The 'show me what just broke' tool: finds the latest deployment for a project+environment and returns formatted log tail. With `follow:true`, polls until the deploy terminates.",
212
+ inputSchema: {
213
+ project_id: z.string().optional(),
214
+ project: z.string().optional(),
215
+ environment: ENV,
216
+ follow: z.boolean().default(false),
217
+ max_lines: z.number().int().positive().max(2000).default(150),
218
+ timeout_ms: z.number().int().positive().max(600_000).default(180_000),
219
+ },
220
+ annotations: { readOnlyHint: true },
221
+ handler: async (args) => {
222
+ const { project } = await resolveProject(ctx, args);
223
+ const deployments = await ctx.client.request(`/projects/${project.id}/deployments`, { query: { environment: args.environment, limit: 1 } });
224
+ const latest = (deployments.deployments ?? [])[0];
225
+ if (!latest) {
226
+ return { text: `(no ${args.environment} deployments yet for ${project.name})` };
227
+ }
228
+ let current = latest;
229
+ let logs = await ctx.client.request(`/deployments/${current.id}/logs`).catch(() => []);
230
+ if (args.follow && !TERMINAL_STATUSES.has(current.status)) {
231
+ const start = Date.now();
232
+ while (Date.now() - start < args.timeout_ms) {
233
+ await sleep(2000);
234
+ current = await ctx.client.request(`/projects/${project.id}/deployments/${current.id}`);
235
+ logs = await ctx.client.request(`/deployments/${current.id}/logs`).catch(() => logs);
236
+ if (TERMINAL_STATUSES.has(current.status))
237
+ break;
238
+ }
239
+ }
240
+ const formatted = formatLogs(logs, { maxLines: args.max_lines, tail: true });
241
+ const sinceFinished = current.finished_at ? ` · finished ${current.finished_at}` : "";
242
+ const header = `Deployment ${current.id} · ${current.status}${sinceFinished}\n${current.environment} · ${current.branch} · commit ${current.commit_sha.slice(0, 8)}\n`;
243
+ const errorSection = formatted.errorAnchors.length > 0 ? `\nError anchors: lines ${formatted.errorAnchors.join(", ")}` : "";
244
+ const footer = formatted.hint ? `\n\n${formatted.hint}` : "";
245
+ return {
246
+ text: `${header}\n${formatted.text}${errorSection}${footer}`,
247
+ data: { deployment: current, logsMeta: { totalLines: formatted.totalLines, returnedLines: formatted.returnedLines, truncated: formatted.truncated, errorAnchors: formatted.errorAnchors } },
248
+ };
249
+ },
250
+ });
251
+ registerTool(server, ctx, {
252
+ name: "debug_failed_deployment",
253
+ description: "Composite: deployment meta + last 200 log lines + screenshot URL. Use as the first call when a build fails.",
254
+ inputSchema: {
255
+ project_id: z.string().optional(),
256
+ project: z.string().optional(),
257
+ deployment_id: z.string(),
258
+ },
259
+ annotations: { readOnlyHint: true },
260
+ handler: async (args) => {
261
+ const { project } = await resolveProject(ctx, args);
262
+ const deployment = await ctx.client.request(`/projects/${project.id}/deployments/${args.deployment_id}`);
263
+ const logs = await ctx.client.request(`/deployments/${deployment.id}/logs`).catch(() => []);
264
+ const formatted = formatLogs(logs, { maxLines: 200, tail: true });
265
+ const screenshotUrl = ctx.client.screenshotUrl(deployment.id);
266
+ const sections = [
267
+ renderDeploymentSummary(deployment),
268
+ ``,
269
+ `Log tail (${formatted.returnedLines}/${formatted.totalLines} lines):`,
270
+ formatted.text,
271
+ ];
272
+ if (formatted.errorAnchors.length > 0) {
273
+ sections.push(``, `Error anchors at lines: ${formatted.errorAnchors.join(", ")}`);
274
+ }
275
+ sections.push(``, `Screenshot URL (if captured): ${screenshotUrl}`);
276
+ return { text: sections.join("\n"), data: { deployment, logsMeta: formatted, screenshotUrl } };
277
+ },
278
+ });
279
+ registerTool(server, ctx, {
280
+ name: "get_project_health",
281
+ description: "Composite snapshot: project + latest deploys per env + domains + volumes + protection status. One call replaces 5+.",
282
+ inputSchema: {
283
+ project_id: z.string().optional(),
284
+ project: z.string().optional(),
285
+ },
286
+ annotations: { readOnlyHint: true },
287
+ handler: async (args) => {
288
+ const { project } = await resolveProject(ctx, args);
289
+ const [domains, volumes, protection, previewList, productionList] = await Promise.all([
290
+ ctx.client.request(`/projects/${project.id}/domains`).catch(() => []),
291
+ ctx.client.request(`/projects/${project.id}/volumes`).catch(() => []),
292
+ ctx.client.request(`/projects/${project.id}/protection`).catch(() => ({ preview_enabled: false, production_enabled: false })),
293
+ ctx.client.request(`/projects/${project.id}/deployments`, {
294
+ query: { environment: "preview", limit: 1 },
295
+ }).catch(() => ({ deployments: [], total: 0 })),
296
+ ctx.client.request(`/projects/${project.id}/deployments`, {
297
+ query: { environment: "production", limit: 1 },
298
+ }).catch(() => ({ deployments: [], total: 0 })),
299
+ ]);
300
+ const lines = [
301
+ renderProjectSummary(project),
302
+ ``,
303
+ `Latest preview: ${previewList.deployments[0] ? `${previewList.deployments[0].status} · ${previewList.deployments[0].id}` : "(none)"}`,
304
+ `Latest production: ${productionList.deployments[0] ? `${productionList.deployments[0].status} · ${productionList.deployments[0].id}` : "(none)"}`,
305
+ ``,
306
+ `Domains:`,
307
+ renderDomainsList(domains),
308
+ ``,
309
+ `Volumes:`,
310
+ renderVolumesList(volumes),
311
+ ``,
312
+ `Protection:`,
313
+ renderProtection(protection),
314
+ ];
315
+ return {
316
+ text: lines.join("\n"),
317
+ data: {
318
+ project,
319
+ latest: { preview: previewList.deployments[0] ?? null, production: productionList.deployments[0] ?? null },
320
+ domains,
321
+ volumes,
322
+ protection,
323
+ },
324
+ };
325
+ },
326
+ });
327
+ registerTool(server, ctx, {
328
+ name: "show_binding",
329
+ description: "Print the current .deployik binding (project + workspace) for this repo, if any. Useful to confirm resolution before running other tools.",
330
+ annotations: { readOnlyHint: true },
331
+ handler: async () => {
332
+ const binding = readBinding(ctx.stateDir);
333
+ if (!binding) {
334
+ return { text: `(no binding yet — run init_in_repo to bind this repo to a Deployik project)` };
335
+ }
336
+ const projects = await fetchProjects(ctx).catch(() => []);
337
+ const project = projects.find((p) => p.name === binding.project);
338
+ const lines = [
339
+ `Binding (${ctx.stateDir}):`,
340
+ ` project: ${binding.project}`,
341
+ ` workspace: ${binding.workspace ?? "(unset)"}`,
342
+ ` defaultEnvironment: ${binding.defaultEnvironment ?? "(unset)"}`,
343
+ ];
344
+ if (project)
345
+ lines.push("", renderProjectSummary(project));
346
+ return { text: lines.join("\n"), data: { binding, project } };
347
+ },
348
+ });
349
+ }
350
+ //# sourceMappingURL=workflows.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"workflows.js","sourceRoot":"","sources":["../../src/tools/workflows.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAExB,OAAO,EAAE,YAAY,EAAoB,MAAM,eAAe,CAAC;AAC/D,OAAO,EAAE,cAAc,EAAE,aAAa,EAAE,MAAM,uBAAuB,CAAC;AACtE,OAAO,EAAE,WAAW,EAAE,MAAM,kBAAkB,CAAC;AAC/C,OAAO,EAAE,SAAS,EAAE,KAAK,EAAE,MAAM,gBAAgB,CAAC;AAClD,OAAO,EAAE,YAAY,EAAE,oBAAoB,EAAE,uBAAuB,EAAE,iBAAiB,EAAE,iBAAiB,EAAE,gBAAgB,EAAE,MAAM,kBAAkB,CAAC;AACvJ,OAAO,EAAE,UAAU,EAAE,MAAM,gBAAgB,CAAC;AAC5C,OAAO,EAAE,YAAY,EAAE,eAAe,EAAE,WAAW,EAAE,MAAM,sBAAsB,CAAC;AAalF,MAAM,GAAG,GAAG,CAAC,CAAC,IAAI,CAAC,CAAC,SAAS,EAAE,YAAY,CAAC,CAAC,CAAC;AAC9C,MAAM,SAAS,GAAG,CAAC,CAAC,IAAI,CAAC,CAAC,QAAQ,EAAE,SAAS,EAAE,YAAY,CAAC,CAAC,CAAC;AAE9D,MAAM,iBAAiB,GAAG,IAAI,GAAG,CAAC,CAAC,MAAM,EAAE,QAAQ,EAAE,UAAU,EAAE,aAAa,CAAC,CAAC,CAAC;AAEjF,MAAM,UAAU,qBAAqB,CAAC,MAAiB,EAAE,GAAgB;IACvE,YAAY,CAAC,MAAM,EAAE,GAAG,EAAE;QACxB,IAAI,EAAE,cAAc;QACpB,WAAW,EACT,0KAA0K;QAC5K,WAAW,EAAE;YACX,OAAO,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;YAC9B,UAAU,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;YACjC,SAAS,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;YAChC,mBAAmB,EAAE,GAAG,CAAC,QAAQ,EAAE;SACpC;QACD,OAAO,EAAE,KAAK,EAAE,IAAI,EAAE,EAAE;YACtB,MAAM,IAAI,GAAG,MAAM,GAAG,CAAC,MAAM,CAAC,OAAO,CAAO,UAAU,CAAC,CAAC;YACxD,MAAM,EAAE,OAAO,EAAE,MAAM,EAAE,GAAG,MAAM,cAAc,CAAC,GAAG,EAAE,IAAI,CAAC,CAAC;YAC5D,MAAM,OAAO,GAAG;gBACd,OAAO,EAAE,OAAO,CAAC,IAAI;gBACrB,SAAS,EAAE,OAAO,CAAC,iBAAiB,IAAI,OAAO,CAAC,eAAe;gBAC/D,kBAAkB,EAAE,IAAI,CAAC,mBAAmB;aACpC,CAAC;YACX,YAAY,CAAC,GAAG,CAAC,QAAQ,EAAE,OAAO,CAAC,CAAC;YACpC,MAAM,gBAAgB,GAAG,eAAe,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;YAClD,MAAM,KAAK,GAAG;gBACZ,wCAAwC,OAAO,CAAC,IAAI,iBAAiB,OAAO,CAAC,SAAS,IAAI;gBAC1F,oBAAoB,IAAI,CAAC,QAAQ,KAAK,IAAI,CAAC,IAAI,IAAI;gBACnD,sBAAsB,MAAM,GAAG;gBAC/B,gBAAgB,CAAC,CAAC,CAAC,mCAAmC,CAAC,CAAC,CAAC,qEAAqE;gBAC9H,cAAc,GAAG,CAAC,QAAQ,EAAE;aAC7B,CAAC;YACF,OAAO,EAAE,IAAI,EAAE,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,EAAE,OAAO,EAAE,OAAO,EAAE,gBAAgB,EAAE,EAAE,CAAC;QAClF,CAAC;KACF,CAAC,CAAC;IAEH,YAAY,CAAC,MAAM,EAAE,GAAG,EAAE;QACxB,IAAI,EAAE,yBAAyB;QAC/B,WAAW,EACT,kMAAkM;QACpM,WAAW,EAAE;YACX,KAAK,EAAE,CAAC,CAAC,MAAM,EAAE;YACjB,IAAI,EAAE,CAAC,CAAC,MAAM,EAAE;YAChB,IAAI,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,CAAC,+BAA+B,CAAC;YAC1D,MAAM,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,OAAO,CAAC,MAAM,CAAC;YAClC,SAAS,EAAE,CAAC,CAAC,IAAI,CAAC,CAAC,QAAQ,EAAE,MAAM,EAAE,OAAO,EAAE,QAAQ,CAAC,CAAC,CAAC,QAAQ,EAAE;YACnE,eAAe,EAAE,CAAC,CAAC,IAAI,CAAC,CAAC,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,CAAC,CAAC,CAAC,QAAQ,EAAE;YAC1E,cAAc,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE,CAAC,QAAQ,CAAC,kDAAkD,CAAC;YAClG,eAAe,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;YACtC,kBAAkB,EAAE,CAAC,CAAC,OAAO,EAAE,CAAC,OAAO,CAAC,IAAI,CAAC;YAC7C,uBAAuB,EAAE,CAAC,CAAC,OAAO,EAAE,CAAC,OAAO,CAAC,KAAK,CAAC;SACpD;QACD,OAAO,EAAE,KAAK,EAAE,IAAI,EAAE,EAAE;YACtB,MAAM,UAAU,GAAG,MAAM,GAAG,CAAC,MAAM,CAAC,OAAO,CACzC,iBAAiB,kBAAkB,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,kBAAkB,CAAC,IAAI,CAAC,IAAI,CAAC,UAAU,EAC1F,EAAE,KAAK,EAAE,EAAE,MAAM,EAAE,IAAI,CAAC,MAAM,EAAE,EAAE,CACnC,CAAC;YAEF,IAAI,WAAkD,CAAC;YACvD,IAAI,IAAI,CAAC,cAAc,KAAK,SAAS,EAAE,CAAC;gBACtC,WAAW,GAAG,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,IAAI,CAAC,cAAc,CAAC,CAAC;YAC5E,CAAC;iBAAM,IAAI,UAAU,CAAC,IAAI,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;gBACtC,WAAW,GAAG,UAAU,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;YACnC,CAAC;YAED,MAAM,OAAO,GAAyB;gBACpC,IAAI,EAAE,IAAI,CAAC,IAAI;gBACf,YAAY,EAAE,IAAI,CAAC,KAAK;gBACxB,WAAW,EAAE,IAAI,CAAC,IAAI;gBACtB,MAAM,EAAE,IAAI,CAAC,MAAM;gBACnB,SAAS,EAAE,IAAI,CAAC,SAAS,IAAI,WAAW,EAAE,SAAS,IAAI,QAAQ;gBAC/D,eAAe,EAAE,IAAI,CAAC,eAAe,IAAI,UAAU,CAAC,eAAe,IAAI,MAAM;gBAC7E,cAAc,EAAE,IAAI,CAAC,cAAc,IAAI,WAAW,EAAE,IAAI,IAAI,EAAE;gBAC9D,gBAAgB,EAAE,WAAW,EAAE,gBAAgB,IAAI,EAAE;gBACrD,aAAa,EAAE,WAAW,EAAE,uBAAuB,IAAI,EAAE;gBACzD,eAAe,EAAE,EAAE;gBACnB,YAAY,EAAE,IAAI;gBAClB,IAAI,EAAE,IAAI;gBACV,kBAAkB,EAAE,IAAI,CAAC,kBAAkB;gBAC3C,uBAAuB,EAAE,IAAI,CAAC,uBAAuB;aACtD,CAAC;YACF,IAAI,IAAI,CAAC,eAAe;gBAAE,OAAO,CAAC,eAAe,GAAG,IAAI,CAAC,eAAe,CAAC;YAEzE,MAAM,OAAO,GAAG,MAAM,GAAG,CAAC,MAAM,CAAC,OAAO,CAAU,WAAW,EAAE,EAAE,MAAM,EAAE,MAAM,EAAE,IAAI,EAAE,OAAO,EAAE,CAAC,CAAC;YAElG,OAAO;gBACL,IAAI,EAAE;oBACJ,oBAAoB,OAAO,CAAC,IAAI,UAAU,OAAO,CAAC,EAAE,IAAI;oBACxD,UAAU,CAAC,WAAW,CAAC,CAAC,CAAC,sCAAsC,OAAO,CAAC,cAAc,IAAI,GAAG,IAAI,CAAC,CAAC,CAAC,kBAAkB;oBACrH,cAAc,OAAO,CAAC,SAAS,uBAAuB,OAAO,CAAC,eAAe,EAAE;oBAC/E,eAAe,IAAI,CAAC,kBAAkB,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,UAAU,sBAAsB,IAAI,CAAC,uBAAuB,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,UAAU,GAAG;oBAC7I,6FAA6F;iBAC9F,CAAC,IAAI,CAAC,IAAI,CAAC;gBACZ,IAAI,EAAE,EAAE,OAAO,EAAE,UAAU,EAAE;aAC9B,CAAC;QACJ,CAAC;KACF,CAAC,CAAC;IAEH,YAAY,CAAC,MAAM,EAAE,GAAG,EAAE;QACxB,IAAI,EAAE,gBAAgB;QACtB,WAAW,EACT,oLAAoL;QACtL,WAAW,EAAE;YACX,UAAU,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;YACjC,OAAO,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;YAC9B,WAAW,EAAE,GAAG;YAChB,MAAM,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;YAC7B,IAAI,EAAE,CAAC,CAAC,OAAO,EAAE,CAAC,OAAO,CAAC,KAAK,CAAC;YAChC,UAAU,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,GAAG,EAAE,CAAC,QAAQ,EAAE,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC,OAAO,CAAC,OAAO,CAAC;YACrE,OAAO,EAAE,CAAC,CAAC,OAAO,EAAE,CAAC,QAAQ,EAAE;YAC/B,YAAY,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;YACnC,UAAU,EAAE,CAAC,CAAC,OAAO,EAAE,CAAC,OAAO,CAAC,KAAK,CAAC;YACtC,QAAQ,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;SAChC;QACD,KAAK,EAAE,IAAI;QACX,OAAO,EAAE,KAAK,EAAE,IAAI,EAAE,EAAE;YACtB,MAAM,EAAE,OAAO,EAAE,GAAG,MAAM,cAAc,CAAC,GAAG,EAAE,IAAI,CAAC,CAAC;YACpD,IAAI,IAAI,CAAC,WAAW,KAAK,YAAY,EAAE,CAAC;gBACtC,MAAM,MAAM,GAAG,WAAW,CACxB;oBACE,QAAQ,EAAE,gBAAgB;oBAC1B,IAAI,EAAE,wBAAwB;oBAC9B,YAAY,EAAE,OAAO,CAAC,IAAI;oBAC1B,MAAM,EAAE,EAAE,OAAO,EAAE,OAAO,CAAC,IAAI,EAAE,WAAW,EAAE,YAAY,EAAE,MAAM,EAAE,IAAI,CAAC,MAAM,IAAI,OAAO,CAAC,MAAM,EAAE,UAAU,EAAE,IAAI,CAAC,UAAU,EAAE;iBACjI,EACD,EAAE,OAAO,EAAE,IAAI,CAAC,OAAO,EAAE,YAAY,EAAE,IAAI,CAAC,YAAY,EAAE,CAC3D,CAAC;gBACF,IAAI,CAAC,MAAM,CAAC,OAAO;oBAAE,OAAO,EAAE,IAAI,EAAE,YAAY,CAAC,MAAM,CAAC,MAAM,CAAC,EAAE,CAAC;YACpE,CAAC;YACD,MAAM,IAAI,GAA4B,EAAE,WAAW,EAAE,IAAI,CAAC,WAAW,EAAE,CAAC;YACxE,IAAI,IAAI,CAAC,MAAM;gBAAE,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC;YAC3C,IAAI,IAAI,CAAC,UAAU;gBAAE,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC;YAC5C,IAAI,IAAI,CAAC,QAAQ;gBAAE,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,QAAQ,CAAC;YACjD,MAAM,UAAU,GAAG,MAAM,GAAG,CAAC,MAAM,CAAC,OAAO,CAAa,aAAa,OAAO,CAAC,EAAE,cAAc,EAAE,EAAE,MAAM,EAAE,MAAM,EAAE,IAAI,EAAE,CAAC,CAAC;YAEzH,IAAI,CAAC,IAAI,CAAC,IAAI,EAAE,CAAC;gBACf,OAAO,EAAE,IAAI,EAAE,aAAa,IAAI,CAAC,WAAW,aAAa,uBAAuB,CAAC,UAAU,CAAC,EAAE,EAAE,IAAI,EAAE,UAAU,EAAE,CAAC;YACrH,CAAC;YAED,MAAM,KAAK,GAAG,MAAM,SAAS,CAC3B,GAAG,EAAE,CAAC,GAAG,CAAC,MAAM,CAAC,OAAO,CAAa,aAAa,OAAO,CAAC,EAAE,gBAAgB,UAAU,CAAC,EAAE,EAAE,CAAC,EAC5F,CAAC,CAAC,EAAE,EAAE,CAAC,iBAAiB,CAAC,GAAG,CAAC,CAAC,CAAC,MAAM,CAAC,EACtC,EAAE,UAAU,EAAE,IAAI,EAAE,SAAS,EAAE,IAAI,CAAC,UAAU,EAAE,cAAc,EAAE,IAAI,EAAE,CACvE,CAAC;YAEF,MAAM,MAAM,GAAG,KAAK,CAAC,KAAK,CAAC;YAC3B,MAAM,IAAI,GAAG,MAAM,GAAG,CAAC,MAAM,CAAC,OAAO,CAAa,gBAAgB,MAAM,CAAC,EAAE,OAAO,CAAC,CAAC,KAAK,CAAC,GAAG,EAAE,CAAC,EAAgB,CAAC,CAAC;YAClH,MAAM,SAAS,GAAG,UAAU,CAAC,IAAI,EAAE,EAAE,QAAQ,EAAE,EAAE,EAAE,IAAI,EAAE,IAAI,EAAE,CAAC,CAAC;YACjE,MAAM,MAAM,GAAG,cAAc,MAAM,CAAC,EAAE,MAAM,MAAM,CAAC,MAAM,GAAG,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,cAAc,EAAE,CAAC;YAC/F,MAAM,IAAI,GAAG,MAAM,CAAC,MAAM,KAAK,QAAQ,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,kBAAkB,SAAS,CAAC,IAAI,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;YACjG,OAAO,EAAE,IAAI,EAAE,GAAG,MAAM,KAAK,uBAAuB,CAAC,MAAM,CAAC,GAAG,IAAI,EAAE,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC;QACxF,CAAC;KACF,CAAC,CAAC;IAEH,YAAY,CAAC,MAAM,EAAE,GAAG,EAAE;QACxB,IAAI,EAAE,YAAY;QAClB,WAAW,EACT,yKAAyK;QAC3K,WAAW,EAAE;YACX,UAAU,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;YACjC,OAAO,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;YAC9B,WAAW,EAAE,SAAS,CAAC,OAAO,CAAC,YAAY,CAAC;YAC5C,GAAG,EAAE,CAAC,CAAC,MAAM,EAAE;YACf,KAAK,EAAE,CAAC,CAAC,MAAM,EAAE;SAClB;QACD,OAAO,EAAE,KAAK,EAAE,IAAI,EAAE,EAAE;YACtB,IAAI,IAAI,CAAC,GAAG,CAAC,UAAU,CAAC,cAAc,CAAC,EAAE,CAAC;gBACxC,OAAO;oBACL,IAAI,EAAE,kHAAkH;oBACxH,OAAO,EAAE,IAAI;iBACd,CAAC;YACJ,CAAC;YACD,MAAM,EAAE,OAAO,EAAE,GAAG,MAAM,cAAc,CAAC,GAAG,EAAE,IAAI,CAAC,CAAC;YACpD,MAAM,GAAG,CAAC,MAAM,CAAC,OAAO,CAAC,aAAa,OAAO,CAAC,EAAE,UAAU,EAAE;gBAC1D,MAAM,EAAE,MAAM;gBACd,IAAI,EAAE,EAAE,WAAW,EAAE,IAAI,CAAC,WAAW,EAAE,GAAG,EAAE,IAAI,CAAC,GAAG,EAAE,KAAK,EAAE,IAAI,CAAC,KAAK,EAAE;aAC1E,CAAC,CAAC;YACH,OAAO,EAAE,IAAI,EAAE,cAAc,IAAI,CAAC,GAAG,OAAO,IAAI,CAAC,WAAW,aAAa,OAAO,CAAC,IAAI,GAAG,EAAE,CAAC;QAC7F,CAAC;KACF,CAAC,CAAC;IAEH,YAAY,CAAC,MAAM,EAAE,GAAG,EAAE;QACxB,IAAI,EAAE,aAAa;QACnB,WAAW,EAAE,8GAA8G;QAC3H,WAAW,EAAE;YACX,UAAU,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;YACjC,OAAO,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;YAC9B,WAAW,EAAE,SAAS,CAAC,OAAO,CAAC,YAAY,CAAC;YAC5C,GAAG,EAAE,CAAC,CAAC,MAAM,EAAE;YACf,KAAK,EAAE,CAAC,CAAC,MAAM,EAAE;SAClB;QACD,OAAO,EAAE,KAAK,EAAE,IAAI,EAAE,EAAE;YACtB,MAAM,EAAE,OAAO,EAAE,GAAG,MAAM,cAAc,CAAC,GAAG,EAAE,IAAI,CAAC,CAAC;YACpD,MAAM,GAAG,CAAC,MAAM,CAAC,OAAO,CAAC,aAAa,OAAO,CAAC,EAAE,MAAM,EAAE;gBACtD,MAAM,EAAE,MAAM;gBACd,IAAI,EAAE,EAAE,WAAW,EAAE,IAAI,CAAC,WAAW,EAAE,GAAG,EAAE,IAAI,CAAC,GAAG,EAAE,KAAK,EAAE,IAAI,CAAC,KAAK,EAAE;aAC1E,CAAC,CAAC;YACH,OAAO,EAAE,IAAI,EAAE,OAAO,IAAI,CAAC,GAAG,OAAO,IAAI,CAAC,WAAW,aAAa,OAAO,CAAC,IAAI,GAAG,EAAE,CAAC;QACtF,CAAC;KACF,CAAC,CAAC;IAEH,YAAY,CAAC,MAAM,EAAE,GAAG,EAAE;QACxB,IAAI,EAAE,qBAAqB;QAC3B,WAAW,EAAE,oHAAoH;QACjI,WAAW,EAAE;YACX,UAAU,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;YACjC,OAAO,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;YAC9B,aAAa,EAAE,CAAC,CAAC,MAAM,EAAE;YACzB,UAAU,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,GAAG,EAAE,CAAC,QAAQ,EAAE,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC,OAAO,CAAC,OAAO,CAAC;SACtE;QACD,OAAO,EAAE,KAAK,EAAE,IAAI,EAAE,EAAE;YACtB,MAAM,EAAE,OAAO,EAAE,GAAG,MAAM,cAAc,CAAC,GAAG,EAAE,IAAI,CAAC,CAAC;YACpD,MAAM,MAAM,GAAG,MAAM,SAAS,CAC5B,GAAG,EAAE,CAAC,GAAG,CAAC,MAAM,CAAC,OAAO,CAAa,aAAa,OAAO,CAAC,EAAE,gBAAgB,IAAI,CAAC,aAAa,EAAE,CAAC,EACjG,CAAC,CAAC,EAAE,EAAE,CAAC,iBAAiB,CAAC,GAAG,CAAC,CAAC,CAAC,MAAM,CAAC,EACtC,EAAE,UAAU,EAAE,IAAI,EAAE,SAAS,EAAE,IAAI,CAAC,UAAU,EAAE,CACjD,CAAC;YACF,OAAO;gBACL,IAAI,EAAE,MAAM,CAAC,IAAI;oBACf,CAAC,CAAC,cAAc,IAAI,CAAC,aAAa,aAAa,MAAM,CAAC,KAAK,CAAC,MAAM,QAAQ,MAAM,CAAC,SAAS,QAAQ,uBAAuB,CAAC,MAAM,CAAC,KAAK,CAAC,EAAE;oBACzI,CAAC,CAAC,qCAAqC,MAAM,CAAC,KAAK,CAAC,MAAM,WAAW,MAAM,CAAC,SAAS,KAAK;gBAC5F,IAAI,EAAE,MAAM,CAAC,KAAK;aACnB,CAAC;QACJ,CAAC;KACF,CAAC,CAAC;IAEH,YAAY,CAAC,MAAM,EAAE,GAAG,EAAE;QACxB,IAAI,EAAE,kBAAkB;QACxB,WAAW,EACT,kLAAkL;QACpL,WAAW,EAAE;YACX,UAAU,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;YACjC,OAAO,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;YAC9B,WAAW,EAAE,GAAG;YAChB,MAAM,EAAE,CAAC,CAAC,OAAO,EAAE,CAAC,OAAO,CAAC,KAAK,CAAC;YAClC,SAAS,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,GAAG,EAAE,CAAC,QAAQ,EAAE,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC,OAAO,CAAC,GAAG,CAAC;YAC7D,UAAU,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,GAAG,EAAE,CAAC,QAAQ,EAAE,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC,OAAO,CAAC,OAAO,CAAC;SACtE;QACD,WAAW,EAAE,EAAE,YAAY,EAAE,IAAI,EAAE;QACnC,OAAO,EAAE,KAAK,EAAE,IAAI,EAAE,EAAE;YACtB,MAAM,EAAE,OAAO,EAAE,GAAG,MAAM,cAAc,CAAC,GAAG,EAAE,IAAI,CAAC,CAAC;YACpD,MAAM,WAAW,GAAG,MAAM,GAAG,CAAC,MAAM,CAAC,OAAO,CAC1C,aAAa,OAAO,CAAC,EAAE,cAAc,EACrC,EAAE,KAAK,EAAE,EAAE,WAAW,EAAE,IAAI,CAAC,WAAW,EAAE,KAAK,EAAE,CAAC,EAAE,EAAE,CACvD,CAAC;YACF,MAAM,MAAM,GAAG,CAAC,WAAW,CAAC,WAAW,IAAI,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC;YAClD,IAAI,CAAC,MAAM,EAAE,CAAC;gBACZ,OAAO,EAAE,IAAI,EAAE,OAAO,IAAI,CAAC,WAAW,wBAAwB,OAAO,CAAC,IAAI,GAAG,EAAE,CAAC;YAClF,CAAC;YAED,IAAI,OAAO,GAAG,MAAM,CAAC;YACrB,IAAI,IAAI,GAAG,MAAM,GAAG,CAAC,MAAM,CAAC,OAAO,CAAa,gBAAgB,OAAO,CAAC,EAAE,OAAO,CAAC,CAAC,KAAK,CAAC,GAAG,EAAE,CAAC,EAAgB,CAAC,CAAC;YAEjH,IAAI,IAAI,CAAC,MAAM,IAAI,CAAC,iBAAiB,CAAC,GAAG,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE,CAAC;gBAC1D,MAAM,KAAK,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;gBACzB,OAAO,IAAI,CAAC,GAAG,EAAE,GAAG,KAAK,GAAG,IAAI,CAAC,UAAU,EAAE,CAAC;oBAC5C,MAAM,KAAK,CAAC,IAAI,CAAC,CAAC;oBAClB,OAAO,GAAG,MAAM,GAAG,CAAC,MAAM,CAAC,OAAO,CAAa,aAAa,OAAO,CAAC,EAAE,gBAAgB,OAAO,CAAC,EAAE,EAAE,CAAC,CAAC;oBACpG,IAAI,GAAG,MAAM,GAAG,CAAC,MAAM,CAAC,OAAO,CAAa,gBAAgB,OAAO,CAAC,EAAE,OAAO,CAAC,CAAC,KAAK,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,CAAC;oBACjG,IAAI,iBAAiB,CAAC,GAAG,CAAC,OAAO,CAAC,MAAM,CAAC;wBAAE,MAAM;gBACnD,CAAC;YACH,CAAC;YAED,MAAM,SAAS,GAAG,UAAU,CAAC,IAAI,EAAE,EAAE,QAAQ,EAAE,IAAI,CAAC,SAAS,EAAE,IAAI,EAAE,IAAI,EAAE,CAAC,CAAC;YAC7E,MAAM,aAAa,GAAG,OAAO,CAAC,WAAW,CAAC,CAAC,CAAC,eAAe,OAAO,CAAC,WAAW,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;YACtF,MAAM,MAAM,GAAG,cAAc,OAAO,CAAC,EAAE,MAAM,OAAO,CAAC,MAAM,GAAG,aAAa,KAAK,OAAO,CAAC,WAAW,MAAM,OAAO,CAAC,MAAM,aAAa,OAAO,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,IAAI,CAAC;YACvK,MAAM,YAAY,GAAG,SAAS,CAAC,YAAY,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,0BAA0B,SAAS,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;YAC5H,MAAM,MAAM,GAAG,SAAS,CAAC,IAAI,CAAC,CAAC,CAAC,OAAO,SAAS,CAAC,IAAI,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;YAC7D,OAAO;gBACL,IAAI,EAAE,GAAG,MAAM,KAAK,SAAS,CAAC,IAAI,GAAG,YAAY,GAAG,MAAM,EAAE;gBAC5D,IAAI,EAAE,EAAE,UAAU,EAAE,OAAO,EAAE,QAAQ,EAAE,EAAE,UAAU,EAAE,SAAS,CAAC,UAAU,EAAE,aAAa,EAAE,SAAS,CAAC,aAAa,EAAE,SAAS,EAAE,SAAS,CAAC,SAAS,EAAE,YAAY,EAAE,SAAS,CAAC,YAAY,EAAE,EAAE;aAC5L,CAAC;QACJ,CAAC;KACF,CAAC,CAAC;IAEH,YAAY,CAAC,MAAM,EAAE,GAAG,EAAE;QACxB,IAAI,EAAE,yBAAyB;QAC/B,WAAW,EAAE,6GAA6G;QAC1H,WAAW,EAAE;YACX,UAAU,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;YACjC,OAAO,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;YAC9B,aAAa,EAAE,CAAC,CAAC,MAAM,EAAE;SAC1B;QACD,WAAW,EAAE,EAAE,YAAY,EAAE,IAAI,EAAE;QACnC,OAAO,EAAE,KAAK,EAAE,IAAI,EAAE,EAAE;YACtB,MAAM,EAAE,OAAO,EAAE,GAAG,MAAM,cAAc,CAAC,GAAG,EAAE,IAAI,CAAC,CAAC;YACpD,MAAM,UAAU,GAAG,MAAM,GAAG,CAAC,MAAM,CAAC,OAAO,CAAa,aAAa,OAAO,CAAC,EAAE,gBAAgB,IAAI,CAAC,aAAa,EAAE,CAAC,CAAC;YACrH,MAAM,IAAI,GAAG,MAAM,GAAG,CAAC,MAAM,CAAC,OAAO,CAAa,gBAAgB,UAAU,CAAC,EAAE,OAAO,CAAC,CAAC,KAAK,CAAC,GAAG,EAAE,CAAC,EAAgB,CAAC,CAAC;YACtH,MAAM,SAAS,GAAG,UAAU,CAAC,IAAI,EAAE,EAAE,QAAQ,EAAE,GAAG,EAAE,IAAI,EAAE,IAAI,EAAE,CAAC,CAAC;YAClE,MAAM,aAAa,GAAG,GAAG,CAAC,MAAM,CAAC,aAAa,CAAC,UAAU,CAAC,EAAE,CAAC,CAAC;YAC9D,MAAM,QAAQ,GAAG;gBACf,uBAAuB,CAAC,UAAU,CAAC;gBACnC,EAAE;gBACF,aAAa,SAAS,CAAC,aAAa,IAAI,SAAS,CAAC,UAAU,UAAU;gBACtE,SAAS,CAAC,IAAI;aACf,CAAC;YACF,IAAI,SAAS,CAAC,YAAY,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;gBACtC,QAAQ,CAAC,IAAI,CAAC,EAAE,EAAE,2BAA2B,SAAS,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;YACpF,CAAC;YACD,QAAQ,CAAC,IAAI,CAAC,EAAE,EAAE,iCAAiC,aAAa,EAAE,CAAC,CAAC;YACpE,OAAO,EAAE,IAAI,EAAE,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,EAAE,UAAU,EAAE,QAAQ,EAAE,SAAS,EAAE,aAAa,EAAE,EAAE,CAAC;QACjG,CAAC;KACF,CAAC,CAAC;IAEH,YAAY,CAAC,MAAM,EAAE,GAAG,EAAE;QACxB,IAAI,EAAE,oBAAoB;QAC1B,WAAW,EAAE,qHAAqH;QAClI,WAAW,EAAE;YACX,UAAU,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;YACjC,OAAO,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;SAC/B;QACD,WAAW,EAAE,EAAE,YAAY,EAAE,IAAI,EAAE;QACnC,OAAO,EAAE,KAAK,EAAE,IAAI,EAAE,EAAE;YACtB,MAAM,EAAE,OAAO,EAAE,GAAG,MAAM,cAAc,CAAC,GAAG,EAAE,IAAI,CAAC,CAAC;YACpD,MAAM,CAAC,OAAO,EAAE,OAAO,EAAE,UAAU,EAAE,WAAW,EAAE,cAAc,CAAC,GAAG,MAAM,OAAO,CAAC,GAAG,CAAC;gBACpF,GAAG,CAAC,MAAM,CAAC,OAAO,CAAW,aAAa,OAAO,CAAC,EAAE,UAAU,CAAC,CAAC,KAAK,CAAC,GAAG,EAAE,CAAC,EAAc,CAAC;gBAC3F,GAAG,CAAC,MAAM,CAAC,OAAO,CAAe,aAAa,OAAO,CAAC,EAAE,UAAU,CAAC,CAAC,KAAK,CAAC,GAAG,EAAE,CAAC,EAAkB,CAAC;gBACnG,GAAG,CAAC,MAAM,CAAC,OAAO,CAAmB,aAAa,OAAO,CAAC,EAAE,aAAa,CAAC,CAAC,KAAK,CAAC,GAAG,EAAE,CAAC,CAAC,EAAE,eAAe,EAAE,KAAK,EAAE,kBAAkB,EAAE,KAAK,EAAuB,CAAA,CAAC;gBACnK,GAAG,CAAC,MAAM,CAAC,OAAO,CAA+C,aAAa,OAAO,CAAC,EAAE,cAAc,EAAE;oBACtG,KAAK,EAAE,EAAE,WAAW,EAAE,SAAS,EAAE,KAAK,EAAE,CAAC,EAAE;iBAC5C,CAAC,CAAC,KAAK,CAAC,GAAG,EAAE,CAAC,CAAC,EAAE,WAAW,EAAE,EAAE,EAAE,KAAK,EAAE,CAAC,EAAE,CAAC,CAAC;gBAC/C,GAAG,CAAC,MAAM,CAAC,OAAO,CAA+C,aAAa,OAAO,CAAC,EAAE,cAAc,EAAE;oBACtG,KAAK,EAAE,EAAE,WAAW,EAAE,YAAY,EAAE,KAAK,EAAE,CAAC,EAAE;iBAC/C,CAAC,CAAC,KAAK,CAAC,GAAG,EAAE,CAAC,CAAC,EAAE,WAAW,EAAE,EAAE,EAAE,KAAK,EAAE,CAAC,EAAE,CAAC,CAAC;aAChD,CAAC,CAAC;YACH,MAAM,KAAK,GAAG;gBACZ,oBAAoB,CAAC,OAAO,CAAC;gBAC7B,EAAE;gBACF,sBAAsB,WAAW,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,WAAW,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,MAAM,MAAM,WAAW,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,QAAQ,EAAE;gBACzI,sBAAsB,cAAc,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,cAAc,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,MAAM,MAAM,cAAc,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,QAAQ,EAAE;gBAClJ,EAAE;gBACF,UAAU;gBACV,iBAAiB,CAAC,OAAO,CAAC;gBAC1B,EAAE;gBACF,UAAU;gBACV,iBAAiB,CAAC,OAAO,CAAC;gBAC1B,EAAE;gBACF,aAAa;gBACb,gBAAgB,CAAC,UAAU,CAAC;aAC7B,CAAC;YACF,OAAO;gBACL,IAAI,EAAE,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC;gBACtB,IAAI,EAAE;oBACJ,OAAO;oBACP,MAAM,EAAE,EAAE,OAAO,EAAE,WAAW,CAAC,WAAW,CAAC,CAAC,CAAC,IAAI,IAAI,EAAE,UAAU,EAAE,cAAc,CAAC,WAAW,CAAC,CAAC,CAAC,IAAI,IAAI,EAAE;oBAC1G,OAAO;oBACP,OAAO;oBACP,UAAU;iBACX;aACF,CAAC;QACJ,CAAC;KACF,CAAC,CAAC;IAEH,YAAY,CAAC,MAAM,EAAE,GAAG,EAAE;QACxB,IAAI,EAAE,cAAc;QACpB,WAAW,EAAE,2IAA2I;QACxJ,WAAW,EAAE,EAAE,YAAY,EAAE,IAAI,EAAE;QACnC,OAAO,EAAE,KAAK,IAAI,EAAE;YAClB,MAAM,OAAO,GAAG,WAAW,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;YAC1C,IAAI,CAAC,OAAO,EAAE,CAAC;gBACb,OAAO,EAAE,IAAI,EAAE,6EAA6E,EAAE,CAAC;YACjG,CAAC;YACD,MAAM,QAAQ,GAAG,MAAM,aAAa,CAAC,GAAG,CAAC,CAAC,KAAK,CAAC,GAAG,EAAE,CAAC,EAAE,CAAC,CAAC;YAC1D,MAAM,OAAO,GAAG,QAAQ,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,OAAO,CAAC,OAAO,CAAC,CAAC;YACjE,MAAM,KAAK,GAAG;gBACZ,YAAY,GAAG,CAAC,QAAQ,IAAI;gBAC5B,0BAA0B,OAAO,CAAC,OAAO,EAAE;gBAC3C,0BAA0B,OAAO,CAAC,SAAS,IAAI,SAAS,EAAE;gBAC1D,0BAA0B,OAAO,CAAC,kBAAkB,IAAI,SAAS,EAAE;aACpE,CAAC;YACF,IAAI,OAAO;gBAAE,KAAK,CAAC,IAAI,CAAC,EAAE,EAAE,oBAAoB,CAAC,OAAO,CAAC,CAAC,CAAC;YAC3D,OAAO,EAAE,IAAI,EAAE,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,EAAE,OAAO,EAAE,OAAO,EAAE,EAAE,CAAC;QAChE,CAAC;KACF,CAAC,CAAC;AACL,CAAC"}
@@ -0,0 +1,48 @@
1
+ import { registerTool } from "./_helpers.js";
2
+ export function registerWorkspaceTools(server, ctx) {
3
+ registerTool(server, ctx, {
4
+ name: "list_workspaces",
5
+ description: "List workspaces (organizations) the token owner can see.",
6
+ annotations: { readOnlyHint: true },
7
+ handler: async () => {
8
+ const orgs = await ctx.client.request(`/organizations`);
9
+ const text = orgs
10
+ .map((o) => ` • ${o.slug.padEnd(24)} ${o.is_personal ? "personal" : "shared"} role=${o.membership_role} projects=${o.project_count}`)
11
+ .join("\n");
12
+ return { text, data: orgs };
13
+ },
14
+ });
15
+ registerTool(server, ctx, {
16
+ name: "get_platform_info",
17
+ description: "Get platform info — currently the VPS IP for DNS A-record setup of custom domains.",
18
+ annotations: { readOnlyHint: true },
19
+ handler: async () => {
20
+ const info = await ctx.client.request(`/platform`);
21
+ return { text: `DNS target IP (point custom domains here): ${info.dns_target_ip}`, data: info };
22
+ },
23
+ });
24
+ registerTool(server, ctx, {
25
+ name: "whoami",
26
+ description: "Return the user the current token belongs to. Use this to validate connectivity + auth on startup.",
27
+ annotations: { readOnlyHint: true },
28
+ handler: async () => {
29
+ const user = await ctx.client.request(`/auth/me`);
30
+ return {
31
+ text: `Authenticated as ${user.username} (${user.role}) — github_id=${user.github_id}, user_id=${user.id}`,
32
+ data: user,
33
+ };
34
+ },
35
+ });
36
+ registerTool(server, ctx, {
37
+ name: "get_health",
38
+ description: "Public health probe — no auth required. Returns the server version block.",
39
+ annotations: { readOnlyHint: true },
40
+ handler: async () => {
41
+ const health = await ctx.client.request(`/health`);
42
+ const v = health.version;
43
+ const versionLine = v ? `version ${v.git_sha} (built ${v.build_time})` : "(no version info)";
44
+ return { text: `Status: ${health.status} — ${versionLine}`, data: health };
45
+ },
46
+ });
47
+ }
48
+ //# sourceMappingURL=workspaces.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"workspaces.js","sourceRoot":"","sources":["../../src/tools/workspaces.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,YAAY,EAAoB,MAAM,eAAe,CAAC;AAG/D,MAAM,UAAU,sBAAsB,CAAC,MAAiB,EAAE,GAAgB;IACxE,YAAY,CAAC,MAAM,EAAE,GAAG,EAAE;QACxB,IAAI,EAAE,iBAAiB;QACvB,WAAW,EAAE,0DAA0D;QACvE,WAAW,EAAE,EAAE,YAAY,EAAE,IAAI,EAAE;QACnC,OAAO,EAAE,KAAK,IAAI,EAAE;YAClB,MAAM,IAAI,GAAG,MAAM,GAAG,CAAC,MAAM,CAAC,OAAO,CAAiB,gBAAgB,CAAC,CAAC;YACxE,MAAM,IAAI,GAAG,IAAI;iBACd,GAAG,CACF,CAAC,CAAC,EAAE,EAAE,CACJ,OAAO,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,EAAE,CAAC,KAAK,CAAC,CAAC,WAAW,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,QAAQ,UAAU,CAAC,CAAC,eAAe,cAAc,CAAC,CAAC,aAAa,EAAE,CAC/H;iBACA,IAAI,CAAC,IAAI,CAAC,CAAC;YACd,OAAO,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,CAAC;QAC9B,CAAC;KACF,CAAC,CAAC;IAEH,YAAY,CAAC,MAAM,EAAE,GAAG,EAAE;QACxB,IAAI,EAAE,mBAAmB;QACzB,WAAW,EAAE,oFAAoF;QACjG,WAAW,EAAE,EAAE,YAAY,EAAE,IAAI,EAAE;QACnC,OAAO,EAAE,KAAK,IAAI,EAAE;YAClB,MAAM,IAAI,GAAG,MAAM,GAAG,CAAC,MAAM,CAAC,OAAO,CAAe,WAAW,CAAC,CAAC;YACjE,OAAO,EAAE,IAAI,EAAE,8CAA8C,IAAI,CAAC,aAAa,EAAE,EAAE,IAAI,EAAE,IAAI,EAAE,CAAC;QAClG,CAAC;KACF,CAAC,CAAC;IAEH,YAAY,CAAC,MAAM,EAAE,GAAG,EAAE;QACxB,IAAI,EAAE,QAAQ;QACd,WAAW,EAAE,oGAAoG;QACjH,WAAW,EAAE,EAAE,YAAY,EAAE,IAAI,EAAE;QACnC,OAAO,EAAE,KAAK,IAAI,EAAE;YAClB,MAAM,IAAI,GAAG,MAAM,GAAG,CAAC,MAAM,CAAC,OAAO,CAAO,UAAU,CAAC,CAAC;YACxD,OAAO;gBACL,IAAI,EAAE,oBAAoB,IAAI,CAAC,QAAQ,KAAK,IAAI,CAAC,IAAI,iBAAiB,IAAI,CAAC,SAAS,aAAa,IAAI,CAAC,EAAE,EAAE;gBAC1G,IAAI,EAAE,IAAI;aACX,CAAC;QACJ,CAAC;KACF,CAAC,CAAC;IAEH,YAAY,CAAC,MAAM,EAAE,GAAG,EAAE;QACxB,IAAI,EAAE,YAAY;QAClB,WAAW,EAAE,2EAA2E;QACxF,WAAW,EAAE,EAAE,YAAY,EAAE,IAAI,EAAE;QACnC,OAAO,EAAE,KAAK,IAAI,EAAE;YAClB,MAAM,MAAM,GAAG,MAAM,GAAG,CAAC,MAAM,CAAC,OAAO,CAAiB,SAAS,CAAC,CAAC;YACnE,MAAM,CAAC,GAAG,MAAM,CAAC,OAAO,CAAC;YACzB,MAAM,WAAW,GAAG,CAAC,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,OAAO,WAAW,CAAC,CAAC,UAAU,GAAG,CAAC,CAAC,CAAC,mBAAmB,CAAC;YAC7F,OAAO,EAAE,IAAI,EAAE,WAAW,MAAM,CAAC,MAAM,MAAM,WAAW,EAAE,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC;QAC7E,CAAC;KACF,CAAC,CAAC;AACL,CAAC"}
package/package.json ADDED
@@ -0,0 +1,50 @@
1
+ {
2
+ "name": "@lovinka/deployik-mcp",
3
+ "version": "0.1.0",
4
+ "description": "MCP server for Deployik — drive projects, deployments, secrets, and domains from any MCP-aware AI.",
5
+ "type": "module",
6
+ "main": "dist/index.js",
7
+ "bin": {
8
+ "deployik-mcp": "dist/index.js"
9
+ },
10
+ "files": [
11
+ "dist",
12
+ "README.md"
13
+ ],
14
+ "scripts": {
15
+ "prebuild": "node scripts/copy-recipes.mjs",
16
+ "build": "tsc -p tsconfig.json",
17
+ "dev": "node scripts/copy-recipes.mjs && tsc -p tsconfig.json --watch",
18
+ "start": "node dist/index.js",
19
+ "inspect": "node scripts/copy-recipes.mjs && tsc -p tsconfig.json && npx @modelcontextprotocol/inspector node dist/index.js",
20
+ "typecheck": "tsc -p tsconfig.json --noEmit",
21
+ "test": "bun test",
22
+ "prepublishOnly": "npm run build"
23
+ },
24
+ "engines": {
25
+ "node": ">=20"
26
+ },
27
+ "keywords": [
28
+ "mcp",
29
+ "model-context-protocol",
30
+ "deployik",
31
+ "lovinka",
32
+ "ai"
33
+ ],
34
+ "author": "Lovinka",
35
+ "license": "MIT",
36
+ "repository": {
37
+ "type": "git",
38
+ "url": "https://github.com/lefteq/lovinka-deployik.git",
39
+ "directory": "mcp"
40
+ },
41
+ "dependencies": {
42
+ "@modelcontextprotocol/sdk": "^1.18.0",
43
+ "zod": "^3.23.8"
44
+ },
45
+ "devDependencies": {
46
+ "@types/bun": "^1.3.13",
47
+ "@types/node": "^22.10.0",
48
+ "typescript": "^5.8.0"
49
+ }
50
+ }