@oobe-protocol-labs/synapse-sap-sdk 0.12.9 → 0.14.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 (640) hide show
  1. package/dist/cjs/accounts/index.js +286 -0
  2. package/dist/cjs/accounts/index.js.map +1 -0
  3. package/dist/cjs/client.js +108 -0
  4. package/dist/cjs/client.js.map +1 -0
  5. package/dist/cjs/constants.js +59 -0
  6. package/dist/cjs/constants.js.map +1 -0
  7. package/dist/cjs/errors.js +250 -0
  8. package/dist/cjs/errors.js.map +1 -0
  9. package/dist/cjs/events/index.js +38 -130
  10. package/dist/cjs/events/index.js.map +1 -1
  11. package/dist/cjs/idlTypes.js +4 -0
  12. package/dist/cjs/idlTypes.js.map +1 -0
  13. package/dist/cjs/index.js +75 -241
  14. package/dist/cjs/index.js.map +1 -1
  15. package/dist/cjs/instructions/agent.js +89 -0
  16. package/dist/cjs/instructions/agent.js.map +1 -0
  17. package/dist/cjs/instructions/attestation.js +112 -0
  18. package/dist/cjs/instructions/attestation.js.map +1 -0
  19. package/dist/cjs/instructions/digest.js +28 -0
  20. package/dist/cjs/instructions/digest.js.map +1 -0
  21. package/dist/cjs/instructions/dispute.js +116 -0
  22. package/dist/cjs/instructions/dispute.js.map +1 -0
  23. package/dist/cjs/instructions/escrow.js +101 -0
  24. package/dist/cjs/instructions/escrow.js.map +1 -0
  25. package/dist/cjs/instructions/global.js +28 -0
  26. package/dist/cjs/instructions/global.js.map +1 -0
  27. package/dist/cjs/instructions/index.js +31 -0
  28. package/dist/cjs/instructions/index.js.map +1 -0
  29. package/dist/cjs/instructions/indexing.js +221 -0
  30. package/dist/cjs/instructions/indexing.js.map +1 -0
  31. package/dist/cjs/instructions/misc.js +73 -0
  32. package/dist/cjs/instructions/misc.js.map +1 -0
  33. package/dist/cjs/instructions/session.js +89 -0
  34. package/dist/cjs/instructions/session.js.map +1 -0
  35. package/dist/cjs/instructions/staking.js +132 -0
  36. package/dist/cjs/instructions/staking.js.map +1 -0
  37. package/dist/cjs/instructions/subscription.js +80 -0
  38. package/dist/cjs/instructions/subscription.js.map +1 -0
  39. package/dist/cjs/instructions/tools.js +109 -0
  40. package/dist/cjs/instructions/tools.js.map +1 -0
  41. package/dist/cjs/instructions/vault.js +106 -0
  42. package/dist/cjs/instructions/vault.js.map +1 -0
  43. package/dist/cjs/pdas/index.js +120 -0
  44. package/dist/cjs/pdas/index.js.map +1 -0
  45. package/dist/cjs/types.js +42 -0
  46. package/dist/cjs/types.js.map +1 -0
  47. package/dist/cjs/utils/index.js +29 -75
  48. package/dist/cjs/utils/index.js.map +1 -1
  49. package/dist/cjs/utils/validate.js +236 -0
  50. package/dist/cjs/utils/validate.js.map +1 -0
  51. package/dist/esm/accounts/index.d.ts +11 -0
  52. package/dist/esm/accounts/index.d.ts.map +1 -0
  53. package/dist/esm/accounts/index.js +273 -0
  54. package/dist/esm/accounts/index.js.map +1 -0
  55. package/dist/esm/client.d.ts +55 -0
  56. package/dist/esm/client.d.ts.map +1 -0
  57. package/dist/esm/client.js +70 -0
  58. package/dist/esm/client.js.map +1 -0
  59. package/dist/esm/constants.d.ts +52 -0
  60. package/dist/esm/constants.d.ts.map +1 -0
  61. package/dist/esm/constants.js +56 -0
  62. package/dist/esm/constants.js.map +1 -0
  63. package/dist/esm/errors.d.ts +111 -0
  64. package/dist/esm/errors.d.ts.map +1 -0
  65. package/dist/esm/errors.js +244 -0
  66. package/dist/esm/errors.js.map +1 -0
  67. package/dist/esm/events/index.d.ts +13 -0
  68. package/dist/esm/events/index.d.ts.map +1 -0
  69. package/dist/esm/events/index.js +36 -128
  70. package/dist/esm/events/index.js.map +1 -1
  71. package/dist/esm/idlTypes.d.ts +925 -0
  72. package/dist/esm/idlTypes.d.ts.map +1 -0
  73. package/dist/esm/idlTypes.js +3 -0
  74. package/dist/esm/idlTypes.js.map +1 -0
  75. package/dist/esm/index.d.ts +12 -0
  76. package/dist/esm/index.d.ts.map +1 -0
  77. package/dist/esm/index.js +15 -88
  78. package/dist/esm/index.js.map +1 -1
  79. package/dist/esm/instructions/agent.d.ts +71 -0
  80. package/dist/esm/instructions/agent.d.ts.map +1 -0
  81. package/dist/esm/instructions/agent.js +85 -0
  82. package/dist/esm/instructions/agent.js.map +1 -0
  83. package/dist/esm/instructions/attestation.d.ts +76 -0
  84. package/dist/esm/instructions/attestation.d.ts.map +1 -0
  85. package/dist/esm/instructions/attestation.js +108 -0
  86. package/dist/esm/instructions/attestation.js.map +1 -0
  87. package/dist/esm/instructions/digest.d.ts +20 -0
  88. package/dist/esm/instructions/digest.d.ts.map +1 -0
  89. package/dist/esm/instructions/digest.js +24 -0
  90. package/dist/esm/instructions/digest.js.map +1 -0
  91. package/dist/esm/instructions/dispute.d.ts +81 -0
  92. package/dist/esm/instructions/dispute.d.ts.map +1 -0
  93. package/dist/esm/instructions/dispute.js +112 -0
  94. package/dist/esm/instructions/dispute.js.map +1 -0
  95. package/dist/esm/instructions/escrow.d.ts +79 -0
  96. package/dist/esm/instructions/escrow.d.ts.map +1 -0
  97. package/dist/esm/instructions/escrow.js +97 -0
  98. package/dist/esm/instructions/escrow.js.map +1 -0
  99. package/dist/esm/instructions/global.d.ts +14 -0
  100. package/dist/esm/instructions/global.d.ts.map +1 -0
  101. package/dist/esm/instructions/global.js +24 -0
  102. package/dist/esm/instructions/global.js.map +1 -0
  103. package/dist/esm/instructions/index.d.ts +14 -0
  104. package/dist/esm/instructions/index.d.ts.map +1 -0
  105. package/dist/esm/instructions/index.js +15 -0
  106. package/dist/esm/instructions/index.js.map +1 -0
  107. package/dist/esm/instructions/indexing.d.ts +150 -0
  108. package/dist/esm/instructions/indexing.d.ts.map +1 -0
  109. package/dist/esm/instructions/indexing.js +217 -0
  110. package/dist/esm/instructions/indexing.js.map +1 -0
  111. package/dist/esm/instructions/memory.d.ts +8 -0
  112. package/dist/esm/instructions/memory.d.ts.map +1 -0
  113. package/dist/esm/instructions/memory.js +234 -0
  114. package/dist/esm/instructions/memory.js.map +1 -0
  115. package/dist/esm/instructions/misc.d.ts +50 -0
  116. package/dist/esm/instructions/misc.d.ts.map +1 -0
  117. package/dist/esm/instructions/misc.js +69 -0
  118. package/dist/esm/instructions/misc.js.map +1 -0
  119. package/dist/esm/instructions/session.d.ts +57 -0
  120. package/dist/esm/instructions/session.d.ts.map +1 -0
  121. package/dist/esm/instructions/session.js +85 -0
  122. package/dist/esm/instructions/session.js.map +1 -0
  123. package/dist/esm/instructions/staking.d.ts +85 -0
  124. package/dist/esm/instructions/staking.d.ts.map +1 -0
  125. package/dist/esm/instructions/staking.js +128 -0
  126. package/dist/esm/instructions/staking.js.map +1 -0
  127. package/dist/esm/instructions/subscription.d.ts +50 -0
  128. package/dist/esm/instructions/subscription.d.ts.map +1 -0
  129. package/dist/esm/instructions/subscription.js +76 -0
  130. package/dist/esm/instructions/subscription.js.map +1 -0
  131. package/dist/esm/instructions/tools.d.ts +88 -0
  132. package/dist/esm/instructions/tools.d.ts.map +1 -0
  133. package/dist/esm/instructions/tools.js +105 -0
  134. package/dist/esm/instructions/tools.js.map +1 -0
  135. package/dist/esm/instructions/vault.d.ts +84 -0
  136. package/dist/esm/instructions/vault.d.ts.map +1 -0
  137. package/dist/esm/instructions/vault.js +102 -0
  138. package/dist/esm/instructions/vault.js.map +1 -0
  139. package/dist/esm/pdas/index.d.ts +37 -0
  140. package/dist/esm/pdas/index.d.ts.map +1 -0
  141. package/dist/esm/pdas/index.js +101 -0
  142. package/dist/esm/pdas/index.js.map +1 -0
  143. package/dist/esm/types.d.ts +208 -0
  144. package/dist/esm/types.d.ts.map +1 -0
  145. package/dist/esm/types.js +39 -0
  146. package/dist/esm/types.js.map +1 -0
  147. package/dist/esm/utils/index.d.ts +4 -0
  148. package/dist/esm/utils/index.d.ts.map +1 -0
  149. package/dist/esm/utils/index.js +13 -29
  150. package/dist/esm/utils/index.js.map +1 -1
  151. package/dist/esm/utils/validate.d.ts +66 -0
  152. package/dist/esm/utils/validate.d.ts.map +1 -0
  153. package/dist/esm/utils/validate.js +221 -0
  154. package/dist/esm/utils/validate.js.map +1 -0
  155. package/package.json +59 -183
  156. package/LICENSE +0 -21
  157. package/README.md +0 -986
  158. package/dist/cjs/constants/addresses.js +0 -143
  159. package/dist/cjs/constants/addresses.js.map +0 -1
  160. package/dist/cjs/constants/index.js +0 -64
  161. package/dist/cjs/constants/index.js.map +0 -1
  162. package/dist/cjs/constants/limits.js +0 -161
  163. package/dist/cjs/constants/limits.js.map +0 -1
  164. package/dist/cjs/constants/network.js +0 -81
  165. package/dist/cjs/constants/network.js.map +0 -1
  166. package/dist/cjs/constants/payments.js +0 -137
  167. package/dist/cjs/constants/payments.js.map +0 -1
  168. package/dist/cjs/constants/programs.js +0 -78
  169. package/dist/cjs/constants/programs.js.map +0 -1
  170. package/dist/cjs/constants/seeds.js +0 -76
  171. package/dist/cjs/constants/seeds.js.map +0 -1
  172. package/dist/cjs/core/client.js +0 -546
  173. package/dist/cjs/core/client.js.map +0 -1
  174. package/dist/cjs/core/connection.js +0 -350
  175. package/dist/cjs/core/connection.js.map +0 -1
  176. package/dist/cjs/core/index.js +0 -25
  177. package/dist/cjs/core/index.js.map +0 -1
  178. package/dist/cjs/errors/index.js +0 -334
  179. package/dist/cjs/errors/index.js.map +0 -1
  180. package/dist/cjs/events/geyser.js +0 -295
  181. package/dist/cjs/events/geyser.js.map +0 -1
  182. package/dist/cjs/idl/index.js +0 -63
  183. package/dist/cjs/idl/index.js.map +0 -1
  184. package/dist/cjs/idl/synapse_agent_sap.json +0 -14595
  185. package/dist/cjs/modules/agent.js +0 -272
  186. package/dist/cjs/modules/agent.js.map +0 -1
  187. package/dist/cjs/modules/attestation.js +0 -147
  188. package/dist/cjs/modules/attestation.js.map +0 -1
  189. package/dist/cjs/modules/base.js +0 -128
  190. package/dist/cjs/modules/base.js.map +0 -1
  191. package/dist/cjs/modules/escrow-v2.js +0 -454
  192. package/dist/cjs/modules/escrow-v2.js.map +0 -1
  193. package/dist/cjs/modules/escrow.js +0 -300
  194. package/dist/cjs/modules/escrow.js.map +0 -1
  195. package/dist/cjs/modules/feedback.js +0 -166
  196. package/dist/cjs/modules/feedback.js.map +0 -1
  197. package/dist/cjs/modules/index.js +0 -43
  198. package/dist/cjs/modules/index.js.map +0 -1
  199. package/dist/cjs/modules/indexing.js +0 -375
  200. package/dist/cjs/modules/indexing.js.map +0 -1
  201. package/dist/cjs/modules/ledger.js +0 -234
  202. package/dist/cjs/modules/ledger.js.map +0 -1
  203. package/dist/cjs/modules/receipt.js +0 -148
  204. package/dist/cjs/modules/receipt.js.map +0 -1
  205. package/dist/cjs/modules/staking.js +0 -124
  206. package/dist/cjs/modules/staking.js.map +0 -1
  207. package/dist/cjs/modules/subscription.js +0 -96
  208. package/dist/cjs/modules/subscription.js.map +0 -1
  209. package/dist/cjs/modules/tools.js +0 -319
  210. package/dist/cjs/modules/tools.js.map +0 -1
  211. package/dist/cjs/modules/vault.js +0 -410
  212. package/dist/cjs/modules/vault.js.map +0 -1
  213. package/dist/cjs/parser/client.js +0 -146
  214. package/dist/cjs/parser/client.js.map +0 -1
  215. package/dist/cjs/parser/complete.js +0 -177
  216. package/dist/cjs/parser/complete.js.map +0 -1
  217. package/dist/cjs/parser/index.js +0 -57
  218. package/dist/cjs/parser/index.js.map +0 -1
  219. package/dist/cjs/parser/inner.js +0 -185
  220. package/dist/cjs/parser/inner.js.map +0 -1
  221. package/dist/cjs/parser/instructions.js +0 -114
  222. package/dist/cjs/parser/instructions.js.map +0 -1
  223. package/dist/cjs/parser/transaction.js +0 -153
  224. package/dist/cjs/parser/transaction.js.map +0 -1
  225. package/dist/cjs/parser/types.js +0 -14
  226. package/dist/cjs/parser/types.js.map +0 -1
  227. package/dist/cjs/pda/index.js +0 -672
  228. package/dist/cjs/pda/index.js.map +0 -1
  229. package/dist/cjs/plugin/index.js +0 -952
  230. package/dist/cjs/plugin/index.js.map +0 -1
  231. package/dist/cjs/plugin/protocols.js +0 -282
  232. package/dist/cjs/plugin/protocols.js.map +0 -1
  233. package/dist/cjs/plugin/schemas.js +0 -863
  234. package/dist/cjs/plugin/schemas.js.map +0 -1
  235. package/dist/cjs/postgres/adapter.js +0 -715
  236. package/dist/cjs/postgres/adapter.js.map +0 -1
  237. package/dist/cjs/postgres/index.js +0 -50
  238. package/dist/cjs/postgres/index.js.map +0 -1
  239. package/dist/cjs/postgres/serializers.js +0 -381
  240. package/dist/cjs/postgres/serializers.js.map +0 -1
  241. package/dist/cjs/postgres/sync.js +0 -289
  242. package/dist/cjs/postgres/sync.js.map +0 -1
  243. package/dist/cjs/postgres/types.js +0 -44
  244. package/dist/cjs/postgres/types.js.map +0 -1
  245. package/dist/cjs/registries/builder.js +0 -414
  246. package/dist/cjs/registries/builder.js.map +0 -1
  247. package/dist/cjs/registries/discovery.js +0 -362
  248. package/dist/cjs/registries/discovery.js.map +0 -1
  249. package/dist/cjs/registries/fairscale.js +0 -639
  250. package/dist/cjs/registries/fairscale.js.map +0 -1
  251. package/dist/cjs/registries/index.js +0 -58
  252. package/dist/cjs/registries/index.js.map +0 -1
  253. package/dist/cjs/registries/metaplex-bridge.js +0 -743
  254. package/dist/cjs/registries/metaplex-bridge.js.map +0 -1
  255. package/dist/cjs/registries/session.js +0 -433
  256. package/dist/cjs/registries/session.js.map +0 -1
  257. package/dist/cjs/registries/x402.js +0 -668
  258. package/dist/cjs/registries/x402.js.map +0 -1
  259. package/dist/cjs/types/accounts.js +0 -13
  260. package/dist/cjs/types/accounts.js.map +0 -1
  261. package/dist/cjs/types/common.js +0 -13
  262. package/dist/cjs/types/common.js.map +0 -1
  263. package/dist/cjs/types/endpoint.js +0 -15
  264. package/dist/cjs/types/endpoint.js.map +0 -1
  265. package/dist/cjs/types/enums.js +0 -269
  266. package/dist/cjs/types/enums.js.map +0 -1
  267. package/dist/cjs/types/index.js +0 -41
  268. package/dist/cjs/types/index.js.map +0 -1
  269. package/dist/cjs/types/instructions.js +0 -92
  270. package/dist/cjs/types/instructions.js.map +0 -1
  271. package/dist/cjs/utils/endpoint-validator.js +0 -232
  272. package/dist/cjs/utils/endpoint-validator.js.map +0 -1
  273. package/dist/cjs/utils/escrow-validation.js +0 -219
  274. package/dist/cjs/utils/escrow-validation.js.map +0 -1
  275. package/dist/cjs/utils/hash.js +0 -109
  276. package/dist/cjs/utils/hash.js.map +0 -1
  277. package/dist/cjs/utils/merchant-validator.js +0 -246
  278. package/dist/cjs/utils/merchant-validator.js.map +0 -1
  279. package/dist/cjs/utils/network-normalizer.js +0 -236
  280. package/dist/cjs/utils/network-normalizer.js.map +0 -1
  281. package/dist/cjs/utils/priority-fee.js +0 -215
  282. package/dist/cjs/utils/priority-fee.js.map +0 -1
  283. package/dist/cjs/utils/rpc-strategy.js +0 -239
  284. package/dist/cjs/utils/rpc-strategy.js.map +0 -1
  285. package/dist/cjs/utils/schemas.js +0 -331
  286. package/dist/cjs/utils/schemas.js.map +0 -1
  287. package/dist/cjs/utils/serialization.js +0 -105
  288. package/dist/cjs/utils/serialization.js.map +0 -1
  289. package/dist/cjs/utils/validation.js +0 -36
  290. package/dist/cjs/utils/validation.js.map +0 -1
  291. package/dist/cjs/utils/x402-direct.js +0 -231
  292. package/dist/cjs/utils/x402-direct.js.map +0 -1
  293. package/dist/esm/constants/addresses.js +0 -140
  294. package/dist/esm/constants/addresses.js.map +0 -1
  295. package/dist/esm/constants/index.js +0 -35
  296. package/dist/esm/constants/index.js.map +0 -1
  297. package/dist/esm/constants/limits.js +0 -158
  298. package/dist/esm/constants/limits.js.map +0 -1
  299. package/dist/esm/constants/network.js +0 -78
  300. package/dist/esm/constants/network.js.map +0 -1
  301. package/dist/esm/constants/payments.js +0 -131
  302. package/dist/esm/constants/payments.js.map +0 -1
  303. package/dist/esm/constants/programs.js +0 -75
  304. package/dist/esm/constants/programs.js.map +0 -1
  305. package/dist/esm/constants/seeds.js +0 -73
  306. package/dist/esm/constants/seeds.js.map +0 -1
  307. package/dist/esm/core/client.js +0 -539
  308. package/dist/esm/core/client.js.map +0 -1
  309. package/dist/esm/core/connection.js +0 -345
  310. package/dist/esm/core/connection.js.map +0 -1
  311. package/dist/esm/core/index.js +0 -19
  312. package/dist/esm/core/index.js.map +0 -1
  313. package/dist/esm/errors/index.js +0 -325
  314. package/dist/esm/errors/index.js.map +0 -1
  315. package/dist/esm/events/geyser.js +0 -258
  316. package/dist/esm/events/geyser.js.map +0 -1
  317. package/dist/esm/idl/index.js +0 -57
  318. package/dist/esm/idl/index.js.map +0 -1
  319. package/dist/esm/idl/synapse_agent_sap.json +0 -14595
  320. package/dist/esm/modules/agent.js +0 -268
  321. package/dist/esm/modules/agent.js.map +0 -1
  322. package/dist/esm/modules/attestation.js +0 -143
  323. package/dist/esm/modules/attestation.js.map +0 -1
  324. package/dist/esm/modules/base.js +0 -124
  325. package/dist/esm/modules/base.js.map +0 -1
  326. package/dist/esm/modules/escrow-v2.js +0 -450
  327. package/dist/esm/modules/escrow-v2.js.map +0 -1
  328. package/dist/esm/modules/escrow.js +0 -296
  329. package/dist/esm/modules/escrow.js.map +0 -1
  330. package/dist/esm/modules/feedback.js +0 -162
  331. package/dist/esm/modules/feedback.js.map +0 -1
  332. package/dist/esm/modules/index.js +0 -27
  333. package/dist/esm/modules/index.js.map +0 -1
  334. package/dist/esm/modules/indexing.js +0 -371
  335. package/dist/esm/modules/indexing.js.map +0 -1
  336. package/dist/esm/modules/ledger.js +0 -230
  337. package/dist/esm/modules/ledger.js.map +0 -1
  338. package/dist/esm/modules/receipt.js +0 -144
  339. package/dist/esm/modules/receipt.js.map +0 -1
  340. package/dist/esm/modules/staking.js +0 -120
  341. package/dist/esm/modules/staking.js.map +0 -1
  342. package/dist/esm/modules/subscription.js +0 -92
  343. package/dist/esm/modules/subscription.js.map +0 -1
  344. package/dist/esm/modules/tools.js +0 -315
  345. package/dist/esm/modules/tools.js.map +0 -1
  346. package/dist/esm/modules/vault.js +0 -406
  347. package/dist/esm/modules/vault.js.map +0 -1
  348. package/dist/esm/parser/client.js +0 -142
  349. package/dist/esm/parser/client.js.map +0 -1
  350. package/dist/esm/parser/complete.js +0 -173
  351. package/dist/esm/parser/complete.js.map +0 -1
  352. package/dist/esm/parser/index.js +0 -43
  353. package/dist/esm/parser/index.js.map +0 -1
  354. package/dist/esm/parser/inner.js +0 -180
  355. package/dist/esm/parser/inner.js.map +0 -1
  356. package/dist/esm/parser/instructions.js +0 -109
  357. package/dist/esm/parser/instructions.js.map +0 -1
  358. package/dist/esm/parser/transaction.js +0 -149
  359. package/dist/esm/parser/transaction.js.map +0 -1
  360. package/dist/esm/parser/types.js +0 -13
  361. package/dist/esm/parser/types.js.map +0 -1
  362. package/dist/esm/pda/index.js +0 -638
  363. package/dist/esm/pda/index.js.map +0 -1
  364. package/dist/esm/plugin/index.js +0 -945
  365. package/dist/esm/plugin/index.js.map +0 -1
  366. package/dist/esm/plugin/protocols.js +0 -279
  367. package/dist/esm/plugin/protocols.js.map +0 -1
  368. package/dist/esm/plugin/schemas.js +0 -860
  369. package/dist/esm/plugin/schemas.js.map +0 -1
  370. package/dist/esm/postgres/adapter.js +0 -678
  371. package/dist/esm/postgres/adapter.js.map +0 -1
  372. package/dist/esm/postgres/index.js +0 -27
  373. package/dist/esm/postgres/index.js.map +0 -1
  374. package/dist/esm/postgres/serializers.js +0 -362
  375. package/dist/esm/postgres/serializers.js.map +0 -1
  376. package/dist/esm/postgres/sync.js +0 -285
  377. package/dist/esm/postgres/sync.js.map +0 -1
  378. package/dist/esm/postgres/types.js +0 -41
  379. package/dist/esm/postgres/types.js.map +0 -1
  380. package/dist/esm/registries/builder.js +0 -410
  381. package/dist/esm/registries/builder.js.map +0 -1
  382. package/dist/esm/registries/discovery.js +0 -358
  383. package/dist/esm/registries/discovery.js.map +0 -1
  384. package/dist/esm/registries/fairscale.js +0 -633
  385. package/dist/esm/registries/fairscale.js.map +0 -1
  386. package/dist/esm/registries/index.js +0 -46
  387. package/dist/esm/registries/index.js.map +0 -1
  388. package/dist/esm/registries/metaplex-bridge.js +0 -706
  389. package/dist/esm/registries/metaplex-bridge.js.map +0 -1
  390. package/dist/esm/registries/session.js +0 -429
  391. package/dist/esm/registries/session.js.map +0 -1
  392. package/dist/esm/registries/x402.js +0 -664
  393. package/dist/esm/registries/x402.js.map +0 -1
  394. package/dist/esm/types/accounts.js +0 -12
  395. package/dist/esm/types/accounts.js.map +0 -1
  396. package/dist/esm/types/common.js +0 -12
  397. package/dist/esm/types/common.js.map +0 -1
  398. package/dist/esm/types/endpoint.js +0 -14
  399. package/dist/esm/types/endpoint.js.map +0 -1
  400. package/dist/esm/types/enums.js +0 -266
  401. package/dist/esm/types/enums.js.map +0 -1
  402. package/dist/esm/types/index.js +0 -25
  403. package/dist/esm/types/index.js.map +0 -1
  404. package/dist/esm/types/instructions.js +0 -89
  405. package/dist/esm/types/instructions.js.map +0 -1
  406. package/dist/esm/utils/endpoint-validator.js +0 -226
  407. package/dist/esm/utils/endpoint-validator.js.map +0 -1
  408. package/dist/esm/utils/escrow-validation.js +0 -212
  409. package/dist/esm/utils/escrow-validation.js.map +0 -1
  410. package/dist/esm/utils/hash.js +0 -103
  411. package/dist/esm/utils/hash.js.map +0 -1
  412. package/dist/esm/utils/merchant-validator.js +0 -241
  413. package/dist/esm/utils/merchant-validator.js.map +0 -1
  414. package/dist/esm/utils/network-normalizer.js +0 -229
  415. package/dist/esm/utils/network-normalizer.js.map +0 -1
  416. package/dist/esm/utils/priority-fee.js +0 -209
  417. package/dist/esm/utils/priority-fee.js.map +0 -1
  418. package/dist/esm/utils/rpc-strategy.js +0 -231
  419. package/dist/esm/utils/rpc-strategy.js.map +0 -1
  420. package/dist/esm/utils/schemas.js +0 -320
  421. package/dist/esm/utils/schemas.js.map +0 -1
  422. package/dist/esm/utils/serialization.js +0 -98
  423. package/dist/esm/utils/serialization.js.map +0 -1
  424. package/dist/esm/utils/validation.js +0 -33
  425. package/dist/esm/utils/validation.js.map +0 -1
  426. package/dist/esm/utils/x402-direct.js +0 -228
  427. package/dist/esm/utils/x402-direct.js.map +0 -1
  428. package/dist/types/constants/addresses.d.ts +0 -117
  429. package/dist/types/constants/addresses.d.ts.map +0 -1
  430. package/dist/types/constants/index.d.ts +0 -31
  431. package/dist/types/constants/index.d.ts.map +0 -1
  432. package/dist/types/constants/limits.d.ts +0 -149
  433. package/dist/types/constants/limits.d.ts.map +0 -1
  434. package/dist/types/constants/network.d.ts +0 -81
  435. package/dist/types/constants/network.d.ts.map +0 -1
  436. package/dist/types/constants/payments.d.ts +0 -121
  437. package/dist/types/constants/payments.d.ts.map +0 -1
  438. package/dist/types/constants/programs.d.ts +0 -69
  439. package/dist/types/constants/programs.d.ts.map +0 -1
  440. package/dist/types/constants/seeds.d.ts +0 -80
  441. package/dist/types/constants/seeds.d.ts.map +0 -1
  442. package/dist/types/core/client.d.ts +0 -452
  443. package/dist/types/core/client.d.ts.map +0 -1
  444. package/dist/types/core/connection.d.ts +0 -305
  445. package/dist/types/core/connection.d.ts.map +0 -1
  446. package/dist/types/core/index.d.ts +0 -20
  447. package/dist/types/core/index.d.ts.map +0 -1
  448. package/dist/types/errors/index.d.ts +0 -276
  449. package/dist/types/errors/index.d.ts.map +0 -1
  450. package/dist/types/events/geyser.d.ts +0 -150
  451. package/dist/types/events/geyser.d.ts.map +0 -1
  452. package/dist/types/events/index.d.ts +0 -248
  453. package/dist/types/events/index.d.ts.map +0 -1
  454. package/dist/types/idl/index.d.ts +0 -70
  455. package/dist/types/idl/index.d.ts.map +0 -1
  456. package/dist/types/index.d.ts +0 -85
  457. package/dist/types/index.d.ts.map +0 -1
  458. package/dist/types/modules/agent.d.ts +0 -166
  459. package/dist/types/modules/agent.d.ts.map +0 -1
  460. package/dist/types/modules/attestation.d.ts +0 -96
  461. package/dist/types/modules/attestation.d.ts.map +0 -1
  462. package/dist/types/modules/base.d.ts +0 -126
  463. package/dist/types/modules/base.d.ts.map +0 -1
  464. package/dist/types/modules/escrow-v2.d.ts +0 -100
  465. package/dist/types/modules/escrow-v2.d.ts.map +0 -1
  466. package/dist/types/modules/escrow.d.ts +0 -168
  467. package/dist/types/modules/escrow.d.ts.map +0 -1
  468. package/dist/types/modules/feedback.d.ts +0 -105
  469. package/dist/types/modules/feedback.d.ts.map +0 -1
  470. package/dist/types/modules/index.d.ts +0 -28
  471. package/dist/types/modules/index.d.ts.map +0 -1
  472. package/dist/types/modules/indexing.d.ts +0 -200
  473. package/dist/types/modules/indexing.d.ts.map +0 -1
  474. package/dist/types/modules/ledger.d.ts +0 -150
  475. package/dist/types/modules/ledger.d.ts.map +0 -1
  476. package/dist/types/modules/receipt.d.ts +0 -77
  477. package/dist/types/modules/receipt.d.ts.map +0 -1
  478. package/dist/types/modules/staking.d.ts +0 -51
  479. package/dist/types/modules/staking.d.ts.map +0 -1
  480. package/dist/types/modules/subscription.d.ts +0 -33
  481. package/dist/types/modules/subscription.d.ts.map +0 -1
  482. package/dist/types/modules/tools.d.ts +0 -182
  483. package/dist/types/modules/tools.d.ts.map +0 -1
  484. package/dist/types/modules/vault.d.ts +0 -240
  485. package/dist/types/modules/vault.d.ts.map +0 -1
  486. package/dist/types/parser/client.d.ts +0 -123
  487. package/dist/types/parser/client.d.ts.map +0 -1
  488. package/dist/types/parser/complete.d.ts +0 -90
  489. package/dist/types/parser/complete.d.ts.map +0 -1
  490. package/dist/types/parser/index.d.ts +0 -40
  491. package/dist/types/parser/index.d.ts.map +0 -1
  492. package/dist/types/parser/inner.d.ts +0 -114
  493. package/dist/types/parser/inner.d.ts.map +0 -1
  494. package/dist/types/parser/instructions.d.ts +0 -76
  495. package/dist/types/parser/instructions.d.ts.map +0 -1
  496. package/dist/types/parser/transaction.d.ts +0 -77
  497. package/dist/types/parser/transaction.d.ts.map +0 -1
  498. package/dist/types/parser/types.d.ts +0 -154
  499. package/dist/types/parser/types.d.ts.map +0 -1
  500. package/dist/types/pda/index.d.ts +0 -510
  501. package/dist/types/pda/index.d.ts.map +0 -1
  502. package/dist/types/plugin/index.d.ts +0 -171
  503. package/dist/types/plugin/index.d.ts.map +0 -1
  504. package/dist/types/plugin/protocols.d.ts +0 -152
  505. package/dist/types/plugin/protocols.d.ts.map +0 -1
  506. package/dist/types/plugin/schemas.d.ts +0 -829
  507. package/dist/types/plugin/schemas.d.ts.map +0 -1
  508. package/dist/types/postgres/adapter.d.ts +0 -355
  509. package/dist/types/postgres/adapter.d.ts.map +0 -1
  510. package/dist/types/postgres/index.d.ts +0 -24
  511. package/dist/types/postgres/index.d.ts.map +0 -1
  512. package/dist/types/postgres/serializers.d.ts +0 -30
  513. package/dist/types/postgres/serializers.d.ts.map +0 -1
  514. package/dist/types/postgres/sync.d.ts +0 -156
  515. package/dist/types/postgres/sync.d.ts.map +0 -1
  516. package/dist/types/postgres/types.d.ts +0 -167
  517. package/dist/types/postgres/types.d.ts.map +0 -1
  518. package/dist/types/registries/builder.d.ts +0 -340
  519. package/dist/types/registries/builder.d.ts.map +0 -1
  520. package/dist/types/registries/discovery.d.ts +0 -333
  521. package/dist/types/registries/discovery.d.ts.map +0 -1
  522. package/dist/types/registries/fairscale.d.ts +0 -680
  523. package/dist/types/registries/fairscale.d.ts.map +0 -1
  524. package/dist/types/registries/index.d.ts +0 -52
  525. package/dist/types/registries/index.d.ts.map +0 -1
  526. package/dist/types/registries/metaplex-bridge.d.ts +0 -488
  527. package/dist/types/registries/metaplex-bridge.d.ts.map +0 -1
  528. package/dist/types/registries/session.d.ts +0 -323
  529. package/dist/types/registries/session.d.ts.map +0 -1
  530. package/dist/types/registries/x402.d.ts +0 -530
  531. package/dist/types/registries/x402.d.ts.map +0 -1
  532. package/dist/types/types/accounts.d.ts +0 -765
  533. package/dist/types/types/accounts.d.ts.map +0 -1
  534. package/dist/types/types/common.d.ts +0 -166
  535. package/dist/types/types/common.d.ts.map +0 -1
  536. package/dist/types/types/endpoint.d.ts +0 -161
  537. package/dist/types/types/endpoint.d.ts.map +0 -1
  538. package/dist/types/types/enums.d.ts +0 -353
  539. package/dist/types/types/enums.d.ts.map +0 -1
  540. package/dist/types/types/index.d.ts +0 -29
  541. package/dist/types/types/index.d.ts.map +0 -1
  542. package/dist/types/types/instructions.d.ts +0 -400
  543. package/dist/types/types/instructions.d.ts.map +0 -1
  544. package/dist/types/utils/endpoint-validator.d.ts +0 -110
  545. package/dist/types/utils/endpoint-validator.d.ts.map +0 -1
  546. package/dist/types/utils/escrow-validation.d.ts +0 -145
  547. package/dist/types/utils/escrow-validation.d.ts.map +0 -1
  548. package/dist/types/utils/hash.d.ts +0 -75
  549. package/dist/types/utils/hash.d.ts.map +0 -1
  550. package/dist/types/utils/index.d.ts +0 -33
  551. package/dist/types/utils/index.d.ts.map +0 -1
  552. package/dist/types/utils/merchant-validator.d.ts +0 -176
  553. package/dist/types/utils/merchant-validator.d.ts.map +0 -1
  554. package/dist/types/utils/network-normalizer.d.ts +0 -120
  555. package/dist/types/utils/network-normalizer.d.ts.map +0 -1
  556. package/dist/types/utils/priority-fee.d.ts +0 -205
  557. package/dist/types/utils/priority-fee.d.ts.map +0 -1
  558. package/dist/types/utils/rpc-strategy.d.ts +0 -172
  559. package/dist/types/utils/rpc-strategy.d.ts.map +0 -1
  560. package/dist/types/utils/schemas.d.ts +0 -351
  561. package/dist/types/utils/schemas.d.ts.map +0 -1
  562. package/dist/types/utils/serialization.d.ts +0 -69
  563. package/dist/types/utils/serialization.d.ts.map +0 -1
  564. package/dist/types/utils/validation.d.ts +0 -29
  565. package/dist/types/utils/validation.d.ts.map +0 -1
  566. package/dist/types/utils/x402-direct.d.ts +0 -114
  567. package/dist/types/utils/x402-direct.d.ts.map +0 -1
  568. package/src/constants/addresses.ts +0 -162
  569. package/src/constants/index.ts +0 -69
  570. package/src/constants/limits.ts +0 -165
  571. package/src/constants/network.ts +0 -89
  572. package/src/constants/payments.ts +0 -145
  573. package/src/constants/programs.ts +0 -83
  574. package/src/constants/seeds.ts +0 -85
  575. package/src/core/client.ts +0 -583
  576. package/src/core/connection.ts +0 -461
  577. package/src/core/index.ts +0 -20
  578. package/src/errors/index.ts +0 -346
  579. package/src/events/geyser.ts +0 -384
  580. package/src/events/index.ts +0 -335
  581. package/src/events/yellowstone.d.ts +0 -7
  582. package/src/idl/index.ts +0 -76
  583. package/src/idl/synapse_agent_sap.json +0 -14595
  584. package/src/index.ts +0 -421
  585. package/src/modules/agent.ts +0 -319
  586. package/src/modules/attestation.ts +0 -168
  587. package/src/modules/base.ts +0 -158
  588. package/src/modules/escrow-v2.ts +0 -658
  589. package/src/modules/escrow.ts +0 -383
  590. package/src/modules/feedback.ts +0 -186
  591. package/src/modules/index.ts +0 -28
  592. package/src/modules/indexing.ts +0 -444
  593. package/src/modules/ledger.ts +0 -262
  594. package/src/modules/receipt.ts +0 -212
  595. package/src/modules/staking.ts +0 -157
  596. package/src/modules/subscription.ts +0 -147
  597. package/src/modules/tools.ts +0 -411
  598. package/src/modules/vault.ts +0 -533
  599. package/src/parser/client.ts +0 -211
  600. package/src/parser/complete.ts +0 -232
  601. package/src/parser/index.ts +0 -71
  602. package/src/parser/inner.ts +0 -255
  603. package/src/parser/instructions.ts +0 -135
  604. package/src/parser/transaction.ts +0 -200
  605. package/src/parser/types.ts +0 -182
  606. package/src/pda/index.ts +0 -919
  607. package/src/plugin/index.ts +0 -1224
  608. package/src/plugin/protocols.ts +0 -404
  609. package/src/plugin/schemas.ts +0 -941
  610. package/src/postgres/adapter.ts +0 -904
  611. package/src/postgres/index.ts +0 -59
  612. package/src/postgres/schema.sql +0 -683
  613. package/src/postgres/serializers.ts +0 -485
  614. package/src/postgres/sync.ts +0 -340
  615. package/src/postgres/types.ts +0 -245
  616. package/src/registries/builder.ts +0 -607
  617. package/src/registries/discovery.ts +0 -572
  618. package/src/registries/fairscale.ts +0 -1278
  619. package/src/registries/index.ts +0 -143
  620. package/src/registries/metaplex-bridge.ts +0 -1199
  621. package/src/registries/session.ts +0 -613
  622. package/src/registries/x402.ts +0 -1048
  623. package/src/types/accounts.ts +0 -858
  624. package/src/types/common.ts +0 -187
  625. package/src/types/endpoint.ts +0 -181
  626. package/src/types/enums.ts +0 -333
  627. package/src/types/index.ts +0 -121
  628. package/src/types/instructions.ts +0 -453
  629. package/src/utils/endpoint-validator.ts +0 -300
  630. package/src/utils/escrow-validation.ts +0 -301
  631. package/src/utils/hash.ts +0 -113
  632. package/src/utils/index.ts +0 -102
  633. package/src/utils/merchant-validator.ts +0 -359
  634. package/src/utils/network-normalizer.ts +0 -240
  635. package/src/utils/priority-fee.ts +0 -325
  636. package/src/utils/rpc-strategy.ts +0 -322
  637. package/src/utils/schemas.ts +0 -359
  638. package/src/utils/serialization.ts +0 -98
  639. package/src/utils/validation.ts +0 -36
  640. package/src/utils/x402-direct.ts +0 -370
@@ -1,658 +0,0 @@
1
- /**
2
- * @module escrow-v2
3
- * @description V2 escrow settlement layer — supports settlement security
4
- * modes (CoSigned, DisputeWindow), receipt-based dispute resolution,
5
- * pending settlements, and automatic resolution via merkle proofs.
6
- *
7
- * @category Modules
8
- * @since v0.7.0
9
- * @packageDocumentation
10
- */
11
-
12
- import {
13
- SystemProgram,
14
- type PublicKey,
15
- type TransactionSignature,
16
- type AccountMeta,
17
- type Signer,
18
- } from "@solana/web3.js";
19
- import { BN } from "@coral-xyz/anchor";
20
- import { BaseModule } from "./base";
21
- import {
22
- deriveAgent,
23
- deriveAgentStats,
24
- deriveEscrowV2,
25
- derivePendingSettlement as derivePendingPda,
26
- deriveDispute as deriveDisputePda,
27
- deriveStake,
28
- deriveSettlementReceipt,
29
- } from "../pda";
30
- import type {
31
- EscrowAccountV2Data,
32
- PendingSettlementData,
33
- DisputeRecordData,
34
- CreateEscrowV2Args,
35
- } from "../types";
36
- import {
37
- buildPriorityFeeIxs,
38
- buildRpcOptions,
39
- } from "../utils/priority-fee";
40
- import type { SettleOptions } from "../utils/priority-fee";
41
- import { isAcceptedPaymentToken, computeRequiredStakeLamports } from "../constants/payments";
42
-
43
- /**
44
- * @name EscrowV2Module
45
- * @description Manages V2 escrow accounts with settlement security modes,
46
- * dispute windows, and pending settlement flows.
47
- *
48
- * @category Modules
49
- * @since v0.7.0
50
- * @extends BaseModule
51
- */
52
- export class EscrowV2Module extends BaseModule {
53
- // ── Helpers ──────────────────────────────────────────
54
-
55
- /** Convert BN | number | bigint → number for PDA seed functions. */
56
- private toNum(v: BN | number | bigint): number {
57
- return BN.isBN(v) ? v.toNumber() : Number(v);
58
- }
59
-
60
- // ── PDA helpers ──────────────────────────────────────
61
-
62
- deriveEscrow(
63
- agentPda: PublicKey,
64
- depositor?: PublicKey,
65
- nonce: BN | number | bigint = 0,
66
- ): readonly [PublicKey, number] {
67
- return deriveEscrowV2(agentPda, depositor ?? this.walletPubkey, this.toNum(nonce));
68
- }
69
-
70
- derivePendingSettlement(
71
- escrowV2Pda: PublicKey,
72
- settlementIndex: BN | number | bigint,
73
- ): readonly [PublicKey, number] {
74
- return derivePendingPda(escrowV2Pda, this.toNum(settlementIndex));
75
- }
76
-
77
- deriveDispute(
78
- pendingSettlementPda: PublicKey,
79
- ): readonly [PublicKey, number] {
80
- return deriveDisputePda(pendingSettlementPda);
81
- }
82
-
83
- // ── Instructions ─────────────────────────────────────
84
-
85
- async create(
86
- agentWallet: PublicKey,
87
- args: CreateEscrowV2Args,
88
- splAccounts: AccountMeta[] = [],
89
- ): Promise<TransactionSignature> {
90
- // v0.10.0: payment-token allowlist (SOL or USDC only).
91
- if (!isAcceptedPaymentToken(args.tokenMint ?? null)) {
92
- throw new Error(
93
- "createEscrowV2: tokenMint must be null (SOL) or USDC (mainnet/devnet). " +
94
- "On-chain will reject with PaymentTokenNotAllowed.",
95
- );
96
- }
97
-
98
- // v0.12.7 preflight: mirror the on-chain settlement-security guards
99
- // (escrow_v2.rs:106-115) so callers fail fast with a clear message
100
- // instead of paying for a tx that aborts with `InvalidSettlementSecurity`
101
- // or `CoSignerRequired`.
102
- const security = args.settlementSecurity;
103
- if (security === 0) {
104
- throw new Error(
105
- "createEscrowV2: settlementSecurity=0 (SelfReport) is deprecated since " +
106
- "v0.7. Use 1 (CoSigned) or 2 (DisputeWindow). On-chain rejects with " +
107
- "SelfReportDeprecated.",
108
- );
109
- }
110
- if (security === 1 && !args.coSigner) {
111
- throw new Error(
112
- "createEscrowV2: settlementSecurity=1 (CoSigned) requires `coSigner` " +
113
- "to be set. On-chain rejects with CoSignerRequired.",
114
- );
115
- }
116
- if (security === 2) {
117
- // The on-chain check is `dispute_window_slots > 0` — i.e. >= 1 slot.
118
- // Zero would let an agent settle and immediately drain pending funds
119
- // before any depositor could possibly file a dispute, defeating the
120
- // entire DisputeWindow security model. Enforce client-side too.
121
- const slots = BigInt(this.bn(args.disputeWindowSlots).toString());
122
- if (slots < 1n) {
123
- throw new Error(
124
- "createEscrowV2: settlementSecurity=2 (DisputeWindow) requires " +
125
- "`disputeWindowSlots >= 1` to prevent the zero-window abuse vector. " +
126
- "Recommended minimum is 2_160 slots (~15 min). On-chain rejects " +
127
- "with InvalidSettlementSecurity.",
128
- );
129
- }
130
- }
131
- if (security !== 0 && security !== 1 && security !== 2) {
132
- throw new Error(
133
- `createEscrowV2: settlementSecurity must be 1 (CoSigned) or 2 (DisputeWindow), got ${String(security)}.`,
134
- );
135
- }
136
-
137
- const [agentPda] = deriveAgent(agentWallet);
138
- const [escrowPda] = this.deriveEscrow(agentPda, undefined, args.escrowNonce);
139
- const [stakePda] = deriveStake(agentPda);
140
- // v0.11 H-1 preflight: surface an actionable error if the agent's stake
141
- // does not cover the slashable share of the new escrow. Saves a failed
142
- // tx fee and gives the caller a clear top-up amount.
143
- try {
144
- const stakeAccount = await this.fetchAccountNullable<{ stakedAmount: BN }>("agentStake", stakePda);
145
- if (stakeAccount) {
146
- const escrowLamports = BigInt(this.bn(args.initialDeposit).toString());
147
- const required = computeRequiredStakeLamports(escrowLamports);
148
- const have = BigInt(stakeAccount.stakedAmount.toString());
149
- if (have < required) {
150
- throw new Error(
151
- `createEscrowV2: agent stake ${have} lamports < required ${required} ` +
152
- `lamports for escrow of ${escrowLamports} lamports. Top up via stakingModule.deposit.`,
153
- );
154
- }
155
- }
156
- // If no stake account exists at all, on-chain will reject with
157
- // AccountNotInitialized — we let that bubble up unchanged.
158
- } catch (err) {
159
- // Preflight is advisory; rethrow only the explicit coverage error.
160
- if (err instanceof Error && err.message.startsWith("createEscrowV2: agent stake")) {
161
- throw err;
162
- }
163
- }
164
- // v0.11 H-1 preflight: surface an actionable error if the agent's stake
165
- // does not cover the slashable share of the new escrow. Saves a failed
166
- // tx fee and gives the caller a clear top-up amount.
167
- try {
168
- const stakeAccount = await this.fetchAccountNullable<{ stakedAmount: BN }>("agentStake", stakePda);
169
- if (stakeAccount) {
170
- const escrowLamports = BigInt(this.bn(args.initialDeposit).toString());
171
- const required = computeRequiredStakeLamports(escrowLamports);
172
- const have = BigInt(stakeAccount.stakedAmount.toString());
173
- if (have < required) {
174
- throw new Error(
175
- `createEscrowV2: agent stake ${have} lamports < required ${required} ` +
176
- `lamports for escrow of ${escrowLamports} lamports. Top up via stakingModule.deposit.`,
177
- );
178
- }
179
- }
180
- // If no stake account exists at all, on-chain will reject with
181
- // AccountNotInitialized — we let that bubble up unchanged.
182
- } catch (err) {
183
- // Preflight is advisory; rethrow only the explicit coverage error.
184
- if (err instanceof Error && err.message.startsWith("createEscrowV2: agent stake")) {
185
- throw err;
186
- }
187
- }
188
-
189
- return this.methods
190
- .createEscrowV2(
191
- this.bn(args.escrowNonce),
192
- this.bn(args.pricePerCall),
193
- this.bn(args.maxCalls),
194
- this.bn(args.initialDeposit),
195
- args.expiresAt,
196
- args.volumeCurve,
197
- args.tokenMint,
198
- args.tokenDecimals,
199
- args.settlementSecurity,
200
- this.bn(args.disputeWindowSlots),
201
- args.coSigner,
202
- args.arbiter,
203
- )
204
- .accounts({
205
- depositor: this.walletPubkey,
206
- agent: agentPda,
207
- agentStake: stakePda,
208
- escrow: escrowPda,
209
- systemProgram: SystemProgram.programId,
210
- })
211
- .remainingAccounts(splAccounts)
212
- .rpc();
213
- }
214
-
215
- async deposit(
216
- agentWallet: PublicKey,
217
- nonce: BN | number | bigint,
218
- amount: BN | number | bigint,
219
- splAccounts: AccountMeta[] = [],
220
- ): Promise<TransactionSignature> {
221
- const [agentPda] = deriveAgent(agentWallet);
222
- const [escrowPda] = this.deriveEscrow(agentPda, undefined, nonce);
223
-
224
- return this.methods
225
- .depositEscrowV2(this.bn(nonce), this.bn(amount))
226
- .accounts({
227
- depositor: this.walletPubkey,
228
- escrow: escrowPda,
229
- systemProgram: SystemProgram.programId,
230
- })
231
- .remainingAccounts(splAccounts)
232
- .rpc();
233
- }
234
-
235
- async settle(
236
- depositorWallet: PublicKey,
237
- nonce: BN | number | bigint,
238
- callsToSettle: BN | number | bigint,
239
- serviceHash: number[],
240
- splAccounts: AccountMeta[] = [],
241
- opts?: SettleOptions,
242
- coSigner?: Signer,
243
- ): Promise<TransactionSignature> {
244
- const [agentPda] = deriveAgent(this.walletPubkey);
245
- const [escrowPda] = this.deriveEscrow(agentPda, depositorWallet, nonce);
246
- const [statsPda] = deriveAgentStats(agentPda);
247
- const [receiptPda] = deriveSettlementReceipt(escrowPda, serviceHash);
248
-
249
- const preIxs = buildPriorityFeeIxs(opts);
250
- const rpcOpts = buildRpcOptions(opts);
251
-
252
- // CoSigned escrows require the co-signer to appear in
253
- // remaining_accounts with `is_signer = true` AND to actually sign
254
- // the transaction (Anchor on-chain checks `acc.is_signer`).
255
- // We dedupe so callers can also pass it manually via splAccounts.
256
- const remaining: AccountMeta[] = coSigner
257
- ? [
258
- ...splAccounts.filter((a) => !a.pubkey.equals(coSigner.publicKey)),
259
- { pubkey: coSigner.publicKey, isSigner: true, isWritable: false },
260
- ]
261
- : splAccounts;
262
-
263
- let builder = this.methods
264
- .settleCallsV2(this.bn(nonce), this.bn(callsToSettle), serviceHash)
265
- .accountsPartial({
266
- wallet: this.walletPubkey,
267
- agent: agentPda,
268
- agentStats: statsPda,
269
- escrow: escrowPda,
270
- settlementReceipt: receiptPda,
271
- systemProgram: SystemProgram.programId,
272
- })
273
- .remainingAccounts(remaining);
274
-
275
- if (coSigner) {
276
- builder = builder.signers([coSigner]);
277
- }
278
-
279
- if (preIxs.length > 0) {
280
- builder = builder.preInstructions(preIxs);
281
- }
282
-
283
- return builder.rpc(rpcOpts);
284
- }
285
-
286
- /**
287
- * Read the current `escrow.settlement_index` from chain.
288
- *
289
- * In DisputeWindow mode (`settlementSecurity = 2`), every successful
290
- * `settleCallsV2` increments this value. The PRE-increment value is the
291
- * one to pass to {@link createPendingSettlement} for that batch.
292
- *
293
- * @returns the current `settlementIndex` as `bigint` (next index to use
294
- * for `createPendingSettlement` if you have NOT yet called `settle` for
295
- * it; if you HAVE just settled, subtract 1 — but prefer the event
296
- * `SettlementPendingEvent.settlement_index` over arithmetic).
297
- * @since v0.12.8
298
- */
299
- async nextSettlementIndex(
300
- agentWallet: PublicKey,
301
- depositorWallet: PublicKey,
302
- nonce: BN | number | bigint,
303
- ): Promise<bigint> {
304
- const [agentPda] = deriveAgent(agentWallet);
305
- const [escrowPda] = this.deriveEscrow(agentPda, depositorWallet, nonce);
306
- const escrow = await this.fetchAccountNullable<EscrowAccountV2Data>(
307
- "escrowAccountV2",
308
- escrowPda,
309
- );
310
- if (!escrow) {
311
- throw new Error(
312
- `nextSettlementIndex: escrow PDA ${escrowPda.toBase58()} not found on-chain`,
313
- );
314
- }
315
- return BigInt(escrow.settlementIndex.toString());
316
- }
317
-
318
- async createPendingSettlement(
319
- agentWallet: PublicKey,
320
- depositorWallet: PublicKey,
321
- nonce: BN | number | bigint,
322
- settlementIndex: BN | number | bigint,
323
- callsToSettle: BN | number | bigint,
324
- amount: BN | number | bigint,
325
- serviceHash: number[],
326
- receiptMerkleRoot: number[] = new Array(32).fill(0),
327
- ): Promise<TransactionSignature> {
328
- const [agentPda] = deriveAgent(agentWallet);
329
- const [escrowPda] = this.deriveEscrow(agentPda, depositorWallet, nonce);
330
- const [pendingPda] = this.derivePendingSettlement(escrowPda, settlementIndex);
331
-
332
- // v0.12.8: preflight against the "Allocate: account already in use"
333
- // SystemProgram error (custom 0x0). The pending_settlement PDA is
334
- // seeded on `escrow + settlement_index`, so reusing the same index
335
- // (e.g. always 0, or a stale retry value) collides with an existing
336
- // account. Fail fast with an actionable message instead of burning a
337
- // failed tx fee on simulation.
338
- const existing = await this.provider.connection.getAccountInfo(pendingPda);
339
- if (existing) {
340
- const idx = this.bn(settlementIndex).toString();
341
- throw new Error(
342
- `createPendingSettlement: pending PDA ${pendingPda.toBase58()} ` +
343
- `already exists for settlementIndex=${idx}. ` +
344
- `Use EscrowV2Module.nextSettlementIndex() to read the current ` +
345
- `escrow.settlement_index, or capture SettlementPendingEvent.settlement_index ` +
346
- `from the preceding settleCallsV2 tx. Reusing a settlementIndex ` +
347
- `causes SystemProgram Allocate (custom 0x0) failures.`,
348
- );
349
- }
350
-
351
- return this.methods
352
- .createPendingSettlement(
353
- this.bn(settlementIndex),
354
- this.bn(callsToSettle),
355
- this.bn(amount),
356
- serviceHash,
357
- receiptMerkleRoot,
358
- )
359
- .accounts({
360
- wallet: this.walletPubkey,
361
- agent: agentPda,
362
- escrow: escrowPda,
363
- pendingSettlement: pendingPda,
364
- systemProgram: SystemProgram.programId,
365
- })
366
- .rpc();
367
- }
368
-
369
- async finalizeSettlement(
370
- agentWallet: PublicKey,
371
- depositorWallet: PublicKey,
372
- nonce: BN | number | bigint,
373
- settlementIndex: BN | number | bigint,
374
- ): Promise<TransactionSignature> {
375
- const [agentPda] = deriveAgent(agentWallet);
376
- const [escrowPda] = this.deriveEscrow(agentPda, depositorWallet, nonce);
377
- const [pendingPda] = this.derivePendingSettlement(escrowPda, settlementIndex);
378
- const [statsPda] = deriveAgentStats(agentPda);
379
-
380
- // v0.12.9: preflight against ArithmeticOverflow at finalize.
381
- //
382
- // The on-chain handler subtracts `pending_settlement.amount` from BOTH
383
- // `escrow.balance` AND `escrow.pending_amount`. If the PendingSettlement
384
- // PDA was created without a preceding `settle_calls_v2` (orphan PDA from
385
- // legacy probe loops, or a buggy caller that skipped the settle step),
386
- // `escrow.pending_amount` is smaller than `pending_settlement.amount`
387
- // and the program aborts with ArithmeticOverflow (error 6075) at
388
- // escrow_v2.rs:633. Each retry burns ~5 000 lamports of base fee.
389
- //
390
- // Detect this BEFORE signing and throw with a clear, actionable message
391
- // pointing at the orphan-recovery path.
392
- const [escrowAcc, pendingAcc] = await Promise.all([
393
- this.fetchAccountNullable<EscrowAccountV2Data>("escrowAccountV2", escrowPda),
394
- this.fetchAccountNullable<PendingSettlementData>("pendingSettlement", pendingPda),
395
- ]);
396
- if (!escrowAcc) {
397
- throw new Error(
398
- `finalizeSettlement: escrow PDA ${escrowPda.toBase58()} not found on-chain.`,
399
- );
400
- }
401
- if (!pendingAcc) {
402
- throw new Error(
403
- `finalizeSettlement: pending PDA ${pendingPda.toBase58()} not found on-chain ` +
404
- `(settlementIndex=${settlementIndex.toString()}). Nothing to finalize.`,
405
- );
406
- }
407
- const psAmount = BigInt(pendingAcc.amount.toString());
408
- const escrowPendingAmount = BigInt(escrowAcc.pendingAmount.toString());
409
- const escrowBalance = BigInt(escrowAcc.balance.toString());
410
- if (psAmount > escrowPendingAmount || psAmount > escrowBalance) {
411
- throw new Error(
412
- `finalizeSettlement: orphan/inconsistent PendingSettlement detected ` +
413
- `at ${pendingPda.toBase58()} (settlementIndex=${settlementIndex.toString()}). ` +
414
- `pending.amount=${psAmount} but escrow.pending_amount=${escrowPendingAmount}, ` +
415
- `escrow.balance=${escrowBalance}. The on-chain finalize would abort with ` +
416
- `ArithmeticOverflow (6075). This PDA was almost certainly created by a ` +
417
- `caller that skipped settle_calls_v2 (legacy probe loop). It cannot be ` +
418
- `finalized and cannot be closed (close_pending_settlement requires ` +
419
- `is_finalized=true). Skip this index permanently in your settle queue.`,
420
- );
421
- }
422
-
423
- return this.methods
424
- .finalizeSettlement()
425
- .accounts({
426
- payer: this.walletPubkey,
427
- agentWallet,
428
- escrow: escrowPda,
429
- pendingSettlement: pendingPda,
430
- agentStats: statsPda,
431
- })
432
- .rpc();
433
- }
434
-
435
- /**
436
- * Identify orphan PendingSettlement PDAs that cannot be finalized.
437
- *
438
- * @returns `null` if the PDA is finalizable (or already finalized / disputed).
439
- * Otherwise an object describing the inconsistency, suitable for
440
- * logging or feeding into a quarantine list. Use this from a
441
- * recovery script to scan a range of `settlement_index` values:
442
- *
443
- * ```ts
444
- * for (let idx = 0n; idx < currentIdx; idx++) {
445
- * const orphan = await sap.escrowV2.diagnoseOrphanPending(
446
- * agentWallet, depositorWallet, nonce, idx,
447
- * );
448
- * if (orphan) log.warn({ idx, ...orphan }, "skip orphan");
449
- * }
450
- * ```
451
- *
452
- * @since v0.12.9
453
- */
454
- async diagnoseOrphanPending(
455
- agentWallet: PublicKey,
456
- depositorWallet: PublicKey,
457
- nonce: BN | number | bigint,
458
- settlementIndex: BN | number | bigint,
459
- ): Promise<{
460
- pendingPda: PublicKey;
461
- psAmount: bigint;
462
- escrowPendingAmount: bigint;
463
- escrowBalance: bigint;
464
- isFinalized: boolean;
465
- isDisputed: boolean;
466
- reason: "ok" | "missing" | "amount_exceeds_pending" | "amount_exceeds_balance" | "already_finalized" | "disputed";
467
- } | null> {
468
- const [agentPda] = deriveAgent(agentWallet);
469
- const [escrowPda] = this.deriveEscrow(agentPda, depositorWallet, nonce);
470
- const [pendingPda] = this.derivePendingSettlement(escrowPda, settlementIndex);
471
- const [escrowAcc, pendingAcc] = await Promise.all([
472
- this.fetchAccountNullable<EscrowAccountV2Data>("escrowAccountV2", escrowPda),
473
- this.fetchAccountNullable<PendingSettlementData>("pendingSettlement", pendingPda),
474
- ]);
475
- if (!escrowAcc) return null;
476
- if (!pendingAcc) {
477
- return {
478
- pendingPda,
479
- psAmount: 0n,
480
- escrowPendingAmount: BigInt(escrowAcc.pendingAmount.toString()),
481
- escrowBalance: BigInt(escrowAcc.balance.toString()),
482
- isFinalized: false,
483
- isDisputed: false,
484
- reason: "missing",
485
- };
486
- }
487
- const psAmount = BigInt(pendingAcc.amount.toString());
488
- const escrowPendingAmount = BigInt(escrowAcc.pendingAmount.toString());
489
- const escrowBalance = BigInt(escrowAcc.balance.toString());
490
- const base = {
491
- pendingPda,
492
- psAmount,
493
- escrowPendingAmount,
494
- escrowBalance,
495
- isFinalized: pendingAcc.isFinalized,
496
- isDisputed: pendingAcc.isDisputed,
497
- };
498
- if (pendingAcc.isFinalized) return { ...base, reason: "already_finalized" };
499
- if (pendingAcc.isDisputed) return { ...base, reason: "disputed" };
500
- if (psAmount > escrowPendingAmount) return { ...base, reason: "amount_exceeds_pending" };
501
- if (psAmount > escrowBalance) return { ...base, reason: "amount_exceeds_balance" };
502
- return null;
503
- }
504
-
505
- async fileDispute(
506
- agentWallet: PublicKey,
507
- nonce: BN | number | bigint,
508
- settlementIndex: BN | number | bigint,
509
- evidenceHash: number[],
510
- disputeType: number = 0,
511
- ): Promise<TransactionSignature> {
512
- const [agentPda] = deriveAgent(agentWallet);
513
- const [escrowPda] = this.deriveEscrow(agentPda, undefined, nonce);
514
- const [pendingPda] = this.derivePendingSettlement(escrowPda, settlementIndex);
515
- const [disputePda] = this.deriveDispute(pendingPda);
516
-
517
- return this.methods
518
- .fileDispute(evidenceHash, disputeType)
519
- .accounts({
520
- depositor: this.walletPubkey,
521
- escrow: escrowPda,
522
- pendingSettlement: pendingPda,
523
- dispute: disputePda,
524
- systemProgram: SystemProgram.programId,
525
- })
526
- .rpc();
527
- }
528
-
529
- /**
530
- * @deprecated Since v0.7.0 — Arbiter-based resolution removed.
531
- * Use {@link ReceiptModule.submitReceiptProof} + {@link ReceiptModule.autoResolveDispute} instead.
532
- */
533
- async resolveDispute(
534
- _depositorWallet: PublicKey,
535
- _agentWallet: PublicKey,
536
- _nonce: BN | number | bigint,
537
- _settlementIndex: BN | number | bigint,
538
- _outcome: number,
539
- ): Promise<TransactionSignature> {
540
- throw new Error("resolveDispute removed in v0.7.0 — use ReceiptModule.autoResolveDispute");
541
- }
542
-
543
- async closeDispute(
544
- pendingSettlementPda: PublicKey,
545
- ): Promise<TransactionSignature> {
546
- const [disputePda] = this.deriveDispute(pendingSettlementPda);
547
-
548
- return this.methods
549
- .closeDispute()
550
- .accounts({
551
- depositor: this.walletPubkey,
552
- dispute: disputePda,
553
- })
554
- .rpc();
555
- }
556
-
557
- async closePendingSettlement(
558
- pendingSettlementPda: PublicKey,
559
- ): Promise<TransactionSignature> {
560
- return this.methods
561
- .closePendingSettlement()
562
- .accounts({
563
- payer: this.walletPubkey,
564
- pendingSettlement: pendingSettlementPda,
565
- })
566
- .rpc();
567
- }
568
-
569
- async withdraw(
570
- agentWallet: PublicKey,
571
- nonce: BN | number | bigint,
572
- amount: BN | number | bigint,
573
- ): Promise<TransactionSignature> {
574
- const [agentPda] = deriveAgent(agentWallet);
575
- const [escrowPda] = this.deriveEscrow(agentPda, undefined, nonce);
576
-
577
- return this.methods
578
- .withdrawEscrowV2(this.bn(amount))
579
- .accounts({
580
- depositor: this.walletPubkey,
581
- escrow: escrowPda,
582
- })
583
- .rpc();
584
- }
585
-
586
- async close(
587
- agentWallet: PublicKey,
588
- nonce: BN | number | bigint = 0,
589
- ): Promise<TransactionSignature> {
590
- const [agentPda] = deriveAgent(agentWallet);
591
- const [escrowPda] = this.deriveEscrow(agentPda, undefined, nonce);
592
-
593
- return this.methods
594
- .closeEscrowV2()
595
- .accounts({
596
- depositor: this.walletPubkey,
597
- escrow: escrowPda,
598
- })
599
- .rpc();
600
- }
601
-
602
- /**
603
- * @deprecated Since v0.7.0 — Migration instruction removed from program.
604
- */
605
- async migrateFromV1(
606
- _agentWallet: PublicKey,
607
- ): Promise<TransactionSignature> {
608
- throw new Error("migrateFromV1 removed in v0.7.0 — migration instruction was deleted");
609
- }
610
-
611
- // ── Fetchers ─────────────────────────────────────────
612
-
613
- async fetch(
614
- agentPda: PublicKey,
615
- depositor?: PublicKey,
616
- nonce: BN | number | bigint = 0,
617
- ): Promise<EscrowAccountV2Data> {
618
- const [pda] = this.deriveEscrow(agentPda, depositor, nonce);
619
- return this.fetchAccount<EscrowAccountV2Data>("escrowAccountV2", pda);
620
- }
621
-
622
- async fetchNullable(
623
- agentPda: PublicKey,
624
- depositor?: PublicKey,
625
- nonce: BN | number | bigint = 0,
626
- ): Promise<EscrowAccountV2Data | null> {
627
- const [pda] = this.deriveEscrow(agentPda, depositor, nonce);
628
- return this.fetchAccountNullable<EscrowAccountV2Data>("escrowAccountV2", pda);
629
- }
630
-
631
- async fetchByPda(escrowPda: PublicKey): Promise<EscrowAccountV2Data> {
632
- return this.fetchAccount<EscrowAccountV2Data>("escrowAccountV2", escrowPda);
633
- }
634
-
635
- async fetchPendingSettlement(
636
- pendingPda: PublicKey,
637
- ): Promise<PendingSettlementData> {
638
- return this.fetchAccount<PendingSettlementData>("pendingSettlement", pendingPda);
639
- }
640
-
641
- async fetchPendingSettlementNullable(
642
- pendingPda: PublicKey,
643
- ): Promise<PendingSettlementData | null> {
644
- return this.fetchAccountNullable<PendingSettlementData>("pendingSettlement", pendingPda);
645
- }
646
-
647
- async fetchDispute(
648
- disputePda: PublicKey,
649
- ): Promise<DisputeRecordData> {
650
- return this.fetchAccount<DisputeRecordData>("disputeRecord", disputePda);
651
- }
652
-
653
- async fetchDisputeNullable(
654
- disputePda: PublicKey,
655
- ): Promise<DisputeRecordData | null> {
656
- return this.fetchAccountNullable<DisputeRecordData>("disputeRecord", disputePda);
657
- }
658
- }