@warmdrift/kgauto-compiler 2.0.0-alpha.3 → 2.0.0-alpha.31
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.
- package/README.md +87 -3
- package/dist/chunk-JQGRWJZO.mjs +1216 -0
- package/dist/chunk-NBO4R5PC.mjs +313 -0
- package/dist/chunk-RO22VFIF.mjs +29 -0
- package/dist/chunk-WXCFWUCN.mjs +678 -0
- package/dist/glassbox/index.d.mts +59 -0
- package/dist/glassbox/index.d.ts +59 -0
- package/dist/glassbox/index.js +312 -0
- package/dist/glassbox/index.mjs +12 -0
- package/dist/glassbox-routes/index.d.mts +242 -0
- package/dist/glassbox-routes/index.d.ts +242 -0
- package/dist/glassbox-routes/index.js +2458 -0
- package/dist/glassbox-routes/index.mjs +658 -0
- package/dist/index.d.mts +1195 -11
- package/dist/index.d.ts +1195 -11
- package/dist/index.js +3503 -236
- package/dist/index.mjs +1588 -78
- package/dist/ir-BIAT9gJk.d.ts +1031 -0
- package/dist/ir-De2AQtlr.d.mts +1031 -0
- package/dist/profiles.d.mts +137 -2
- package/dist/profiles.d.ts +137 -2
- package/dist/profiles.js +820 -11
- package/dist/profiles.mjs +5 -1
- package/dist/types-BjrIFPGe.d.mts +131 -0
- package/dist/types-D_JAhCv4.d.ts +131 -0
- package/package.json +12 -2
- package/dist/chunk-MBEI5UOM.mjs +0 -409
- package/dist/profiles-BiyrF36f.d.mts +0 -489
- package/dist/profiles-C5lVqF8_.d.ts +0 -489
|
@@ -0,0 +1,313 @@
|
|
|
1
|
+
// src/glassbox/types.ts
|
|
2
|
+
var GLASSBOX_STREAM_TTL_MS = 6e4;
|
|
3
|
+
|
|
4
|
+
// src/glassbox/pubsub-upstash.ts
|
|
5
|
+
var UpstashPubSub = class {
|
|
6
|
+
url;
|
|
7
|
+
token;
|
|
8
|
+
fetchImpl;
|
|
9
|
+
blockMs;
|
|
10
|
+
maxLen;
|
|
11
|
+
constructor(cfg) {
|
|
12
|
+
this.url = cfg.url.replace(/\/$/, "");
|
|
13
|
+
this.token = cfg.token;
|
|
14
|
+
this.fetchImpl = cfg.fetchImpl ?? globalThis.fetch.bind(globalThis);
|
|
15
|
+
this.blockMs = cfg.blockMs ?? 100;
|
|
16
|
+
this.maxLen = cfg.maxLen ?? 100;
|
|
17
|
+
}
|
|
18
|
+
async publish(channelKey, event) {
|
|
19
|
+
const key = channelKey;
|
|
20
|
+
const payload = JSON.stringify(event);
|
|
21
|
+
await this.cmd([
|
|
22
|
+
"XADD",
|
|
23
|
+
key,
|
|
24
|
+
"MAXLEN",
|
|
25
|
+
"~",
|
|
26
|
+
String(this.maxLen),
|
|
27
|
+
"*",
|
|
28
|
+
"event",
|
|
29
|
+
payload
|
|
30
|
+
]);
|
|
31
|
+
await this.cmd(["EXPIRE", key, String(Math.ceil(GLASSBOX_STREAM_TTL_MS / 1e3))]);
|
|
32
|
+
}
|
|
33
|
+
subscribe(channelKey) {
|
|
34
|
+
const key = channelKey;
|
|
35
|
+
const self = this;
|
|
36
|
+
let cursor = "$";
|
|
37
|
+
let cancelled = false;
|
|
38
|
+
let ttlDeadline = Date.now() + GLASSBOX_STREAM_TTL_MS;
|
|
39
|
+
return new ReadableStream({
|
|
40
|
+
async start(controller) {
|
|
41
|
+
try {
|
|
42
|
+
while (!cancelled && Date.now() < ttlDeadline) {
|
|
43
|
+
const resp = await self.cmd([
|
|
44
|
+
"XREAD",
|
|
45
|
+
"BLOCK",
|
|
46
|
+
String(self.blockMs),
|
|
47
|
+
"STREAMS",
|
|
48
|
+
key,
|
|
49
|
+
cursor
|
|
50
|
+
]);
|
|
51
|
+
if (cancelled) break;
|
|
52
|
+
const parsed = parseXReadResult(resp.result);
|
|
53
|
+
if (parsed.entries.length === 0) {
|
|
54
|
+
continue;
|
|
55
|
+
}
|
|
56
|
+
for (const entry of parsed.entries) {
|
|
57
|
+
const evt = decodeEvent(entry.fields);
|
|
58
|
+
if (evt) {
|
|
59
|
+
try {
|
|
60
|
+
controller.enqueue(evt);
|
|
61
|
+
} catch {
|
|
62
|
+
cancelled = true;
|
|
63
|
+
break;
|
|
64
|
+
}
|
|
65
|
+
}
|
|
66
|
+
cursor = entry.id;
|
|
67
|
+
}
|
|
68
|
+
ttlDeadline = Date.now() + GLASSBOX_STREAM_TTL_MS;
|
|
69
|
+
}
|
|
70
|
+
} catch (err) {
|
|
71
|
+
if (!cancelled) {
|
|
72
|
+
try {
|
|
73
|
+
controller.error(err);
|
|
74
|
+
} catch {
|
|
75
|
+
}
|
|
76
|
+
return;
|
|
77
|
+
}
|
|
78
|
+
}
|
|
79
|
+
try {
|
|
80
|
+
controller.close();
|
|
81
|
+
} catch {
|
|
82
|
+
}
|
|
83
|
+
},
|
|
84
|
+
cancel() {
|
|
85
|
+
cancelled = true;
|
|
86
|
+
}
|
|
87
|
+
});
|
|
88
|
+
}
|
|
89
|
+
async cmd(args) {
|
|
90
|
+
const res = await this.fetchImpl(this.url, {
|
|
91
|
+
method: "POST",
|
|
92
|
+
headers: {
|
|
93
|
+
Authorization: `Bearer ${this.token}`,
|
|
94
|
+
"Content-Type": "application/json"
|
|
95
|
+
},
|
|
96
|
+
body: JSON.stringify(args)
|
|
97
|
+
});
|
|
98
|
+
if (!res.ok) {
|
|
99
|
+
throw new Error(`Upstash ${args[0]} failed: HTTP ${res.status}`);
|
|
100
|
+
}
|
|
101
|
+
const json = await res.json();
|
|
102
|
+
if (json.error) {
|
|
103
|
+
throw new Error(`Upstash ${args[0]} failed: ${json.error}`);
|
|
104
|
+
}
|
|
105
|
+
return json;
|
|
106
|
+
}
|
|
107
|
+
};
|
|
108
|
+
function traceChannel(traceId) {
|
|
109
|
+
return `glassbox:trace:${traceId}`;
|
|
110
|
+
}
|
|
111
|
+
function appChannel(appId) {
|
|
112
|
+
return `glassbox:app:${appId}`;
|
|
113
|
+
}
|
|
114
|
+
function decodeEvent(fields) {
|
|
115
|
+
const raw = fields["event"];
|
|
116
|
+
if (!raw) return void 0;
|
|
117
|
+
try {
|
|
118
|
+
const parsed = JSON.parse(raw);
|
|
119
|
+
if (typeof parsed.kind === "string" && typeof parsed.at === "number") {
|
|
120
|
+
return parsed;
|
|
121
|
+
}
|
|
122
|
+
return void 0;
|
|
123
|
+
} catch {
|
|
124
|
+
return void 0;
|
|
125
|
+
}
|
|
126
|
+
}
|
|
127
|
+
function parseXReadResult(raw) {
|
|
128
|
+
if (!Array.isArray(raw)) return { entries: [] };
|
|
129
|
+
const entries = [];
|
|
130
|
+
for (const stream of raw) {
|
|
131
|
+
if (!Array.isArray(stream) || stream.length < 2) continue;
|
|
132
|
+
const streamEntries = stream[1];
|
|
133
|
+
if (!Array.isArray(streamEntries)) continue;
|
|
134
|
+
for (const entry of streamEntries) {
|
|
135
|
+
if (!Array.isArray(entry) || entry.length < 2) continue;
|
|
136
|
+
const id = String(entry[0]);
|
|
137
|
+
const flat = entry[1];
|
|
138
|
+
if (!Array.isArray(flat)) continue;
|
|
139
|
+
const fields = {};
|
|
140
|
+
for (let i = 0; i < flat.length; i += 2) {
|
|
141
|
+
const k = flat[i];
|
|
142
|
+
const v = flat[i + 1];
|
|
143
|
+
if (typeof k === "string") fields[k] = String(v ?? "");
|
|
144
|
+
}
|
|
145
|
+
entries.push({ id, fields });
|
|
146
|
+
}
|
|
147
|
+
}
|
|
148
|
+
return { entries };
|
|
149
|
+
}
|
|
150
|
+
|
|
151
|
+
// src/glassbox/pubsub-memory.ts
|
|
152
|
+
var MemoryPubSub = class {
|
|
153
|
+
subscribers = /* @__PURE__ */ new Map();
|
|
154
|
+
async publish(channelKey, event) {
|
|
155
|
+
const subs = this.subscribers.get(channelKey);
|
|
156
|
+
if (!subs || subs.size === 0) return;
|
|
157
|
+
for (const sub of subs) {
|
|
158
|
+
if (sub.closed) continue;
|
|
159
|
+
try {
|
|
160
|
+
sub.controller.enqueue(event);
|
|
161
|
+
} catch {
|
|
162
|
+
sub.closed = true;
|
|
163
|
+
continue;
|
|
164
|
+
}
|
|
165
|
+
this.refreshTtl(channelKey, sub);
|
|
166
|
+
}
|
|
167
|
+
}
|
|
168
|
+
subscribe(channelKey) {
|
|
169
|
+
const self = this;
|
|
170
|
+
let sub;
|
|
171
|
+
return new ReadableStream({
|
|
172
|
+
start(controller) {
|
|
173
|
+
sub = {
|
|
174
|
+
controller,
|
|
175
|
+
ttlTimer: setTimeout(() => {
|
|
176
|
+
self.closeSubscriber(channelKey, sub);
|
|
177
|
+
}, GLASSBOX_STREAM_TTL_MS),
|
|
178
|
+
closed: false
|
|
179
|
+
};
|
|
180
|
+
let set = self.subscribers.get(channelKey);
|
|
181
|
+
if (!set) {
|
|
182
|
+
set = /* @__PURE__ */ new Set();
|
|
183
|
+
self.subscribers.set(channelKey, set);
|
|
184
|
+
}
|
|
185
|
+
set.add(sub);
|
|
186
|
+
},
|
|
187
|
+
cancel() {
|
|
188
|
+
if (sub) self.removeSubscriber(channelKey, sub);
|
|
189
|
+
}
|
|
190
|
+
});
|
|
191
|
+
}
|
|
192
|
+
/**
|
|
193
|
+
* Refresh the rolling TTL for a subscriber after an event lands. Replaces
|
|
194
|
+
* the existing timer with a fresh 60s one.
|
|
195
|
+
*/
|
|
196
|
+
refreshTtl(channelKey, sub) {
|
|
197
|
+
clearTimeout(sub.ttlTimer);
|
|
198
|
+
sub.ttlTimer = setTimeout(() => {
|
|
199
|
+
this.closeSubscriber(channelKey, sub);
|
|
200
|
+
}, GLASSBOX_STREAM_TTL_MS);
|
|
201
|
+
}
|
|
202
|
+
/**
|
|
203
|
+
* Close the subscriber's stream cleanly and remove from the fan-out set.
|
|
204
|
+
* Idempotent — safe to call multiple times.
|
|
205
|
+
*/
|
|
206
|
+
closeSubscriber(channelKey, sub) {
|
|
207
|
+
if (sub.closed) return;
|
|
208
|
+
sub.closed = true;
|
|
209
|
+
clearTimeout(sub.ttlTimer);
|
|
210
|
+
try {
|
|
211
|
+
sub.controller.close();
|
|
212
|
+
} catch {
|
|
213
|
+
}
|
|
214
|
+
this.removeSubscriber(channelKey, sub);
|
|
215
|
+
}
|
|
216
|
+
removeSubscriber(channelKey, sub) {
|
|
217
|
+
clearTimeout(sub.ttlTimer);
|
|
218
|
+
const set = this.subscribers.get(channelKey);
|
|
219
|
+
if (!set) return;
|
|
220
|
+
set.delete(sub);
|
|
221
|
+
if (set.size === 0) this.subscribers.delete(channelKey);
|
|
222
|
+
}
|
|
223
|
+
/**
|
|
224
|
+
* Test-only reset. Tears down all subscribers, clears all state. Calling
|
|
225
|
+
* outside of tests is harmless but cancels every active stream.
|
|
226
|
+
*/
|
|
227
|
+
_reset() {
|
|
228
|
+
for (const [, set] of this.subscribers) {
|
|
229
|
+
for (const sub of set) {
|
|
230
|
+
this.closeSubscriber("", sub);
|
|
231
|
+
}
|
|
232
|
+
}
|
|
233
|
+
this.subscribers.clear();
|
|
234
|
+
}
|
|
235
|
+
};
|
|
236
|
+
|
|
237
|
+
// src/glassbox/emit.ts
|
|
238
|
+
var activePubSub;
|
|
239
|
+
function getPubSub() {
|
|
240
|
+
if (activePubSub) return activePubSub;
|
|
241
|
+
const url = readEnv("UPSTASH_REDIS_URL");
|
|
242
|
+
const token = readEnv("UPSTASH_REDIS_TOKEN");
|
|
243
|
+
if (url && token) {
|
|
244
|
+
activePubSub = new UpstashPubSub({ url, token });
|
|
245
|
+
} else {
|
|
246
|
+
activePubSub = new MemoryPubSub();
|
|
247
|
+
}
|
|
248
|
+
return activePubSub;
|
|
249
|
+
}
|
|
250
|
+
function readEnv(key) {
|
|
251
|
+
try {
|
|
252
|
+
if (typeof process !== "undefined" && process.env) {
|
|
253
|
+
const v = process.env[key];
|
|
254
|
+
return v && v.trim() !== "" ? v : void 0;
|
|
255
|
+
}
|
|
256
|
+
} catch {
|
|
257
|
+
}
|
|
258
|
+
return void 0;
|
|
259
|
+
}
|
|
260
|
+
function emitGlassboxEvent(traceId, appId, kind, data) {
|
|
261
|
+
if (!traceId) return;
|
|
262
|
+
const event = { kind, at: Date.now(), data };
|
|
263
|
+
const ps = getPubSub();
|
|
264
|
+
try {
|
|
265
|
+
const p1 = ps.publish(traceChannel(traceId), event);
|
|
266
|
+
if (p1 && typeof p1.then === "function") {
|
|
267
|
+
p1.catch(() => {
|
|
268
|
+
});
|
|
269
|
+
}
|
|
270
|
+
} catch {
|
|
271
|
+
}
|
|
272
|
+
if (appId) {
|
|
273
|
+
try {
|
|
274
|
+
const p2 = ps.publish(appChannel(appId), event);
|
|
275
|
+
if (p2 && typeof p2.then === "function") {
|
|
276
|
+
p2.catch(() => {
|
|
277
|
+
});
|
|
278
|
+
}
|
|
279
|
+
} catch {
|
|
280
|
+
}
|
|
281
|
+
}
|
|
282
|
+
}
|
|
283
|
+
function emitCompileStart(traceId, appId, data) {
|
|
284
|
+
emitGlassboxEvent(traceId, appId, "compile.start", data);
|
|
285
|
+
}
|
|
286
|
+
function emitCompileDone(traceId, appId, data) {
|
|
287
|
+
emitGlassboxEvent(traceId, appId, "compile.done", data);
|
|
288
|
+
}
|
|
289
|
+
function emitExecuteAttempt(traceId, appId, data) {
|
|
290
|
+
emitGlassboxEvent(traceId, appId, "execute.attempt", data);
|
|
291
|
+
}
|
|
292
|
+
function emitExecuteSuccess(traceId, appId, data) {
|
|
293
|
+
emitGlassboxEvent(traceId, appId, "execute.success", data);
|
|
294
|
+
}
|
|
295
|
+
function emitAdvisoryFired(traceId, appId, data) {
|
|
296
|
+
emitGlassboxEvent(traceId, appId, "advisory.fired", data);
|
|
297
|
+
}
|
|
298
|
+
function emitFallbackWalked(traceId, appId, data) {
|
|
299
|
+
emitGlassboxEvent(traceId, appId, "fallback.walked", data);
|
|
300
|
+
}
|
|
301
|
+
|
|
302
|
+
export {
|
|
303
|
+
GLASSBOX_STREAM_TTL_MS,
|
|
304
|
+
traceChannel,
|
|
305
|
+
appChannel,
|
|
306
|
+
getPubSub,
|
|
307
|
+
emitCompileStart,
|
|
308
|
+
emitCompileDone,
|
|
309
|
+
emitExecuteAttempt,
|
|
310
|
+
emitExecuteSuccess,
|
|
311
|
+
emitAdvisoryFired,
|
|
312
|
+
emitFallbackWalked
|
|
313
|
+
};
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
import {
|
|
2
|
+
appChannel,
|
|
3
|
+
getPubSub,
|
|
4
|
+
traceChannel
|
|
5
|
+
} from "./chunk-NBO4R5PC.mjs";
|
|
6
|
+
|
|
7
|
+
// src/glassbox/subscribe.ts
|
|
8
|
+
function emptyStream() {
|
|
9
|
+
return new ReadableStream({
|
|
10
|
+
start(controller) {
|
|
11
|
+
controller.close();
|
|
12
|
+
}
|
|
13
|
+
});
|
|
14
|
+
}
|
|
15
|
+
function subscribe(traceId) {
|
|
16
|
+
if (!traceId) return emptyStream();
|
|
17
|
+
return getPubSub().subscribe(traceChannel(traceId));
|
|
18
|
+
}
|
|
19
|
+
function subscribeApp({
|
|
20
|
+
appId
|
|
21
|
+
}) {
|
|
22
|
+
if (!appId) return emptyStream();
|
|
23
|
+
return getPubSub().subscribe(appChannel(appId));
|
|
24
|
+
}
|
|
25
|
+
|
|
26
|
+
export {
|
|
27
|
+
subscribe,
|
|
28
|
+
subscribeApp
|
|
29
|
+
};
|