@tasker-systems/tasker 0.1.2 → 0.1.4

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/dist/index.js CHANGED
@@ -1,8 +1,9 @@
1
1
  import { EventEmitter } from 'eventemitter3';
2
2
  import pino from 'pino';
3
3
  import { existsSync } from 'fs';
4
+ import { dirname, join } from 'path';
5
+ import { fileURLToPath } from 'url';
4
6
  import { readdir } from 'fs/promises';
5
- import { join } from 'path';
6
7
 
7
8
  var __create = Object.create;
8
9
  var __defProp = Object.defineProperty;
@@ -71,1254 +72,1385 @@ var init_runtime_interface = __esm({
71
72
  }
72
73
  });
73
74
 
74
- // node_modules/koffi/build/koffi/darwin_arm64/koffi.node
75
- var koffi_default;
76
- var init_koffi = __esm({
77
- "node_modules/koffi/build/koffi/darwin_arm64/koffi.node"() {
78
- koffi_default = "./koffi-X7JMBSZH.node";
79
- }
80
- });
81
-
82
- // node-file:/home/runner/work/tasker-core/tasker-core/workers/typescript/node_modules/koffi/build/koffi/darwin_arm64/koffi.node
83
- var require_koffi = __commonJS2({
84
- "node-file:/home/runner/work/tasker-core/tasker-core/workers/typescript/node_modules/koffi/build/koffi/darwin_arm64/koffi.node"(exports2, module2) {
85
- init_koffi();
86
- try {
87
- module2.exports = __require(koffi_default);
88
- } catch {
89
- }
90
- }
91
- });
92
-
93
- // node_modules/koffi/build/koffi/darwin_x64/koffi.node
94
- var koffi_default2;
95
- var init_koffi2 = __esm({
96
- "node_modules/koffi/build/koffi/darwin_x64/koffi.node"() {
97
- koffi_default2 = "./koffi-OMHWL3D6.node";
98
- }
99
- });
100
-
101
- // node-file:/home/runner/work/tasker-core/tasker-core/workers/typescript/node_modules/koffi/build/koffi/darwin_x64/koffi.node
102
- var require_koffi2 = __commonJS2({
103
- "node-file:/home/runner/work/tasker-core/tasker-core/workers/typescript/node_modules/koffi/build/koffi/darwin_x64/koffi.node"(exports2, module2) {
104
- init_koffi2();
105
- try {
106
- module2.exports = __require(koffi_default2);
107
- } catch {
108
- }
109
- }
110
- });
111
-
112
- // node_modules/koffi/build/koffi/freebsd_arm64/koffi.node
113
- var koffi_default3;
114
- var init_koffi3 = __esm({
115
- "node_modules/koffi/build/koffi/freebsd_arm64/koffi.node"() {
116
- koffi_default3 = "./koffi-AVDVVSXH.node";
117
- }
118
- });
119
-
120
- // node-file:/home/runner/work/tasker-core/tasker-core/workers/typescript/node_modules/koffi/build/koffi/freebsd_arm64/koffi.node
121
- var require_koffi3 = __commonJS2({
122
- "node-file:/home/runner/work/tasker-core/tasker-core/workers/typescript/node_modules/koffi/build/koffi/freebsd_arm64/koffi.node"(exports2, module2) {
123
- init_koffi3();
124
- try {
125
- module2.exports = __require(koffi_default3);
126
- } catch {
127
- }
128
- }
129
- });
130
-
131
- // node_modules/koffi/build/koffi/freebsd_ia32/koffi.node
132
- var koffi_default4;
133
- var init_koffi4 = __esm({
134
- "node_modules/koffi/build/koffi/freebsd_ia32/koffi.node"() {
135
- koffi_default4 = "./koffi-GG4SDSYA.node";
136
- }
137
- });
138
-
139
- // node-file:/home/runner/work/tasker-core/tasker-core/workers/typescript/node_modules/koffi/build/koffi/freebsd_ia32/koffi.node
140
- var require_koffi4 = __commonJS2({
141
- "node-file:/home/runner/work/tasker-core/tasker-core/workers/typescript/node_modules/koffi/build/koffi/freebsd_ia32/koffi.node"(exports2, module2) {
142
- init_koffi4();
143
- try {
144
- module2.exports = __require(koffi_default4);
145
- } catch {
146
- }
147
- }
148
- });
149
-
150
- // node_modules/koffi/build/koffi/freebsd_x64/koffi.node
151
- var koffi_default5;
152
- var init_koffi5 = __esm({
153
- "node_modules/koffi/build/koffi/freebsd_x64/koffi.node"() {
154
- koffi_default5 = "./koffi-AHHUCM3C.node";
155
- }
156
- });
157
-
158
- // node-file:/home/runner/work/tasker-core/tasker-core/workers/typescript/node_modules/koffi/build/koffi/freebsd_x64/koffi.node
159
- var require_koffi5 = __commonJS2({
160
- "node-file:/home/runner/work/tasker-core/tasker-core/workers/typescript/node_modules/koffi/build/koffi/freebsd_x64/koffi.node"(exports2, module2) {
161
- init_koffi5();
162
- try {
163
- module2.exports = __require(koffi_default5);
164
- } catch {
165
- }
166
- }
167
- });
168
-
169
- // node_modules/koffi/build/koffi/linux_armhf/koffi.node
170
- var koffi_default6;
171
- var init_koffi6 = __esm({
172
- "node_modules/koffi/build/koffi/linux_armhf/koffi.node"() {
173
- koffi_default6 = "./koffi-YNQDUF3Q.node";
174
- }
175
- });
176
-
177
- // node-file:/home/runner/work/tasker-core/tasker-core/workers/typescript/node_modules/koffi/build/koffi/linux_armhf/koffi.node
178
- var require_koffi6 = __commonJS2({
179
- "node-file:/home/runner/work/tasker-core/tasker-core/workers/typescript/node_modules/koffi/build/koffi/linux_armhf/koffi.node"(exports2, module2) {
180
- init_koffi6();
181
- try {
182
- module2.exports = __require(koffi_default6);
183
- } catch {
184
- }
185
- }
186
- });
187
-
188
- // node_modules/koffi/build/koffi/linux_arm64/koffi.node
189
- var koffi_default7;
190
- var init_koffi7 = __esm({
191
- "node_modules/koffi/build/koffi/linux_arm64/koffi.node"() {
192
- koffi_default7 = "./koffi-SE4ZI36U.node";
193
- }
194
- });
195
-
196
- // node-file:/home/runner/work/tasker-core/tasker-core/workers/typescript/node_modules/koffi/build/koffi/linux_arm64/koffi.node
197
- var require_koffi7 = __commonJS2({
198
- "node-file:/home/runner/work/tasker-core/tasker-core/workers/typescript/node_modules/koffi/build/koffi/linux_arm64/koffi.node"(exports2, module2) {
199
- init_koffi7();
200
- try {
201
- module2.exports = __require(koffi_default7);
202
- } catch {
203
- }
204
- }
205
- });
206
-
207
- // node_modules/koffi/build/koffi/linux_ia32/koffi.node
208
- var koffi_default8;
209
- var init_koffi8 = __esm({
210
- "node_modules/koffi/build/koffi/linux_ia32/koffi.node"() {
211
- koffi_default8 = "./koffi-LOH6WKRQ.node";
212
- }
213
- });
214
-
215
- // node-file:/home/runner/work/tasker-core/tasker-core/workers/typescript/node_modules/koffi/build/koffi/linux_ia32/koffi.node
216
- var require_koffi8 = __commonJS2({
217
- "node-file:/home/runner/work/tasker-core/tasker-core/workers/typescript/node_modules/koffi/build/koffi/linux_ia32/koffi.node"(exports2, module2) {
218
- init_koffi8();
219
- try {
220
- module2.exports = __require(koffi_default8);
221
- } catch {
222
- }
223
- }
224
- });
225
-
226
- // node_modules/koffi/build/koffi/linux_loong64/koffi.node
227
- var koffi_default9;
228
- var init_koffi9 = __esm({
229
- "node_modules/koffi/build/koffi/linux_loong64/koffi.node"() {
230
- koffi_default9 = "./koffi-QKY2KSXW.node";
231
- }
232
- });
233
-
234
- // node-file:/home/runner/work/tasker-core/tasker-core/workers/typescript/node_modules/koffi/build/koffi/linux_loong64/koffi.node
235
- var require_koffi9 = __commonJS2({
236
- "node-file:/home/runner/work/tasker-core/tasker-core/workers/typescript/node_modules/koffi/build/koffi/linux_loong64/koffi.node"(exports2, module2) {
237
- init_koffi9();
238
- try {
239
- module2.exports = __require(koffi_default9);
240
- } catch {
241
- }
242
- }
243
- });
244
-
245
- // node_modules/koffi/build/koffi/linux_riscv64d/koffi.node
246
- var koffi_default10;
247
- var init_koffi10 = __esm({
248
- "node_modules/koffi/build/koffi/linux_riscv64d/koffi.node"() {
249
- koffi_default10 = "./koffi-X3YT67KE.node";
250
- }
251
- });
252
-
253
- // node-file:/home/runner/work/tasker-core/tasker-core/workers/typescript/node_modules/koffi/build/koffi/linux_riscv64d/koffi.node
254
- var require_koffi10 = __commonJS2({
255
- "node-file:/home/runner/work/tasker-core/tasker-core/workers/typescript/node_modules/koffi/build/koffi/linux_riscv64d/koffi.node"(exports2, module2) {
256
- init_koffi10();
257
- try {
258
- module2.exports = __require(koffi_default10);
259
- } catch {
260
- }
261
- }
262
- });
263
-
264
- // node_modules/koffi/build/koffi/linux_x64/koffi.node
265
- var koffi_default11;
266
- var init_koffi11 = __esm({
267
- "node_modules/koffi/build/koffi/linux_x64/koffi.node"() {
268
- koffi_default11 = "./koffi-G4D35B2D.node";
269
- }
270
- });
271
-
272
- // node-file:/home/runner/work/tasker-core/tasker-core/workers/typescript/node_modules/koffi/build/koffi/linux_x64/koffi.node
273
- var require_koffi11 = __commonJS2({
274
- "node-file:/home/runner/work/tasker-core/tasker-core/workers/typescript/node_modules/koffi/build/koffi/linux_x64/koffi.node"(exports2, module2) {
275
- init_koffi11();
276
- try {
277
- module2.exports = __require(koffi_default11);
278
- } catch {
279
- }
280
- }
281
- });
282
-
283
- // node_modules/koffi/build/koffi/openbsd_ia32/koffi.node
284
- var koffi_default12;
285
- var init_koffi12 = __esm({
286
- "node_modules/koffi/build/koffi/openbsd_ia32/koffi.node"() {
287
- koffi_default12 = "./koffi-LUY2JHJP.node";
288
- }
289
- });
290
-
291
- // node-file:/home/runner/work/tasker-core/tasker-core/workers/typescript/node_modules/koffi/build/koffi/openbsd_ia32/koffi.node
292
- var require_koffi12 = __commonJS2({
293
- "node-file:/home/runner/work/tasker-core/tasker-core/workers/typescript/node_modules/koffi/build/koffi/openbsd_ia32/koffi.node"(exports2, module2) {
294
- init_koffi12();
295
- try {
296
- module2.exports = __require(koffi_default12);
297
- } catch {
298
- }
299
- }
300
- });
301
-
302
- // node_modules/koffi/build/koffi/openbsd_x64/koffi.node
303
- var koffi_default13;
304
- var init_koffi13 = __esm({
305
- "node_modules/koffi/build/koffi/openbsd_x64/koffi.node"() {
306
- koffi_default13 = "./koffi-ROB3FRHA.node";
307
- }
308
- });
309
-
310
- // node-file:/home/runner/work/tasker-core/tasker-core/workers/typescript/node_modules/koffi/build/koffi/openbsd_x64/koffi.node
311
- var require_koffi13 = __commonJS2({
312
- "node-file:/home/runner/work/tasker-core/tasker-core/workers/typescript/node_modules/koffi/build/koffi/openbsd_x64/koffi.node"(exports2, module2) {
313
- init_koffi13();
314
- try {
315
- module2.exports = __require(koffi_default13);
316
- } catch {
317
- }
318
- }
75
+ // src/ffi/deno-runtime.ts
76
+ var deno_runtime_exports = {};
77
+ __export(deno_runtime_exports, {
78
+ DenoRuntime: () => DenoRuntime
319
79
  });
320
-
321
- // node_modules/koffi/build/koffi/win32_arm64/koffi.node
322
- var koffi_default14;
323
- var init_koffi14 = __esm({
324
- "node_modules/koffi/build/koffi/win32_arm64/koffi.node"() {
325
- koffi_default14 = "./koffi-GOENU54R.node";
326
- }
327
- });
328
-
329
- // node-file:/home/runner/work/tasker-core/tasker-core/workers/typescript/node_modules/koffi/build/koffi/win32_arm64/koffi.node
330
- var require_koffi14 = __commonJS2({
331
- "node-file:/home/runner/work/tasker-core/tasker-core/workers/typescript/node_modules/koffi/build/koffi/win32_arm64/koffi.node"(exports2, module2) {
332
- init_koffi14();
333
- try {
334
- module2.exports = __require(koffi_default14);
335
- } catch {
336
- }
337
- }
338
- });
339
-
340
- // node_modules/koffi/build/koffi/win32_ia32/koffi.node
341
- var koffi_default15;
342
- var init_koffi15 = __esm({
343
- "node_modules/koffi/build/koffi/win32_ia32/koffi.node"() {
344
- koffi_default15 = "./koffi-KFZAXWPQ.node";
345
- }
346
- });
347
-
348
- // node-file:/home/runner/work/tasker-core/tasker-core/workers/typescript/node_modules/koffi/build/koffi/win32_ia32/koffi.node
349
- var require_koffi15 = __commonJS2({
350
- "node-file:/home/runner/work/tasker-core/tasker-core/workers/typescript/node_modules/koffi/build/koffi/win32_ia32/koffi.node"(exports2, module2) {
351
- init_koffi15();
352
- try {
353
- module2.exports = __require(koffi_default15);
354
- } catch {
355
- }
356
- }
357
- });
358
-
359
- // node_modules/koffi/build/koffi/win32_x64/koffi.node
360
- var koffi_default16;
361
- var init_koffi16 = __esm({
362
- "node_modules/koffi/build/koffi/win32_x64/koffi.node"() {
363
- koffi_default16 = "./koffi-IDX6JEDH.node";
364
- }
365
- });
366
-
367
- // node-file:/home/runner/work/tasker-core/tasker-core/workers/typescript/node_modules/koffi/build/koffi/win32_x64/koffi.node
368
- var require_koffi16 = __commonJS2({
369
- "node-file:/home/runner/work/tasker-core/tasker-core/workers/typescript/node_modules/koffi/build/koffi/win32_x64/koffi.node"(exports2, module2) {
370
- init_koffi16();
371
- try {
372
- module2.exports = __require(koffi_default16);
373
- } catch {
374
- }
375
- }
376
- });
377
-
378
- // node_modules/koffi/build/koffi/musl_arm64/koffi.node
379
- var koffi_default17;
380
- var init_koffi17 = __esm({
381
- "node_modules/koffi/build/koffi/musl_arm64/koffi.node"() {
382
- koffi_default17 = "./koffi-3HFAASOB.node";
383
- }
384
- });
385
-
386
- // node-file:/home/runner/work/tasker-core/tasker-core/workers/typescript/node_modules/koffi/build/koffi/musl_arm64/koffi.node
387
- var require_koffi17 = __commonJS2({
388
- "node-file:/home/runner/work/tasker-core/tasker-core/workers/typescript/node_modules/koffi/build/koffi/musl_arm64/koffi.node"(exports2, module2) {
389
- init_koffi17();
390
- try {
391
- module2.exports = __require(koffi_default17);
392
- } catch {
393
- }
394
- }
395
- });
396
-
397
- // node_modules/koffi/build/koffi/musl_x64/koffi.node
398
- var koffi_default18;
399
- var init_koffi18 = __esm({
400
- "node_modules/koffi/build/koffi/musl_x64/koffi.node"() {
401
- koffi_default18 = "./koffi-BMO5K7B3.node";
402
- }
403
- });
404
-
405
- // node-file:/home/runner/work/tasker-core/tasker-core/workers/typescript/node_modules/koffi/build/koffi/musl_x64/koffi.node
406
- var require_koffi18 = __commonJS2({
407
- "node-file:/home/runner/work/tasker-core/tasker-core/workers/typescript/node_modules/koffi/build/koffi/musl_x64/koffi.node"(exports2, module2) {
408
- init_koffi18();
409
- try {
410
- module2.exports = __require(koffi_default18);
411
- } catch {
412
- }
413
- }
414
- });
415
-
416
- // node_modules/koffi/index.js
417
- var require_koffi19 = __commonJS2({
418
- "node_modules/koffi/index.js"(exports$1, module) {
419
- var __getOwnPropNames = Object.getOwnPropertyNames;
420
- var __commonJS = (cb, mod3) => function __require2() {
421
- return mod3 || (0, cb[__getOwnPropNames(cb)[0]])((mod3 = { exports: {} }).exports, mod3), mod3.exports;
422
- };
423
- var require_tools = __commonJS({
424
- "bin/Koffi/package/src/cnoke/src/tools.js"(exports2, module2) {
425
- var crypto2 = __require("crypto");
426
- var fs2 = __require("fs");
427
- var http = __require("https");
428
- var path2 = __require("path");
429
- var zlib = __require("zlib");
430
- async function download_http(url, dest) {
431
- console.log(">> Downloading " + url);
432
- let [tmp_name, file] = open_temporary_stream(dest);
433
- try {
434
- await new Promise((resolve, reject) => {
435
- let request = http.get(url, (response) => {
436
- if (response.statusCode != 200) {
437
- let err = new Error(`Download failed: ${response.statusMessage} [${response.statusCode}]`);
438
- err.code = response.statusCode;
439
- reject(err);
440
- return;
441
- }
442
- response.pipe(file);
443
- file.on("finish", () => file.close(() => {
444
- try {
445
- fs2.renameSync(file.path, dest);
446
- } catch (err) {
447
- if (!fs2.existsSync(dest))
448
- reject(err);
449
- }
450
- resolve();
451
- }));
452
- });
453
- request.on("error", reject);
454
- file.on("error", reject);
455
- });
456
- } catch (err) {
457
- file.close();
458
- try {
459
- fs2.unlinkSync(tmp_name);
460
- } catch (err2) {
461
- if (err2.code != "ENOENT")
462
- throw err2;
463
- }
464
- throw err;
465
- }
466
- }
467
- function open_temporary_stream(prefix) {
468
- let buf = Buffer.allocUnsafe(4);
469
- for (; ; ) {
470
- try {
471
- crypto2.randomFillSync(buf);
472
- let suffix = buf.toString("hex").padStart(8, "0");
473
- let filename2 = `${prefix}.${suffix}`;
474
- let file = fs2.createWriteStream(filename2, { flags: "wx", mode: 420 });
475
- return [filename2, file];
476
- } catch (err) {
477
- if (err.code != "EEXIST")
478
- throw err;
479
- }
480
- }
80
+ var DenoRuntime;
81
+ var init_deno_runtime = __esm({
82
+ "src/ffi/deno-runtime.ts"() {
83
+ init_runtime_interface();
84
+ DenoRuntime = class extends BaseTaskerRuntime {
85
+ name = "deno";
86
+ lib = null;
87
+ encoder = new TextEncoder();
88
+ get isLoaded() {
89
+ return this.lib !== null;
90
+ }
91
+ async load(libraryPath) {
92
+ if (this.lib !== null) {
93
+ return;
481
94
  }
482
- function extract_targz(filename2, dest_dir, strip = 0) {
483
- let reader = fs2.createReadStream(filename2).pipe(zlib.createGunzip());
484
- return new Promise((resolve, reject) => {
485
- let header = null;
486
- let extended = {};
487
- reader.on("readable", () => {
488
- try {
489
- for (; ; ) {
490
- if (header == null) {
491
- let buf = reader.read(512);
492
- if (buf == null)
493
- break;
494
- if (!buf[0])
495
- continue;
496
- header = {
497
- filename: buf.toString("utf-8", 0, 100).replace(/\0/g, ""),
498
- mode: parseInt(buf.toString("ascii", 100, 109), 8),
499
- size: parseInt(buf.toString("ascii", 124, 137), 8),
500
- type: String.fromCharCode(buf[156])
501
- };
502
- Object.assign(header, extended);
503
- extended = {};
504
- header.filename = header.filename.replace(/\\/g, "/");
505
- if (!header.filename.length)
506
- throw new Error(`Insecure empty filename inside TAR archive`);
507
- if (path_is_absolute(header.filename[0]))
508
- throw new Error(`Insecure filename starting with / inside TAR archive`);
509
- if (path_has_dotdot(header.filename))
510
- throw new Error(`Insecure filename containing '..' inside TAR archive`);
511
- for (let i = 0; i < strip; i++)
512
- header.filename = header.filename.substr(header.filename.indexOf("/") + 1);
513
- }
514
- let aligned = Math.floor((header.size + 511) / 512) * 512;
515
- let data = header.size ? reader.read(aligned) : null;
516
- if (data == null) {
517
- if (header.size)
518
- break;
519
- data = Buffer.alloc(0);
520
- }
521
- data = data.subarray(0, header.size);
522
- if (header.type == "0" || header.type == "7") {
523
- let filename3 = dest_dir + "/" + header.filename;
524
- let dirname = path2.dirname(filename3);
525
- fs2.mkdirSync(dirname, { recursive: true, mode: 493 });
526
- fs2.writeFileSync(filename3, data, { mode: header.mode });
527
- } else if (header.type == "5") {
528
- let filename3 = dest_dir + "/" + header.filename;
529
- fs2.mkdirSync(filename3, { recursive: true, mode: header.mode });
530
- } else if (header.type == "L") {
531
- extended.filename = data.toString("utf-8").replace(/\0/g, "");
532
- } else if (header.type == "x") {
533
- let str = data.toString("utf-8");
534
- try {
535
- while (str.length) {
536
- let matches = str.match(/^([0-9]+) ([a-zA-Z0-9\._]+)=(.*)\n/);
537
- let skip = parseInt(matches[1], 10);
538
- let key = matches[2];
539
- let value = matches[3];
540
- switch (key) {
541
- case "path":
542
- {
543
- extended.filename = value;
544
- }
545
- break;
546
- case "size":
547
- {
548
- extended.size = parseInt(value, 10);
549
- }
550
- break;
551
- }
552
- str = str.substr(skip).trimStart();
553
- }
554
- } catch (err) {
555
- throw new Error("Malformed PAX entry");
556
- }
557
- }
558
- header = null;
559
- }
560
- } catch (err) {
561
- reject(err);
562
- }
563
- });
564
- reader.on("error", reject);
565
- reader.on("end", resolve);
566
- });
95
+ if (typeof Deno === "undefined") {
96
+ throw new Error("Deno runtime not detected");
567
97
  }
568
- function path_is_absolute(path3) {
569
- if (process.platform == "win32" && path3.match(/^[a-zA-Z]:/))
570
- path3 = path3.substr(2);
571
- return is_path_separator(path3[0]);
572
- }
573
- function path_has_dotdot(path3) {
574
- let start = 0;
575
- for (; ; ) {
576
- let offset = path3.indexOf("..", start);
577
- if (offset < 0)
578
- break;
579
- start = offset + 2;
580
- if (offset && !is_path_separator(path3[offset - 1]))
581
- continue;
582
- if (offset + 2 < path3.length && !is_path_separator(path3[offset + 2]))
583
- continue;
584
- return true;
585
- }
586
- return false;
587
- }
588
- function is_path_separator(c) {
589
- if (c == "/")
590
- return true;
591
- if (process.platform == "win32" && c == "\\")
592
- return true;
593
- return false;
594
- }
595
- function sync_files(src_dir, dest_dir) {
596
- let keep = /* @__PURE__ */ new Set();
597
- {
598
- let entries = fs2.readdirSync(src_dir, { withFileTypes: true });
599
- for (let entry of entries) {
600
- if (!entry.isFile())
601
- continue;
602
- keep.add(entry.name);
603
- fs2.copyFileSync(src_dir + `/${entry.name}`, dest_dir + `/${entry.name}`);
604
- }
605
- }
606
- {
607
- let entries = fs2.readdirSync(dest_dir, { withFileTypes: true });
608
- for (let entry of entries) {
609
- if (!entry.isFile())
610
- continue;
611
- if (keep.has(entry.name))
612
- continue;
613
- fs2.unlinkSync(dest_dir + `/${entry.name}`);
614
- }
98
+ this.lib = Deno.dlopen(libraryPath, {
99
+ get_version: {
100
+ parameters: [],
101
+ result: "pointer"
102
+ },
103
+ get_rust_version: {
104
+ parameters: [],
105
+ result: "pointer"
106
+ },
107
+ health_check: {
108
+ parameters: [],
109
+ result: "i32"
110
+ },
111
+ is_worker_running: {
112
+ parameters: [],
113
+ result: "i32"
114
+ },
115
+ bootstrap_worker: {
116
+ parameters: ["buffer"],
117
+ result: "pointer"
118
+ },
119
+ get_worker_status: {
120
+ parameters: [],
121
+ result: "pointer"
122
+ },
123
+ stop_worker: {
124
+ parameters: [],
125
+ result: "pointer"
126
+ },
127
+ transition_to_graceful_shutdown: {
128
+ parameters: [],
129
+ result: "pointer"
130
+ },
131
+ poll_step_events: {
132
+ parameters: [],
133
+ result: "pointer"
134
+ },
135
+ poll_in_process_events: {
136
+ parameters: [],
137
+ result: "pointer"
138
+ },
139
+ complete_step_event: {
140
+ parameters: ["buffer", "buffer"],
141
+ result: "i32"
142
+ },
143
+ checkpoint_yield_step_event: {
144
+ parameters: ["buffer", "buffer"],
145
+ result: "i32"
146
+ },
147
+ get_ffi_dispatch_metrics: {
148
+ parameters: [],
149
+ result: "pointer"
150
+ },
151
+ check_starvation_warnings: {
152
+ parameters: [],
153
+ result: "void"
154
+ },
155
+ cleanup_timeouts: {
156
+ parameters: [],
157
+ result: "void"
158
+ },
159
+ log_error: {
160
+ parameters: ["buffer", "buffer"],
161
+ result: "void"
162
+ },
163
+ log_warn: {
164
+ parameters: ["buffer", "buffer"],
165
+ result: "void"
166
+ },
167
+ log_info: {
168
+ parameters: ["buffer", "buffer"],
169
+ result: "void"
170
+ },
171
+ log_debug: {
172
+ parameters: ["buffer", "buffer"],
173
+ result: "void"
174
+ },
175
+ log_trace: {
176
+ parameters: ["buffer", "buffer"],
177
+ result: "void"
178
+ },
179
+ free_rust_string: {
180
+ parameters: ["pointer"],
181
+ result: "void"
182
+ },
183
+ // Client API functions (TAS-231)
184
+ client_create_task: {
185
+ parameters: ["buffer"],
186
+ result: "pointer"
187
+ },
188
+ client_get_task: {
189
+ parameters: ["buffer"],
190
+ result: "pointer"
191
+ },
192
+ client_list_tasks: {
193
+ parameters: ["buffer"],
194
+ result: "pointer"
195
+ },
196
+ client_cancel_task: {
197
+ parameters: ["buffer"],
198
+ result: "pointer"
199
+ },
200
+ client_list_task_steps: {
201
+ parameters: ["buffer"],
202
+ result: "pointer"
203
+ },
204
+ client_get_step: {
205
+ parameters: ["buffer", "buffer"],
206
+ result: "pointer"
207
+ },
208
+ client_get_step_audit_history: {
209
+ parameters: ["buffer", "buffer"],
210
+ result: "pointer"
211
+ },
212
+ client_health_check: {
213
+ parameters: [],
214
+ result: "pointer"
615
215
  }
216
+ });
217
+ }
218
+ unload() {
219
+ if (this.lib) {
220
+ this.lib.close();
221
+ this.lib = null;
616
222
  }
617
- function determine_arch2() {
618
- let arch = process.arch;
619
- if (arch == "riscv32" || arch == "riscv64") {
620
- let buf = read_file_header(process.execPath, 512);
621
- let header = decode_elf_header(buf);
622
- let float_abi = header.e_flags & 6;
623
- switch (float_abi) {
624
- case 0:
625
- break;
626
- case 2:
627
- {
628
- arch += "f";
629
- }
630
- break;
631
- case 4:
632
- {
633
- arch += "d";
634
- }
635
- break;
636
- case 6:
637
- {
638
- arch += "q";
639
- }
640
- break;
641
- }
642
- } else if (arch == "arm") {
643
- let buf = read_file_header(process.execPath, 512);
644
- let header = decode_elf_header(buf);
645
- if (header.e_flags & 1024) {
646
- arch += "hf";
647
- } else if (header.e_flags & 512) {
648
- arch += "sf";
649
- } else {
650
- throw new Error("Unknown ARM floating-point ABI");
651
- }
652
- }
653
- return arch;
223
+ }
224
+ ensureLoaded() {
225
+ if (!this.lib) {
226
+ throw new Error("Native library not loaded. Call load() first.");
654
227
  }
655
- function read_file_header(filename2, read) {
656
- try {
657
- let fd2 = fs2.openSync(filename2);
658
- let buf = Buffer.allocUnsafe(read);
659
- let len = fs2.readSync(fd2, buf);
660
- return buf.subarray(0, len);
661
- } finally {
662
- }
228
+ return this.lib.symbols;
229
+ }
230
+ /**
231
+ * Creates a null-terminated C string buffer.
232
+ * With 'buffer' FFI type, we return Uint8Array directly.
233
+ */
234
+ toCString(str) {
235
+ return this.encoder.encode(`${str}\0`);
236
+ }
237
+ // biome-ignore lint/suspicious/noExplicitAny: Deno PointerValue type
238
+ fromCString(ptr) {
239
+ if (ptr === null || Deno.UnsafePointer.equals(ptr, null)) {
240
+ return null;
663
241
  }
664
- function decode_elf_header(buf) {
665
- let header = {};
666
- if (buf.length < 16)
667
- throw new Error("Truncated header");
668
- if (buf[0] != 127 || buf[1] != 69 || buf[2] != 76 || buf[3] != 70)
669
- throw new Error("Invalid magic number");
670
- if (buf[6] != 1)
671
- throw new Error("Invalid ELF version");
672
- if (buf[5] != 1)
673
- throw new Error("Big-endian architectures are not supported");
674
- let machine = buf.readUInt16LE(18);
675
- switch (machine) {
676
- case 3:
677
- {
678
- header.e_machine = "ia32";
679
- }
680
- break;
681
- case 40:
682
- {
683
- header.e_machine = "arm";
684
- }
685
- break;
686
- case 62:
687
- {
688
- header.e_machine = "amd64";
689
- }
690
- break;
691
- case 183:
692
- {
693
- header.e_machine = "arm64";
694
- }
695
- break;
696
- case 243:
697
- {
698
- switch (buf[4]) {
699
- case 1:
700
- {
701
- header.e_machine = "riscv32";
702
- }
703
- break;
704
- case 2:
705
- {
706
- header.e_machine = "riscv64";
707
- }
708
- break;
709
- }
710
- }
711
- break;
712
- case 248:
713
- {
714
- switch (buf[4]) {
715
- case 1:
716
- {
717
- header.e_machine = "loong32";
718
- }
719
- break;
720
- case 2:
721
- {
722
- header.e_machine = "loong64";
723
- }
724
- break;
725
- }
726
- }
727
- break;
728
- default:
729
- throw new Error("Unknown ELF machine type");
730
- }
731
- switch (buf[4]) {
732
- case 1:
733
- {
734
- buf = buf.subarray(0, 68);
735
- if (buf.length < 68)
736
- throw new Error("Truncated ELF header");
737
- header.ei_class = 32;
738
- header.e_flags = buf.readUInt32LE(36);
739
- }
740
- break;
741
- case 2:
742
- {
743
- buf = buf.subarray(0, 120);
744
- if (buf.length < 120)
745
- throw new Error("Truncated ELF header");
746
- header.ei_class = 64;
747
- header.e_flags = buf.readUInt32LE(48);
748
- }
749
- break;
750
- default:
751
- throw new Error("Invalid ELF class");
752
- }
753
- return header;
242
+ const view = new Deno.UnsafePointerView(ptr);
243
+ return view.getCString();
244
+ }
245
+ getVersion() {
246
+ const symbols = this.ensureLoaded();
247
+ const result = symbols.get_version();
248
+ const version = this.fromCString(result) ?? "unknown";
249
+ if (result !== null) symbols.free_rust_string(result);
250
+ return version;
251
+ }
252
+ getRustVersion() {
253
+ const symbols = this.ensureLoaded();
254
+ const result = symbols.get_rust_version();
255
+ const version = this.fromCString(result) ?? "unknown";
256
+ if (result !== null) symbols.free_rust_string(result);
257
+ return version;
258
+ }
259
+ healthCheck() {
260
+ const symbols = this.ensureLoaded();
261
+ return symbols.health_check() === 1;
262
+ }
263
+ bootstrapWorker(config) {
264
+ const symbols = this.ensureLoaded();
265
+ const configBuf = config ? this.toCString(this.toJson(config)) : null;
266
+ const result = symbols.bootstrap_worker(configBuf);
267
+ const jsonStr = this.fromCString(result);
268
+ if (result !== null) symbols.free_rust_string(result);
269
+ const parsed = this.parseJson(jsonStr);
270
+ return parsed ?? {
271
+ success: false,
272
+ status: "error",
273
+ message: "Failed to parse bootstrap result",
274
+ error: "Invalid JSON response"
275
+ };
276
+ }
277
+ isWorkerRunning() {
278
+ const symbols = this.ensureLoaded();
279
+ return symbols.is_worker_running() === 1;
280
+ }
281
+ getWorkerStatus() {
282
+ const symbols = this.ensureLoaded();
283
+ const result = symbols.get_worker_status();
284
+ const jsonStr = this.fromCString(result);
285
+ if (result !== null) symbols.free_rust_string(result);
286
+ const parsed = this.parseJson(jsonStr);
287
+ return parsed ?? { success: false, running: false };
288
+ }
289
+ stopWorker() {
290
+ const symbols = this.ensureLoaded();
291
+ const result = symbols.stop_worker();
292
+ const jsonStr = this.fromCString(result);
293
+ if (result !== null) symbols.free_rust_string(result);
294
+ const parsed = this.parseJson(jsonStr);
295
+ return parsed ?? {
296
+ success: false,
297
+ status: "error",
298
+ message: "Failed to parse stop result",
299
+ error: "Invalid JSON response"
300
+ };
301
+ }
302
+ transitionToGracefulShutdown() {
303
+ const symbols = this.ensureLoaded();
304
+ const result = symbols.transition_to_graceful_shutdown();
305
+ const jsonStr = this.fromCString(result);
306
+ if (result !== null) symbols.free_rust_string(result);
307
+ const parsed = this.parseJson(jsonStr);
308
+ return parsed ?? {
309
+ success: false,
310
+ status: "error",
311
+ message: "Failed to parse shutdown result",
312
+ error: "Invalid JSON response"
313
+ };
314
+ }
315
+ pollStepEvents() {
316
+ const symbols = this.ensureLoaded();
317
+ const result = symbols.poll_step_events();
318
+ if (result === null || Deno.UnsafePointer.equals(result, null)) {
319
+ return null;
754
320
  }
755
- function unlink_recursive(path3) {
321
+ const jsonStr = this.fromCString(result);
322
+ symbols.free_rust_string(result);
323
+ return this.parseJson(jsonStr);
324
+ }
325
+ pollInProcessEvents() {
326
+ const symbols = this.ensureLoaded();
327
+ const result = symbols.poll_in_process_events();
328
+ if (result === null || Deno.UnsafePointer.equals(result, null)) {
329
+ return null;
330
+ }
331
+ const jsonStr = this.fromCString(result);
332
+ symbols.free_rust_string(result);
333
+ return this.parseJson(jsonStr);
334
+ }
335
+ completeStepEvent(eventId, result) {
336
+ const symbols = this.ensureLoaded();
337
+ const eventIdBuf = this.toCString(eventId);
338
+ const resultJsonBuf = this.toCString(this.toJson(result));
339
+ return symbols.complete_step_event(eventIdBuf, resultJsonBuf) === 1;
340
+ }
341
+ checkpointYieldStepEvent(eventId, checkpointData) {
342
+ const symbols = this.ensureLoaded();
343
+ const eventIdBuf = this.toCString(eventId);
344
+ const checkpointJsonBuf = this.toCString(this.toJson(checkpointData));
345
+ return symbols.checkpoint_yield_step_event(eventIdBuf, checkpointJsonBuf) === 1;
346
+ }
347
+ getFfiDispatchMetrics() {
348
+ const symbols = this.ensureLoaded();
349
+ const result = symbols.get_ffi_dispatch_metrics();
350
+ const jsonStr = this.fromCString(result);
351
+ if (result !== null) symbols.free_rust_string(result);
352
+ const parsed = this.parseJson(jsonStr);
353
+ if (parsed && typeof parsed.pending_count === "number") {
354
+ return parsed;
355
+ }
356
+ return {
357
+ pending_count: 0,
358
+ starvation_detected: false,
359
+ starving_event_count: 0,
360
+ oldest_pending_age_ms: null,
361
+ newest_pending_age_ms: null,
362
+ oldest_event_id: null
363
+ };
364
+ }
365
+ checkStarvationWarnings() {
366
+ const symbols = this.ensureLoaded();
367
+ symbols.check_starvation_warnings();
368
+ }
369
+ cleanupTimeouts() {
370
+ const symbols = this.ensureLoaded();
371
+ symbols.cleanup_timeouts();
372
+ }
373
+ logError(message, fields) {
374
+ const symbols = this.ensureLoaded();
375
+ const msgBuf = this.toCString(message);
376
+ const fieldsBuf = fields ? this.toCString(this.toJson(fields)) : null;
377
+ symbols.log_error(msgBuf, fieldsBuf);
378
+ }
379
+ logWarn(message, fields) {
380
+ const symbols = this.ensureLoaded();
381
+ const msgBuf = this.toCString(message);
382
+ const fieldsBuf = fields ? this.toCString(this.toJson(fields)) : null;
383
+ symbols.log_warn(msgBuf, fieldsBuf);
384
+ }
385
+ logInfo(message, fields) {
386
+ const symbols = this.ensureLoaded();
387
+ const msgBuf = this.toCString(message);
388
+ const fieldsBuf = fields ? this.toCString(this.toJson(fields)) : null;
389
+ symbols.log_info(msgBuf, fieldsBuf);
390
+ }
391
+ logDebug(message, fields) {
392
+ const symbols = this.ensureLoaded();
393
+ const msgBuf = this.toCString(message);
394
+ const fieldsBuf = fields ? this.toCString(this.toJson(fields)) : null;
395
+ symbols.log_debug(msgBuf, fieldsBuf);
396
+ }
397
+ logTrace(message, fields) {
398
+ const symbols = this.ensureLoaded();
399
+ const msgBuf = this.toCString(message);
400
+ const fieldsBuf = fields ? this.toCString(this.toJson(fields)) : null;
401
+ symbols.log_trace(msgBuf, fieldsBuf);
402
+ }
403
+ // ==========================================================================
404
+ // Client API Operations (TAS-231)
405
+ // ==========================================================================
406
+ parseClientResult(result) {
407
+ const jsonStr = this.fromCString(result);
408
+ if (result !== null) this.ensureLoaded().free_rust_string(result);
409
+ const parsed = this.parseJson(jsonStr);
410
+ return parsed ?? {
411
+ success: false,
412
+ data: null,
413
+ error: "Failed to parse client result",
414
+ recoverable: null
415
+ };
416
+ }
417
+ clientCreateTask(requestJson) {
418
+ const symbols = this.ensureLoaded();
419
+ const buf = this.toCString(requestJson);
420
+ const result = symbols.client_create_task(buf);
421
+ return this.parseClientResult(result);
422
+ }
423
+ clientGetTask(taskUuid) {
424
+ const symbols = this.ensureLoaded();
425
+ const buf = this.toCString(taskUuid);
426
+ const result = symbols.client_get_task(buf);
427
+ return this.parseClientResult(result);
428
+ }
429
+ clientListTasks(paramsJson) {
430
+ const symbols = this.ensureLoaded();
431
+ const buf = this.toCString(paramsJson);
432
+ const result = symbols.client_list_tasks(buf);
433
+ return this.parseClientResult(result);
434
+ }
435
+ clientCancelTask(taskUuid) {
436
+ const symbols = this.ensureLoaded();
437
+ const buf = this.toCString(taskUuid);
438
+ const result = symbols.client_cancel_task(buf);
439
+ return this.parseClientResult(result);
440
+ }
441
+ clientListTaskSteps(taskUuid) {
442
+ const symbols = this.ensureLoaded();
443
+ const buf = this.toCString(taskUuid);
444
+ const result = symbols.client_list_task_steps(buf);
445
+ return this.parseClientResult(result);
446
+ }
447
+ clientGetStep(taskUuid, stepUuid) {
448
+ const symbols = this.ensureLoaded();
449
+ const tBuf = this.toCString(taskUuid);
450
+ const sBuf = this.toCString(stepUuid);
451
+ const result = symbols.client_get_step(tBuf, sBuf);
452
+ return this.parseClientResult(result);
453
+ }
454
+ clientGetStepAuditHistory(taskUuid, stepUuid) {
455
+ const symbols = this.ensureLoaded();
456
+ const tBuf = this.toCString(taskUuid);
457
+ const sBuf = this.toCString(stepUuid);
458
+ const result = symbols.client_get_step_audit_history(tBuf, sBuf);
459
+ return this.parseClientResult(result);
460
+ }
461
+ clientHealthCheck() {
462
+ const symbols = this.ensureLoaded();
463
+ const result = symbols.client_health_check();
464
+ return this.parseClientResult(result);
465
+ }
466
+ };
467
+ }
468
+ });
469
+
470
+ // node_modules/koffi/build/koffi/darwin_arm64/koffi.node
471
+ var koffi_default;
472
+ var init_koffi = __esm({
473
+ "node_modules/koffi/build/koffi/darwin_arm64/koffi.node"() {
474
+ koffi_default = "./koffi-X7JMBSZH.node";
475
+ }
476
+ });
477
+
478
+ // node-file:/home/runner/work/tasker-core/tasker-core/workers/typescript/node_modules/koffi/build/koffi/darwin_arm64/koffi.node
479
+ var require_koffi = __commonJS2({
480
+ "node-file:/home/runner/work/tasker-core/tasker-core/workers/typescript/node_modules/koffi/build/koffi/darwin_arm64/koffi.node"(exports2, module2) {
481
+ init_koffi();
482
+ try {
483
+ module2.exports = __require(koffi_default);
484
+ } catch {
485
+ }
486
+ }
487
+ });
488
+
489
+ // node_modules/koffi/build/koffi/darwin_x64/koffi.node
490
+ var koffi_default2;
491
+ var init_koffi2 = __esm({
492
+ "node_modules/koffi/build/koffi/darwin_x64/koffi.node"() {
493
+ koffi_default2 = "./koffi-OMHWL3D6.node";
494
+ }
495
+ });
496
+
497
+ // node-file:/home/runner/work/tasker-core/tasker-core/workers/typescript/node_modules/koffi/build/koffi/darwin_x64/koffi.node
498
+ var require_koffi2 = __commonJS2({
499
+ "node-file:/home/runner/work/tasker-core/tasker-core/workers/typescript/node_modules/koffi/build/koffi/darwin_x64/koffi.node"(exports2, module2) {
500
+ init_koffi2();
501
+ try {
502
+ module2.exports = __require(koffi_default2);
503
+ } catch {
504
+ }
505
+ }
506
+ });
507
+
508
+ // node_modules/koffi/build/koffi/freebsd_arm64/koffi.node
509
+ var koffi_default3;
510
+ var init_koffi3 = __esm({
511
+ "node_modules/koffi/build/koffi/freebsd_arm64/koffi.node"() {
512
+ koffi_default3 = "./koffi-AVDVVSXH.node";
513
+ }
514
+ });
515
+
516
+ // node-file:/home/runner/work/tasker-core/tasker-core/workers/typescript/node_modules/koffi/build/koffi/freebsd_arm64/koffi.node
517
+ var require_koffi3 = __commonJS2({
518
+ "node-file:/home/runner/work/tasker-core/tasker-core/workers/typescript/node_modules/koffi/build/koffi/freebsd_arm64/koffi.node"(exports2, module2) {
519
+ init_koffi3();
520
+ try {
521
+ module2.exports = __require(koffi_default3);
522
+ } catch {
523
+ }
524
+ }
525
+ });
526
+
527
+ // node_modules/koffi/build/koffi/freebsd_ia32/koffi.node
528
+ var koffi_default4;
529
+ var init_koffi4 = __esm({
530
+ "node_modules/koffi/build/koffi/freebsd_ia32/koffi.node"() {
531
+ koffi_default4 = "./koffi-GG4SDSYA.node";
532
+ }
533
+ });
534
+
535
+ // node-file:/home/runner/work/tasker-core/tasker-core/workers/typescript/node_modules/koffi/build/koffi/freebsd_ia32/koffi.node
536
+ var require_koffi4 = __commonJS2({
537
+ "node-file:/home/runner/work/tasker-core/tasker-core/workers/typescript/node_modules/koffi/build/koffi/freebsd_ia32/koffi.node"(exports2, module2) {
538
+ init_koffi4();
539
+ try {
540
+ module2.exports = __require(koffi_default4);
541
+ } catch {
542
+ }
543
+ }
544
+ });
545
+
546
+ // node_modules/koffi/build/koffi/freebsd_x64/koffi.node
547
+ var koffi_default5;
548
+ var init_koffi5 = __esm({
549
+ "node_modules/koffi/build/koffi/freebsd_x64/koffi.node"() {
550
+ koffi_default5 = "./koffi-AHHUCM3C.node";
551
+ }
552
+ });
553
+
554
+ // node-file:/home/runner/work/tasker-core/tasker-core/workers/typescript/node_modules/koffi/build/koffi/freebsd_x64/koffi.node
555
+ var require_koffi5 = __commonJS2({
556
+ "node-file:/home/runner/work/tasker-core/tasker-core/workers/typescript/node_modules/koffi/build/koffi/freebsd_x64/koffi.node"(exports2, module2) {
557
+ init_koffi5();
558
+ try {
559
+ module2.exports = __require(koffi_default5);
560
+ } catch {
561
+ }
562
+ }
563
+ });
564
+
565
+ // node_modules/koffi/build/koffi/linux_armhf/koffi.node
566
+ var koffi_default6;
567
+ var init_koffi6 = __esm({
568
+ "node_modules/koffi/build/koffi/linux_armhf/koffi.node"() {
569
+ koffi_default6 = "./koffi-YNQDUF3Q.node";
570
+ }
571
+ });
572
+
573
+ // node-file:/home/runner/work/tasker-core/tasker-core/workers/typescript/node_modules/koffi/build/koffi/linux_armhf/koffi.node
574
+ var require_koffi6 = __commonJS2({
575
+ "node-file:/home/runner/work/tasker-core/tasker-core/workers/typescript/node_modules/koffi/build/koffi/linux_armhf/koffi.node"(exports2, module2) {
576
+ init_koffi6();
577
+ try {
578
+ module2.exports = __require(koffi_default6);
579
+ } catch {
580
+ }
581
+ }
582
+ });
583
+
584
+ // node_modules/koffi/build/koffi/linux_arm64/koffi.node
585
+ var koffi_default7;
586
+ var init_koffi7 = __esm({
587
+ "node_modules/koffi/build/koffi/linux_arm64/koffi.node"() {
588
+ koffi_default7 = "./koffi-SE4ZI36U.node";
589
+ }
590
+ });
591
+
592
+ // node-file:/home/runner/work/tasker-core/tasker-core/workers/typescript/node_modules/koffi/build/koffi/linux_arm64/koffi.node
593
+ var require_koffi7 = __commonJS2({
594
+ "node-file:/home/runner/work/tasker-core/tasker-core/workers/typescript/node_modules/koffi/build/koffi/linux_arm64/koffi.node"(exports2, module2) {
595
+ init_koffi7();
596
+ try {
597
+ module2.exports = __require(koffi_default7);
598
+ } catch {
599
+ }
600
+ }
601
+ });
602
+
603
+ // node_modules/koffi/build/koffi/linux_ia32/koffi.node
604
+ var koffi_default8;
605
+ var init_koffi8 = __esm({
606
+ "node_modules/koffi/build/koffi/linux_ia32/koffi.node"() {
607
+ koffi_default8 = "./koffi-LOH6WKRQ.node";
608
+ }
609
+ });
610
+
611
+ // node-file:/home/runner/work/tasker-core/tasker-core/workers/typescript/node_modules/koffi/build/koffi/linux_ia32/koffi.node
612
+ var require_koffi8 = __commonJS2({
613
+ "node-file:/home/runner/work/tasker-core/tasker-core/workers/typescript/node_modules/koffi/build/koffi/linux_ia32/koffi.node"(exports2, module2) {
614
+ init_koffi8();
615
+ try {
616
+ module2.exports = __require(koffi_default8);
617
+ } catch {
618
+ }
619
+ }
620
+ });
621
+
622
+ // node_modules/koffi/build/koffi/linux_loong64/koffi.node
623
+ var koffi_default9;
624
+ var init_koffi9 = __esm({
625
+ "node_modules/koffi/build/koffi/linux_loong64/koffi.node"() {
626
+ koffi_default9 = "./koffi-QKY2KSXW.node";
627
+ }
628
+ });
629
+
630
+ // node-file:/home/runner/work/tasker-core/tasker-core/workers/typescript/node_modules/koffi/build/koffi/linux_loong64/koffi.node
631
+ var require_koffi9 = __commonJS2({
632
+ "node-file:/home/runner/work/tasker-core/tasker-core/workers/typescript/node_modules/koffi/build/koffi/linux_loong64/koffi.node"(exports2, module2) {
633
+ init_koffi9();
634
+ try {
635
+ module2.exports = __require(koffi_default9);
636
+ } catch {
637
+ }
638
+ }
639
+ });
640
+
641
+ // node_modules/koffi/build/koffi/linux_riscv64d/koffi.node
642
+ var koffi_default10;
643
+ var init_koffi10 = __esm({
644
+ "node_modules/koffi/build/koffi/linux_riscv64d/koffi.node"() {
645
+ koffi_default10 = "./koffi-X3YT67KE.node";
646
+ }
647
+ });
648
+
649
+ // node-file:/home/runner/work/tasker-core/tasker-core/workers/typescript/node_modules/koffi/build/koffi/linux_riscv64d/koffi.node
650
+ var require_koffi10 = __commonJS2({
651
+ "node-file:/home/runner/work/tasker-core/tasker-core/workers/typescript/node_modules/koffi/build/koffi/linux_riscv64d/koffi.node"(exports2, module2) {
652
+ init_koffi10();
653
+ try {
654
+ module2.exports = __require(koffi_default10);
655
+ } catch {
656
+ }
657
+ }
658
+ });
659
+
660
+ // node_modules/koffi/build/koffi/linux_x64/koffi.node
661
+ var koffi_default11;
662
+ var init_koffi11 = __esm({
663
+ "node_modules/koffi/build/koffi/linux_x64/koffi.node"() {
664
+ koffi_default11 = "./koffi-G4D35B2D.node";
665
+ }
666
+ });
667
+
668
+ // node-file:/home/runner/work/tasker-core/tasker-core/workers/typescript/node_modules/koffi/build/koffi/linux_x64/koffi.node
669
+ var require_koffi11 = __commonJS2({
670
+ "node-file:/home/runner/work/tasker-core/tasker-core/workers/typescript/node_modules/koffi/build/koffi/linux_x64/koffi.node"(exports2, module2) {
671
+ init_koffi11();
672
+ try {
673
+ module2.exports = __require(koffi_default11);
674
+ } catch {
675
+ }
676
+ }
677
+ });
678
+
679
+ // node_modules/koffi/build/koffi/openbsd_ia32/koffi.node
680
+ var koffi_default12;
681
+ var init_koffi12 = __esm({
682
+ "node_modules/koffi/build/koffi/openbsd_ia32/koffi.node"() {
683
+ koffi_default12 = "./koffi-LUY2JHJP.node";
684
+ }
685
+ });
686
+
687
+ // node-file:/home/runner/work/tasker-core/tasker-core/workers/typescript/node_modules/koffi/build/koffi/openbsd_ia32/koffi.node
688
+ var require_koffi12 = __commonJS2({
689
+ "node-file:/home/runner/work/tasker-core/tasker-core/workers/typescript/node_modules/koffi/build/koffi/openbsd_ia32/koffi.node"(exports2, module2) {
690
+ init_koffi12();
691
+ try {
692
+ module2.exports = __require(koffi_default12);
693
+ } catch {
694
+ }
695
+ }
696
+ });
697
+
698
+ // node_modules/koffi/build/koffi/openbsd_x64/koffi.node
699
+ var koffi_default13;
700
+ var init_koffi13 = __esm({
701
+ "node_modules/koffi/build/koffi/openbsd_x64/koffi.node"() {
702
+ koffi_default13 = "./koffi-ROB3FRHA.node";
703
+ }
704
+ });
705
+
706
+ // node-file:/home/runner/work/tasker-core/tasker-core/workers/typescript/node_modules/koffi/build/koffi/openbsd_x64/koffi.node
707
+ var require_koffi13 = __commonJS2({
708
+ "node-file:/home/runner/work/tasker-core/tasker-core/workers/typescript/node_modules/koffi/build/koffi/openbsd_x64/koffi.node"(exports2, module2) {
709
+ init_koffi13();
710
+ try {
711
+ module2.exports = __require(koffi_default13);
712
+ } catch {
713
+ }
714
+ }
715
+ });
716
+
717
+ // node_modules/koffi/build/koffi/win32_arm64/koffi.node
718
+ var koffi_default14;
719
+ var init_koffi14 = __esm({
720
+ "node_modules/koffi/build/koffi/win32_arm64/koffi.node"() {
721
+ koffi_default14 = "./koffi-GOENU54R.node";
722
+ }
723
+ });
724
+
725
+ // node-file:/home/runner/work/tasker-core/tasker-core/workers/typescript/node_modules/koffi/build/koffi/win32_arm64/koffi.node
726
+ var require_koffi14 = __commonJS2({
727
+ "node-file:/home/runner/work/tasker-core/tasker-core/workers/typescript/node_modules/koffi/build/koffi/win32_arm64/koffi.node"(exports2, module2) {
728
+ init_koffi14();
729
+ try {
730
+ module2.exports = __require(koffi_default14);
731
+ } catch {
732
+ }
733
+ }
734
+ });
735
+
736
+ // node_modules/koffi/build/koffi/win32_ia32/koffi.node
737
+ var koffi_default15;
738
+ var init_koffi15 = __esm({
739
+ "node_modules/koffi/build/koffi/win32_ia32/koffi.node"() {
740
+ koffi_default15 = "./koffi-KFZAXWPQ.node";
741
+ }
742
+ });
743
+
744
+ // node-file:/home/runner/work/tasker-core/tasker-core/workers/typescript/node_modules/koffi/build/koffi/win32_ia32/koffi.node
745
+ var require_koffi15 = __commonJS2({
746
+ "node-file:/home/runner/work/tasker-core/tasker-core/workers/typescript/node_modules/koffi/build/koffi/win32_ia32/koffi.node"(exports2, module2) {
747
+ init_koffi15();
748
+ try {
749
+ module2.exports = __require(koffi_default15);
750
+ } catch {
751
+ }
752
+ }
753
+ });
754
+
755
+ // node_modules/koffi/build/koffi/win32_x64/koffi.node
756
+ var koffi_default16;
757
+ var init_koffi16 = __esm({
758
+ "node_modules/koffi/build/koffi/win32_x64/koffi.node"() {
759
+ koffi_default16 = "./koffi-IDX6JEDH.node";
760
+ }
761
+ });
762
+
763
+ // node-file:/home/runner/work/tasker-core/tasker-core/workers/typescript/node_modules/koffi/build/koffi/win32_x64/koffi.node
764
+ var require_koffi16 = __commonJS2({
765
+ "node-file:/home/runner/work/tasker-core/tasker-core/workers/typescript/node_modules/koffi/build/koffi/win32_x64/koffi.node"(exports2, module2) {
766
+ init_koffi16();
767
+ try {
768
+ module2.exports = __require(koffi_default16);
769
+ } catch {
770
+ }
771
+ }
772
+ });
773
+
774
+ // node_modules/koffi/build/koffi/musl_arm64/koffi.node
775
+ var koffi_default17;
776
+ var init_koffi17 = __esm({
777
+ "node_modules/koffi/build/koffi/musl_arm64/koffi.node"() {
778
+ koffi_default17 = "./koffi-3HFAASOB.node";
779
+ }
780
+ });
781
+
782
+ // node-file:/home/runner/work/tasker-core/tasker-core/workers/typescript/node_modules/koffi/build/koffi/musl_arm64/koffi.node
783
+ var require_koffi17 = __commonJS2({
784
+ "node-file:/home/runner/work/tasker-core/tasker-core/workers/typescript/node_modules/koffi/build/koffi/musl_arm64/koffi.node"(exports2, module2) {
785
+ init_koffi17();
786
+ try {
787
+ module2.exports = __require(koffi_default17);
788
+ } catch {
789
+ }
790
+ }
791
+ });
792
+
793
+ // node_modules/koffi/build/koffi/musl_x64/koffi.node
794
+ var koffi_default18;
795
+ var init_koffi18 = __esm({
796
+ "node_modules/koffi/build/koffi/musl_x64/koffi.node"() {
797
+ koffi_default18 = "./koffi-BMO5K7B3.node";
798
+ }
799
+ });
800
+
801
+ // node-file:/home/runner/work/tasker-core/tasker-core/workers/typescript/node_modules/koffi/build/koffi/musl_x64/koffi.node
802
+ var require_koffi18 = __commonJS2({
803
+ "node-file:/home/runner/work/tasker-core/tasker-core/workers/typescript/node_modules/koffi/build/koffi/musl_x64/koffi.node"(exports2, module2) {
804
+ init_koffi18();
805
+ try {
806
+ module2.exports = __require(koffi_default18);
807
+ } catch {
808
+ }
809
+ }
810
+ });
811
+
812
+ // node_modules/koffi/index.js
813
+ var require_koffi19 = __commonJS2({
814
+ "node_modules/koffi/index.js"(exports$1, module) {
815
+ var __getOwnPropNames = Object.getOwnPropertyNames;
816
+ var __commonJS = (cb, mod3) => function __require2() {
817
+ return mod3 || (0, cb[__getOwnPropNames(cb)[0]])((mod3 = { exports: {} }).exports, mod3), mod3.exports;
818
+ };
819
+ var require_tools = __commonJS({
820
+ "bin/Koffi/package/src/cnoke/src/tools.js"(exports2, module2) {
821
+ var crypto2 = __require("crypto");
822
+ var fs2 = __require("fs");
823
+ var http = __require("https");
824
+ var path2 = __require("path");
825
+ var zlib = __require("zlib");
826
+ async function download_http(url, dest) {
827
+ console.log(">> Downloading " + url);
828
+ let [tmp_name, file] = open_temporary_stream(dest);
756
829
  try {
757
- if (fs2.rmSync != null) {
758
- fs2.rmSync(path3, { recursive: true, maxRetries: process.platform == "win32" ? 3 : 0 });
759
- } else {
760
- fs2.rmdirSync(path3, { recursive: true, maxRetries: process.platform == "win32" ? 3 : 0 });
761
- }
830
+ await new Promise((resolve, reject) => {
831
+ let request = http.get(url, (response) => {
832
+ if (response.statusCode != 200) {
833
+ let err = new Error(`Download failed: ${response.statusMessage} [${response.statusCode}]`);
834
+ err.code = response.statusCode;
835
+ reject(err);
836
+ return;
837
+ }
838
+ response.pipe(file);
839
+ file.on("finish", () => file.close(() => {
840
+ try {
841
+ fs2.renameSync(file.path, dest);
842
+ } catch (err) {
843
+ if (!fs2.existsSync(dest))
844
+ reject(err);
845
+ }
846
+ resolve();
847
+ }));
848
+ });
849
+ request.on("error", reject);
850
+ file.on("error", reject);
851
+ });
762
852
  } catch (err) {
763
- if (err.code !== "ENOENT")
764
- throw err;
853
+ file.close();
854
+ try {
855
+ fs2.unlinkSync(tmp_name);
856
+ } catch (err2) {
857
+ if (err2.code != "ENOENT")
858
+ throw err2;
859
+ }
860
+ throw err;
765
861
  }
766
862
  }
767
- function get_napi_version2(napi, major) {
768
- if (napi > 8)
769
- return null;
770
- const support = {
771
- 6: ["6.14.2", "6.14.2", "6.14.2"],
772
- 8: ["8.6.0", "8.10.0", "8.11.2"],
773
- 9: ["9.0.0", "9.3.0", "9.11.0"],
774
- 10: ["10.0.0", "10.0.0", "10.0.0", "10.16.0", "10.17.0", "10.20.0", "10.23.0"],
775
- 11: ["11.0.0", "11.0.0", "11.0.0", "11.8.0"],
776
- 12: ["12.0.0", "12.0.0", "12.0.0", "12.0.0", "12.11.0", "12.17.0", "12.19.0", "12.22.0"],
777
- 13: ["13.0.0", "13.0.0", "13.0.0", "13.0.0", "13.0.0"],
778
- 14: ["14.0.0", "14.0.0", "14.0.0", "14.0.0", "14.0.0", "14.0.0", "14.12.0", "14.17.0"],
779
- 15: ["15.0.0", "15.0.0", "15.0.0", "15.0.0", "15.0.0", "15.0.0", "15.0.0", "15.12.0"]
780
- };
781
- const max = Math.max(...Object.keys(support).map((k) => parseInt(k, 10)));
782
- if (major > max)
783
- return major + ".0.0";
784
- if (support[major] == null)
785
- return null;
786
- let required = support[major][napi - 1] || null;
787
- return required;
788
- }
789
- function cmp_version(ver1, ver2) {
790
- ver1 = String(ver1).replace(/-.*$/, "").split(".").reduce((acc, v, idx) => acc + parseInt(v, 10) * Math.pow(10, 2 * (5 - idx)), 0);
791
- ver2 = String(ver2).replace(/-.*$/, "").split(".").reduce((acc, v, idx) => acc + parseInt(v, 10) * Math.pow(10, 2 * (5 - idx)), 0);
792
- let cmp = Math.min(Math.max(ver1 - ver2, -1), 1);
793
- return cmp;
794
- }
795
- module2.exports = {
796
- download_http,
797
- extract_targz,
798
- path_is_absolute,
799
- path_has_dotdot,
800
- sync_files,
801
- determine_arch: determine_arch2,
802
- unlink_recursive,
803
- get_napi_version: get_napi_version2,
804
- cmp_version
805
- };
806
- }
807
- });
808
- var require_package = __commonJS({
809
- "bin/Koffi/package/src/koffi/package.json"(exports2, module2) {
810
- module2.exports = {
811
- name: "koffi",
812
- version: "2.15.0",
813
- description: "Fast and simple C FFI (foreign function interface) for Node.js",
814
- keywords: [
815
- "foreign",
816
- "function",
817
- "interface",
818
- "ffi",
819
- "binding",
820
- "c",
821
- "napi"
822
- ],
823
- repository: {
824
- type: "git",
825
- url: "https://github.com/Koromix/koffi"
826
- },
827
- homepage: "https://koffi.dev/",
828
- author: {
829
- name: "Niels Martign\xE8ne",
830
- email: "niels.martignene@protonmail.com",
831
- url: "https://koromix.dev/"
832
- },
833
- main: "./index.js",
834
- types: "./index.d.ts",
835
- scripts: {
836
- test: "node tools/koffi.js test",
837
- prepack: `echo 'Use "npm run package" instead' && false`,
838
- prepublishOnly: `echo 'Use "npm run package" instead' && false`,
839
- package: "node tools/koffi.js build"
840
- },
841
- license: "MIT",
842
- cnoke: {
843
- api: "../../vendor/node-api-headers",
844
- output: "../../bin/Koffi/{{ platform }}_{{ arch }}",
845
- node: 16,
846
- napi: 8,
847
- require: "./index.js"
848
- },
849
- funding: "https://buymeacoffee.com/koromix"
850
- };
851
- }
852
- });
853
- var require_init = __commonJS({
854
- "bin/Koffi/package/src/koffi/src/init.js"(exports$1, module) {
855
- var fs = __require("fs");
856
- var path = __require("path");
857
- var util = __require("util");
858
- var { get_napi_version, determine_arch } = require_tools();
859
- var pkg = require_package();
860
- function detect() {
861
- if (process.versions.napi == null || process.versions.napi < pkg.cnoke.napi) {
862
- let major = parseInt(process.versions.node, 10);
863
- let required = get_napi_version(pkg.cnoke.napi, major);
864
- if (required != null) {
865
- throw new Error(`This engine is based on Node ${process.versions.node}, but ${pkg.name} requires Node >= ${required} in the Node ${major}.x branch (N-API >= ${pkg.cnoke.napi})`);
866
- } else {
867
- throw new Error(`This engine is based on Node ${process.versions.node}, but ${pkg.name} does not support the Node ${major}.x branch (N-API < ${pkg.cnoke.napi})`);
863
+ function open_temporary_stream(prefix) {
864
+ let buf = Buffer.allocUnsafe(4);
865
+ for (; ; ) {
866
+ try {
867
+ crypto2.randomFillSync(buf);
868
+ let suffix = buf.toString("hex").padStart(8, "0");
869
+ let filename2 = `${prefix}.${suffix}`;
870
+ let file = fs2.createWriteStream(filename2, { flags: "wx", mode: 420 });
871
+ return [filename2, file];
872
+ } catch (err) {
873
+ if (err.code != "EEXIST")
874
+ throw err;
868
875
  }
869
876
  }
870
- let arch = determine_arch();
871
- let triplet3 = `${process.platform}_${arch}`;
872
- return triplet3;
873
877
  }
874
- function init(triplet, native) {
875
- if (native == null) {
876
- let roots = [path.join(__dirname, "..")];
877
- let triplets = [triplet];
878
- if (process.resourcesPath != null)
879
- roots.push(process.resourcesPath);
880
- if (triplet.startsWith("linux_")) {
881
- let musl = triplet.replace(/^linux_/, "musl_");
882
- triplets.push(musl);
883
- }
884
- let filenames = roots.flatMap((root) => triplets.flatMap((triplet3) => [
885
- `${root}/build/koffi/${triplet3}/koffi.node`,
886
- `${root}/koffi/${triplet3}/koffi.node`,
887
- `${root}/node_modules/koffi/build/koffi/${triplet3}/koffi.node`,
888
- `${root}/../../bin/Koffi/${triplet3}/koffi.node`
889
- ]));
890
- let first_err = null;
891
- for (let filename of filenames) {
892
- if (!fs.existsSync(filename))
893
- continue;
878
+ function extract_targz(filename2, dest_dir, strip = 0) {
879
+ let reader = fs2.createReadStream(filename2).pipe(zlib.createGunzip());
880
+ return new Promise((resolve, reject) => {
881
+ let header = null;
882
+ let extended = {};
883
+ reader.on("readable", () => {
894
884
  try {
895
- native = eval("require")(filename);
885
+ for (; ; ) {
886
+ if (header == null) {
887
+ let buf = reader.read(512);
888
+ if (buf == null)
889
+ break;
890
+ if (!buf[0])
891
+ continue;
892
+ header = {
893
+ filename: buf.toString("utf-8", 0, 100).replace(/\0/g, ""),
894
+ mode: parseInt(buf.toString("ascii", 100, 109), 8),
895
+ size: parseInt(buf.toString("ascii", 124, 137), 8),
896
+ type: String.fromCharCode(buf[156])
897
+ };
898
+ Object.assign(header, extended);
899
+ extended = {};
900
+ header.filename = header.filename.replace(/\\/g, "/");
901
+ if (!header.filename.length)
902
+ throw new Error(`Insecure empty filename inside TAR archive`);
903
+ if (path_is_absolute(header.filename[0]))
904
+ throw new Error(`Insecure filename starting with / inside TAR archive`);
905
+ if (path_has_dotdot(header.filename))
906
+ throw new Error(`Insecure filename containing '..' inside TAR archive`);
907
+ for (let i = 0; i < strip; i++)
908
+ header.filename = header.filename.substr(header.filename.indexOf("/") + 1);
909
+ }
910
+ let aligned = Math.floor((header.size + 511) / 512) * 512;
911
+ let data = header.size ? reader.read(aligned) : null;
912
+ if (data == null) {
913
+ if (header.size)
914
+ break;
915
+ data = Buffer.alloc(0);
916
+ }
917
+ data = data.subarray(0, header.size);
918
+ if (header.type == "0" || header.type == "7") {
919
+ let filename3 = dest_dir + "/" + header.filename;
920
+ let dirname2 = path2.dirname(filename3);
921
+ fs2.mkdirSync(dirname2, { recursive: true, mode: 493 });
922
+ fs2.writeFileSync(filename3, data, { mode: header.mode });
923
+ } else if (header.type == "5") {
924
+ let filename3 = dest_dir + "/" + header.filename;
925
+ fs2.mkdirSync(filename3, { recursive: true, mode: header.mode });
926
+ } else if (header.type == "L") {
927
+ extended.filename = data.toString("utf-8").replace(/\0/g, "");
928
+ } else if (header.type == "x") {
929
+ let str = data.toString("utf-8");
930
+ try {
931
+ while (str.length) {
932
+ let matches = str.match(/^([0-9]+) ([a-zA-Z0-9\._]+)=(.*)\n/);
933
+ let skip = parseInt(matches[1], 10);
934
+ let key = matches[2];
935
+ let value = matches[3];
936
+ switch (key) {
937
+ case "path":
938
+ {
939
+ extended.filename = value;
940
+ }
941
+ break;
942
+ case "size":
943
+ {
944
+ extended.size = parseInt(value, 10);
945
+ }
946
+ break;
947
+ }
948
+ str = str.substr(skip).trimStart();
949
+ }
950
+ } catch (err) {
951
+ throw new Error("Malformed PAX entry");
952
+ }
953
+ }
954
+ header = null;
955
+ }
896
956
  } catch (err) {
897
- if (first_err == null)
898
- first_err = err;
899
- continue;
957
+ reject(err);
900
958
  }
959
+ });
960
+ reader.on("error", reject);
961
+ reader.on("end", resolve);
962
+ });
963
+ }
964
+ function path_is_absolute(path3) {
965
+ if (process.platform == "win32" && path3.match(/^[a-zA-Z]:/))
966
+ path3 = path3.substr(2);
967
+ return is_path_separator(path3[0]);
968
+ }
969
+ function path_has_dotdot(path3) {
970
+ let start = 0;
971
+ for (; ; ) {
972
+ let offset = path3.indexOf("..", start);
973
+ if (offset < 0)
901
974
  break;
902
- }
903
- if (first_err != null)
904
- throw first_err;
975
+ start = offset + 2;
976
+ if (offset && !is_path_separator(path3[offset - 1]))
977
+ continue;
978
+ if (offset + 2 < path3.length && !is_path_separator(path3[offset + 2]))
979
+ continue;
980
+ return true;
905
981
  }
906
- if (native == null)
907
- throw new Error("Cannot find the native Koffi module; did you bundle it correctly?");
908
- if (native.version != pkg.version)
909
- throw new Error("Mismatched native Koffi modules");
910
- let mod = wrap(native);
911
- return mod;
982
+ return false;
912
983
  }
913
- function wrap(native3) {
914
- let obj = {
915
- ...native3,
916
- // Deprecated functions
917
- handle: util.deprecate(native3.opaque, "The koffi.handle() function was deprecated in Koffi 2.1, use koffi.opaque() instead", "KOFFI001"),
918
- callback: util.deprecate(native3.proto, "The koffi.callback() function was deprecated in Koffi 2.4, use koffi.proto() instead", "KOFFI002")
919
- };
920
- obj.load = (...args) => {
921
- let lib = native3.load(...args);
922
- lib.cdecl = util.deprecate((...args2) => lib.func("__cdecl", ...args2), "The koffi.cdecl() function was deprecated in Koffi 2.7, use koffi.func(...) instead", "KOFFI003");
923
- lib.stdcall = util.deprecate((...args2) => lib.func("__stdcall", ...args2), 'The koffi.stdcall() function was deprecated in Koffi 2.7, use koffi.func("__stdcall", ...) instead', "KOFFI004");
924
- lib.fastcall = util.deprecate((...args2) => lib.func("__fastcall", ...args2), 'The koffi.fastcall() function was deprecated in Koffi 2.7, use koffi.func("__fastcall", ...) instead', "KOFFI005");
925
- lib.thiscall = util.deprecate((...args2) => lib.func("__thiscall", ...args2), 'The koffi.thiscall() function was deprecated in Koffi 2.7, use koffi.func("__thiscall", ...) instead', "KOFFI006");
926
- return lib;
927
- };
928
- return obj;
984
+ function is_path_separator(c) {
985
+ if (c == "/")
986
+ return true;
987
+ if (process.platform == "win32" && c == "\\")
988
+ return true;
989
+ return false;
929
990
  }
930
- module.exports = {
931
- detect,
932
- init
933
- };
934
- }
935
- });
936
- var { detect: detect2, init: init2 } = require_init();
937
- var triplet2 = detect2();
938
- var native2 = null;
939
- try {
940
- switch (triplet2) {
941
- case "darwin_arm64":
942
- {
943
- native2 = require_koffi();
944
- }
945
- break;
946
- case "darwin_x64":
947
- {
948
- native2 = require_koffi2();
949
- }
950
- break;
951
- case "freebsd_arm64":
952
- {
953
- native2 = require_koffi3();
954
- }
955
- break;
956
- case "freebsd_ia32":
957
- {
958
- native2 = require_koffi4();
959
- }
960
- break;
961
- case "freebsd_x64":
962
- {
963
- native2 = require_koffi5();
964
- }
965
- break;
966
- case "linux_armhf":
967
- {
968
- native2 = require_koffi6();
969
- }
970
- break;
971
- case "linux_arm64":
972
- {
973
- native2 = require_koffi7();
974
- }
975
- break;
976
- case "linux_ia32":
977
- {
978
- native2 = require_koffi8();
979
- }
980
- break;
981
- case "linux_loong64":
982
- {
983
- native2 = require_koffi9();
984
- }
985
- break;
986
- case "linux_riscv64d":
987
- {
988
- native2 = require_koffi10();
989
- }
990
- break;
991
- case "linux_x64":
991
+ function sync_files(src_dir, dest_dir) {
992
+ let keep = /* @__PURE__ */ new Set();
992
993
  {
993
- native2 = require_koffi11();
994
+ let entries = fs2.readdirSync(src_dir, { withFileTypes: true });
995
+ for (let entry of entries) {
996
+ if (!entry.isFile())
997
+ continue;
998
+ keep.add(entry.name);
999
+ fs2.copyFileSync(src_dir + `/${entry.name}`, dest_dir + `/${entry.name}`);
1000
+ }
994
1001
  }
995
- break;
996
- case "openbsd_ia32":
997
1002
  {
998
- native2 = require_koffi12();
1003
+ let entries = fs2.readdirSync(dest_dir, { withFileTypes: true });
1004
+ for (let entry of entries) {
1005
+ if (!entry.isFile())
1006
+ continue;
1007
+ if (keep.has(entry.name))
1008
+ continue;
1009
+ fs2.unlinkSync(dest_dir + `/${entry.name}`);
1010
+ }
999
1011
  }
1000
- break;
1001
- case "openbsd_x64":
1002
- {
1003
- native2 = require_koffi13();
1012
+ }
1013
+ function determine_arch2() {
1014
+ let arch = process.arch;
1015
+ if (arch == "riscv32" || arch == "riscv64") {
1016
+ let buf = read_file_header(process.execPath, 512);
1017
+ let header = decode_elf_header(buf);
1018
+ let float_abi = header.e_flags & 6;
1019
+ switch (float_abi) {
1020
+ case 0:
1021
+ break;
1022
+ case 2:
1023
+ {
1024
+ arch += "f";
1025
+ }
1026
+ break;
1027
+ case 4:
1028
+ {
1029
+ arch += "d";
1030
+ }
1031
+ break;
1032
+ case 6:
1033
+ {
1034
+ arch += "q";
1035
+ }
1036
+ break;
1037
+ }
1038
+ } else if (arch == "arm") {
1039
+ let buf = read_file_header(process.execPath, 512);
1040
+ let header = decode_elf_header(buf);
1041
+ if (header.e_flags & 1024) {
1042
+ arch += "hf";
1043
+ } else if (header.e_flags & 512) {
1044
+ arch += "sf";
1045
+ } else {
1046
+ throw new Error("Unknown ARM floating-point ABI");
1047
+ }
1004
1048
  }
1005
- break;
1006
- case "win32_arm64":
1007
- {
1008
- native2 = require_koffi14();
1049
+ return arch;
1050
+ }
1051
+ function read_file_header(filename2, read) {
1052
+ try {
1053
+ let fd2 = fs2.openSync(filename2);
1054
+ let buf = Buffer.allocUnsafe(read);
1055
+ let len = fs2.readSync(fd2, buf);
1056
+ return buf.subarray(0, len);
1057
+ } finally {
1009
1058
  }
1010
- break;
1011
- case "win32_ia32":
1012
- {
1013
- native2 = require_koffi15();
1059
+ }
1060
+ function decode_elf_header(buf) {
1061
+ let header = {};
1062
+ if (buf.length < 16)
1063
+ throw new Error("Truncated header");
1064
+ if (buf[0] != 127 || buf[1] != 69 || buf[2] != 76 || buf[3] != 70)
1065
+ throw new Error("Invalid magic number");
1066
+ if (buf[6] != 1)
1067
+ throw new Error("Invalid ELF version");
1068
+ if (buf[5] != 1)
1069
+ throw new Error("Big-endian architectures are not supported");
1070
+ let machine = buf.readUInt16LE(18);
1071
+ switch (machine) {
1072
+ case 3:
1073
+ {
1074
+ header.e_machine = "ia32";
1075
+ }
1076
+ break;
1077
+ case 40:
1078
+ {
1079
+ header.e_machine = "arm";
1080
+ }
1081
+ break;
1082
+ case 62:
1083
+ {
1084
+ header.e_machine = "amd64";
1085
+ }
1086
+ break;
1087
+ case 183:
1088
+ {
1089
+ header.e_machine = "arm64";
1090
+ }
1091
+ break;
1092
+ case 243:
1093
+ {
1094
+ switch (buf[4]) {
1095
+ case 1:
1096
+ {
1097
+ header.e_machine = "riscv32";
1098
+ }
1099
+ break;
1100
+ case 2:
1101
+ {
1102
+ header.e_machine = "riscv64";
1103
+ }
1104
+ break;
1105
+ }
1106
+ }
1107
+ break;
1108
+ case 248:
1109
+ {
1110
+ switch (buf[4]) {
1111
+ case 1:
1112
+ {
1113
+ header.e_machine = "loong32";
1114
+ }
1115
+ break;
1116
+ case 2:
1117
+ {
1118
+ header.e_machine = "loong64";
1119
+ }
1120
+ break;
1121
+ }
1122
+ }
1123
+ break;
1124
+ default:
1125
+ throw new Error("Unknown ELF machine type");
1014
1126
  }
1015
- break;
1016
- case "win32_x64":
1017
- {
1018
- native2 = require_koffi16();
1127
+ switch (buf[4]) {
1128
+ case 1:
1129
+ {
1130
+ buf = buf.subarray(0, 68);
1131
+ if (buf.length < 68)
1132
+ throw new Error("Truncated ELF header");
1133
+ header.ei_class = 32;
1134
+ header.e_flags = buf.readUInt32LE(36);
1135
+ }
1136
+ break;
1137
+ case 2:
1138
+ {
1139
+ buf = buf.subarray(0, 120);
1140
+ if (buf.length < 120)
1141
+ throw new Error("Truncated ELF header");
1142
+ header.ei_class = 64;
1143
+ header.e_flags = buf.readUInt32LE(48);
1144
+ }
1145
+ break;
1146
+ default:
1147
+ throw new Error("Invalid ELF class");
1019
1148
  }
1020
- break;
1021
- }
1022
- } catch {
1023
- try {
1024
- switch (triplet2) {
1025
- case "linux_arm64":
1026
- {
1027
- native2 = require_koffi17();
1028
- }
1029
- break;
1030
- case "linux_x64":
1031
- {
1032
- native2 = require_koffi18();
1033
- }
1034
- break;
1035
- }
1036
- } catch {
1037
- }
1038
- }
1039
- var mod2 = init2(triplet2, native2);
1040
- module.exports = mod2;
1041
- }
1042
- });
1043
-
1044
- // src/ffi/node-runtime.ts
1045
- var node_runtime_exports = {};
1046
- __export(node_runtime_exports, {
1047
- NodeRuntime: () => NodeRuntime
1048
- });
1049
- var NodeRuntime;
1050
- var init_node_runtime = __esm({
1051
- "src/ffi/node-runtime.ts"() {
1052
- init_runtime_interface();
1053
- NodeRuntime = class extends BaseTaskerRuntime {
1054
- name = "node";
1055
- lib = null;
1056
- // biome-ignore lint/suspicious/noExplicitAny: koffi module type
1057
- koffi = null;
1058
- get isLoaded() {
1059
- return this.lib !== null;
1060
- }
1061
- async load(libraryPath) {
1062
- if (this.lib !== null) {
1063
- return;
1064
- }
1065
- const koffiModule = await Promise.resolve().then(() => __toESM(require_koffi19()));
1066
- this.koffi = koffiModule.default ?? koffiModule;
1067
- const lib = this.koffi.load(libraryPath);
1068
- this.lib = {
1069
- get_version: lib.func("void* get_version()"),
1070
- get_rust_version: lib.func("void* get_rust_version()"),
1071
- health_check: lib.func("int health_check()"),
1072
- is_worker_running: lib.func("int is_worker_running()"),
1073
- bootstrap_worker: lib.func("void* bootstrap_worker(str)"),
1074
- get_worker_status: lib.func("void* get_worker_status()"),
1075
- stop_worker: lib.func("void* stop_worker()"),
1076
- transition_to_graceful_shutdown: lib.func("void* transition_to_graceful_shutdown()"),
1077
- poll_step_events: lib.func("void* poll_step_events()"),
1078
- poll_in_process_events: lib.func("void* poll_in_process_events()"),
1079
- complete_step_event: lib.func("int complete_step_event(str, str)"),
1080
- checkpoint_yield_step_event: lib.func("int checkpoint_yield_step_event(str, str)"),
1081
- get_ffi_dispatch_metrics: lib.func("void* get_ffi_dispatch_metrics()"),
1082
- check_starvation_warnings: lib.func("void check_starvation_warnings()"),
1083
- cleanup_timeouts: lib.func("void cleanup_timeouts()"),
1084
- log_error: lib.func("void log_error(str, str)"),
1085
- log_warn: lib.func("void log_warn(str, str)"),
1086
- log_info: lib.func("void log_info(str, str)"),
1087
- log_debug: lib.func("void log_debug(str, str)"),
1088
- log_trace: lib.func("void log_trace(str, str)"),
1089
- free_rust_string: lib.func("void free_rust_string(void*)"),
1090
- // Client API functions (TAS-231)
1091
- client_create_task: lib.func("void* client_create_task(str)"),
1092
- client_get_task: lib.func("void* client_get_task(str)"),
1093
- client_list_tasks: lib.func("void* client_list_tasks(str)"),
1094
- client_cancel_task: lib.func("void* client_cancel_task(str)"),
1095
- client_list_task_steps: lib.func("void* client_list_task_steps(str)"),
1096
- client_get_step: lib.func("void* client_get_step(str, str)"),
1097
- client_get_step_audit_history: lib.func("void* client_get_step_audit_history(str, str)"),
1098
- client_health_check: lib.func("void* client_health_check()")
1099
- };
1100
- }
1101
- unload() {
1102
- this.lib = null;
1103
- this.koffi = null;
1104
- }
1105
- ensureLoaded() {
1106
- if (!this.lib) {
1107
- throw new Error("Native library not loaded. Call load() first.");
1149
+ return header;
1108
1150
  }
1109
- return this.lib;
1110
- }
1111
- /**
1112
- * Read a C string from a pointer and free the Rust-allocated memory.
1113
- *
1114
- * Uses koffi.decode with 'char' type and -1 length for null-terminated strings.
1115
- */
1116
- readAndFreeRustString(ptr) {
1117
- if (!ptr) return null;
1118
- const lib = this.ensureLoaded();
1119
- const str = this.koffi.decode(ptr, "char", -1);
1120
- lib.free_rust_string(ptr);
1121
- return str;
1122
- }
1123
- getVersion() {
1124
- const lib = this.ensureLoaded();
1125
- const ptr = lib.get_version();
1126
- return this.readAndFreeRustString(ptr) ?? "unknown";
1127
- }
1128
- getRustVersion() {
1129
- const lib = this.ensureLoaded();
1130
- const ptr = lib.get_rust_version();
1131
- return this.readAndFreeRustString(ptr) ?? "unknown";
1132
- }
1133
- healthCheck() {
1134
- const lib = this.ensureLoaded();
1135
- return lib.health_check() === 1;
1136
- }
1137
- bootstrapWorker(config) {
1138
- const lib = this.ensureLoaded();
1139
- const configJson = config ? this.toJson(config) : null;
1140
- const ptr = lib.bootstrap_worker(configJson);
1141
- const jsonStr = this.readAndFreeRustString(ptr);
1142
- const parsed = this.parseJson(jsonStr);
1143
- return parsed ?? {
1144
- success: false,
1145
- status: "error",
1146
- message: "Failed to parse bootstrap result",
1147
- error: "Invalid JSON response"
1148
- };
1149
- }
1150
- isWorkerRunning() {
1151
- const lib = this.ensureLoaded();
1152
- return lib.is_worker_running() === 1;
1153
- }
1154
- getWorkerStatus() {
1155
- const lib = this.ensureLoaded();
1156
- const ptr = lib.get_worker_status();
1157
- const jsonStr = this.readAndFreeRustString(ptr);
1158
- const parsed = this.parseJson(jsonStr);
1159
- return parsed ?? { success: false, running: false };
1160
- }
1161
- stopWorker() {
1162
- const lib = this.ensureLoaded();
1163
- const ptr = lib.stop_worker();
1164
- const jsonStr = this.readAndFreeRustString(ptr);
1165
- const parsed = this.parseJson(jsonStr);
1166
- return parsed ?? {
1167
- success: false,
1168
- status: "error",
1169
- message: "Failed to parse stop result",
1170
- error: "Invalid JSON response"
1171
- };
1172
- }
1173
- transitionToGracefulShutdown() {
1174
- const lib = this.ensureLoaded();
1175
- const ptr = lib.transition_to_graceful_shutdown();
1176
- const jsonStr = this.readAndFreeRustString(ptr);
1177
- const parsed = this.parseJson(jsonStr);
1178
- return parsed ?? {
1179
- success: false,
1180
- status: "error",
1181
- message: "Failed to parse shutdown result",
1182
- error: "Invalid JSON response"
1183
- };
1184
- }
1185
- pollStepEvents() {
1186
- const lib = this.ensureLoaded();
1187
- const ptr = lib.poll_step_events();
1188
- if (!ptr) return null;
1189
- const jsonStr = this.readAndFreeRustString(ptr);
1190
- return this.parseJson(jsonStr);
1191
- }
1192
- pollInProcessEvents() {
1193
- const lib = this.ensureLoaded();
1194
- const ptr = lib.poll_in_process_events();
1195
- if (!ptr) return null;
1196
- const jsonStr = this.readAndFreeRustString(ptr);
1197
- return this.parseJson(jsonStr);
1198
- }
1199
- completeStepEvent(eventId, result) {
1200
- const lib = this.ensureLoaded();
1201
- return lib.complete_step_event(eventId, this.toJson(result)) === 1;
1202
- }
1203
- checkpointYieldStepEvent(eventId, checkpointData) {
1204
- const lib = this.ensureLoaded();
1205
- return lib.checkpoint_yield_step_event(eventId, this.toJson(checkpointData)) === 1;
1206
- }
1207
- getFfiDispatchMetrics() {
1208
- const lib = this.ensureLoaded();
1209
- const ptr = lib.get_ffi_dispatch_metrics();
1210
- const jsonStr = this.readAndFreeRustString(ptr);
1211
- const parsed = this.parseJson(jsonStr);
1212
- if (parsed && typeof parsed.pending_count === "number") {
1213
- return parsed;
1151
+ function unlink_recursive(path3) {
1152
+ try {
1153
+ if (fs2.rmSync != null) {
1154
+ fs2.rmSync(path3, { recursive: true, maxRetries: process.platform == "win32" ? 3 : 0 });
1155
+ } else {
1156
+ fs2.rmdirSync(path3, { recursive: true, maxRetries: process.platform == "win32" ? 3 : 0 });
1157
+ }
1158
+ } catch (err) {
1159
+ if (err.code !== "ENOENT")
1160
+ throw err;
1161
+ }
1214
1162
  }
1215
- return {
1216
- pending_count: 0,
1217
- starvation_detected: false,
1218
- starving_event_count: 0,
1219
- oldest_pending_age_ms: null,
1220
- newest_pending_age_ms: null,
1221
- oldest_event_id: null
1163
+ function get_napi_version2(napi, major) {
1164
+ if (napi > 8)
1165
+ return null;
1166
+ const support = {
1167
+ 6: ["6.14.2", "6.14.2", "6.14.2"],
1168
+ 8: ["8.6.0", "8.10.0", "8.11.2"],
1169
+ 9: ["9.0.0", "9.3.0", "9.11.0"],
1170
+ 10: ["10.0.0", "10.0.0", "10.0.0", "10.16.0", "10.17.0", "10.20.0", "10.23.0"],
1171
+ 11: ["11.0.0", "11.0.0", "11.0.0", "11.8.0"],
1172
+ 12: ["12.0.0", "12.0.0", "12.0.0", "12.0.0", "12.11.0", "12.17.0", "12.19.0", "12.22.0"],
1173
+ 13: ["13.0.0", "13.0.0", "13.0.0", "13.0.0", "13.0.0"],
1174
+ 14: ["14.0.0", "14.0.0", "14.0.0", "14.0.0", "14.0.0", "14.0.0", "14.12.0", "14.17.0"],
1175
+ 15: ["15.0.0", "15.0.0", "15.0.0", "15.0.0", "15.0.0", "15.0.0", "15.0.0", "15.12.0"]
1176
+ };
1177
+ const max = Math.max(...Object.keys(support).map((k) => parseInt(k, 10)));
1178
+ if (major > max)
1179
+ return major + ".0.0";
1180
+ if (support[major] == null)
1181
+ return null;
1182
+ let required = support[major][napi - 1] || null;
1183
+ return required;
1184
+ }
1185
+ function cmp_version(ver1, ver2) {
1186
+ ver1 = String(ver1).replace(/-.*$/, "").split(".").reduce((acc, v, idx) => acc + parseInt(v, 10) * Math.pow(10, 2 * (5 - idx)), 0);
1187
+ ver2 = String(ver2).replace(/-.*$/, "").split(".").reduce((acc, v, idx) => acc + parseInt(v, 10) * Math.pow(10, 2 * (5 - idx)), 0);
1188
+ let cmp = Math.min(Math.max(ver1 - ver2, -1), 1);
1189
+ return cmp;
1190
+ }
1191
+ module2.exports = {
1192
+ download_http,
1193
+ extract_targz,
1194
+ path_is_absolute,
1195
+ path_has_dotdot,
1196
+ sync_files,
1197
+ determine_arch: determine_arch2,
1198
+ unlink_recursive,
1199
+ get_napi_version: get_napi_version2,
1200
+ cmp_version
1222
1201
  };
1223
1202
  }
1224
- checkStarvationWarnings() {
1225
- const lib = this.ensureLoaded();
1226
- lib.check_starvation_warnings();
1227
- }
1228
- cleanupTimeouts() {
1229
- const lib = this.ensureLoaded();
1230
- lib.cleanup_timeouts();
1231
- }
1232
- logError(message, fields) {
1233
- const lib = this.ensureLoaded();
1234
- lib.log_error(message, fields ? this.toJson(fields) : null);
1235
- }
1236
- logWarn(message, fields) {
1237
- const lib = this.ensureLoaded();
1238
- lib.log_warn(message, fields ? this.toJson(fields) : null);
1239
- }
1240
- logInfo(message, fields) {
1241
- const lib = this.ensureLoaded();
1242
- lib.log_info(message, fields ? this.toJson(fields) : null);
1243
- }
1244
- logDebug(message, fields) {
1245
- const lib = this.ensureLoaded();
1246
- lib.log_debug(message, fields ? this.toJson(fields) : null);
1247
- }
1248
- logTrace(message, fields) {
1249
- const lib = this.ensureLoaded();
1250
- lib.log_trace(message, fields ? this.toJson(fields) : null);
1251
- }
1252
- // ==========================================================================
1253
- // Client API Operations (TAS-231)
1254
- // ==========================================================================
1255
- parseClientResult(ptr) {
1256
- const jsonStr = this.readAndFreeRustString(ptr);
1257
- const parsed = this.parseJson(jsonStr);
1258
- return parsed ?? {
1259
- success: false,
1260
- data: null,
1261
- error: "Failed to parse client result",
1262
- recoverable: null
1203
+ });
1204
+ var require_package = __commonJS({
1205
+ "bin/Koffi/package/src/koffi/package.json"(exports2, module2) {
1206
+ module2.exports = {
1207
+ name: "koffi",
1208
+ version: "2.15.0",
1209
+ description: "Fast and simple C FFI (foreign function interface) for Node.js",
1210
+ keywords: [
1211
+ "foreign",
1212
+ "function",
1213
+ "interface",
1214
+ "ffi",
1215
+ "binding",
1216
+ "c",
1217
+ "napi"
1218
+ ],
1219
+ repository: {
1220
+ type: "git",
1221
+ url: "https://github.com/Koromix/koffi"
1222
+ },
1223
+ homepage: "https://koffi.dev/",
1224
+ author: {
1225
+ name: "Niels Martign\xE8ne",
1226
+ email: "niels.martignene@protonmail.com",
1227
+ url: "https://koromix.dev/"
1228
+ },
1229
+ main: "./index.js",
1230
+ types: "./index.d.ts",
1231
+ scripts: {
1232
+ test: "node tools/koffi.js test",
1233
+ prepack: `echo 'Use "npm run package" instead' && false`,
1234
+ prepublishOnly: `echo 'Use "npm run package" instead' && false`,
1235
+ package: "node tools/koffi.js build"
1236
+ },
1237
+ license: "MIT",
1238
+ cnoke: {
1239
+ api: "../../vendor/node-api-headers",
1240
+ output: "../../bin/Koffi/{{ platform }}_{{ arch }}",
1241
+ node: 16,
1242
+ napi: 8,
1243
+ require: "./index.js"
1244
+ },
1245
+ funding: "https://buymeacoffee.com/koromix"
1263
1246
  };
1264
1247
  }
1265
- clientCreateTask(requestJson) {
1266
- const lib = this.ensureLoaded();
1267
- const ptr = lib.client_create_task(requestJson);
1268
- return this.parseClientResult(ptr);
1269
- }
1270
- clientGetTask(taskUuid) {
1271
- const lib = this.ensureLoaded();
1272
- const ptr = lib.client_get_task(taskUuid);
1273
- return this.parseClientResult(ptr);
1274
- }
1275
- clientListTasks(paramsJson) {
1276
- const lib = this.ensureLoaded();
1277
- const ptr = lib.client_list_tasks(paramsJson);
1278
- return this.parseClientResult(ptr);
1279
- }
1280
- clientCancelTask(taskUuid) {
1281
- const lib = this.ensureLoaded();
1282
- const ptr = lib.client_cancel_task(taskUuid);
1283
- return this.parseClientResult(ptr);
1284
- }
1285
- clientListTaskSteps(taskUuid) {
1286
- const lib = this.ensureLoaded();
1287
- const ptr = lib.client_list_task_steps(taskUuid);
1288
- return this.parseClientResult(ptr);
1289
- }
1290
- clientGetStep(taskUuid, stepUuid) {
1291
- const lib = this.ensureLoaded();
1292
- const ptr = lib.client_get_step(taskUuid, stepUuid);
1293
- return this.parseClientResult(ptr);
1248
+ });
1249
+ var require_init = __commonJS({
1250
+ "bin/Koffi/package/src/koffi/src/init.js"(exports$1, module) {
1251
+ var fs = __require("fs");
1252
+ var path = __require("path");
1253
+ var util = __require("util");
1254
+ var { get_napi_version, determine_arch } = require_tools();
1255
+ var pkg = require_package();
1256
+ function detect() {
1257
+ if (process.versions.napi == null || process.versions.napi < pkg.cnoke.napi) {
1258
+ let major = parseInt(process.versions.node, 10);
1259
+ let required = get_napi_version(pkg.cnoke.napi, major);
1260
+ if (required != null) {
1261
+ throw new Error(`This engine is based on Node ${process.versions.node}, but ${pkg.name} requires Node >= ${required} in the Node ${major}.x branch (N-API >= ${pkg.cnoke.napi})`);
1262
+ } else {
1263
+ throw new Error(`This engine is based on Node ${process.versions.node}, but ${pkg.name} does not support the Node ${major}.x branch (N-API < ${pkg.cnoke.napi})`);
1264
+ }
1265
+ }
1266
+ let arch = determine_arch();
1267
+ let triplet3 = `${process.platform}_${arch}`;
1268
+ return triplet3;
1269
+ }
1270
+ function init(triplet, native) {
1271
+ if (native == null) {
1272
+ let roots = [path.join(__dirname, "..")];
1273
+ let triplets = [triplet];
1274
+ if (process.resourcesPath != null)
1275
+ roots.push(process.resourcesPath);
1276
+ if (triplet.startsWith("linux_")) {
1277
+ let musl = triplet.replace(/^linux_/, "musl_");
1278
+ triplets.push(musl);
1279
+ }
1280
+ let filenames = roots.flatMap((root) => triplets.flatMap((triplet3) => [
1281
+ `${root}/build/koffi/${triplet3}/koffi.node`,
1282
+ `${root}/koffi/${triplet3}/koffi.node`,
1283
+ `${root}/node_modules/koffi/build/koffi/${triplet3}/koffi.node`,
1284
+ `${root}/../../bin/Koffi/${triplet3}/koffi.node`
1285
+ ]));
1286
+ let first_err = null;
1287
+ for (let filename of filenames) {
1288
+ if (!fs.existsSync(filename))
1289
+ continue;
1290
+ try {
1291
+ native = eval("require")(filename);
1292
+ } catch (err) {
1293
+ if (first_err == null)
1294
+ first_err = err;
1295
+ continue;
1296
+ }
1297
+ break;
1298
+ }
1299
+ if (first_err != null)
1300
+ throw first_err;
1301
+ }
1302
+ if (native == null)
1303
+ throw new Error("Cannot find the native Koffi module; did you bundle it correctly?");
1304
+ if (native.version != pkg.version)
1305
+ throw new Error("Mismatched native Koffi modules");
1306
+ let mod = wrap(native);
1307
+ return mod;
1308
+ }
1309
+ function wrap(native3) {
1310
+ let obj = {
1311
+ ...native3,
1312
+ // Deprecated functions
1313
+ handle: util.deprecate(native3.opaque, "The koffi.handle() function was deprecated in Koffi 2.1, use koffi.opaque() instead", "KOFFI001"),
1314
+ callback: util.deprecate(native3.proto, "The koffi.callback() function was deprecated in Koffi 2.4, use koffi.proto() instead", "KOFFI002")
1315
+ };
1316
+ obj.load = (...args) => {
1317
+ let lib = native3.load(...args);
1318
+ lib.cdecl = util.deprecate((...args2) => lib.func("__cdecl", ...args2), "The koffi.cdecl() function was deprecated in Koffi 2.7, use koffi.func(...) instead", "KOFFI003");
1319
+ lib.stdcall = util.deprecate((...args2) => lib.func("__stdcall", ...args2), 'The koffi.stdcall() function was deprecated in Koffi 2.7, use koffi.func("__stdcall", ...) instead', "KOFFI004");
1320
+ lib.fastcall = util.deprecate((...args2) => lib.func("__fastcall", ...args2), 'The koffi.fastcall() function was deprecated in Koffi 2.7, use koffi.func("__fastcall", ...) instead', "KOFFI005");
1321
+ lib.thiscall = util.deprecate((...args2) => lib.func("__thiscall", ...args2), 'The koffi.thiscall() function was deprecated in Koffi 2.7, use koffi.func("__thiscall", ...) instead', "KOFFI006");
1322
+ return lib;
1323
+ };
1324
+ return obj;
1325
+ }
1326
+ module.exports = {
1327
+ detect,
1328
+ init
1329
+ };
1294
1330
  }
1295
- clientGetStepAuditHistory(taskUuid, stepUuid) {
1296
- const lib = this.ensureLoaded();
1297
- const ptr = lib.client_get_step_audit_history(taskUuid, stepUuid);
1298
- return this.parseClientResult(ptr);
1331
+ });
1332
+ var { detect: detect2, init: init2 } = require_init();
1333
+ var triplet2 = detect2();
1334
+ var native2 = null;
1335
+ try {
1336
+ switch (triplet2) {
1337
+ case "darwin_arm64":
1338
+ {
1339
+ native2 = require_koffi();
1340
+ }
1341
+ break;
1342
+ case "darwin_x64":
1343
+ {
1344
+ native2 = require_koffi2();
1345
+ }
1346
+ break;
1347
+ case "freebsd_arm64":
1348
+ {
1349
+ native2 = require_koffi3();
1350
+ }
1351
+ break;
1352
+ case "freebsd_ia32":
1353
+ {
1354
+ native2 = require_koffi4();
1355
+ }
1356
+ break;
1357
+ case "freebsd_x64":
1358
+ {
1359
+ native2 = require_koffi5();
1360
+ }
1361
+ break;
1362
+ case "linux_armhf":
1363
+ {
1364
+ native2 = require_koffi6();
1365
+ }
1366
+ break;
1367
+ case "linux_arm64":
1368
+ {
1369
+ native2 = require_koffi7();
1370
+ }
1371
+ break;
1372
+ case "linux_ia32":
1373
+ {
1374
+ native2 = require_koffi8();
1375
+ }
1376
+ break;
1377
+ case "linux_loong64":
1378
+ {
1379
+ native2 = require_koffi9();
1380
+ }
1381
+ break;
1382
+ case "linux_riscv64d":
1383
+ {
1384
+ native2 = require_koffi10();
1385
+ }
1386
+ break;
1387
+ case "linux_x64":
1388
+ {
1389
+ native2 = require_koffi11();
1390
+ }
1391
+ break;
1392
+ case "openbsd_ia32":
1393
+ {
1394
+ native2 = require_koffi12();
1395
+ }
1396
+ break;
1397
+ case "openbsd_x64":
1398
+ {
1399
+ native2 = require_koffi13();
1400
+ }
1401
+ break;
1402
+ case "win32_arm64":
1403
+ {
1404
+ native2 = require_koffi14();
1405
+ }
1406
+ break;
1407
+ case "win32_ia32":
1408
+ {
1409
+ native2 = require_koffi15();
1410
+ }
1411
+ break;
1412
+ case "win32_x64":
1413
+ {
1414
+ native2 = require_koffi16();
1415
+ }
1416
+ break;
1299
1417
  }
1300
- clientHealthCheck() {
1301
- const lib = this.ensureLoaded();
1302
- const ptr = lib.client_health_check();
1303
- return this.parseClientResult(ptr);
1418
+ } catch {
1419
+ try {
1420
+ switch (triplet2) {
1421
+ case "linux_arm64":
1422
+ {
1423
+ native2 = require_koffi17();
1424
+ }
1425
+ break;
1426
+ case "linux_x64":
1427
+ {
1428
+ native2 = require_koffi18();
1429
+ }
1430
+ break;
1431
+ }
1432
+ } catch {
1304
1433
  }
1305
- };
1434
+ }
1435
+ var mod2 = init2(triplet2, native2);
1436
+ module.exports = mod2;
1306
1437
  }
1307
1438
  });
1308
1439
 
1309
- // src/ffi/deno-runtime.ts
1310
- var deno_runtime_exports = {};
1311
- __export(deno_runtime_exports, {
1312
- DenoRuntime: () => DenoRuntime
1440
+ // src/ffi/node-runtime.ts
1441
+ var node_runtime_exports = {};
1442
+ __export(node_runtime_exports, {
1443
+ NodeRuntime: () => NodeRuntime
1313
1444
  });
1314
- var DenoRuntime;
1315
- var init_deno_runtime = __esm({
1316
- "src/ffi/deno-runtime.ts"() {
1445
+ var NodeRuntime;
1446
+ var init_node_runtime = __esm({
1447
+ "src/ffi/node-runtime.ts"() {
1317
1448
  init_runtime_interface();
1318
- DenoRuntime = class extends BaseTaskerRuntime {
1319
- name = "deno";
1449
+ NodeRuntime = class extends BaseTaskerRuntime {
1450
+ name = "node";
1320
1451
  lib = null;
1321
- encoder = new TextEncoder();
1452
+ // biome-ignore lint/suspicious/noExplicitAny: koffi module type
1453
+ koffi = null;
1322
1454
  get isLoaded() {
1323
1455
  return this.lib !== null;
1324
1456
  }
@@ -1326,180 +1458,83 @@ var init_deno_runtime = __esm({
1326
1458
  if (this.lib !== null) {
1327
1459
  return;
1328
1460
  }
1329
- if (typeof Deno === "undefined") {
1330
- throw new Error("Deno runtime not detected");
1331
- }
1332
- this.lib = Deno.dlopen(libraryPath, {
1333
- get_version: {
1334
- parameters: [],
1335
- result: "pointer"
1336
- },
1337
- get_rust_version: {
1338
- parameters: [],
1339
- result: "pointer"
1340
- },
1341
- health_check: {
1342
- parameters: [],
1343
- result: "i32"
1344
- },
1345
- is_worker_running: {
1346
- parameters: [],
1347
- result: "i32"
1348
- },
1349
- bootstrap_worker: {
1350
- parameters: ["buffer"],
1351
- result: "pointer"
1352
- },
1353
- get_worker_status: {
1354
- parameters: [],
1355
- result: "pointer"
1356
- },
1357
- stop_worker: {
1358
- parameters: [],
1359
- result: "pointer"
1360
- },
1361
- transition_to_graceful_shutdown: {
1362
- parameters: [],
1363
- result: "pointer"
1364
- },
1365
- poll_step_events: {
1366
- parameters: [],
1367
- result: "pointer"
1368
- },
1369
- poll_in_process_events: {
1370
- parameters: [],
1371
- result: "pointer"
1372
- },
1373
- complete_step_event: {
1374
- parameters: ["buffer", "buffer"],
1375
- result: "i32"
1376
- },
1377
- checkpoint_yield_step_event: {
1378
- parameters: ["buffer", "buffer"],
1379
- result: "i32"
1380
- },
1381
- get_ffi_dispatch_metrics: {
1382
- parameters: [],
1383
- result: "pointer"
1384
- },
1385
- check_starvation_warnings: {
1386
- parameters: [],
1387
- result: "void"
1388
- },
1389
- cleanup_timeouts: {
1390
- parameters: [],
1391
- result: "void"
1392
- },
1393
- log_error: {
1394
- parameters: ["buffer", "buffer"],
1395
- result: "void"
1396
- },
1397
- log_warn: {
1398
- parameters: ["buffer", "buffer"],
1399
- result: "void"
1400
- },
1401
- log_info: {
1402
- parameters: ["buffer", "buffer"],
1403
- result: "void"
1404
- },
1405
- log_debug: {
1406
- parameters: ["buffer", "buffer"],
1407
- result: "void"
1408
- },
1409
- log_trace: {
1410
- parameters: ["buffer", "buffer"],
1411
- result: "void"
1412
- },
1413
- free_rust_string: {
1414
- parameters: ["pointer"],
1415
- result: "void"
1416
- },
1417
- // Client API functions (TAS-231)
1418
- client_create_task: {
1419
- parameters: ["buffer"],
1420
- result: "pointer"
1421
- },
1422
- client_get_task: {
1423
- parameters: ["buffer"],
1424
- result: "pointer"
1425
- },
1426
- client_list_tasks: {
1427
- parameters: ["buffer"],
1428
- result: "pointer"
1429
- },
1430
- client_cancel_task: {
1431
- parameters: ["buffer"],
1432
- result: "pointer"
1433
- },
1434
- client_list_task_steps: {
1435
- parameters: ["buffer"],
1436
- result: "pointer"
1437
- },
1438
- client_get_step: {
1439
- parameters: ["buffer", "buffer"],
1440
- result: "pointer"
1441
- },
1442
- client_get_step_audit_history: {
1443
- parameters: ["buffer", "buffer"],
1444
- result: "pointer"
1445
- },
1446
- client_health_check: {
1447
- parameters: [],
1448
- result: "pointer"
1449
- }
1450
- });
1461
+ const koffiModule = await Promise.resolve().then(() => __toESM(require_koffi19()));
1462
+ this.koffi = koffiModule.default ?? koffiModule;
1463
+ const lib = this.koffi.load(libraryPath);
1464
+ this.lib = {
1465
+ get_version: lib.func("void* get_version()"),
1466
+ get_rust_version: lib.func("void* get_rust_version()"),
1467
+ health_check: lib.func("int health_check()"),
1468
+ is_worker_running: lib.func("int is_worker_running()"),
1469
+ bootstrap_worker: lib.func("void* bootstrap_worker(str)"),
1470
+ get_worker_status: lib.func("void* get_worker_status()"),
1471
+ stop_worker: lib.func("void* stop_worker()"),
1472
+ transition_to_graceful_shutdown: lib.func("void* transition_to_graceful_shutdown()"),
1473
+ poll_step_events: lib.func("void* poll_step_events()"),
1474
+ poll_in_process_events: lib.func("void* poll_in_process_events()"),
1475
+ complete_step_event: lib.func("int complete_step_event(str, str)"),
1476
+ checkpoint_yield_step_event: lib.func("int checkpoint_yield_step_event(str, str)"),
1477
+ get_ffi_dispatch_metrics: lib.func("void* get_ffi_dispatch_metrics()"),
1478
+ check_starvation_warnings: lib.func("void check_starvation_warnings()"),
1479
+ cleanup_timeouts: lib.func("void cleanup_timeouts()"),
1480
+ log_error: lib.func("void log_error(str, str)"),
1481
+ log_warn: lib.func("void log_warn(str, str)"),
1482
+ log_info: lib.func("void log_info(str, str)"),
1483
+ log_debug: lib.func("void log_debug(str, str)"),
1484
+ log_trace: lib.func("void log_trace(str, str)"),
1485
+ free_rust_string: lib.func("void free_rust_string(void*)"),
1486
+ // Client API functions (TAS-231)
1487
+ client_create_task: lib.func("void* client_create_task(str)"),
1488
+ client_get_task: lib.func("void* client_get_task(str)"),
1489
+ client_list_tasks: lib.func("void* client_list_tasks(str)"),
1490
+ client_cancel_task: lib.func("void* client_cancel_task(str)"),
1491
+ client_list_task_steps: lib.func("void* client_list_task_steps(str)"),
1492
+ client_get_step: lib.func("void* client_get_step(str, str)"),
1493
+ client_get_step_audit_history: lib.func("void* client_get_step_audit_history(str, str)"),
1494
+ client_health_check: lib.func("void* client_health_check()")
1495
+ };
1451
1496
  }
1452
1497
  unload() {
1453
- if (this.lib) {
1454
- this.lib.close();
1455
- this.lib = null;
1456
- }
1498
+ this.lib = null;
1499
+ this.koffi = null;
1457
1500
  }
1458
1501
  ensureLoaded() {
1459
1502
  if (!this.lib) {
1460
1503
  throw new Error("Native library not loaded. Call load() first.");
1461
1504
  }
1462
- return this.lib.symbols;
1505
+ return this.lib;
1463
1506
  }
1464
1507
  /**
1465
- * Creates a null-terminated C string buffer.
1466
- * With 'buffer' FFI type, we return Uint8Array directly.
1508
+ * Read a C string from a pointer and free the Rust-allocated memory.
1509
+ *
1510
+ * Uses koffi.decode with 'char' type and -1 length for null-terminated strings.
1467
1511
  */
1468
- toCString(str) {
1469
- return this.encoder.encode(`${str}\0`);
1470
- }
1471
- // biome-ignore lint/suspicious/noExplicitAny: Deno PointerValue type
1472
- fromCString(ptr) {
1473
- if (ptr === null || Deno.UnsafePointer.equals(ptr, null)) {
1474
- return null;
1475
- }
1476
- const view = new Deno.UnsafePointerView(ptr);
1477
- return view.getCString();
1512
+ readAndFreeRustString(ptr) {
1513
+ if (!ptr) return null;
1514
+ const lib = this.ensureLoaded();
1515
+ const str = this.koffi.decode(ptr, "char", -1);
1516
+ lib.free_rust_string(ptr);
1517
+ return str;
1478
1518
  }
1479
1519
  getVersion() {
1480
- const symbols = this.ensureLoaded();
1481
- const result = symbols.get_version();
1482
- const version = this.fromCString(result) ?? "unknown";
1483
- if (result !== null) symbols.free_rust_string(result);
1484
- return version;
1520
+ const lib = this.ensureLoaded();
1521
+ const ptr = lib.get_version();
1522
+ return this.readAndFreeRustString(ptr) ?? "unknown";
1485
1523
  }
1486
1524
  getRustVersion() {
1487
- const symbols = this.ensureLoaded();
1488
- const result = symbols.get_rust_version();
1489
- const version = this.fromCString(result) ?? "unknown";
1490
- if (result !== null) symbols.free_rust_string(result);
1491
- return version;
1525
+ const lib = this.ensureLoaded();
1526
+ const ptr = lib.get_rust_version();
1527
+ return this.readAndFreeRustString(ptr) ?? "unknown";
1492
1528
  }
1493
1529
  healthCheck() {
1494
- const symbols = this.ensureLoaded();
1495
- return symbols.health_check() === 1;
1530
+ const lib = this.ensureLoaded();
1531
+ return lib.health_check() === 1;
1496
1532
  }
1497
1533
  bootstrapWorker(config) {
1498
- const symbols = this.ensureLoaded();
1499
- const configBuf = config ? this.toCString(this.toJson(config)) : null;
1500
- const result = symbols.bootstrap_worker(configBuf);
1501
- const jsonStr = this.fromCString(result);
1502
- if (result !== null) symbols.free_rust_string(result);
1534
+ const lib = this.ensureLoaded();
1535
+ const configJson = config ? this.toJson(config) : null;
1536
+ const ptr = lib.bootstrap_worker(configJson);
1537
+ const jsonStr = this.readAndFreeRustString(ptr);
1503
1538
  const parsed = this.parseJson(jsonStr);
1504
1539
  return parsed ?? {
1505
1540
  success: false,
@@ -1509,22 +1544,20 @@ var init_deno_runtime = __esm({
1509
1544
  };
1510
1545
  }
1511
1546
  isWorkerRunning() {
1512
- const symbols = this.ensureLoaded();
1513
- return symbols.is_worker_running() === 1;
1547
+ const lib = this.ensureLoaded();
1548
+ return lib.is_worker_running() === 1;
1514
1549
  }
1515
1550
  getWorkerStatus() {
1516
- const symbols = this.ensureLoaded();
1517
- const result = symbols.get_worker_status();
1518
- const jsonStr = this.fromCString(result);
1519
- if (result !== null) symbols.free_rust_string(result);
1551
+ const lib = this.ensureLoaded();
1552
+ const ptr = lib.get_worker_status();
1553
+ const jsonStr = this.readAndFreeRustString(ptr);
1520
1554
  const parsed = this.parseJson(jsonStr);
1521
1555
  return parsed ?? { success: false, running: false };
1522
1556
  }
1523
1557
  stopWorker() {
1524
- const symbols = this.ensureLoaded();
1525
- const result = symbols.stop_worker();
1526
- const jsonStr = this.fromCString(result);
1527
- if (result !== null) symbols.free_rust_string(result);
1558
+ const lib = this.ensureLoaded();
1559
+ const ptr = lib.stop_worker();
1560
+ const jsonStr = this.readAndFreeRustString(ptr);
1528
1561
  const parsed = this.parseJson(jsonStr);
1529
1562
  return parsed ?? {
1530
1563
  success: false,
@@ -1534,10 +1567,9 @@ var init_deno_runtime = __esm({
1534
1567
  };
1535
1568
  }
1536
1569
  transitionToGracefulShutdown() {
1537
- const symbols = this.ensureLoaded();
1538
- const result = symbols.transition_to_graceful_shutdown();
1539
- const jsonStr = this.fromCString(result);
1540
- if (result !== null) symbols.free_rust_string(result);
1570
+ const lib = this.ensureLoaded();
1571
+ const ptr = lib.transition_to_graceful_shutdown();
1572
+ const jsonStr = this.readAndFreeRustString(ptr);
1541
1573
  const parsed = this.parseJson(jsonStr);
1542
1574
  return parsed ?? {
1543
1575
  success: false,
@@ -1547,42 +1579,31 @@ var init_deno_runtime = __esm({
1547
1579
  };
1548
1580
  }
1549
1581
  pollStepEvents() {
1550
- const symbols = this.ensureLoaded();
1551
- const result = symbols.poll_step_events();
1552
- if (result === null || Deno.UnsafePointer.equals(result, null)) {
1553
- return null;
1554
- }
1555
- const jsonStr = this.fromCString(result);
1556
- symbols.free_rust_string(result);
1582
+ const lib = this.ensureLoaded();
1583
+ const ptr = lib.poll_step_events();
1584
+ if (!ptr) return null;
1585
+ const jsonStr = this.readAndFreeRustString(ptr);
1557
1586
  return this.parseJson(jsonStr);
1558
1587
  }
1559
1588
  pollInProcessEvents() {
1560
- const symbols = this.ensureLoaded();
1561
- const result = symbols.poll_in_process_events();
1562
- if (result === null || Deno.UnsafePointer.equals(result, null)) {
1563
- return null;
1564
- }
1565
- const jsonStr = this.fromCString(result);
1566
- symbols.free_rust_string(result);
1589
+ const lib = this.ensureLoaded();
1590
+ const ptr = lib.poll_in_process_events();
1591
+ if (!ptr) return null;
1592
+ const jsonStr = this.readAndFreeRustString(ptr);
1567
1593
  return this.parseJson(jsonStr);
1568
1594
  }
1569
1595
  completeStepEvent(eventId, result) {
1570
- const symbols = this.ensureLoaded();
1571
- const eventIdBuf = this.toCString(eventId);
1572
- const resultJsonBuf = this.toCString(this.toJson(result));
1573
- return symbols.complete_step_event(eventIdBuf, resultJsonBuf) === 1;
1596
+ const lib = this.ensureLoaded();
1597
+ return lib.complete_step_event(eventId, this.toJson(result)) === 1;
1574
1598
  }
1575
1599
  checkpointYieldStepEvent(eventId, checkpointData) {
1576
- const symbols = this.ensureLoaded();
1577
- const eventIdBuf = this.toCString(eventId);
1578
- const checkpointJsonBuf = this.toCString(this.toJson(checkpointData));
1579
- return symbols.checkpoint_yield_step_event(eventIdBuf, checkpointJsonBuf) === 1;
1600
+ const lib = this.ensureLoaded();
1601
+ return lib.checkpoint_yield_step_event(eventId, this.toJson(checkpointData)) === 1;
1580
1602
  }
1581
1603
  getFfiDispatchMetrics() {
1582
- const symbols = this.ensureLoaded();
1583
- const result = symbols.get_ffi_dispatch_metrics();
1584
- const jsonStr = this.fromCString(result);
1585
- if (result !== null) symbols.free_rust_string(result);
1604
+ const lib = this.ensureLoaded();
1605
+ const ptr = lib.get_ffi_dispatch_metrics();
1606
+ const jsonStr = this.readAndFreeRustString(ptr);
1586
1607
  const parsed = this.parseJson(jsonStr);
1587
1608
  if (parsed && typeof parsed.pending_count === "number") {
1588
1609
  return parsed;
@@ -1597,49 +1618,38 @@ var init_deno_runtime = __esm({
1597
1618
  };
1598
1619
  }
1599
1620
  checkStarvationWarnings() {
1600
- const symbols = this.ensureLoaded();
1601
- symbols.check_starvation_warnings();
1621
+ const lib = this.ensureLoaded();
1622
+ lib.check_starvation_warnings();
1602
1623
  }
1603
1624
  cleanupTimeouts() {
1604
- const symbols = this.ensureLoaded();
1605
- symbols.cleanup_timeouts();
1625
+ const lib = this.ensureLoaded();
1626
+ lib.cleanup_timeouts();
1606
1627
  }
1607
1628
  logError(message, fields) {
1608
- const symbols = this.ensureLoaded();
1609
- const msgBuf = this.toCString(message);
1610
- const fieldsBuf = fields ? this.toCString(this.toJson(fields)) : null;
1611
- symbols.log_error(msgBuf, fieldsBuf);
1629
+ const lib = this.ensureLoaded();
1630
+ lib.log_error(message, fields ? this.toJson(fields) : null);
1612
1631
  }
1613
1632
  logWarn(message, fields) {
1614
- const symbols = this.ensureLoaded();
1615
- const msgBuf = this.toCString(message);
1616
- const fieldsBuf = fields ? this.toCString(this.toJson(fields)) : null;
1617
- symbols.log_warn(msgBuf, fieldsBuf);
1633
+ const lib = this.ensureLoaded();
1634
+ lib.log_warn(message, fields ? this.toJson(fields) : null);
1618
1635
  }
1619
1636
  logInfo(message, fields) {
1620
- const symbols = this.ensureLoaded();
1621
- const msgBuf = this.toCString(message);
1622
- const fieldsBuf = fields ? this.toCString(this.toJson(fields)) : null;
1623
- symbols.log_info(msgBuf, fieldsBuf);
1637
+ const lib = this.ensureLoaded();
1638
+ lib.log_info(message, fields ? this.toJson(fields) : null);
1624
1639
  }
1625
1640
  logDebug(message, fields) {
1626
- const symbols = this.ensureLoaded();
1627
- const msgBuf = this.toCString(message);
1628
- const fieldsBuf = fields ? this.toCString(this.toJson(fields)) : null;
1629
- symbols.log_debug(msgBuf, fieldsBuf);
1641
+ const lib = this.ensureLoaded();
1642
+ lib.log_debug(message, fields ? this.toJson(fields) : null);
1630
1643
  }
1631
1644
  logTrace(message, fields) {
1632
- const symbols = this.ensureLoaded();
1633
- const msgBuf = this.toCString(message);
1634
- const fieldsBuf = fields ? this.toCString(this.toJson(fields)) : null;
1635
- symbols.log_trace(msgBuf, fieldsBuf);
1645
+ const lib = this.ensureLoaded();
1646
+ lib.log_trace(message, fields ? this.toJson(fields) : null);
1636
1647
  }
1637
1648
  // ==========================================================================
1638
1649
  // Client API Operations (TAS-231)
1639
1650
  // ==========================================================================
1640
- parseClientResult(result) {
1641
- const jsonStr = this.fromCString(result);
1642
- if (result !== null) this.ensureLoaded().free_rust_string(result);
1651
+ parseClientResult(ptr) {
1652
+ const jsonStr = this.readAndFreeRustString(ptr);
1643
1653
  const parsed = this.parseJson(jsonStr);
1644
1654
  return parsed ?? {
1645
1655
  success: false,
@@ -1649,53 +1659,44 @@ var init_deno_runtime = __esm({
1649
1659
  };
1650
1660
  }
1651
1661
  clientCreateTask(requestJson) {
1652
- const symbols = this.ensureLoaded();
1653
- const buf = this.toCString(requestJson);
1654
- const result = symbols.client_create_task(buf);
1655
- return this.parseClientResult(result);
1662
+ const lib = this.ensureLoaded();
1663
+ const ptr = lib.client_create_task(requestJson);
1664
+ return this.parseClientResult(ptr);
1656
1665
  }
1657
1666
  clientGetTask(taskUuid) {
1658
- const symbols = this.ensureLoaded();
1659
- const buf = this.toCString(taskUuid);
1660
- const result = symbols.client_get_task(buf);
1661
- return this.parseClientResult(result);
1667
+ const lib = this.ensureLoaded();
1668
+ const ptr = lib.client_get_task(taskUuid);
1669
+ return this.parseClientResult(ptr);
1662
1670
  }
1663
1671
  clientListTasks(paramsJson) {
1664
- const symbols = this.ensureLoaded();
1665
- const buf = this.toCString(paramsJson);
1666
- const result = symbols.client_list_tasks(buf);
1667
- return this.parseClientResult(result);
1672
+ const lib = this.ensureLoaded();
1673
+ const ptr = lib.client_list_tasks(paramsJson);
1674
+ return this.parseClientResult(ptr);
1668
1675
  }
1669
1676
  clientCancelTask(taskUuid) {
1670
- const symbols = this.ensureLoaded();
1671
- const buf = this.toCString(taskUuid);
1672
- const result = symbols.client_cancel_task(buf);
1673
- return this.parseClientResult(result);
1677
+ const lib = this.ensureLoaded();
1678
+ const ptr = lib.client_cancel_task(taskUuid);
1679
+ return this.parseClientResult(ptr);
1674
1680
  }
1675
1681
  clientListTaskSteps(taskUuid) {
1676
- const symbols = this.ensureLoaded();
1677
- const buf = this.toCString(taskUuid);
1678
- const result = symbols.client_list_task_steps(buf);
1679
- return this.parseClientResult(result);
1682
+ const lib = this.ensureLoaded();
1683
+ const ptr = lib.client_list_task_steps(taskUuid);
1684
+ return this.parseClientResult(ptr);
1680
1685
  }
1681
1686
  clientGetStep(taskUuid, stepUuid) {
1682
- const symbols = this.ensureLoaded();
1683
- const tBuf = this.toCString(taskUuid);
1684
- const sBuf = this.toCString(stepUuid);
1685
- const result = symbols.client_get_step(tBuf, sBuf);
1686
- return this.parseClientResult(result);
1687
+ const lib = this.ensureLoaded();
1688
+ const ptr = lib.client_get_step(taskUuid, stepUuid);
1689
+ return this.parseClientResult(ptr);
1687
1690
  }
1688
1691
  clientGetStepAuditHistory(taskUuid, stepUuid) {
1689
- const symbols = this.ensureLoaded();
1690
- const tBuf = this.toCString(taskUuid);
1691
- const sBuf = this.toCString(stepUuid);
1692
- const result = symbols.client_get_step_audit_history(tBuf, sBuf);
1693
- return this.parseClientResult(result);
1692
+ const lib = this.ensureLoaded();
1693
+ const ptr = lib.client_get_step_audit_history(taskUuid, stepUuid);
1694
+ return this.parseClientResult(ptr);
1694
1695
  }
1695
1696
  clientHealthCheck() {
1696
- const symbols = this.ensureLoaded();
1697
- const result = symbols.client_health_check();
1698
- return this.parseClientResult(result);
1697
+ const lib = this.ensureLoaded();
1698
+ const ptr = lib.client_health_check();
1699
+ return this.parseClientResult(ptr);
1699
1700
  }
1700
1701
  };
1701
1702
  }
@@ -3916,12 +3917,6 @@ var EventSystem = class {
3916
3917
  }
3917
3918
  };
3918
3919
 
3919
- // src/ffi/bun-runtime.ts
3920
- init_node_runtime();
3921
- var BunRuntime = class extends NodeRuntime {
3922
- name = "bun";
3923
- };
3924
-
3925
3920
  // src/ffi/index.ts
3926
3921
  init_deno_runtime();
3927
3922
 
@@ -4048,7 +4043,10 @@ var FfiLayer = class _FfiLayer {
4048
4043
  const path2 = customPath ?? this.configuredLibraryPath ?? this.discoverLibraryPath();
4049
4044
  if (!path2) {
4050
4045
  throw new Error(
4051
- "FFI library not found. TASKER_FFI_LIBRARY_PATH environment variable must be set to the path of the compiled library.\nExample: export TASKER_FFI_LIBRARY_PATH=/path/to/target/debug/libtasker_ts.dylib\nBuild the library with: cargo build -p tasker-ts"
4046
+ `FFI library not found. No bundled native library matches this platform, and TASKER_FFI_LIBRARY_PATH is not set.
4047
+ Current platform: ${process.platform}-${process.arch}
4048
+ Supported: linux-x64, linux-arm64, darwin-arm64
4049
+ Override: export TASKER_FFI_LIBRARY_PATH=/path/to/libtasker_ts.dylib`
4052
4050
  );
4053
4051
  }
4054
4052
  this.runtime = await this.createRuntime();
@@ -4102,23 +4100,27 @@ var FfiLayer = class _FfiLayer {
4102
4100
  * Static method for finding the library path without creating an instance.
4103
4101
  * Useful for test utilities and pre-flight checks.
4104
4102
  *
4105
- * REQUIRES: TASKER_FFI_LIBRARY_PATH environment variable to be set.
4106
- * This explicit requirement prevents confusion from automatic debug/release
4107
- * library discovery and ensures intentional configuration at build/runtime.
4103
+ * Resolution order:
4104
+ * 1. TASKER_FFI_LIBRARY_PATH environment variable (explicit override)
4105
+ * 2. Bundled native library in the package's native/ directory
4108
4106
  *
4109
4107
  * @param _callerDir Deprecated parameter, kept for API compatibility
4110
4108
  * @returns Path to the library if found and exists, null otherwise
4111
4109
  */
4112
4110
  static findLibraryPath(_callerDir) {
4113
4111
  const envPath = process.env.TASKER_FFI_LIBRARY_PATH;
4114
- if (!envPath) {
4115
- return null;
4112
+ if (envPath) {
4113
+ if (!existsSync(envPath)) {
4114
+ console.warn(`TASKER_FFI_LIBRARY_PATH is set to "${envPath}" but the file does not exist`);
4115
+ return null;
4116
+ }
4117
+ return envPath;
4116
4118
  }
4117
- if (!existsSync(envPath)) {
4118
- console.warn(`TASKER_FFI_LIBRARY_PATH is set to "${envPath}" but the file does not exist`);
4119
- return null;
4119
+ const bundledPath = findBundledNativeLibrary();
4120
+ if (bundledPath && existsSync(bundledPath)) {
4121
+ return bundledPath;
4120
4122
  }
4121
- return envPath;
4123
+ return null;
4122
4124
  }
4123
4125
  /**
4124
4126
  * Discover the FFI library path.
@@ -4131,10 +4133,9 @@ var FfiLayer = class _FfiLayer {
4131
4133
  /**
4132
4134
  * Create a runtime adapter for the configured runtime type.
4133
4135
  *
4134
- * NOTE: We use koffi (NodeRuntime) for both Node.js and Bun because:
4135
- * - bun:ffi is experimental with known bugs (per Bun docs)
4136
- * - koffi is stable and works with both Node.js and Bun via Node-API
4137
- * - See: https://bun.sh/docs/runtime/node-api
4136
+ * NOTE: We use koffi (NodeRuntime) for both Node.js and Bun.
4137
+ * koffi is stable and works with both runtimes via Node-API.
4138
+ * See: https://bun.sh/docs/runtime/node-api
4138
4139
  */
4139
4140
  async createRuntime() {
4140
4141
  switch (this.runtimeType) {
@@ -4154,6 +4155,27 @@ var FfiLayer = class _FfiLayer {
4154
4155
  }
4155
4156
  }
4156
4157
  };
4158
+ var BUNDLED_LIBRARIES = {
4159
+ "linux-x64": "libtasker_ts-linux-x64.so",
4160
+ "linux-arm64": "libtasker_ts-linux-arm64.so",
4161
+ "darwin-arm64": "libtasker_ts-darwin-arm64.dylib"
4162
+ };
4163
+ function findBundledNativeLibrary() {
4164
+ const key = `${process.platform}-${process.arch}`;
4165
+ const filename2 = BUNDLED_LIBRARIES[key];
4166
+ if (!filename2) {
4167
+ return null;
4168
+ }
4169
+ let dir = dirname(fileURLToPath(import.meta.url));
4170
+ for (let i = 0; i < 5; i++) {
4171
+ const candidate = join(dir, "native", filename2);
4172
+ if (existsSync(candidate)) return candidate;
4173
+ const parent = dirname(dir);
4174
+ if (parent === dir) break;
4175
+ dir = parent;
4176
+ }
4177
+ return null;
4178
+ }
4157
4179
 
4158
4180
  // src/ffi/index.ts
4159
4181
  init_node_runtime();
@@ -8010,6 +8032,6 @@ var WorkerServer = class {
8010
8032
  }
8011
8033
  };
8012
8034
 
8013
- export { APIMixin, ApiHandler, ApiResponse, BasePublisher, BaseSubscriber, BaseTaskerRuntime, BatchableMixin, BunRuntime, ClassLookupResolver, DecisionHandler, DecisionMixin, DecisionType, DefaultPublisher, DenoRuntime, DuplicatePublisherError, ErrorType, EventNames, EventPoller, EventSystem, ExplicitMappingResolver, FfiLayer, HandlerRegistry, HandlerSystem, InProcessDomainEventPoller, MethodDispatchError, MethodDispatchWrapper, MetricsEventNames, NoResolverMatchError, NodeRuntime, PollerEventNames, PublisherNotFoundError, PublisherRegistry, PublisherValidationError, RegistryFrozenError, RegistryResolver, ResolutionError, ResolverChain, ResolverNotFoundError, ShutdownController, StepContext, StepEventNames, StepExecutionSubscriber, StepHandler, StepHandlerResult, SubscriberRegistry, TaskerClient, TaskerClientError, TaskerEventEmitter, WorkerEventNames, WorkerServer, aggregateBatchResults, applyAPI, applyBatchable, applyDecision, bootstrapWorker, createBatchWorkerContext, createBatches, createDomainEvent, createEventPoller, createFfiPollAdapter, createLogger, createStepEventContext, detectRuntime, effectiveMethod, ffiEventToDomainEvent, fromCallable, fromDto, getLibraryPath, getRuntimeInfo, getRustVersion, getVersion, getWorkerStatus, hasResolverHint, healthCheck, isBun, isCreateBatches, isDeno, isNoBatches, isNode, isStandardErrorType, isTypicallyRetryable, isWorkerRunning, logDebug, logError, logInfo, logTrace, logWarn, noBatches, normalizeToDefinition, stopWorker, transitionToGracefulShutdown, usesMethodDispatch };
8035
+ export { APIMixin, ApiHandler, ApiResponse, BasePublisher, BaseSubscriber, BaseTaskerRuntime, BatchableMixin, ClassLookupResolver, DecisionHandler, DecisionMixin, DecisionType, DefaultPublisher, DenoRuntime, DuplicatePublisherError, ErrorType, EventNames, EventPoller, EventSystem, ExplicitMappingResolver, FfiLayer, HandlerRegistry, HandlerSystem, InProcessDomainEventPoller, MethodDispatchError, MethodDispatchWrapper, MetricsEventNames, NoResolverMatchError, NodeRuntime, PollerEventNames, PublisherNotFoundError, PublisherRegistry, PublisherValidationError, RegistryFrozenError, RegistryResolver, ResolutionError, ResolverChain, ResolverNotFoundError, ShutdownController, StepContext, StepEventNames, StepExecutionSubscriber, StepHandler, StepHandlerResult, SubscriberRegistry, TaskerClient, TaskerClientError, TaskerEventEmitter, WorkerEventNames, WorkerServer, aggregateBatchResults, applyAPI, applyBatchable, applyDecision, bootstrapWorker, createBatchWorkerContext, createBatches, createDomainEvent, createEventPoller, createFfiPollAdapter, createLogger, createStepEventContext, detectRuntime, effectiveMethod, ffiEventToDomainEvent, fromCallable, fromDto, getLibraryPath, getRuntimeInfo, getRustVersion, getVersion, getWorkerStatus, hasResolverHint, healthCheck, isBun, isCreateBatches, isDeno, isNoBatches, isNode, isStandardErrorType, isTypicallyRetryable, isWorkerRunning, logDebug, logError, logInfo, logTrace, logWarn, noBatches, normalizeToDefinition, stopWorker, transitionToGracefulShutdown, usesMethodDispatch };
8014
8036
  //# sourceMappingURL=index.js.map
8015
8037
  //# sourceMappingURL=index.js.map