@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,319 @@
1
+ "use strict";
2
+ /**
3
+ * @module core/connection
4
+ * @description RPC connection factory for SAP v2 SDK.
5
+ *
6
+ * Provides a high-level, synapse-client-sdk–compatible entry point
7
+ * for creating {@link SapClient} instances from an RPC URL and wallet.
8
+ *
9
+ * @category Core
10
+ * @since v0.1.0
11
+ *
12
+ * @example
13
+ * ```ts
14
+ * import { SapConnection } from "@synapse-sap/sdk";
15
+ *
16
+ * // Quick start — RPC URL + Keypair
17
+ * const sap = SapConnection.fromKeypair("https://api.devnet.solana.com", keypair);
18
+ * const agent = await sap.client.agent.fetch();
19
+ *
20
+ * // Or build step-by-step
21
+ * const conn = new SapConnection({
22
+ * rpcUrl: "https://us-1-mainnet.oobeprotocol.ai/rpc?api_key=xxx",
23
+ * cluster: "mainnet-beta",
24
+ * commitment: "confirmed",
25
+ * });
26
+ * const client = conn.createClient(wallet);
27
+ * ```
28
+ */
29
+ Object.defineProperty(exports, "__esModule", { value: true });
30
+ exports.SapConnection = void 0;
31
+ const web3_js_1 = require("@solana/web3.js");
32
+ const anchor_1 = require("@coral-xyz/anchor");
33
+ const constants_1 = require("../constants");
34
+ const client_1 = require("./client");
35
+ // ═══════════════════════════════════════════════════════════════════
36
+ // Implementation
37
+ // ═══════════════════════════════════════════════════════════════════
38
+ /**
39
+ * @name SapConnection
40
+ * @description Lightweight RPC connection wrapper that creates
41
+ * properly-configured {@link SapClient} instances.
42
+ *
43
+ * Compatible with the `synapse-client-sdk` connection model:
44
+ * start from an RPC URL, attach a wallet, get a typed client.
45
+ *
46
+ * @category Core
47
+ * @since v0.1.0
48
+ * @see {@link SapClient}
49
+ * @see {@link SapConnectionConfig}
50
+ *
51
+ * @example
52
+ * ```ts
53
+ * // Factory shortcut for devnet
54
+ * const conn = SapConnection.devnet();
55
+ * const client = conn.createClient(wallet);
56
+ *
57
+ * // One-liner with Keypair
58
+ * const { client } = SapConnection.fromKeypair(
59
+ * "https://api.devnet.solana.com",
60
+ * keypair,
61
+ * );
62
+ * ```
63
+ */
64
+ class SapConnection {
65
+ /**
66
+ * @readonly
67
+ * @description Raw Solana {@link Connection}. Exposed for advanced
68
+ * use-cases that need direct RPC access.
69
+ */
70
+ connection;
71
+ /**
72
+ * @readonly
73
+ * @description The resolved Solana cluster for this connection,
74
+ * either explicitly provided or auto-detected from the RPC URL.
75
+ */
76
+ cluster;
77
+ /**
78
+ * @readonly
79
+ * @description Commitment level used for all queries and
80
+ * transaction confirmations on this connection.
81
+ */
82
+ commitment;
83
+ /**
84
+ * @readonly
85
+ * @description The SAP on-chain program {@link PublicKey} resolved
86
+ * for the current {@link cluster}.
87
+ * @see {@link SapConnection.programIdForCluster}
88
+ */
89
+ programId;
90
+ constructor(config) {
91
+ this.commitment = config.commitment ?? "confirmed";
92
+ this.cluster = config.cluster ?? SapConnection.detectCluster(config.rpcUrl);
93
+ this.programId = SapConnection.programIdForCluster(this.cluster);
94
+ this.connection = new web3_js_1.Connection(config.rpcUrl, {
95
+ commitment: this.commitment,
96
+ wsEndpoint: config.wsUrl,
97
+ });
98
+ }
99
+ // ─────────────────────────────────────────────
100
+ // Factory helpers
101
+ // ─────────────────────────────────────────────
102
+ /**
103
+ * Create a {@link SapConnection} for **devnet** with sensible defaults.
104
+ *
105
+ * @static
106
+ * @param {Commitment} [commitment="confirmed"] — Commitment level.
107
+ * @returns {SapConnection} A connection targeting Solana devnet.
108
+ * @since v0.1.0
109
+ *
110
+ * @example
111
+ * ```ts
112
+ * const conn = SapConnection.devnet();
113
+ * ```
114
+ */
115
+ static devnet(commitment = "confirmed") {
116
+ return new SapConnection({
117
+ rpcUrl: "https://api.devnet.solana.com",
118
+ cluster: "devnet",
119
+ commitment,
120
+ });
121
+ }
122
+ /**
123
+ * Create a {@link SapConnection} for **mainnet-beta** with sensible defaults.
124
+ *
125
+ * @static
126
+ * @param {string} [rpcUrl="https://api.mainnet-beta.solana.com"] — Custom RPC URL.
127
+ * @param {Commitment} [commitment="confirmed"] — Commitment level.
128
+ * @returns {SapConnection} A connection targeting Solana mainnet-beta.
129
+ * @since v0.1.0
130
+ *
131
+ * @example
132
+ * ```ts
133
+ * const conn = SapConnection.mainnet("https://my-rpc.example.com");
134
+ * ```
135
+ */
136
+ static mainnet(rpcUrl = "https://api.mainnet-beta.solana.com", commitment = "confirmed") {
137
+ return new SapConnection({ rpcUrl, cluster: "mainnet-beta", commitment });
138
+ }
139
+ /**
140
+ * Create a {@link SapConnection} for **localnet** (`localhost:8899`).
141
+ *
142
+ * @static
143
+ * @param {Commitment} [commitment="confirmed"] — Commitment level.
144
+ * @returns {SapConnection} A connection targeting a local validator.
145
+ * @since v0.1.0
146
+ *
147
+ * @example
148
+ * ```ts
149
+ * const conn = SapConnection.localnet();
150
+ * ```
151
+ */
152
+ static localnet(commitment = "confirmed") {
153
+ return new SapConnection({
154
+ rpcUrl: "http://localhost:8899",
155
+ cluster: "localnet",
156
+ commitment,
157
+ });
158
+ }
159
+ /**
160
+ * One-liner: create a {@link SapConnection} + {@link SapClient} from
161
+ * an RPC URL and a `Keypair`. Perfect for scripts and CLI tools.
162
+ *
163
+ * @static
164
+ * @param {string} rpcUrl — Solana JSON-RPC endpoint.
165
+ * @param {Keypair} keypair — Signer keypair.
166
+ * @param {object} [opts] — Optional overrides.
167
+ * @param {Commitment} [opts.commitment] — Commitment level.
168
+ * @param {SapCluster} [opts.cluster] — Explicit cluster hint.
169
+ * @returns {SapConnection & { readonly client: SapClient }} Connection with an attached client.
170
+ * @since v0.1.0
171
+ *
172
+ * @example
173
+ * ```ts
174
+ * const { client, connection } = SapConnection.fromKeypair(
175
+ * "https://api.devnet.solana.com",
176
+ * Keypair.generate(),
177
+ * );
178
+ * ```
179
+ */
180
+ static fromKeypair(rpcUrl, keypair, opts) {
181
+ const conn = new SapConnection({
182
+ rpcUrl,
183
+ commitment: opts?.commitment,
184
+ cluster: opts?.cluster,
185
+ });
186
+ const client = conn.createClient(new anchor_1.Wallet(keypair));
187
+ return Object.assign(conn, { client });
188
+ }
189
+ // ─────────────────────────────────────────────
190
+ // Client creation
191
+ // ─────────────────────────────────────────────
192
+ /**
193
+ * Create a {@link SapClient} from an Anchor {@link Wallet} (signer).
194
+ *
195
+ * @param {Wallet} wallet — An Anchor-compatible wallet/signer.
196
+ * @returns {SapClient} A fully-configured SAP client.
197
+ * @since v0.1.0
198
+ *
199
+ * @example
200
+ * ```ts
201
+ * const client = conn.createClient(new Wallet(keypair));
202
+ * ```
203
+ */
204
+ createClient(wallet) {
205
+ const provider = new anchor_1.AnchorProvider(this.connection, wallet, {
206
+ commitment: this.commitment,
207
+ });
208
+ return client_1.SapClient.from(provider, this.programId);
209
+ }
210
+ /**
211
+ * Create a {@link SapClient} from a raw {@link Keypair}.
212
+ *
213
+ * @param {Keypair} keypair — The signer keypair.
214
+ * @returns {SapClient} A fully-configured SAP client.
215
+ * @since v0.1.0
216
+ *
217
+ * @example
218
+ * ```ts
219
+ * const client = conn.fromKeypair(Keypair.generate());
220
+ * ```
221
+ */
222
+ fromKeypair(keypair) {
223
+ return this.createClient(new anchor_1.Wallet(keypair));
224
+ }
225
+ // ─────────────────────────────────────────────
226
+ // Utility methods
227
+ // ─────────────────────────────────────────────
228
+ /**
229
+ * Request an airdrop (devnet / localnet only).
230
+ *
231
+ * @param {PublicKey} to — Recipient public key.
232
+ * @param {number} solAmount — Amount of SOL to airdrop.
233
+ * @returns {Promise<string>} The confirmed transaction signature.
234
+ * @throws {Error} If the airdrop request or confirmation fails (e.g. on mainnet).
235
+ * @since v0.1.0
236
+ *
237
+ * @example
238
+ * ```ts
239
+ * const sig = await conn.airdrop(wallet.publicKey, 2);
240
+ * ```
241
+ */
242
+ async airdrop(to, solAmount) {
243
+ const sig = await this.connection.requestAirdrop(to, solAmount * web3_js_1.LAMPORTS_PER_SOL);
244
+ await this.connection.confirmTransaction(sig, this.commitment);
245
+ return sig;
246
+ }
247
+ /**
248
+ * Get the SOL balance of an address in **lamports**.
249
+ *
250
+ * @param {PublicKey} address — The account to query.
251
+ * @returns {Promise<number>} Balance in lamports.
252
+ * @since v0.1.0
253
+ */
254
+ async getBalance(address) {
255
+ return this.connection.getBalance(address, this.commitment);
256
+ }
257
+ /**
258
+ * Get the SOL balance of an address in **SOL** (human-readable).
259
+ *
260
+ * @param {PublicKey} address — The account to query.
261
+ * @returns {Promise<number>} Balance in SOL.
262
+ * @since v0.1.0
263
+ *
264
+ * @example
265
+ * ```ts
266
+ * const sol = await conn.getBalanceSol(wallet.publicKey);
267
+ * console.log(`Balance: ${sol} SOL`);
268
+ * ```
269
+ */
270
+ async getBalanceSol(address) {
271
+ const lamports = await this.getBalance(address);
272
+ return lamports / web3_js_1.LAMPORTS_PER_SOL;
273
+ }
274
+ // ─────────────────────────────────────────────
275
+ // Internal helpers
276
+ // ─────────────────────────────────────────────
277
+ /**
278
+ * Infer the {@link SapCluster} from an RPC URL by inspecting
279
+ * well-known substrings (`devnet`, `localhost`, `:8899`).
280
+ *
281
+ * @static
282
+ * @param {string} rpcUrl — The RPC endpoint to inspect.
283
+ * @returns {SapCluster} The detected cluster, defaulting to `"mainnet-beta"`.
284
+ * @since v0.1.0
285
+ */
286
+ static detectCluster(rpcUrl) {
287
+ const lower = rpcUrl.toLowerCase();
288
+ if (lower.includes("devnet"))
289
+ return "devnet";
290
+ if (lower.includes("localhost") ||
291
+ lower.includes("127.0.0.1") ||
292
+ lower.includes(":8899"))
293
+ return "localnet";
294
+ return "mainnet-beta";
295
+ }
296
+ /**
297
+ * Map a {@link SapCluster} to the canonical SAP on-chain program ID.
298
+ *
299
+ * @static
300
+ * @param {SapCluster} cluster — Target cluster.
301
+ * @returns {PublicKey} The program {@link PublicKey} for the given cluster.
302
+ * @since v0.1.0
303
+ * @see {@link SAP_PROGRAM_ID}
304
+ */
305
+ static programIdForCluster(cluster) {
306
+ switch (cluster) {
307
+ case "mainnet-beta":
308
+ return constants_1.MAINNET_SAP_PROGRAM_ID;
309
+ case "devnet":
310
+ return constants_1.DEVNET_SAP_PROGRAM_ID;
311
+ case "localnet":
312
+ return constants_1.LOCALNET_SAP_PROGRAM_ID;
313
+ default:
314
+ return constants_1.SAP_PROGRAM_ID;
315
+ }
316
+ }
317
+ }
318
+ exports.SapConnection = SapConnection;
319
+ //# sourceMappingURL=connection.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"connection.js","sourceRoot":"","sources":["../../../src/core/connection.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,24 @@
1
+ "use strict";
2
+ /**
3
+ * @module core
4
+ * @description Core infrastructure — client creation and RPC connection.
5
+ *
6
+ * @example
7
+ * ```ts
8
+ * import { SapClient, SapConnection } from "@synapse-sap/sdk";
9
+ *
10
+ * // From Anchor provider
11
+ * const client = SapClient.from(provider);
12
+ *
13
+ * // From RPC URL + keypair (synapse-client-sdk compatible)
14
+ * const conn = SapConnection.devnet();
15
+ * const client2 = conn.fromKeypair(keypair);
16
+ * ```
17
+ */
18
+ Object.defineProperty(exports, "__esModule", { value: true });
19
+ exports.SapConnection = exports.SapClient = void 0;
20
+ var client_1 = require("./client");
21
+ Object.defineProperty(exports, "SapClient", { enumerable: true, get: function () { return client_1.SapClient; } });
22
+ var connection_1 = require("./connection");
23
+ Object.defineProperty(exports, "SapConnection", { enumerable: true, get: function () { return connection_1.SapConnection; } });
24
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/core/index.ts"],"names":[],"mappings":";AAAA;;;;;;;;;;;;;;;GAeG;;;AAEH,mCAAqC;AAA5B,mGAAA,SAAS,OAAA;AAClB,2CAA6C;AAApC,2GAAA,aAAa,OAAA"}
@@ -0,0 +1,334 @@
1
+ "use strict";
2
+ /**
3
+ * @module errors
4
+ * @description Typed error classes for the SAP v2 SDK.
5
+ *
6
+ * All SDK errors extend {@link SapError} to allow catch-all handling,
7
+ * while concrete subclasses enable fine-grained error matching.
8
+ *
9
+ * @category Errors
10
+ * @since v0.1.0
11
+ *
12
+ * @example
13
+ * ```ts
14
+ * import { SapError, SapRpcError, SapAccountNotFoundError } from "@synapse-sap/sdk/errors";
15
+ *
16
+ * try {
17
+ * const agent = await client.agent.fetch();
18
+ * } catch (err) {
19
+ * if (err instanceof SapAccountNotFoundError) {
20
+ * console.log("Agent not registered yet");
21
+ * } else if (err instanceof SapRpcError) {
22
+ * console.error("RPC failure:", err.rpcCode);
23
+ * } else if (err instanceof SapError) {
24
+ * console.error("SAP error:", err.message);
25
+ * }
26
+ * }
27
+ * ```
28
+ *
29
+ * @see {@link SapError}
30
+ * @see {@link SapValidationError}
31
+ * @see {@link SapRpcError}
32
+ * @see {@link SapAccountNotFoundError}
33
+ * @see {@link SapTimeoutError}
34
+ * @see {@link SapPermissionError}
35
+ */
36
+ Object.defineProperty(exports, "__esModule", { value: true });
37
+ exports.SapPermissionError = exports.SapTimeoutError = exports.SapAccountNotFoundError = exports.SapRpcError = exports.SapValidationError = exports.SapError = void 0;
38
+ // ═══════════════════════════════════════════════════════════════════
39
+ // Base Error
40
+ // ═══════════════════════════════════════════════════════════════════
41
+ /**
42
+ * @name SapError
43
+ * @description Base class for all SAP SDK errors.
44
+ *
45
+ * Extends `Error` and sets `name` automatically so `instanceof`
46
+ * checks work correctly in both CJS and ESM environments.
47
+ *
48
+ * @category Errors
49
+ * @since v0.1.0
50
+ * @extends {Error}
51
+ *
52
+ * @example
53
+ * ```ts
54
+ * try {
55
+ * await client.agent.fetch();
56
+ * } catch (err) {
57
+ * if (err instanceof SapError) {
58
+ * console.error(`[${err.code}] ${err.message}`);
59
+ * }
60
+ * }
61
+ * ```
62
+ *
63
+ * @see {@link SapValidationError}
64
+ * @see {@link SapRpcError}
65
+ * @see {@link SapAccountNotFoundError}
66
+ * @see {@link SapTimeoutError}
67
+ * @see {@link SapPermissionError}
68
+ */
69
+ class SapError extends Error {
70
+ /**
71
+ * @description Machine-readable error code for programmatic handling.
72
+ * @readonly
73
+ */
74
+ code;
75
+ /**
76
+ * @param message - A human-readable description of the error.
77
+ * @param code - Machine-readable error code (defaults to `"SAP_ERROR"`).
78
+ */
79
+ constructor(message, code = "SAP_ERROR") {
80
+ super(message);
81
+ this.name = "SapError";
82
+ this.code = code;
83
+ // Fix prototype chain for instanceof checks
84
+ Object.setPrototypeOf(this, new.target.prototype);
85
+ }
86
+ }
87
+ exports.SapError = SapError;
88
+ // ═══════════════════════════════════════════════════════════════════
89
+ // Validation Error
90
+ // ═══════════════════════════════════════════════════════════════════
91
+ /**
92
+ * @name SapValidationError
93
+ * @description Thrown when SDK-side input validation fails before sending a
94
+ * transaction or making an RPC call.
95
+ *
96
+ * @category Errors
97
+ * @since v0.1.0
98
+ * @extends {SapError}
99
+ *
100
+ * @example
101
+ * ```ts
102
+ * try {
103
+ * await client.agent.register({ name: "" });
104
+ * } catch (err) {
105
+ * if (err instanceof SapValidationError) {
106
+ * console.error(`Validation failed on field "${err.field}": ${err.message}`);
107
+ * }
108
+ * }
109
+ * ```
110
+ *
111
+ * @see {@link SapError}
112
+ */
113
+ class SapValidationError extends SapError {
114
+ /**
115
+ * @description Field or parameter that failed validation (if applicable).
116
+ * @readonly
117
+ */
118
+ field;
119
+ /**
120
+ * @param message - A human-readable description of the validation failure.
121
+ * @param field - The name of the field or parameter that failed validation.
122
+ */
123
+ constructor(message, field) {
124
+ super(message, "SAP_VALIDATION_ERROR");
125
+ this.name = "SapValidationError";
126
+ this.field = field;
127
+ }
128
+ }
129
+ exports.SapValidationError = SapValidationError;
130
+ // ═══════════════════════════════════════════════════════════════════
131
+ // RPC / Transaction Error
132
+ // ═══════════════════════════════════════════════════════════════════
133
+ /**
134
+ * @name SapRpcError
135
+ * @description Wraps Solana RPC or Anchor transaction errors with additional
136
+ * context (error code, logs).
137
+ *
138
+ * @category Errors
139
+ * @since v0.1.0
140
+ * @extends {SapError}
141
+ *
142
+ * @example
143
+ * ```ts
144
+ * try {
145
+ * await client.agent.register(params);
146
+ * } catch (err) {
147
+ * if (err instanceof SapRpcError) {
148
+ * console.error(`RPC error ${err.rpcCode}: ${err.message}`);
149
+ * err.logs?.forEach((log) => console.debug(log));
150
+ * }
151
+ * }
152
+ * ```
153
+ *
154
+ * @see {@link SapRpcError.fromAnchor}
155
+ * @see {@link SapError}
156
+ */
157
+ class SapRpcError extends SapError {
158
+ /**
159
+ * @description Anchor / program error code, if available.
160
+ * @readonly
161
+ */
162
+ rpcCode;
163
+ /**
164
+ * @description Transaction logs returned by the RPC node.
165
+ * @readonly
166
+ */
167
+ logs;
168
+ /**
169
+ * @param message - A human-readable description of the RPC or transaction error.
170
+ * @param opts - Optional additional context.
171
+ * @param opts.rpcCode - Anchor or Solana program error code.
172
+ * @param opts.logs - Raw transaction logs from the RPC node.
173
+ */
174
+ constructor(message, opts) {
175
+ super(message, "SAP_RPC_ERROR");
176
+ this.name = "SapRpcError";
177
+ this.rpcCode = opts?.rpcCode;
178
+ this.logs = opts?.logs;
179
+ }
180
+ /**
181
+ * @static
182
+ * @description Create a {@link SapRpcError} from an Anchor-style error object.
183
+ * Extracts `code` and `logs` automatically from the Anchor error shape.
184
+ *
185
+ * @param err - The raw Anchor or Solana error object.
186
+ * @returns A new {@link SapRpcError} populated with extracted code, logs, and message.
187
+ *
188
+ * @example
189
+ * ```ts
190
+ * try {
191
+ * await program.methods.registerAgent(args).rpc();
192
+ * } catch (raw) {
193
+ * throw SapRpcError.fromAnchor(raw);
194
+ * }
195
+ * ```
196
+ *
197
+ * @see {@link SapRpcError}
198
+ */
199
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
200
+ static fromAnchor(err) {
201
+ const code = err?.error?.errorCode?.number ?? err?.code;
202
+ const logs = err?.logs ?? err?.error?.logs ?? [];
203
+ const msg = err?.error?.errorMessage ?? err?.message ?? "Unknown RPC error";
204
+ return new SapRpcError(msg, { rpcCode: code, logs });
205
+ }
206
+ }
207
+ exports.SapRpcError = SapRpcError;
208
+ // ═══════════════════════════════════════════════════════════════════
209
+ // Account Not Found
210
+ // ═══════════════════════════════════════════════════════════════════
211
+ /**
212
+ * @name SapAccountNotFoundError
213
+ * @description Thrown when an expected on-chain account does not exist or has
214
+ * been closed.
215
+ *
216
+ * @category Errors
217
+ * @since v0.1.0
218
+ * @extends {SapError}
219
+ *
220
+ * @example
221
+ * ```ts
222
+ * try {
223
+ * const agent = await client.agent.fetch(agentPda);
224
+ * } catch (err) {
225
+ * if (err instanceof SapAccountNotFoundError) {
226
+ * console.warn(`Missing ${err.accountType ?? "account"}: ${err.address}`);
227
+ * }
228
+ * }
229
+ * ```
230
+ *
231
+ * @see {@link SapError}
232
+ */
233
+ class SapAccountNotFoundError extends SapError {
234
+ /**
235
+ * @description The base-58 encoded account address that was not found.
236
+ * @readonly
237
+ */
238
+ address;
239
+ /**
240
+ * @description The expected account type (e.g. `"AgentRecord"`, `"VaultAccount"`).
241
+ * @readonly
242
+ */
243
+ accountType;
244
+ /**
245
+ * @param address - The base-58 encoded address of the missing account.
246
+ * @param accountType - Optional label for the expected account type.
247
+ */
248
+ constructor(address, accountType) {
249
+ const label = accountType ? `${accountType} account` : "Account";
250
+ super(`${label} not found: ${address}`, "SAP_ACCOUNT_NOT_FOUND");
251
+ this.name = "SapAccountNotFoundError";
252
+ this.address = address;
253
+ this.accountType = accountType;
254
+ }
255
+ }
256
+ exports.SapAccountNotFoundError = SapAccountNotFoundError;
257
+ // ═══════════════════════════════════════════════════════════════════
258
+ // Timeout Error
259
+ // ═══════════════════════════════════════════════════════════════════
260
+ /**
261
+ * @name SapTimeoutError
262
+ * @description Thrown when an operation (e.g., transaction confirmation) exceeds
263
+ * the configured timeout.
264
+ *
265
+ * @category Errors
266
+ * @since v0.1.0
267
+ * @extends {SapError}
268
+ *
269
+ * @example
270
+ * ```ts
271
+ * try {
272
+ * await client.agent.register(params, { timeoutMs: 30_000 });
273
+ * } catch (err) {
274
+ * if (err instanceof SapTimeoutError) {
275
+ * console.error(`Timed out after ${err.timeoutMs}ms: ${err.message}`);
276
+ * }
277
+ * }
278
+ * ```
279
+ *
280
+ * @see {@link SapError}
281
+ */
282
+ class SapTimeoutError extends SapError {
283
+ /**
284
+ * @description Timeout duration in milliseconds that was exceeded.
285
+ * @readonly
286
+ */
287
+ timeoutMs;
288
+ /**
289
+ * @param message - A human-readable description of the timeout.
290
+ * @param timeoutMs - The timeout threshold in milliseconds.
291
+ */
292
+ constructor(message, timeoutMs) {
293
+ super(message, "SAP_TIMEOUT");
294
+ this.name = "SapTimeoutError";
295
+ this.timeoutMs = timeoutMs;
296
+ }
297
+ }
298
+ exports.SapTimeoutError = SapTimeoutError;
299
+ // ═══════════════════════════════════════════════════════════════════
300
+ // Permission Error
301
+ // ═══════════════════════════════════════════════════════════════════
302
+ /**
303
+ * @name SapPermissionError
304
+ * @description Thrown when the current wallet lacks the required permission
305
+ * (authority, delegate, etc.) for an operation.
306
+ *
307
+ * @category Errors
308
+ * @since v0.1.0
309
+ * @extends {SapError}
310
+ *
311
+ * @example
312
+ * ```ts
313
+ * try {
314
+ * await client.agent.update(agentPda, updates);
315
+ * } catch (err) {
316
+ * if (err instanceof SapPermissionError) {
317
+ * console.error(`Permission denied: ${err.message}`);
318
+ * }
319
+ * }
320
+ * ```
321
+ *
322
+ * @see {@link SapError}
323
+ */
324
+ class SapPermissionError extends SapError {
325
+ /**
326
+ * @param message - A human-readable description of the permission failure.
327
+ */
328
+ constructor(message) {
329
+ super(message, "SAP_PERMISSION_DENIED");
330
+ this.name = "SapPermissionError";
331
+ }
332
+ }
333
+ exports.SapPermissionError = SapPermissionError;
334
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/errors/index.ts"],"names":[],"mappings":"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"}