@agirails/sdk 2.0.0 → 2.0.1-beta

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 (405) hide show
  1. package/README.md +108 -116
  2. package/dist/ACTPClient.d.ts +33 -456
  3. package/dist/ACTPClient.d.ts.map +1 -1
  4. package/dist/ACTPClient.js +93 -477
  5. package/dist/ACTPClient.js.map +1 -1
  6. package/dist/abi/EscrowVault.json +38 -106
  7. package/dist/builders/DeliveryProofBuilder.d.ts +1 -60
  8. package/dist/builders/DeliveryProofBuilder.d.ts.map +1 -1
  9. package/dist/builders/DeliveryProofBuilder.js +5 -81
  10. package/dist/builders/DeliveryProofBuilder.js.map +1 -1
  11. package/dist/builders/QuoteBuilder.d.ts +0 -101
  12. package/dist/builders/QuoteBuilder.d.ts.map +1 -1
  13. package/dist/builders/QuoteBuilder.js +3 -120
  14. package/dist/builders/QuoteBuilder.js.map +1 -1
  15. package/dist/builders/index.d.ts +0 -4
  16. package/dist/builders/index.d.ts.map +1 -1
  17. package/dist/builders/index.js +0 -4
  18. package/dist/builders/index.js.map +1 -1
  19. package/dist/config/networks.d.ts +0 -28
  20. package/dist/config/networks.d.ts.map +1 -1
  21. package/dist/config/networks.js +12 -60
  22. package/dist/config/networks.js.map +1 -1
  23. package/dist/errors/index.d.ts +2 -165
  24. package/dist/errors/index.d.ts.map +1 -1
  25. package/dist/errors/index.js +2 -260
  26. package/dist/errors/index.js.map +1 -1
  27. package/dist/index.d.ts +13 -61
  28. package/dist/index.d.ts.map +1 -1
  29. package/dist/index.js +36 -141
  30. package/dist/index.js.map +1 -1
  31. package/dist/protocol/ACTPKernel.d.ts +2 -229
  32. package/dist/protocol/ACTPKernel.d.ts.map +1 -1
  33. package/dist/protocol/ACTPKernel.js +33 -367
  34. package/dist/protocol/ACTPKernel.js.map +1 -1
  35. package/dist/protocol/EASHelper.d.ts +2 -57
  36. package/dist/protocol/EASHelper.d.ts.map +1 -1
  37. package/dist/protocol/EASHelper.js +37 -230
  38. package/dist/protocol/EASHelper.js.map +1 -1
  39. package/dist/protocol/EscrowVault.d.ts +2 -93
  40. package/dist/protocol/EscrowVault.d.ts.map +1 -1
  41. package/dist/protocol/EscrowVault.js +33 -122
  42. package/dist/protocol/EscrowVault.js.map +1 -1
  43. package/dist/protocol/EventMonitor.d.ts +1 -45
  44. package/dist/protocol/EventMonitor.d.ts.map +1 -1
  45. package/dist/protocol/EventMonitor.js +8 -64
  46. package/dist/protocol/EventMonitor.js.map +1 -1
  47. package/dist/protocol/MessageSigner.d.ts +2 -116
  48. package/dist/protocol/MessageSigner.d.ts.map +1 -1
  49. package/dist/protocol/MessageSigner.js +9 -215
  50. package/dist/protocol/MessageSigner.js.map +1 -1
  51. package/dist/protocol/ProofGenerator.d.ts +0 -93
  52. package/dist/protocol/ProofGenerator.d.ts.map +1 -1
  53. package/dist/protocol/ProofGenerator.js +9 -194
  54. package/dist/protocol/ProofGenerator.js.map +1 -1
  55. package/dist/protocol/QuoteBuilder.d.ts +0 -8
  56. package/dist/protocol/QuoteBuilder.d.ts.map +1 -1
  57. package/dist/protocol/QuoteBuilder.js +0 -8
  58. package/dist/protocol/QuoteBuilder.js.map +1 -1
  59. package/dist/types/eip712.d.ts +0 -34
  60. package/dist/types/eip712.d.ts.map +1 -1
  61. package/dist/types/eip712.js +5 -31
  62. package/dist/types/eip712.js.map +1 -1
  63. package/dist/types/escrow.d.ts +10 -17
  64. package/dist/types/escrow.d.ts.map +1 -1
  65. package/dist/types/index.d.ts +0 -5
  66. package/dist/types/index.d.ts.map +1 -1
  67. package/dist/types/index.js +0 -8
  68. package/dist/types/index.js.map +1 -1
  69. package/dist/types/message.d.ts +0 -32
  70. package/dist/types/message.d.ts.map +1 -1
  71. package/dist/types/message.js +0 -4
  72. package/dist/types/message.js.map +1 -1
  73. package/dist/types/state.d.ts +0 -28
  74. package/dist/types/state.d.ts.map +1 -1
  75. package/dist/types/state.js +6 -37
  76. package/dist/types/state.js.map +1 -1
  77. package/dist/types/transaction.d.ts +0 -17
  78. package/dist/types/transaction.d.ts.map +1 -1
  79. package/dist/utils/IPFSClient.d.ts +0 -113
  80. package/dist/utils/IPFSClient.d.ts.map +1 -1
  81. package/dist/utils/IPFSClient.js +7 -128
  82. package/dist/utils/IPFSClient.js.map +1 -1
  83. package/dist/utils/NonceManager.d.ts +1 -234
  84. package/dist/utils/NonceManager.d.ts.map +1 -1
  85. package/dist/utils/NonceManager.js +7 -372
  86. package/dist/utils/NonceManager.js.map +1 -1
  87. package/dist/utils/ReceivedNonceTracker.d.ts +0 -175
  88. package/dist/utils/ReceivedNonceTracker.d.ts.map +1 -1
  89. package/dist/utils/ReceivedNonceTracker.js +5 -261
  90. package/dist/utils/ReceivedNonceTracker.js.map +1 -1
  91. package/dist/utils/canonicalJson.d.ts +0 -22
  92. package/dist/utils/canonicalJson.d.ts.map +1 -1
  93. package/dist/utils/canonicalJson.js +3 -26
  94. package/dist/utils/canonicalJson.js.map +1 -1
  95. package/dist/utils/computeTypeHash.d.ts +0 -14
  96. package/dist/utils/computeTypeHash.d.ts.map +1 -1
  97. package/dist/utils/computeTypeHash.js +2 -19
  98. package/dist/utils/computeTypeHash.js.map +1 -1
  99. package/dist/utils/validation.d.ts +0 -40
  100. package/dist/utils/validation.d.ts.map +1 -1
  101. package/dist/utils/validation.js +7 -184
  102. package/dist/utils/validation.js.map +1 -1
  103. package/package.json +37 -54
  104. package/src/ACTPClient.ts +178 -692
  105. package/src/__tests__/ProofGenerator.test.ts +124 -0
  106. package/src/__tests__/QuoteBuilder.test.ts +516 -0
  107. package/src/__tests__/StateMachine.test.ts +82 -0
  108. package/src/__tests__/builders/DeliveryProofBuilder.test.ts +581 -0
  109. package/src/__tests__/integration/ACTPClient.test.ts +263 -0
  110. package/src/__tests__/integration.test.ts +289 -0
  111. package/src/__tests__/protocol/EASHelper.test.ts +472 -0
  112. package/src/__tests__/protocol/EventMonitor.test.ts +382 -0
  113. package/src/__tests__/security/ACTPKernel.security.test.ts +1167 -0
  114. package/src/__tests__/security/EscrowVault.security.test.ts +570 -0
  115. package/src/__tests__/security/MessageSigner.security.test.ts +286 -0
  116. package/src/__tests__/security/NonceReplay.security.test.ts +501 -0
  117. package/src/__tests__/security/validation.security.test.ts +376 -0
  118. package/src/__tests__/utils/IPFSClient.test.ts +262 -0
  119. package/src/__tests__/utils/NonceManager.test.ts +205 -0
  120. package/src/__tests__/utils/canonicalJson.test.ts +153 -0
  121. package/src/abi/EscrowVault.json +38 -106
  122. package/src/builders/DeliveryProofBuilder.ts +2 -3
  123. package/src/config/networks.ts +9 -32
  124. package/src/errors/index.ts +1 -298
  125. package/src/index.ts +71 -207
  126. package/src/protocol/ACTPKernel.ts +23 -175
  127. package/src/protocol/EASHelper.ts +46 -230
  128. package/src/protocol/EscrowVault.ts +50 -68
  129. package/src/protocol/EventMonitor.ts +15 -44
  130. package/src/protocol/MessageSigner.ts +13 -193
  131. package/src/protocol/ProofGenerator.ts +4 -223
  132. package/src/types/escrow.ts +11 -12
  133. package/src/types/index.ts +1 -5
  134. package/src/types/state.ts +3 -12
  135. package/src/types/transaction.ts +1 -4
  136. package/src/utils/IPFSClient.ts +5 -122
  137. package/src/utils/NonceManager.ts +8 -305
  138. package/src/utils/ReceivedNonceTracker.ts +0 -170
  139. package/src/utils/validation.ts +0 -164
  140. package/LICENSE +0 -190
  141. package/bin/actp +0 -10
  142. package/dist/abi/AgentRegistry.json +0 -782
  143. package/dist/abi/IdentityRegistry.json +0 -316
  144. package/dist/adapters/BaseAdapter.d.ts +0 -231
  145. package/dist/adapters/BaseAdapter.d.ts.map +0 -1
  146. package/dist/adapters/BaseAdapter.js +0 -393
  147. package/dist/adapters/BaseAdapter.js.map +0 -1
  148. package/dist/adapters/BeginnerAdapter.d.ts +0 -152
  149. package/dist/adapters/BeginnerAdapter.d.ts.map +0 -1
  150. package/dist/adapters/BeginnerAdapter.js +0 -168
  151. package/dist/adapters/BeginnerAdapter.js.map +0 -1
  152. package/dist/adapters/IntermediateAdapter.d.ts +0 -211
  153. package/dist/adapters/IntermediateAdapter.d.ts.map +0 -1
  154. package/dist/adapters/IntermediateAdapter.js +0 -260
  155. package/dist/adapters/IntermediateAdapter.js.map +0 -1
  156. package/dist/adapters/index.d.ts +0 -15
  157. package/dist/adapters/index.d.ts.map +0 -1
  158. package/dist/adapters/index.js +0 -26
  159. package/dist/adapters/index.js.map +0 -1
  160. package/dist/cli/commands/balance.d.ts +0 -13
  161. package/dist/cli/commands/balance.d.ts.map +0 -1
  162. package/dist/cli/commands/balance.js +0 -89
  163. package/dist/cli/commands/balance.js.map +0 -1
  164. package/dist/cli/commands/batch.d.ts +0 -24
  165. package/dist/cli/commands/batch.d.ts.map +0 -1
  166. package/dist/cli/commands/batch.js +0 -424
  167. package/dist/cli/commands/batch.js.map +0 -1
  168. package/dist/cli/commands/config.d.ts +0 -13
  169. package/dist/cli/commands/config.d.ts.map +0 -1
  170. package/dist/cli/commands/config.js +0 -192
  171. package/dist/cli/commands/config.js.map +0 -1
  172. package/dist/cli/commands/init.d.ts +0 -19
  173. package/dist/cli/commands/init.d.ts.map +0 -1
  174. package/dist/cli/commands/init.js +0 -143
  175. package/dist/cli/commands/init.js.map +0 -1
  176. package/dist/cli/commands/mint.d.ts +0 -13
  177. package/dist/cli/commands/mint.d.ts.map +0 -1
  178. package/dist/cli/commands/mint.js +0 -91
  179. package/dist/cli/commands/mint.js.map +0 -1
  180. package/dist/cli/commands/pay.d.ts +0 -18
  181. package/dist/cli/commands/pay.d.ts.map +0 -1
  182. package/dist/cli/commands/pay.js +0 -87
  183. package/dist/cli/commands/pay.js.map +0 -1
  184. package/dist/cli/commands/simulate.d.ts +0 -32
  185. package/dist/cli/commands/simulate.d.ts.map +0 -1
  186. package/dist/cli/commands/simulate.js +0 -290
  187. package/dist/cli/commands/simulate.js.map +0 -1
  188. package/dist/cli/commands/time.d.ts +0 -29
  189. package/dist/cli/commands/time.d.ts.map +0 -1
  190. package/dist/cli/commands/time.js +0 -252
  191. package/dist/cli/commands/time.js.map +0 -1
  192. package/dist/cli/commands/tx.d.ts +0 -16
  193. package/dist/cli/commands/tx.d.ts.map +0 -1
  194. package/dist/cli/commands/tx.js +0 -379
  195. package/dist/cli/commands/tx.js.map +0 -1
  196. package/dist/cli/commands/watch.d.ts +0 -20
  197. package/dist/cli/commands/watch.d.ts.map +0 -1
  198. package/dist/cli/commands/watch.js +0 -160
  199. package/dist/cli/commands/watch.js.map +0 -1
  200. package/dist/cli/index.d.ts +0 -17
  201. package/dist/cli/index.d.ts.map +0 -1
  202. package/dist/cli/index.js +0 -104
  203. package/dist/cli/index.js.map +0 -1
  204. package/dist/cli/utils/client.d.ts +0 -70
  205. package/dist/cli/utils/client.d.ts.map +0 -1
  206. package/dist/cli/utils/client.js +0 -240
  207. package/dist/cli/utils/client.js.map +0 -1
  208. package/dist/cli/utils/config.d.ts +0 -91
  209. package/dist/cli/utils/config.d.ts.map +0 -1
  210. package/dist/cli/utils/config.js +0 -240
  211. package/dist/cli/utils/config.js.map +0 -1
  212. package/dist/cli/utils/output.d.ts +0 -174
  213. package/dist/cli/utils/output.d.ts.map +0 -1
  214. package/dist/cli/utils/output.js +0 -380
  215. package/dist/cli/utils/output.js.map +0 -1
  216. package/dist/level0/Provider.d.ts +0 -106
  217. package/dist/level0/Provider.d.ts.map +0 -1
  218. package/dist/level0/Provider.js +0 -10
  219. package/dist/level0/Provider.js.map +0 -1
  220. package/dist/level0/ServiceDirectory.d.ts +0 -74
  221. package/dist/level0/ServiceDirectory.d.ts.map +0 -1
  222. package/dist/level0/ServiceDirectory.js +0 -122
  223. package/dist/level0/ServiceDirectory.js.map +0 -1
  224. package/dist/level0/index.d.ts +0 -10
  225. package/dist/level0/index.d.ts.map +0 -1
  226. package/dist/level0/index.js +0 -15
  227. package/dist/level0/index.js.map +0 -1
  228. package/dist/level0/provide.d.ts +0 -51
  229. package/dist/level0/provide.d.ts.map +0 -1
  230. package/dist/level0/provide.js +0 -113
  231. package/dist/level0/provide.js.map +0 -1
  232. package/dist/level0/request.d.ts +0 -53
  233. package/dist/level0/request.d.ts.map +0 -1
  234. package/dist/level0/request.js +0 -462
  235. package/dist/level0/request.js.map +0 -1
  236. package/dist/level1/Agent.d.ts +0 -472
  237. package/dist/level1/Agent.d.ts.map +0 -1
  238. package/dist/level1/Agent.js +0 -1091
  239. package/dist/level1/Agent.js.map +0 -1
  240. package/dist/level1/index.d.ts +0 -10
  241. package/dist/level1/index.d.ts.map +0 -1
  242. package/dist/level1/index.js +0 -30
  243. package/dist/level1/index.js.map +0 -1
  244. package/dist/level1/pricing/PriceCalculator.d.ts +0 -62
  245. package/dist/level1/pricing/PriceCalculator.d.ts.map +0 -1
  246. package/dist/level1/pricing/PriceCalculator.js +0 -237
  247. package/dist/level1/pricing/PriceCalculator.js.map +0 -1
  248. package/dist/level1/pricing/PricingStrategy.d.ts +0 -179
  249. package/dist/level1/pricing/PricingStrategy.d.ts.map +0 -1
  250. package/dist/level1/pricing/PricingStrategy.js +0 -11
  251. package/dist/level1/pricing/PricingStrategy.js.map +0 -1
  252. package/dist/level1/types/Job.d.ts +0 -166
  253. package/dist/level1/types/Job.d.ts.map +0 -1
  254. package/dist/level1/types/Job.js +0 -11
  255. package/dist/level1/types/Job.js.map +0 -1
  256. package/dist/level1/types/Options.d.ts +0 -258
  257. package/dist/level1/types/Options.d.ts.map +0 -1
  258. package/dist/level1/types/Options.js +0 -8
  259. package/dist/level1/types/Options.js.map +0 -1
  260. package/dist/level1/types/index.d.ts +0 -8
  261. package/dist/level1/types/index.d.ts.map +0 -1
  262. package/dist/level1/types/index.js +0 -8
  263. package/dist/level1/types/index.js.map +0 -1
  264. package/dist/protocol/AgentRegistry.d.ts +0 -177
  265. package/dist/protocol/AgentRegistry.d.ts.map +0 -1
  266. package/dist/protocol/AgentRegistry.js +0 -449
  267. package/dist/protocol/AgentRegistry.js.map +0 -1
  268. package/dist/protocol/DIDManager.d.ts +0 -289
  269. package/dist/protocol/DIDManager.d.ts.map +0 -1
  270. package/dist/protocol/DIDManager.js +0 -481
  271. package/dist/protocol/DIDManager.js.map +0 -1
  272. package/dist/protocol/DIDResolver.d.ts +0 -236
  273. package/dist/protocol/DIDResolver.d.ts.map +0 -1
  274. package/dist/protocol/DIDResolver.js +0 -495
  275. package/dist/protocol/DIDResolver.js.map +0 -1
  276. package/dist/runtime/BlockchainRuntime.d.ts +0 -360
  277. package/dist/runtime/BlockchainRuntime.d.ts.map +0 -1
  278. package/dist/runtime/BlockchainRuntime.js +0 -767
  279. package/dist/runtime/BlockchainRuntime.js.map +0 -1
  280. package/dist/runtime/IACTPRuntime.d.ts +0 -271
  281. package/dist/runtime/IACTPRuntime.d.ts.map +0 -1
  282. package/dist/runtime/IACTPRuntime.js +0 -15
  283. package/dist/runtime/IACTPRuntime.js.map +0 -1
  284. package/dist/runtime/MockRuntime.d.ts +0 -445
  285. package/dist/runtime/MockRuntime.d.ts.map +0 -1
  286. package/dist/runtime/MockRuntime.js +0 -1065
  287. package/dist/runtime/MockRuntime.js.map +0 -1
  288. package/dist/runtime/MockStateManager.d.ts +0 -233
  289. package/dist/runtime/MockStateManager.d.ts.map +0 -1
  290. package/dist/runtime/MockStateManager.js +0 -533
  291. package/dist/runtime/MockStateManager.js.map +0 -1
  292. package/dist/runtime/index.d.ts +0 -14
  293. package/dist/runtime/index.d.ts.map +0 -1
  294. package/dist/runtime/index.js +0 -42
  295. package/dist/runtime/index.js.map +0 -1
  296. package/dist/runtime/types/MockState.d.ts +0 -167
  297. package/dist/runtime/types/MockState.d.ts.map +0 -1
  298. package/dist/runtime/types/MockState.js +0 -43
  299. package/dist/runtime/types/MockState.js.map +0 -1
  300. package/dist/types/agent.d.ts +0 -76
  301. package/dist/types/agent.d.ts.map +0 -1
  302. package/dist/types/agent.js +0 -8
  303. package/dist/types/agent.js.map +0 -1
  304. package/dist/types/did.d.ts +0 -192
  305. package/dist/types/did.d.ts.map +0 -1
  306. package/dist/types/did.js +0 -38
  307. package/dist/types/did.js.map +0 -1
  308. package/dist/utils/ErrorRecoveryGuide.d.ts +0 -125
  309. package/dist/utils/ErrorRecoveryGuide.d.ts.map +0 -1
  310. package/dist/utils/ErrorRecoveryGuide.js +0 -579
  311. package/dist/utils/ErrorRecoveryGuide.js.map +0 -1
  312. package/dist/utils/Helpers.d.ts +0 -453
  313. package/dist/utils/Helpers.d.ts.map +0 -1
  314. package/dist/utils/Helpers.js +0 -623
  315. package/dist/utils/Helpers.js.map +0 -1
  316. package/dist/utils/Logger.d.ts +0 -195
  317. package/dist/utils/Logger.d.ts.map +0 -1
  318. package/dist/utils/Logger.js +0 -382
  319. package/dist/utils/Logger.js.map +0 -1
  320. package/dist/utils/RateLimiter.d.ts +0 -253
  321. package/dist/utils/RateLimiter.d.ts.map +0 -1
  322. package/dist/utils/RateLimiter.js +0 -424
  323. package/dist/utils/RateLimiter.js.map +0 -1
  324. package/dist/utils/SDKLifecycle.d.ts +0 -156
  325. package/dist/utils/SDKLifecycle.d.ts.map +0 -1
  326. package/dist/utils/SDKLifecycle.js +0 -347
  327. package/dist/utils/SDKLifecycle.js.map +0 -1
  328. package/dist/utils/SecureNonce.d.ts +0 -57
  329. package/dist/utils/SecureNonce.d.ts.map +0 -1
  330. package/dist/utils/SecureNonce.js +0 -80
  331. package/dist/utils/SecureNonce.js.map +0 -1
  332. package/dist/utils/Semaphore.d.ts +0 -123
  333. package/dist/utils/Semaphore.d.ts.map +0 -1
  334. package/dist/utils/Semaphore.js +0 -247
  335. package/dist/utils/Semaphore.js.map +0 -1
  336. package/dist/utils/UsedAttestationTracker.d.ts +0 -167
  337. package/dist/utils/UsedAttestationTracker.d.ts.map +0 -1
  338. package/dist/utils/UsedAttestationTracker.js +0 -309
  339. package/dist/utils/UsedAttestationTracker.js.map +0 -1
  340. package/dist/utils/fsSafe.d.ts +0 -14
  341. package/dist/utils/fsSafe.d.ts.map +0 -1
  342. package/dist/utils/fsSafe.js +0 -89
  343. package/dist/utils/fsSafe.js.map +0 -1
  344. package/dist/utils/index.d.ts +0 -15
  345. package/dist/utils/index.d.ts.map +0 -1
  346. package/dist/utils/index.js +0 -51
  347. package/dist/utils/index.js.map +0 -1
  348. package/dist/utils/security.d.ts +0 -147
  349. package/dist/utils/security.d.ts.map +0 -1
  350. package/dist/utils/security.js +0 -391
  351. package/dist/utils/security.js.map +0 -1
  352. package/src/abi/AgentRegistry.json +0 -782
  353. package/src/abi/IdentityRegistry.json +0 -316
  354. package/src/adapters/BaseAdapter.ts +0 -473
  355. package/src/adapters/BeginnerAdapter.ts +0 -232
  356. package/src/adapters/IntermediateAdapter.ts +0 -316
  357. package/src/adapters/index.ts +0 -25
  358. package/src/cli/commands/balance.ts +0 -110
  359. package/src/cli/commands/batch.ts +0 -487
  360. package/src/cli/commands/config.ts +0 -231
  361. package/src/cli/commands/init.ts +0 -161
  362. package/src/cli/commands/mint.ts +0 -116
  363. package/src/cli/commands/pay.ts +0 -113
  364. package/src/cli/commands/simulate.ts +0 -345
  365. package/src/cli/commands/time.ts +0 -303
  366. package/src/cli/commands/tx.ts +0 -448
  367. package/src/cli/commands/watch.ts +0 -211
  368. package/src/cli/index.ts +0 -116
  369. package/src/cli/utils/client.ts +0 -249
  370. package/src/cli/utils/config.ts +0 -282
  371. package/src/cli/utils/output.ts +0 -465
  372. package/src/level0/Provider.ts +0 -117
  373. package/src/level0/ServiceDirectory.ts +0 -131
  374. package/src/level0/index.ts +0 -10
  375. package/src/level0/provide.ts +0 -131
  376. package/src/level0/request.ts +0 -494
  377. package/src/level1/Agent.ts +0 -1432
  378. package/src/level1/index.ts +0 -10
  379. package/src/level1/pricing/PriceCalculator.ts +0 -255
  380. package/src/level1/pricing/PricingStrategy.ts +0 -198
  381. package/src/level1/types/Job.ts +0 -179
  382. package/src/level1/types/Options.ts +0 -291
  383. package/src/level1/types/index.ts +0 -8
  384. package/src/protocol/AgentRegistry.ts +0 -559
  385. package/src/protocol/DIDManager.ts +0 -629
  386. package/src/protocol/DIDResolver.ts +0 -554
  387. package/src/runtime/BlockchainRuntime.ts +0 -993
  388. package/src/runtime/IACTPRuntime.ts +0 -284
  389. package/src/runtime/MockRuntime.ts +0 -1244
  390. package/src/runtime/MockStateManager.ts +0 -576
  391. package/src/runtime/index.ts +0 -25
  392. package/src/runtime/types/MockState.ts +0 -227
  393. package/src/types/agent.ts +0 -79
  394. package/src/types/did.ts +0 -223
  395. package/src/utils/ErrorRecoveryGuide.ts +0 -675
  396. package/src/utils/Helpers.ts +0 -688
  397. package/src/utils/Logger.ts +0 -484
  398. package/src/utils/RateLimiter.ts +0 -534
  399. package/src/utils/SDKLifecycle.ts +0 -416
  400. package/src/utils/SecureNonce.ts +0 -78
  401. package/src/utils/Semaphore.ts +0 -276
  402. package/src/utils/UsedAttestationTracker.ts +0 -387
  403. package/src/utils/fsSafe.ts +0 -75
  404. package/src/utils/index.ts +0 -80
  405. package/src/utils/security.ts +0 -418
@@ -1,675 +0,0 @@
1
- /**
2
- * ErrorRecoveryGuide - Structured Error Classification and Recovery Guidance
3
- *
4
- * SECURITY FIX (HIGH-6): Provides comprehensive error recovery documentation
5
- * to help developers handle errors appropriately and avoid security pitfalls.
6
- *
7
- * @module utils/ErrorRecoveryGuide
8
- */
9
-
10
- /**
11
- * Error severity levels for prioritization
12
- */
13
- export type ErrorSeverity = 'critical' | 'high' | 'medium' | 'low';
14
-
15
- /**
16
- * Error categories for classification
17
- */
18
- export type ErrorCategory =
19
- | 'network' // Network/RPC issues
20
- | 'authentication' // Signer/key issues
21
- | 'validation' // Input validation failures
22
- | 'state' // Invalid state transitions
23
- | 'escrow' // Escrow/fund issues
24
- | 'attestation' // EAS/attestation issues
25
- | 'permission' // Access control issues
26
- | 'timeout' // Deadline/timeout issues
27
- | 'unknown'; // Unclassified errors
28
-
29
- /**
30
- * Structured error recovery information
31
- */
32
- export interface ErrorRecoveryInfo {
33
- /** Error category */
34
- category: ErrorCategory;
35
- /** Severity level */
36
- severity: ErrorSeverity;
37
- /** Human-readable description */
38
- description: string;
39
- /** Recovery steps to attempt */
40
- recoverySteps: string[];
41
- /** Whether the operation can be safely retried */
42
- retryable: boolean;
43
- /** Suggested retry delay in milliseconds (if retryable) */
44
- retryDelayMs?: number;
45
- /** Maximum retry attempts (if retryable) */
46
- maxRetries?: number;
47
- /** Whether user intervention is required */
48
- requiresUserAction: boolean;
49
- /** Security implications to be aware of */
50
- securityNotes?: string[];
51
- }
52
-
53
- /**
54
- * Error pattern for matching
55
- */
56
- interface ErrorPattern {
57
- /** Pattern to match (string contains or regex) */
58
- pattern: string | RegExp;
59
- /** Recovery information */
60
- recovery: ErrorRecoveryInfo;
61
- }
62
-
63
- /**
64
- * Predefined error patterns and their recovery guidance
65
- */
66
- const ERROR_PATTERNS: ErrorPattern[] = [
67
- // Network Errors
68
- {
69
- pattern: /provider connection lost/i,
70
- recovery: {
71
- category: 'network',
72
- severity: 'high',
73
- description: 'Lost connection to the blockchain RPC provider',
74
- recoverySteps: [
75
- '1. Check your internet connection',
76
- '2. Verify RPC endpoint is reachable',
77
- '3. SDK will automatically attempt reconnection with exponential backoff',
78
- '4. If persistent, try a different RPC provider',
79
- '5. Check RPC rate limits (may need paid tier)',
80
- ],
81
- retryable: true,
82
- retryDelayMs: 1000,
83
- maxRetries: 5,
84
- requiresUserAction: false,
85
- securityNotes: [
86
- 'Do not expose RPC URLs with API keys in client-side code',
87
- 'Consider using a fallback RPC provider',
88
- ],
89
- },
90
- },
91
- {
92
- pattern: /nonce too low/i,
93
- recovery: {
94
- category: 'network',
95
- severity: 'medium',
96
- description: 'Transaction nonce is out of sync with blockchain',
97
- recoverySteps: [
98
- '1. Wait for pending transactions to confirm',
99
- '2. Reset transaction nonce manually if needed',
100
- '3. Use getTransactionCount("pending") for accurate nonce',
101
- ],
102
- retryable: true,
103
- retryDelayMs: 5000,
104
- maxRetries: 3,
105
- requiresUserAction: false,
106
- },
107
- },
108
- {
109
- pattern: /replacement transaction underpriced/i,
110
- recovery: {
111
- category: 'network',
112
- severity: 'medium',
113
- description: 'Transaction fee too low for replacement',
114
- recoverySteps: [
115
- '1. Increase gas price by at least 10%',
116
- '2. Wait for original transaction to be mined',
117
- '3. Or wait for it to be dropped from mempool',
118
- ],
119
- retryable: true,
120
- retryDelayMs: 10000,
121
- maxRetries: 2,
122
- requiresUserAction: true,
123
- },
124
- },
125
-
126
- // Authentication Errors
127
- {
128
- pattern: /privateKey is required/i,
129
- recovery: {
130
- category: 'authentication',
131
- severity: 'critical',
132
- description: 'Missing private key for blockchain operations',
133
- recoverySteps: [
134
- '1. Provide privateKey in ACTPClient.create() config',
135
- '2. Use environment variables (process.env.PRIVATE_KEY)',
136
- '3. NEVER hardcode private keys in source code',
137
- ],
138
- retryable: false,
139
- requiresUserAction: true,
140
- securityNotes: [
141
- 'Never log or expose private keys',
142
- 'Use hardware wallets in production',
143
- 'Store keys in secure environment variables',
144
- ],
145
- },
146
- },
147
- {
148
- pattern: /not initialized.*call initialize/i,
149
- recovery: {
150
- category: 'authentication',
151
- severity: 'high',
152
- description: 'BlockchainRuntime not properly initialized',
153
- recoverySteps: [
154
- '1. Ensure await runtime.initialize() is called after construction',
155
- '2. Use ACTPClient.create() factory which handles initialization',
156
- '3. Check for initialization errors in try/catch',
157
- ],
158
- retryable: false,
159
- requiresUserAction: true,
160
- },
161
- },
162
-
163
- // Validation Errors
164
- {
165
- pattern: /invalid.*address/i,
166
- recovery: {
167
- category: 'validation',
168
- severity: 'medium',
169
- description: 'Invalid Ethereum address format',
170
- recoverySteps: [
171
- '1. Verify address is 0x-prefixed',
172
- '2. Verify address is 40 hex characters (42 total)',
173
- '3. Use ethers.isAddress() to validate before passing',
174
- ],
175
- retryable: false,
176
- requiresUserAction: true,
177
- },
178
- },
179
- {
180
- pattern: /amount must be positive/i,
181
- recovery: {
182
- category: 'validation',
183
- severity: 'medium',
184
- description: 'Transaction amount must be greater than zero',
185
- recoverySteps: [
186
- '1. Verify amount is a positive number',
187
- '2. Check for unit conversion issues (USDC has 6 decimals)',
188
- '3. Use parseUnits("100", 6) for 100 USDC',
189
- ],
190
- retryable: false,
191
- requiresUserAction: true,
192
- },
193
- },
194
- {
195
- pattern: /deadline must be in the future/i,
196
- recovery: {
197
- category: 'validation',
198
- severity: 'medium',
199
- description: 'Transaction deadline has already passed',
200
- recoverySteps: [
201
- '1. Set deadline to a future timestamp',
202
- '2. Use relative format like "+24h" or "+7d"',
203
- '3. Account for block time variations',
204
- ],
205
- retryable: false,
206
- requiresUserAction: true,
207
- },
208
- },
209
-
210
- // State Errors
211
- {
212
- pattern: /invalid state transition/i,
213
- recovery: {
214
- category: 'state',
215
- severity: 'high',
216
- description: 'Cannot transition from current state to requested state',
217
- recoverySteps: [
218
- '1. Check current transaction state with getTransaction()',
219
- '2. Verify state transition is allowed (see ACTP state machine)',
220
- '3. Valid transitions: INITIATED->COMMITTED->DELIVERED->SETTLED',
221
- ],
222
- retryable: false,
223
- requiresUserAction: true,
224
- },
225
- },
226
- {
227
- pattern: /cannot link escrow.*state/i,
228
- recovery: {
229
- category: 'state',
230
- severity: 'high',
231
- description: 'Escrow can only be linked in INITIATED or QUOTED state',
232
- recoverySteps: [
233
- '1. Check transaction state with getTransaction()',
234
- '2. linkEscrow() only works in INITIATED or QUOTED state',
235
- '3. Create a new transaction if needed',
236
- ],
237
- retryable: false,
238
- requiresUserAction: true,
239
- },
240
- },
241
- {
242
- pattern: /unknown transaction state/i,
243
- recovery: {
244
- category: 'state',
245
- severity: 'critical',
246
- description: 'Contract returned unexpected state value',
247
- recoverySteps: [
248
- '1. Check SDK version matches contract version',
249
- '2. Verify contract address is correct',
250
- '3. Contact support - may indicate contract upgrade needed',
251
- ],
252
- retryable: false,
253
- requiresUserAction: true,
254
- securityNotes: [
255
- 'Unknown states may indicate contract tampering',
256
- 'Verify contract address against official deployment',
257
- ],
258
- },
259
- },
260
-
261
- // Escrow Errors
262
- {
263
- pattern: /insufficient.*balance/i,
264
- recovery: {
265
- category: 'escrow',
266
- severity: 'high',
267
- description: 'Insufficient token balance for escrow deposit',
268
- recoverySteps: [
269
- '1. Check USDC balance with getBalance()',
270
- '2. Ensure sufficient USDC to cover amount + gas',
271
- '3. In mock mode: use mintTokens() to add funds',
272
- '4. In testnet: get USDC from faucet',
273
- ],
274
- retryable: false,
275
- requiresUserAction: true,
276
- },
277
- },
278
- {
279
- pattern: /escrow.*not found/i,
280
- recovery: {
281
- category: 'escrow',
282
- severity: 'high',
283
- description: 'Referenced escrow does not exist',
284
- recoverySteps: [
285
- '1. Verify escrowId is correct',
286
- '2. Check if escrow was already released',
287
- '3. Use getTransaction() to find linked escrowId',
288
- ],
289
- retryable: false,
290
- requiresUserAction: true,
291
- },
292
- },
293
-
294
- // Attestation Errors
295
- {
296
- pattern: /attestation.*required.*escrow release/i,
297
- recovery: {
298
- category: 'attestation',
299
- severity: 'critical',
300
- description: 'Attestation verification required before escrow release',
301
- recoverySteps: [
302
- '1. Provider must submit delivery attestation via EAS',
303
- '2. Pass attestationParams to releaseEscrow()',
304
- '3. attestationParams: { txId, attestationUID }',
305
- '4. Verify attestation is not revoked before using',
306
- ],
307
- retryable: false,
308
- requiresUserAction: true,
309
- securityNotes: [
310
- 'Never release escrow without valid attestation',
311
- 'Attestation prevents fund theft',
312
- ],
313
- },
314
- },
315
- {
316
- pattern: /attestation.*already used/i,
317
- recovery: {
318
- category: 'attestation',
319
- severity: 'critical',
320
- description: 'Attestation has been used for a different transaction',
321
- recoverySteps: [
322
- '1. This may indicate a replay attack attempt',
323
- '2. Verify the attestation belongs to this transaction',
324
- '3. Provider must create new attestation for this transaction',
325
- ],
326
- retryable: false,
327
- requiresUserAction: true,
328
- securityNotes: [
329
- 'Attestation replay is a security vulnerability',
330
- 'Each transaction needs unique attestation',
331
- ],
332
- },
333
- },
334
- {
335
- pattern: /nonce replay detected/i,
336
- recovery: {
337
- category: 'attestation',
338
- severity: 'critical',
339
- description: 'Message nonce has been reused (replay attack prevention)',
340
- recoverySteps: [
341
- '1. Use NonceManager to generate fresh nonces',
342
- '2. Nonces must be monotonically increasing per sender',
343
- '3. Do not reuse nonces from previous messages',
344
- ],
345
- retryable: false,
346
- requiresUserAction: true,
347
- securityNotes: [
348
- 'Nonce replay is a serious security vulnerability',
349
- 'Indicates potential message replay attack',
350
- ],
351
- },
352
- },
353
- {
354
- pattern: /global nonce tracker limit reached/i,
355
- recovery: {
356
- category: 'attestation',
357
- severity: 'high',
358
- description: 'Nonce tracker memory limit reached (DoS protection)',
359
- recoverySteps: [
360
- '1. This may indicate a DoS attack with many sender addresses',
361
- '2. Clean up old nonce entries if legitimate traffic',
362
- '3. Increase maxTotalEntries limit if needed',
363
- '4. Consider using persistent storage for large deployments',
364
- ],
365
- retryable: false,
366
- requiresUserAction: true,
367
- securityNotes: [
368
- 'Global limit prevents memory exhaustion attacks',
369
- 'Monitor for unusual sender patterns',
370
- ],
371
- },
372
- },
373
-
374
- // Permission Errors
375
- {
376
- pattern: /only available in mock mode/i,
377
- recovery: {
378
- category: 'permission',
379
- severity: 'low',
380
- description: 'Method only available in local development mode',
381
- recoverySteps: [
382
- '1. This method (reset/mintTokens) is for testing only',
383
- '2. In testnet/mainnet, use actual faucets for tokens',
384
- '3. Consider switching to mock mode for local testing',
385
- ],
386
- retryable: false,
387
- requiresUserAction: true,
388
- },
389
- },
390
- {
391
- pattern: /cannot pay yourself/i,
392
- recovery: {
393
- category: 'permission',
394
- severity: 'medium',
395
- description: 'Requester and provider cannot be the same address',
396
- recoverySteps: [
397
- '1. Use different addresses for requester and provider',
398
- '2. Verify provider address is correct',
399
- ],
400
- retryable: false,
401
- requiresUserAction: true,
402
- },
403
- },
404
-
405
- // Timeout Errors
406
- {
407
- pattern: /deadline.*passed/i,
408
- recovery: {
409
- category: 'timeout',
410
- severity: 'high',
411
- description: 'Transaction deadline has expired',
412
- recoverySteps: [
413
- '1. Transaction can no longer be accepted after deadline',
414
- '2. Create a new transaction with longer deadline',
415
- '3. Consider using cancel if still in INITIATED state',
416
- ],
417
- retryable: false,
418
- requiresUserAction: true,
419
- },
420
- },
421
- {
422
- pattern: /dispute window.*active/i,
423
- recovery: {
424
- category: 'timeout',
425
- severity: 'medium',
426
- description: 'Cannot finalize during active dispute window',
427
- recoverySteps: [
428
- '1. Wait for dispute window to expire',
429
- '2. Check transaction.completedAt + disputeWindow',
430
- '3. Default dispute window is 48 hours',
431
- ],
432
- retryable: true,
433
- retryDelayMs: 60000, // Check every minute
434
- maxRetries: 1000,
435
- requiresUserAction: false,
436
- },
437
- },
438
- ];
439
-
440
- /**
441
- * Default recovery info for unclassified errors
442
- */
443
- const DEFAULT_RECOVERY: ErrorRecoveryInfo = {
444
- category: 'unknown',
445
- severity: 'medium',
446
- description: 'An unexpected error occurred',
447
- recoverySteps: [
448
- '1. Check error message for specific details',
449
- '2. Verify all input parameters are correct',
450
- '3. Check network connectivity',
451
- '4. Review SDK documentation',
452
- '5. If persistent, report issue with full error details',
453
- ],
454
- retryable: false,
455
- requiresUserAction: true,
456
- securityNotes: [
457
- 'Do not include sensitive data in error reports',
458
- 'Never expose private keys or secrets',
459
- ],
460
- };
461
-
462
- /**
463
- * ErrorRecoveryGuide - Utility for error classification and recovery guidance
464
- *
465
- * @example
466
- * ```typescript
467
- * try {
468
- * await client.beginner.pay({ to: provider, amount: '100' });
469
- * } catch (error) {
470
- * const recovery = ErrorRecoveryGuide.analyze(error);
471
- * console.log('Category:', recovery.category);
472
- * console.log('Steps:', recovery.recoverySteps.join('\n'));
473
- *
474
- * if (recovery.retryable) {
475
- * console.log(`Retrying in ${recovery.retryDelayMs}ms...`);
476
- * }
477
- * }
478
- * ```
479
- */
480
- export class ErrorRecoveryGuide {
481
- /**
482
- * Analyze an error and return recovery guidance
483
- *
484
- * @param error - The error to analyze
485
- * @returns Recovery information with steps and recommendations
486
- */
487
- static analyze(error: unknown): ErrorRecoveryInfo {
488
- const errorMessage = error instanceof Error ? error.message : String(error);
489
-
490
- // Find matching pattern
491
- for (const pattern of ERROR_PATTERNS) {
492
- const matches =
493
- typeof pattern.pattern === 'string'
494
- ? errorMessage.toLowerCase().includes(pattern.pattern.toLowerCase())
495
- : pattern.pattern.test(errorMessage);
496
-
497
- if (matches) {
498
- return {
499
- ...pattern.recovery,
500
- description: `${pattern.recovery.description}: ${errorMessage}`,
501
- };
502
- }
503
- }
504
-
505
- // Return default recovery if no pattern matched
506
- return {
507
- ...DEFAULT_RECOVERY,
508
- description: `${DEFAULT_RECOVERY.description}: ${errorMessage}`,
509
- };
510
- }
511
-
512
- /**
513
- * Get all known error patterns (for documentation/testing)
514
- */
515
- static getKnownPatterns(): string[] {
516
- return ERROR_PATTERNS.map((p) =>
517
- typeof p.pattern === 'string' ? p.pattern : p.pattern.source
518
- );
519
- }
520
-
521
- /**
522
- * Check if an error is retryable
523
- *
524
- * @param error - The error to check
525
- * @returns true if the error can be retried
526
- */
527
- static isRetryable(error: unknown): boolean {
528
- const recovery = this.analyze(error);
529
- return recovery.retryable;
530
- }
531
-
532
- /**
533
- * Get retry parameters for an error
534
- *
535
- * @param error - The error to check
536
- * @returns Retry parameters or null if not retryable
537
- */
538
- static getRetryParams(
539
- error: unknown
540
- ): { delayMs: number; maxRetries: number } | null {
541
- const recovery = this.analyze(error);
542
-
543
- if (!recovery.retryable) {
544
- return null;
545
- }
546
-
547
- return {
548
- delayMs: recovery.retryDelayMs || 1000,
549
- maxRetries: recovery.maxRetries || 3,
550
- };
551
- }
552
-
553
- /**
554
- * Check if an error requires user action
555
- *
556
- * @param error - The error to check
557
- * @returns true if user intervention is needed
558
- */
559
- static requiresUserAction(error: unknown): boolean {
560
- const recovery = this.analyze(error);
561
- return recovery.requiresUserAction;
562
- }
563
-
564
- /**
565
- * Get security notes for an error (if any)
566
- *
567
- * @param error - The error to check
568
- * @returns Security notes or undefined
569
- */
570
- static getSecurityNotes(error: unknown): string[] | undefined {
571
- const recovery = this.analyze(error);
572
- return recovery.securityNotes;
573
- }
574
-
575
- /**
576
- * Format recovery guidance as a string for logging
577
- *
578
- * @param error - The error to analyze
579
- * @returns Formatted recovery guidance string
580
- */
581
- static formatGuidance(error: unknown): string {
582
- const recovery = this.analyze(error);
583
-
584
- let output = `
585
- ================================================================================
586
- ERROR RECOVERY GUIDANCE
587
- ================================================================================
588
- Category: ${recovery.category.toUpperCase()}
589
- Severity: ${recovery.severity.toUpperCase()}
590
- Description: ${recovery.description}
591
-
592
- Recovery Steps:
593
- ${recovery.recoverySteps.join('\n')}
594
-
595
- Retryable: ${recovery.retryable ? 'Yes' : 'No'}`;
596
-
597
- if (recovery.retryable) {
598
- output += `
599
- Retry Delay: ${recovery.retryDelayMs || 1000}ms
600
- Max Retries: ${recovery.maxRetries || 3}`;
601
- }
602
-
603
- output += `
604
- User Action: ${recovery.requiresUserAction ? 'Required' : 'Not Required'}`;
605
-
606
- if (recovery.securityNotes && recovery.securityNotes.length > 0) {
607
- output += `
608
-
609
- Security Notes:
610
- ${recovery.securityNotes.map((n) => ` ! ${n}`).join('\n')}`;
611
- }
612
-
613
- output += '\n================================================================================';
614
-
615
- return output;
616
- }
617
- }
618
-
619
- /**
620
- * Helper function for try-catch with automatic recovery guidance
621
- *
622
- * @example
623
- * ```typescript
624
- * const result = await withRecoveryGuidance(
625
- * () => client.beginner.pay({ to: provider, amount: '100' }),
626
- * { logGuidance: true, autoRetry: true }
627
- * );
628
- * ```
629
- */
630
- export async function withRecoveryGuidance<T>(
631
- operation: () => Promise<T>,
632
- options: {
633
- logGuidance?: boolean;
634
- autoRetry?: boolean;
635
- onError?: (error: unknown, recovery: ErrorRecoveryInfo) => void;
636
- } = {}
637
- ): Promise<T> {
638
- const { logGuidance = false, autoRetry = false, onError } = options;
639
-
640
- let lastError: unknown;
641
- let attempts = 0;
642
-
643
- do {
644
- try {
645
- return await operation();
646
- } catch (error) {
647
- lastError = error;
648
- const recovery = ErrorRecoveryGuide.analyze(error);
649
-
650
- if (onError) {
651
- onError(error, recovery);
652
- }
653
-
654
- if (logGuidance) {
655
- console.error(ErrorRecoveryGuide.formatGuidance(error));
656
- }
657
-
658
- if (autoRetry && recovery.retryable) {
659
- const retryParams = ErrorRecoveryGuide.getRetryParams(error);
660
- if (retryParams && attempts < retryParams.maxRetries) {
661
- attempts++;
662
- console.log(
663
- `Retrying (${attempts}/${retryParams.maxRetries}) after ${retryParams.delayMs}ms...`
664
- );
665
- await new Promise((resolve) =>
666
- setTimeout(resolve, retryParams.delayMs)
667
- );
668
- continue;
669
- }
670
- }
671
-
672
- throw error;
673
- }
674
- } while (true);
675
- }