@oobe-protocol-labs/synapse-sap-sdk 0.14.0 → 0.15.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 (651) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +986 -0
  3. package/dist/cjs/client.js +30 -13
  4. package/dist/cjs/client.js.map +1 -1
  5. package/dist/cjs/constants/addresses.js +143 -0
  6. package/dist/cjs/constants/addresses.js.map +1 -0
  7. package/dist/cjs/constants/index.js +64 -0
  8. package/dist/cjs/constants/index.js.map +1 -0
  9. package/dist/cjs/constants/limits.js +161 -0
  10. package/dist/cjs/constants/limits.js.map +1 -0
  11. package/dist/cjs/constants/network.js +81 -0
  12. package/dist/cjs/constants/network.js.map +1 -0
  13. package/dist/cjs/constants/payments.js +137 -0
  14. package/dist/cjs/constants/payments.js.map +1 -0
  15. package/dist/cjs/constants/programs.js +78 -0
  16. package/dist/cjs/constants/programs.js.map +1 -0
  17. package/dist/cjs/constants/seeds.js +76 -0
  18. package/dist/cjs/constants/seeds.js.map +1 -0
  19. package/dist/cjs/constants.js +39 -32
  20. package/dist/cjs/constants.js.map +1 -1
  21. package/dist/cjs/core/client.js +546 -0
  22. package/dist/cjs/core/client.js.map +1 -0
  23. package/dist/cjs/core/connection.js +350 -0
  24. package/dist/cjs/core/connection.js.map +1 -0
  25. package/dist/cjs/core/index.js +25 -0
  26. package/dist/cjs/core/index.js.map +1 -0
  27. package/dist/cjs/errors/index.js +334 -0
  28. package/dist/cjs/errors/index.js.map +1 -0
  29. package/dist/cjs/errors.js +15 -5
  30. package/dist/cjs/errors.js.map +1 -1
  31. package/dist/cjs/events/geyser.js +295 -0
  32. package/dist/cjs/events/geyser.js.map +1 -0
  33. package/dist/cjs/events/index.js +32 -26
  34. package/dist/cjs/events/index.js.map +1 -1
  35. package/dist/cjs/idl/index.js +63 -0
  36. package/dist/cjs/idl/index.js.map +1 -0
  37. package/dist/cjs/idl/synapse_agent_sap.json +14595 -0
  38. package/dist/cjs/instructions/agent.js +1 -0
  39. package/dist/cjs/instructions/agent.js.map +1 -1
  40. package/dist/cjs/instructions/attestation.js +1 -0
  41. package/dist/cjs/instructions/attestation.js.map +1 -1
  42. package/dist/cjs/instructions/digest.js +1 -0
  43. package/dist/cjs/instructions/digest.js.map +1 -1
  44. package/dist/cjs/instructions/dispute.js +1 -0
  45. package/dist/cjs/instructions/dispute.js.map +1 -1
  46. package/dist/cjs/instructions/escrow.js +1 -0
  47. package/dist/cjs/instructions/escrow.js.map +1 -1
  48. package/dist/cjs/instructions/global.js +1 -0
  49. package/dist/cjs/instructions/global.js.map +1 -1
  50. package/dist/cjs/instructions/indexing.js +1 -0
  51. package/dist/cjs/instructions/indexing.js.map +1 -1
  52. package/dist/cjs/instructions/misc.js +1 -0
  53. package/dist/cjs/instructions/misc.js.map +1 -1
  54. package/dist/cjs/instructions/session.js +1 -0
  55. package/dist/cjs/instructions/session.js.map +1 -1
  56. package/dist/cjs/instructions/staking.js +1 -0
  57. package/dist/cjs/instructions/staking.js.map +1 -1
  58. package/dist/cjs/instructions/subscription.js +1 -0
  59. package/dist/cjs/instructions/subscription.js.map +1 -1
  60. package/dist/cjs/instructions/tools.js +1 -0
  61. package/dist/cjs/instructions/tools.js.map +1 -1
  62. package/dist/cjs/instructions/vault.js +1 -0
  63. package/dist/cjs/instructions/vault.js.map +1 -1
  64. package/dist/cjs/modules/agent.js +272 -0
  65. package/dist/cjs/modules/agent.js.map +1 -0
  66. package/dist/cjs/modules/attestation.js +147 -0
  67. package/dist/cjs/modules/attestation.js.map +1 -0
  68. package/dist/cjs/modules/base.js +189 -0
  69. package/dist/cjs/modules/base.js.map +1 -0
  70. package/dist/cjs/modules/escrow-v2.js +607 -0
  71. package/dist/cjs/modules/escrow-v2.js.map +1 -0
  72. package/dist/cjs/modules/escrow.js +336 -0
  73. package/dist/cjs/modules/escrow.js.map +1 -0
  74. package/dist/cjs/modules/feedback.js +166 -0
  75. package/dist/cjs/modules/feedback.js.map +1 -0
  76. package/dist/cjs/modules/index.js +43 -0
  77. package/dist/cjs/modules/index.js.map +1 -0
  78. package/dist/cjs/modules/indexing.js +375 -0
  79. package/dist/cjs/modules/indexing.js.map +1 -0
  80. package/dist/cjs/modules/ledger.js +234 -0
  81. package/dist/cjs/modules/ledger.js.map +1 -0
  82. package/dist/cjs/modules/receipt.js +148 -0
  83. package/dist/cjs/modules/receipt.js.map +1 -0
  84. package/dist/cjs/modules/staking.js +159 -0
  85. package/dist/cjs/modules/staking.js.map +1 -0
  86. package/dist/cjs/modules/subscription.js +96 -0
  87. package/dist/cjs/modules/subscription.js.map +1 -0
  88. package/dist/cjs/modules/tools.js +345 -0
  89. package/dist/cjs/modules/tools.js.map +1 -0
  90. package/dist/cjs/modules/vault.js +427 -0
  91. package/dist/cjs/modules/vault.js.map +1 -0
  92. package/dist/cjs/parser/client.js +146 -0
  93. package/dist/cjs/parser/client.js.map +1 -0
  94. package/dist/cjs/parser/complete.js +177 -0
  95. package/dist/cjs/parser/complete.js.map +1 -0
  96. package/dist/cjs/parser/index.js +57 -0
  97. package/dist/cjs/parser/index.js.map +1 -0
  98. package/dist/cjs/parser/inner.js +185 -0
  99. package/dist/cjs/parser/inner.js.map +1 -0
  100. package/dist/cjs/parser/instructions.js +114 -0
  101. package/dist/cjs/parser/instructions.js.map +1 -0
  102. package/dist/cjs/parser/transaction.js +153 -0
  103. package/dist/cjs/parser/transaction.js.map +1 -0
  104. package/dist/cjs/parser/types.js +14 -0
  105. package/dist/cjs/parser/types.js.map +1 -0
  106. package/dist/cjs/pda/index.js +672 -0
  107. package/dist/cjs/pda/index.js.map +1 -0
  108. package/dist/cjs/plugin/index.js +952 -0
  109. package/dist/cjs/plugin/index.js.map +1 -0
  110. package/dist/cjs/plugin/protocols.js +282 -0
  111. package/dist/cjs/plugin/protocols.js.map +1 -0
  112. package/dist/cjs/plugin/schemas.js +863 -0
  113. package/dist/cjs/plugin/schemas.js.map +1 -0
  114. package/dist/cjs/postgres/adapter.js +715 -0
  115. package/dist/cjs/postgres/adapter.js.map +1 -0
  116. package/dist/cjs/postgres/index.js +50 -0
  117. package/dist/cjs/postgres/index.js.map +1 -0
  118. package/dist/cjs/postgres/serializers.js +381 -0
  119. package/dist/cjs/postgres/serializers.js.map +1 -0
  120. package/dist/cjs/postgres/sync.js +289 -0
  121. package/dist/cjs/postgres/sync.js.map +1 -0
  122. package/dist/cjs/postgres/types.js +44 -0
  123. package/dist/cjs/postgres/types.js.map +1 -0
  124. package/dist/cjs/registries/builder.js +414 -0
  125. package/dist/cjs/registries/builder.js.map +1 -0
  126. package/dist/cjs/registries/discovery.js +362 -0
  127. package/dist/cjs/registries/discovery.js.map +1 -0
  128. package/dist/cjs/registries/fairscale.js +639 -0
  129. package/dist/cjs/registries/fairscale.js.map +1 -0
  130. package/dist/cjs/registries/index.js +58 -0
  131. package/dist/cjs/registries/index.js.map +1 -0
  132. package/dist/cjs/registries/metaplex-bridge.js +743 -0
  133. package/dist/cjs/registries/metaplex-bridge.js.map +1 -0
  134. package/dist/cjs/registries/session.js +433 -0
  135. package/dist/cjs/registries/session.js.map +1 -0
  136. package/dist/cjs/registries/x402.js +668 -0
  137. package/dist/cjs/registries/x402.js.map +1 -0
  138. package/dist/cjs/types/accounts.js +13 -0
  139. package/dist/cjs/types/accounts.js.map +1 -0
  140. package/dist/cjs/types/common.js +13 -0
  141. package/dist/cjs/types/common.js.map +1 -0
  142. package/dist/cjs/types/endpoint.js +15 -0
  143. package/dist/cjs/types/endpoint.js.map +1 -0
  144. package/dist/cjs/types/enums.js +269 -0
  145. package/dist/cjs/types/enums.js.map +1 -0
  146. package/dist/cjs/types/index.js +41 -0
  147. package/dist/cjs/types/index.js.map +1 -0
  148. package/dist/cjs/types/instructions.js +92 -0
  149. package/dist/cjs/types/instructions.js.map +1 -0
  150. package/dist/cjs/types.js +4 -1
  151. package/dist/cjs/types.js.map +1 -1
  152. package/dist/cjs/utils/anchor-errors.js +453 -0
  153. package/dist/cjs/utils/anchor-errors.js.map +1 -0
  154. package/dist/cjs/utils/endpoint-validator.js +232 -0
  155. package/dist/cjs/utils/endpoint-validator.js.map +1 -0
  156. package/dist/cjs/utils/escrow-validation.js +219 -0
  157. package/dist/cjs/utils/escrow-validation.js.map +1 -0
  158. package/dist/cjs/utils/hash.js +109 -0
  159. package/dist/cjs/utils/hash.js.map +1 -0
  160. package/dist/cjs/utils/index.js +10 -4
  161. package/dist/cjs/utils/index.js.map +1 -1
  162. package/dist/cjs/utils/merchant-validator.js +246 -0
  163. package/dist/cjs/utils/merchant-validator.js.map +1 -0
  164. package/dist/cjs/utils/network-normalizer.js +236 -0
  165. package/dist/cjs/utils/network-normalizer.js.map +1 -0
  166. package/dist/cjs/utils/priority-fee.js +215 -0
  167. package/dist/cjs/utils/priority-fee.js.map +1 -0
  168. package/dist/cjs/utils/rpc-strategy.js +239 -0
  169. package/dist/cjs/utils/rpc-strategy.js.map +1 -0
  170. package/dist/cjs/utils/schemas.js +331 -0
  171. package/dist/cjs/utils/schemas.js.map +1 -0
  172. package/dist/cjs/utils/serialization.js +105 -0
  173. package/dist/cjs/utils/serialization.js.map +1 -0
  174. package/dist/cjs/utils/validate.js +1 -1
  175. package/dist/cjs/utils/validate.js.map +1 -1
  176. package/dist/cjs/utils/validation.js +36 -0
  177. package/dist/cjs/utils/validation.js.map +1 -0
  178. package/dist/cjs/utils/volume-curve.js +117 -0
  179. package/dist/cjs/utils/volume-curve.js.map +1 -0
  180. package/dist/cjs/utils/x402-direct.js +231 -0
  181. package/dist/cjs/utils/x402-direct.js.map +1 -0
  182. package/dist/esm/client.js +30 -13
  183. package/dist/esm/client.js.map +1 -1
  184. package/dist/esm/constants/addresses.d.ts +117 -0
  185. package/dist/esm/constants/addresses.d.ts.map +1 -0
  186. package/dist/esm/constants/addresses.js +140 -0
  187. package/dist/esm/constants/addresses.js.map +1 -0
  188. package/dist/esm/constants/index.d.ts +31 -0
  189. package/dist/esm/constants/index.d.ts.map +1 -0
  190. package/dist/esm/constants/index.js +35 -0
  191. package/dist/esm/constants/index.js.map +1 -0
  192. package/dist/esm/constants/limits.d.ts +149 -0
  193. package/dist/esm/constants/limits.d.ts.map +1 -0
  194. package/dist/esm/constants/limits.js +158 -0
  195. package/dist/esm/constants/limits.js.map +1 -0
  196. package/dist/esm/constants/network.d.ts +81 -0
  197. package/dist/esm/constants/network.d.ts.map +1 -0
  198. package/dist/esm/constants/network.js +78 -0
  199. package/dist/esm/constants/network.js.map +1 -0
  200. package/dist/esm/constants/payments.d.ts +121 -0
  201. package/dist/esm/constants/payments.d.ts.map +1 -0
  202. package/dist/esm/constants/payments.js +131 -0
  203. package/dist/esm/constants/payments.js.map +1 -0
  204. package/dist/esm/constants/programs.d.ts +69 -0
  205. package/dist/esm/constants/programs.d.ts.map +1 -0
  206. package/dist/esm/constants/programs.js +75 -0
  207. package/dist/esm/constants/programs.js.map +1 -0
  208. package/dist/esm/constants/seeds.d.ts +80 -0
  209. package/dist/esm/constants/seeds.d.ts.map +1 -0
  210. package/dist/esm/constants/seeds.js +73 -0
  211. package/dist/esm/constants/seeds.js.map +1 -0
  212. package/dist/esm/constants.d.ts +14 -27
  213. package/dist/esm/constants.d.ts.map +1 -1
  214. package/dist/esm/constants.js +16 -31
  215. package/dist/esm/constants.js.map +1 -1
  216. package/dist/esm/core/client.d.ts +452 -0
  217. package/dist/esm/core/client.d.ts.map +1 -0
  218. package/dist/esm/core/client.js +539 -0
  219. package/dist/esm/core/client.js.map +1 -0
  220. package/dist/esm/core/connection.d.ts +305 -0
  221. package/dist/esm/core/connection.d.ts.map +1 -0
  222. package/dist/esm/core/connection.js +345 -0
  223. package/dist/esm/core/connection.js.map +1 -0
  224. package/dist/esm/core/index.d.ts +20 -0
  225. package/dist/esm/core/index.d.ts.map +1 -0
  226. package/dist/esm/core/index.js +19 -0
  227. package/dist/esm/core/index.js.map +1 -0
  228. package/dist/esm/errors/index.d.ts +276 -0
  229. package/dist/esm/errors/index.d.ts.map +1 -0
  230. package/dist/esm/errors/index.js +325 -0
  231. package/dist/esm/errors/index.js.map +1 -0
  232. package/dist/esm/errors.d.ts +8 -0
  233. package/dist/esm/errors.d.ts.map +1 -1
  234. package/dist/esm/errors.js +8 -0
  235. package/dist/esm/errors.js.map +1 -1
  236. package/dist/esm/events/geyser.d.ts +150 -0
  237. package/dist/esm/events/geyser.d.ts.map +1 -0
  238. package/dist/esm/events/geyser.js +258 -0
  239. package/dist/esm/events/geyser.js.map +1 -0
  240. package/dist/esm/events/index.d.ts +11 -7
  241. package/dist/esm/events/index.d.ts.map +1 -1
  242. package/dist/esm/events/index.js +30 -26
  243. package/dist/esm/events/index.js.map +1 -1
  244. package/dist/esm/idl/index.d.ts +70 -0
  245. package/dist/esm/idl/index.d.ts.map +1 -0
  246. package/dist/esm/idl/index.js +57 -0
  247. package/dist/esm/idl/index.js.map +1 -0
  248. package/dist/esm/idl/synapse_agent_sap.json +14595 -0
  249. package/dist/esm/instructions/agent.js +1 -0
  250. package/dist/esm/instructions/agent.js.map +1 -1
  251. package/dist/esm/instructions/attestation.js +1 -0
  252. package/dist/esm/instructions/attestation.js.map +1 -1
  253. package/dist/esm/instructions/digest.js +1 -0
  254. package/dist/esm/instructions/digest.js.map +1 -1
  255. package/dist/esm/instructions/dispute.js +1 -0
  256. package/dist/esm/instructions/dispute.js.map +1 -1
  257. package/dist/esm/instructions/escrow.js +1 -0
  258. package/dist/esm/instructions/escrow.js.map +1 -1
  259. package/dist/esm/instructions/global.js +1 -0
  260. package/dist/esm/instructions/global.js.map +1 -1
  261. package/dist/esm/instructions/indexing.js +1 -0
  262. package/dist/esm/instructions/indexing.js.map +1 -1
  263. package/dist/esm/instructions/misc.js +1 -0
  264. package/dist/esm/instructions/misc.js.map +1 -1
  265. package/dist/esm/instructions/session.js +1 -0
  266. package/dist/esm/instructions/session.js.map +1 -1
  267. package/dist/esm/instructions/staking.js +1 -0
  268. package/dist/esm/instructions/staking.js.map +1 -1
  269. package/dist/esm/instructions/subscription.js +1 -0
  270. package/dist/esm/instructions/subscription.js.map +1 -1
  271. package/dist/esm/instructions/tools.js +1 -0
  272. package/dist/esm/instructions/tools.js.map +1 -1
  273. package/dist/esm/instructions/vault.js +1 -0
  274. package/dist/esm/instructions/vault.js.map +1 -1
  275. package/dist/esm/modules/agent.d.ts +166 -0
  276. package/dist/esm/modules/agent.d.ts.map +1 -0
  277. package/dist/esm/modules/agent.js +268 -0
  278. package/dist/esm/modules/agent.js.map +1 -0
  279. package/dist/esm/modules/attestation.d.ts +96 -0
  280. package/dist/esm/modules/attestation.d.ts.map +1 -0
  281. package/dist/esm/modules/attestation.js +143 -0
  282. package/dist/esm/modules/attestation.js.map +1 -0
  283. package/dist/esm/modules/base.d.ts +161 -0
  284. package/dist/esm/modules/base.d.ts.map +1 -0
  285. package/dist/esm/modules/base.js +185 -0
  286. package/dist/esm/modules/base.js.map +1 -0
  287. package/dist/esm/modules/escrow-v2.d.ts +169 -0
  288. package/dist/esm/modules/escrow-v2.d.ts.map +1 -0
  289. package/dist/esm/modules/escrow-v2.js +603 -0
  290. package/dist/esm/modules/escrow-v2.js.map +1 -0
  291. package/dist/esm/modules/escrow.d.ts +168 -0
  292. package/dist/esm/modules/escrow.d.ts.map +1 -0
  293. package/dist/esm/modules/escrow.js +332 -0
  294. package/dist/esm/modules/escrow.js.map +1 -0
  295. package/dist/esm/modules/feedback.d.ts +105 -0
  296. package/dist/esm/modules/feedback.d.ts.map +1 -0
  297. package/dist/esm/modules/feedback.js +162 -0
  298. package/dist/esm/modules/feedback.js.map +1 -0
  299. package/dist/esm/modules/index.d.ts +28 -0
  300. package/dist/esm/modules/index.d.ts.map +1 -0
  301. package/dist/esm/modules/index.js +27 -0
  302. package/dist/esm/modules/index.js.map +1 -0
  303. package/dist/esm/modules/indexing.d.ts +200 -0
  304. package/dist/esm/modules/indexing.d.ts.map +1 -0
  305. package/dist/esm/modules/indexing.js +371 -0
  306. package/dist/esm/modules/indexing.js.map +1 -0
  307. package/dist/esm/modules/ledger.d.ts +150 -0
  308. package/dist/esm/modules/ledger.d.ts.map +1 -0
  309. package/dist/esm/modules/ledger.js +230 -0
  310. package/dist/esm/modules/ledger.js.map +1 -0
  311. package/dist/esm/modules/receipt.d.ts +77 -0
  312. package/dist/esm/modules/receipt.d.ts.map +1 -0
  313. package/dist/esm/modules/receipt.js +144 -0
  314. package/dist/esm/modules/receipt.js.map +1 -0
  315. package/dist/esm/modules/staking.d.ts +51 -0
  316. package/dist/esm/modules/staking.d.ts.map +1 -0
  317. package/dist/esm/modules/staking.js +155 -0
  318. package/dist/esm/modules/staking.js.map +1 -0
  319. package/dist/esm/modules/subscription.d.ts +33 -0
  320. package/dist/esm/modules/subscription.d.ts.map +1 -0
  321. package/dist/esm/modules/subscription.js +92 -0
  322. package/dist/esm/modules/subscription.js.map +1 -0
  323. package/dist/esm/modules/tools.d.ts +182 -0
  324. package/dist/esm/modules/tools.d.ts.map +1 -0
  325. package/dist/esm/modules/tools.js +341 -0
  326. package/dist/esm/modules/tools.js.map +1 -0
  327. package/dist/esm/modules/vault.d.ts +240 -0
  328. package/dist/esm/modules/vault.d.ts.map +1 -0
  329. package/dist/esm/modules/vault.js +423 -0
  330. package/dist/esm/modules/vault.js.map +1 -0
  331. package/dist/esm/parser/client.d.ts +123 -0
  332. package/dist/esm/parser/client.d.ts.map +1 -0
  333. package/dist/esm/parser/client.js +142 -0
  334. package/dist/esm/parser/client.js.map +1 -0
  335. package/dist/esm/parser/complete.d.ts +90 -0
  336. package/dist/esm/parser/complete.d.ts.map +1 -0
  337. package/dist/esm/parser/complete.js +173 -0
  338. package/dist/esm/parser/complete.js.map +1 -0
  339. package/dist/esm/parser/index.d.ts +40 -0
  340. package/dist/esm/parser/index.d.ts.map +1 -0
  341. package/dist/esm/parser/index.js +43 -0
  342. package/dist/esm/parser/index.js.map +1 -0
  343. package/dist/esm/parser/inner.d.ts +114 -0
  344. package/dist/esm/parser/inner.d.ts.map +1 -0
  345. package/dist/esm/parser/inner.js +180 -0
  346. package/dist/esm/parser/inner.js.map +1 -0
  347. package/dist/esm/parser/instructions.d.ts +76 -0
  348. package/dist/esm/parser/instructions.d.ts.map +1 -0
  349. package/dist/esm/parser/instructions.js +109 -0
  350. package/dist/esm/parser/instructions.js.map +1 -0
  351. package/dist/esm/parser/transaction.d.ts +77 -0
  352. package/dist/esm/parser/transaction.d.ts.map +1 -0
  353. package/dist/esm/parser/transaction.js +149 -0
  354. package/dist/esm/parser/transaction.js.map +1 -0
  355. package/dist/esm/parser/types.d.ts +154 -0
  356. package/dist/esm/parser/types.d.ts.map +1 -0
  357. package/dist/esm/parser/types.js +13 -0
  358. package/dist/esm/parser/types.js.map +1 -0
  359. package/dist/esm/pda/index.d.ts +510 -0
  360. package/dist/esm/pda/index.d.ts.map +1 -0
  361. package/dist/esm/pda/index.js +638 -0
  362. package/dist/esm/pda/index.js.map +1 -0
  363. package/dist/esm/plugin/index.d.ts +171 -0
  364. package/dist/esm/plugin/index.d.ts.map +1 -0
  365. package/dist/esm/plugin/index.js +945 -0
  366. package/dist/esm/plugin/index.js.map +1 -0
  367. package/dist/esm/plugin/protocols.d.ts +152 -0
  368. package/dist/esm/plugin/protocols.d.ts.map +1 -0
  369. package/dist/esm/plugin/protocols.js +279 -0
  370. package/dist/esm/plugin/protocols.js.map +1 -0
  371. package/dist/esm/plugin/schemas.d.ts +829 -0
  372. package/dist/esm/plugin/schemas.d.ts.map +1 -0
  373. package/dist/esm/plugin/schemas.js +860 -0
  374. package/dist/esm/plugin/schemas.js.map +1 -0
  375. package/dist/esm/postgres/adapter.d.ts +355 -0
  376. package/dist/esm/postgres/adapter.d.ts.map +1 -0
  377. package/dist/esm/postgres/adapter.js +678 -0
  378. package/dist/esm/postgres/adapter.js.map +1 -0
  379. package/dist/esm/postgres/index.d.ts +24 -0
  380. package/dist/esm/postgres/index.d.ts.map +1 -0
  381. package/dist/esm/postgres/index.js +27 -0
  382. package/dist/esm/postgres/index.js.map +1 -0
  383. package/dist/esm/postgres/serializers.d.ts +30 -0
  384. package/dist/esm/postgres/serializers.d.ts.map +1 -0
  385. package/dist/esm/postgres/serializers.js +362 -0
  386. package/dist/esm/postgres/serializers.js.map +1 -0
  387. package/dist/esm/postgres/sync.d.ts +156 -0
  388. package/dist/esm/postgres/sync.d.ts.map +1 -0
  389. package/dist/esm/postgres/sync.js +285 -0
  390. package/dist/esm/postgres/sync.js.map +1 -0
  391. package/dist/esm/postgres/types.d.ts +167 -0
  392. package/dist/esm/postgres/types.d.ts.map +1 -0
  393. package/dist/esm/postgres/types.js +41 -0
  394. package/dist/esm/postgres/types.js.map +1 -0
  395. package/dist/esm/registries/builder.d.ts +340 -0
  396. package/dist/esm/registries/builder.d.ts.map +1 -0
  397. package/dist/esm/registries/builder.js +410 -0
  398. package/dist/esm/registries/builder.js.map +1 -0
  399. package/dist/esm/registries/discovery.d.ts +333 -0
  400. package/dist/esm/registries/discovery.d.ts.map +1 -0
  401. package/dist/esm/registries/discovery.js +358 -0
  402. package/dist/esm/registries/discovery.js.map +1 -0
  403. package/dist/esm/registries/fairscale.d.ts +680 -0
  404. package/dist/esm/registries/fairscale.d.ts.map +1 -0
  405. package/dist/esm/registries/fairscale.js +633 -0
  406. package/dist/esm/registries/fairscale.js.map +1 -0
  407. package/dist/esm/registries/index.d.ts +52 -0
  408. package/dist/esm/registries/index.d.ts.map +1 -0
  409. package/dist/esm/registries/index.js +46 -0
  410. package/dist/esm/registries/index.js.map +1 -0
  411. package/dist/esm/registries/metaplex-bridge.d.ts +489 -0
  412. package/dist/esm/registries/metaplex-bridge.d.ts.map +1 -0
  413. package/dist/esm/registries/metaplex-bridge.js +706 -0
  414. package/dist/esm/registries/metaplex-bridge.js.map +1 -0
  415. package/dist/esm/registries/session.d.ts +323 -0
  416. package/dist/esm/registries/session.d.ts.map +1 -0
  417. package/dist/esm/registries/session.js +429 -0
  418. package/dist/esm/registries/session.js.map +1 -0
  419. package/dist/esm/registries/x402.d.ts +530 -0
  420. package/dist/esm/registries/x402.d.ts.map +1 -0
  421. package/dist/esm/registries/x402.js +664 -0
  422. package/dist/esm/registries/x402.js.map +1 -0
  423. package/dist/esm/types/accounts.d.ts +765 -0
  424. package/dist/esm/types/accounts.d.ts.map +1 -0
  425. package/dist/esm/types/accounts.js +12 -0
  426. package/dist/esm/types/accounts.js.map +1 -0
  427. package/dist/esm/types/common.d.ts +166 -0
  428. package/dist/esm/types/common.d.ts.map +1 -0
  429. package/dist/esm/types/common.js +12 -0
  430. package/dist/esm/types/common.js.map +1 -0
  431. package/dist/esm/types/endpoint.d.ts +161 -0
  432. package/dist/esm/types/endpoint.d.ts.map +1 -0
  433. package/dist/esm/types/endpoint.js +14 -0
  434. package/dist/esm/types/endpoint.js.map +1 -0
  435. package/dist/esm/types/enums.d.ts +353 -0
  436. package/dist/esm/types/enums.d.ts.map +1 -0
  437. package/dist/esm/types/enums.js +266 -0
  438. package/dist/esm/types/enums.js.map +1 -0
  439. package/dist/esm/types/index.d.ts +29 -0
  440. package/dist/esm/types/index.d.ts.map +1 -0
  441. package/dist/esm/types/index.js +25 -0
  442. package/dist/esm/types/index.js.map +1 -0
  443. package/dist/esm/types/instructions.d.ts +400 -0
  444. package/dist/esm/types/instructions.d.ts.map +1 -0
  445. package/dist/esm/types/instructions.js +89 -0
  446. package/dist/esm/types/instructions.js.map +1 -0
  447. package/dist/esm/types.d.ts +28 -0
  448. package/dist/esm/types.d.ts.map +1 -1
  449. package/dist/esm/types.js +1 -0
  450. package/dist/esm/types.js.map +1 -1
  451. package/dist/esm/utils/anchor-errors.d.ts +61 -0
  452. package/dist/esm/utils/anchor-errors.d.ts.map +1 -0
  453. package/dist/esm/utils/anchor-errors.js +447 -0
  454. package/dist/esm/utils/anchor-errors.js.map +1 -0
  455. package/dist/esm/utils/endpoint-validator.d.ts +110 -0
  456. package/dist/esm/utils/endpoint-validator.d.ts.map +1 -0
  457. package/dist/esm/utils/endpoint-validator.js +226 -0
  458. package/dist/esm/utils/endpoint-validator.js.map +1 -0
  459. package/dist/esm/utils/escrow-validation.d.ts +145 -0
  460. package/dist/esm/utils/escrow-validation.d.ts.map +1 -0
  461. package/dist/esm/utils/escrow-validation.js +212 -0
  462. package/dist/esm/utils/escrow-validation.js.map +1 -0
  463. package/dist/esm/utils/hash.d.ts +75 -0
  464. package/dist/esm/utils/hash.d.ts.map +1 -0
  465. package/dist/esm/utils/hash.js +103 -0
  466. package/dist/esm/utils/hash.js.map +1 -0
  467. package/dist/esm/utils/index.d.ts +3 -1
  468. package/dist/esm/utils/index.d.ts.map +1 -1
  469. package/dist/esm/utils/index.js +6 -3
  470. package/dist/esm/utils/index.js.map +1 -1
  471. package/dist/esm/utils/merchant-validator.d.ts +176 -0
  472. package/dist/esm/utils/merchant-validator.d.ts.map +1 -0
  473. package/dist/esm/utils/merchant-validator.js +241 -0
  474. package/dist/esm/utils/merchant-validator.js.map +1 -0
  475. package/dist/esm/utils/network-normalizer.d.ts +120 -0
  476. package/dist/esm/utils/network-normalizer.d.ts.map +1 -0
  477. package/dist/esm/utils/network-normalizer.js +229 -0
  478. package/dist/esm/utils/network-normalizer.js.map +1 -0
  479. package/dist/esm/utils/priority-fee.d.ts +205 -0
  480. package/dist/esm/utils/priority-fee.d.ts.map +1 -0
  481. package/dist/esm/utils/priority-fee.js +209 -0
  482. package/dist/esm/utils/priority-fee.js.map +1 -0
  483. package/dist/esm/utils/rpc-strategy.d.ts +172 -0
  484. package/dist/esm/utils/rpc-strategy.d.ts.map +1 -0
  485. package/dist/esm/utils/rpc-strategy.js +231 -0
  486. package/dist/esm/utils/rpc-strategy.js.map +1 -0
  487. package/dist/esm/utils/schemas.d.ts +351 -0
  488. package/dist/esm/utils/schemas.d.ts.map +1 -0
  489. package/dist/esm/utils/schemas.js +320 -0
  490. package/dist/esm/utils/schemas.js.map +1 -0
  491. package/dist/esm/utils/serialization.d.ts +69 -0
  492. package/dist/esm/utils/serialization.d.ts.map +1 -0
  493. package/dist/esm/utils/serialization.js +98 -0
  494. package/dist/esm/utils/serialization.js.map +1 -0
  495. package/dist/esm/utils/validate.js +1 -1
  496. package/dist/esm/utils/validate.js.map +1 -1
  497. package/dist/esm/utils/validation.d.ts +29 -0
  498. package/dist/esm/utils/validation.d.ts.map +1 -0
  499. package/dist/esm/utils/validation.js +33 -0
  500. package/dist/esm/utils/validation.js.map +1 -0
  501. package/dist/esm/utils/volume-curve.d.ts +60 -0
  502. package/dist/esm/utils/volume-curve.d.ts.map +1 -0
  503. package/dist/esm/utils/volume-curve.js +114 -0
  504. package/dist/esm/utils/volume-curve.js.map +1 -0
  505. package/dist/esm/utils/x402-direct.d.ts +114 -0
  506. package/dist/esm/utils/x402-direct.d.ts.map +1 -0
  507. package/dist/esm/utils/x402-direct.js +228 -0
  508. package/dist/esm/utils/x402-direct.js.map +1 -0
  509. package/dist/types/constants/addresses.d.ts +117 -0
  510. package/dist/types/constants/addresses.d.ts.map +1 -0
  511. package/dist/types/constants/index.d.ts +31 -0
  512. package/dist/types/constants/index.d.ts.map +1 -0
  513. package/dist/types/constants/limits.d.ts +149 -0
  514. package/dist/types/constants/limits.d.ts.map +1 -0
  515. package/dist/types/constants/network.d.ts +81 -0
  516. package/dist/types/constants/network.d.ts.map +1 -0
  517. package/dist/types/constants/payments.d.ts +121 -0
  518. package/dist/types/constants/payments.d.ts.map +1 -0
  519. package/dist/types/constants/programs.d.ts +69 -0
  520. package/dist/types/constants/programs.d.ts.map +1 -0
  521. package/dist/types/constants/seeds.d.ts +82 -0
  522. package/dist/types/constants/seeds.d.ts.map +1 -0
  523. package/dist/types/core/client.d.ts +467 -0
  524. package/dist/types/core/client.d.ts.map +1 -0
  525. package/dist/types/core/connection.d.ts +305 -0
  526. package/dist/types/core/connection.d.ts.map +1 -0
  527. package/dist/types/core/index.d.ts +20 -0
  528. package/dist/types/core/index.d.ts.map +1 -0
  529. package/dist/types/errors/index.d.ts +335 -0
  530. package/dist/types/errors/index.d.ts.map +1 -0
  531. package/dist/types/events/geyser.d.ts +150 -0
  532. package/dist/types/events/geyser.d.ts.map +1 -0
  533. package/dist/types/events/index.d.ts +248 -0
  534. package/dist/types/events/index.d.ts.map +1 -0
  535. package/dist/types/idl/index.d.ts +70 -0
  536. package/dist/types/idl/index.d.ts.map +1 -0
  537. package/dist/types/index.d.ts +86 -0
  538. package/dist/types/index.d.ts.map +1 -0
  539. package/dist/types/modules/agent.d.ts +156 -0
  540. package/dist/types/modules/agent.d.ts.map +1 -0
  541. package/dist/types/modules/attestation.d.ts +96 -0
  542. package/dist/types/modules/attestation.d.ts.map +1 -0
  543. package/dist/types/modules/base.d.ts +215 -0
  544. package/dist/types/modules/base.d.ts.map +1 -0
  545. package/dist/types/modules/escrow-v2.d.ts +285 -0
  546. package/dist/types/modules/escrow-v2.d.ts.map +1 -0
  547. package/dist/types/modules/feedback.d.ts +105 -0
  548. package/dist/types/modules/feedback.d.ts.map +1 -0
  549. package/dist/types/modules/index.d.ts +27 -0
  550. package/dist/types/modules/index.d.ts.map +1 -0
  551. package/dist/types/modules/indexing.d.ts +200 -0
  552. package/dist/types/modules/indexing.d.ts.map +1 -0
  553. package/dist/types/modules/ledger.d.ts +150 -0
  554. package/dist/types/modules/ledger.d.ts.map +1 -0
  555. package/dist/types/modules/receipt.d.ts +91 -0
  556. package/dist/types/modules/receipt.d.ts.map +1 -0
  557. package/dist/types/modules/staking.d.ts +51 -0
  558. package/dist/types/modules/staking.d.ts.map +1 -0
  559. package/dist/types/modules/subscription.d.ts +33 -0
  560. package/dist/types/modules/subscription.d.ts.map +1 -0
  561. package/dist/types/modules/tools.d.ts +172 -0
  562. package/dist/types/modules/tools.d.ts.map +1 -0
  563. package/dist/types/modules/vault.d.ts +240 -0
  564. package/dist/types/modules/vault.d.ts.map +1 -0
  565. package/dist/types/parser/client.d.ts +123 -0
  566. package/dist/types/parser/client.d.ts.map +1 -0
  567. package/dist/types/parser/complete.d.ts +90 -0
  568. package/dist/types/parser/complete.d.ts.map +1 -0
  569. package/dist/types/parser/index.d.ts +40 -0
  570. package/dist/types/parser/index.d.ts.map +1 -0
  571. package/dist/types/parser/inner.d.ts +114 -0
  572. package/dist/types/parser/inner.d.ts.map +1 -0
  573. package/dist/types/parser/instructions.d.ts +76 -0
  574. package/dist/types/parser/instructions.d.ts.map +1 -0
  575. package/dist/types/parser/transaction.d.ts +77 -0
  576. package/dist/types/parser/transaction.d.ts.map +1 -0
  577. package/dist/types/parser/types.d.ts +154 -0
  578. package/dist/types/parser/types.d.ts.map +1 -0
  579. package/dist/types/pda/index.d.ts +527 -0
  580. package/dist/types/pda/index.d.ts.map +1 -0
  581. package/dist/types/plugin/index.d.ts +171 -0
  582. package/dist/types/plugin/index.d.ts.map +1 -0
  583. package/dist/types/plugin/protocols.d.ts +152 -0
  584. package/dist/types/plugin/protocols.d.ts.map +1 -0
  585. package/dist/types/plugin/schemas.d.ts +829 -0
  586. package/dist/types/plugin/schemas.d.ts.map +1 -0
  587. package/dist/types/postgres/adapter.d.ts +355 -0
  588. package/dist/types/postgres/adapter.d.ts.map +1 -0
  589. package/dist/types/postgres/index.d.ts +24 -0
  590. package/dist/types/postgres/index.d.ts.map +1 -0
  591. package/dist/types/postgres/serializers.d.ts +30 -0
  592. package/dist/types/postgres/serializers.d.ts.map +1 -0
  593. package/dist/types/postgres/sync.d.ts +156 -0
  594. package/dist/types/postgres/sync.d.ts.map +1 -0
  595. package/dist/types/postgres/types.d.ts +167 -0
  596. package/dist/types/postgres/types.d.ts.map +1 -0
  597. package/dist/types/registries/builder.d.ts +333 -0
  598. package/dist/types/registries/builder.d.ts.map +1 -0
  599. package/dist/types/registries/discovery.d.ts +333 -0
  600. package/dist/types/registries/discovery.d.ts.map +1 -0
  601. package/dist/types/registries/fairscale.d.ts +680 -0
  602. package/dist/types/registries/fairscale.d.ts.map +1 -0
  603. package/dist/types/registries/index.d.ts +52 -0
  604. package/dist/types/registries/index.d.ts.map +1 -0
  605. package/dist/types/registries/metaplex-bridge.d.ts +488 -0
  606. package/dist/types/registries/metaplex-bridge.d.ts.map +1 -0
  607. package/dist/types/registries/session.d.ts +317 -0
  608. package/dist/types/registries/session.d.ts.map +1 -0
  609. package/dist/types/registries/x402.d.ts +523 -0
  610. package/dist/types/registries/x402.d.ts.map +1 -0
  611. package/dist/types/types/accounts.d.ts +817 -0
  612. package/dist/types/types/accounts.d.ts.map +1 -0
  613. package/dist/types/types/common.d.ts +166 -0
  614. package/dist/types/types/common.d.ts.map +1 -0
  615. package/dist/types/types/endpoint.d.ts +161 -0
  616. package/dist/types/types/endpoint.d.ts.map +1 -0
  617. package/dist/types/types/enums.d.ts +353 -0
  618. package/dist/types/types/enums.d.ts.map +1 -0
  619. package/dist/types/types/index.d.ts +29 -0
  620. package/dist/types/types/index.d.ts.map +1 -0
  621. package/dist/types/types/instructions.d.ts +400 -0
  622. package/dist/types/types/instructions.d.ts.map +1 -0
  623. package/dist/types/utils/anchor-errors.d.ts +61 -0
  624. package/dist/types/utils/anchor-errors.d.ts.map +1 -0
  625. package/dist/types/utils/endpoint-validator.d.ts +110 -0
  626. package/dist/types/utils/endpoint-validator.d.ts.map +1 -0
  627. package/dist/types/utils/escrow-validation.d.ts +145 -0
  628. package/dist/types/utils/escrow-validation.d.ts.map +1 -0
  629. package/dist/types/utils/hash.d.ts +75 -0
  630. package/dist/types/utils/hash.d.ts.map +1 -0
  631. package/dist/types/utils/index.d.ts +36 -0
  632. package/dist/types/utils/index.d.ts.map +1 -0
  633. package/dist/types/utils/merchant-validator.d.ts +176 -0
  634. package/dist/types/utils/merchant-validator.d.ts.map +1 -0
  635. package/dist/types/utils/network-normalizer.d.ts +120 -0
  636. package/dist/types/utils/network-normalizer.d.ts.map +1 -0
  637. package/dist/types/utils/priority-fee.d.ts +205 -0
  638. package/dist/types/utils/priority-fee.d.ts.map +1 -0
  639. package/dist/types/utils/rpc-strategy.d.ts +179 -0
  640. package/dist/types/utils/rpc-strategy.d.ts.map +1 -0
  641. package/dist/types/utils/schemas.d.ts +351 -0
  642. package/dist/types/utils/schemas.d.ts.map +1 -0
  643. package/dist/types/utils/serialization.d.ts +69 -0
  644. package/dist/types/utils/serialization.d.ts.map +1 -0
  645. package/dist/types/utils/validation.d.ts +29 -0
  646. package/dist/types/utils/validation.d.ts.map +1 -0
  647. package/dist/types/utils/volume-curve.d.ts +60 -0
  648. package/dist/types/utils/volume-curve.d.ts.map +1 -0
  649. package/dist/types/utils/x402-direct.d.ts +114 -0
  650. package/dist/types/utils/x402-direct.d.ts.map +1 -0
  651. package/package.json +2 -2
package/README.md ADDED
@@ -0,0 +1,986 @@
1
+ # @synapse-sap/sdk
2
+
3
+ > TypeScript SDK for the **Synapse Agent Protocol (SAP v2)** on Solana.
4
+
5
+ [![License: MIT](https://img.shields.io/badge/License-MIT-blue.svg)](LICENSE)
6
+ [![TypeScript](https://img.shields.io/badge/TypeScript-5.7-blue.svg)](https://www.typescriptlang.org/)
7
+ [![Solana](https://img.shields.io/badge/Solana-Anchor%200.32-purple.svg)](https://www.anchor-lang.com/)
8
+
9
+ ---
10
+
11
+ ## Table of Contents
12
+
13
+ - [Features](#features)
14
+ - [Installation](#installation)
15
+ - [CLI — `synapse-sap`](#cli--synapse-sap)
16
+ - [Quick Start](#quick-start)
17
+ - [Architecture](#architecture)
18
+ - [Core — Client & Connection](#core--client--connection)
19
+ - [Modules (Low-Level)](#modules-low-level)
20
+ - [Registries (High-Level)](#registries-high-level)
21
+ - [Plugin (SynapseAgentKit)](#plugin-synapseagentkit)
22
+ - [PDA Derivation](#pda-derivation)
23
+ - [Events](#events)
24
+ - [Error Handling](#error-handling)
25
+ - [Utilities](#utilities)
26
+ - [Types](#types)
27
+ - [Constants](#constants)
28
+ - [Deep Imports](#deep-imports)
29
+ - [API Reference](#api-reference)
30
+ - [Development](#development)
31
+ - [License](#license)
32
+
33
+ ---
34
+
35
+ ## Features
36
+
37
+ - **8 domain modules** — Agent, Feedback, Indexing, Tools, Vault, Escrow, Attestation, Ledger
38
+ - **4 high-level registries** — Discovery, x402 Payments, Session Manager, Agent Builder
39
+ - **52-tool plugin adapter** — drop-in for `SynapseAgentKit` / LangChain tooling
40
+ - **SapConnection** — RPC-first entry point compatible with `synapse-client-sdk`
41
+ - **Typed errors** — `SapError`, `SapRpcError`, `SapAccountNotFoundError`, etc.
42
+ - **Serialization** — automatic `PublicKey`/`BN` → JSON-safe object conversion
43
+ - **17 PDA functions** — deterministic, pure, memoizable
44
+ - **Fully typed** — 17 account interfaces, 11 instruction DTOs, 38 decoded events
45
+ - **Dual output** — CommonJS + ESM with TypeScript declarations
46
+ - **Subpath exports** — `@synapse-sap/sdk/core`, `@synapse-sap/sdk/types`, etc.
47
+ - **Tree-shakeable** — import only what you need
48
+ - **Embedded IDL** — zero external workspace dependency; npm-ready
49
+ - **Strict TypeScript** — `strict`, `noUncheckedIndexedAccess`, `noUnusedLocals`
50
+
51
+ ## Installation
52
+
53
+ ```bash
54
+ # Yarn
55
+ yarn add @synapse-sap/sdk @coral-xyz/anchor @solana/web3.js
56
+
57
+ # npm
58
+ npm install @synapse-sap/sdk @coral-xyz/anchor @solana/web3.js
59
+ ```
60
+
61
+ ### Peer Dependencies
62
+
63
+ | Package | Version | Notes |
64
+ |---------|---------|-------|
65
+ | `@coral-xyz/anchor` | `>=0.30.0` | Required |
66
+ | `@solana/web3.js` | `>=1.90.0` | Required |
67
+ | `zod` | `>=3.20.0` | Optional — only for plugin schemas |
68
+
69
+ ---
70
+
71
+ ## CLI — `synapse-sap`
72
+
73
+ The SDK ships with a full-featured CLI for interacting with the SAP network from
74
+ your terminal.
75
+
76
+ ### Install the CLI
77
+
78
+ ```bash
79
+ # From the monorepo
80
+ cd synapse-sap-sdk/cli
81
+ npm install
82
+ npm run build
83
+ npm link # makes "synapse-sap" available globally
84
+
85
+ # Or install globally from npm (when published separately)
86
+ npm install -g @oobe-protocol-labs/synapse-sap-cli
87
+ ```
88
+
89
+ ### Initial Setup
90
+
91
+ ```bash
92
+ # Generate a .env from template
93
+ synapse-sap env init --template devnet
94
+
95
+ # Set your RPC (OOBE Protocol recommended)
96
+ # Edit .env or use config:
97
+ synapse-sap config set rpcUrl "https://us-1-mainnet.oobeprotocol.ai/rpc?api_key=sk_example123"
98
+
99
+ # Generate or import a keypair
100
+ synapse-sap env keypair generate --out keys/my-agent.json
101
+ synapse-sap env keypair import ./my-existing-key.json --out keys/agent.json
102
+
103
+ # Verify everything works
104
+ synapse-sap doctor run
105
+ ```
106
+
107
+ ### Usage Examples
108
+
109
+ ```bash
110
+ # ─── Agent Discovery ──────────────────────────────────
111
+ synapse-sap agent list --active --protocol kamiyo
112
+ synapse-sap agent info <WALLET> --fetch-tools --fetch-endpoints
113
+ synapse-sap agent health <WALLET> --timeout 5000
114
+ synapse-sap discovery scan --limit 50 --sort reputation --output json
115
+ synapse-sap discovery validate --wallet <WALLET>
116
+
117
+ # ─── Escrow & Payments ────────────────────────────────
118
+ synapse-sap escrow open <AGENT_WALLET> \
119
+ --deposit 100000 --max-calls 100 --token sol
120
+ synapse-sap escrow deposit <AGENT_WALLET> --amount 50000
121
+ synapse-sap escrow list
122
+ synapse-sap escrow monitor <AGENT_WALLET>
123
+
124
+ # ─── x402 Calls ──────────────────────────────────────
125
+ synapse-sap x402 headers <AGENT_WALLET> --network solana:mainnet-beta
126
+ synapse-sap x402 call <AGENT_WALLET> swap \
127
+ --args '{"inputMint":"SOL","outputMint":"USDC","amount":1}' \
128
+ --endpoint https://agent.example.com/x402 \
129
+ --save
130
+ synapse-sap x402 settle <CLIENT_WALLET> --calls 5 --service "batch-result"
131
+
132
+ # ─── Tools & Manifests ────────────────────────────────
133
+ synapse-sap tools manifest generate <WALLET> --out manifest.json --include-schema
134
+ synapse-sap tools manifest validate manifest.json
135
+ synapse-sap tools typify manifest.json --out types/agent.ts
136
+ synapse-sap tools compare <WALLET_A> <WALLET_B>
137
+
138
+ # ─── Diagnostics ──────────────────────────────────────
139
+ synapse-sap doctor run --quick
140
+ synapse-sap env check
141
+ synapse-sap config show
142
+ ```
143
+
144
+ ### Global Flags
145
+
146
+ | Flag | Description |
147
+ |------|-------------|
148
+ | `--rpc <url>` | Override primary RPC (e.g. `https://us-1-mainnet.oobeprotocol.ai/rpc?api_key=sk_...`) |
149
+ | `--fallback-rpc <url>` | Override fallback RPC |
150
+ | `--cluster <cluster>` | `mainnet-beta` \| `devnet` \| `localnet` |
151
+ | `--json` | JSON output for scripting |
152
+ | `--silent` | Suppress log output |
153
+ | `--env-file <path>` | Custom `.env` file path |
154
+
155
+ ### 10 Command Groups
156
+
157
+ | Group | Subcommands | Description |
158
+ |-------|-------------|-------------|
159
+ | `agent` | `list`, `info`, `tools`, `health`, `register` | Agent lifecycle |
160
+ | `discovery` | `scan`, `validate`, `cache` | Network scanning |
161
+ | `escrow` | `open`, `deposit`, `withdraw`, `close`, `dump`, `list`, `monitor` | Escrow management |
162
+ | `x402` | `headers`, `call`, `sign`, `verify`, `settle`, `replay` | Payment flows |
163
+ | `tools` | `manifest generate/validate`, `typify`, `publish`, `compare`, `doc` | Manifest & schema |
164
+ | `env` | `init`, `check`, `keypair show/generate/import` | Environment setup |
165
+ | `config` | `show`, `set`, `edit`, `reset`, `path` | Configuration |
166
+ | `doctor` | `run` | 8 diagnostic checks |
167
+ | `tmp` | `list`, `cat`, `diff`, `clean`, `archive` | Artifact management |
168
+ | `plugin` | `list`, `install`, `create`, `validate` | Plugin system |
169
+
170
+ > Full CLI reference: [`cli/README.md`](cli/README.md)
171
+
172
+ ---
173
+
174
+ ## Quick Start
175
+
176
+ ### Option A — Anchor Provider (classic)
177
+
178
+ ```typescript
179
+ import { SapClient } from "@synapse-sap/sdk";
180
+ import { AnchorProvider } from "@coral-xyz/anchor";
181
+
182
+ const provider = AnchorProvider.env();
183
+ const client = SapClient.from(provider);
184
+
185
+ // Register agent
186
+ await client.agent.register({
187
+ name: "SwapBot",
188
+ description: "AI-powered DEX aggregator",
189
+ capabilities: [{ id: "jupiter:swap", description: null, protocolId: "jupiter", version: "1.0.0" }],
190
+ pricing: [],
191
+ protocols: ["jupiter"],
192
+ });
193
+
194
+ // Fetch agent
195
+ const agent = await client.agent.fetch();
196
+ console.log(agent.name, agent.isActive);
197
+ ```
198
+
199
+ ### Option B — RPC URL + Keypair (synapse-client-sdk compatible)
200
+
201
+ ```typescript
202
+ import { SapConnection } from "@synapse-sap/sdk";
203
+ import { Keypair } from "@solana/web3.js";
204
+
205
+ // One-liner (OOBE Protocol RPC):
206
+ const { client } = SapConnection.fromKeypair(
207
+ "https://us-1-mainnet.oobeprotocol.ai/rpc?api_key=sk_example123",
208
+ Keypair.generate(),
209
+ );
210
+
211
+ // Or step-by-step:
212
+ const conn = SapConnection.mainnet("https://us-1-mainnet.oobeprotocol.ai/rpc?api_key=sk_example123");
213
+ const client = conn.fromKeypair(myKeypair);
214
+
215
+ // Use exactly the same API:
216
+ await client.agent.register({ ... });
217
+ ```
218
+
219
+ ### Option C — Fluent Builder
220
+
221
+ ```typescript
222
+ import { SapClient } from "@synapse-sap/sdk";
223
+
224
+ const client = SapClient.from(provider);
225
+
226
+ await client.builder
227
+ .agent("SwapBot")
228
+ .description("AI-powered swap agent")
229
+ .x402Endpoint("https://api.example.com/x402")
230
+ .addCapability("jupiter:swap", { protocol: "jupiter" })
231
+ .addPricingTier({
232
+ tierId: "standard",
233
+ pricePerCall: 1000,
234
+ rateLimit: 60,
235
+ })
236
+ .register();
237
+ ```
238
+
239
+ ---
240
+
241
+ ## Architecture
242
+
243
+ ### Directory Structure
244
+
245
+ ```
246
+ src/
247
+ ├── index.ts # Root barrel export
248
+
249
+ ├── core/ # Client & connection infrastructure
250
+ │ ├── client.ts # SapClient — Anchor program wrapper
251
+ │ ├── connection.ts # SapConnection — RPC factory (synapse-client-sdk compat)
252
+ │ └── index.ts
253
+
254
+ ├── types/ # On-chain type mirrors
255
+ │ ├── enums.ts # Anchor enum variant objects
256
+ │ ├── common.ts # Shared structs (Capability, PricingTier, …)
257
+ │ ├── accounts.ts # 17 account data interfaces
258
+ │ ├── instructions.ts # 11 instruction arg DTOs + helpers
259
+ │ └── index.ts
260
+
261
+ ├── constants/ # Protocol constants
262
+ │ ├── programs.ts # Network-specific program IDs
263
+ │ ├── seeds.ts # 20 PDA seed prefixes
264
+ │ ├── limits.ts # Size constraints, versions
265
+ │ └── index.ts
266
+
267
+ ├── pda/ # PDA derivation functions
268
+ │ └── index.ts # 17 derive* functions
269
+
270
+ ├── events/ # Event parsing
271
+ │ └── index.ts # EventParser + 38 event types
272
+
273
+ ├── errors/ # Typed SDK error classes
274
+ │ └── index.ts # SapError hierarchy
275
+
276
+ ├── utils/ # Shared utilities
277
+ │ ├── hash.ts # sha256, hashToArray
278
+ │ ├── validation.ts # assert
279
+ │ ├── serialization.ts # serializeAccount, serializeValue
280
+ │ └── index.ts
281
+
282
+ ├── modules/ # Low-level instruction wrappers
283
+ │ ├── base.ts # BaseModule abstract class
284
+ │ ├── agent.ts # Identity, reputation, lifecycle
285
+ │ ├── feedback.ts # Trustless reviews
286
+ │ ├── indexing.ts # Discovery indexes
287
+ │ ├── tools.ts # Tool schema registry
288
+ │ ├── vault.ts # Encrypted memory vault
289
+ │ ├── escrow.ts # x402 micropayments
290
+ │ ├── attestation.ts # Web-of-trust vouching
291
+ │ ├── ledger.ts # Ring-buffer memory
292
+ │ └── index.ts
293
+
294
+ ├── registries/ # High-level abstractions
295
+ │ ├── discovery.ts # DiscoveryRegistry — findAgents*, profiles
296
+ │ ├── x402.ts # X402Registry — pricing, headers, settlement
297
+ │ ├── session.ts # SessionManager — vault+session+ledger lifecycle
298
+ │ ├── builder.ts # AgentBuilder — fluent registration
299
+ │ └── index.ts
300
+
301
+ ├── plugin/ # SynapseAgentKit adapter (52 tools)
302
+ │ ├── index.ts # createSAPPlugin factory
303
+ │ ├── protocols.ts # 8 protocol method registries
304
+ │ └── schemas.ts # Zod schemas for LLM tool validation
305
+
306
+ └── idl/ # Embedded Anchor IDL
307
+ ├── index.ts # SAP_IDL, IDL_PROGRAM_ADDRESS
308
+ └── synapse_agent_sap.json # 58 ix, 17 accounts, 38 events
309
+ ```
310
+
311
+ ### SapClient Access Tree
312
+
313
+ ```
314
+ SapClient
315
+
316
+ │ Modules (low-level, 1:1 with program instructions):
317
+ ├── .agent → AgentModule (identity, reputation, lifecycle)
318
+ ├── .feedback → FeedbackModule (trustless reviews)
319
+ ├── .indexing → IndexingModule (capability/protocol/category indexes)
320
+ ├── .tools → ToolsModule (tool schemas, checkpoints)
321
+ ├── .vault → VaultModule (encrypted memory, delegation)
322
+ ├── .escrow → EscrowModule (x402 micropayments, batch settle)
323
+ ├── .attestation → AttestationModule (web-of-trust vouching)
324
+ ├── .ledger → LedgerModule (ring buffer, sealed pages)
325
+ ├── .events → EventParser (decoded TX-log events)
326
+
327
+ │ Registries (high-level, cross-module aggregation):
328
+ ├── .discovery → DiscoveryRegistry (findAgents*, profiles, network overview)
329
+ ├── .x402 → X402Registry (pricing, headers, settlement lifecycle)
330
+ ├── .session → SessionManager (vault → session → ledger lifecycle)
331
+ └── .builder → AgentBuilder (fluent registration + tools)
332
+ ```
333
+
334
+ All module and registry properties are **lazily instantiated** (created on first access).
335
+
336
+ ---
337
+
338
+ ## Core — Client & Connection
339
+
340
+ ### SapClient
341
+
342
+ The primary entry point. Wraps an Anchor `Program` and exposes domain modules.
343
+
344
+ ```typescript
345
+ import { SapClient } from "@synapse-sap/sdk";
346
+
347
+ // From AnchorProvider (auto-loads embedded IDL)
348
+ const client = SapClient.from(provider);
349
+
350
+ // From an existing Program instance
351
+ const client = SapClient.fromProgram(program);
352
+
353
+ // With custom program ID
354
+ const client = SapClient.from(provider, customProgramId);
355
+
356
+ // Access properties
357
+ client.program; // Anchor Program instance
358
+ client.walletPubkey; // Wallet public key
359
+ ```
360
+
361
+ ### SapConnection
362
+
363
+ RPC-first factory. Creates `SapClient` instances from an RPC URL — no Anchor boilerplate. Resolves the correct program ID automatically based on cluster.
364
+
365
+ ```typescript
366
+ import { SapConnection } from "@synapse-sap/sdk";
367
+
368
+ // ─── Cluster shortcuts ───
369
+ const conn = SapConnection.devnet();
370
+ const conn = SapConnection.mainnet("https://my-rpc.com");
371
+ const conn = SapConnection.localnet();
372
+
373
+ // ─── Custom config ───
374
+ const conn = new SapConnection({
375
+ rpcUrl: "https://my-rpc-provider.com",
376
+ cluster: "mainnet-beta",
377
+ commitment: "confirmed",
378
+ wsUrl: "wss://my-rpc-provider.com/ws",
379
+ });
380
+
381
+ // ─── Create client ───
382
+ const client = conn.fromKeypair(keypair);
383
+ const client = conn.createClient(wallet); // Anchor Wallet
384
+
385
+ // ─── One-liner with client attached ───
386
+ const { client, connection, cluster, programId } = SapConnection.fromKeypair(
387
+ "https://api.devnet.solana.com",
388
+ keypair,
389
+ );
390
+
391
+ // ─── Utility methods ───
392
+ await conn.airdrop(pubkey, 2); // 2 SOL (devnet/localnet)
393
+ const balance = await conn.getBalanceSol(pubkey); // SOL balance
394
+ ```
395
+
396
+ ---
397
+
398
+ ## Modules (Low-Level)
399
+
400
+ Each module wraps one protocol domain. All methods return `TransactionSignature` (the TX hash) unless documented otherwise.
401
+
402
+ ### Agent
403
+
404
+ ```typescript
405
+ // Register
406
+ await client.agent.register({
407
+ name: "Bot",
408
+ description: "AI agent",
409
+ capabilities: [{ id: "swap", description: null, protocolId: "jupiter", version: "1.0.0" }],
410
+ pricing: [],
411
+ protocols: ["jupiter"],
412
+ });
413
+
414
+ // Update metadata
415
+ await client.agent.update({ name: "BotV2" });
416
+
417
+ // Report metrics
418
+ await client.agent.reportCalls(42);
419
+ await client.agent.updateReputation(150, 9950); // 150ms latency, 99.50% uptime
420
+
421
+ // Lifecycle
422
+ await client.agent.deactivate();
423
+ await client.agent.reactivate();
424
+ await client.agent.close();
425
+
426
+ // Fetch
427
+ const agent = await client.agent.fetch(walletPubkey);
428
+ const stats = await client.agent.fetchStats(agentPda);
429
+ const registry = await client.agent.fetchGlobalRegistry();
430
+ ```
431
+
432
+ ### Vault (Encrypted Memory)
433
+
434
+ ```typescript
435
+ // Init vault
436
+ await client.vault.initVault(Array.from(nonce));
437
+
438
+ // Open session
439
+ await client.vault.openSession(Array.from(sessionHash));
440
+
441
+ // Inscribe encrypted data (zero rent — written to TX log)
442
+ await client.vault.inscribe({
443
+ sequence: 0,
444
+ encryptedData: ciphertext,
445
+ nonce: nonce,
446
+ contentHash: hash,
447
+ totalFragments: 1,
448
+ fragmentIndex: 0,
449
+ compression: 0,
450
+ epochIndex: 0,
451
+ });
452
+
453
+ // Delegation (hot wallet)
454
+ await client.vault.addDelegate(hotWallet, 0b111, expiresAt);
455
+ await client.vault.revokeDelegate(hotWallet);
456
+
457
+ // Close
458
+ await client.vault.closeSession(vaultPda, sessionPda);
459
+ await client.vault.closeVault();
460
+ ```
461
+
462
+ ### Escrow (x402 Micropayments)
463
+
464
+ ```typescript
465
+ // Create SOL escrow
466
+ await client.escrow.create(agentWallet, {
467
+ pricePerCall: new BN(1_000_000),
468
+ maxCalls: new BN(100),
469
+ initialDeposit: new BN(100_000_000),
470
+ expiresAt: new BN(0),
471
+ volumeCurve: [],
472
+ tokenMint: null,
473
+ tokenDecimals: 9,
474
+ });
475
+
476
+ // Deposit
477
+ await client.escrow.deposit(agentWallet, new BN(50_000_000));
478
+
479
+ // Agent settles calls
480
+ await client.escrow.settle(depositorWallet, 10, serviceHash);
481
+
482
+ // Batch settlement (up to 10 per TX, SDK auto-sizes CU since v0.12.5)
483
+ await client.escrow.settleBatch(depositorWallet, [
484
+ { callsToSettle: new BN(5), serviceHash: hash1 },
485
+ { callsToSettle: new BN(3), serviceHash: hash2 },
486
+ ]);
487
+
488
+ // Withdraw remaining
489
+ await client.escrow.withdraw(agentWallet, new BN(10_000_000));
490
+ ```
491
+
492
+ ### Ledger (Ring Buffer Memory)
493
+
494
+ ```typescript
495
+ // Init ledger (~0.032 SOL rent)
496
+ await client.ledger.init(sessionPda);
497
+
498
+ // Write entries (TX fee only, zero additional rent)
499
+ await client.ledger.write(sessionPda, data, contentHash);
500
+
501
+ // Seal current buffer to permanent page (~0.031 SOL)
502
+ await client.ledger.seal(sessionPda);
503
+
504
+ // Read
505
+ const ledger = await client.ledger.fetchLedger(sessionPda);
506
+ const page = await client.ledger.fetchPage(ledgerPda, 0);
507
+ const entries = client.ledger.decodeRingBuffer(ledgerData.ringBuffer);
508
+
509
+ // Close
510
+ await client.ledger.close(sessionPda);
511
+ ```
512
+
513
+ ### Feedback, Attestation, Tools, Indexing
514
+
515
+ ```typescript
516
+ // ── Feedback ──
517
+ await client.feedback.give(agentWallet, { score: 5, tag: "fast", commentHash: null });
518
+ await client.feedback.update(agentWallet, { newScore: 4, newTag: null, commentHash: null });
519
+ await client.feedback.revoke(agentWallet);
520
+
521
+ // ── Attestation ──
522
+ await client.attestation.create(agentWallet, {
523
+ attestationType: 1,
524
+ metadataHash: [...hashBytes],
525
+ expiresAt: new BN(Date.now() / 1000 + 86400 * 365),
526
+ });
527
+ await client.attestation.revoke(agentWallet);
528
+
529
+ // ── Tools ──
530
+ await client.tools.publishByName("swap", "jupiter", "Execute swap", input, output, 1, 0, 3, 2, false);
531
+ await client.tools.inscribeSchema("swap", { schemaType: 0, schemaData, schemaHash, compression: 0 });
532
+ await client.tools.update("swap", { httpMethod: 1, category: null, ... });
533
+
534
+ // ── Indexing ──
535
+ await client.indexing.initCapabilityIndex("jupiter:swap");
536
+ await client.indexing.addToCapabilityIndex("jupiter:swap");
537
+ await client.indexing.initProtocolIndex("jupiter");
538
+ await client.indexing.addToProtocolIndex("jupiter");
539
+ ```
540
+
541
+ ---
542
+
543
+ ## Registries (High-Level)
544
+
545
+ Registries provide **cross-module orchestration** with developer-friendly APIs.
546
+
547
+ ### DiscoveryRegistry
548
+
549
+ ```typescript
550
+ // Find agents by protocol
551
+ const agents = await client.discovery.findAgentsByProtocol("jupiter");
552
+
553
+ // Find by capability
554
+ const swappers = await client.discovery.findAgentsByCapability("jupiter:swap");
555
+
556
+ // Get full agent profile
557
+ const profile = await client.discovery.getAgentProfile(agentWallet);
558
+ // → { agent, stats, tools, feedback, attestations }
559
+
560
+ // Find tools by category
561
+ const tools = await client.discovery.findToolsByCategory("swap");
562
+
563
+ // Network overview
564
+ const overview = await client.discovery.getNetworkOverview();
565
+ // → { totalAgents, activeAgents, totalTools, protocols, categories }
566
+ ```
567
+
568
+ ### X402Registry
569
+
570
+ ```typescript
571
+ // Prepare payment context
572
+ const ctx = await client.x402.preparePayment(agentWallet, {
573
+ tierId: "standard",
574
+ maxCalls: 100,
575
+ initialDeposit: new BN(100_000_000),
576
+ });
577
+
578
+ // Build HTTP headers (for x402 protocol)
579
+ const headers = client.x402.buildPaymentHeaders(ctx);
580
+ // → { "X-402-Token": "...", "X-402-Agent": "...", ... }
581
+
582
+ // Estimate costs
583
+ const cost = await client.x402.estimateCost(agentWallet, 50);
584
+ // → { totalLamports, perCallLamports, tierId }
585
+
586
+ // Settle
587
+ const receipt = await client.x402.settle(depositor, 5, serviceData);
588
+
589
+ // Batch settle
590
+ const results = await client.x402.batchSettle(depositor, settlements);
591
+
592
+ // Check balance
593
+ const balance = await client.x402.getBalance(agentWallet, depositorWallet);
594
+ ```
595
+
596
+ ### SessionManager
597
+
598
+ Manages the full `vault → session → ledger` lifecycle in one API:
599
+
600
+ ```typescript
601
+ // Start a session (inits vault + opens session + inits ledger)
602
+ const ctx = await client.session.start("conversation-123");
603
+ // → { vaultPda, sessionPda, ledgerPda, sessionHash }
604
+
605
+ // Write data
606
+ const result = await client.session.write(ctx, "Hello from agent");
607
+ // → { txSignature, sequence }
608
+
609
+ // Read latest entries
610
+ const messages = await client.session.readLatest(ctx);
611
+ // → RingBufferEntry[]
612
+
613
+ // Seal to permanent storage
614
+ const seal = await client.session.seal(ctx);
615
+ // → { txSignature, pageIndex }
616
+
617
+ // Get session status
618
+ const status = await client.session.getStatus(ctx);
619
+ // → { isOpen, totalWrites, sealedPages, ringBufferUsage }
620
+
621
+ // End session
622
+ await client.session.end(ctx);
623
+ ```
624
+
625
+ ### AgentBuilder
626
+
627
+ Fluent builder for one-shot agent registration with tools:
628
+
629
+ ```typescript
630
+ const result = await client.builder
631
+ .agent("SwapBot")
632
+ .description("AI-powered DEX aggregator using Jupiter")
633
+ .x402Endpoint("https://api.mybot.com/x402")
634
+ .addCapability("jupiter:swap", {
635
+ protocol: "jupiter",
636
+ description: "Execute token swaps",
637
+ })
638
+ .addCapability("jupiter:quote", {
639
+ protocol: "jupiter",
640
+ description: "Get swap quotes",
641
+ })
642
+ .addPricingTier({
643
+ tierId: "standard",
644
+ pricePerCall: 1000,
645
+ rateLimit: 60,
646
+ tokenType: "sol",
647
+ settlementMode: "x402",
648
+ })
649
+ .addTool({
650
+ name: "swap",
651
+ protocolId: "jupiter",
652
+ description: "Execute a token swap",
653
+ category: "swap",
654
+ httpMethod: "post",
655
+ paramsCount: 3,
656
+ requiredParams: 2,
657
+ })
658
+ .registerWithTools();
659
+ // → { agentTx, toolTxs: string[] }
660
+ ```
661
+
662
+ ---
663
+
664
+ ## Plugin (SynapseAgentKit)
665
+
666
+ The SDK ships a 52-tool plugin that integrates with `SynapseAgentKit` and
667
+ LangChain-compatible AI agent frameworks:
668
+
669
+ ```typescript
670
+ import { createSAPPlugin } from "@synapse-sap/sdk/plugin";
671
+
672
+ // Create plugin
673
+ const sapPlugin = createSAPPlugin({ provider });
674
+
675
+ // Use with SynapseAgentKit
676
+ const kit = new SynapseAgentKit({ rpcUrl })
677
+ .use(sapPlugin);
678
+
679
+ const tools = kit.getTools(); // → 52 LangChain StructuredTool instances
680
+ ```
681
+
682
+ **8 Protocol Domains × Tools:**
683
+
684
+ | Protocol | Tools |
685
+ |----------|-------|
686
+ | `sap-agent` | registerAgent, updateAgent, deactivateAgent, reactivateAgent, reportCalls, updateReputation, fetchAgent, fetchGlobalRegistry |
687
+ | `sap-feedback` | giveFeedback, updateFeedback, revokeFeedback, fetchFeedback |
688
+ | `sap-attestation` | createAttestation, revokeAttestation, fetchAttestation |
689
+ | `sap-escrow` | createEscrow, depositEscrow, settleEscrow, withdrawEscrow, batchSettle, fetchEscrow |
690
+ | `sap-tools` | publishToolByName, inscribeToolSchema, updateTool, deactivateTool, reactivateTool, reportInvocations, fetchTool |
691
+ | `sap-vault` | initVault, openSession, inscribeMemory, closeSession, closeVault, rotateNonce, addDelegate, revokeDelegate, fetchVault, fetchSession |
692
+ | `sap-indexing` | initCapabilityIndex, addToCapabilityIndex, removeFromCapabilityIndex, initProtocolIndex, addToProtocolIndex, removeFromProtocolIndex, fetchCapabilityIndex, fetchProtocolIndex |
693
+ | `sap-ledger` | initLedger, writeLedger, sealLedger, closeLedger, fetchLedger, fetchLedgerPage |
694
+
695
+ ---
696
+
697
+ ## PDA Derivation
698
+
699
+ All 17 PDA functions are pure (no RPC calls) and return `[PublicKey, bump]`:
700
+
701
+ ```typescript
702
+ import {
703
+ deriveAgent,
704
+ deriveVault,
705
+ deriveSession,
706
+ deriveEscrow,
707
+ deriveTool,
708
+ deriveLedger,
709
+ deriveAttestation,
710
+ } from "@synapse-sap/sdk/pda";
711
+
712
+ const [agentPda, bump] = deriveAgent(walletPubkey);
713
+ const [vaultPda] = deriveVault(agentPda);
714
+ const [sessionPda] = deriveSession(vaultPda, sessionHashBytes);
715
+ const [escrowPda] = deriveEscrow(agentPda, depositorPubkey);
716
+ const [toolPda] = deriveTool(agentPda, toolNameHash);
717
+ const [ledgerPda] = deriveLedger(sessionPda);
718
+ const [attestPda] = deriveAttestation(agentPda, attesterPubkey);
719
+ ```
720
+
721
+ **Full list:** `deriveGlobalRegistry`, `deriveAgent`, `deriveAgentStats`, `deriveFeedback`, `deriveCapabilityIndex`, `deriveProtocolIndex`, `deriveToolCategoryIndex`, `deriveVault`, `deriveSession`, `deriveEpochPage`, `deriveVaultDelegate`, `deriveCheckpoint`, `deriveTool`, `deriveEscrow`, `deriveAttestation`, `deriveLedger`, `deriveLedgerPage`
722
+
723
+ ---
724
+
725
+ ## Events
726
+
727
+ Decode SAP events from transaction logs:
728
+
729
+ ```typescript
730
+ import { EventParser } from "@synapse-sap/sdk";
731
+
732
+ // Parse
733
+ const events = client.events.parseLogs(txLogs);
734
+
735
+ // Filter
736
+ const inscriptions = client.events.filterByName(events, "MemoryInscribedEvent");
737
+ const payments = client.events.filterByName(events, "PaymentSettledEvent");
738
+
739
+ // 38 event types available (see API Reference)
740
+ ```
741
+
742
+ ---
743
+
744
+ ## Error Handling
745
+
746
+ The SDK provides a typed error hierarchy for precise error handling:
747
+
748
+ ```typescript
749
+ import {
750
+ SapError,
751
+ SapRpcError,
752
+ SapAccountNotFoundError,
753
+ SapValidationError,
754
+ SapTimeoutError,
755
+ SapPermissionError,
756
+ } from "@synapse-sap/sdk";
757
+
758
+ try {
759
+ const agent = await client.agent.fetch();
760
+ } catch (err) {
761
+ if (err instanceof SapAccountNotFoundError) {
762
+ // Account doesn't exist on-chain
763
+ console.log(`${err.accountType} not found: ${err.address}`);
764
+ } else if (err instanceof SapRpcError) {
765
+ // Anchor / RPC error with code and logs
766
+ console.error(`RPC error ${err.rpcCode}:`, err.logs);
767
+ } else if (err instanceof SapValidationError) {
768
+ // SDK-side validation failed
769
+ console.error(`Invalid ${err.field}:`, err.message);
770
+ } else if (err instanceof SapTimeoutError) {
771
+ // Transaction confirmation timeout
772
+ console.error(`Timeout after ${err.timeoutMs}ms`);
773
+ } else if (err instanceof SapPermissionError) {
774
+ // Missing authority / delegate permission
775
+ console.error(err.message);
776
+ } else if (err instanceof SapError) {
777
+ // Catch-all for any SAP SDK error
778
+ console.error(`[${err.code}]`, err.message);
779
+ }
780
+ }
781
+
782
+ // Wrapping Anchor errors
783
+ try {
784
+ await program.methods.registerAgent(...).rpc();
785
+ } catch (e) {
786
+ throw SapRpcError.fromAnchor(e); // extracts code + logs
787
+ }
788
+ ```
789
+
790
+ ---
791
+
792
+ ## Utilities
793
+
794
+ ```typescript
795
+ import { sha256, hashToArray, assert, serializeAccount, serializeValue } from "@synapse-sap/sdk";
796
+
797
+ // ── Hashing ──
798
+ const hash = sha256("jupiter:swap"); // Uint8Array (32 bytes)
799
+ const arr = hashToArray(hash); // number[] for Anchor args
800
+
801
+ // ── Assertion ──
802
+ assert(score >= 1 && score <= 5, "Score must be 1–5"); // throws RangeError
803
+
804
+ // ── Serialization (PublicKey/BN → JSON-safe) ──
805
+ const raw = await program.account.agent.fetch(pda);
806
+ const json = serializeAccount(raw);
807
+ // { authority: "GBL...", totalCalls: "42", isActive: true }
808
+
809
+ const val = serializeValue(somePublicKey); // → "base58string"
810
+ const val = serializeValue(new BN(1000)); // → "1000"
811
+ ```
812
+
813
+ ---
814
+
815
+ ## Types
816
+
817
+ Every on-chain type is mirrored in TypeScript:
818
+
819
+ ```typescript
820
+ import type {
821
+ // Account data
822
+ AgentAccountData,
823
+ EscrowAccountData,
824
+ MemoryVaultData,
825
+ ToolDescriptorData,
826
+
827
+ // Instruction args
828
+ RegisterAgentArgs,
829
+ CreateEscrowArgs,
830
+ InscribeMemoryArgs,
831
+
832
+ // Helper types
833
+ Capability,
834
+ PricingTier,
835
+ Settlement,
836
+ VolumeCurveBreakpoint,
837
+ } from "@synapse-sap/sdk/types";
838
+
839
+ import {
840
+ TokenType, // { sol: {}, usdc: {}, spl: {} }
841
+ SettlementMode, // { instant: {}, escrow: {}, batched: {}, x402: {} }
842
+ ToolCategory, // { swap: {}, lend: {}, stake: {}, ... }
843
+ DelegatePermission, // READ, WRITE, ADMIN bit flags
844
+ SchemaType, // INPUT, OUTPUT, DESCRIPTION
845
+ CompressionType, // NONE, DEFLATE, GZIP, BROTLI
846
+ } from "@synapse-sap/sdk/types";
847
+ ```
848
+
849
+ ---
850
+
851
+ ## Constants
852
+
853
+ ```typescript
854
+ import {
855
+ SAP_PROGRAM_ADDRESS, // "SAPpUhsWLJG1FfkGRcXagEDMrMsWGjbky7AyhGpFETZ"
856
+ SAP_PROGRAM_ID, // PublicKey (= devnet for now)
857
+ MAINNET_SAP_PROGRAM_ID, // PublicKey
858
+ DEVNET_SAP_PROGRAM_ID, // PublicKey
859
+ LOCALNET_SAP_PROGRAM_ID, // PublicKey
860
+ SEEDS, // { agent: "agent", vault: "vault", ... } (20 seeds)
861
+ LIMITS, // { maxNameLen: 64, maxCapabilities: 10, ... } (23 limits)
862
+ AGENT_VERSION, // 2
863
+ VAULT_PROTOCOL_VERSION, // 2
864
+ TOOL_CATEGORY_VALUES, // { swap: 0, lend: 1, ... }
865
+ HTTP_METHOD_VALUES, // { get: 0, post: 1, ... }
866
+ } from "@synapse-sap/sdk/constants";
867
+ ```
868
+
869
+ ---
870
+
871
+ ## Deep Imports
872
+
873
+ Import individual packages for smaller bundles:
874
+
875
+ ```typescript
876
+ // Core
877
+ import { SapClient, SapConnection } from "@synapse-sap/sdk/core";
878
+
879
+ // Individual modules
880
+ import { AgentModule } from "@synapse-sap/sdk/agent";
881
+ import { EscrowModule } from "@synapse-sap/sdk/escrow";
882
+
883
+ // Types only (zero runtime cost)
884
+ import type { AgentAccountData } from "@synapse-sap/sdk/types";
885
+ import type { SapCluster } from "@synapse-sap/sdk/core";
886
+
887
+ // PDA derivation
888
+ import { deriveAgent, deriveEscrow } from "@synapse-sap/sdk/pda";
889
+
890
+ // Constants
891
+ import { SEEDS, LIMITS } from "@synapse-sap/sdk/constants";
892
+
893
+ // Events
894
+ import { EventParser } from "@synapse-sap/sdk/events";
895
+
896
+ // Errors
897
+ import { SapError, SapRpcError } from "@synapse-sap/sdk/errors";
898
+
899
+ // Utilities
900
+ import { sha256, serializeAccount } from "@synapse-sap/sdk/utils";
901
+
902
+ // IDL
903
+ import { SAP_IDL } from "@synapse-sap/sdk/idl";
904
+
905
+ // Plugin
906
+ import { createSAPPlugin } from "@synapse-sap/sdk/plugin";
907
+
908
+ // Registries
909
+ import { DiscoveryRegistry } from "@synapse-sap/sdk/registries/discovery";
910
+ import { X402Registry } from "@synapse-sap/sdk/registries/x402";
911
+ import { SessionManager } from "@synapse-sap/sdk/registries/session";
912
+ import { AgentBuilder } from "@synapse-sap/sdk/registries/builder";
913
+ ```
914
+
915
+ ---
916
+
917
+ ## API Reference
918
+
919
+ ### Accounts (17 types)
920
+
921
+ | Account | Description |
922
+ |---------|-------------|
923
+ | `AgentAccountData` | Agent identity, capabilities, pricing, protocols |
924
+ | `AgentStatsData` | Call count, latency, uptime metrics |
925
+ | `GlobalRegistryData` | Protocol-wide agent counter + authority |
926
+ | `FeedbackAccountData` | Single reviewer's feedback for an agent |
927
+ | `CapabilityIndexData` | List of agents with a given capability |
928
+ | `ProtocolIndexData` | List of agents supporting a protocol |
929
+ | `ToolCategoryIndexData` | List of tools in a category |
930
+ | `ToolDescriptorData` | Tool schema, metadata, invocation stats |
931
+ | `SessionCheckpointData` | Session checkpoint for recovery |
932
+ | `MemoryVaultData` | Encrypted vault metadata + encryption nonce |
933
+ | `SessionLedgerData` | Session within a vault |
934
+ | `EpochPageData` | Finalized epoch page of inscriptions |
935
+ | `VaultDelegateData` | Delegate permissions + expiry |
936
+ | `EscrowAccountData` | x402 escrow balance + settlement state |
937
+ | `AgentAttestationData` | Attestation metadata + expiry |
938
+ | `MemoryLedgerData` | Ring-buffer ledger metadata |
939
+ | `LedgerPageData` | Sealed ledger page content |
940
+
941
+ ### Events (38 types)
942
+
943
+ `RegisteredEvent` · `UpdatedEvent` · `DeactivatedEvent` · `ReactivatedEvent` · `ClosedEvent` · `FeedbackEvent` · `FeedbackUpdatedEvent` · `FeedbackRevokedEvent` · `ReputationUpdatedEvent` · `CallsReportedEvent` · `VaultInitializedEvent` · `SessionOpenedEvent` · `MemoryInscribedEvent` · `EpochOpenedEvent` · `SessionClosedEvent` · `VaultClosedEvent` · `SessionPdaClosedEvent` · `EpochPageClosedEvent` · `VaultNonceRotatedEvent` · `DelegateAddedEvent` · `DelegateRevokedEvent` · `ToolPublishedEvent` · `ToolSchemaInscribedEvent` · `ToolUpdatedEvent` · `ToolDeactivatedEvent` · `ToolReactivatedEvent` · `ToolClosedEvent` · `ToolInvocationReportedEvent` · `CheckpointCreatedEvent` · `EscrowCreatedEvent` · `EscrowDepositedEvent` · `PaymentSettledEvent` · `EscrowWithdrawnEvent` · `BatchSettledEvent` · `AttestationCreatedEvent` · `AttestationRevokedEvent` · `LedgerEntryEvent` · `LedgerSealedEvent`
944
+
945
+ ### Enum Constants
946
+
947
+ | Enum | Variants |
948
+ |------|----------|
949
+ | `TokenType` | `sol`, `usdc`, `spl` |
950
+ | `PluginType` | `native`, `wasm`, `external` |
951
+ | `SettlementMode` | `instant`, `escrow`, `batched`, `x402` |
952
+ | `ToolHttpMethod` | `get`, `post`, `put`, `delete`, `compound` |
953
+ | `ToolCategory` | `swap`, `lend`, `stake`, `nft`, `payment`, `data`, `governance`, `bridge`, `analytics`, `custom` |
954
+ | `DelegatePermission` | `READ` (1), `WRITE` (2), `ADMIN` (4) |
955
+ | `SchemaType` | `INPUT` (0), `OUTPUT` (1), `DESCRIPTION` (2) |
956
+ | `CompressionType` | `NONE` (0), `DEFLATE` (1), `GZIP` (2), `BROTLI` (3) |
957
+
958
+ ---
959
+
960
+ ## Development
961
+
962
+ ```bash
963
+ yarn install # Install dependencies
964
+ yarn typecheck # Type-check (strict mode)
965
+ yarn build # Build CJS + ESM + declarations
966
+ yarn clean # Remove dist/
967
+ yarn sync-idl # Copy latest IDL from anchor build
968
+ ```
969
+
970
+ ### Building for Developers
971
+
972
+ The SDK outputs three artifacts:
973
+
974
+ | Output | Path | Config |
975
+ |--------|------|--------|
976
+ | ESM | `dist/esm/` | `tsconfig.esm.json` |
977
+ | CJS | `dist/cjs/` | `tsconfig.cjs.json` |
978
+ | Types | `dist/types/` | `tsconfig.json --emitDeclarationOnly` |
979
+
980
+ See [CONTRIBUTING.md](CONTRIBUTING.md) for full development guidelines.
981
+
982
+ ---
983
+
984
+ ## License
985
+
986
+ [MIT](LICENSE)