chkit 0.1.0-beta.21 → 0.1.0-beta.23

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 (236) hide show
  1. package/README.md +1 -1
  2. package/dist/bin/chkit.js +162 -102
  3. package/dist/bin/chkit.js.map +1 -1
  4. package/dist/bin/command-dispatch.d.ts +0 -5
  5. package/dist/bin/command-dispatch.d.ts.map +1 -1
  6. package/dist/bin/command-dispatch.js +1 -1
  7. package/dist/bin/command-dispatch.js.map +1 -1
  8. package/dist/bin/commands/drift.d.ts +2 -1
  9. package/dist/bin/commands/drift.d.ts.map +1 -1
  10. package/dist/bin/internal-plugins/skill-hint.d.ts +1 -6
  11. package/dist/bin/internal-plugins/skill-hint.d.ts.map +1 -1
  12. package/dist/bin/internal-plugins/skill-hint.js +1 -1
  13. package/dist/bin/internal-plugins/skill-hint.js.map +1 -1
  14. package/dist/bin/journal-store.d.ts +2 -6
  15. package/dist/bin/journal-store.d.ts.map +1 -1
  16. package/dist/bin/journal-store.js +1 -5
  17. package/dist/bin/journal-store.js.map +1 -1
  18. package/dist/bin/json-output.d.ts +2 -5
  19. package/dist/bin/json-output.d.ts.map +1 -1
  20. package/dist/bin/json-output.js +1 -1
  21. package/dist/bin/json-output.js.map +1 -1
  22. package/dist/bin/lib.d.ts +2 -5
  23. package/dist/bin/lib.d.ts.map +1 -1
  24. package/dist/bin/lib.js +2 -5
  25. package/dist/bin/lib.js.map +1 -1
  26. package/dist/bin/migration-store.d.ts +2 -2
  27. package/dist/bin/migration-store.d.ts.map +1 -1
  28. package/dist/bin/migration-store.js +1 -1
  29. package/dist/bin/migration-store.js.map +1 -1
  30. package/dist/bin/safety-markers.d.ts +1 -3
  31. package/dist/bin/safety-markers.d.ts.map +1 -1
  32. package/dist/bin/safety-markers.js +2 -2
  33. package/dist/bin/safety-markers.js.map +1 -1
  34. package/dist/bin/table-scope.d.ts +1 -2
  35. package/dist/bin/table-scope.d.ts.map +1 -1
  36. package/dist/bin/table-scope.js +1 -1
  37. package/dist/bin/table-scope.js.map +1 -1
  38. package/dist/commands/check/command.d.ts +3 -0
  39. package/dist/commands/check/command.d.ts.map +1 -0
  40. package/dist/commands/check/command.js +106 -0
  41. package/dist/commands/check/command.js.map +1 -0
  42. package/dist/commands/check/output.d.ts +35 -0
  43. package/dist/commands/check/output.d.ts.map +1 -0
  44. package/dist/commands/check/output.js +105 -0
  45. package/dist/commands/check/output.js.map +1 -0
  46. package/dist/commands/drift/command.d.ts +3 -0
  47. package/dist/commands/drift/command.d.ts.map +1 -0
  48. package/dist/commands/drift/command.js +128 -0
  49. package/dist/commands/drift/command.js.map +1 -0
  50. package/dist/commands/drift/compare.d.ts +66 -0
  51. package/dist/commands/drift/compare.d.ts.map +1 -0
  52. package/dist/commands/drift/compare.js +220 -0
  53. package/dist/commands/drift/compare.js.map +1 -0
  54. package/dist/commands/drift/diff.d.ts +8 -0
  55. package/dist/commands/drift/diff.d.ts.map +1 -0
  56. package/dist/commands/drift/diff.js +46 -0
  57. package/dist/commands/drift/diff.js.map +1 -0
  58. package/dist/commands/drift/payload.d.ts +24 -0
  59. package/dist/commands/drift/payload.d.ts.map +1 -0
  60. package/dist/commands/drift/payload.js +96 -0
  61. package/dist/commands/drift/payload.js.map +1 -0
  62. package/dist/commands/generate/command.d.ts +3 -0
  63. package/dist/commands/generate/command.d.ts.map +1 -0
  64. package/dist/commands/generate/command.js +163 -0
  65. package/dist/commands/generate/command.js.map +1 -0
  66. package/dist/commands/generate/output.d.ts +8 -0
  67. package/dist/commands/generate/output.d.ts.map +1 -0
  68. package/dist/commands/generate/output.js +59 -0
  69. package/dist/commands/generate/output.js.map +1 -0
  70. package/dist/commands/generate/plan-pipeline.d.ts +7 -0
  71. package/dist/commands/generate/plan-pipeline.d.ts.map +1 -0
  72. package/dist/commands/generate/plan-pipeline.js +143 -0
  73. package/dist/commands/generate/plan-pipeline.js.map +1 -0
  74. package/dist/commands/generate/rename-mappings.d.ts +29 -0
  75. package/dist/commands/generate/rename-mappings.d.ts.map +1 -0
  76. package/dist/commands/generate/rename-mappings.js +195 -0
  77. package/dist/commands/generate/rename-mappings.js.map +1 -0
  78. package/dist/commands/init.d.ts +2 -0
  79. package/dist/commands/init.d.ts.map +1 -0
  80. package/dist/commands/init.js +24 -0
  81. package/dist/commands/init.js.map +1 -0
  82. package/dist/commands/migrate/apply.d.ts +18 -0
  83. package/dist/commands/migrate/apply.d.ts.map +1 -0
  84. package/dist/commands/migrate/apply.js +48 -0
  85. package/dist/commands/migrate/apply.js.map +1 -0
  86. package/dist/commands/migrate/command.d.ts +3 -0
  87. package/dist/commands/migrate/command.d.ts.map +1 -0
  88. package/dist/commands/migrate/command.js +174 -0
  89. package/dist/commands/migrate/command.js.map +1 -0
  90. package/dist/commands/migrate/destructive.d.ts +7 -0
  91. package/dist/commands/migrate/destructive.d.ts.map +1 -0
  92. package/dist/commands/migrate/destructive.js +16 -0
  93. package/dist/commands/migrate/destructive.js.map +1 -0
  94. package/dist/commands/migrate/prompts.d.ts +6 -0
  95. package/dist/commands/migrate/prompts.d.ts.map +1 -0
  96. package/dist/commands/migrate/prompts.js +40 -0
  97. package/dist/commands/migrate/prompts.js.map +1 -0
  98. package/dist/commands/migrate/scope.d.ts +2 -0
  99. package/dist/commands/migrate/scope.d.ts.map +1 -0
  100. package/dist/commands/migrate/scope.js +25 -0
  101. package/dist/commands/migrate/scope.js.map +1 -0
  102. package/dist/commands/plugin.d.ts +3 -0
  103. package/dist/commands/plugin.d.ts.map +1 -0
  104. package/dist/commands/plugin.js +129 -0
  105. package/dist/commands/plugin.js.map +1 -0
  106. package/dist/commands/query.d.ts +8 -0
  107. package/dist/commands/query.d.ts.map +1 -0
  108. package/dist/commands/query.js +114 -0
  109. package/dist/commands/query.js.map +1 -0
  110. package/dist/commands/status.d.ts +3 -0
  111. package/dist/commands/status.d.ts.map +1 -0
  112. package/dist/commands/status.js +64 -0
  113. package/dist/commands/status.js.map +1 -0
  114. package/dist/drift.d.ts +7 -6
  115. package/dist/drift.d.ts.map +1 -1
  116. package/dist/internal-plugins/core/plugin.d.ts +2 -0
  117. package/dist/internal-plugins/core/plugin.d.ts.map +1 -0
  118. package/dist/internal-plugins/core/plugin.js +21 -0
  119. package/dist/internal-plugins/core/plugin.js.map +1 -0
  120. package/dist/internal-plugins/index.d.ts +3 -0
  121. package/dist/internal-plugins/index.d.ts.map +1 -0
  122. package/dist/internal-plugins/index.js +6 -0
  123. package/dist/internal-plugins/index.js.map +1 -0
  124. package/dist/internal-plugins/skill-hint/agent-detect.d.ts +20 -0
  125. package/dist/internal-plugins/skill-hint/agent-detect.d.ts.map +1 -0
  126. package/dist/internal-plugins/skill-hint/agent-detect.js +68 -0
  127. package/dist/internal-plugins/skill-hint/agent-detect.js.map +1 -0
  128. package/dist/internal-plugins/skill-hint/plugin.d.ts +16 -0
  129. package/dist/internal-plugins/skill-hint/plugin.d.ts.map +1 -0
  130. package/dist/internal-plugins/skill-hint/plugin.js +60 -0
  131. package/dist/internal-plugins/skill-hint/plugin.js.map +1 -0
  132. package/dist/internal-plugins/skill-hint/prompt.d.ts +5 -0
  133. package/dist/internal-plugins/skill-hint/prompt.d.ts.map +1 -0
  134. package/dist/internal-plugins/skill-hint/prompt.js +37 -0
  135. package/dist/internal-plugins/skill-hint/prompt.js.map +1 -0
  136. package/dist/internal-plugins/skill-hint/state.d.ts +7 -0
  137. package/dist/internal-plugins/skill-hint/state.d.ts.map +1 -0
  138. package/dist/internal-plugins/skill-hint/state.js +23 -0
  139. package/dist/internal-plugins/skill-hint/state.js.map +1 -0
  140. package/dist/plugins.d.ts +56 -32
  141. package/dist/plugins.d.ts.map +1 -1
  142. package/dist/plugins.js +0 -6
  143. package/dist/plugins.js.map +1 -1
  144. package/dist/runtime/command-dispatch.d.ts +18 -0
  145. package/dist/runtime/command-dispatch.d.ts.map +1 -0
  146. package/dist/runtime/command-dispatch.js +221 -0
  147. package/dist/runtime/command-dispatch.js.map +1 -0
  148. package/dist/runtime/command-registry.d.ts +31 -0
  149. package/dist/runtime/command-registry.d.ts.map +1 -0
  150. package/dist/runtime/command-registry.js +74 -0
  151. package/dist/runtime/command-registry.js.map +1 -0
  152. package/dist/runtime/config-merge.d.ts +4 -0
  153. package/dist/runtime/config-merge.d.ts.map +1 -0
  154. package/dist/runtime/config-merge.js +72 -0
  155. package/dist/runtime/config-merge.js.map +1 -0
  156. package/dist/runtime/config.d.ts +22 -0
  157. package/dist/runtime/config.d.ts.map +1 -0
  158. package/dist/runtime/config.js +126 -0
  159. package/dist/runtime/config.js.map +1 -0
  160. package/dist/runtime/debug.d.ts +3 -0
  161. package/dist/runtime/debug.d.ts.map +1 -0
  162. package/dist/runtime/debug.js +14 -0
  163. package/dist/runtime/debug.js.map +1 -0
  164. package/dist/runtime/extract-config-path.d.ts +2 -0
  165. package/dist/runtime/extract-config-path.d.ts.map +1 -0
  166. package/dist/runtime/extract-config-path.js +13 -0
  167. package/dist/runtime/extract-config-path.js.map +1 -0
  168. package/dist/runtime/global-flags.d.ts +16 -0
  169. package/dist/runtime/global-flags.d.ts.map +1 -0
  170. package/dist/runtime/global-flags.js +7 -0
  171. package/dist/runtime/global-flags.js.map +1 -0
  172. package/dist/runtime/help.d.ts +5 -0
  173. package/dist/runtime/help.d.ts.map +1 -0
  174. package/dist/runtime/help.js +84 -0
  175. package/dist/runtime/help.js.map +1 -0
  176. package/dist/runtime/journal-store.d.ts +10 -0
  177. package/dist/runtime/journal-store.d.ts.map +1 -0
  178. package/dist/runtime/journal-store.js +137 -0
  179. package/dist/runtime/journal-store.js.map +1 -0
  180. package/dist/runtime/json-output.d.ts +5 -0
  181. package/dist/runtime/json-output.d.ts.map +1 -0
  182. package/dist/runtime/json-output.js +21 -0
  183. package/dist/runtime/json-output.js.map +1 -0
  184. package/dist/runtime/logging.d.ts +3 -0
  185. package/dist/runtime/logging.d.ts.map +1 -0
  186. package/dist/runtime/logging.js +31 -0
  187. package/dist/runtime/logging.js.map +1 -0
  188. package/dist/runtime/migration-store.d.ts +22 -0
  189. package/dist/runtime/migration-store.d.ts.map +1 -0
  190. package/dist/runtime/migration-store.js +60 -0
  191. package/dist/runtime/migration-store.js.map +1 -0
  192. package/dist/runtime/plugin-runtime/errors.d.ts +3 -0
  193. package/dist/runtime/plugin-runtime/errors.d.ts.map +1 -0
  194. package/dist/runtime/plugin-runtime/errors.js +13 -0
  195. package/dist/runtime/plugin-runtime/errors.js.map +1 -0
  196. package/dist/runtime/plugin-runtime/executor-debug.d.ts +3 -0
  197. package/dist/runtime/plugin-runtime/executor-debug.d.ts.map +1 -0
  198. package/dist/runtime/plugin-runtime/executor-debug.js +65 -0
  199. package/dist/runtime/plugin-runtime/executor-debug.js.map +1 -0
  200. package/dist/runtime/plugin-runtime/hooks.d.ts +23 -0
  201. package/dist/runtime/plugin-runtime/hooks.d.ts.map +1 -0
  202. package/dist/runtime/plugin-runtime/hooks.js +148 -0
  203. package/dist/runtime/plugin-runtime/hooks.js.map +1 -0
  204. package/dist/runtime/plugin-runtime/index.d.ts +9 -0
  205. package/dist/runtime/plugin-runtime/index.d.ts.map +1 -0
  206. package/dist/runtime/plugin-runtime/index.js +178 -0
  207. package/dist/runtime/plugin-runtime/index.js.map +1 -0
  208. package/dist/runtime/plugin-runtime/loader.d.ts +11 -0
  209. package/dist/runtime/plugin-runtime/loader.d.ts.map +1 -0
  210. package/dist/runtime/plugin-runtime/loader.js +37 -0
  211. package/dist/runtime/plugin-runtime/loader.js.map +1 -0
  212. package/dist/runtime/plugin-runtime/null-executor.d.ts +3 -0
  213. package/dist/runtime/plugin-runtime/null-executor.d.ts.map +1 -0
  214. package/dist/runtime/plugin-runtime/null-executor.js +17 -0
  215. package/dist/runtime/plugin-runtime/null-executor.js.map +1 -0
  216. package/dist/runtime/safety-markers.d.ts +23 -0
  217. package/dist/runtime/safety-markers.d.ts.map +1 -0
  218. package/dist/runtime/safety-markers.js +85 -0
  219. package/dist/runtime/safety-markers.js.map +1 -0
  220. package/dist/runtime/schema-loader.d.ts +3 -0
  221. package/dist/runtime/schema-loader.d.ts.map +1 -0
  222. package/dist/runtime/schema-loader.js +11 -0
  223. package/dist/runtime/schema-loader.js.map +1 -0
  224. package/dist/runtime/table-scope.d.ts +33 -0
  225. package/dist/runtime/table-scope.d.ts.map +1 -0
  226. package/dist/runtime/table-scope.js +167 -0
  227. package/dist/runtime/table-scope.js.map +1 -0
  228. package/dist/runtime/user-config.d.ts +4 -0
  229. package/dist/runtime/user-config.d.ts.map +1 -0
  230. package/dist/runtime/user-config.js +11 -0
  231. package/dist/runtime/user-config.js.map +1 -0
  232. package/dist/runtime/version.d.ts +2 -0
  233. package/dist/runtime/version.d.ts.map +1 -0
  234. package/dist/runtime/version.js +5 -0
  235. package/dist/runtime/version.js.map +1 -0
  236. package/package.json +9 -7
@@ -0,0 +1,137 @@
1
+ import { isUnknownDatabaseError } from '@chkit/clickhouse';
2
+ import { CLI_VERSION } from './version.js';
3
+ import { debug } from './debug.js';
4
+ const DEFAULT_JOURNAL_TABLE = '_chkit_migrations';
5
+ function resolveJournalTableName() {
6
+ const candidate = process.env.CHKIT_JOURNAL_TABLE?.trim();
7
+ if (!candidate)
8
+ return DEFAULT_JOURNAL_TABLE;
9
+ if (!/^[A-Za-z_][A-Za-z0-9_]*$/.test(candidate)) {
10
+ throw new Error(`Invalid CHKIT_JOURNAL_TABLE "${candidate}". Expected unquoted identifier matching [A-Za-z_][A-Za-z0-9_]*`);
11
+ }
12
+ return candidate;
13
+ }
14
+ function isRetryableInsertRace(error) {
15
+ if (!(error instanceof Error))
16
+ return false;
17
+ const message = error.message;
18
+ return message.includes('INSERT race condition') || message.includes('Please retry the INSERT');
19
+ }
20
+ export function createJournalStore(db) {
21
+ const journalTable = resolveJournalTableName();
22
+ debug('journal', `journal table: ${journalTable}${process.env.CHKIT_JOURNAL_TABLE ? ' (from CHKIT_JOURNAL_TABLE)' : ''}`);
23
+ const createTableSql = `CREATE TABLE IF NOT EXISTS ${journalTable} (
24
+ name String,
25
+ applied_at DateTime64(3, 'UTC'),
26
+ checksum String,
27
+ chkit_version String
28
+ ) ENGINE = ReplacingMergeTree(applied_at)
29
+ ORDER BY (name)
30
+ SETTINGS index_granularity = 1`;
31
+ let bootstrapped = false;
32
+ let _databaseMissing = false;
33
+ async function ensureTable() {
34
+ if (bootstrapped)
35
+ return;
36
+ debug('journal', `probing journal table "${journalTable}"`);
37
+ try {
38
+ await db.query(`SELECT name FROM ${journalTable} LIMIT 0`);
39
+ debug('journal', 'journal table exists');
40
+ bootstrapped = true;
41
+ return;
42
+ }
43
+ catch (error) {
44
+ if (isUnknownDatabaseError(error)) {
45
+ debug('journal', 'database does not exist');
46
+ _databaseMissing = true;
47
+ bootstrapped = true;
48
+ return;
49
+ }
50
+ }
51
+ debug('journal', 'creating journal table');
52
+ try {
53
+ await db.command(createTableSql);
54
+ }
55
+ catch (error) {
56
+ if (isUnknownDatabaseError(error)) {
57
+ debug('journal', 'database missing on CREATE — deferring');
58
+ _databaseMissing = true;
59
+ bootstrapped = true;
60
+ return;
61
+ }
62
+ throw error;
63
+ }
64
+ for (let attempt = 0; attempt < 10; attempt++) {
65
+ try {
66
+ await db.query(`SELECT name FROM ${journalTable} LIMIT 0`);
67
+ debug('journal', `DDL propagation confirmed (attempt ${attempt + 1})`);
68
+ break;
69
+ }
70
+ catch {
71
+ await new Promise((r) => setTimeout(r, 250));
72
+ }
73
+ }
74
+ bootstrapped = true;
75
+ }
76
+ return {
77
+ get databaseMissing() {
78
+ return _databaseMissing;
79
+ },
80
+ async readJournal() {
81
+ debug('journal', 'reading journal');
82
+ await ensureTable();
83
+ if (_databaseMissing) {
84
+ debug('journal', 'database missing — returning empty journal');
85
+ return { version: 1, applied: [] };
86
+ }
87
+ try {
88
+ await db.command(`SYSTEM SYNC REPLICA ${journalTable}`);
89
+ }
90
+ catch {
91
+ // Non-replicated or single-node setups don't support SYSTEM SYNC REPLICA.
92
+ }
93
+ const rows = await db.query(`SELECT name, applied_at, checksum, chkit_version FROM ${journalTable} ORDER BY name SETTINGS select_sequential_consistency = 1`);
94
+ debug('journal', `journal has ${rows.length} applied entries`);
95
+ return {
96
+ version: 1,
97
+ applied: rows.map((row) => ({
98
+ name: row.name,
99
+ appliedAt: row.applied_at,
100
+ checksum: row.checksum,
101
+ })),
102
+ };
103
+ },
104
+ async appendEntry(entry) {
105
+ debug('journal', `appending entry: ${entry.name} (checksum: ${entry.checksum})`);
106
+ if (_databaseMissing) {
107
+ debug('journal', 'resetting databaseMissing flag — migration may have created the database');
108
+ _databaseMissing = false;
109
+ bootstrapped = false;
110
+ }
111
+ await ensureTable();
112
+ const esc = (s) => s.replace(/\\/g, '\\\\').replace(/'/g, "\\'");
113
+ const insertSql = `INSERT INTO ${journalTable} (name, applied_at, checksum, chkit_version) VALUES ('${esc(entry.name)}', '${esc(entry.appliedAt)}', '${esc(entry.checksum)}', '${esc(CLI_VERSION)}')`;
114
+ const maxAttempts = 5;
115
+ for (let attempt = 1; attempt <= maxAttempts; attempt += 1) {
116
+ try {
117
+ await db.command(insertSql);
118
+ break;
119
+ }
120
+ catch (error) {
121
+ if (!isRetryableInsertRace(error) || attempt === maxAttempts) {
122
+ throw error;
123
+ }
124
+ debug('journal', `insert race detected — retrying (attempt ${attempt}/${maxAttempts})`);
125
+ await new Promise((r) => setTimeout(r, attempt * 150));
126
+ }
127
+ }
128
+ try {
129
+ await db.command(`SYSTEM SYNC REPLICA ${journalTable}`);
130
+ }
131
+ catch {
132
+ // Non-replicated or single-node setups don't support SYSTEM SYNC REPLICA.
133
+ }
134
+ },
135
+ };
136
+ }
137
+ //# sourceMappingURL=journal-store.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"journal-store.js","sourceRoot":"","sources":["../../src/runtime/journal-store.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,5 @@
1
+ type Command = 'generate' | 'migrate' | 'status' | 'drift' | 'check' | 'plugin' | 'query';
2
+ export declare function printOutput(value: unknown, jsonMode: boolean): void;
3
+ export declare function emitJson<T extends object>(command: Command, payload: T): void;
4
+ export {};
5
+ //# sourceMappingURL=json-output.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"json-output.d.ts","sourceRoot":"","sources":["../../src/runtime/json-output.ts"],"names":[],"mappings":"AAAA,KAAK,OAAO,GACR,UAAU,GACV,SAAS,GACT,QAAQ,GACR,OAAO,GACP,OAAO,GACP,QAAQ,GACR,OAAO,CAAA;AAIX,wBAAgB,WAAW,CAAC,KAAK,EAAE,OAAO,EAAE,QAAQ,EAAE,OAAO,GAAG,IAAI,CAQnE;AAaD,wBAAgB,QAAQ,CAAC,CAAC,SAAS,MAAM,EAAE,OAAO,EAAE,OAAO,EAAE,OAAO,EAAE,CAAC,GAAG,IAAI,CAE7E"}
@@ -0,0 +1,21 @@
1
+ const JSON_CONTRACT_VERSION = 1;
2
+ export function printOutput(value, jsonMode) {
3
+ if (jsonMode) {
4
+ console.log(JSON.stringify(value, null, 2));
5
+ return;
6
+ }
7
+ if (typeof value === 'string') {
8
+ console.log(value);
9
+ }
10
+ }
11
+ function jsonPayload(command, payload) {
12
+ return {
13
+ command,
14
+ schemaVersion: JSON_CONTRACT_VERSION,
15
+ ...payload,
16
+ };
17
+ }
18
+ export function emitJson(command, payload) {
19
+ printOutput(jsonPayload(command, payload), true);
20
+ }
21
+ //# sourceMappingURL=json-output.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"json-output.js","sourceRoot":"","sources":["../../src/runtime/json-output.ts"],"names":[],"mappings":"AASA,MAAM,qBAAqB,GAAG,CAAC,CAAA;AAE/B,MAAM,UAAU,WAAW,CAAC,KAAc,EAAE,QAAiB;IAC3D,IAAI,QAAQ,EAAE,CAAC;QACb,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,SAAS,CAAC,KAAK,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC,CAAA;QAC3C,OAAM;IACR,CAAC;IACD,IAAI,OAAO,KAAK,KAAK,QAAQ,EAAE,CAAC;QAC9B,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,CAAA;IACpB,CAAC;AACH,CAAC;AAED,SAAS,WAAW,CAAmB,OAAgB,EAAE,OAAU;IAIjE,OAAO;QACL,OAAO;QACP,aAAa,EAAE,qBAAqB;QACpC,GAAG,OAAO;KACX,CAAA;AACH,CAAC;AAED,MAAM,UAAU,QAAQ,CAAmB,OAAgB,EAAE,OAAU;IACrE,WAAW,CAAC,WAAW,CAAC,OAAO,EAAE,OAAO,CAAC,EAAE,IAAI,CAAC,CAAA;AAClD,CAAC"}
@@ -0,0 +1,3 @@
1
+ export declare function configureCliLogging(): void;
2
+ export declare function isDebugEnabled(): boolean;
3
+ //# sourceMappingURL=logging.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"logging.d.ts","sourceRoot":"","sources":["../../src/runtime/logging.ts"],"names":[],"mappings":"AAMA,wBAAgB,mBAAmB,IAAI,IAAI,CAuB1C;AAED,wBAAgB,cAAc,IAAI,OAAO,CAExC"}
@@ -0,0 +1,31 @@
1
+ import process from 'node:process';
2
+ import { configureSync, getConfig, getConsoleSink, getTextFormatter } from '@logtape/logtape';
3
+ const enabled = process.env.CHKIT_DEBUG === '1' || process.env.CHKIT_DEBUG === 'true';
4
+ export function configureCliLogging() {
5
+ if (!enabled || getConfig())
6
+ return;
7
+ configureSync({
8
+ sinks: {
9
+ console: getConsoleSink({
10
+ formatter: getTextFormatter({ timestamp: 'time' }),
11
+ }),
12
+ },
13
+ loggers: [
14
+ {
15
+ category: 'chkit',
16
+ sinks: ['console'],
17
+ lowestLevel: 'debug',
18
+ },
19
+ {
20
+ category: 'logtape',
21
+ sinks: ['console'],
22
+ lowestLevel: 'error',
23
+ },
24
+ ],
25
+ reset: true,
26
+ });
27
+ }
28
+ export function isDebugEnabled() {
29
+ return enabled;
30
+ }
31
+ //# sourceMappingURL=logging.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"logging.js","sourceRoot":"","sources":["../../src/runtime/logging.ts"],"names":[],"mappings":"AAAA,OAAO,OAAO,MAAM,cAAc,CAAA;AAElC,OAAO,EAAE,aAAa,EAAE,SAAS,EAAE,cAAc,EAAE,gBAAgB,EAAE,MAAM,kBAAkB,CAAA;AAE7F,MAAM,OAAO,GAAG,OAAO,CAAC,GAAG,CAAC,WAAW,KAAK,GAAG,IAAI,OAAO,CAAC,GAAG,CAAC,WAAW,KAAK,MAAM,CAAA;AAErF,MAAM,UAAU,mBAAmB;IACjC,IAAI,CAAC,OAAO,IAAI,SAAS,EAAE;QAAE,OAAM;IAEnC,aAAa,CAAC;QACZ,KAAK,EAAE;YACL,OAAO,EAAE,cAAc,CAAC;gBACtB,SAAS,EAAE,gBAAgB,CAAC,EAAE,SAAS,EAAE,MAAM,EAAE,CAAC;aACnD,CAAC;SACH;QACD,OAAO,EAAE;YACP;gBACE,QAAQ,EAAE,OAAO;gBACjB,KAAK,EAAE,CAAC,SAAS,CAAC;gBAClB,WAAW,EAAE,OAAO;aACrB;YACD;gBACE,QAAQ,EAAE,SAAS;gBACnB,KAAK,EAAE,CAAC,SAAS,CAAC;gBAClB,WAAW,EAAE,OAAO;aACrB;SACF;QACD,KAAK,EAAE,IAAI;KACZ,CAAC,CAAA;AACJ,CAAC;AAED,MAAM,UAAU,cAAc;IAC5B,OAAO,OAAO,CAAA;AAChB,CAAC"}
@@ -0,0 +1,22 @@
1
+ import { type MigrationOperation, type Snapshot } from '@chkit/core';
2
+ export interface MigrationJournalEntry {
3
+ name: string;
4
+ appliedAt: string;
5
+ checksum: string;
6
+ }
7
+ export interface MigrationJournal {
8
+ version: 1;
9
+ applied: MigrationJournalEntry[];
10
+ }
11
+ interface ChecksumMismatch {
12
+ name: string;
13
+ expected: string;
14
+ actual: string;
15
+ }
16
+ export declare function readSnapshot(metaDir: string): Promise<Snapshot | null>;
17
+ export declare function summarizePlan(operations: MigrationOperation[]): string[];
18
+ export declare function listMigrations(migrationsDir: string): Promise<string[]>;
19
+ export declare function findChecksumMismatches(migrationsDir: string, journal: MigrationJournal): Promise<ChecksumMismatch[]>;
20
+ export declare function checksumSQL(value: string): string;
21
+ export {};
22
+ //# sourceMappingURL=migration-store.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"migration-store.d.ts","sourceRoot":"","sources":["../../src/runtime/migration-store.ts"],"names":[],"mappings":"AAOA,OAAO,EAA2B,KAAK,kBAAkB,EAAyB,KAAK,QAAQ,EAAE,MAAM,aAAa,CAAA;AAEpH,MAAM,WAAW,qBAAqB;IACpC,IAAI,EAAE,MAAM,CAAA;IACZ,SAAS,EAAE,MAAM,CAAA;IACjB,QAAQ,EAAE,MAAM,CAAA;CACjB;AAED,MAAM,WAAW,gBAAgB;IAC/B,OAAO,EAAE,CAAC,CAAA;IACV,OAAO,EAAE,qBAAqB,EAAE,CAAA;CACjC;AAED,UAAU,gBAAgB;IACxB,IAAI,EAAE,MAAM,CAAA;IACZ,QAAQ,EAAE,MAAM,CAAA;IAChB,MAAM,EAAE,MAAM,CAAA;CACf;AAUD,wBAAsB,YAAY,CAAC,OAAO,EAAE,MAAM,GAAG,OAAO,CAAC,QAAQ,GAAG,IAAI,CAAC,CAc5E;AAED,wBAAgB,aAAa,CAAC,UAAU,EAAE,kBAAkB,EAAE,GAAG,MAAM,EAAE,CAExE;AAED,wBAAsB,cAAc,CAAC,aAAa,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,EAAE,CAAC,CAG7E;AAMD,wBAAsB,sBAAsB,CAC1C,aAAa,EAAE,MAAM,EACrB,OAAO,EAAE,gBAAgB,GACxB,OAAO,CAAC,gBAAgB,EAAE,CAAC,CAiB7B;AAED,wBAAgB,WAAW,CAAC,KAAK,EAAE,MAAM,GAAG,MAAM,CAEjD"}
@@ -0,0 +1,60 @@
1
+ import { createHash } from 'node:crypto';
2
+ import { existsSync } from 'node:fs';
3
+ import { readFile } from 'node:fs/promises';
4
+ import { join } from 'node:path';
5
+ import fg from 'fast-glob';
6
+ import { canonicalizeDefinitions } from '@chkit/core';
7
+ function parseJSONOrThrow(raw, filePath, kind) {
8
+ try {
9
+ return JSON.parse(raw);
10
+ }
11
+ catch {
12
+ throw new Error(`Invalid ${kind} JSON at ${filePath}. Fix or remove the file and retry.`);
13
+ }
14
+ }
15
+ export async function readSnapshot(metaDir) {
16
+ const file = join(metaDir, 'snapshot.json');
17
+ if (!existsSync(file))
18
+ return null;
19
+ const raw = await readFile(file, 'utf8');
20
+ const parsed = parseJSONOrThrow(raw, file, 'snapshot');
21
+ return {
22
+ version: 1,
23
+ generatedAt: parsed.generatedAt ?? '',
24
+ definitions: canonicalizeDefinitions(parsed.definitions ?? []),
25
+ };
26
+ }
27
+ export function summarizePlan(operations) {
28
+ return operations.map((op) => `${op.type} [${op.risk}] ${op.key}`);
29
+ }
30
+ export async function listMigrations(migrationsDir) {
31
+ const files = await fg('*.sql', { cwd: migrationsDir, onlyFiles: true });
32
+ return files.sort();
33
+ }
34
+ function checksum(value) {
35
+ return createHash('sha256').update(value, 'utf8').digest('hex');
36
+ }
37
+ export async function findChecksumMismatches(migrationsDir, journal) {
38
+ const mismatches = [];
39
+ for (const entry of journal.applied) {
40
+ if (!entry.checksum)
41
+ continue;
42
+ const fullPath = join(migrationsDir, entry.name);
43
+ if (!existsSync(fullPath))
44
+ continue;
45
+ const sql = await readFile(fullPath, 'utf8');
46
+ const actual = checksum(sql);
47
+ if (actual !== entry.checksum) {
48
+ mismatches.push({
49
+ name: entry.name,
50
+ expected: entry.checksum,
51
+ actual,
52
+ });
53
+ }
54
+ }
55
+ return mismatches;
56
+ }
57
+ export function checksumSQL(value) {
58
+ return checksum(value);
59
+ }
60
+ //# sourceMappingURL=migration-store.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"migration-store.js","sourceRoot":"","sources":["../../src/runtime/migration-store.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,3 @@
1
+ export declare function formatPluginError(pluginName: string, hook: string, error: unknown): Error;
2
+ export declare function guardHook<T>(pluginName: string, hookName: string, fn: () => Promise<T> | T): Promise<T>;
3
+ //# sourceMappingURL=errors.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"errors.d.ts","sourceRoot":"","sources":["../../../src/runtime/plugin-runtime/errors.ts"],"names":[],"mappings":"AAAA,wBAAgB,iBAAiB,CAC/B,UAAU,EAAE,MAAM,EAClB,IAAI,EAAE,MAAM,EACZ,KAAK,EAAE,OAAO,GACb,KAAK,CAGP;AAED,wBAAsB,SAAS,CAAC,CAAC,EAC/B,UAAU,EAAE,MAAM,EAClB,QAAQ,EAAE,MAAM,EAChB,EAAE,EAAE,MAAM,OAAO,CAAC,CAAC,CAAC,GAAG,CAAC,GACvB,OAAO,CAAC,CAAC,CAAC,CAMZ"}
@@ -0,0 +1,13 @@
1
+ export function formatPluginError(pluginName, hook, error) {
2
+ const message = error instanceof Error ? error.message : String(error);
3
+ return new Error(`Plugin "${pluginName}" failed in ${hook}: ${message}`);
4
+ }
5
+ export async function guardHook(pluginName, hookName, fn) {
6
+ try {
7
+ return await fn();
8
+ }
9
+ catch (error) {
10
+ throw formatPluginError(pluginName, hookName, error);
11
+ }
12
+ }
13
+ //# sourceMappingURL=errors.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"errors.js","sourceRoot":"","sources":["../../../src/runtime/plugin-runtime/errors.ts"],"names":[],"mappings":"AAAA,MAAM,UAAU,iBAAiB,CAC/B,UAAkB,EAClB,IAAY,EACZ,KAAc;IAEd,MAAM,OAAO,GAAG,KAAK,YAAY,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,CAAA;IACtE,OAAO,IAAI,KAAK,CAAC,WAAW,UAAU,eAAe,IAAI,KAAK,OAAO,EAAE,CAAC,CAAA;AAC1E,CAAC;AAED,MAAM,CAAC,KAAK,UAAU,SAAS,CAC7B,UAAkB,EAClB,QAAgB,EAChB,EAAwB;IAExB,IAAI,CAAC;QACH,OAAO,MAAM,EAAE,EAAE,CAAA;IACnB,CAAC;IAAC,OAAO,KAAK,EAAE,CAAC;QACf,MAAM,iBAAiB,CAAC,UAAU,EAAE,QAAQ,EAAE,KAAK,CAAC,CAAA;IACtD,CAAC;AACH,CAAC"}
@@ -0,0 +1,3 @@
1
+ import type { ClickHouseExecutor } from '@chkit/clickhouse';
2
+ export declare function wrapExecutorWithDebug(executor: ClickHouseExecutor): ClickHouseExecutor;
3
+ //# sourceMappingURL=executor-debug.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"executor-debug.d.ts","sourceRoot":"","sources":["../../../src/runtime/plugin-runtime/executor-debug.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,mBAAmB,CAAA;AA6B3D,wBAAgB,qBAAqB,CACnC,QAAQ,EAAE,kBAAkB,GAC3B,kBAAkB,CAwEpB"}
@@ -0,0 +1,65 @@
1
+ import { debug, isDebugEnabled } from '../debug.js';
2
+ function truncate(sql) {
3
+ return sql.length > 200 ? `${sql.slice(0, 200)}...` : sql;
4
+ }
5
+ async function trace(label, describeOk, fn) {
6
+ const start = performance.now();
7
+ try {
8
+ const result = await fn();
9
+ const detail = describeOk ? ` — ${describeOk(result)}` : '';
10
+ debug('clickhouse', `${label} OK${detail} (${Math.round(performance.now() - start)}ms)`);
11
+ return result;
12
+ }
13
+ catch (error) {
14
+ debug('clickhouse', `${label} FAILED (${Math.round(performance.now() - start)}ms)`, error instanceof Error ? error.message : error);
15
+ throw error;
16
+ }
17
+ }
18
+ export function wrapExecutorWithDebug(executor) {
19
+ if (!isDebugEnabled())
20
+ return executor;
21
+ const queryJson = executor.queryJson?.bind(executor);
22
+ return {
23
+ command(sql) {
24
+ debug('clickhouse', `command: ${truncate(sql)}`);
25
+ return trace('command', null, () => executor.command(sql));
26
+ },
27
+ query(sql) {
28
+ debug('clickhouse', `query: ${truncate(sql)}`);
29
+ return trace('query', (rows) => `${rows.length} rows`, () => executor.query(sql));
30
+ },
31
+ ...(queryJson
32
+ ? {
33
+ queryJson(sql) {
34
+ debug('clickhouse', `queryJson: ${truncate(sql)}`);
35
+ return trace('queryJson', (payload) => `${payload.rows} rows`, () => queryJson(sql));
36
+ },
37
+ }
38
+ : {}),
39
+ insert(params) {
40
+ debug('clickhouse', `insert into ${params.table} — ${params.values.length} rows`);
41
+ return trace('insert', null, () => executor.insert(params));
42
+ },
43
+ submit(sql, queryId) {
44
+ debug('clickhouse', `submit${queryId ? ` (id: ${queryId})` : ''}: ${truncate(sql)}`);
45
+ return trace('submit', (id) => `id: ${id}`, () => executor.submit(sql, queryId));
46
+ },
47
+ queryStatus(queryId, options) {
48
+ debug('clickhouse', `queryStatus for ${queryId}`);
49
+ return trace('queryStatus', (status) => status.status, () => executor.queryStatus(queryId, options));
50
+ },
51
+ listSchemaObjects() {
52
+ debug('clickhouse', 'listSchemaObjects');
53
+ return trace('listSchemaObjects', (objects) => `${objects.length} objects`, () => executor.listSchemaObjects());
54
+ },
55
+ listTableDetails(databases) {
56
+ debug('clickhouse', `listTableDetails for databases: [${databases.join(', ')}]`);
57
+ return trace('listTableDetails', (tables) => `${tables.length} tables`, () => executor.listTableDetails(databases));
58
+ },
59
+ async close() {
60
+ debug('clickhouse', 'closing connections');
61
+ await executor.close();
62
+ },
63
+ };
64
+ }
65
+ //# sourceMappingURL=executor-debug.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"executor-debug.js","sourceRoot":"","sources":["../../../src/runtime/plugin-runtime/executor-debug.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,23 @@
1
+ import { type MigrationPlan } from '@chkit/core';
2
+ import type { ChxOnAfterApplyContext, ChxOnBeforeApplyContext, ChxOnBeforePluginCommandContext, ChxOnBeforePluginCommandResult, ChxOnCheckContext, ChxOnCheckResult, ChxOnCompleteContext, ChxOnConfigLoadedContext, ChxOnInitContext, ChxOnPlanCreatedContext, ChxOnSchemaLoadedContext, LoadedPlugin, TableScope } from '../../plugins.js';
3
+ declare const UNFILTERED_TABLE_SCOPE: TableScope;
4
+ export declare function runOnInit(loaded: LoadedPlugin[], context: Omit<ChxOnInitContext, 'options'>): Promise<void>;
5
+ export declare function runOnComplete(loaded: LoadedPlugin[], context: Omit<ChxOnCompleteContext, 'options' | 'exitCode'> & {
6
+ exitCode?: number;
7
+ }): Promise<void>;
8
+ export declare function runOnConfigLoaded(loaded: LoadedPlugin[], context: Omit<ChxOnConfigLoadedContext, 'options' | 'tableScope'> & {
9
+ tableScope?: TableScope;
10
+ }): Promise<void>;
11
+ export declare function runOnSchemaLoaded(loaded: LoadedPlugin[], context: ChxOnSchemaLoadedContext): Promise<import("@chkit/core").SchemaDefinition[]>;
12
+ export declare function runOnPlanCreated(loaded: LoadedPlugin[], context: Omit<ChxOnPlanCreatedContext, 'plan' | 'tableScope'> & {
13
+ tableScope?: TableScope;
14
+ }, initialPlan: MigrationPlan): Promise<MigrationPlan>;
15
+ export declare function runOnBeforeApply(loaded: LoadedPlugin[], context: ChxOnBeforeApplyContext): Promise<string[]>;
16
+ export declare function runOnAfterApply(loaded: LoadedPlugin[], context: ChxOnAfterApplyContext): Promise<void>;
17
+ export declare function runOnCheck(loaded: LoadedPlugin[], context: Omit<ChxOnCheckContext, 'options' | 'tableScope'> & {
18
+ tableScope?: TableScope;
19
+ }): Promise<ChxOnCheckResult[]>;
20
+ export declare function runOnCheckReport(byName: Map<string, LoadedPlugin>, results: ChxOnCheckResult[], print: (line: string) => void): Promise<void>;
21
+ export declare function runOnBeforePluginCommand(loaded: LoadedPlugin[], pluginName: string, commandName: string, context: Omit<ChxOnBeforePluginCommandContext, 'targetPlugin' | 'command' | 'options'>): Promise<ChxOnBeforePluginCommandResult>;
22
+ export { UNFILTERED_TABLE_SCOPE };
23
+ //# sourceMappingURL=hooks.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"hooks.d.ts","sourceRoot":"","sources":["../../../src/runtime/plugin-runtime/hooks.ts"],"names":[],"mappings":"AAAA,OAAO,EAA2B,KAAK,aAAa,EAAE,MAAM,aAAa,CAAA;AAEzE,OAAO,KAAK,EACV,sBAAsB,EACtB,uBAAuB,EACvB,+BAA+B,EAC/B,8BAA8B,EAC9B,iBAAiB,EACjB,gBAAgB,EAChB,oBAAoB,EACpB,wBAAwB,EACxB,gBAAgB,EAChB,uBAAuB,EACvB,wBAAwB,EACxB,YAAY,EACZ,UAAU,EACX,MAAM,kBAAkB,CAAA;AAIzB,QAAA,MAAM,sBAAsB,EAAE,UAI7B,CAAA;AAED,wBAAsB,SAAS,CAC7B,MAAM,EAAE,YAAY,EAAE,EACtB,OAAO,EAAE,IAAI,CAAC,gBAAgB,EAAE,SAAS,CAAC,GACzC,OAAO,CAAC,IAAI,CAAC,CASf;AAED,wBAAsB,aAAa,CACjC,MAAM,EAAE,YAAY,EAAE,EACtB,OAAO,EAAE,IAAI,CAAC,oBAAoB,EAAE,SAAS,GAAG,UAAU,CAAC,GAAG;IAAE,QAAQ,CAAC,EAAE,MAAM,CAAA;CAAE,GAClF,OAAO,CAAC,IAAI,CAAC,CAUf;AAED,wBAAsB,iBAAiB,CACrC,MAAM,EAAE,YAAY,EAAE,EACtB,OAAO,EAAE,IAAI,CAAC,wBAAwB,EAAE,SAAS,GAAG,YAAY,CAAC,GAAG;IAAE,UAAU,CAAC,EAAE,UAAU,CAAA;CAAE,GAC9F,OAAO,CAAC,IAAI,CAAC,CAUf;AAED,wBAAsB,iBAAiB,CACrC,MAAM,EAAE,YAAY,EAAE,EACtB,OAAO,EAAE,wBAAwB,qDAsBlC;AAED,wBAAsB,gBAAgB,CACpC,MAAM,EAAE,YAAY,EAAE,EACtB,OAAO,EAAE,IAAI,CAAC,uBAAuB,EAAE,MAAM,GAAG,YAAY,CAAC,GAAG;IAAE,UAAU,CAAC,EAAE,UAAU,CAAA;CAAE,EAC3F,WAAW,EAAE,aAAa,GACzB,OAAO,CAAC,aAAa,CAAC,CAsBxB;AAED,wBAAsB,gBAAgB,CACpC,MAAM,EAAE,YAAY,EAAE,EACtB,OAAO,EAAE,uBAAuB,GAC/B,OAAO,CAAC,MAAM,EAAE,CAAC,CAqBnB;AAED,wBAAsB,eAAe,CACnC,MAAM,EAAE,YAAY,EAAE,EACtB,OAAO,EAAE,sBAAsB,GAC9B,OAAO,CAAC,IAAI,CAAC,CAOf;AAED,wBAAsB,UAAU,CAC9B,MAAM,EAAE,YAAY,EAAE,EACtB,OAAO,EAAE,IAAI,CAAC,iBAAiB,EAAE,SAAS,GAAG,YAAY,CAAC,GAAG;IAAE,UAAU,CAAC,EAAE,UAAU,CAAA;CAAE,GACvF,OAAO,CAAC,gBAAgB,EAAE,CAAC,CAwB7B;AAED,wBAAsB,gBAAgB,CACpC,MAAM,EAAE,GAAG,CAAC,MAAM,EAAE,YAAY,CAAC,EACjC,OAAO,EAAE,gBAAgB,EAAE,EAC3B,KAAK,EAAE,CAAC,IAAI,EAAE,MAAM,KAAK,IAAI,GAC5B,OAAO,CAAC,IAAI,CAAC,CAUf;AAED,wBAAsB,wBAAwB,CAC5C,MAAM,EAAE,YAAY,EAAE,EACtB,UAAU,EAAE,MAAM,EAClB,WAAW,EAAE,MAAM,EACnB,OAAO,EAAE,IAAI,CAAC,+BAA+B,EAAE,cAAc,GAAG,SAAS,GAAG,SAAS,CAAC,GACrF,OAAO,CAAC,8BAA8B,CAAC,CA6BzC;AAED,OAAO,EAAE,sBAAsB,EAAE,CAAA"}
@@ -0,0 +1,148 @@
1
+ import { canonicalizeDefinitions } from '@chkit/core';
2
+ import { debug } from '../debug.js';
3
+ import { guardHook } from './errors.js';
4
+ const UNFILTERED_TABLE_SCOPE = {
5
+ enabled: false,
6
+ matchedTables: [],
7
+ matchCount: 0,
8
+ };
9
+ export async function runOnInit(loaded, context) {
10
+ for (const item of loaded) {
11
+ const hook = item.plugin.hooks?.onInit;
12
+ if (!hook)
13
+ continue;
14
+ debug('hook', `onInit → ${item.plugin.manifest.name}`);
15
+ await guardHook(item.plugin.manifest.name, 'onInit', () => hook({ ...context, options: item.options }));
16
+ }
17
+ }
18
+ export async function runOnComplete(loaded, context) {
19
+ const exitCode = context.exitCode ?? 0;
20
+ for (const item of loaded) {
21
+ const hook = item.plugin.hooks?.onComplete;
22
+ if (!hook)
23
+ continue;
24
+ debug('hook', `onComplete → ${item.plugin.manifest.name} (exitCode: ${exitCode})`);
25
+ await guardHook(item.plugin.manifest.name, 'onComplete', () => hook({ ...context, exitCode, options: item.options }));
26
+ }
27
+ }
28
+ export async function runOnConfigLoaded(loaded, context) {
29
+ const tableScope = context.tableScope ?? UNFILTERED_TABLE_SCOPE;
30
+ for (const item of loaded) {
31
+ const hook = item.plugin.hooks?.onConfigLoaded;
32
+ if (!hook)
33
+ continue;
34
+ debug('hook', `onConfigLoaded → ${item.plugin.manifest.name}`);
35
+ await guardHook(item.plugin.manifest.name, 'onConfigLoaded', () => hook({ ...context, options: item.options, tableScope }));
36
+ }
37
+ }
38
+ export async function runOnSchemaLoaded(loaded, context) {
39
+ let definitions = context.definitions;
40
+ for (const item of loaded) {
41
+ const hook = item.plugin.hooks?.onSchemaLoaded;
42
+ if (!hook)
43
+ continue;
44
+ debug('hook', `onSchemaLoaded → ${item.plugin.manifest.name} (${definitions.length} definitions)`);
45
+ const next = await guardHook(item.plugin.manifest.name, 'onSchemaLoaded', () => hook({ ...context, definitions }));
46
+ if (Array.isArray(next)) {
47
+ debug('hook', `onSchemaLoaded ← ${item.plugin.manifest.name} returned ${next.length} definitions`);
48
+ definitions = canonicalizeDefinitions(next);
49
+ }
50
+ }
51
+ return definitions;
52
+ }
53
+ export async function runOnPlanCreated(loaded, context, initialPlan) {
54
+ const tableScope = context.tableScope ?? UNFILTERED_TABLE_SCOPE;
55
+ let plan = initialPlan;
56
+ for (const item of loaded) {
57
+ const hook = item.plugin.hooks?.onPlanCreated;
58
+ if (!hook)
59
+ continue;
60
+ debug('hook', `onPlanCreated → ${item.plugin.manifest.name} (${plan.operations.length} operations)`);
61
+ const next = await guardHook(item.plugin.manifest.name, 'onPlanCreated', () => hook({ ...context, tableScope, plan }));
62
+ if (next) {
63
+ debug('hook', `onPlanCreated ← ${item.plugin.manifest.name} modified plan (${next.operations.length} operations)`);
64
+ plan = next;
65
+ }
66
+ }
67
+ return plan;
68
+ }
69
+ export async function runOnBeforeApply(loaded, context) {
70
+ let statements = context.statements;
71
+ for (const item of loaded) {
72
+ const hook = item.plugin.hooks?.onBeforeApply;
73
+ if (!hook)
74
+ continue;
75
+ debug('hook', `onBeforeApply → ${item.plugin.manifest.name} (${context.migration}, ${statements.length} statements)`);
76
+ const result = await guardHook(item.plugin.manifest.name, 'onBeforeApply', () => hook({ ...context, statements }));
77
+ if (result?.statements) {
78
+ debug('hook', `onBeforeApply ← ${item.plugin.manifest.name} modified statements (${result.statements.length})`);
79
+ statements = result.statements;
80
+ }
81
+ }
82
+ return statements;
83
+ }
84
+ export async function runOnAfterApply(loaded, context) {
85
+ for (const item of loaded) {
86
+ const hook = item.plugin.hooks?.onAfterApply;
87
+ if (!hook)
88
+ continue;
89
+ debug('hook', `onAfterApply → ${item.plugin.manifest.name} (${context.migration})`);
90
+ await guardHook(item.plugin.manifest.name, 'onAfterApply', () => hook(context));
91
+ }
92
+ }
93
+ export async function runOnCheck(loaded, context) {
94
+ const tableScope = context.tableScope ?? UNFILTERED_TABLE_SCOPE;
95
+ const results = [];
96
+ for (const item of loaded) {
97
+ const hook = item.plugin.hooks?.onCheck;
98
+ if (!hook)
99
+ continue;
100
+ debug('hook', `onCheck → ${item.plugin.manifest.name}`);
101
+ const result = await guardHook(item.plugin.manifest.name, 'onCheck', () => hook({ ...context, options: item.options, tableScope }));
102
+ if (!result)
103
+ continue;
104
+ debug('hook', `onCheck ← ${item.plugin.manifest.name}: ok=${result.ok}, findings=${result.findings.length}`);
105
+ results.push({
106
+ plugin: result.plugin || item.plugin.manifest.name,
107
+ evaluated: result.evaluated,
108
+ ok: result.ok,
109
+ findings: result.findings,
110
+ metadata: result.metadata,
111
+ });
112
+ }
113
+ return results;
114
+ }
115
+ export async function runOnCheckReport(byName, results, print) {
116
+ for (const result of results) {
117
+ const item = byName.get(result.plugin);
118
+ if (!item)
119
+ continue;
120
+ const hook = item.plugin.hooks?.onCheckReport;
121
+ if (!hook)
122
+ continue;
123
+ await guardHook(item.plugin.manifest.name, 'onCheckReport', () => hook({ result, print }));
124
+ }
125
+ }
126
+ export async function runOnBeforePluginCommand(loaded, pluginName, commandName, context) {
127
+ for (const item of loaded) {
128
+ if (item.plugin.manifest.name === pluginName)
129
+ continue;
130
+ const hook = item.plugin.hooks?.onBeforePluginCommand;
131
+ if (!hook)
132
+ continue;
133
+ debug('hook', `onBeforePluginCommand → ${item.plugin.manifest.name} (target: ${pluginName}:${commandName})`);
134
+ const result = await guardHook(item.plugin.manifest.name, 'onBeforePluginCommand', () => hook({
135
+ ...context,
136
+ targetPlugin: pluginName,
137
+ command: commandName,
138
+ options: item.options,
139
+ }));
140
+ if (result.handled) {
141
+ debug('hook', `onBeforePluginCommand ← ${item.plugin.manifest.name} handled command (exitCode: ${result.exitCode})`);
142
+ return result;
143
+ }
144
+ }
145
+ return { handled: false };
146
+ }
147
+ export { UNFILTERED_TABLE_SCOPE };
148
+ //# sourceMappingURL=hooks.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"hooks.js","sourceRoot":"","sources":["../../../src/runtime/plugin-runtime/hooks.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,9 @@
1
+ import { type ResolvedChxConfig } from '@chkit/core';
2
+ import type { ChxPlugin, PluginRuntime } from '../../plugins.js';
3
+ export declare function loadPluginRuntime(input: {
4
+ config: ResolvedChxConfig;
5
+ configPath: string;
6
+ cliVersion: string;
7
+ internalPlugins?: ChxPlugin[];
8
+ }): Promise<PluginRuntime>;
9
+ //# sourceMappingURL=index.d.ts.map