@oobe-protocol-labs/synapse-sap-sdk 0.13.0 → 0.15.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (418) 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 +125 -0
  4. package/dist/cjs/client.js.map +1 -0
  5. package/dist/cjs/constants/seeds.js +9 -9
  6. package/dist/cjs/constants/seeds.js.map +1 -1
  7. package/dist/cjs/constants.js +66 -0
  8. package/dist/cjs/constants.js.map +1 -0
  9. package/dist/cjs/errors.js +260 -0
  10. package/dist/cjs/errors.js.map +1 -0
  11. package/dist/cjs/events/index.js +37 -123
  12. package/dist/cjs/events/index.js.map +1 -1
  13. package/dist/cjs/idlTypes.js +4 -0
  14. package/dist/cjs/idlTypes.js.map +1 -0
  15. package/dist/cjs/index.js +75 -241
  16. package/dist/cjs/index.js.map +1 -1
  17. package/dist/cjs/instructions/agent.js +90 -0
  18. package/dist/cjs/instructions/agent.js.map +1 -0
  19. package/dist/cjs/instructions/attestation.js +113 -0
  20. package/dist/cjs/instructions/attestation.js.map +1 -0
  21. package/dist/cjs/instructions/digest.js +29 -0
  22. package/dist/cjs/instructions/digest.js.map +1 -0
  23. package/dist/cjs/instructions/dispute.js +117 -0
  24. package/dist/cjs/instructions/dispute.js.map +1 -0
  25. package/dist/cjs/instructions/escrow.js +102 -0
  26. package/dist/cjs/instructions/escrow.js.map +1 -0
  27. package/dist/cjs/instructions/global.js +29 -0
  28. package/dist/cjs/instructions/global.js.map +1 -0
  29. package/dist/cjs/instructions/index.js +31 -0
  30. package/dist/cjs/instructions/index.js.map +1 -0
  31. package/dist/cjs/instructions/indexing.js +222 -0
  32. package/dist/cjs/instructions/indexing.js.map +1 -0
  33. package/dist/cjs/instructions/misc.js +74 -0
  34. package/dist/cjs/instructions/misc.js.map +1 -0
  35. package/dist/cjs/instructions/session.js +90 -0
  36. package/dist/cjs/instructions/session.js.map +1 -0
  37. package/dist/cjs/instructions/staking.js +133 -0
  38. package/dist/cjs/instructions/staking.js.map +1 -0
  39. package/dist/cjs/instructions/subscription.js +81 -0
  40. package/dist/cjs/instructions/subscription.js.map +1 -0
  41. package/dist/cjs/instructions/tools.js +110 -0
  42. package/dist/cjs/instructions/tools.js.map +1 -0
  43. package/dist/cjs/instructions/vault.js +107 -0
  44. package/dist/cjs/instructions/vault.js.map +1 -0
  45. package/dist/cjs/pdas/index.js +120 -0
  46. package/dist/cjs/pdas/index.js.map +1 -0
  47. package/dist/cjs/registries/fairscale.js +1 -1
  48. package/dist/cjs/registries/fairscale.js.map +1 -1
  49. package/dist/cjs/registries/metaplex-bridge.js +1 -1
  50. package/dist/cjs/registries/metaplex-bridge.js.map +1 -1
  51. package/dist/cjs/types.js +45 -0
  52. package/dist/cjs/types.js.map +1 -0
  53. package/dist/cjs/utils/escrow-validation.js +1 -1
  54. package/dist/cjs/utils/escrow-validation.js.map +1 -1
  55. package/dist/cjs/utils/index.js +32 -83
  56. package/dist/cjs/utils/index.js.map +1 -1
  57. package/dist/cjs/utils/merchant-validator.js +5 -5
  58. package/dist/cjs/utils/merchant-validator.js.map +1 -1
  59. package/dist/cjs/utils/validate.js +236 -0
  60. package/dist/cjs/utils/validate.js.map +1 -0
  61. package/dist/cjs/utils/volume-curve.js +1 -1
  62. package/dist/cjs/utils/volume-curve.js.map +1 -1
  63. package/dist/esm/accounts/index.d.ts +11 -0
  64. package/dist/esm/accounts/index.d.ts.map +1 -0
  65. package/dist/esm/accounts/index.js +273 -0
  66. package/dist/esm/accounts/index.js.map +1 -0
  67. package/dist/esm/client.d.ts +55 -0
  68. package/dist/esm/client.d.ts.map +1 -0
  69. package/dist/esm/client.js +87 -0
  70. package/dist/esm/client.js.map +1 -0
  71. package/dist/esm/constants/addresses.d.ts +117 -0
  72. package/dist/esm/constants/addresses.d.ts.map +1 -0
  73. package/dist/esm/constants/index.d.ts +31 -0
  74. package/dist/esm/constants/index.d.ts.map +1 -0
  75. package/dist/esm/constants/limits.d.ts +149 -0
  76. package/dist/esm/constants/limits.d.ts.map +1 -0
  77. package/{src/constants/network.ts → dist/esm/constants/network.d.ts} +23 -31
  78. package/dist/esm/constants/network.d.ts.map +1 -0
  79. package/{src/constants/payments.ts → dist/esm/constants/payments.d.ts} +11 -35
  80. package/dist/esm/constants/payments.d.ts.map +1 -0
  81. package/{src/constants/programs.ts → dist/esm/constants/programs.d.ts} +6 -20
  82. package/dist/esm/constants/programs.d.ts.map +1 -0
  83. package/dist/esm/constants/seeds.d.ts +80 -0
  84. package/dist/esm/constants/seeds.d.ts.map +1 -0
  85. package/dist/esm/constants/seeds.js +9 -9
  86. package/dist/esm/constants/seeds.js.map +1 -1
  87. package/dist/esm/constants.d.ts +39 -0
  88. package/dist/esm/constants.d.ts.map +1 -0
  89. package/dist/esm/constants.js +41 -0
  90. package/dist/esm/constants.js.map +1 -0
  91. package/dist/esm/core/client.d.ts +452 -0
  92. package/dist/esm/core/client.d.ts.map +1 -0
  93. package/dist/esm/core/connection.d.ts +305 -0
  94. package/dist/esm/core/connection.d.ts.map +1 -0
  95. package/{src/core/index.ts → dist/esm/core/index.d.ts} +1 -1
  96. package/dist/esm/core/index.d.ts.map +1 -0
  97. package/dist/esm/errors/index.d.ts +276 -0
  98. package/dist/esm/errors/index.d.ts.map +1 -0
  99. package/dist/esm/errors.d.ts +119 -0
  100. package/dist/esm/errors.d.ts.map +1 -0
  101. package/dist/esm/errors.js +252 -0
  102. package/dist/esm/errors.js.map +1 -0
  103. package/dist/esm/events/geyser.d.ts +150 -0
  104. package/dist/esm/events/geyser.d.ts.map +1 -0
  105. package/dist/esm/events/index.d.ts +17 -0
  106. package/dist/esm/events/index.d.ts.map +1 -0
  107. package/dist/esm/events/index.js +34 -122
  108. package/dist/esm/events/index.js.map +1 -1
  109. package/{src/idl/index.ts → dist/esm/idl/index.d.ts} +9 -15
  110. package/dist/esm/idl/index.d.ts.map +1 -0
  111. package/dist/esm/idlTypes.d.ts +925 -0
  112. package/dist/esm/idlTypes.d.ts.map +1 -0
  113. package/dist/esm/idlTypes.js +3 -0
  114. package/dist/esm/idlTypes.js.map +1 -0
  115. package/dist/esm/index.d.ts +12 -0
  116. package/dist/esm/index.d.ts.map +1 -0
  117. package/dist/esm/index.js +15 -88
  118. package/dist/esm/index.js.map +1 -1
  119. package/dist/esm/instructions/agent.d.ts +71 -0
  120. package/dist/esm/instructions/agent.d.ts.map +1 -0
  121. package/dist/esm/instructions/agent.js +86 -0
  122. package/dist/esm/instructions/agent.js.map +1 -0
  123. package/dist/esm/instructions/attestation.d.ts +76 -0
  124. package/dist/esm/instructions/attestation.d.ts.map +1 -0
  125. package/dist/esm/instructions/attestation.js +109 -0
  126. package/dist/esm/instructions/attestation.js.map +1 -0
  127. package/dist/esm/instructions/digest.d.ts +20 -0
  128. package/dist/esm/instructions/digest.d.ts.map +1 -0
  129. package/dist/esm/instructions/digest.js +25 -0
  130. package/dist/esm/instructions/digest.js.map +1 -0
  131. package/dist/esm/instructions/dispute.d.ts +81 -0
  132. package/dist/esm/instructions/dispute.d.ts.map +1 -0
  133. package/dist/esm/instructions/dispute.js +113 -0
  134. package/dist/esm/instructions/dispute.js.map +1 -0
  135. package/dist/esm/instructions/escrow.d.ts +79 -0
  136. package/dist/esm/instructions/escrow.d.ts.map +1 -0
  137. package/dist/esm/instructions/escrow.js +98 -0
  138. package/dist/esm/instructions/escrow.js.map +1 -0
  139. package/dist/esm/instructions/global.d.ts +14 -0
  140. package/dist/esm/instructions/global.d.ts.map +1 -0
  141. package/dist/esm/instructions/global.js +25 -0
  142. package/dist/esm/instructions/global.js.map +1 -0
  143. package/dist/esm/instructions/index.d.ts +14 -0
  144. package/dist/esm/instructions/index.d.ts.map +1 -0
  145. package/dist/esm/instructions/index.js +15 -0
  146. package/dist/esm/instructions/index.js.map +1 -0
  147. package/dist/esm/instructions/indexing.d.ts +150 -0
  148. package/dist/esm/instructions/indexing.d.ts.map +1 -0
  149. package/dist/esm/instructions/indexing.js +218 -0
  150. package/dist/esm/instructions/indexing.js.map +1 -0
  151. package/dist/esm/instructions/memory.d.ts +8 -0
  152. package/dist/esm/instructions/memory.d.ts.map +1 -0
  153. package/dist/esm/instructions/memory.js +234 -0
  154. package/dist/esm/instructions/memory.js.map +1 -0
  155. package/dist/esm/instructions/misc.d.ts +50 -0
  156. package/dist/esm/instructions/misc.d.ts.map +1 -0
  157. package/dist/esm/instructions/misc.js +70 -0
  158. package/dist/esm/instructions/misc.js.map +1 -0
  159. package/dist/esm/instructions/session.d.ts +57 -0
  160. package/dist/esm/instructions/session.d.ts.map +1 -0
  161. package/dist/esm/instructions/session.js +86 -0
  162. package/dist/esm/instructions/session.js.map +1 -0
  163. package/dist/esm/instructions/staking.d.ts +85 -0
  164. package/dist/esm/instructions/staking.d.ts.map +1 -0
  165. package/dist/esm/instructions/staking.js +129 -0
  166. package/dist/esm/instructions/staking.js.map +1 -0
  167. package/dist/esm/instructions/subscription.d.ts +50 -0
  168. package/dist/esm/instructions/subscription.d.ts.map +1 -0
  169. package/dist/esm/instructions/subscription.js +77 -0
  170. package/dist/esm/instructions/subscription.js.map +1 -0
  171. package/dist/esm/instructions/tools.d.ts +88 -0
  172. package/dist/esm/instructions/tools.d.ts.map +1 -0
  173. package/dist/esm/instructions/tools.js +106 -0
  174. package/dist/esm/instructions/tools.js.map +1 -0
  175. package/dist/esm/instructions/vault.d.ts +84 -0
  176. package/dist/esm/instructions/vault.d.ts.map +1 -0
  177. package/dist/esm/instructions/vault.js +103 -0
  178. package/dist/esm/instructions/vault.js.map +1 -0
  179. package/dist/esm/modules/agent.d.ts +166 -0
  180. package/dist/esm/modules/agent.d.ts.map +1 -0
  181. package/dist/esm/modules/attestation.d.ts +96 -0
  182. package/dist/esm/modules/attestation.d.ts.map +1 -0
  183. package/dist/esm/modules/base.d.ts +161 -0
  184. package/dist/esm/modules/base.d.ts.map +1 -0
  185. package/dist/esm/modules/escrow-v2.d.ts +169 -0
  186. package/dist/esm/modules/escrow-v2.d.ts.map +1 -0
  187. package/dist/esm/modules/feedback.d.ts +105 -0
  188. package/dist/esm/modules/feedback.d.ts.map +1 -0
  189. package/{src/modules/index.ts → dist/esm/modules/index.d.ts} +1 -1
  190. package/dist/esm/modules/index.d.ts.map +1 -0
  191. package/dist/esm/modules/indexing.d.ts +200 -0
  192. package/dist/esm/modules/indexing.d.ts.map +1 -0
  193. package/dist/esm/modules/ledger.d.ts +150 -0
  194. package/dist/esm/modules/ledger.d.ts.map +1 -0
  195. package/dist/esm/modules/receipt.d.ts +77 -0
  196. package/dist/esm/modules/receipt.d.ts.map +1 -0
  197. package/dist/esm/modules/staking.d.ts +51 -0
  198. package/dist/esm/modules/staking.d.ts.map +1 -0
  199. package/dist/esm/modules/subscription.d.ts +33 -0
  200. package/dist/esm/modules/subscription.d.ts.map +1 -0
  201. package/dist/esm/modules/tools.d.ts +182 -0
  202. package/dist/esm/modules/tools.d.ts.map +1 -0
  203. package/dist/esm/modules/vault.d.ts +240 -0
  204. package/dist/esm/modules/vault.d.ts.map +1 -0
  205. package/dist/esm/parser/client.d.ts +123 -0
  206. package/dist/esm/parser/client.d.ts.map +1 -0
  207. package/dist/esm/parser/complete.d.ts +90 -0
  208. package/dist/esm/parser/complete.d.ts.map +1 -0
  209. package/{src/parser/index.ts → dist/esm/parser/index.d.ts} +6 -37
  210. package/dist/esm/parser/index.d.ts.map +1 -0
  211. package/dist/esm/parser/inner.d.ts +114 -0
  212. package/dist/esm/parser/inner.d.ts.map +1 -0
  213. package/{src/parser/instructions.ts → dist/esm/parser/instructions.d.ts} +4 -63
  214. package/dist/esm/parser/instructions.d.ts.map +1 -0
  215. package/dist/esm/parser/transaction.d.ts +77 -0
  216. package/dist/esm/parser/transaction.d.ts.map +1 -0
  217. package/dist/esm/parser/types.d.ts +154 -0
  218. package/dist/esm/parser/types.d.ts.map +1 -0
  219. package/{src/pda/index.ts → dist/esm/pda/index.d.ts} +33 -442
  220. package/dist/esm/pda/index.d.ts.map +1 -0
  221. package/dist/esm/pdas/index.d.ts +37 -0
  222. package/dist/esm/pdas/index.d.ts.map +1 -0
  223. package/dist/esm/pdas/index.js +101 -0
  224. package/dist/esm/pdas/index.js.map +1 -0
  225. package/dist/esm/plugin/index.d.ts +171 -0
  226. package/dist/esm/plugin/index.d.ts.map +1 -0
  227. package/dist/esm/plugin/protocols.d.ts +152 -0
  228. package/dist/esm/plugin/protocols.d.ts.map +1 -0
  229. package/dist/esm/plugin/schemas.d.ts +829 -0
  230. package/dist/esm/plugin/schemas.d.ts.map +1 -0
  231. package/dist/esm/postgres/adapter.d.ts +355 -0
  232. package/dist/esm/postgres/adapter.d.ts.map +1 -0
  233. package/dist/esm/postgres/index.d.ts +24 -0
  234. package/dist/esm/postgres/index.d.ts.map +1 -0
  235. package/dist/esm/postgres/serializers.d.ts +30 -0
  236. package/dist/esm/postgres/serializers.d.ts.map +1 -0
  237. package/dist/esm/postgres/sync.d.ts +156 -0
  238. package/dist/esm/postgres/sync.d.ts.map +1 -0
  239. package/dist/esm/postgres/types.d.ts +167 -0
  240. package/dist/esm/postgres/types.d.ts.map +1 -0
  241. package/dist/esm/registries/builder.d.ts +340 -0
  242. package/dist/esm/registries/builder.d.ts.map +1 -0
  243. package/dist/esm/registries/discovery.d.ts +333 -0
  244. package/dist/esm/registries/discovery.d.ts.map +1 -0
  245. package/dist/esm/registries/fairscale.d.ts +680 -0
  246. package/dist/esm/registries/fairscale.d.ts.map +1 -0
  247. package/dist/esm/registries/fairscale.js +1 -1
  248. package/dist/esm/registries/fairscale.js.map +1 -1
  249. package/dist/esm/registries/index.d.ts +52 -0
  250. package/dist/esm/registries/index.d.ts.map +1 -0
  251. package/dist/esm/registries/metaplex-bridge.d.ts +489 -0
  252. package/dist/esm/registries/metaplex-bridge.d.ts.map +1 -0
  253. package/dist/esm/registries/metaplex-bridge.js +1 -1
  254. package/dist/esm/registries/metaplex-bridge.js.map +1 -1
  255. package/dist/esm/registries/session.d.ts +323 -0
  256. package/dist/esm/registries/session.d.ts.map +1 -0
  257. package/dist/esm/registries/x402.d.ts +530 -0
  258. package/dist/esm/registries/x402.d.ts.map +1 -0
  259. package/dist/esm/types/accounts.d.ts +765 -0
  260. package/dist/esm/types/accounts.d.ts.map +1 -0
  261. package/dist/esm/types/common.d.ts +166 -0
  262. package/dist/esm/types/common.d.ts.map +1 -0
  263. package/dist/esm/types/endpoint.d.ts +161 -0
  264. package/dist/esm/types/endpoint.d.ts.map +1 -0
  265. package/dist/esm/types/enums.d.ts +353 -0
  266. package/dist/esm/types/enums.d.ts.map +1 -0
  267. package/dist/esm/types/index.d.ts +29 -0
  268. package/dist/esm/types/index.d.ts.map +1 -0
  269. package/dist/esm/types/instructions.d.ts +400 -0
  270. package/dist/esm/types/instructions.d.ts.map +1 -0
  271. package/dist/esm/types.d.ts +236 -0
  272. package/dist/esm/types.d.ts.map +1 -0
  273. package/dist/esm/types.js +40 -0
  274. package/dist/esm/types.js.map +1 -0
  275. package/dist/esm/utils/anchor-errors.d.ts +61 -0
  276. package/dist/esm/utils/anchor-errors.d.ts.map +1 -0
  277. package/dist/esm/utils/endpoint-validator.d.ts +110 -0
  278. package/dist/esm/utils/endpoint-validator.d.ts.map +1 -0
  279. package/dist/esm/utils/escrow-validation.d.ts +145 -0
  280. package/dist/esm/utils/escrow-validation.d.ts.map +1 -0
  281. package/dist/esm/utils/escrow-validation.js +1 -1
  282. package/dist/esm/utils/escrow-validation.js.map +1 -1
  283. package/{src/utils/hash.ts → dist/esm/utils/hash.d.ts} +4 -42
  284. package/dist/esm/utils/hash.d.ts.map +1 -0
  285. package/dist/esm/utils/index.d.ts +6 -0
  286. package/dist/esm/utils/index.d.ts.map +1 -0
  287. package/dist/esm/utils/index.js +16 -33
  288. package/dist/esm/utils/index.js.map +1 -1
  289. package/dist/esm/utils/merchant-validator.d.ts +176 -0
  290. package/dist/esm/utils/merchant-validator.d.ts.map +1 -0
  291. package/dist/esm/utils/merchant-validator.js +1 -1
  292. package/dist/esm/utils/merchant-validator.js.map +1 -1
  293. package/dist/esm/utils/network-normalizer.d.ts +120 -0
  294. package/dist/esm/utils/network-normalizer.d.ts.map +1 -0
  295. package/dist/esm/utils/priority-fee.d.ts +205 -0
  296. package/dist/esm/utils/priority-fee.d.ts.map +1 -0
  297. package/dist/esm/utils/rpc-strategy.d.ts +172 -0
  298. package/dist/esm/utils/rpc-strategy.d.ts.map +1 -0
  299. package/dist/esm/utils/schemas.d.ts +351 -0
  300. package/dist/esm/utils/schemas.d.ts.map +1 -0
  301. package/{src/utils/serialization.ts → dist/esm/utils/serialization.d.ts} +3 -32
  302. package/dist/esm/utils/serialization.d.ts.map +1 -0
  303. package/dist/esm/utils/validate.d.ts +66 -0
  304. package/dist/esm/utils/validate.d.ts.map +1 -0
  305. package/dist/esm/utils/validate.js +221 -0
  306. package/dist/esm/utils/validate.js.map +1 -0
  307. package/{src/utils/validation.ts → dist/esm/utils/validation.d.ts} +2 -9
  308. package/dist/esm/utils/validation.d.ts.map +1 -0
  309. package/{src/utils/volume-curve.ts → dist/esm/utils/volume-curve.d.ts} +2 -73
  310. package/dist/esm/utils/volume-curve.d.ts.map +1 -0
  311. package/dist/esm/utils/volume-curve.js +1 -1
  312. package/dist/esm/utils/volume-curve.js.map +1 -1
  313. package/dist/esm/utils/x402-direct.d.ts +114 -0
  314. package/dist/esm/utils/x402-direct.d.ts.map +1 -0
  315. package/dist/types/constants/seeds.d.ts +2 -0
  316. package/dist/types/constants/seeds.d.ts.map +1 -1
  317. package/dist/types/core/client.d.ts +21 -6
  318. package/dist/types/core/client.d.ts.map +1 -1
  319. package/dist/types/errors/index.d.ts +59 -0
  320. package/dist/types/errors/index.d.ts.map +1 -1
  321. package/dist/types/index.d.ts +3 -2
  322. package/dist/types/index.d.ts.map +1 -1
  323. package/dist/types/modules/agent.d.ts +9 -19
  324. package/dist/types/modules/agent.d.ts.map +1 -1
  325. package/dist/types/modules/attestation.d.ts.map +1 -1
  326. package/dist/types/modules/base.d.ts +54 -0
  327. package/dist/types/modules/base.d.ts.map +1 -1
  328. package/dist/types/modules/escrow-v2.d.ts +117 -1
  329. package/dist/types/modules/escrow-v2.d.ts.map +1 -1
  330. package/dist/types/modules/index.d.ts +1 -2
  331. package/dist/types/modules/index.d.ts.map +1 -1
  332. package/dist/types/modules/receipt.d.ts +14 -0
  333. package/dist/types/modules/receipt.d.ts.map +1 -1
  334. package/dist/types/modules/subscription.d.ts.map +1 -1
  335. package/dist/types/modules/tools.d.ts +0 -10
  336. package/dist/types/modules/tools.d.ts.map +1 -1
  337. package/dist/types/modules/vault.d.ts.map +1 -1
  338. package/dist/types/pda/index.d.ts +17 -0
  339. package/dist/types/pda/index.d.ts.map +1 -1
  340. package/dist/types/plugin/index.d.ts.map +1 -1
  341. package/dist/types/registries/builder.d.ts +2 -9
  342. package/dist/types/registries/builder.d.ts.map +1 -1
  343. package/dist/types/registries/metaplex-bridge.d.ts.map +1 -1
  344. package/dist/types/registries/session.d.ts +3 -9
  345. package/dist/types/registries/session.d.ts.map +1 -1
  346. package/dist/types/registries/x402.d.ts +2 -9
  347. package/dist/types/registries/x402.d.ts.map +1 -1
  348. package/dist/types/types/accounts.d.ts +52 -0
  349. package/dist/types/types/accounts.d.ts.map +1 -1
  350. package/dist/types/types/index.d.ts +1 -1
  351. package/dist/types/types/index.d.ts.map +1 -1
  352. package/dist/types/utils/rpc-strategy.d.ts +7 -0
  353. package/dist/types/utils/rpc-strategy.d.ts.map +1 -1
  354. package/package.json +59 -183
  355. package/src/constants/addresses.ts +0 -162
  356. package/src/constants/index.ts +0 -69
  357. package/src/constants/limits.ts +0 -165
  358. package/src/constants/seeds.ts +0 -85
  359. package/src/core/client.ts +0 -583
  360. package/src/core/connection.ts +0 -461
  361. package/src/errors/index.ts +0 -346
  362. package/src/events/geyser.ts +0 -384
  363. package/src/events/index.ts +0 -335
  364. package/src/events/yellowstone.d.ts +0 -7
  365. package/src/idl/synapse_agent_sap.json +0 -14595
  366. package/src/index.ts +0 -421
  367. package/src/modules/agent.ts +0 -319
  368. package/src/modules/attestation.ts +0 -168
  369. package/src/modules/base.ts +0 -247
  370. package/src/modules/escrow-v2.ts +0 -871
  371. package/src/modules/escrow.ts +0 -439
  372. package/src/modules/feedback.ts +0 -186
  373. package/src/modules/indexing.ts +0 -444
  374. package/src/modules/ledger.ts +0 -262
  375. package/src/modules/receipt.ts +0 -212
  376. package/src/modules/staking.ts +0 -223
  377. package/src/modules/subscription.ts +0 -147
  378. package/src/modules/tools.ts +0 -454
  379. package/src/modules/vault.ts +0 -558
  380. package/src/parser/client.ts +0 -211
  381. package/src/parser/complete.ts +0 -232
  382. package/src/parser/inner.ts +0 -255
  383. package/src/parser/transaction.ts +0 -200
  384. package/src/parser/types.ts +0 -182
  385. package/src/plugin/index.ts +0 -1224
  386. package/src/plugin/protocols.ts +0 -404
  387. package/src/plugin/schemas.ts +0 -941
  388. package/src/postgres/adapter.ts +0 -904
  389. package/src/postgres/index.ts +0 -59
  390. package/src/postgres/schema.sql +0 -683
  391. package/src/postgres/serializers.ts +0 -485
  392. package/src/postgres/sync.ts +0 -340
  393. package/src/postgres/types.ts +0 -245
  394. package/src/registries/builder.ts +0 -607
  395. package/src/registries/discovery.ts +0 -572
  396. package/src/registries/fairscale.ts +0 -1278
  397. package/src/registries/index.ts +0 -143
  398. package/src/registries/metaplex-bridge.ts +0 -1199
  399. package/src/registries/session.ts +0 -613
  400. package/src/registries/x402.ts +0 -1048
  401. package/src/types/accounts.ts +0 -858
  402. package/src/types/common.ts +0 -187
  403. package/src/types/endpoint.ts +0 -181
  404. package/src/types/enums.ts +0 -333
  405. package/src/types/index.ts +0 -121
  406. package/src/types/instructions.ts +0 -453
  407. package/src/utils/anchor-errors.ts +0 -461
  408. package/src/utils/endpoint-validator.ts +0 -300
  409. package/src/utils/escrow-validation.ts +0 -301
  410. package/src/utils/index.ts +0 -118
  411. package/src/utils/merchant-validator.ts +0 -359
  412. package/src/utils/network-normalizer.ts +0 -240
  413. package/src/utils/priority-fee.ts +0 -325
  414. package/src/utils/rpc-strategy.ts +0 -322
  415. package/src/utils/schemas.ts +0 -359
  416. package/src/utils/x402-direct.ts +0 -370
  417. /package/dist/{types → esm}/modules/escrow.d.ts +0 -0
  418. /package/dist/{types → esm}/modules/escrow.d.ts.map +0 -0
@@ -1,871 +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
- import { throwPredicted } from "../utils/anchor-errors";
43
- import { calculateSettleAmount } from "../utils/volume-curve";
44
-
45
- /**
46
- * @name EscrowV2Module
47
- * @description Manages V2 escrow accounts with settlement security modes,
48
- * dispute windows, and pending settlement flows.
49
- *
50
- * @category Modules
51
- * @since v0.7.0
52
- * @extends BaseModule
53
- */
54
- export class EscrowV2Module extends BaseModule {
55
- // ── Helpers ──────────────────────────────────────────
56
-
57
- /** Convert BN | number | bigint → number for PDA seed functions. */
58
- private toNum(v: BN | number | bigint): number {
59
- return BN.isBN(v) ? v.toNumber() : Number(v);
60
- }
61
-
62
- // ── PDA helpers ──────────────────────────────────────
63
-
64
- deriveEscrow(
65
- agentPda: PublicKey,
66
- depositor?: PublicKey,
67
- nonce: BN | number | bigint = 0,
68
- ): readonly [PublicKey, number] {
69
- return deriveEscrowV2(agentPda, depositor ?? this.walletPubkey, this.toNum(nonce));
70
- }
71
-
72
- derivePendingSettlement(
73
- escrowV2Pda: PublicKey,
74
- settlementIndex: BN | number | bigint,
75
- ): readonly [PublicKey, number] {
76
- return derivePendingPda(escrowV2Pda, this.toNum(settlementIndex));
77
- }
78
-
79
- deriveDispute(
80
- pendingSettlementPda: PublicKey,
81
- ): readonly [PublicKey, number] {
82
- return deriveDisputePda(pendingSettlementPda);
83
- }
84
-
85
- // ── Instructions ─────────────────────────────────────
86
-
87
- async create(
88
- agentWallet: PublicKey,
89
- args: CreateEscrowV2Args,
90
- splAccounts: AccountMeta[] = [],
91
- ): Promise<TransactionSignature> {
92
- // v0.10.0: payment-token allowlist (SOL or USDC only).
93
- if (!isAcceptedPaymentToken(args.tokenMint ?? null)) {
94
- throw new Error(
95
- "createEscrowV2: tokenMint must be null (SOL) or USDC (mainnet/devnet). " +
96
- "On-chain will reject with PaymentTokenNotAllowed.",
97
- );
98
- }
99
-
100
- // v0.12.7 preflight: mirror the on-chain settlement-security guards
101
- // (escrow_v2.rs:106-115) so callers fail fast with a clear message
102
- // instead of paying for a tx that aborts with `InvalidSettlementSecurity`
103
- // or `CoSignerRequired`.
104
- const security = args.settlementSecurity;
105
- if (security === 0) {
106
- throw new Error(
107
- "createEscrowV2: settlementSecurity=0 (SelfReport) is deprecated since " +
108
- "v0.7. Use 1 (CoSigned) or 2 (DisputeWindow). On-chain rejects with " +
109
- "SelfReportDeprecated.",
110
- );
111
- }
112
- if (security === 1 && !args.coSigner) {
113
- throw new Error(
114
- "createEscrowV2: settlementSecurity=1 (CoSigned) requires `coSigner` " +
115
- "to be set. On-chain rejects with CoSignerRequired.",
116
- );
117
- }
118
- if (security === 2) {
119
- // The on-chain check is `dispute_window_slots > 0` — i.e. >= 1 slot.
120
- // Zero would let an agent settle and immediately drain pending funds
121
- // before any depositor could possibly file a dispute, defeating the
122
- // entire DisputeWindow security model. Enforce client-side too.
123
- const slots = BigInt(this.bn(args.disputeWindowSlots).toString());
124
- if (slots < 1n) {
125
- throw new Error(
126
- "createEscrowV2: settlementSecurity=2 (DisputeWindow) requires " +
127
- "`disputeWindowSlots >= 1` to prevent the zero-window abuse vector. " +
128
- "Recommended minimum is 2_160 slots (~15 min). On-chain rejects " +
129
- "with InvalidSettlementSecurity.",
130
- );
131
- }
132
- }
133
- if (security !== 0 && security !== 1 && security !== 2) {
134
- throw new Error(
135
- `createEscrowV2: settlementSecurity must be 1 (CoSigned) or 2 (DisputeWindow), got ${String(security)}.`,
136
- );
137
- }
138
-
139
- const [agentPda] = deriveAgent(agentWallet);
140
- const [escrowPda] = this.deriveEscrow(agentPda, undefined, args.escrowNonce);
141
- const [stakePda] = deriveStake(agentPda);
142
- // v0.11 H-1 preflight: surface an actionable error if the agent's stake
143
- // does not cover the slashable share of the new escrow. Saves a failed
144
- // tx fee and gives the caller a clear top-up amount.
145
- try {
146
- const stakeAccount = await this.fetchAccountNullable<{ stakedAmount: BN }>("agentStake", stakePda);
147
- if (stakeAccount) {
148
- const escrowLamports = BigInt(this.bn(args.initialDeposit).toString());
149
- const required = computeRequiredStakeLamports(escrowLamports);
150
- const have = BigInt(stakeAccount.stakedAmount.toString());
151
- if (have < required) {
152
- throw new Error(
153
- `createEscrowV2: agent stake ${have} lamports < required ${required} ` +
154
- `lamports for escrow of ${escrowLamports} lamports. Top up via stakingModule.deposit.`,
155
- );
156
- }
157
- }
158
- // If no stake account exists at all, on-chain will reject with
159
- // AccountNotInitialized — we let that bubble up unchanged.
160
- } catch (err) {
161
- // Preflight is advisory; rethrow only the explicit coverage error.
162
- if (err instanceof Error && err.message.startsWith("createEscrowV2: agent stake")) {
163
- throw err;
164
- }
165
- }
166
- // v0.11 H-1 preflight: surface an actionable error if the agent's stake
167
- // does not cover the slashable share of the new escrow. Saves a failed
168
- // tx fee and gives the caller a clear top-up amount.
169
- try {
170
- const stakeAccount = await this.fetchAccountNullable<{ stakedAmount: BN }>("agentStake", stakePda);
171
- if (stakeAccount) {
172
- const escrowLamports = BigInt(this.bn(args.initialDeposit).toString());
173
- const required = computeRequiredStakeLamports(escrowLamports);
174
- const have = BigInt(stakeAccount.stakedAmount.toString());
175
- if (have < required) {
176
- throw new Error(
177
- `createEscrowV2: agent stake ${have} lamports < required ${required} ` +
178
- `lamports for escrow of ${escrowLamports} lamports. Top up via stakingModule.deposit.`,
179
- );
180
- }
181
- }
182
- // If no stake account exists at all, on-chain will reject with
183
- // AccountNotInitialized — we let that bubble up unchanged.
184
- } catch (err) {
185
- // Preflight is advisory; rethrow only the explicit coverage error.
186
- if (err instanceof Error && err.message.startsWith("createEscrowV2: agent stake")) {
187
- throw err;
188
- }
189
- }
190
-
191
- return this.methods
192
- .createEscrowV2(
193
- this.bn(args.escrowNonce),
194
- this.bn(args.pricePerCall),
195
- this.bn(args.maxCalls),
196
- this.bn(args.initialDeposit),
197
- args.expiresAt,
198
- args.volumeCurve,
199
- args.tokenMint,
200
- args.tokenDecimals,
201
- args.settlementSecurity,
202
- this.bn(args.disputeWindowSlots),
203
- args.coSigner,
204
- args.arbiter,
205
- )
206
- .accounts({
207
- depositor: this.walletPubkey,
208
- agent: agentPda,
209
- agentStake: stakePda,
210
- escrow: escrowPda,
211
- systemProgram: SystemProgram.programId,
212
- })
213
- .remainingAccounts(splAccounts)
214
- .rpc();
215
- }
216
-
217
- async deposit(
218
- agentWallet: PublicKey,
219
- nonce: BN | number | bigint,
220
- amount: BN | number | bigint,
221
- splAccounts: AccountMeta[] = [],
222
- ): Promise<TransactionSignature> {
223
- const [agentPda] = deriveAgent(agentWallet);
224
- const [escrowPda] = this.deriveEscrow(agentPda, undefined, nonce);
225
-
226
- // v0.13.0 preflights — escrow exists, token shape matches, amount > 0
227
- const escrow = await this.requireAccountExists<EscrowAccountV2Data>(
228
- "escrowAccountV2",
229
- escrowPda,
230
- { predicted: "NotAuthority", hint: "Escrow V2 PDA not found — call createEscrow first" },
231
- );
232
- const want = BigInt(this.bn(amount).toString());
233
- if (want <= 0n) throwPredicted("InsufficientEscrowBalance", "Deposit amount must be > 0");
234
- const isSpl = escrow.tokenMint != null;
235
- if (isSpl && splAccounts.length < 4) {
236
- throwPredicted("SplTokenRequired", "Pass [depositorAta, escrowAta, tokenMint, tokenProgram]");
237
- }
238
- if (!isSpl && splAccounts.length > 0) {
239
- throwPredicted("InvalidTokenAccount", "SOL escrow does not accept splAccounts");
240
- }
241
-
242
- return this.methods
243
- .depositEscrowV2(this.bn(nonce), this.bn(amount))
244
- .accounts({
245
- depositor: this.walletPubkey,
246
- escrow: escrowPda,
247
- systemProgram: SystemProgram.programId,
248
- })
249
- .remainingAccounts(splAccounts)
250
- .rpc();
251
- }
252
-
253
- /**
254
- * Settle a batch of calls against a V2 escrow.
255
- *
256
- * **v0.13.0 — Auto-bundle DisputeWindow:** when the escrow's
257
- * `settlementSecurity` is `DisputeWindow`, this method now bundles
258
- * **`settleCallsV2` + `createPendingSettlement`** into the SAME
259
- * transaction. This eliminates the foot-gun where a caller would call
260
- * `createPendingSettlement` directly without a preceding `settleCallsV2`,
261
- * leaving `escrow.pending_amount = 0` and causing `finalizeSettlement`
262
- * to abort with `ArithmeticOverflow` (6075).
263
- *
264
- * Flow per security mode:
265
- * - **CoSigned** — single IX (`settleCallsV2`) with co-signer in
266
- * remaining accounts; funds move immediately.
267
- * - **DisputeWindow** — two IXs in one tx:
268
- * 1. `settleCallsV2` — bumps `pending_amount` and `settlement_index`
269
- * 2. `createPendingSettlement(idx)` — locks the dispute tracker PDA
270
- *
271
- * After this tx confirms, wait `escrow.disputeWindowSlots` slots and
272
- * call {@link finalizeSettlement} with the index returned via
273
- * `SettlementPendingEvent` or readable from `escrow.settlement_index - 1`.
274
- *
275
- * Pass `opts.skipAutoPending = true` to opt out of the auto-bundle (e.g.
276
- * if you want to drive `createPendingSettlement` separately for advanced
277
- * flows like batched off-chain receipt aggregation).
278
- *
279
- * @param depositorWallet - Depositor of the escrow being settled.
280
- * @param nonce - Escrow nonce (default 0 for the canonical escrow).
281
- * @param callsToSettle - Number of calls to settle in this batch.
282
- * @param serviceHash - 32-byte sha256 of the service payload.
283
- * @param splAccounts - Optional remaining accounts (SPL transfer + co-signer).
284
- * @param opts - Priority-fee + auto-pending options.
285
- * @param coSigner - Required for CoSigned escrows.
286
- * @returns The transaction signature.
287
- * @since v0.7.0 — initial release
288
- * @since v0.13.0 — auto-bundles `createPendingSettlement` for DisputeWindow
289
- */
290
- async settle(
291
- depositorWallet: PublicKey,
292
- nonce: BN | number | bigint,
293
- callsToSettle: BN | number | bigint,
294
- serviceHash: number[],
295
- splAccounts: AccountMeta[] = [],
296
- opts?: SettleOptions & {
297
- /**
298
- * v0.13.0 — Opt out of the DisputeWindow auto-bundle. When `true`,
299
- * `settle()` only emits `settleCallsV2` and the caller is responsible
300
- * for sending `createPendingSettlement` afterwards (legacy 2-tx flow).
301
- * Default: `false` (auto-bundle is on).
302
- */
303
- skipAutoPending?: boolean;
304
- /**
305
- * v0.13.0 — `receiptMerkleRoot` to inscribe in the auto-bundled
306
- * `createPendingSettlement`. Defaults to 32 zero bytes (no receipt
307
- * batch). Ignored when `skipAutoPending = true`.
308
- */
309
- receiptMerkleRoot?: number[];
310
- },
311
- coSigner?: Signer,
312
- ): Promise<TransactionSignature> {
313
- const [agentPda] = deriveAgent(this.walletPubkey);
314
- const [escrowPda] = this.deriveEscrow(agentPda, depositorWallet, nonce);
315
- const [statsPda] = deriveAgentStats(agentPda);
316
- const [receiptPda] = deriveSettlementReceipt(escrowPda, serviceHash);
317
-
318
- const preIxs = buildPriorityFeeIxs(opts);
319
- const rpcOpts = buildRpcOptions(opts);
320
-
321
- // CoSigned escrows require the co-signer to appear in
322
- // remaining_accounts with `is_signer = true` AND to actually sign
323
- // the transaction (Anchor on-chain checks `acc.is_signer`).
324
- // We dedupe so callers can also pass it manually via splAccounts.
325
- const remaining: AccountMeta[] = coSigner
326
- ? [
327
- ...splAccounts.filter((a) => !a.pubkey.equals(coSigner.publicKey)),
328
- { pubkey: coSigner.publicKey, isSigner: true, isWritable: false },
329
- ]
330
- : splAccounts;
331
-
332
- // ── v0.13.0 preflight: fetch escrow once to drive both branches ──
333
- // We need it to (a) detect DisputeWindow vs CoSigned, (b) read the
334
- // current `settlement_index` to feed `createPendingSettlement`, and
335
- // (c) compute `amount` via the volume curve so the bundled IX matches
336
- // what `settle_calls_v2` will compute on-chain.
337
- const escrowAcc = await this.fetchAccountNullable<EscrowAccountV2Data>(
338
- "escrowAccountV2",
339
- escrowPda,
340
- );
341
- if (!escrowAcc) {
342
- throw new Error(
343
- `escrowV2.settle: escrow PDA ${escrowPda.toBase58()} not found on-chain ` +
344
- `(agent=${agentPda.toBase58()}, depositor=${depositorWallet.toBase58()}, nonce=${this.bn(nonce).toString()}). ` +
345
- `Did the depositor call escrowV2.create() yet?`,
346
- );
347
- }
348
-
349
- const isDisputeWindow =
350
- typeof escrowAcc.settlementSecurity === "object" &&
351
- escrowAcc.settlementSecurity !== null &&
352
- "disputeWindow" in (escrowAcc.settlementSecurity as Record<string, unknown>);
353
-
354
- let builder = this.methods
355
- .settleCallsV2(this.bn(nonce), this.bn(callsToSettle), serviceHash)
356
- .accountsPartial({
357
- wallet: this.walletPubkey,
358
- agent: agentPda,
359
- agentStats: statsPda,
360
- escrow: escrowPda,
361
- settlementReceipt: receiptPda,
362
- systemProgram: SystemProgram.programId,
363
- })
364
- .remainingAccounts(remaining);
365
-
366
- if (coSigner) {
367
- builder = builder.signers([coSigner]);
368
- }
369
-
370
- if (preIxs.length > 0) {
371
- builder = builder.preInstructions(preIxs);
372
- }
373
-
374
- // ── v0.13.0: auto-bundle createPendingSettlement on DisputeWindow ──
375
- // The on-chain `settle_calls_v2_handler` (DisputeWindow branch) only
376
- // bumps `escrow.pending_amount` and `escrow.settlement_index` — it
377
- // does NOT create the PendingSettlement PDA. Without the followup
378
- // `createPendingSettlement` IX in the SAME tx, a buggy caller can
379
- // (a) call `createPendingSettlement` later with a stale index, or
380
- // (b) skip `settleCallsV2` entirely on a fresh escrow → orphan PDA
381
- // whose `amount > escrow.pending_amount` → finalize aborts forever
382
- // with `ArithmeticOverflow` (6075). Bundling is the only way to
383
- // make that race impossible.
384
- const skipAutoPending = opts?.skipAutoPending === true;
385
- if (isDisputeWindow && !skipAutoPending) {
386
- // PRE-increment settlement_index — settle_calls_v2 will bump it
387
- // to (current + 1) AFTER our IX runs, but the PDA seed used by
388
- // create_pending_settlement is the PRE-increment value (matches
389
- // `SettlementPendingEvent.settlement_index`).
390
- const settlementIndex = escrowAcc.settlementIndex;
391
-
392
- // Mirror the on-chain volume-curve math so `pending.amount`
393
- // matches what `escrow.pending_amount` was bumped by.
394
- const totalCallsBefore = escrowAcc.totalCallsSettled.add(escrowAcc.pendingCalls);
395
- const amount = calculateSettleAmount(
396
- escrowAcc.pricePerCall,
397
- escrowAcc.volumeCurve,
398
- totalCallsBefore,
399
- this.bn(callsToSettle),
400
- );
401
-
402
- const [pendingPda] = this.derivePendingSettlement(escrowPda, settlementIndex);
403
-
404
- // Defensive: if a stale pending PDA exists at this index (orphan
405
- // from an aborted prior run), refuse to send — otherwise the IX
406
- // will fail with `Allocate: account already in use` (custom 0x0).
407
- const existing = await this.provider.connection.getAccountInfo(pendingPda);
408
- if (existing) {
409
- throw new Error(
410
- `escrowV2.settle (auto-bundle): pending PDA ${pendingPda.toBase58()} ` +
411
- `already exists for settlementIndex=${settlementIndex.toString()}. ` +
412
- `An earlier run created it but did not finalize. Either finalize ` +
413
- `that index first or skip it permanently. (Pass skipAutoPending=true ` +
414
- `to bypass this guard and emit only settleCallsV2.)`,
415
- );
416
- }
417
-
418
- const receiptMerkleRoot = opts?.receiptMerkleRoot ?? new Array(32).fill(0);
419
- const pendingIx = await this.methods
420
- .createPendingSettlement(
421
- settlementIndex,
422
- this.bn(callsToSettle),
423
- amount,
424
- serviceHash,
425
- receiptMerkleRoot,
426
- )
427
- .accounts({
428
- wallet: this.walletPubkey,
429
- agent: agentPda,
430
- escrow: escrowPda,
431
- pendingSettlement: pendingPda,
432
- systemProgram: SystemProgram.programId,
433
- })
434
- .instruction();
435
-
436
- builder = builder.postInstructions([pendingIx]);
437
- }
438
-
439
- return builder.rpc(rpcOpts);
440
- }
441
-
442
- /**
443
- * Read the current `escrow.settlement_index` from chain.
444
- *
445
- * In DisputeWindow mode (`settlementSecurity = 2`), every successful
446
- * `settleCallsV2` increments this value. The PRE-increment value is the
447
- * one to pass to {@link createPendingSettlement} for that batch.
448
- *
449
- * @returns the current `settlementIndex` as `bigint` (next index to use
450
- * for `createPendingSettlement` if you have NOT yet called `settle` for
451
- * it; if you HAVE just settled, subtract 1 — but prefer the event
452
- * `SettlementPendingEvent.settlement_index` over arithmetic).
453
- * @since v0.12.8
454
- */
455
- async nextSettlementIndex(
456
- agentWallet: PublicKey,
457
- depositorWallet: PublicKey,
458
- nonce: BN | number | bigint,
459
- ): Promise<bigint> {
460
- const [agentPda] = deriveAgent(agentWallet);
461
- const [escrowPda] = this.deriveEscrow(agentPda, depositorWallet, nonce);
462
- const escrow = await this.fetchAccountNullable<EscrowAccountV2Data>(
463
- "escrowAccountV2",
464
- escrowPda,
465
- );
466
- if (!escrow) {
467
- throw new Error(
468
- `nextSettlementIndex: escrow PDA ${escrowPda.toBase58()} not found on-chain`,
469
- );
470
- }
471
- return BigInt(escrow.settlementIndex.toString());
472
- }
473
-
474
- /**
475
- * Create the PendingSettlement PDA for a DisputeWindow batch.
476
- *
477
- * **v0.13.0 NOTE:** in almost all cases you should call
478
- * {@link settle} instead — it auto-bundles `settleCallsV2 +
479
- * createPendingSettlement` in a single transaction so the two
480
- * cannot drift out of sync. Use this method standalone ONLY when
481
- * you intentionally pass `skipAutoPending: true` to `settle()`
482
- * (e.g. batched receipt-merkle aggregation across multiple
483
- * `settleCallsV2` runs).
484
- *
485
- * Calling this without a preceding `settleCallsV2` (which bumps
486
- * `escrow.pending_amount`) creates an orphan PDA whose
487
- * `pending.amount > escrow.pending_amount` — `finalizeSettlement`
488
- * will then abort with `ArithmeticOverflow` (6075) forever.
489
- *
490
- * @since v0.7.0
491
- */
492
- async createPendingSettlement(
493
- agentWallet: PublicKey,
494
- depositorWallet: PublicKey,
495
- nonce: BN | number | bigint,
496
- settlementIndex: BN | number | bigint,
497
- callsToSettle: BN | number | bigint,
498
- amount: BN | number | bigint,
499
- serviceHash: number[],
500
- receiptMerkleRoot: number[] = new Array(32).fill(0),
501
- ): Promise<TransactionSignature> {
502
- const [agentPda] = deriveAgent(agentWallet);
503
- const [escrowPda] = this.deriveEscrow(agentPda, depositorWallet, nonce);
504
- const [pendingPda] = this.derivePendingSettlement(escrowPda, settlementIndex);
505
-
506
- // v0.12.8: preflight against the "Allocate: account already in use"
507
- // SystemProgram error (custom 0x0). The pending_settlement PDA is
508
- // seeded on `escrow + settlement_index`, so reusing the same index
509
- // (e.g. always 0, or a stale retry value) collides with an existing
510
- // account. Fail fast with an actionable message instead of burning a
511
- // failed tx fee on simulation.
512
- const existing = await this.provider.connection.getAccountInfo(pendingPda);
513
- if (existing) {
514
- const idx = this.bn(settlementIndex).toString();
515
- throw new Error(
516
- `createPendingSettlement: pending PDA ${pendingPda.toBase58()} ` +
517
- `already exists for settlementIndex=${idx}. ` +
518
- `Use EscrowV2Module.nextSettlementIndex() to read the current ` +
519
- `escrow.settlement_index, or capture SettlementPendingEvent.settlement_index ` +
520
- `from the preceding settleCallsV2 tx. Reusing a settlementIndex ` +
521
- `causes SystemProgram Allocate (custom 0x0) failures.`,
522
- );
523
- }
524
-
525
- return this.methods
526
- .createPendingSettlement(
527
- this.bn(settlementIndex),
528
- this.bn(callsToSettle),
529
- this.bn(amount),
530
- serviceHash,
531
- receiptMerkleRoot,
532
- )
533
- .accounts({
534
- wallet: this.walletPubkey,
535
- agent: agentPda,
536
- escrow: escrowPda,
537
- pendingSettlement: pendingPda,
538
- systemProgram: SystemProgram.programId,
539
- })
540
- .rpc();
541
- }
542
-
543
- async finalizeSettlement(
544
- agentWallet: PublicKey,
545
- depositorWallet: PublicKey,
546
- nonce: BN | number | bigint,
547
- settlementIndex: BN | number | bigint,
548
- ): Promise<TransactionSignature> {
549
- const [agentPda] = deriveAgent(agentWallet);
550
- const [escrowPda] = this.deriveEscrow(agentPda, depositorWallet, nonce);
551
- const [pendingPda] = this.derivePendingSettlement(escrowPda, settlementIndex);
552
- const [statsPda] = deriveAgentStats(agentPda);
553
-
554
- // v0.12.9: preflight against ArithmeticOverflow at finalize.
555
- //
556
- // The on-chain handler subtracts `pending_settlement.amount` from BOTH
557
- // `escrow.balance` AND `escrow.pending_amount`. If the PendingSettlement
558
- // PDA was created without a preceding `settle_calls_v2` (orphan PDA from
559
- // legacy probe loops, or a buggy caller that skipped the settle step),
560
- // `escrow.pending_amount` is smaller than `pending_settlement.amount`
561
- // and the program aborts with ArithmeticOverflow (error 6075) at
562
- // escrow_v2.rs:633. Each retry burns ~5 000 lamports of base fee.
563
- //
564
- // Detect this BEFORE signing and throw with a clear, actionable message
565
- // pointing at the orphan-recovery path.
566
- const [escrowAcc, pendingAcc] = await Promise.all([
567
- this.fetchAccountNullable<EscrowAccountV2Data>("escrowAccountV2", escrowPda),
568
- this.fetchAccountNullable<PendingSettlementData>("pendingSettlement", pendingPda),
569
- ]);
570
- if (!escrowAcc) {
571
- throw new Error(
572
- `finalizeSettlement: escrow PDA ${escrowPda.toBase58()} not found on-chain.`,
573
- );
574
- }
575
- if (!pendingAcc) {
576
- throw new Error(
577
- `finalizeSettlement: pending PDA ${pendingPda.toBase58()} not found on-chain ` +
578
- `(settlementIndex=${settlementIndex.toString()}). Nothing to finalize.`,
579
- );
580
- }
581
- const psAmount = BigInt(pendingAcc.amount.toString());
582
- const escrowPendingAmount = BigInt(escrowAcc.pendingAmount.toString());
583
- const escrowBalance = BigInt(escrowAcc.balance.toString());
584
- if (psAmount > escrowPendingAmount || psAmount > escrowBalance) {
585
- throw new Error(
586
- `finalizeSettlement: orphan/inconsistent PendingSettlement detected ` +
587
- `at ${pendingPda.toBase58()} (settlementIndex=${settlementIndex.toString()}). ` +
588
- `pending.amount=${psAmount} but escrow.pending_amount=${escrowPendingAmount}, ` +
589
- `escrow.balance=${escrowBalance}. The on-chain finalize would abort with ` +
590
- `ArithmeticOverflow (6075). This PDA was almost certainly created by a ` +
591
- `caller that skipped settle_calls_v2 (legacy probe loop). It cannot be ` +
592
- `finalized and cannot be closed (close_pending_settlement requires ` +
593
- `is_finalized=true). Skip this index permanently in your settle queue.`,
594
- );
595
- }
596
-
597
- return this.methods
598
- .finalizeSettlement()
599
- .accounts({
600
- payer: this.walletPubkey,
601
- agentWallet,
602
- escrow: escrowPda,
603
- pendingSettlement: pendingPda,
604
- agentStats: statsPda,
605
- })
606
- .rpc();
607
- }
608
-
609
- /**
610
- * Identify orphan PendingSettlement PDAs that cannot be finalized.
611
- *
612
- * @returns `null` if the PDA is finalizable (or already finalized / disputed).
613
- * Otherwise an object describing the inconsistency, suitable for
614
- * logging or feeding into a quarantine list. Use this from a
615
- * recovery script to scan a range of `settlement_index` values:
616
- *
617
- * ```ts
618
- * for (let idx = 0n; idx < currentIdx; idx++) {
619
- * const orphan = await sap.escrowV2.diagnoseOrphanPending(
620
- * agentWallet, depositorWallet, nonce, idx,
621
- * );
622
- * if (orphan) log.warn({ idx, ...orphan }, "skip orphan");
623
- * }
624
- * ```
625
- *
626
- * @since v0.12.9
627
- */
628
- async diagnoseOrphanPending(
629
- agentWallet: PublicKey,
630
- depositorWallet: PublicKey,
631
- nonce: BN | number | bigint,
632
- settlementIndex: BN | number | bigint,
633
- ): Promise<{
634
- pendingPda: PublicKey;
635
- psAmount: bigint;
636
- escrowPendingAmount: bigint;
637
- escrowBalance: bigint;
638
- isFinalized: boolean;
639
- isDisputed: boolean;
640
- reason: "ok" | "missing" | "amount_exceeds_pending" | "amount_exceeds_balance" | "already_finalized" | "disputed";
641
- } | null> {
642
- const [agentPda] = deriveAgent(agentWallet);
643
- const [escrowPda] = this.deriveEscrow(agentPda, depositorWallet, nonce);
644
- const [pendingPda] = this.derivePendingSettlement(escrowPda, settlementIndex);
645
- const [escrowAcc, pendingAcc] = await Promise.all([
646
- this.fetchAccountNullable<EscrowAccountV2Data>("escrowAccountV2", escrowPda),
647
- this.fetchAccountNullable<PendingSettlementData>("pendingSettlement", pendingPda),
648
- ]);
649
- if (!escrowAcc) return null;
650
- if (!pendingAcc) {
651
- return {
652
- pendingPda,
653
- psAmount: 0n,
654
- escrowPendingAmount: BigInt(escrowAcc.pendingAmount.toString()),
655
- escrowBalance: BigInt(escrowAcc.balance.toString()),
656
- isFinalized: false,
657
- isDisputed: false,
658
- reason: "missing",
659
- };
660
- }
661
- const psAmount = BigInt(pendingAcc.amount.toString());
662
- const escrowPendingAmount = BigInt(escrowAcc.pendingAmount.toString());
663
- const escrowBalance = BigInt(escrowAcc.balance.toString());
664
- const base = {
665
- pendingPda,
666
- psAmount,
667
- escrowPendingAmount,
668
- escrowBalance,
669
- isFinalized: pendingAcc.isFinalized,
670
- isDisputed: pendingAcc.isDisputed,
671
- };
672
- if (pendingAcc.isFinalized) return { ...base, reason: "already_finalized" };
673
- if (pendingAcc.isDisputed) return { ...base, reason: "disputed" };
674
- if (psAmount > escrowPendingAmount) return { ...base, reason: "amount_exceeds_pending" };
675
- if (psAmount > escrowBalance) return { ...base, reason: "amount_exceeds_balance" };
676
- return null;
677
- }
678
-
679
- async fileDispute(
680
- agentWallet: PublicKey,
681
- nonce: BN | number | bigint,
682
- settlementIndex: BN | number | bigint,
683
- evidenceHash: number[],
684
- disputeType: number = 0,
685
- ): Promise<TransactionSignature> {
686
- const [agentPda] = deriveAgent(agentWallet);
687
- const [escrowPda] = this.deriveEscrow(agentPda, undefined, nonce);
688
- const [pendingPda] = this.derivePendingSettlement(escrowPda, settlementIndex);
689
- const [disputePda] = this.deriveDispute(pendingPda);
690
-
691
- return this.methods
692
- .fileDispute(evidenceHash, disputeType)
693
- .accounts({
694
- depositor: this.walletPubkey,
695
- escrow: escrowPda,
696
- pendingSettlement: pendingPda,
697
- dispute: disputePda,
698
- systemProgram: SystemProgram.programId,
699
- })
700
- .rpc();
701
- }
702
-
703
- /**
704
- * @deprecated Since v0.7.0 — Arbiter-based resolution removed.
705
- * Use {@link ReceiptModule.submitReceiptProof} + {@link ReceiptModule.autoResolveDispute} instead.
706
- */
707
- async resolveDispute(
708
- _depositorWallet: PublicKey,
709
- _agentWallet: PublicKey,
710
- _nonce: BN | number | bigint,
711
- _settlementIndex: BN | number | bigint,
712
- _outcome: number,
713
- ): Promise<TransactionSignature> {
714
- throw new Error("resolveDispute removed in v0.7.0 — use ReceiptModule.autoResolveDispute");
715
- }
716
-
717
- async closeDispute(
718
- pendingSettlementPda: PublicKey,
719
- ): Promise<TransactionSignature> {
720
- const [disputePda] = this.deriveDispute(pendingSettlementPda);
721
-
722
- return this.methods
723
- .closeDispute()
724
- .accounts({
725
- depositor: this.walletPubkey,
726
- dispute: disputePda,
727
- })
728
- .rpc();
729
- }
730
-
731
- async closePendingSettlement(
732
- pendingSettlementPda: PublicKey,
733
- ): Promise<TransactionSignature> {
734
- return this.methods
735
- .closePendingSettlement()
736
- .accounts({
737
- payer: this.walletPubkey,
738
- pendingSettlement: pendingSettlementPda,
739
- })
740
- .rpc();
741
- }
742
-
743
- async withdraw(
744
- agentWallet: PublicKey,
745
- nonce: BN | number | bigint,
746
- amount: BN | number | bigint,
747
- ): Promise<TransactionSignature> {
748
- const [agentPda] = deriveAgent(agentWallet);
749
- const [escrowPda] = this.deriveEscrow(agentPda, undefined, nonce);
750
-
751
- // v0.13.0 preflight — amount must fit (balance - pendingAmount); the
752
- // on-chain handler subtracts pending_amount from withdrawable funds.
753
- const escrow = await this.requireAccountExists<EscrowAccountV2Data>(
754
- "escrowAccountV2",
755
- escrowPda,
756
- { predicted: "NotAuthority", hint: "Escrow V2 PDA not found" },
757
- );
758
- const want = BigInt(this.bn(amount).toString());
759
- if (want <= 0n) throwPredicted("InsufficientEscrowBalance", "Withdraw amount must be > 0");
760
- const balance = BigInt(escrow.balance.toString());
761
- const pending = BigInt(escrow.pendingAmount.toString());
762
- const free = balance > pending ? balance - pending : 0n;
763
- if (want > free) {
764
- throwPredicted(
765
- "InsufficientEscrowBalance",
766
- `requested ${want}, withdrawable ${free} (balance ${balance} − pending ${pending})`,
767
- );
768
- }
769
-
770
- return this.methods
771
- .withdrawEscrowV2(this.bn(amount))
772
- .accounts({
773
- depositor: this.walletPubkey,
774
- escrow: escrowPda,
775
- })
776
- .rpc();
777
- }
778
-
779
- async close(
780
- agentWallet: PublicKey,
781
- nonce: BN | number | bigint = 0,
782
- ): Promise<TransactionSignature> {
783
- const [agentPda] = deriveAgent(agentWallet);
784
- const [escrowPda] = this.deriveEscrow(agentPda, undefined, nonce);
785
-
786
- // v0.13.0 preflight — close fails if balance != 0 OR pending_amount != 0.
787
- // Pending != 0 commonly indicates orphan PendingSettlement PDAs;
788
- // run diagnoseOrphanPending() across the index range to identify them.
789
- const escrow = await this.requireAccountExists<EscrowAccountV2Data>(
790
- "escrowAccountV2",
791
- escrowPda,
792
- { predicted: "NotAuthority", hint: "Escrow V2 PDA already closed" },
793
- );
794
- const balance = BigInt(escrow.balance.toString());
795
- const pending = BigInt(escrow.pendingAmount.toString());
796
- if (balance !== 0n) {
797
- throwPredicted("EscrowNotEmpty", `balance ${balance} > 0 — withdraw first`);
798
- }
799
- if (pending !== 0n) {
800
- throwPredicted(
801
- "EscrowNotClosed",
802
- `pending_amount ${pending} > 0 — finalize all PendingSettlements first or quarantine orphans via diagnoseOrphanPending`,
803
- );
804
- }
805
-
806
- return this.methods
807
- .closeEscrowV2()
808
- .accounts({
809
- depositor: this.walletPubkey,
810
- escrow: escrowPda,
811
- })
812
- .rpc();
813
- }
814
-
815
- /**
816
- * @deprecated Since v0.7.0 — Migration instruction removed from program.
817
- */
818
- async migrateFromV1(
819
- _agentWallet: PublicKey,
820
- ): Promise<TransactionSignature> {
821
- throw new Error("migrateFromV1 removed in v0.7.0 — migration instruction was deleted");
822
- }
823
-
824
- // ── Fetchers ─────────────────────────────────────────
825
-
826
- async fetch(
827
- agentPda: PublicKey,
828
- depositor?: PublicKey,
829
- nonce: BN | number | bigint = 0,
830
- ): Promise<EscrowAccountV2Data> {
831
- const [pda] = this.deriveEscrow(agentPda, depositor, nonce);
832
- return this.fetchAccount<EscrowAccountV2Data>("escrowAccountV2", pda);
833
- }
834
-
835
- async fetchNullable(
836
- agentPda: PublicKey,
837
- depositor?: PublicKey,
838
- nonce: BN | number | bigint = 0,
839
- ): Promise<EscrowAccountV2Data | null> {
840
- const [pda] = this.deriveEscrow(agentPda, depositor, nonce);
841
- return this.fetchAccountNullable<EscrowAccountV2Data>("escrowAccountV2", pda);
842
- }
843
-
844
- async fetchByPda(escrowPda: PublicKey): Promise<EscrowAccountV2Data> {
845
- return this.fetchAccount<EscrowAccountV2Data>("escrowAccountV2", escrowPda);
846
- }
847
-
848
- async fetchPendingSettlement(
849
- pendingPda: PublicKey,
850
- ): Promise<PendingSettlementData> {
851
- return this.fetchAccount<PendingSettlementData>("pendingSettlement", pendingPda);
852
- }
853
-
854
- async fetchPendingSettlementNullable(
855
- pendingPda: PublicKey,
856
- ): Promise<PendingSettlementData | null> {
857
- return this.fetchAccountNullable<PendingSettlementData>("pendingSettlement", pendingPda);
858
- }
859
-
860
- async fetchDispute(
861
- disputePda: PublicKey,
862
- ): Promise<DisputeRecordData> {
863
- return this.fetchAccount<DisputeRecordData>("disputeRecord", disputePda);
864
- }
865
-
866
- async fetchDisputeNullable(
867
- disputePda: PublicKey,
868
- ): Promise<DisputeRecordData | null> {
869
- return this.fetchAccountNullable<DisputeRecordData>("disputeRecord", disputePda);
870
- }
871
- }