@oobe-protocol-labs/synapse-sap-sdk 0.1.0

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 (315) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +882 -0
  3. package/dist/cjs/constants/index.js +43 -0
  4. package/dist/cjs/constants/index.js.map +1 -0
  5. package/dist/cjs/constants/limits.js +161 -0
  6. package/dist/cjs/constants/limits.js.map +1 -0
  7. package/dist/cjs/constants/programs.js +78 -0
  8. package/dist/cjs/constants/programs.js.map +1 -0
  9. package/dist/cjs/constants/seeds.js +57 -0
  10. package/dist/cjs/constants/seeds.js.map +1 -0
  11. package/dist/cjs/core/client.js +391 -0
  12. package/dist/cjs/core/client.js.map +1 -0
  13. package/dist/cjs/core/connection.js +319 -0
  14. package/dist/cjs/core/connection.js.map +1 -0
  15. package/dist/cjs/core/index.js +24 -0
  16. package/dist/cjs/core/index.js.map +1 -0
  17. package/dist/cjs/errors/index.js +334 -0
  18. package/dist/cjs/errors/index.js.map +1 -0
  19. package/dist/cjs/events/index.js +136 -0
  20. package/dist/cjs/events/index.js.map +1 -0
  21. package/dist/cjs/idl/index.js +63 -0
  22. package/dist/cjs/idl/index.js.map +1 -0
  23. package/dist/cjs/idl/synapse_agent_sap.json +9710 -0
  24. package/dist/cjs/index.js +147 -0
  25. package/dist/cjs/index.js.map +1 -0
  26. package/dist/cjs/modules/agent.js +272 -0
  27. package/dist/cjs/modules/agent.js.map +1 -0
  28. package/dist/cjs/modules/attestation.js +147 -0
  29. package/dist/cjs/modules/attestation.js.map +1 -0
  30. package/dist/cjs/modules/base.js +128 -0
  31. package/dist/cjs/modules/base.js.map +1 -0
  32. package/dist/cjs/modules/escrow.js +246 -0
  33. package/dist/cjs/modules/escrow.js.map +1 -0
  34. package/dist/cjs/modules/feedback.js +166 -0
  35. package/dist/cjs/modules/feedback.js.map +1 -0
  36. package/dist/cjs/modules/index.js +35 -0
  37. package/dist/cjs/modules/index.js.map +1 -0
  38. package/dist/cjs/modules/indexing.js +375 -0
  39. package/dist/cjs/modules/indexing.js.map +1 -0
  40. package/dist/cjs/modules/ledger.js +234 -0
  41. package/dist/cjs/modules/ledger.js.map +1 -0
  42. package/dist/cjs/modules/tools.js +319 -0
  43. package/dist/cjs/modules/tools.js.map +1 -0
  44. package/dist/cjs/modules/vault.js +410 -0
  45. package/dist/cjs/modules/vault.js.map +1 -0
  46. package/dist/cjs/pda/index.js +377 -0
  47. package/dist/cjs/pda/index.js.map +1 -0
  48. package/dist/cjs/plugin/index.js +934 -0
  49. package/dist/cjs/plugin/index.js.map +1 -0
  50. package/dist/cjs/plugin/protocols.js +282 -0
  51. package/dist/cjs/plugin/protocols.js.map +1 -0
  52. package/dist/cjs/plugin/schemas.js +831 -0
  53. package/dist/cjs/plugin/schemas.js.map +1 -0
  54. package/dist/cjs/postgres/adapter.js +715 -0
  55. package/dist/cjs/postgres/adapter.js.map +1 -0
  56. package/dist/cjs/postgres/index.js +50 -0
  57. package/dist/cjs/postgres/index.js.map +1 -0
  58. package/dist/cjs/postgres/serializers.js +381 -0
  59. package/dist/cjs/postgres/serializers.js.map +1 -0
  60. package/dist/cjs/postgres/sync.js +221 -0
  61. package/dist/cjs/postgres/sync.js.map +1 -0
  62. package/dist/cjs/postgres/types.js +44 -0
  63. package/dist/cjs/postgres/types.js.map +1 -0
  64. package/dist/cjs/registries/builder.js +414 -0
  65. package/dist/cjs/registries/builder.js.map +1 -0
  66. package/dist/cjs/registries/discovery.js +362 -0
  67. package/dist/cjs/registries/discovery.js.map +1 -0
  68. package/dist/cjs/registries/index.js +51 -0
  69. package/dist/cjs/registries/index.js.map +1 -0
  70. package/dist/cjs/registries/session.js +433 -0
  71. package/dist/cjs/registries/session.js.map +1 -0
  72. package/dist/cjs/registries/x402.js +577 -0
  73. package/dist/cjs/registries/x402.js.map +1 -0
  74. package/dist/cjs/types/accounts.js +13 -0
  75. package/dist/cjs/types/accounts.js.map +1 -0
  76. package/dist/cjs/types/common.js +13 -0
  77. package/dist/cjs/types/common.js.map +1 -0
  78. package/dist/cjs/types/enums.js +174 -0
  79. package/dist/cjs/types/enums.js.map +1 -0
  80. package/dist/cjs/types/index.js +36 -0
  81. package/dist/cjs/types/index.js.map +1 -0
  82. package/dist/cjs/types/instructions.js +92 -0
  83. package/dist/cjs/types/instructions.js.map +1 -0
  84. package/dist/cjs/utils/hash.js +58 -0
  85. package/dist/cjs/utils/hash.js.map +1 -0
  86. package/dist/cjs/utils/index.js +27 -0
  87. package/dist/cjs/utils/index.js.map +1 -0
  88. package/dist/cjs/utils/serialization.js +105 -0
  89. package/dist/cjs/utils/serialization.js.map +1 -0
  90. package/dist/cjs/utils/validation.js +36 -0
  91. package/dist/cjs/utils/validation.js.map +1 -0
  92. package/dist/esm/constants/index.js +29 -0
  93. package/dist/esm/constants/index.js.map +1 -0
  94. package/dist/esm/constants/limits.js +158 -0
  95. package/dist/esm/constants/limits.js.map +1 -0
  96. package/dist/esm/constants/programs.js +75 -0
  97. package/dist/esm/constants/programs.js.map +1 -0
  98. package/dist/esm/constants/seeds.js +54 -0
  99. package/dist/esm/constants/seeds.js.map +1 -0
  100. package/dist/esm/core/client.js +384 -0
  101. package/dist/esm/core/client.js.map +1 -0
  102. package/dist/esm/core/connection.js +315 -0
  103. package/dist/esm/core/connection.js.map +1 -0
  104. package/dist/esm/core/index.js +19 -0
  105. package/dist/esm/core/index.js.map +1 -0
  106. package/dist/esm/errors/index.js +325 -0
  107. package/dist/esm/errors/index.js.map +1 -0
  108. package/dist/esm/events/index.js +132 -0
  109. package/dist/esm/events/index.js.map +1 -0
  110. package/dist/esm/idl/index.js +57 -0
  111. package/dist/esm/idl/index.js.map +1 -0
  112. package/dist/esm/idl/synapse_agent_sap.json +9710 -0
  113. package/dist/esm/index.js +70 -0
  114. package/dist/esm/index.js.map +1 -0
  115. package/dist/esm/modules/agent.js +268 -0
  116. package/dist/esm/modules/agent.js.map +1 -0
  117. package/dist/esm/modules/attestation.js +143 -0
  118. package/dist/esm/modules/attestation.js.map +1 -0
  119. package/dist/esm/modules/base.js +124 -0
  120. package/dist/esm/modules/base.js.map +1 -0
  121. package/dist/esm/modules/escrow.js +242 -0
  122. package/dist/esm/modules/escrow.js.map +1 -0
  123. package/dist/esm/modules/feedback.js +162 -0
  124. package/dist/esm/modules/feedback.js.map +1 -0
  125. package/dist/esm/modules/index.js +23 -0
  126. package/dist/esm/modules/index.js.map +1 -0
  127. package/dist/esm/modules/indexing.js +371 -0
  128. package/dist/esm/modules/indexing.js.map +1 -0
  129. package/dist/esm/modules/ledger.js +230 -0
  130. package/dist/esm/modules/ledger.js.map +1 -0
  131. package/dist/esm/modules/tools.js +315 -0
  132. package/dist/esm/modules/tools.js.map +1 -0
  133. package/dist/esm/modules/vault.js +406 -0
  134. package/dist/esm/modules/vault.js.map +1 -0
  135. package/dist/esm/pda/index.js +357 -0
  136. package/dist/esm/pda/index.js.map +1 -0
  137. package/dist/esm/plugin/index.js +927 -0
  138. package/dist/esm/plugin/index.js.map +1 -0
  139. package/dist/esm/plugin/protocols.js +279 -0
  140. package/dist/esm/plugin/protocols.js.map +1 -0
  141. package/dist/esm/plugin/schemas.js +828 -0
  142. package/dist/esm/plugin/schemas.js.map +1 -0
  143. package/dist/esm/postgres/adapter.js +678 -0
  144. package/dist/esm/postgres/adapter.js.map +1 -0
  145. package/dist/esm/postgres/index.js +27 -0
  146. package/dist/esm/postgres/index.js.map +1 -0
  147. package/dist/esm/postgres/serializers.js +362 -0
  148. package/dist/esm/postgres/serializers.js.map +1 -0
  149. package/dist/esm/postgres/sync.js +217 -0
  150. package/dist/esm/postgres/sync.js.map +1 -0
  151. package/dist/esm/postgres/types.js +41 -0
  152. package/dist/esm/postgres/types.js.map +1 -0
  153. package/dist/esm/registries/builder.js +410 -0
  154. package/dist/esm/registries/builder.js.map +1 -0
  155. package/dist/esm/registries/discovery.js +358 -0
  156. package/dist/esm/registries/discovery.js.map +1 -0
  157. package/dist/esm/registries/index.js +44 -0
  158. package/dist/esm/registries/index.js.map +1 -0
  159. package/dist/esm/registries/session.js +429 -0
  160. package/dist/esm/registries/session.js.map +1 -0
  161. package/dist/esm/registries/x402.js +573 -0
  162. package/dist/esm/registries/x402.js.map +1 -0
  163. package/dist/esm/types/accounts.js +12 -0
  164. package/dist/esm/types/accounts.js.map +1 -0
  165. package/dist/esm/types/common.js +12 -0
  166. package/dist/esm/types/common.js.map +1 -0
  167. package/dist/esm/types/enums.js +171 -0
  168. package/dist/esm/types/enums.js.map +1 -0
  169. package/dist/esm/types/index.js +25 -0
  170. package/dist/esm/types/index.js.map +1 -0
  171. package/dist/esm/types/instructions.js +89 -0
  172. package/dist/esm/types/instructions.js.map +1 -0
  173. package/dist/esm/utils/hash.js +53 -0
  174. package/dist/esm/utils/hash.js.map +1 -0
  175. package/dist/esm/utils/index.js +19 -0
  176. package/dist/esm/utils/index.js.map +1 -0
  177. package/dist/esm/utils/serialization.js +98 -0
  178. package/dist/esm/utils/serialization.js.map +1 -0
  179. package/dist/esm/utils/validation.js +33 -0
  180. package/dist/esm/utils/validation.js.map +1 -0
  181. package/dist/types/constants/index.d.ts +27 -0
  182. package/dist/types/constants/index.d.ts.map +1 -0
  183. package/dist/types/constants/limits.d.ts +149 -0
  184. package/dist/types/constants/limits.d.ts.map +1 -0
  185. package/dist/types/constants/programs.d.ts +69 -0
  186. package/dist/types/constants/programs.d.ts.map +1 -0
  187. package/dist/types/constants/seeds.d.ts +61 -0
  188. package/dist/types/constants/seeds.d.ts.map +1 -0
  189. package/dist/types/core/client.d.ts +323 -0
  190. package/dist/types/core/client.d.ts.map +1 -0
  191. package/dist/types/core/connection.d.ts +279 -0
  192. package/dist/types/core/connection.d.ts.map +1 -0
  193. package/dist/types/core/index.d.ts +20 -0
  194. package/dist/types/core/index.d.ts.map +1 -0
  195. package/dist/types/errors/index.d.ts +276 -0
  196. package/dist/types/errors/index.d.ts.map +1 -0
  197. package/dist/types/events/index.d.ts +248 -0
  198. package/dist/types/events/index.d.ts.map +1 -0
  199. package/dist/types/idl/index.d.ts +70 -0
  200. package/dist/types/idl/index.d.ts.map +1 -0
  201. package/dist/types/index.d.ts +68 -0
  202. package/dist/types/index.d.ts.map +1 -0
  203. package/dist/types/modules/agent.d.ts +166 -0
  204. package/dist/types/modules/agent.d.ts.map +1 -0
  205. package/dist/types/modules/attestation.d.ts +96 -0
  206. package/dist/types/modules/attestation.d.ts.map +1 -0
  207. package/dist/types/modules/base.d.ts +126 -0
  208. package/dist/types/modules/base.d.ts.map +1 -0
  209. package/dist/types/modules/escrow.d.ts +151 -0
  210. package/dist/types/modules/escrow.d.ts.map +1 -0
  211. package/dist/types/modules/feedback.d.ts +105 -0
  212. package/dist/types/modules/feedback.d.ts.map +1 -0
  213. package/dist/types/modules/index.d.ts +24 -0
  214. package/dist/types/modules/index.d.ts.map +1 -0
  215. package/dist/types/modules/indexing.d.ts +200 -0
  216. package/dist/types/modules/indexing.d.ts.map +1 -0
  217. package/dist/types/modules/ledger.d.ts +150 -0
  218. package/dist/types/modules/ledger.d.ts.map +1 -0
  219. package/dist/types/modules/tools.d.ts +182 -0
  220. package/dist/types/modules/tools.d.ts.map +1 -0
  221. package/dist/types/modules/vault.d.ts +240 -0
  222. package/dist/types/modules/vault.d.ts.map +1 -0
  223. package/dist/types/pda/index.d.ts +296 -0
  224. package/dist/types/pda/index.d.ts.map +1 -0
  225. package/dist/types/plugin/index.d.ts +171 -0
  226. package/dist/types/plugin/index.d.ts.map +1 -0
  227. package/dist/types/plugin/protocols.d.ts +152 -0
  228. package/dist/types/plugin/protocols.d.ts.map +1 -0
  229. package/dist/types/plugin/schemas.d.ts +823 -0
  230. package/dist/types/plugin/schemas.d.ts.map +1 -0
  231. package/dist/types/postgres/adapter.d.ts +355 -0
  232. package/dist/types/postgres/adapter.d.ts.map +1 -0
  233. package/dist/types/postgres/index.d.ts +24 -0
  234. package/dist/types/postgres/index.d.ts.map +1 -0
  235. package/dist/types/postgres/serializers.d.ts +30 -0
  236. package/dist/types/postgres/serializers.d.ts.map +1 -0
  237. package/dist/types/postgres/sync.d.ts +132 -0
  238. package/dist/types/postgres/sync.d.ts.map +1 -0
  239. package/dist/types/postgres/types.d.ts +167 -0
  240. package/dist/types/postgres/types.d.ts.map +1 -0
  241. package/dist/types/registries/builder.d.ts +340 -0
  242. package/dist/types/registries/builder.d.ts.map +1 -0
  243. package/dist/types/registries/discovery.d.ts +333 -0
  244. package/dist/types/registries/discovery.d.ts.map +1 -0
  245. package/dist/types/registries/index.d.ts +48 -0
  246. package/dist/types/registries/index.d.ts.map +1 -0
  247. package/dist/types/registries/session.d.ts +323 -0
  248. package/dist/types/registries/session.d.ts.map +1 -0
  249. package/dist/types/registries/x402.d.ts +463 -0
  250. package/dist/types/registries/x402.d.ts.map +1 -0
  251. package/dist/types/types/accounts.d.ts +565 -0
  252. package/dist/types/types/accounts.d.ts.map +1 -0
  253. package/dist/types/types/common.d.ts +166 -0
  254. package/dist/types/types/common.d.ts.map +1 -0
  255. package/dist/types/types/enums.d.ts +238 -0
  256. package/dist/types/types/enums.d.ts.map +1 -0
  257. package/dist/types/types/index.d.ts +28 -0
  258. package/dist/types/types/index.d.ts.map +1 -0
  259. package/dist/types/types/instructions.d.ts +366 -0
  260. package/dist/types/types/instructions.d.ts.map +1 -0
  261. package/dist/types/utils/hash.d.ts +48 -0
  262. package/dist/types/utils/hash.d.ts.map +1 -0
  263. package/dist/types/utils/index.d.ts +19 -0
  264. package/dist/types/utils/index.d.ts.map +1 -0
  265. package/dist/types/utils/serialization.d.ts +69 -0
  266. package/dist/types/utils/serialization.d.ts.map +1 -0
  267. package/dist/types/utils/validation.d.ts +29 -0
  268. package/dist/types/utils/validation.d.ts.map +1 -0
  269. package/package.json +178 -0
  270. package/src/constants/index.ts +44 -0
  271. package/src/constants/limits.ts +165 -0
  272. package/src/constants/programs.ts +83 -0
  273. package/src/constants/seeds.ts +66 -0
  274. package/src/core/client.ts +416 -0
  275. package/src/core/connection.ts +409 -0
  276. package/src/core/index.ts +20 -0
  277. package/src/errors/index.ts +346 -0
  278. package/src/events/index.ts +335 -0
  279. package/src/idl/index.ts +76 -0
  280. package/src/idl/synapse_agent_sap.json +9710 -0
  281. package/src/index.ts +253 -0
  282. package/src/modules/agent.ts +319 -0
  283. package/src/modules/attestation.ts +168 -0
  284. package/src/modules/base.ts +158 -0
  285. package/src/modules/escrow.ts +308 -0
  286. package/src/modules/feedback.ts +186 -0
  287. package/src/modules/index.ts +24 -0
  288. package/src/modules/indexing.ts +444 -0
  289. package/src/modules/ledger.ts +262 -0
  290. package/src/modules/tools.ts +411 -0
  291. package/src/modules/vault.ts +533 -0
  292. package/src/pda/index.ts +512 -0
  293. package/src/plugin/index.ts +1202 -0
  294. package/src/plugin/protocols.ts +404 -0
  295. package/src/plugin/schemas.ts +909 -0
  296. package/src/postgres/adapter.ts +904 -0
  297. package/src/postgres/index.ts +59 -0
  298. package/src/postgres/schema.sql +683 -0
  299. package/src/postgres/serializers.ts +485 -0
  300. package/src/postgres/sync.ts +254 -0
  301. package/src/postgres/types.ts +245 -0
  302. package/src/registries/builder.ts +607 -0
  303. package/src/registries/discovery.ts +572 -0
  304. package/src/registries/index.ts +77 -0
  305. package/src/registries/session.ts +613 -0
  306. package/src/registries/x402.ts +906 -0
  307. package/src/types/accounts.ts +618 -0
  308. package/src/types/common.ts +187 -0
  309. package/src/types/enums.ts +214 -0
  310. package/src/types/index.ts +92 -0
  311. package/src/types/instructions.ts +413 -0
  312. package/src/utils/hash.ts +57 -0
  313. package/src/utils/index.ts +19 -0
  314. package/src/utils/serialization.ts +98 -0
  315. package/src/utils/validation.ts +36 -0
@@ -0,0 +1,934 @@
1
+ "use strict";
2
+ /**
3
+ * @module plugin
4
+ * @description SynapsePlugin adapter for SAP v2.
5
+ *
6
+ * Exposes 52 tools across 8 on-chain protocol domains as a drop-in
7
+ * `SynapsePlugin` for `SynapseAgentKit`:
8
+ *
9
+ * ```ts
10
+ * import { SynapseAgentKit } from '@oobe-protocol-labs/synapse-client-sdk/ai/plugins';
11
+ * import { createSAPPlugin } from '@synapse-sap/sdk/plugin';
12
+ *
13
+ * const sapPlugin = createSAPPlugin({ provider });
14
+ * const kit = new SynapseAgentKit({ rpcUrl })
15
+ * .use(sapPlugin);
16
+ *
17
+ * const tools = kit.getTools(); // → StructuredTool[] (LangChain)
18
+ * ```
19
+ *
20
+ * Architecture:
21
+ * 1. Schemas (Zod) → runtime validation + LLM-friendly descriptions
22
+ * 2. Protocols → 8 domain method registries (agent, feedback, …)
23
+ * 3. Executor → dispatches tool calls to SapClient module methods
24
+ * 4. Serialization → PublicKey↔string, BN↔string bridging
25
+ *
26
+ * @category Plugin
27
+ * @since v0.1.0
28
+ */
29
+ var __importDefault = (this && this.__importDefault) || function (mod) {
30
+ return (mod && mod.__esModule) ? mod : { "default": mod };
31
+ };
32
+ Object.defineProperty(exports, "__esModule", { value: true });
33
+ exports.SAPPlugin = void 0;
34
+ exports.createSAPPlugin = createSAPPlugin;
35
+ const web3_js_1 = require("@solana/web3.js");
36
+ const bn_js_1 = __importDefault(require("bn.js"));
37
+ const client_1 = require("../core/client");
38
+ const protocols_1 = require("./protocols");
39
+ const pda_1 = require("../pda");
40
+ const utils_1 = require("../utils");
41
+ // ═══════════════════════════════════════════════════════════════════
42
+ // Version
43
+ // ═══════════════════════════════════════════════════════════════════
44
+ /**
45
+ * Current SAP plugin version string.
46
+ *
47
+ * @name SAP_PLUGIN_VERSION
48
+ * @description Semver version embedded in the plugin’s {@link PluginMeta}.
49
+ * @internal
50
+ * @since v0.1.0
51
+ */
52
+ const SAP_PLUGIN_VERSION = "0.1.0";
53
+ // ═══════════════════════════════════════════════════════════════════
54
+ // Serialization Helpers
55
+ // ═══════════════════════════════════════════════════════════════════
56
+ /**
57
+ * Convert a base58 string to PublicKey.
58
+ *
59
+ * @name toPubkey
60
+ * @description Returns `undefined` for nullish input, otherwise wraps
61
+ * the base58 string in a Solana `PublicKey`.
62
+ * @param value - Base58-encoded public key or nullish
63
+ * @returns A `PublicKey` instance, or `undefined`
64
+ * @internal
65
+ * @since v0.1.0
66
+ */
67
+ function toPubkey(value) {
68
+ return value ? new web3_js_1.PublicKey(value) : undefined;
69
+ }
70
+ /**
71
+ * Convert a string amount to BN.
72
+ *
73
+ * @name toBN
74
+ * @description Returns `undefined` for nullish input, otherwise parses
75
+ * the string as a `BN` (big number) instance.
76
+ * @param value - Numeric string or nullish
77
+ * @returns A `BN` instance, or `undefined`
78
+ * @internal
79
+ * @since v0.1.0
80
+ */
81
+ function toBN(value) {
82
+ return value ? new bn_js_1.default(value) : undefined;
83
+ }
84
+ /**
85
+ * Convert a hex string to a Node.js Buffer.
86
+ *
87
+ * @name hexToBuffer
88
+ * @description Used for encrypted data payloads before sending to
89
+ * on-chain instructions.
90
+ * @param hex - Hex-encoded string
91
+ * @returns Buffer of decoded bytes
92
+ * @internal
93
+ * @since v0.1.0
94
+ */
95
+ function hexToBuffer(hex) {
96
+ return Buffer.from(hex, "hex");
97
+ }
98
+ /**
99
+ * Convert a hex string to Uint8Array for PDA seed derivation.
100
+ *
101
+ * @name hexToBytes
102
+ * @description Wraps `Buffer.from(hex, 'hex')` into a `Uint8Array`
103
+ * suitable for Solana PDA seed arrays.
104
+ * @param hex - Hex-encoded string
105
+ * @returns Uint8Array of decoded bytes
106
+ * @internal
107
+ * @since v0.1.0
108
+ */
109
+ function hexToBytes(hex) {
110
+ return new Uint8Array(Buffer.from(hex, "hex"));
111
+ }
112
+ /**
113
+ * Map token type strings to Anchor enum variant objects.
114
+ *
115
+ * @name toTokenType
116
+ * @description Converts `"sol"`, `"usdc"`, or `"spl"` to the
117
+ * corresponding Anchor enum variant. Defaults to `{ sol: {} }`.
118
+ * @param s - Token type string
119
+ * @returns Anchor-compatible enum variant object
120
+ * @internal
121
+ * @since v0.1.0
122
+ */
123
+ function toTokenType(s) {
124
+ const map = {
125
+ sol: { sol: {} },
126
+ usdc: { usdc: {} },
127
+ spl: { spl: {} },
128
+ };
129
+ return map[s] ?? { sol: {} };
130
+ }
131
+ /**
132
+ * Map settlement mode strings to Anchor enum variant objects.
133
+ *
134
+ * @name toSettlementMode
135
+ * @description Converts `"instant"`, `"escrow"`, `"batched"`, or `"x402"`
136
+ * to the corresponding Anchor enum variant. Returns `null` for nullish input.
137
+ * @param s - Settlement mode string or nullish
138
+ * @returns Anchor-compatible enum variant object, or `null`
139
+ * @internal
140
+ * @since v0.1.0
141
+ */
142
+ function toSettlementMode(s) {
143
+ if (!s)
144
+ return null;
145
+ const map = {
146
+ instant: { instant: {} },
147
+ escrow: { escrow: {} },
148
+ batched: { batched: {} },
149
+ x402: { x402: {} },
150
+ };
151
+ return map[s] ?? null;
152
+ }
153
+ /**
154
+ * Map HTTP method strings to numeric enum values.
155
+ *
156
+ * @name toHttpMethodNum
157
+ * @description Converts lowercase method names (`"get"`, `"post"`, etc.)
158
+ * to their on-chain numeric representation. Defaults to `0` (GET).
159
+ * @param s - HTTP method string
160
+ * @returns Numeric enum value
161
+ * @internal
162
+ * @since v0.1.0
163
+ */
164
+ function toHttpMethodNum(s) {
165
+ const map = {
166
+ get: 0,
167
+ post: 1,
168
+ put: 2,
169
+ delete: 3,
170
+ compound: 4,
171
+ };
172
+ return map[s] ?? 0;
173
+ }
174
+ /**
175
+ * Map category strings to numeric enum values.
176
+ *
177
+ * @name toCategoryNum
178
+ * @description Converts category names (`"swap"`, `"lend"`, etc.)
179
+ * to their on-chain numeric representation. Defaults to `9` (custom).
180
+ * @param s - Category string
181
+ * @returns Numeric enum value
182
+ * @internal
183
+ * @since v0.1.0
184
+ */
185
+ function toCategoryNum(s) {
186
+ const map = {
187
+ swap: 0,
188
+ lend: 1,
189
+ stake: 2,
190
+ nft: 3,
191
+ payment: 4,
192
+ data: 5,
193
+ governance: 6,
194
+ bridge: 7,
195
+ analytics: 8,
196
+ custom: 9,
197
+ };
198
+ return map[s] ?? 9;
199
+ }
200
+ /**
201
+ * Map schema type strings to numeric enum values.
202
+ *
203
+ * @name toSchemaTypeNum
204
+ * @description Converts `"input"`, `"output"`, or `"description"`
205
+ * to their on-chain numeric representation. Defaults to `0` (input).
206
+ * @param s - Schema type string
207
+ * @returns Numeric enum value
208
+ * @internal
209
+ * @since v0.1.0
210
+ */
211
+ function toSchemaTypeNum(s) {
212
+ const map = { input: 0, output: 1, description: 2 };
213
+ return map[s] ?? 0;
214
+ }
215
+ /**
216
+ * Map compression type strings to numeric enum values.
217
+ *
218
+ * @name toCompressionNum
219
+ * @description Converts `"none"`, `"deflate"`, `"gzip"`, or `"brotli"`
220
+ * to their on-chain numeric representation. Defaults to `0` (none).
221
+ * @param s - Compression type string
222
+ * @returns Numeric enum value
223
+ * @internal
224
+ * @since v0.1.0
225
+ */
226
+ function toCompressionNum(s) {
227
+ const map = {
228
+ none: 0,
229
+ deflate: 1,
230
+ gzip: 2,
231
+ brotli: 3,
232
+ };
233
+ return map[s] ?? 0;
234
+ }
235
+ /**
236
+ * Convert a JSON-serialized pricing tier from plugin input
237
+ * into the SDK’s PricingTier shape with BN/PublicKey/enum conversions.
238
+ *
239
+ * @name toPricingTier
240
+ * @description Transforms raw JSON input (string amounts, string enums)
241
+ * into the native Anchor-compatible shape with `BN`, `PublicKey`,
242
+ * and enum variant objects.
243
+ * @param raw - Raw pricing tier object from Zod-validated plugin input
244
+ * @returns Anchor-compatible PricingTier object
245
+ * @internal
246
+ * @since v0.1.0
247
+ */
248
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
249
+ function toPricingTier(raw) {
250
+ return {
251
+ tierId: raw.tierId,
252
+ pricePerCall: new bn_js_1.default(raw.pricePerCall),
253
+ minPricePerCall: toBN(raw.minPricePerCall) ?? null,
254
+ maxPricePerCall: toBN(raw.maxPricePerCall) ?? null,
255
+ rateLimit: raw.rateLimit,
256
+ maxCallsPerSession: raw.maxCallsPerSession,
257
+ burstLimit: raw.burstLimit ?? null,
258
+ tokenType: toTokenType(raw.tokenType),
259
+ tokenMint: toPubkey(raw.tokenMint) ?? null,
260
+ tokenDecimals: raw.tokenDecimals ?? null,
261
+ settlementMode: toSettlementMode(raw.settlementMode),
262
+ minEscrowDeposit: toBN(raw.minEscrowDeposit) ?? null,
263
+ batchIntervalSec: raw.batchIntervalSec ?? null,
264
+ volumeCurve: raw.volumeCurve
265
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
266
+ ? raw.volumeCurve.map((v) => ({
267
+ afterCalls: v.afterCalls,
268
+ pricePerCall: new bn_js_1.default(v.pricePerCall),
269
+ }))
270
+ : null,
271
+ };
272
+ }
273
+ /**
274
+ * Serialize an on-chain account object to a JSON-safe shape.
275
+ *
276
+ * @name serializeAccount
277
+ * @description Recursively converts `PublicKey` → base58 string,
278
+ * `BN` → decimal string, and nested objects/arrays. Used to
279
+ * return tool output that is JSON-serializable for LLMs.
280
+ * @param obj - Raw account data record from Anchor deserialization
281
+ * @returns JSON-safe record with all Solana types converted to strings
282
+ * @internal
283
+ * @since v0.1.0
284
+ */
285
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
286
+ function serializeAccount(obj) {
287
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
288
+ const result = {};
289
+ for (const [key, value] of Object.entries(obj)) {
290
+ if (value === null || value === undefined) {
291
+ result[key] = null;
292
+ }
293
+ else if (value instanceof web3_js_1.PublicKey) {
294
+ result[key] = value.toBase58();
295
+ }
296
+ else if (bn_js_1.default.isBN(value)) {
297
+ result[key] = value.toString();
298
+ }
299
+ else if (Array.isArray(value)) {
300
+ result[key] = value.map((item) => {
301
+ if (item instanceof web3_js_1.PublicKey)
302
+ return item.toBase58();
303
+ if (bn_js_1.default.isBN(item))
304
+ return item.toString();
305
+ if (typeof item === "object" && item !== null)
306
+ return serializeAccount(item);
307
+ return item;
308
+ });
309
+ }
310
+ else if (typeof value === "object") {
311
+ result[key] = serializeAccount(value);
312
+ }
313
+ else {
314
+ result[key] = value;
315
+ }
316
+ }
317
+ return result;
318
+ }
319
+ // ═══════════════════════════════════════════════════════════════════
320
+ // Executor Builder
321
+ // ═══════════════════════════════════════════════════════════════════
322
+ /**
323
+ * Build the executor function that dispatches incoming tool calls
324
+ * to the appropriate SapClient module method.
325
+ *
326
+ * @name buildExecutor
327
+ * @description Creates a closure over a `SapClient` instance that routes
328
+ * each incoming `ProtocolMethod` to the correct per-protocol dispatcher
329
+ * based on `method.protocol`.
330
+ * @param client - Initialized SapClient for the configured provider
331
+ * @returns Async executor function `(method, input) => Promise<unknown>`
332
+ * @internal
333
+ * @since v0.1.0
334
+ */
335
+ function buildExecutor(client) {
336
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
337
+ return async (method, raw) => {
338
+ switch (method.protocol) {
339
+ // ────────────────────── Agent ──────────────────────
340
+ case "sap-agent":
341
+ return executeAgent(client, method.name, raw);
342
+ // ────────────────────── Feedback ───────────────────
343
+ case "sap-feedback":
344
+ return executeFeedback(client, method.name, raw);
345
+ // ────────────────────── Attestation ────────────────
346
+ case "sap-attestation":
347
+ return executeAttestation(client, method.name, raw);
348
+ // ────────────────────── Escrow ─────────────────────
349
+ case "sap-escrow":
350
+ return executeEscrow(client, method.name, raw);
351
+ // ────────────────────── Tools ──────────────────────
352
+ case "sap-tools":
353
+ return executeTools(client, method.name, raw);
354
+ // ────────────────────── Vault ──────────────────────
355
+ case "sap-vault":
356
+ return executeVault(client, method.name, raw);
357
+ // ────────────────────── Indexing ───────────────────
358
+ case "sap-indexing":
359
+ return executeIndexing(client, method.name, raw);
360
+ // ────────────────────── Ledger ─────────────────────
361
+ case "sap-ledger":
362
+ return executeLedger(client, method.name, raw);
363
+ default:
364
+ throw new Error(`Unknown SAP protocol: ${method.protocol}`);
365
+ }
366
+ };
367
+ }
368
+ // ═══════════════════════════════════════════════════════════════════
369
+ // Per-Protocol Dispatchers
370
+ // ═══════════════════════════════════════════════════════════════════
371
+ /**
372
+ * Dispatch tool calls for the **sap-agent** protocol.
373
+ *
374
+ * @name executeAgent
375
+ * @description Routes agent-domain method names to `client.agent.*` calls,
376
+ * handling argument conversion and account serialization.
377
+ * @param client - SapClient instance
378
+ * @param name - Method name (e.g. `"registerAgent"`)
379
+ * @param input - Zod-validated input from the LLM tool call
380
+ * @returns Transaction signature or serialized account data
381
+ * @internal
382
+ * @since v0.1.0
383
+ */
384
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
385
+ async function executeAgent(client, name, input) {
386
+ switch (name) {
387
+ case "registerAgent": {
388
+ const args = {
389
+ name: input.name,
390
+ description: input.description,
391
+ capabilities: input.capabilities,
392
+ pricing: (input.pricing ?? []).map(toPricingTier),
393
+ protocols: input.protocols ?? [],
394
+ agentId: input.agentId ?? null,
395
+ agentUri: input.agentUri ?? null,
396
+ x402Endpoint: input.x402Endpoint ?? null,
397
+ };
398
+ const tx = await client.agent.register(args);
399
+ return { txSignature: tx };
400
+ }
401
+ case "updateAgent": {
402
+ const args = {
403
+ name: input.name ?? null,
404
+ description: input.description ?? null,
405
+ capabilities: input.capabilities ?? null,
406
+ pricing: input.pricing ? input.pricing.map(toPricingTier) : null,
407
+ protocols: input.protocols ?? null,
408
+ agentId: input.agentId ?? null,
409
+ agentUri: input.agentUri ?? null,
410
+ x402Endpoint: input.x402Endpoint ?? null,
411
+ };
412
+ const tx = await client.agent.update(args);
413
+ return { txSignature: tx };
414
+ }
415
+ case "deactivateAgent": {
416
+ const tx = await client.agent.deactivate();
417
+ return { txSignature: tx };
418
+ }
419
+ case "reactivateAgent": {
420
+ const tx = await client.agent.reactivate();
421
+ return { txSignature: tx };
422
+ }
423
+ case "reportCalls": {
424
+ const tx = await client.agent.reportCalls(input.callsServed);
425
+ return { txSignature: tx };
426
+ }
427
+ case "updateReputation": {
428
+ const tx = await client.agent.updateReputation(input.avgLatencyMs, input.uptimePercent);
429
+ return { txSignature: tx };
430
+ }
431
+ case "fetchAgent": {
432
+ const wallet = toPubkey(input.wallet);
433
+ const data = await client.agent.fetch(wallet);
434
+ return serializeAccount(data);
435
+ }
436
+ case "fetchGlobalRegistry": {
437
+ const data = await client.agent.fetchGlobalRegistry();
438
+ return serializeAccount(data);
439
+ }
440
+ default:
441
+ throw new Error(`Unknown sap-agent method: ${name}`);
442
+ }
443
+ }
444
+ /**
445
+ * Dispatch tool calls for the **sap-feedback** protocol.
446
+ *
447
+ * @name executeFeedback
448
+ * @description Routes feedback-domain method names to `client.feedback.*` calls.
449
+ * @param client - SapClient instance
450
+ * @param name - Method name (e.g. `"giveFeedback"`)
451
+ * @param input - Zod-validated input from the LLM tool call
452
+ * @returns Transaction signature or serialized account data
453
+ * @internal
454
+ * @since v0.1.0
455
+ */
456
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
457
+ async function executeFeedback(client, name, input) {
458
+ switch (name) {
459
+ case "giveFeedback": {
460
+ const agentWallet = new web3_js_1.PublicKey(input.agentWallet);
461
+ const args = {
462
+ score: input.score,
463
+ tag: input.tag,
464
+ commentHash: input.commentHash ?? null,
465
+ };
466
+ const tx = await client.feedback.give(agentWallet, args);
467
+ return { txSignature: tx };
468
+ }
469
+ case "updateFeedback": {
470
+ const agentWallet = new web3_js_1.PublicKey(input.agentWallet);
471
+ const args = {
472
+ newScore: input.newScore,
473
+ newTag: input.newTag ?? null,
474
+ commentHash: input.commentHash ?? null,
475
+ };
476
+ const tx = await client.feedback.update(agentWallet, args);
477
+ return { txSignature: tx };
478
+ }
479
+ case "revokeFeedback": {
480
+ const tx = await client.feedback.revoke(new web3_js_1.PublicKey(input.agentWallet));
481
+ return { txSignature: tx };
482
+ }
483
+ case "fetchFeedback": {
484
+ const [agentPda] = (0, pda_1.deriveAgent)(new web3_js_1.PublicKey(input.agentWallet));
485
+ const reviewer = toPubkey(input.reviewer);
486
+ const data = await client.feedback.fetch(agentPda, reviewer);
487
+ return serializeAccount(data);
488
+ }
489
+ default:
490
+ throw new Error(`Unknown sap-feedback method: ${name}`);
491
+ }
492
+ }
493
+ /**
494
+ * Dispatch tool calls for the **sap-attestation** protocol.
495
+ *
496
+ * @name executeAttestation
497
+ * @description Routes attestation-domain method names to `client.attestation.*` calls.
498
+ * @param client - SapClient instance
499
+ * @param name - Method name (e.g. `"createAttestation"`)
500
+ * @param input - Zod-validated input from the LLM tool call
501
+ * @returns Transaction signature or serialized account data
502
+ * @internal
503
+ * @since v0.1.0
504
+ */
505
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
506
+ async function executeAttestation(client, name, input) {
507
+ switch (name) {
508
+ case "createAttestation": {
509
+ const args = {
510
+ attestationType: input.attestationType,
511
+ metadataHash: input.metadataHash,
512
+ expiresAt: new bn_js_1.default(input.expiresAt),
513
+ };
514
+ const tx = await client.attestation.create(new web3_js_1.PublicKey(input.agentWallet), args);
515
+ return { txSignature: tx };
516
+ }
517
+ case "revokeAttestation": {
518
+ const tx = await client.attestation.revoke(new web3_js_1.PublicKey(input.agentWallet));
519
+ return { txSignature: tx };
520
+ }
521
+ case "fetchAttestation": {
522
+ const [agentPda] = (0, pda_1.deriveAgent)(new web3_js_1.PublicKey(input.agentWallet));
523
+ const attester = toPubkey(input.attester);
524
+ const data = await client.attestation.fetch(agentPda, attester);
525
+ return serializeAccount(data);
526
+ }
527
+ default:
528
+ throw new Error(`Unknown sap-attestation method: ${name}`);
529
+ }
530
+ }
531
+ /**
532
+ * Dispatch tool calls for the **sap-escrow** protocol.
533
+ *
534
+ * @name executeEscrow
535
+ * @description Routes escrow-domain method names to `client.escrow.*` calls,
536
+ * including BN conversion for amounts and volume curves.
537
+ * @param client - SapClient instance
538
+ * @param name - Method name (e.g. `"createEscrow"`)
539
+ * @param input - Zod-validated input from the LLM tool call
540
+ * @returns Transaction signature or serialized account data
541
+ * @internal
542
+ * @since v0.1.0
543
+ */
544
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
545
+ async function executeEscrow(client, name, input) {
546
+ switch (name) {
547
+ case "createEscrow": {
548
+ const args = {
549
+ pricePerCall: new bn_js_1.default(input.pricePerCall),
550
+ maxCalls: new bn_js_1.default(input.maxCalls),
551
+ initialDeposit: new bn_js_1.default(input.initialDeposit),
552
+ expiresAt: new bn_js_1.default(input.expiresAt),
553
+ volumeCurve: (input.volumeCurve ?? []).map(
554
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
555
+ (v) => ({
556
+ afterCalls: v.afterCalls,
557
+ pricePerCall: new bn_js_1.default(v.pricePerCall),
558
+ })),
559
+ tokenMint: toPubkey(input.tokenMint) ?? null,
560
+ tokenDecimals: input.tokenDecimals ?? 9,
561
+ };
562
+ const tx = await client.escrow.create(new web3_js_1.PublicKey(input.agentWallet), args);
563
+ return { txSignature: tx };
564
+ }
565
+ case "depositEscrow": {
566
+ const tx = await client.escrow.deposit(new web3_js_1.PublicKey(input.agentWallet), new bn_js_1.default(input.amount));
567
+ return { txSignature: tx };
568
+ }
569
+ case "settleEscrow": {
570
+ const tx = await client.escrow.settle(new web3_js_1.PublicKey(input.depositorWallet), new bn_js_1.default(input.callsToSettle), input.serviceHash);
571
+ return { txSignature: tx };
572
+ }
573
+ case "withdrawEscrow": {
574
+ const tx = await client.escrow.withdraw(new web3_js_1.PublicKey(input.agentWallet), new bn_js_1.default(input.amount));
575
+ return { txSignature: tx };
576
+ }
577
+ case "batchSettle": {
578
+ const settlements = input.settlements.map(
579
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
580
+ (s) => ({
581
+ callsToSettle: new bn_js_1.default(s.callsToSettle),
582
+ serviceHash: s.serviceHash,
583
+ }));
584
+ const tx = await client.escrow.settleBatch(new web3_js_1.PublicKey(input.depositorWallet), settlements);
585
+ return { txSignature: tx };
586
+ }
587
+ case "fetchEscrow": {
588
+ const [agentPda] = (0, pda_1.deriveAgent)(new web3_js_1.PublicKey(input.agentWallet));
589
+ const depositor = toPubkey(input.depositor);
590
+ const data = await client.escrow.fetch(agentPda, depositor);
591
+ return serializeAccount(data);
592
+ }
593
+ default:
594
+ throw new Error(`Unknown sap-escrow method: ${name}`);
595
+ }
596
+ }
597
+ /**
598
+ * Dispatch tool calls for the **sap-tools** protocol.
599
+ *
600
+ * @name executeTools
601
+ * @description Routes tools-domain method names to `client.tools.*` calls,
602
+ * handling schema hashing and enum conversions.
603
+ * @param client - SapClient instance
604
+ * @param name - Method name (e.g. `"publishToolByName"`)
605
+ * @param input - Zod-validated input from the LLM tool call
606
+ * @returns Transaction signature or serialized account data
607
+ * @internal
608
+ * @since v0.1.0
609
+ */
610
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
611
+ async function executeTools(client, name, input) {
612
+ switch (name) {
613
+ case "publishToolByName": {
614
+ const tx = await client.tools.publishByName(input.toolName, input.protocolId, input.description, input.inputSchema, input.outputSchema, toHttpMethodNum(input.httpMethod), toCategoryNum(input.category), input.paramsCount, input.requiredParams, input.isCompound ?? false);
615
+ return { txSignature: tx };
616
+ }
617
+ case "inscribeToolSchema": {
618
+ const args = {
619
+ schemaType: toSchemaTypeNum(input.schemaType),
620
+ schemaData: Buffer.from(input.schemaData, "utf-8"),
621
+ schemaHash: (0, utils_1.hashToArray)((0, utils_1.sha256)(input.schemaData)),
622
+ compression: toCompressionNum(input.compression ?? "none"),
623
+ };
624
+ const tx = await client.tools.inscribeSchema(input.toolName, args);
625
+ return { txSignature: tx };
626
+ }
627
+ case "updateTool": {
628
+ const args = {
629
+ descriptionHash: null,
630
+ inputSchemaHash: null,
631
+ outputSchemaHash: null,
632
+ httpMethod: input.httpMethod != null ? toHttpMethodNum(input.httpMethod) : null,
633
+ category: input.category != null ? toCategoryNum(input.category) : null,
634
+ paramsCount: input.paramsCount ?? null,
635
+ requiredParams: input.requiredParams ?? null,
636
+ };
637
+ const tx = await client.tools.update(input.toolName, args);
638
+ return { txSignature: tx };
639
+ }
640
+ case "deactivateTool": {
641
+ const tx = await client.tools.deactivate(input.toolName);
642
+ return { txSignature: tx };
643
+ }
644
+ case "reactivateTool": {
645
+ const tx = await client.tools.reactivate(input.toolName);
646
+ return { txSignature: tx };
647
+ }
648
+ case "reportInvocations": {
649
+ const tx = await client.tools.reportInvocations(input.toolName, input.invocations);
650
+ return { txSignature: tx };
651
+ }
652
+ case "fetchTool": {
653
+ const [agentPda] = (0, pda_1.deriveAgent)(new web3_js_1.PublicKey(input.agentWallet));
654
+ const data = await client.tools.fetch(agentPda, input.toolName);
655
+ return serializeAccount(data);
656
+ }
657
+ default:
658
+ throw new Error(`Unknown sap-tools method: ${name}`);
659
+ }
660
+ }
661
+ /**
662
+ * Dispatch tool calls for the **sap-vault** protocol.
663
+ *
664
+ * @name executeVault
665
+ * @description Routes vault-domain method names to `client.vault.*` calls,
666
+ * handling hex-to-bytes conversion and PDA derivation for sessions.
667
+ * @param client - SapClient instance
668
+ * @param name - Method name (e.g. `"initVault"`)
669
+ * @param input - Zod-validated input from the LLM tool call
670
+ * @returns Transaction signature or serialized account data
671
+ * @internal
672
+ * @since v0.1.0
673
+ */
674
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
675
+ async function executeVault(client, name, input) {
676
+ switch (name) {
677
+ case "initVault": {
678
+ const tx = await client.vault.initVault(input.vaultNonce);
679
+ return { txSignature: tx };
680
+ }
681
+ case "openSession": {
682
+ const tx = await client.vault.openSession(input.sessionHash);
683
+ return { txSignature: tx };
684
+ }
685
+ case "inscribeMemory": {
686
+ const args = {
687
+ sequence: input.sequence,
688
+ encryptedData: hexToBuffer(input.encryptedData),
689
+ nonce: input.nonce,
690
+ contentHash: input.contentHash,
691
+ totalFragments: input.totalFragments ?? 1,
692
+ fragmentIndex: input.fragmentIndex ?? 0,
693
+ compression: input.compression ?? 0,
694
+ epochIndex: input.epochIndex ?? 0,
695
+ };
696
+ const tx = await client.vault.inscribe(args);
697
+ return { txSignature: tx };
698
+ }
699
+ case "closeSession": {
700
+ const [agentPda] = (0, pda_1.deriveAgent)(client.walletPubkey);
701
+ const [vaultPda] = (0, pda_1.deriveVault)(agentPda);
702
+ const sessionHashBytes = hexToBytes(input.sessionHash);
703
+ const [sessionPda] = (0, pda_1.deriveSession)(vaultPda, sessionHashBytes);
704
+ const tx = await client.vault.closeSession(vaultPda, sessionPda);
705
+ return { txSignature: tx };
706
+ }
707
+ case "closeVault": {
708
+ const tx = await client.vault.closeVault();
709
+ return { txSignature: tx };
710
+ }
711
+ case "rotateNonce": {
712
+ const tx = await client.vault.rotateNonce(input.newNonce);
713
+ return { txSignature: tx };
714
+ }
715
+ case "addDelegate": {
716
+ const tx = await client.vault.addDelegate(new web3_js_1.PublicKey(input.delegatePubkey), input.permissions, BigInt(input.expiresAt));
717
+ return { txSignature: tx };
718
+ }
719
+ case "revokeDelegate": {
720
+ const tx = await client.vault.revokeDelegate(new web3_js_1.PublicKey(input.delegatePubkey));
721
+ return { txSignature: tx };
722
+ }
723
+ case "fetchVault": {
724
+ const wallet = toPubkey(input.agentWallet) ?? client.walletPubkey;
725
+ const [agentPda] = (0, pda_1.deriveAgent)(wallet);
726
+ const data = await client.vault.fetchVault(agentPda);
727
+ return serializeAccount(data);
728
+ }
729
+ case "fetchSession": {
730
+ const wallet = new web3_js_1.PublicKey(input.agentWallet);
731
+ const [agentPda] = (0, pda_1.deriveAgent)(wallet);
732
+ const [vaultPda] = (0, pda_1.deriveVault)(agentPda);
733
+ const sessionHashBytes = hexToBytes(input.sessionHash);
734
+ const data = await client.vault.fetchSession(vaultPda, sessionHashBytes);
735
+ return serializeAccount(data);
736
+ }
737
+ default:
738
+ throw new Error(`Unknown sap-vault method: ${name}`);
739
+ }
740
+ }
741
+ /**
742
+ * Dispatch tool calls for the **sap-indexing** protocol.
743
+ *
744
+ * @name executeIndexing
745
+ * @description Routes indexing-domain method names to `client.indexing.*` calls
746
+ * for capability and protocol index management.
747
+ * @param client - SapClient instance
748
+ * @param name - Method name (e.g. `"initCapabilityIndex"`)
749
+ * @param input - Zod-validated input from the LLM tool call
750
+ * @returns Transaction signature or serialized account data
751
+ * @internal
752
+ * @since v0.1.0
753
+ */
754
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
755
+ async function executeIndexing(client, name, input) {
756
+ switch (name) {
757
+ case "initCapabilityIndex": {
758
+ const tx = await client.indexing.initCapabilityIndex(input.capabilityId);
759
+ return { txSignature: tx };
760
+ }
761
+ case "addToCapabilityIndex": {
762
+ const tx = await client.indexing.addToCapabilityIndex(input.capabilityId);
763
+ return { txSignature: tx };
764
+ }
765
+ case "removeFromCapabilityIndex": {
766
+ const tx = await client.indexing.removeFromCapabilityIndex(input.capabilityId);
767
+ return { txSignature: tx };
768
+ }
769
+ case "initProtocolIndex": {
770
+ const tx = await client.indexing.initProtocolIndex(input.protocolId);
771
+ return { txSignature: tx };
772
+ }
773
+ case "addToProtocolIndex": {
774
+ const tx = await client.indexing.addToProtocolIndex(input.protocolId);
775
+ return { txSignature: tx };
776
+ }
777
+ case "removeFromProtocolIndex": {
778
+ const tx = await client.indexing.removeFromProtocolIndex(input.protocolId);
779
+ return { txSignature: tx };
780
+ }
781
+ case "fetchCapabilityIndex": {
782
+ const data = await client.indexing.fetchCapabilityIndex(input.capabilityId);
783
+ return serializeAccount(data);
784
+ }
785
+ case "fetchProtocolIndex": {
786
+ const data = await client.indexing.fetchProtocolIndex(input.protocolId);
787
+ return serializeAccount(data);
788
+ }
789
+ default:
790
+ throw new Error(`Unknown sap-indexing method: ${name}`);
791
+ }
792
+ }
793
+ /**
794
+ * Dispatch tool calls for the **sap-ledger** protocol.
795
+ *
796
+ * @name executeLedger
797
+ * @description Routes ledger-domain method names to `client.ledger.*` calls,
798
+ * deriving session PDAs from hex-encoded session hashes.
799
+ * @param client - SapClient instance
800
+ * @param name - Method name (e.g. `"initLedger"`)
801
+ * @param input - Zod-validated input from the LLM tool call
802
+ * @returns Transaction signature or serialized account data
803
+ * @internal
804
+ * @since v0.1.0
805
+ */
806
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
807
+ async function executeLedger(client, name, input) {
808
+ const resolveSessionPda = (sessionHash, agentWallet) => {
809
+ const wallet = toPubkey(agentWallet) ?? client.walletPubkey;
810
+ const [agentPda] = (0, pda_1.deriveAgent)(wallet);
811
+ const [vaultPda] = (0, pda_1.deriveVault)(agentPda);
812
+ const sessionHashBytes = hexToBytes(sessionHash);
813
+ const [sessionPda] = (0, pda_1.deriveSession)(vaultPda, sessionHashBytes);
814
+ return sessionPda;
815
+ };
816
+ switch (name) {
817
+ case "initLedger": {
818
+ const sessionPda = resolveSessionPda(input.sessionHash, input.agentWallet);
819
+ const tx = await client.ledger.init(sessionPda);
820
+ return { txSignature: tx };
821
+ }
822
+ case "writeLedger": {
823
+ const sessionPda = resolveSessionPda(input.sessionHash, input.agentWallet);
824
+ const data = hexToBuffer(input.data);
825
+ const tx = await client.ledger.write(sessionPda, data, input.contentHash);
826
+ return { txSignature: tx };
827
+ }
828
+ case "sealLedger": {
829
+ const sessionPda = resolveSessionPda(input.sessionHash, input.agentWallet);
830
+ const tx = await client.ledger.seal(sessionPda);
831
+ return { txSignature: tx };
832
+ }
833
+ case "closeLedger": {
834
+ const sessionPda = resolveSessionPda(input.sessionHash, input.agentWallet);
835
+ const tx = await client.ledger.close(sessionPda);
836
+ return { txSignature: tx };
837
+ }
838
+ case "fetchLedger": {
839
+ const sessionPda = resolveSessionPda(input.sessionHash, input.agentWallet);
840
+ const data = await client.ledger.fetchLedger(sessionPda);
841
+ return serializeAccount(data);
842
+ }
843
+ case "fetchLedgerPage": {
844
+ const sessionPda = resolveSessionPda(input.sessionHash, input.agentWallet);
845
+ const [ledgerPda] = (0, pda_1.deriveLedger)(sessionPda);
846
+ const data = await client.ledger.fetchPage(ledgerPda, input.pageIndex);
847
+ return serializeAccount(data);
848
+ }
849
+ default:
850
+ throw new Error(`Unknown sap-ledger method: ${name}`);
851
+ }
852
+ }
853
+ // ═══════════════════════════════════════════════════════════════════
854
+ // Plugin Factory
855
+ // ═══════════════════════════════════════════════════════════════════
856
+ /**
857
+ * Create a SynapsePlugin for SAP v2.
858
+ *
859
+ * @name createSAPPlugin
860
+ * @description Factory function that returns a fully configured
861
+ * {@link SynapsePlugin} exposing 52 tools across 8 on-chain
862
+ * protocol domains. The plugin can be installed into a
863
+ * `SynapseAgentKit` instance or used standalone.
864
+ * @param config - Plugin configuration with Anchor provider and optional program ID
865
+ * @returns A configured {@link SynapsePlugin} instance
866
+ * @category Plugin
867
+ * @since v0.1.0
868
+ *
869
+ * @example
870
+ * ```ts
871
+ * import { createSAPPlugin } from '@synapse-sap/sdk/plugin';
872
+ *
873
+ * const sapPlugin = createSAPPlugin({ provider });
874
+ *
875
+ * // Use with SynapseAgentKit:
876
+ * kit.use(sapPlugin);
877
+ *
878
+ * // Or standalone:
879
+ * const executor = sapPlugin.install({ client, config: {} }).executor;
880
+ * await executor(someMethod, someInput);
881
+ * ```
882
+ */
883
+ function createSAPPlugin(config) {
884
+ return {
885
+ meta: {
886
+ id: "sap",
887
+ name: "SAP v2 — Solana Agent Protocol",
888
+ version: SAP_PLUGIN_VERSION,
889
+ description: "On-chain agent identity, reputation, tool registry, encrypted memory vault, x402 escrow, attestation, discovery indexes, and unified memory ledger on Solana",
890
+ tags: [
891
+ "solana",
892
+ "agent",
893
+ "identity",
894
+ "reputation",
895
+ "x402",
896
+ "escrow",
897
+ "vault",
898
+ "memory",
899
+ "tools",
900
+ "attestation",
901
+ "erc-8004",
902
+ ],
903
+ },
904
+ protocols: protocols_1.SAP_PROTOCOLS,
905
+ install(_context) {
906
+ const client = client_1.SapClient.from(config.provider, config.programId);
907
+ const executor = buildExecutor(client);
908
+ return { executor };
909
+ },
910
+ };
911
+ }
912
+ /**
913
+ * Pre-built plugin object for static use patterns.
914
+ *
915
+ * @name SAPPlugin
916
+ * @description Convenience namespace exposing a `configure` method
917
+ * that delegates to {@link createSAPPlugin}. Useful for concise
918
+ * one-liner instantiation.
919
+ * @category Plugin
920
+ * @since v0.1.0
921
+ *
922
+ * @example
923
+ * ```ts
924
+ * import { SAPPlugin } from '@synapse-sap/sdk/plugin';
925
+ *
926
+ * const plugin = SAPPlugin.configure({ provider });
927
+ * kit.use(plugin);
928
+ * ```
929
+ */
930
+ exports.SAPPlugin = {
931
+ /** Create a configured SynapsePlugin from an AnchorProvider. */
932
+ configure: createSAPPlugin,
933
+ };
934
+ //# sourceMappingURL=index.js.map