@duckcodeailabs/dql-cli 1.0.4 → 1.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 (99) hide show
  1. package/dist/args.d.ts +1 -0
  2. package/dist/args.d.ts.map +1 -1
  3. package/dist/args.js +4 -0
  4. package/dist/args.js.map +1 -1
  5. package/dist/assets/dql-notebook/assets/index-DWPIGGBJ.js +628 -0
  6. package/dist/assets/dql-notebook/index.html +1 -1
  7. package/dist/commands/app.d.ts +3 -0
  8. package/dist/commands/app.d.ts.map +1 -0
  9. package/dist/commands/app.js +191 -0
  10. package/dist/commands/app.js.map +1 -0
  11. package/dist/commands/build.d.ts.map +1 -1
  12. package/dist/commands/build.js +30 -2
  13. package/dist/commands/build.js.map +1 -1
  14. package/dist/commands/fmt.d.ts.map +1 -1
  15. package/dist/commands/fmt.js +26 -9
  16. package/dist/commands/fmt.js.map +1 -1
  17. package/dist/commands/init.d.ts.map +1 -1
  18. package/dist/commands/init.js +1 -1
  19. package/dist/commands/init.js.map +1 -1
  20. package/dist/commands/mcp.d.ts +7 -0
  21. package/dist/commands/mcp.d.ts.map +1 -0
  22. package/dist/commands/mcp.js +16 -0
  23. package/dist/commands/mcp.js.map +1 -0
  24. package/dist/commands/schedule.d.ts +3 -0
  25. package/dist/commands/schedule.d.ts.map +1 -0
  26. package/dist/commands/schedule.js +215 -0
  27. package/dist/commands/schedule.js.map +1 -0
  28. package/dist/digest.d.ts +10 -0
  29. package/dist/digest.d.ts.map +1 -0
  30. package/dist/digest.js +83 -0
  31. package/dist/digest.js.map +1 -0
  32. package/dist/index.js +16 -1
  33. package/dist/index.js.map +1 -1
  34. package/dist/llm/index.d.ts +4 -0
  35. package/dist/llm/index.d.ts.map +1 -0
  36. package/dist/llm/index.js +16 -0
  37. package/dist/llm/index.js.map +1 -0
  38. package/dist/llm/providers/claude-agent-sdk.d.ts +3 -0
  39. package/dist/llm/providers/claude-agent-sdk.d.ts.map +1 -0
  40. package/dist/llm/providers/claude-agent-sdk.js +174 -0
  41. package/dist/llm/providers/claude-agent-sdk.js.map +1 -0
  42. package/dist/llm/providers/claude-code.d.ts +8 -0
  43. package/dist/llm/providers/claude-code.d.ts.map +1 -0
  44. package/dist/llm/providers/claude-code.js +171 -0
  45. package/dist/llm/providers/claude-code.js.map +1 -0
  46. package/dist/llm/tools.d.ts +9 -0
  47. package/dist/llm/tools.d.ts.map +1 -0
  48. package/dist/llm/tools.js +112 -0
  49. package/dist/llm/tools.js.map +1 -0
  50. package/dist/llm/types.d.ts +70 -0
  51. package/dist/llm/types.d.ts.map +1 -0
  52. package/dist/llm/types.js +2 -0
  53. package/dist/llm/types.js.map +1 -0
  54. package/dist/local-runtime.d.ts +6 -0
  55. package/dist/local-runtime.d.ts.map +1 -1
  56. package/dist/local-runtime.js +174 -3
  57. package/dist/local-runtime.js.map +1 -1
  58. package/dist/schedule/alerts.d.ts +5 -0
  59. package/dist/schedule/alerts.d.ts.map +1 -0
  60. package/dist/schedule/alerts.js +54 -0
  61. package/dist/schedule/alerts.js.map +1 -0
  62. package/dist/schedule/discovery.d.ts +4 -0
  63. package/dist/schedule/discovery.d.ts.map +1 -0
  64. package/dist/schedule/discovery.js +36 -0
  65. package/dist/schedule/discovery.js.map +1 -0
  66. package/dist/schedule/notifiers/email.d.ts +3 -0
  67. package/dist/schedule/notifiers/email.d.ts.map +1 -0
  68. package/dist/schedule/notifiers/email.js +76 -0
  69. package/dist/schedule/notifiers/email.js.map +1 -0
  70. package/dist/schedule/notifiers/file.d.ts +3 -0
  71. package/dist/schedule/notifiers/file.d.ts.map +1 -0
  72. package/dist/schedule/notifiers/file.js +50 -0
  73. package/dist/schedule/notifiers/file.js.map +1 -0
  74. package/dist/schedule/notifiers/index.d.ts +10 -0
  75. package/dist/schedule/notifiers/index.d.ts.map +1 -0
  76. package/dist/schedule/notifiers/index.js +33 -0
  77. package/dist/schedule/notifiers/index.js.map +1 -0
  78. package/dist/schedule/notifiers/slack.d.ts +3 -0
  79. package/dist/schedule/notifiers/slack.d.ts.map +1 -0
  80. package/dist/schedule/notifiers/slack.js +58 -0
  81. package/dist/schedule/notifiers/slack.js.map +1 -0
  82. package/dist/schedule/runner.d.ts +11 -0
  83. package/dist/schedule/runner.d.ts.map +1 -0
  84. package/dist/schedule/runner.js +109 -0
  85. package/dist/schedule/runner.js.map +1 -0
  86. package/dist/schedule/runs.d.ts +5 -0
  87. package/dist/schedule/runs.d.ts.map +1 -0
  88. package/dist/schedule/runs.js +41 -0
  89. package/dist/schedule/runs.js.map +1 -0
  90. package/dist/schedule/service.d.ts +12 -0
  91. package/dist/schedule/service.d.ts.map +1 -0
  92. package/dist/schedule/service.js +49 -0
  93. package/dist/schedule/service.js.map +1 -0
  94. package/dist/schedule/types.d.ts +64 -0
  95. package/dist/schedule/types.d.ts.map +1 -0
  96. package/dist/schedule/types.js +2 -0
  97. package/dist/schedule/types.js.map +1 -0
  98. package/package.json +16 -10
  99. package/dist/assets/dql-notebook/assets/index-dZVjj9xj.js +0 -623
@@ -0,0 +1,49 @@
1
+ import { QueryExecutor } from '@duckcodeailabs/dql-connectors';
2
+ import { findProjectRoot, loadProjectConfig, normalizeProjectConnection } from '../local-runtime.js';
3
+ import { discoverScheduledBlocks } from './discovery.js';
4
+ import { runBlock } from './runner.js';
5
+ export async function startScheduleService(options = {}) {
6
+ const projectRoot = options.projectRoot ?? findProjectRoot(process.cwd());
7
+ const projectConfig = loadProjectConfig(projectRoot);
8
+ const connection = options.connection ??
9
+ normalizeProjectConnection(projectConfig.defaultConnection ?? { driver: 'duckdb' }, projectRoot);
10
+ const executor = new QueryExecutor();
11
+ const blocks = discoverScheduledBlocks(projectRoot);
12
+ // Dynamic import so node-cron stays off the hot path for one-shot commands.
13
+ const nodeCron = (await import('node-cron'));
14
+ const tasks = [];
15
+ for (const block of blocks) {
16
+ if (!nodeCron.validate(block.schedule.cron)) {
17
+ console.error(`[schedule] invalid cron "${block.schedule.cron}" on ${block.name}, skipping`);
18
+ continue;
19
+ }
20
+ const task = nodeCron.schedule(block.schedule.cron, () => {
21
+ void (async () => {
22
+ try {
23
+ const record = await runBlock(block.path, {
24
+ executor,
25
+ connection,
26
+ projectRoot,
27
+ trigger: 'cron',
28
+ });
29
+ const breached = record.alerts.filter((a) => a.breached).length;
30
+ const tag = record.error ? 'error' : breached > 0 ? `breached:${breached}` : 'ok';
31
+ console.log(`[schedule] ${record.startedAt} ${block.name} → ${tag}`);
32
+ }
33
+ catch (err) {
34
+ const msg = err instanceof Error ? err.message : String(err);
35
+ console.error(`[schedule] run failed for ${block.name}: ${msg}`);
36
+ }
37
+ })();
38
+ });
39
+ tasks.push({ stop: () => task.stop() });
40
+ }
41
+ return {
42
+ blocks,
43
+ async stop() {
44
+ for (const t of tasks)
45
+ t.stop();
46
+ },
47
+ };
48
+ }
49
+ //# sourceMappingURL=service.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"service.js","sourceRoot":"","sources":["../../src/schedule/service.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,64 @@
1
+ import type { ScheduleIR, NotificationIR, AlertIR, DigestDiagnostic } from '@duckcodeailabs/dql-compiler';
2
+ export interface ScheduledBlock {
3
+ /** Absolute path to the .dql file. */
4
+ path: string;
5
+ /** Name derived from the path, e.g. "finance/revenue_by_month". */
6
+ name: string;
7
+ schedule: ScheduleIR;
8
+ notifications: NotificationIR[];
9
+ alerts: AlertIR[];
10
+ }
11
+ export interface AlertEvaluation {
12
+ alert: AlertIR;
13
+ breached: boolean;
14
+ observedValue?: number;
15
+ reason?: string;
16
+ error?: string;
17
+ }
18
+ export interface QueryRunResult {
19
+ chartId: string;
20
+ sql: string;
21
+ rowCount: number;
22
+ durationMs: number;
23
+ error?: string;
24
+ preview?: Array<Record<string, unknown>>;
25
+ }
26
+ export interface RunRecord {
27
+ startedAt: string;
28
+ finishedAt: string;
29
+ block: string;
30
+ path: string;
31
+ trigger: 'manual' | 'cron';
32
+ queries: QueryRunResult[];
33
+ alerts: AlertEvaluation[];
34
+ notifications: Array<{
35
+ type: string;
36
+ recipients: string[];
37
+ delivered: boolean;
38
+ error?: string;
39
+ }>;
40
+ error?: string;
41
+ }
42
+ export interface NotifierPayload {
43
+ block: string;
44
+ path: string;
45
+ startedAt: string;
46
+ alerts: AlertEvaluation[];
47
+ queries: QueryRunResult[];
48
+ trigger: 'manual' | 'cron';
49
+ /** Rendered digest HTML (present when the block is a digest). */
50
+ html?: string;
51
+ /** Digest markdown sibling — preferred as an email/slack preview body. */
52
+ markdown?: string;
53
+ /** Title/name shown in digest headers, defaults to `block` when absent. */
54
+ digestTitle?: string;
55
+ digestDiagnostics?: DigestDiagnostic[];
56
+ }
57
+ export interface Notifier {
58
+ type: 'email' | 'slack' | 'file';
59
+ send(recipients: string[], payload: NotifierPayload): Promise<{
60
+ delivered: boolean;
61
+ error?: string;
62
+ }>;
63
+ }
64
+ //# sourceMappingURL=types.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../src/schedule/types.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,UAAU,EAAE,cAAc,EAAE,OAAO,EAAE,gBAAgB,EAAE,MAAM,8BAA8B,CAAC;AAE1G,MAAM,WAAW,cAAc;IAC7B,sCAAsC;IACtC,IAAI,EAAE,MAAM,CAAC;IACb,mEAAmE;IACnE,IAAI,EAAE,MAAM,CAAC;IACb,QAAQ,EAAE,UAAU,CAAC;IACrB,aAAa,EAAE,cAAc,EAAE,CAAC;IAChC,MAAM,EAAE,OAAO,EAAE,CAAC;CACnB;AAED,MAAM,WAAW,eAAe;IAC9B,KAAK,EAAE,OAAO,CAAC;IACf,QAAQ,EAAE,OAAO,CAAC;IAClB,aAAa,CAAC,EAAE,MAAM,CAAC;IACvB,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,KAAK,CAAC,EAAE,MAAM,CAAC;CAChB;AAED,MAAM,WAAW,cAAc;IAC7B,OAAO,EAAE,MAAM,CAAC;IAChB,GAAG,EAAE,MAAM,CAAC;IACZ,QAAQ,EAAE,MAAM,CAAC;IACjB,UAAU,EAAE,MAAM,CAAC;IACnB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,OAAO,CAAC,EAAE,KAAK,CAAC,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC,CAAC;CAC1C;AAED,MAAM,WAAW,SAAS;IACxB,SAAS,EAAE,MAAM,CAAC;IAClB,UAAU,EAAE,MAAM,CAAC;IACnB,KAAK,EAAE,MAAM,CAAC;IACd,IAAI,EAAE,MAAM,CAAC;IACb,OAAO,EAAE,QAAQ,GAAG,MAAM,CAAC;IAC3B,OAAO,EAAE,cAAc,EAAE,CAAC;IAC1B,MAAM,EAAE,eAAe,EAAE,CAAC;IAC1B,aAAa,EAAE,KAAK,CAAC;QAAE,IAAI,EAAE,MAAM,CAAC;QAAC,UAAU,EAAE,MAAM,EAAE,CAAC;QAAC,SAAS,EAAE,OAAO,CAAC;QAAC,KAAK,CAAC,EAAE,MAAM,CAAA;KAAE,CAAC,CAAC;IACjG,KAAK,CAAC,EAAE,MAAM,CAAC;CAChB;AAED,MAAM,WAAW,eAAe;IAC9B,KAAK,EAAE,MAAM,CAAC;IACd,IAAI,EAAE,MAAM,CAAC;IACb,SAAS,EAAE,MAAM,CAAC;IAClB,MAAM,EAAE,eAAe,EAAE,CAAC;IAC1B,OAAO,EAAE,cAAc,EAAE,CAAC;IAC1B,OAAO,EAAE,QAAQ,GAAG,MAAM,CAAC;IAC3B,iEAAiE;IACjE,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,0EAA0E;IAC1E,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,2EAA2E;IAC3E,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,iBAAiB,CAAC,EAAE,gBAAgB,EAAE,CAAC;CACxC;AAED,MAAM,WAAW,QAAQ;IACvB,IAAI,EAAE,OAAO,GAAG,OAAO,GAAG,MAAM,CAAC;IACjC,IAAI,CAAC,UAAU,EAAE,MAAM,EAAE,EAAE,OAAO,EAAE,eAAe,GAAG,OAAO,CAAC;QAAE,SAAS,EAAE,OAAO,CAAC;QAAC,KAAK,CAAC,EAAE,MAAM,CAAA;KAAE,CAAC,CAAC;CACvG"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=types.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.js","sourceRoot":"","sources":["../../src/schedule/types.ts"],"names":[],"mappings":""}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@duckcodeailabs/dql-cli",
3
- "version": "1.0.4",
3
+ "version": "1.2.2",
4
4
  "description": "Public CLI for parsing, formatting, testing, and certifying DQL blocks",
5
5
  "license": "Apache-2.0",
6
6
  "type": "module",
@@ -19,19 +19,25 @@
19
19
  "directory": "apps/cli"
20
20
  },
21
21
  "dependencies": {
22
- "@duckcodeailabs/dql-compiler": "^1.0.4",
23
- "@duckcodeailabs/dql-connectors": "^1.0.4",
24
- "@duckcodeailabs/dql-core": "^1.0.4",
25
- "@duckcodeailabs/dql-governance": "^1.0.4",
26
- "@duckcodeailabs/dql-notebook": "^1.0.4",
27
- "@duckcodeailabs/dql-project": "^1.0.4",
28
- "isomorphic-git": "^1.27.0"
22
+ "@duckcodeailabs/dql-compiler": "^1.2.2",
23
+ "@duckcodeailabs/dql-connectors": "^1.2.2",
24
+ "@duckcodeailabs/dql-core": "^1.2.2",
25
+ "@duckcodeailabs/dql-governance": "^1.2.2",
26
+ "@duckcodeailabs/dql-mcp": "^1.2.2",
27
+ "@duckcodeailabs/dql-notebook": "^1.2.2",
28
+ "@duckcodeailabs/dql-project": "^1.2.2",
29
+ "isomorphic-git": "^1.27.0",
30
+ "js-yaml": "^4.1.0",
31
+ "node-cron": "^3.0.3",
32
+ "nodemailer": "^6.9.16"
29
33
  },
30
34
  "devDependencies": {
35
+ "@types/js-yaml": "^4.0.9",
36
+ "@types/node-cron": "^3.0.11",
37
+ "@types/nodemailer": "^6.4.17",
31
38
  "tsx": "^4.19.0",
32
39
  "typescript": "^5.7.0",
33
- "vitest": "^3.0.0",
34
- "@duckcodeailabs/dql-notebook-app": "1.0.4"
40
+ "vitest": "^3.0.0"
35
41
  },
36
42
  "engines": {
37
43
  "node": ">=18.0.0"