@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,375 @@
1
+ "use strict";
2
+ /**
3
+ * @module indexing
4
+ * @description Scalable discovery layer — capability indexes, protocol indexes,
5
+ * and tool category indexes for the Solana Agent Protocol.
6
+ *
7
+ * Indexes are shared PDA-based registries that map agents and tools to
8
+ * discovery dimensions, enabling efficient on-chain lookups.
9
+ *
10
+ * @category Modules
11
+ * @since v0.1.0
12
+ * @packageDocumentation
13
+ */
14
+ Object.defineProperty(exports, "__esModule", { value: true });
15
+ exports.IndexingModule = void 0;
16
+ const web3_js_1 = require("@solana/web3.js");
17
+ const base_1 = require("./base");
18
+ const pda_1 = require("../pda");
19
+ const utils_1 = require("../utils");
20
+ /**
21
+ * @name IndexingModule
22
+ * @description Manages on-chain discovery indexes for the Solana Agent Protocol.
23
+ * Provides methods to create, populate, prune, close, and fetch capability
24
+ * indexes, protocol indexes, and tool category indexes.
25
+ *
26
+ * @category Modules
27
+ * @since v0.1.0
28
+ * @extends BaseModule
29
+ *
30
+ * @example
31
+ * ```ts
32
+ * const sap = new SapClient(provider);
33
+ * // Create a capability index and add your agent
34
+ * await sap.indexing.initCapabilityIndex("text-generation");
35
+ * // Query agents by capability
36
+ * const idx = await sap.indexing.fetchCapabilityIndex("text-generation");
37
+ * ```
38
+ */
39
+ class IndexingModule extends base_1.BaseModule {
40
+ // ── Helpers ──────────────────────────────────────────
41
+ /**
42
+ * @name hash
43
+ * @description Hash a capability or protocol ID string for use as a PDA seed.
44
+ * Uses SHA-256 internally.
45
+ * @param id - The capability or protocol identifier string.
46
+ * @returns {Uint8Array} The 32-byte SHA-256 hash.
47
+ * @since v0.1.0
48
+ */
49
+ hash(id) {
50
+ return (0, utils_1.sha256)(id);
51
+ }
52
+ // ── Capability Index ─────────────────────────────────
53
+ /**
54
+ * @name initCapabilityIndex
55
+ * @description Create a new capability index and register the caller’s agent.
56
+ * The capability ID is hashed to derive the PDA.
57
+ * @param capabilityId - Human-readable capability identifier (e.g. `"text-generation"`).
58
+ * @returns {Promise<TransactionSignature>} The transaction signature.
59
+ * @since v0.1.0
60
+ */
61
+ async initCapabilityIndex(capabilityId) {
62
+ const capHash = this.hash(capabilityId);
63
+ const [agentPda] = (0, pda_1.deriveAgent)(this.walletPubkey);
64
+ const [capIdxPda] = (0, pda_1.deriveCapabilityIndex)(capHash);
65
+ const [globalPda] = (0, pda_1.deriveGlobalRegistry)();
66
+ return this.methods
67
+ .initCapabilityIndex(capabilityId, (0, utils_1.hashToArray)(capHash))
68
+ .accounts({
69
+ wallet: this.walletPubkey,
70
+ agent: agentPda,
71
+ capabilityIndex: capIdxPda,
72
+ globalRegistry: globalPda,
73
+ systemProgram: web3_js_1.SystemProgram.programId,
74
+ })
75
+ .rpc();
76
+ }
77
+ /**
78
+ * @name addToCapabilityIndex
79
+ * @description Add the caller’s agent to an existing capability index.
80
+ * @param capabilityId - The capability identifier string.
81
+ * @returns {Promise<TransactionSignature>} The transaction signature.
82
+ * @since v0.1.0
83
+ */
84
+ async addToCapabilityIndex(capabilityId) {
85
+ const capHash = this.hash(capabilityId);
86
+ const [agentPda] = (0, pda_1.deriveAgent)(this.walletPubkey);
87
+ const [capIdxPda] = (0, pda_1.deriveCapabilityIndex)(capHash);
88
+ return this.methods
89
+ .addToCapabilityIndex((0, utils_1.hashToArray)(capHash))
90
+ .accounts({
91
+ wallet: this.walletPubkey,
92
+ agent: agentPda,
93
+ capabilityIndex: capIdxPda,
94
+ })
95
+ .rpc();
96
+ }
97
+ /**
98
+ * @name removeFromCapabilityIndex
99
+ * @description Remove the caller’s agent from a capability index.
100
+ * @param capabilityId - The capability identifier string.
101
+ * @returns {Promise<TransactionSignature>} The transaction signature.
102
+ * @since v0.1.0
103
+ */
104
+ async removeFromCapabilityIndex(capabilityId) {
105
+ const capHash = this.hash(capabilityId);
106
+ const [agentPda] = (0, pda_1.deriveAgent)(this.walletPubkey);
107
+ const [capIdxPda] = (0, pda_1.deriveCapabilityIndex)(capHash);
108
+ return this.methods
109
+ .removeFromCapabilityIndex((0, utils_1.hashToArray)(capHash))
110
+ .accounts({
111
+ wallet: this.walletPubkey,
112
+ agent: agentPda,
113
+ capabilityIndex: capIdxPda,
114
+ })
115
+ .rpc();
116
+ }
117
+ /**
118
+ * @name closeCapabilityIndex
119
+ * @description Close an empty capability index PDA and reclaim rent.
120
+ * @param capabilityId - The capability identifier string.
121
+ * @returns {Promise<TransactionSignature>} The transaction signature.
122
+ * @since v0.1.0
123
+ */
124
+ async closeCapabilityIndex(capabilityId) {
125
+ const capHash = this.hash(capabilityId);
126
+ const [capIdxPda] = (0, pda_1.deriveCapabilityIndex)(capHash);
127
+ const [globalPda] = (0, pda_1.deriveGlobalRegistry)();
128
+ return this.methods
129
+ .closeCapabilityIndex((0, utils_1.hashToArray)(capHash))
130
+ .accounts({
131
+ wallet: this.walletPubkey,
132
+ capabilityIndex: capIdxPda,
133
+ globalRegistry: globalPda,
134
+ })
135
+ .rpc();
136
+ }
137
+ // ── Protocol Index ───────────────────────────────────
138
+ /**
139
+ * @name initProtocolIndex
140
+ * @description Create a new protocol index and register the caller’s agent.
141
+ * The protocol ID is hashed to derive the PDA.
142
+ * @param protocolId - Human-readable protocol identifier (e.g. `"mcp-v1"`).
143
+ * @returns {Promise<TransactionSignature>} The transaction signature.
144
+ * @since v0.1.0
145
+ */
146
+ async initProtocolIndex(protocolId) {
147
+ const protoHash = this.hash(protocolId);
148
+ const [agentPda] = (0, pda_1.deriveAgent)(this.walletPubkey);
149
+ const [protoIdxPda] = (0, pda_1.deriveProtocolIndex)(protoHash);
150
+ const [globalPda] = (0, pda_1.deriveGlobalRegistry)();
151
+ return this.methods
152
+ .initProtocolIndex(protocolId, (0, utils_1.hashToArray)(protoHash))
153
+ .accounts({
154
+ wallet: this.walletPubkey,
155
+ agent: agentPda,
156
+ protocolIndex: protoIdxPda,
157
+ globalRegistry: globalPda,
158
+ systemProgram: web3_js_1.SystemProgram.programId,
159
+ })
160
+ .rpc();
161
+ }
162
+ /**
163
+ * @name addToProtocolIndex
164
+ * @description Add the caller’s agent to an existing protocol index.
165
+ * @param protocolId - The protocol identifier string.
166
+ * @returns {Promise<TransactionSignature>} The transaction signature.
167
+ * @since v0.1.0
168
+ */
169
+ async addToProtocolIndex(protocolId) {
170
+ const protoHash = this.hash(protocolId);
171
+ const [agentPda] = (0, pda_1.deriveAgent)(this.walletPubkey);
172
+ const [protoIdxPda] = (0, pda_1.deriveProtocolIndex)(protoHash);
173
+ return this.methods
174
+ .addToProtocolIndex((0, utils_1.hashToArray)(protoHash))
175
+ .accounts({
176
+ wallet: this.walletPubkey,
177
+ agent: agentPda,
178
+ protocolIndex: protoIdxPda,
179
+ })
180
+ .rpc();
181
+ }
182
+ /**
183
+ * @name removeFromProtocolIndex
184
+ * @description Remove the caller’s agent from a protocol index.
185
+ * @param protocolId - The protocol identifier string.
186
+ * @returns {Promise<TransactionSignature>} The transaction signature.
187
+ * @since v0.1.0
188
+ */
189
+ async removeFromProtocolIndex(protocolId) {
190
+ const protoHash = this.hash(protocolId);
191
+ const [agentPda] = (0, pda_1.deriveAgent)(this.walletPubkey);
192
+ const [protoIdxPda] = (0, pda_1.deriveProtocolIndex)(protoHash);
193
+ return this.methods
194
+ .removeFromProtocolIndex((0, utils_1.hashToArray)(protoHash))
195
+ .accounts({
196
+ wallet: this.walletPubkey,
197
+ agent: agentPda,
198
+ protocolIndex: protoIdxPda,
199
+ })
200
+ .rpc();
201
+ }
202
+ /**
203
+ * @name closeProtocolIndex
204
+ * @description Close an empty protocol index PDA and reclaim rent.
205
+ * @param protocolId - The protocol identifier string.
206
+ * @returns {Promise<TransactionSignature>} The transaction signature.
207
+ * @since v0.1.0
208
+ */
209
+ async closeProtocolIndex(protocolId) {
210
+ const protoHash = this.hash(protocolId);
211
+ const [protoIdxPda] = (0, pda_1.deriveProtocolIndex)(protoHash);
212
+ const [globalPda] = (0, pda_1.deriveGlobalRegistry)();
213
+ return this.methods
214
+ .closeProtocolIndex((0, utils_1.hashToArray)(protoHash))
215
+ .accounts({
216
+ wallet: this.walletPubkey,
217
+ protocolIndex: protoIdxPda,
218
+ globalRegistry: globalPda,
219
+ })
220
+ .rpc();
221
+ }
222
+ // ── Tool Category Index ──────────────────────────────
223
+ /**
224
+ * @name initToolCategoryIndex
225
+ * @description Create a new tool category index PDA.
226
+ * @param category - Numeric tool category enum value.
227
+ * @returns {Promise<TransactionSignature>} The transaction signature.
228
+ * @since v0.1.0
229
+ */
230
+ async initToolCategoryIndex(category) {
231
+ const [catIdxPda] = (0, pda_1.deriveToolCategoryIndex)(category);
232
+ return this.methods
233
+ .initToolCategoryIndex(category)
234
+ .accounts({
235
+ wallet: this.walletPubkey,
236
+ toolCategoryIndex: catIdxPda,
237
+ systemProgram: web3_js_1.SystemProgram.programId,
238
+ })
239
+ .rpc();
240
+ }
241
+ /**
242
+ * @name addToToolCategory
243
+ * @description Add a tool to its matching category index.
244
+ * @param category - Numeric tool category enum value.
245
+ * @param toolPda - The tool descriptor PDA to add.
246
+ * @returns {Promise<TransactionSignature>} The transaction signature.
247
+ * @since v0.1.0
248
+ */
249
+ async addToToolCategory(category, toolPda) {
250
+ const [agentPda] = (0, pda_1.deriveAgent)(this.walletPubkey);
251
+ const [catIdxPda] = (0, pda_1.deriveToolCategoryIndex)(category);
252
+ return this.methods
253
+ .addToToolCategory(category)
254
+ .accounts({
255
+ wallet: this.walletPubkey,
256
+ agent: agentPda,
257
+ tool: toolPda,
258
+ toolCategoryIndex: catIdxPda,
259
+ })
260
+ .rpc();
261
+ }
262
+ /**
263
+ * @name removeFromToolCategory
264
+ * @description Remove a tool from a category index.
265
+ * @param category - Numeric tool category enum value.
266
+ * @param toolPda - The tool descriptor PDA to remove.
267
+ * @returns {Promise<TransactionSignature>} The transaction signature.
268
+ * @since v0.1.0
269
+ */
270
+ async removeFromToolCategory(category, toolPda) {
271
+ const [agentPda] = (0, pda_1.deriveAgent)(this.walletPubkey);
272
+ const [catIdxPda] = (0, pda_1.deriveToolCategoryIndex)(category);
273
+ return this.methods
274
+ .removeFromToolCategory(category)
275
+ .accounts({
276
+ wallet: this.walletPubkey,
277
+ agent: agentPda,
278
+ tool: toolPda,
279
+ toolCategoryIndex: catIdxPda,
280
+ })
281
+ .rpc();
282
+ }
283
+ /**
284
+ * @name closeToolCategoryIndex
285
+ * @description Close an empty tool category index PDA and reclaim rent.
286
+ * @param category - Numeric tool category enum value.
287
+ * @returns {Promise<TransactionSignature>} The transaction signature.
288
+ * @since v0.1.0
289
+ */
290
+ async closeToolCategoryIndex(category) {
291
+ const [catIdxPda] = (0, pda_1.deriveToolCategoryIndex)(category);
292
+ return this.methods
293
+ .closeToolCategoryIndex(category)
294
+ .accounts({
295
+ wallet: this.walletPubkey,
296
+ toolCategoryIndex: catIdxPda,
297
+ })
298
+ .rpc();
299
+ }
300
+ // ── Fetchers ─────────────────────────────────────────
301
+ /**
302
+ * @name fetchCapabilityIndex
303
+ * @description Fetch a deserialized `CapabilityIndex` account by capability ID.
304
+ * @param capabilityId - The capability identifier string.
305
+ * @returns {Promise<CapabilityIndexData>} The capability index data.
306
+ * @throws Will throw if the capability index does not exist.
307
+ * @since v0.1.0
308
+ */
309
+ async fetchCapabilityIndex(capabilityId) {
310
+ const [pda] = (0, pda_1.deriveCapabilityIndex)(this.hash(capabilityId));
311
+ return this.fetchAccount("capabilityIndex", pda);
312
+ }
313
+ /**
314
+ * @name fetchCapabilityIndexNullable
315
+ * @description Fetch a deserialized `CapabilityIndex` account, or `null`
316
+ * if it does not exist on-chain.
317
+ * @param capabilityId - The capability identifier string.
318
+ * @returns {Promise<CapabilityIndexData | null>} The capability index data or `null`.
319
+ * @since v0.1.0
320
+ */
321
+ async fetchCapabilityIndexNullable(capabilityId) {
322
+ const [pda] = (0, pda_1.deriveCapabilityIndex)(this.hash(capabilityId));
323
+ return this.fetchAccountNullable("capabilityIndex", pda);
324
+ }
325
+ /**
326
+ * @name fetchProtocolIndex
327
+ * @description Fetch a deserialized `ProtocolIndex` account by protocol ID.
328
+ * @param protocolId - The protocol identifier string.
329
+ * @returns {Promise<ProtocolIndexData>} The protocol index data.
330
+ * @throws Will throw if the protocol index does not exist.
331
+ * @since v0.1.0
332
+ */
333
+ async fetchProtocolIndex(protocolId) {
334
+ const [pda] = (0, pda_1.deriveProtocolIndex)(this.hash(protocolId));
335
+ return this.fetchAccount("protocolIndex", pda);
336
+ }
337
+ /**
338
+ * @name fetchProtocolIndexNullable
339
+ * @description Fetch a deserialized `ProtocolIndex` account, or `null`
340
+ * if it does not exist on-chain.
341
+ * @param protocolId - The protocol identifier string.
342
+ * @returns {Promise<ProtocolIndexData | null>} The protocol index data or `null`.
343
+ * @since v0.1.0
344
+ */
345
+ async fetchProtocolIndexNullable(protocolId) {
346
+ const [pda] = (0, pda_1.deriveProtocolIndex)(this.hash(protocolId));
347
+ return this.fetchAccountNullable("protocolIndex", pda);
348
+ }
349
+ /**
350
+ * @name fetchToolCategoryIndex
351
+ * @description Fetch a deserialized `ToolCategoryIndex` account by category number.
352
+ * @param category - Numeric tool category enum value.
353
+ * @returns {Promise<ToolCategoryIndexData>} The tool category index data.
354
+ * @throws Will throw if the tool category index does not exist.
355
+ * @since v0.1.0
356
+ */
357
+ async fetchToolCategoryIndex(category) {
358
+ const [pda] = (0, pda_1.deriveToolCategoryIndex)(category);
359
+ return this.fetchAccount("toolCategoryIndex", pda);
360
+ }
361
+ /**
362
+ * @name fetchToolCategoryIndexNullable
363
+ * @description Fetch a deserialized `ToolCategoryIndex` account, or `null`
364
+ * if it does not exist on-chain.
365
+ * @param category - Numeric tool category enum value.
366
+ * @returns {Promise<ToolCategoryIndexData | null>} The tool category index data or `null`.
367
+ * @since v0.1.0
368
+ */
369
+ async fetchToolCategoryIndexNullable(category) {
370
+ const [pda] = (0, pda_1.deriveToolCategoryIndex)(category);
371
+ return this.fetchAccountNullable("toolCategoryIndex", pda);
372
+ }
373
+ }
374
+ exports.IndexingModule = IndexingModule;
375
+ //# sourceMappingURL=indexing.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"indexing.js","sourceRoot":"","sources":["../../../src/modules/indexing.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,234 @@
1
+ "use strict";
2
+ /**
3
+ * @module ledger
4
+ * @description Unified on-chain memory — init, write, seal, and close ledger.
5
+ *
6
+ * The recommended memory system: fixed-cost PDA with 4 KB ring buffer,
7
+ * automatic TX log persistence, and rolling merkle proof.
8
+ * Write cost is TX fee only (~0.000005 SOL). ZERO additional rent.
9
+ *
10
+ * @category Modules
11
+ * @since v0.1.0
12
+ * @packageDocumentation
13
+ */
14
+ Object.defineProperty(exports, "__esModule", { value: true });
15
+ exports.LedgerModule = void 0;
16
+ const web3_js_1 = require("@solana/web3.js");
17
+ const base_1 = require("./base");
18
+ const pda_1 = require("../pda");
19
+ /**
20
+ * @name LedgerModule
21
+ * @description Manage on-chain memory ledgers for sessions.
22
+ * Each session can have one MemoryLedger PDA with a 4KB ring buffer for recent entries.
23
+ * When the ring buffer fills, it can be sealed into a permanent LedgerPage.
24
+ * Ledgers are designed for high-frequency writes with minimal cost (~0.000005 SOL per write).
25
+ * Sealed pages are immutable and stored on-chain (~0.031 SOL per page).
26
+ */
27
+ /**
28
+ * @name LedgerModule
29
+ * @description Manages the unified on-chain memory ledger for the Solana Agent
30
+ * Protocol. Provides methods to initialise a ledger with a 4 KB ring buffer,
31
+ * write data (TX fee only), seal pages permanently, close ledgers, and
32
+ * decode ring buffer contents.
33
+ *
34
+ * @category Modules
35
+ * @since v0.1.0
36
+ * @extends BaseModule
37
+ *
38
+ * @example
39
+ * ```ts
40
+ * const sap = new SapClient(provider);
41
+ * // Init ledger, write data, seal
42
+ * await sap.ledger.init(sessionPda);
43
+ * await sap.ledger.write(sessionPda, data, contentHash);
44
+ * await sap.ledger.seal(sessionPda);
45
+ * ```
46
+ */
47
+ class LedgerModule extends base_1.BaseModule {
48
+ // ── PDA helpers ──────────────────────────────────────
49
+ /**
50
+ * @name deriveLedger
51
+ * @description Derive the `MemoryLedger` PDA for a given session.
52
+ * @param sessionPda - The session ledger PDA.
53
+ * @returns A tuple of `[PublicKey, bump]` for the ledger PDA.
54
+ * @see {@link deriveLedger} from `pda/` module for the underlying derivation.
55
+ * @since v0.1.0
56
+ */
57
+ deriveLedger(sessionPda) {
58
+ return (0, pda_1.deriveLedger)(sessionPda);
59
+ }
60
+ /**
61
+ * @name deriveLedgerPage
62
+ * @description Derive a `LedgerPage` PDA for a given ledger and page index.
63
+ * @param ledgerPda - The memory ledger PDA.
64
+ * @param pageIndex - The zero-based page index.
65
+ * @returns A tuple of `[PublicKey, bump]` for the page PDA.
66
+ * @see {@link deriveLedgerPage} from `pda/` module for the underlying derivation.
67
+ * @since v0.1.0
68
+ */
69
+ deriveLedgerPage(ledgerPda, pageIndex) {
70
+ return (0, pda_1.deriveLedgerPage)(ledgerPda, pageIndex);
71
+ }
72
+ // ── Instructions ─────────────────────────────────────
73
+ /**
74
+ * @name init
75
+ * @description Create a `MemoryLedger` with a 4 KB ring buffer (~0.032 SOL rent).
76
+ * @param sessionPda - The session ledger PDA to attach the ledger to.
77
+ * @returns {Promise<TransactionSignature>} The transaction signature.
78
+ * @since v0.1.0
79
+ */
80
+ async init(sessionPda) {
81
+ const [ledgerPda] = (0, pda_1.deriveLedger)(sessionPda);
82
+ return this.methods
83
+ .initLedger()
84
+ .accounts({
85
+ wallet: this.walletPubkey,
86
+ session: sessionPda,
87
+ ledger: ledgerPda,
88
+ systemProgram: web3_js_1.SystemProgram.programId,
89
+ })
90
+ .rpc();
91
+ }
92
+ /**
93
+ * @name write
94
+ * @description Write data to the ledger (ring buffer + TX log simultaneously).
95
+ * Cost: TX fee only (~0.000005 SOL). ZERO additional rent.
96
+ * @param sessionPda - The session ledger PDA.
97
+ * @param data - The data payload to write (Buffer or Uint8Array).
98
+ * @param contentHash - A 32-byte SHA-256 content hash for verification.
99
+ * @returns {Promise<TransactionSignature>} The transaction signature.
100
+ * @since v0.1.0
101
+ */
102
+ async write(sessionPda, data, contentHash) {
103
+ const [ledgerPda] = (0, pda_1.deriveLedger)(sessionPda);
104
+ return this.methods
105
+ .writeLedger(Buffer.from(data), contentHash)
106
+ .accounts({
107
+ wallet: this.walletPubkey,
108
+ session: sessionPda,
109
+ ledger: ledgerPda,
110
+ })
111
+ .rpc();
112
+ }
113
+ /**
114
+ * @name seal
115
+ * @description Seal the ring buffer into a permanent `LedgerPage`.
116
+ * Pages are WRITE-ONCE, NEVER-DELETE: ~0.031 SOL per page.
117
+ * Automatically fetches the current page index from the ledger.
118
+ * @param sessionPda - The session ledger PDA.
119
+ * @returns {Promise<TransactionSignature>} The transaction signature.
120
+ * @since v0.1.0
121
+ */
122
+ async seal(sessionPda) {
123
+ const [ledgerPda] = (0, pda_1.deriveLedger)(sessionPda);
124
+ // Fetch ledger to get current page index
125
+ const ledger = await this.fetchLedger(sessionPda);
126
+ const [pagePda] = (0, pda_1.deriveLedgerPage)(ledgerPda, ledger.numPages);
127
+ return this.methods
128
+ .sealLedger()
129
+ .accounts({
130
+ wallet: this.walletPubkey,
131
+ session: sessionPda,
132
+ ledger: ledgerPda,
133
+ page: pagePda,
134
+ systemProgram: web3_js_1.SystemProgram.programId,
135
+ })
136
+ .rpc();
137
+ }
138
+ /**
139
+ * @name close
140
+ * @description Close a ledger PDA and reclaim ~0.032 SOL rent.
141
+ * @param sessionPda - The session ledger PDA.
142
+ * @returns {Promise<TransactionSignature>} The transaction signature.
143
+ * @since v0.1.0
144
+ */
145
+ async close(sessionPda) {
146
+ const [ledgerPda] = (0, pda_1.deriveLedger)(sessionPda);
147
+ return this.methods
148
+ .closeLedger()
149
+ .accounts({
150
+ wallet: this.walletPubkey,
151
+ session: sessionPda,
152
+ ledger: ledgerPda,
153
+ })
154
+ .rpc();
155
+ }
156
+ // ── Fetchers ─────────────────────────────────────────
157
+ /**
158
+ * @name fetchLedger
159
+ * @description Fetch a deserialized `MemoryLedger` account.
160
+ * @param sessionPda - The session ledger PDA.
161
+ * @returns {Promise<MemoryLedgerData>} The memory ledger data.
162
+ * @throws Will throw if the ledger does not exist.
163
+ * @since v0.1.0
164
+ */
165
+ async fetchLedger(sessionPda) {
166
+ const [pda] = (0, pda_1.deriveLedger)(sessionPda);
167
+ return this.fetchAccount("memoryLedger", pda);
168
+ }
169
+ /**
170
+ * @name fetchLedgerNullable
171
+ * @description Fetch a deserialized `MemoryLedger` account, or `null`
172
+ * if it does not exist on-chain.
173
+ * @param sessionPda - The session ledger PDA.
174
+ * @returns {Promise<MemoryLedgerData | null>} The ledger data or `null`.
175
+ * @since v0.1.0
176
+ */
177
+ async fetchLedgerNullable(sessionPda) {
178
+ const [pda] = (0, pda_1.deriveLedger)(sessionPda);
179
+ return this.fetchAccountNullable("memoryLedger", pda);
180
+ }
181
+ /**
182
+ * @name fetchPage
183
+ * @description Fetch a deserialized sealed `LedgerPage` account.
184
+ * @param ledgerPda - The memory ledger PDA.
185
+ * @param pageIndex - The zero-based page index.
186
+ * @returns {Promise<LedgerPageData>} The ledger page data.
187
+ * @throws Will throw if the page does not exist.
188
+ * @since v0.1.0
189
+ */
190
+ async fetchPage(ledgerPda, pageIndex) {
191
+ const [pda] = (0, pda_1.deriveLedgerPage)(ledgerPda, pageIndex);
192
+ return this.fetchAccount("ledgerPage", pda);
193
+ }
194
+ /**
195
+ * @name fetchPageNullable
196
+ * @description Fetch a deserialized sealed `LedgerPage` account, or `null`
197
+ * if it does not exist on-chain.
198
+ * @param ledgerPda - The memory ledger PDA.
199
+ * @param pageIndex - The zero-based page index.
200
+ * @returns {Promise<LedgerPageData | null>} The page data or `null`.
201
+ * @since v0.1.0
202
+ */
203
+ async fetchPageNullable(ledgerPda, pageIndex) {
204
+ const [pda] = (0, pda_1.deriveLedgerPage)(ledgerPda, pageIndex);
205
+ return this.fetchAccountNullable("ledgerPage", pda);
206
+ }
207
+ /**
208
+ * @name decodeRingBuffer
209
+ * @description Decode the ring buffer into individual entries.
210
+ * Each entry is stored as `[u16 LE data_len][data bytes]`.
211
+ * An entry with `data_len === 0` acts as the empty sentinel.
212
+ * @param ring - Raw ring buffer data (byte array or Uint8Array).
213
+ * @returns {Uint8Array[]} Array of decoded data entries.
214
+ * @since v0.1.0
215
+ */
216
+ decodeRingBuffer(ring) {
217
+ const buf = Buffer.from(ring);
218
+ const entries = [];
219
+ let offset = 0;
220
+ while (offset + 2 <= buf.length) {
221
+ const len = buf.readUInt16LE(offset);
222
+ if (len === 0)
223
+ break; // empty sentinel
224
+ offset += 2;
225
+ if (offset + len > buf.length)
226
+ break;
227
+ entries.push(new Uint8Array(buf.subarray(offset, offset + len)));
228
+ offset += len;
229
+ }
230
+ return entries;
231
+ }
232
+ }
233
+ exports.LedgerModule = LedgerModule;
234
+ //# sourceMappingURL=ledger.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ledger.js","sourceRoot":"","sources":["../../../src/modules/ledger.ts"],"names":[],"mappings":"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"}