@nekzus/liop 2.1.0-beta.2 → 2.1.0-beta.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.
Files changed (92) hide show
  1. package/README.md +12 -0
  2. package/dist/bin/agent.js +301 -4
  3. package/dist/bin/agent.js.map +1 -1
  4. package/dist/bridge.d.ts +2 -2
  5. package/dist/bridge.js +3 -1
  6. package/dist/chunk-2JLG4DET.js +3354 -0
  7. package/dist/chunk-2JLG4DET.js.map +1 -0
  8. package/dist/chunk-32ADSAJS.js +104 -0
  9. package/dist/chunk-32ADSAJS.js.map +1 -0
  10. package/dist/chunk-72MNYFR6.js +64 -0
  11. package/dist/chunk-72MNYFR6.js.map +1 -0
  12. package/dist/chunk-CT6NHSYP.js +30 -0
  13. package/dist/chunk-CT6NHSYP.js.map +1 -0
  14. package/dist/chunk-E5QBDD5E.js +469 -0
  15. package/dist/chunk-E5QBDD5E.js.map +1 -0
  16. package/dist/chunk-HB5DXX3Q.js +1976 -0
  17. package/dist/chunk-HB5DXX3Q.js.map +1 -0
  18. package/dist/chunk-IJHTRIZC.js +56 -0
  19. package/dist/chunk-IJHTRIZC.js.map +1 -0
  20. package/dist/chunk-J3WPBMJ5.js +332 -0
  21. package/dist/chunk-J3WPBMJ5.js.map +1 -0
  22. package/dist/chunk-NJRSFFD7.js +815 -0
  23. package/dist/chunk-NJRSFFD7.js.map +1 -0
  24. package/dist/chunk-OUUTDSOW.js +24 -0
  25. package/dist/chunk-OUUTDSOW.js.map +1 -0
  26. package/dist/chunk-PHTWUTY7.js +300 -0
  27. package/dist/chunk-PHTWUTY7.js.map +1 -0
  28. package/dist/chunk-QLCOEP5J.js +68 -0
  29. package/dist/chunk-QLCOEP5J.js.map +1 -0
  30. package/dist/chunk-RDWCGZ2A.js +87 -0
  31. package/dist/chunk-RDWCGZ2A.js.map +1 -0
  32. package/dist/chunk-RWRRBYG4.js +1 -0
  33. package/dist/chunk-UVO7DII3.js +463 -0
  34. package/dist/chunk-UVO7DII3.js.map +1 -0
  35. package/dist/client.d.ts +2 -2
  36. package/dist/client.js +8 -1
  37. package/dist/gateway.d.ts +2 -2
  38. package/dist/gateway.js +9 -1
  39. package/dist/{index-DO97j6hP.d.ts → index-BlGc0iym.d.ts} +10 -1
  40. package/dist/{index-Brfvxmdt.d.ts → index-qM8ZH8sC.d.ts} +1 -1
  41. package/dist/index.d.ts +5 -5
  42. package/dist/index.js +58 -4
  43. package/dist/index.js.map +1 -1
  44. package/dist/kyber-3ULIJSE3.js +3 -0
  45. package/dist/{kyber-NONMBQNH.js.map → kyber-3ULIJSE3.js.map} +1 -1
  46. package/dist/mesh.js +4 -1
  47. package/dist/server.d.ts +2 -2
  48. package/dist/server.js +6 -1
  49. package/dist/{types-DzEXgi4s.d.ts → types-sKeUxuky.d.ts} +4 -46
  50. package/dist/types.d.ts +1 -1
  51. package/dist/types.js +2 -1
  52. package/dist/verifier-3FAKCFNN.js +5 -0
  53. package/dist/{verifier-XU2DB56Z.js.map → verifier-3FAKCFNN.js.map} +1 -1
  54. package/dist/workers/logic-execution.js +255 -1
  55. package/dist/workers/logic-execution.js.map +1 -1
  56. package/dist/workers/zk-verifier.js +173 -1
  57. package/dist/workers/zk-verifier.js.map +1 -1
  58. package/package.json +45 -45
  59. package/dist/chunk-2MGFSIXN.js +0 -2
  60. package/dist/chunk-2MGFSIXN.js.map +0 -1
  61. package/dist/chunk-4C666HHU.js +0 -2
  62. package/dist/chunk-4C666HHU.js.map +0 -1
  63. package/dist/chunk-ANFXJGMP.js +0 -2
  64. package/dist/chunk-ANFXJGMP.js.map +0 -1
  65. package/dist/chunk-DBXGYHKY.js +0 -2
  66. package/dist/chunk-DBXGYHKY.js.map +0 -1
  67. package/dist/chunk-DQ6UW6L7.js +0 -2
  68. package/dist/chunk-DQ6UW6L7.js.map +0 -1
  69. package/dist/chunk-FIPXSEHO.js +0 -3
  70. package/dist/chunk-FIPXSEHO.js.map +0 -1
  71. package/dist/chunk-GI2LSJYZ.js +0 -13
  72. package/dist/chunk-GI2LSJYZ.js.map +0 -1
  73. package/dist/chunk-I46YEWND.js +0 -33
  74. package/dist/chunk-I46YEWND.js.map +0 -1
  75. package/dist/chunk-MJOZVESE.js +0 -54
  76. package/dist/chunk-MJOZVESE.js.map +0 -1
  77. package/dist/chunk-PWCXZWSE.js +0 -2
  78. package/dist/chunk-PWCXZWSE.js.map +0 -1
  79. package/dist/chunk-RYYRR4N5.js +0 -31
  80. package/dist/chunk-RYYRR4N5.js.map +0 -1
  81. package/dist/chunk-S6RJHZV2.js +0 -2
  82. package/dist/chunk-S6RJHZV2.js.map +0 -1
  83. package/dist/chunk-SB5XJXKV.js +0 -2
  84. package/dist/chunk-SB5XJXKV.js.map +0 -1
  85. package/dist/chunk-T3L6OCM3.js +0 -3
  86. package/dist/chunk-T3L6OCM3.js.map +0 -1
  87. package/dist/chunk-TYVG6TXQ.js +0 -2
  88. package/dist/chunk-TYVG6TXQ.js.map +0 -1
  89. package/dist/chunk-V5MKJT6S.js +0 -2
  90. package/dist/chunk-V5MKJT6S.js.map +0 -1
  91. package/dist/kyber-NONMBQNH.js +0 -2
  92. package/dist/verifier-XU2DB56Z.js +0 -2
@@ -0,0 +1,104 @@
1
+ import { deriveLogicImageDigest } from './chunk-OUUTDSOW.js';
2
+ import { log } from './chunk-72MNYFR6.js';
3
+ import * as fs from 'fs';
4
+ import { createRequire } from 'module';
5
+ import path from 'path';
6
+ import { fileURLToPath, pathToFileURL } from 'url';
7
+ import { Piscina } from 'piscina';
8
+
9
+ var __filename$1 = fileURLToPath(import.meta.url);
10
+ var __dirname$1 = path.dirname(__filename$1);
11
+ var LiopVerifier = class _LiopVerifier {
12
+ // Singleton Worker Pool for heavy ZK verification
13
+ static zkWorkerPool = null;
14
+ getZkPool() {
15
+ if (!_LiopVerifier.zkWorkerPool) {
16
+ const isTS = import.meta.url.endsWith(".ts");
17
+ const workerExt = isTS ? ".ts" : ".js";
18
+ let execArgv = [];
19
+ if (isTS) {
20
+ try {
21
+ const req = createRequire(import.meta.url);
22
+ const tsxPkg = req.resolve("tsx/package.json");
23
+ const absoluteTsx = pathToFileURL(
24
+ path.join(path.dirname(tsxPkg), "dist", "loader.mjs")
25
+ ).href;
26
+ execArgv = ["--import", absoluteTsx];
27
+ } catch (_e) {
28
+ execArgv = ["--import", "tsx"];
29
+ }
30
+ }
31
+ const workerPaths = [
32
+ path.resolve(__dirname$1, `./workers/zk-verifier${workerExt}`),
33
+ // Flat dist/ (tsup)
34
+ path.resolve(__dirname$1, `../workers/zk-verifier${workerExt}`)
35
+ // Original src/
36
+ ];
37
+ const workerFilename = workerPaths.find((p) => fs.existsSync(p)) || workerPaths[1];
38
+ _LiopVerifier.zkWorkerPool = new Piscina({
39
+ filename: workerFilename,
40
+ minThreads: 1,
41
+ maxThreads: 2,
42
+ // Minimal footprint since verification is fast compared to generation
43
+ idleTimeout: 3e4,
44
+ execArgv
45
+ });
46
+ _LiopVerifier.zkWorkerPool.run({ action: "warmup" }).catch((err) => {
47
+ log.debug(
48
+ `[LiopVerifier] Verification pool warm-up ping failed: ${err.message}`
49
+ );
50
+ });
51
+ }
52
+ return _LiopVerifier.zkWorkerPool;
53
+ }
54
+ /**
55
+ * Verifies a Zero-Knowledge Receipt from a remote LIOP node via Worker Pool.
56
+ *
57
+ * @param logicPayload The raw WASM or JS logic that was sent to the provider.
58
+ * @param remoteImageIdHex The ImageID reported by the provider (must match our local calculation).
59
+ * @param zkReceipt The mathematical proof (Seal + Journal) from the zkVM.
60
+ */
61
+ async verifyZkReceipt(logicPayload, remoteImageIdHex, zkReceipt, sessionSecret, expectedOutput) {
62
+ const pool = this.getZkPool();
63
+ if (!pool) throw new Error("Worker pool initialization failed");
64
+ const result = await pool.run({
65
+ action: "verify_receipt",
66
+ logicPayload: new Uint8Array(logicPayload),
67
+ remoteImageIdHex,
68
+ zkReceipt: new Uint8Array(zkReceipt),
69
+ sessionSecret: sessionSecret ? new Uint8Array(sessionSecret) : void 0,
70
+ expectedOutput
71
+ });
72
+ if (result.verified) {
73
+ log.info(`[LiopVerifier] ${result.message}`);
74
+ return true;
75
+ }
76
+ log.error(`[LiopVerifier] FAILED: ${result.message}`);
77
+ return false;
78
+ }
79
+ /**
80
+ * Verifies if a node is running inside an authenticated TEE (e.g. AWS Nitro).
81
+ *
82
+ * @param attestationReport The COSE-signed attestation document from the hardware.
83
+ */
84
+ async verifyTeeAttestation(attestationReport) {
85
+ if (attestationReport.length === 0) return true;
86
+ try {
87
+ log.info("[LiopVerifier] TEE Attestation: Not configured (no-op).");
88
+ return true;
89
+ } catch (err) {
90
+ log.error("[LiopVerifier] TEE Verification Failed:", err);
91
+ return false;
92
+ }
93
+ }
94
+ /**
95
+ * Derives the ImageID of a logic payload following the LIOP v1 Standard.
96
+ */
97
+ deriveImageId(logicPayload) {
98
+ return deriveLogicImageDigest(logicPayload);
99
+ }
100
+ };
101
+
102
+ export { LiopVerifier };
103
+ //# sourceMappingURL=chunk-32ADSAJS.js.map
104
+ //# sourceMappingURL=chunk-32ADSAJS.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/crypto/verifier.ts"],"names":["__filename","__dirname"],"mappings":"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","file":"chunk-32ADSAJS.js","sourcesContent":["import * as fs from \"node:fs\";\nimport { createRequire } from \"node:module\";\nimport path from \"node:path\";\nimport { fileURLToPath, pathToFileURL } from \"node:url\";\nimport { Piscina } from \"piscina\";\nimport { log } from \"../utils/logger.js\";\nimport { deriveLogicImageDigest } from \"./logic-image-id.js\";\n\nconst __filename = fileURLToPath(import.meta.url);\nconst __dirname = path.dirname(__filename);\n\n/**\n * LIOP Tier-0 Industrial Verifier\n *\n * This engine is responsible for the trustless verification of remote logic execution.\n * It validates both the integrity of the code (ZkImageID) and the mathematical proof\n * of its execution (ZkSeal), as well as hardware-level attestation (TEE).\n */\nexport class LiopVerifier {\n\t// Singleton Worker Pool for heavy ZK verification\n\tprivate static zkWorkerPool: Piscina | null = null;\n\n\tprivate getZkPool() {\n\t\tif (!LiopVerifier.zkWorkerPool) {\n\t\t\tconst isTS = import.meta.url.endsWith(\".ts\");\n\t\t\tconst workerExt = isTS ? \".ts\" : \".js\";\n\n\t\t\tlet execArgv: string[] = [];\n\t\t\tif (isTS) {\n\t\t\t\ttry {\n\t\t\t\t\tconst req = createRequire(import.meta.url);\n\t\t\t\t\tconst tsxPkg = req.resolve(\"tsx/package.json\");\n\t\t\t\t\tconst absoluteTsx = pathToFileURL(\n\t\t\t\t\t\tpath.join(path.dirname(tsxPkg), \"dist\", \"loader.mjs\"),\n\t\t\t\t\t).href;\n\t\t\t\t\texecArgv = [\"--import\", absoluteTsx];\n\t\t\t\t} catch (_e) {\n\t\t\t\t\texecArgv = [\"--import\", \"tsx\"];\n\t\t\t\t}\n\t\t\t}\n\n\t\t\t// Support both flat dist/ and original src/ structure\n\t\t\tconst workerPaths = [\n\t\t\t\tpath.resolve(__dirname, `./workers/zk-verifier${workerExt}`), // Flat dist/ (tsup)\n\t\t\t\tpath.resolve(__dirname, `../workers/zk-verifier${workerExt}`), // Original src/\n\t\t\t];\n\n\t\t\tconst workerFilename =\n\t\t\t\tworkerPaths.find((p) => fs.existsSync(p)) || workerPaths[1];\n\n\t\t\tLiopVerifier.zkWorkerPool = new Piscina({\n\t\t\t\tfilename: workerFilename,\n\t\t\t\tminThreads: 1,\n\t\t\t\tmaxThreads: 2, // Minimal footprint since verification is fast compared to generation\n\t\t\t\tidleTimeout: 30000,\n\t\t\t\texecArgv,\n\t\t\t});\n\n\t\t\t// Pre-warm the verification worker\n\t\t\tLiopVerifier.zkWorkerPool.run({ action: \"warmup\" }).catch((err) => {\n\t\t\t\tlog.debug(\n\t\t\t\t\t`[LiopVerifier] Verification pool warm-up ping failed: ${err.message}`,\n\t\t\t\t);\n\t\t\t});\n\t\t}\n\t\treturn LiopVerifier.zkWorkerPool;\n\t}\n\n\t/**\n\t * Verifies a Zero-Knowledge Receipt from a remote LIOP node via Worker Pool.\n\t *\n\t * @param logicPayload The raw WASM or JS logic that was sent to the provider.\n\t * @param remoteImageIdHex The ImageID reported by the provider (must match our local calculation).\n\t * @param zkReceipt The mathematical proof (Seal + Journal) from the zkVM.\n\t */\n\tpublic async verifyZkReceipt(\n\t\tlogicPayload: Buffer,\n\t\tremoteImageIdHex: string,\n\t\tzkReceipt: Buffer,\n\t\tsessionSecret?: Buffer,\n\t\texpectedOutput?: unknown,\n\t): Promise<boolean> {\n\t\tconst pool = this.getZkPool();\n\t\tif (!pool) throw new Error(\"Worker pool initialization failed\");\n\t\tconst result = await pool.run({\n\t\t\taction: \"verify_receipt\",\n\t\t\tlogicPayload: new Uint8Array(logicPayload),\n\t\t\tremoteImageIdHex,\n\t\t\tzkReceipt: new Uint8Array(zkReceipt),\n\t\t\tsessionSecret: sessionSecret ? new Uint8Array(sessionSecret) : undefined,\n\t\t\texpectedOutput,\n\t\t});\n\n\t\tif (result.verified) {\n\t\t\tlog.info(`[LiopVerifier] ${result.message}`);\n\t\t\treturn true;\n\t\t}\n\n\t\tlog.error(`[LiopVerifier] FAILED: ${result.message}`);\n\t\treturn false;\n\t}\n\n\t/**\n\t * Verifies if a node is running inside an authenticated TEE (e.g. AWS Nitro).\n\t *\n\t * @param attestationReport The COSE-signed attestation document from the hardware.\n\t */\n\tpublic async verifyTeeAttestation(\n\t\tattestationReport: Buffer,\n\t): Promise<boolean> {\n\t\tif (attestationReport.length === 0) return true; // Optional in Mesh Alpha\n\n\t\ttry {\n\t\t\t// Architecture for AWS Nitro Enclaves:\n\t\t\t// 1. Decode CBOR/COSE\n\t\t\t// 2. Verify Signature against AWS Nitro Root CA\n\t\t\t// 3. Compare PCRs\n\t\t\tlog.info(\"[LiopVerifier] TEE Attestation: Not configured (no-op).\");\n\t\t\treturn true;\n\t\t} catch (err) {\n\t\t\tlog.error(\"[LiopVerifier] TEE Verification Failed:\", err);\n\t\t\treturn false;\n\t\t}\n\t}\n\n\t/**\n\t * Derives the ImageID of a logic payload following the LIOP v1 Standard.\n\t */\n\tpublic deriveImageId(logicPayload: Buffer): Buffer {\n\t\treturn deriveLogicImageDigest(logicPayload);\n\t}\n}\n"]}
@@ -0,0 +1,64 @@
1
+ // src/utils/logger.ts
2
+ var LiopLogger = class _LiopLogger {
3
+ static instance;
4
+ level = "info";
5
+ constructor() {
6
+ this.setLevelFromEnv();
7
+ }
8
+ static getInstance() {
9
+ if (!_LiopLogger.instance) {
10
+ _LiopLogger.instance = new _LiopLogger();
11
+ }
12
+ return _LiopLogger.instance;
13
+ }
14
+ setLevelFromEnv() {
15
+ const envLevel = process.env.LIOP_LOG_LEVEL?.toLowerCase();
16
+ if (envLevel === "silent" || envLevel === "error" || envLevel === "warn" || envLevel === "info" || envLevel === "debug") {
17
+ this.level = envLevel;
18
+ } else {
19
+ this.level = "info";
20
+ }
21
+ }
22
+ setLevel(level) {
23
+ this.level = level;
24
+ }
25
+ shouldLog(targetLevel) {
26
+ const levels = {
27
+ silent: 0,
28
+ error: 1,
29
+ warn: 2,
30
+ info: 3,
31
+ debug: 4
32
+ };
33
+ return levels[this.level] >= levels[targetLevel];
34
+ }
35
+ formatMessage(level, message) {
36
+ const ts = (/* @__PURE__ */ new Date()).toISOString();
37
+ return `[${ts}] [${level}] ${message}`;
38
+ }
39
+ error(message, ...args) {
40
+ if (this.shouldLog("error")) {
41
+ console.error(this.formatMessage("ERROR", message), ...args);
42
+ }
43
+ }
44
+ warn(message, ...args) {
45
+ if (this.shouldLog("warn")) {
46
+ console.error(this.formatMessage("WARN", message), ...args);
47
+ }
48
+ }
49
+ info(message, ...args) {
50
+ if (this.shouldLog("info")) {
51
+ console.error(this.formatMessage("INFO", message), ...args);
52
+ }
53
+ }
54
+ debug(message, ...args) {
55
+ if (this.shouldLog("debug")) {
56
+ console.error(this.formatMessage("DEBUG", message), ...args);
57
+ }
58
+ }
59
+ };
60
+ var log = LiopLogger.getInstance();
61
+
62
+ export { log };
63
+ //# sourceMappingURL=chunk-72MNYFR6.js.map
64
+ //# sourceMappingURL=chunk-72MNYFR6.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/utils/logger.ts"],"names":[],"mappings":";AAOO,IAAM,UAAA,GAAN,MAAM,WAAA,CAAW;AAAA,EACvB,OAAe,QAAA;AAAA,EACP,KAAA,GAAkB,MAAA;AAAA,EAElB,WAAA,GAAc;AACrB,IAAA,IAAA,CAAK,eAAA,EAAgB;AAAA,EACtB;AAAA,EAEA,OAAc,WAAA,GAA0B;AACvC,IAAA,IAAI,CAAC,YAAW,QAAA,EAAU;AACzB,MAAA,WAAA,CAAW,QAAA,GAAW,IAAI,WAAA,EAAW;AAAA,IACtC;AACA,IAAA,OAAO,WAAA,CAAW,QAAA;AAAA,EACnB;AAAA,EAEQ,eAAA,GAAkB;AACzB,IAAA,MAAM,QAAA,GAAW,OAAA,CAAQ,GAAA,CAAI,cAAA,EAAgB,WAAA,EAAY;AACzD,IAAA,IACC,QAAA,KAAa,YACb,QAAA,KAAa,OAAA,IACb,aAAa,MAAA,IACb,QAAA,KAAa,MAAA,IACb,QAAA,KAAa,OAAA,EACZ;AACD,MAAA,IAAA,CAAK,KAAA,GAAQ,QAAA;AAAA,IACd,CAAA,MAAO;AAEN,MAAA,IAAA,CAAK,KAAA,GAAQ,MAAA;AAAA,IACd;AAAA,EACD;AAAA,EAEO,SAAS,KAAA,EAAiB;AAChC,IAAA,IAAA,CAAK,KAAA,GAAQ,KAAA;AAAA,EACd;AAAA,EAEQ,UAAU,WAAA,EAAgC;AACjD,IAAA,MAAM,MAAA,GAAmC;AAAA,MACxC,MAAA,EAAQ,CAAA;AAAA,MACR,KAAA,EAAO,CAAA;AAAA,MACP,IAAA,EAAM,CAAA;AAAA,MACN,IAAA,EAAM,CAAA;AAAA,MACN,KAAA,EAAO;AAAA,KACR;AACA,IAAA,OAAO,MAAA,CAAO,IAAA,CAAK,KAAK,CAAA,IAAK,OAAO,WAAW,CAAA;AAAA,EAChD;AAAA,EAEQ,aAAA,CAAc,OAAe,OAAA,EAAyB;AAC7D,IAAA,MAAM,EAAA,GAAA,iBAAK,IAAI,IAAA,EAAK,EAAE,WAAA,EAAY;AAClC,IAAA,OAAO,CAAA,CAAA,EAAI,EAAE,CAAA,GAAA,EAAM,KAAK,KAAK,OAAO,CAAA,CAAA;AAAA,EACrC;AAAA,EAEO,KAAA,CAAM,YAAoB,IAAA,EAAiB;AACjD,IAAA,IAAI,IAAA,CAAK,SAAA,CAAU,OAAO,CAAA,EAAG;AAC5B,MAAA,OAAA,CAAQ,MAAM,IAAA,CAAK,aAAA,CAAc,SAAS,OAAO,CAAA,EAAG,GAAG,IAAI,CAAA;AAAA,IAC5D;AAAA,EACD;AAAA,EAEO,IAAA,CAAK,YAAoB,IAAA,EAAiB;AAChD,IAAA,IAAI,IAAA,CAAK,SAAA,CAAU,MAAM,CAAA,EAAG;AAC3B,MAAA,OAAA,CAAQ,MAAM,IAAA,CAAK,aAAA,CAAc,QAAQ,OAAO,CAAA,EAAG,GAAG,IAAI,CAAA;AAAA,IAC3D;AAAA,EACD;AAAA,EAEO,IAAA,CAAK,YAAoB,IAAA,EAAiB;AAChD,IAAA,IAAI,IAAA,CAAK,SAAA,CAAU,MAAM,CAAA,EAAG;AAC3B,MAAA,OAAA,CAAQ,MAAM,IAAA,CAAK,aAAA,CAAc,QAAQ,OAAO,CAAA,EAAG,GAAG,IAAI,CAAA;AAAA,IAC3D;AAAA,EACD;AAAA,EAEO,KAAA,CAAM,YAAoB,IAAA,EAAiB;AACjD,IAAA,IAAI,IAAA,CAAK,SAAA,CAAU,OAAO,CAAA,EAAG;AAC5B,MAAA,OAAA,CAAQ,MAAM,IAAA,CAAK,aAAA,CAAc,SAAS,OAAO,CAAA,EAAG,GAAG,IAAI,CAAA;AAAA,IAC5D;AAAA,EACD;AACD,CAAA;AAEO,IAAM,GAAA,GAAM,WAAW,WAAA","file":"chunk-72MNYFR6.js","sourcesContent":["export type LogLevel = \"silent\" | \"error\" | \"warn\" | \"info\" | \"debug\";\n\n/**\n * LiopLogger - Structured Logging Abstraction\n * Configurable via `process.env.LIOP_LOG_LEVEL`.\n * Emits strictly to stderr to comply with MCP stdio protocols.\n */\nexport class LiopLogger {\n\tprivate static instance: LiopLogger;\n\tprivate level: LogLevel = \"info\";\n\n\tprivate constructor() {\n\t\tthis.setLevelFromEnv();\n\t}\n\n\tpublic static getInstance(): LiopLogger {\n\t\tif (!LiopLogger.instance) {\n\t\t\tLiopLogger.instance = new LiopLogger();\n\t\t}\n\t\treturn LiopLogger.instance;\n\t}\n\n\tprivate setLevelFromEnv() {\n\t\tconst envLevel = process.env.LIOP_LOG_LEVEL?.toLowerCase();\n\t\tif (\n\t\t\tenvLevel === \"silent\" ||\n\t\t\tenvLevel === \"error\" ||\n\t\t\tenvLevel === \"warn\" ||\n\t\t\tenvLevel === \"info\" ||\n\t\t\tenvLevel === \"debug\"\n\t\t) {\n\t\t\tthis.level = envLevel as LogLevel;\n\t\t} else {\n\t\t\t// Default level: info\n\t\t\tthis.level = \"info\";\n\t\t}\n\t}\n\n\tpublic setLevel(level: LogLevel) {\n\t\tthis.level = level;\n\t}\n\n\tprivate shouldLog(targetLevel: LogLevel): boolean {\n\t\tconst levels: Record<LogLevel, number> = {\n\t\t\tsilent: 0,\n\t\t\terror: 1,\n\t\t\twarn: 2,\n\t\t\tinfo: 3,\n\t\t\tdebug: 4,\n\t\t};\n\t\treturn levels[this.level] >= levels[targetLevel];\n\t}\n\n\tprivate formatMessage(level: string, message: string): string {\n\t\tconst ts = new Date().toISOString();\n\t\treturn `[${ts}] [${level}] ${message}`;\n\t}\n\n\tpublic error(message: string, ...args: unknown[]) {\n\t\tif (this.shouldLog(\"error\")) {\n\t\t\tconsole.error(this.formatMessage(\"ERROR\", message), ...args);\n\t\t}\n\t}\n\n\tpublic warn(message: string, ...args: unknown[]) {\n\t\tif (this.shouldLog(\"warn\")) {\n\t\t\tconsole.error(this.formatMessage(\"WARN\", message), ...args);\n\t\t}\n\t}\n\n\tpublic info(message: string, ...args: unknown[]) {\n\t\tif (this.shouldLog(\"info\")) {\n\t\t\tconsole.error(this.formatMessage(\"INFO\", message), ...args);\n\t\t}\n\t}\n\n\tpublic debug(message: string, ...args: unknown[]) {\n\t\tif (this.shouldLog(\"debug\")) {\n\t\t\tconsole.error(this.formatMessage(\"DEBUG\", message), ...args);\n\t\t}\n\t}\n}\n\nexport const log = LiopLogger.getInstance();\n"]}
@@ -0,0 +1,30 @@
1
+ import { z } from 'zod';
2
+
3
+ // src/types.ts
4
+ var ToolSchema = z.object({
5
+ name: z.string(),
6
+ description: z.string().optional(),
7
+ inputSchema: z.record(z.string(), z.unknown())
8
+ // Represents a JSON Schema
9
+ });
10
+ var ResourceSchema = z.object({
11
+ uri: z.string(),
12
+ name: z.string(),
13
+ description: z.string().optional(),
14
+ mimeType: z.string().optional()
15
+ });
16
+ var PromptSchema = z.object({
17
+ name: z.string(),
18
+ description: z.string().optional(),
19
+ arguments: z.array(
20
+ z.object({
21
+ name: z.string(),
22
+ description: z.string().optional(),
23
+ required: z.boolean().optional()
24
+ })
25
+ ).optional()
26
+ });
27
+
28
+ export { PromptSchema, ResourceSchema, ToolSchema };
29
+ //# sourceMappingURL=chunk-CT6NHSYP.js.map
30
+ //# sourceMappingURL=chunk-CT6NHSYP.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/types.ts"],"names":[],"mappings":";;;AAMO,IAAM,UAAA,GAAa,EAAE,MAAA,CAAO;AAAA,EAClC,IAAA,EAAM,EAAE,MAAA,EAAO;AAAA,EACf,WAAA,EAAa,CAAA,CAAE,MAAA,EAAO,CAAE,QAAA,EAAS;AAAA,EACjC,WAAA,EAAa,EAAE,MAAA,CAAO,CAAA,CAAE,QAAO,EAAG,CAAA,CAAE,SAAS;AAAA;AAC9C,CAAC;AAIM,IAAM,cAAA,GAAiB,EAAE,MAAA,CAAO;AAAA,EACtC,GAAA,EAAK,EAAE,MAAA,EAAO;AAAA,EACd,IAAA,EAAM,EAAE,MAAA,EAAO;AAAA,EACf,WAAA,EAAa,CAAA,CAAE,MAAA,EAAO,CAAE,QAAA,EAAS;AAAA,EACjC,QAAA,EAAU,CAAA,CAAE,MAAA,EAAO,CAAE,QAAA;AACtB,CAAC;AAIM,IAAM,YAAA,GAAe,EAAE,MAAA,CAAO;AAAA,EACpC,IAAA,EAAM,EAAE,MAAA,EAAO;AAAA,EACf,WAAA,EAAa,CAAA,CAAE,MAAA,EAAO,CAAE,QAAA,EAAS;AAAA,EACjC,WAAW,CAAA,CACT,KAAA;AAAA,IACA,EAAE,MAAA,CAAO;AAAA,MACR,IAAA,EAAM,EAAE,MAAA,EAAO;AAAA,MACf,WAAA,EAAa,CAAA,CAAE,MAAA,EAAO,CAAE,QAAA,EAAS;AAAA,MACjC,QAAA,EAAU,CAAA,CAAE,OAAA,EAAQ,CAAE,QAAA;AAAS,KAC/B;AAAA,IAED,QAAA;AACH,CAAC","file":"chunk-CT6NHSYP.js","sourcesContent":["import { z } from \"zod\";\n\n/**\n * Base Protocol Types representing parity with Model Context Protocol\n */\n\nexport const ToolSchema = z.object({\n\tname: z.string(),\n\tdescription: z.string().optional(),\n\tinputSchema: z.record(z.string(), z.unknown()), // Represents a JSON Schema\n});\n\nexport type Tool = z.infer<typeof ToolSchema>;\n\nexport const ResourceSchema = z.object({\n\turi: z.string(),\n\tname: z.string(),\n\tdescription: z.string().optional(),\n\tmimeType: z.string().optional(),\n});\n\nexport type Resource = z.infer<typeof ResourceSchema>;\n\nexport const PromptSchema = z.object({\n\tname: z.string(),\n\tdescription: z.string().optional(),\n\targuments: z\n\t\t.array(\n\t\t\tz.object({\n\t\t\t\tname: z.string(),\n\t\t\t\tdescription: z.string().optional(),\n\t\t\t\trequired: z.boolean().optional(),\n\t\t\t}),\n\t\t)\n\t\t.optional(),\n});\n\nexport type Prompt = z.infer<typeof PromptSchema>;\n\nexport interface CallToolRequest {\n\tname: string;\n\targuments?: Record<string, unknown>;\n}\n\nexport interface CallToolResult {\n\tcontent: Array<{\n\t\ttype: \"text\" | \"image\" | \"resource\";\n\t\ttext?: string;\n\t\tdata?: string;\n\t\tmimeType?: string;\n\t\tresource?: {\n\t\t\turi: string;\n\t\t\ttext?: string;\n\t\t\tblob?: string;\n\t\t};\n\t}>;\n\tisError?: boolean;\n}\n\nexport interface GetPromptRequest {\n\tname: string;\n\targuments?: Record<string, string>;\n}\n\nexport interface GetPromptResult {\n\tdescription?: string;\n\tmessages: Array<{\n\t\trole: \"user\" | \"assistant\";\n\t\tcontent:\n\t\t\t| { type: \"text\"; text: string }\n\t\t\t| { type: \"image\"; data: string; mimeType: string }\n\t\t\t| {\n\t\t\t\t\ttype: \"resource\";\n\t\t\t\t\tresource: { uri: string; text?: string; blob?: string };\n\t\t\t };\n\t}>;\n}\n\nexport interface ServerInfo {\n\tname: string;\n\tversion: string;\n\tcapabilities?: {\n\t\tprompts?: { listChanged?: boolean };\n\t\tresources?: { subscribe?: boolean; listChanged?: boolean };\n\t\ttools?: { listChanged?: boolean };\n\t\tlogging?: Record<string, unknown>;\n\t};\n}\n\nexport interface McpRequest {\n\tmethod: string;\n\tparams?: unknown;\n\tid?: string | number | null;\n\tjsonrpc?: \"2.0\";\n}\n\nexport interface McpResponse {\n\tjsonrpc: \"2.0\";\n\tid?: string | number | null;\n\tresult?: unknown;\n\terror?: {\n\t\tcode: number;\n\t\tmessage: string;\n\t\tdata?: unknown;\n\t};\n}\n\n/**\n * Re-export AuthInfo from the security module for convenience.\n * Compatible with MCP TypeScript SDK AuthInfo interface shape.\n */\nexport type { AuthInfo } from \"./security/jwt-validator.js\";\n"]}