@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
@@ -0,0 +1,382 @@
1
+ /**
2
+ * EventMonitor Test Suite
3
+ *
4
+ * Coverage Target: 80%+ (statements, functions, lines, branches)
5
+ *
6
+ * Test Categories:
7
+ * 1. Event Watching (3 tests)
8
+ * 2. State Monitoring (3 tests)
9
+ * 3. Transaction History (3 tests)
10
+ * 4. Event Subscriptions (3 tests)
11
+ *
12
+ * References:
13
+ * - EventMonitor.ts implementation
14
+ */
15
+
16
+ import { EventMonitor } from '../../protocol/EventMonitor';
17
+ import { State } from '../../types';
18
+
19
+ // Mock contract
20
+ const mockKernelContract = {
21
+ filters: {
22
+ StateTransitioned: jest.fn(),
23
+ TransactionCreated: jest.fn(),
24
+ EscrowReleased: jest.fn()
25
+ },
26
+ on: jest.fn(),
27
+ off: jest.fn(),
28
+ queryFilter: jest.fn(),
29
+ transactions: jest.fn()
30
+ };
31
+
32
+ const mockEscrowContract = {};
33
+
34
+ describe('EventMonitor - Event Watching & Subscriptions', () => {
35
+ let eventMonitor: EventMonitor;
36
+
37
+ beforeEach(() => {
38
+ jest.clearAllMocks();
39
+ eventMonitor = new EventMonitor(
40
+ mockKernelContract as any,
41
+ mockEscrowContract as any
42
+ );
43
+ });
44
+
45
+ describe('watchTransaction - Event Listening', () => {
46
+ it('should set up event listener for transaction state changes', () => {
47
+ const txId = '0x' + '1'.repeat(64);
48
+ const mockFilter = { address: 'mock-filter' };
49
+ const callback = jest.fn();
50
+
51
+ mockKernelContract.filters.StateTransitioned.mockReturnValue(mockFilter);
52
+
53
+ const cleanup = eventMonitor.watchTransaction(txId, callback);
54
+
55
+ expect(mockKernelContract.filters.StateTransitioned).toHaveBeenCalledWith(txId);
56
+ expect(mockKernelContract.on).toHaveBeenCalledWith(mockFilter, expect.any(Function));
57
+ expect(typeof cleanup).toBe('function');
58
+ });
59
+
60
+ it('should invoke callback when state transition event occurs', () => {
61
+ const txId = '0x' + '1'.repeat(64);
62
+ const mockFilter = { address: 'mock-filter' };
63
+ const callback = jest.fn();
64
+
65
+ mockKernelContract.filters.StateTransitioned.mockReturnValue(mockFilter);
66
+
67
+ let eventListener: any;
68
+ mockKernelContract.on.mockImplementation((_filter, listener) => {
69
+ eventListener = listener;
70
+ });
71
+
72
+ eventMonitor.watchTransaction(txId, callback);
73
+
74
+ // Simulate state transition event
75
+ const mockEvent = { blockNumber: 12345 };
76
+ eventListener(txId, State.INITIATED, State.QUOTED, mockEvent);
77
+
78
+ expect(callback).toHaveBeenCalledWith(State.QUOTED);
79
+ });
80
+
81
+ it('should remove event listener when cleanup function is called', () => {
82
+ const txId = '0x' + '1'.repeat(64);
83
+ const mockFilter = { address: 'mock-filter' };
84
+ const callback = jest.fn();
85
+
86
+ mockKernelContract.filters.StateTransitioned.mockReturnValue(mockFilter);
87
+
88
+ const cleanup = eventMonitor.watchTransaction(txId, callback);
89
+ cleanup();
90
+
91
+ expect(mockKernelContract.off).toHaveBeenCalledWith(mockFilter, expect.any(Function));
92
+ });
93
+ });
94
+
95
+ describe('waitForState - Async State Monitoring', () => {
96
+ it('should resolve when target state is reached', async () => {
97
+ const txId = '0x' + '1'.repeat(64);
98
+ const mockFilter = { address: 'mock-filter' };
99
+
100
+ mockKernelContract.filters.StateTransitioned.mockReturnValue(mockFilter);
101
+
102
+ let eventListener: any;
103
+ mockKernelContract.on.mockImplementation((_filter, listener) => {
104
+ eventListener = listener;
105
+ });
106
+
107
+ const waitPromise = eventMonitor.waitForState(txId, State.DELIVERED, 5000);
108
+
109
+ // Simulate state transition to target state
110
+ setTimeout(() => {
111
+ const mockEvent = { blockNumber: 12345 };
112
+ eventListener(txId, State.IN_PROGRESS, State.DELIVERED, mockEvent);
113
+ }, 100);
114
+
115
+ await expect(waitPromise).resolves.toBeUndefined();
116
+ });
117
+
118
+ it('should reject with timeout error if target state not reached', async () => {
119
+ const txId = '0x' + '1'.repeat(64);
120
+ const mockFilter = { address: 'mock-filter' };
121
+
122
+ mockKernelContract.filters.StateTransitioned.mockReturnValue(mockFilter);
123
+
124
+ const waitPromise = eventMonitor.waitForState(txId, State.DELIVERED, 100);
125
+
126
+ await expect(waitPromise).rejects.toThrow('Timeout waiting for state DELIVERED');
127
+ });
128
+
129
+ it('should ignore non-matching state transitions', async () => {
130
+ const txId = '0x' + '1'.repeat(64);
131
+ const mockFilter = { address: 'mock-filter' };
132
+
133
+ mockKernelContract.filters.StateTransitioned.mockReturnValue(mockFilter);
134
+
135
+ let eventListener: any;
136
+ mockKernelContract.on.mockImplementation((_filter, listener) => {
137
+ eventListener = listener;
138
+ });
139
+
140
+ const waitPromise = eventMonitor.waitForState(txId, State.DELIVERED, 1000);
141
+
142
+ // Simulate state transitions to non-target states
143
+ setTimeout(() => {
144
+ const mockEvent = { blockNumber: 12345 };
145
+ eventListener(txId, State.INITIATED, State.QUOTED, mockEvent);
146
+ eventListener(txId, State.QUOTED, State.COMMITTED, mockEvent);
147
+ }, 100);
148
+
149
+ // Then emit target state
150
+ setTimeout(() => {
151
+ const mockEvent = { blockNumber: 12346 };
152
+ eventListener(txId, State.COMMITTED, State.DELIVERED, mockEvent);
153
+ }, 200);
154
+
155
+ await expect(waitPromise).resolves.toBeUndefined();
156
+ });
157
+ });
158
+
159
+ describe('getTransactionHistory - Historical Data', () => {
160
+ it('should fetch transaction history for requester', async () => {
161
+ const requesterAddress = '0x' + 'a'.repeat(40);
162
+ const mockFilter = { address: 'mock-filter' };
163
+
164
+ mockKernelContract.filters.TransactionCreated.mockReturnValue(mockFilter);
165
+
166
+ const mockEvents = [
167
+ {
168
+ args: {
169
+ transactionId: '0x' + '1'.repeat(64)
170
+ }
171
+ },
172
+ {
173
+ args: {
174
+ transactionId: '0x' + '2'.repeat(64)
175
+ }
176
+ }
177
+ ];
178
+
179
+ mockKernelContract.queryFilter.mockResolvedValue(mockEvents);
180
+
181
+ mockKernelContract.transactions.mockImplementation((txId: string) => {
182
+ return Promise.resolve({
183
+ transactionId: txId,
184
+ requester: requesterAddress,
185
+ provider: '0x' + 'b'.repeat(40),
186
+ amount: BigInt('100000000'),
187
+ state: State.INITIATED,
188
+ createdAt: BigInt(Math.floor(Date.now() / 1000)),
189
+ deadline: BigInt(Math.floor(Date.now() / 1000) + 86400),
190
+ disputeWindow: BigInt(7200),
191
+ escrowContract: '0x' + 'c'.repeat(40),
192
+ escrowId: '0x' + '3'.repeat(64),
193
+ serviceHash: '0x0000000000000000000000000000000000000000000000000000000000000000'
194
+ });
195
+ });
196
+
197
+ const transactions = await eventMonitor.getTransactionHistory(requesterAddress, 'requester');
198
+
199
+ expect(mockKernelContract.filters.TransactionCreated).toHaveBeenCalledWith(null, null, requesterAddress);
200
+ expect(transactions).toHaveLength(2);
201
+ expect(transactions[0].txId).toBe('0x' + '1'.repeat(64));
202
+ expect(transactions[1].txId).toBe('0x' + '2'.repeat(64));
203
+ });
204
+
205
+ it('should fetch transaction history for provider', async () => {
206
+ const providerAddress = '0x' + 'b'.repeat(40);
207
+ const mockFilter = { address: 'mock-filter' };
208
+
209
+ mockKernelContract.filters.TransactionCreated.mockReturnValue(mockFilter);
210
+ mockKernelContract.queryFilter.mockResolvedValue([]);
211
+
212
+ await eventMonitor.getTransactionHistory(providerAddress, 'provider');
213
+
214
+ expect(mockKernelContract.filters.TransactionCreated).toHaveBeenCalledWith(null, providerAddress, null);
215
+ });
216
+
217
+ it('should default to requester role if not specified', async () => {
218
+ const address = '0x' + 'a'.repeat(40);
219
+ const mockFilter = { address: 'mock-filter' };
220
+
221
+ mockKernelContract.filters.TransactionCreated.mockReturnValue(mockFilter);
222
+ mockKernelContract.queryFilter.mockResolvedValue([]);
223
+
224
+ await eventMonitor.getTransactionHistory(address);
225
+
226
+ expect(mockKernelContract.filters.TransactionCreated).toHaveBeenCalledWith(null, null, address);
227
+ });
228
+ });
229
+
230
+ describe('onTransactionCreated - Event Subscription', () => {
231
+ it('should subscribe to transaction creation events', () => {
232
+ const mockFilter = { address: 'mock-filter' };
233
+ const callback = jest.fn();
234
+
235
+ mockKernelContract.filters.TransactionCreated.mockReturnValue(mockFilter);
236
+
237
+ const cleanup = eventMonitor.onTransactionCreated(callback);
238
+
239
+ expect(mockKernelContract.filters.TransactionCreated).toHaveBeenCalledWith();
240
+ expect(mockKernelContract.on).toHaveBeenCalledWith(mockFilter, expect.any(Function));
241
+ expect(typeof cleanup).toBe('function');
242
+ });
243
+
244
+ it('should invoke callback when transaction is created', () => {
245
+ const mockFilter = { address: 'mock-filter' };
246
+ const callback = jest.fn();
247
+
248
+ mockKernelContract.filters.TransactionCreated.mockReturnValue(mockFilter);
249
+
250
+ let eventListener: any;
251
+ mockKernelContract.on.mockImplementation((_filter, listener) => {
252
+ eventListener = listener;
253
+ });
254
+
255
+ eventMonitor.onTransactionCreated(callback);
256
+
257
+ // Simulate TransactionCreated event
258
+ const mockEvent = { blockNumber: 12345 };
259
+ const txId = '0x' + '1'.repeat(64);
260
+ const provider = '0x' + 'b'.repeat(40);
261
+ const requester = '0x' + 'a'.repeat(40);
262
+ const amount = BigInt('100000000');
263
+
264
+ eventListener(txId, provider, requester, amount, mockEvent);
265
+
266
+ expect(callback).toHaveBeenCalledWith({
267
+ txId,
268
+ provider,
269
+ requester,
270
+ amount
271
+ });
272
+ });
273
+
274
+ it('should remove listener when cleanup function is called', () => {
275
+ const mockFilter = { address: 'mock-filter' };
276
+ const callback = jest.fn();
277
+
278
+ mockKernelContract.filters.TransactionCreated.mockReturnValue(mockFilter);
279
+
280
+ const cleanup = eventMonitor.onTransactionCreated(callback);
281
+ cleanup();
282
+
283
+ expect(mockKernelContract.off).toHaveBeenCalledWith(mockFilter, expect.any(Function));
284
+ });
285
+ });
286
+
287
+ describe('onStateChanged - State Change Subscription', () => {
288
+ it('should subscribe to state change events', () => {
289
+ const mockFilter = { address: 'mock-filter' };
290
+ const callback = jest.fn();
291
+
292
+ mockKernelContract.filters.StateTransitioned.mockReturnValue(mockFilter);
293
+
294
+ const cleanup = eventMonitor.onStateChanged(callback);
295
+
296
+ expect(mockKernelContract.filters.StateTransitioned).toHaveBeenCalledWith();
297
+ expect(mockKernelContract.on).toHaveBeenCalledWith(mockFilter, expect.any(Function));
298
+ expect(typeof cleanup).toBe('function');
299
+ });
300
+
301
+ it('should invoke callback with state transition details', () => {
302
+ const mockFilter = { address: 'mock-filter' };
303
+ const callback = jest.fn();
304
+
305
+ mockKernelContract.filters.StateTransitioned.mockReturnValue(mockFilter);
306
+
307
+ let eventListener: any;
308
+ mockKernelContract.on.mockImplementation((_filter, listener) => {
309
+ eventListener = listener;
310
+ });
311
+
312
+ eventMonitor.onStateChanged(callback);
313
+
314
+ // Simulate StateTransitioned event
315
+ const txId = '0x' + '1'.repeat(64);
316
+ eventListener(txId, State.INITIATED, State.QUOTED);
317
+
318
+ expect(callback).toHaveBeenCalledWith(txId, State.INITIATED, State.QUOTED);
319
+ });
320
+
321
+ it('should remove listener when cleanup function is called', () => {
322
+ const mockFilter = { address: 'mock-filter' };
323
+ const callback = jest.fn();
324
+
325
+ mockKernelContract.filters.StateTransitioned.mockReturnValue(mockFilter);
326
+
327
+ const cleanup = eventMonitor.onStateChanged(callback);
328
+ cleanup();
329
+
330
+ expect(mockKernelContract.off).toHaveBeenCalledWith(mockFilter, expect.any(Function));
331
+ });
332
+ });
333
+
334
+ describe('onEscrowReleased - Escrow Release Subscription', () => {
335
+ it('should subscribe to escrow release events', () => {
336
+ const mockFilter = { address: 'mock-filter' };
337
+ const callback = jest.fn();
338
+
339
+ mockKernelContract.filters.EscrowReleased.mockReturnValue(mockFilter);
340
+
341
+ const cleanup = eventMonitor.onEscrowReleased(callback);
342
+
343
+ expect(mockKernelContract.filters.EscrowReleased).toHaveBeenCalledWith();
344
+ expect(mockKernelContract.on).toHaveBeenCalledWith(mockFilter, expect.any(Function));
345
+ expect(typeof cleanup).toBe('function');
346
+ });
347
+
348
+ it('should invoke callback when escrow is released', () => {
349
+ const mockFilter = { address: 'mock-filter' };
350
+ const callback = jest.fn();
351
+
352
+ mockKernelContract.filters.EscrowReleased.mockReturnValue(mockFilter);
353
+
354
+ let eventListener: any;
355
+ mockKernelContract.on.mockImplementation((_filter, listener) => {
356
+ eventListener = listener;
357
+ });
358
+
359
+ eventMonitor.onEscrowReleased(callback);
360
+
361
+ // Simulate EscrowReleased event
362
+ const txId = '0x' + '1'.repeat(64);
363
+ const amount = BigInt('100000000');
364
+
365
+ eventListener(txId, amount);
366
+
367
+ expect(callback).toHaveBeenCalledWith(txId, amount);
368
+ });
369
+
370
+ it('should remove listener when cleanup function is called', () => {
371
+ const mockFilter = { address: 'mock-filter' };
372
+ const callback = jest.fn();
373
+
374
+ mockKernelContract.filters.EscrowReleased.mockReturnValue(mockFilter);
375
+
376
+ const cleanup = eventMonitor.onEscrowReleased(callback);
377
+ cleanup();
378
+
379
+ expect(mockKernelContract.off).toHaveBeenCalledWith(mockFilter, expect.any(Function));
380
+ });
381
+ });
382
+ });