@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
package/src/cli/index.ts DELETED
@@ -1,116 +0,0 @@
1
- #!/usr/bin/env node
2
- /**
3
- * ACTP CLI - Agent Commerce Transaction Protocol Command Line Interface
4
- *
5
- * The ACTP CLI is designed for AI agents - not humans clicking buttons.
6
- * Key differentiators:
7
- *
8
- * 1. **Machine-readable output**: JSON by default for scripting
9
- * 2. **Pipe-friendly**: Commands output just what you need
10
- * 3. **Structured exit codes**: 0=success, 1=error, 2=pending
11
- * 4. **Agent-first features**: watch, simulate, batch
12
- *
13
- * @module cli
14
- * @see https://docs.agirails.io/cli
15
- */
16
-
17
- import { Command } from 'commander';
18
- import { readFileSync } from 'fs';
19
- import { join } from 'path';
20
-
21
- // Read version from package.json (works in both src and dist)
22
- function getVersion(): string {
23
- try {
24
- // Try dist location first (when running compiled)
25
- const distPath = join(__dirname, '../../package.json');
26
- const pkg = JSON.parse(readFileSync(distPath, 'utf-8'));
27
- return pkg.version;
28
- } catch {
29
- try {
30
- // Fallback to src location (when running ts-node)
31
- const srcPath = join(__dirname, '../../../package.json');
32
- const pkg = JSON.parse(readFileSync(srcPath, 'utf-8'));
33
- return pkg.version;
34
- } catch {
35
- return '0.0.0'; // Fallback if package.json not found
36
- }
37
- }
38
- }
39
-
40
- // Import commands
41
- import { createInitCommand } from './commands/init';
42
- import { createPayCommand } from './commands/pay';
43
- import { createTxCommand } from './commands/tx';
44
- import { createBalanceCommand } from './commands/balance';
45
- import { createMintCommand } from './commands/mint';
46
- import { createConfigCommand } from './commands/config';
47
- import { createWatchCommand } from './commands/watch';
48
- import { createSimulateCommand } from './commands/simulate';
49
- import { createBatchCommand } from './commands/batch';
50
- import { createTimeCommand } from './commands/time';
51
-
52
- // ============================================================================
53
- // Program Setup
54
- // ============================================================================
55
-
56
- const program = new Command();
57
-
58
- program
59
- .name('actp')
60
- .description(
61
- 'ACTP CLI - Agent Commerce Transaction Protocol\n\n' +
62
- 'The payment layer for AI agents. Create escrow-backed transactions,\n' +
63
- 'track state changes, and settle payments programmatically.\n\n' +
64
- 'Quick Start:\n' +
65
- ' $ actp init Initialize in current directory\n' +
66
- ' $ actp pay 0xProvider 100 Create a payment\n' +
67
- ' $ actp tx status <txId> Check transaction status\n\n' +
68
- 'Output Modes:\n' +
69
- ' --json Machine-readable JSON output\n' +
70
- ' --quiet Minimal output (just the essential value)'
71
- )
72
- .version(getVersion(), '-v, --version', 'Output the version number')
73
- .helpOption('-h, --help', 'Display help for command');
74
-
75
- // ============================================================================
76
- // Register Commands
77
- // ============================================================================
78
-
79
- // Core commands (most used)
80
- program.addCommand(createInitCommand());
81
- program.addCommand(createPayCommand());
82
- program.addCommand(createTxCommand());
83
- program.addCommand(createBalanceCommand());
84
- program.addCommand(createMintCommand());
85
- program.addCommand(createConfigCommand());
86
-
87
- // Agent-first features
88
- program.addCommand(createWatchCommand());
89
- program.addCommand(createSimulateCommand());
90
- program.addCommand(createBatchCommand());
91
-
92
- // Mock mode utilities
93
- program.addCommand(createTimeCommand());
94
-
95
- // ============================================================================
96
- // Error Handling
97
- // ============================================================================
98
-
99
- // Handle unknown commands
100
- program.on('command:*', (operands) => {
101
- console.error(`Error: Unknown command '${operands[0]}'`);
102
- console.error('');
103
- console.error('Run "actp --help" for available commands.');
104
- process.exit(1);
105
- });
106
-
107
- // ============================================================================
108
- // Parse & Execute
109
- // ============================================================================
110
-
111
- program.parse(process.argv);
112
-
113
- // If no arguments, show help
114
- if (process.argv.length === 2) {
115
- program.outputHelp();
116
- }
@@ -1,249 +0,0 @@
1
- /**
2
- * SDK Client Factory for CLI
3
- *
4
- * Creates and manages ACTPClient instances based on CLI configuration.
5
- * Handles mode-specific initialization and error mapping.
6
- *
7
- * SECURITY: Error messages are sanitized to prevent information disclosure.
8
- *
9
- * @module cli/utils/client
10
- */
11
-
12
- import * as os from 'os';
13
- import { ACTPClient, ACTPClientConfig } from '../../ACTPClient';
14
- import { loadConfig, validateConfigForMode } from './config';
15
-
16
- // ============================================================================
17
- // Security: Path Sanitization
18
- // ============================================================================
19
-
20
- /**
21
- * Sanitize a file path for safe display in error messages.
22
- *
23
- * SECURITY: Replaces home directory with ~ to prevent disclosure of:
24
- * - Full home directory paths
25
- * - Usernames embedded in paths
26
- * - System-specific directory structures
27
- *
28
- * @param fullPath - The full file path to sanitize
29
- * @returns Sanitized path safe for display
30
- */
31
- function sanitizePath(fullPath: string): string {
32
- const home = os.homedir();
33
- // Replace home directory with ~ to avoid disclosing username/path
34
- return fullPath.replace(home, '~');
35
- }
36
-
37
- // ============================================================================
38
- // Client Factory
39
- // ============================================================================
40
-
41
- /**
42
- * Create an ACTPClient instance from CLI configuration
43
- *
44
- * Reads configuration from .actp/config.json and creates
45
- * an appropriate client instance for the configured mode.
46
- *
47
- * @param projectRoot - Project root directory (defaults to cwd)
48
- * @returns Initialized ACTPClient
49
- * @throws Error if config invalid or client creation fails
50
- */
51
- export async function createClient(
52
- projectRoot: string = process.cwd()
53
- ): Promise<ACTPClient> {
54
- // Load configuration
55
- const config = loadConfig(projectRoot);
56
-
57
- // Validate config for the mode
58
- validateConfigForMode(config);
59
-
60
- // Build client config
61
- const clientConfig: ACTPClientConfig = {
62
- mode: config.mode,
63
- requesterAddress: config.address,
64
- stateDirectory: projectRoot,
65
- };
66
-
67
- // Create and return client
68
- return ACTPClient.create(clientConfig);
69
- }
70
-
71
- // ============================================================================
72
- // Error Mapping
73
- // ============================================================================
74
-
75
- /**
76
- * Error codes for CLI errors
77
- */
78
- export const ErrorCode = {
79
- // Configuration errors
80
- NOT_INITIALIZED: 'NOT_INITIALIZED',
81
- CONFIG_CORRUPTED: 'CONFIG_CORRUPTED',
82
- INVALID_CONFIG: 'INVALID_CONFIG',
83
-
84
- // Input validation errors
85
- INVALID_ADDRESS: 'INVALID_ADDRESS',
86
- INVALID_AMOUNT: 'INVALID_AMOUNT',
87
- INVALID_DEADLINE: 'INVALID_DEADLINE',
88
- INVALID_TX_ID: 'INVALID_TX_ID',
89
-
90
- // Transaction errors
91
- TX_NOT_FOUND: 'TX_NOT_FOUND',
92
- INVALID_STATE_TRANSITION: 'INVALID_STATE_TRANSITION',
93
- INSUFFICIENT_BALANCE: 'INSUFFICIENT_BALANCE',
94
- DEADLINE_PASSED: 'DEADLINE_PASSED',
95
- DISPUTE_WINDOW_ACTIVE: 'DISPUTE_WINDOW_ACTIVE',
96
-
97
- // System errors
98
- FILE_LOCK_ERROR: 'FILE_LOCK_ERROR',
99
- NETWORK_ERROR: 'NETWORK_ERROR',
100
- UNKNOWN_ERROR: 'UNKNOWN_ERROR',
101
- } as const;
102
-
103
- export type ErrorCodeValue = (typeof ErrorCode)[keyof typeof ErrorCode];
104
-
105
- /**
106
- * Structured CLI error with code and details
107
- */
108
- export interface StructuredError {
109
- code: ErrorCodeValue;
110
- message: string;
111
- details?: Record<string, unknown>;
112
- }
113
-
114
- /**
115
- * Map SDK errors to CLI-friendly structured errors.
116
- *
117
- * SECURITY: Sanitizes paths and stack traces to prevent information disclosure.
118
- */
119
- export function mapError(error: unknown): StructuredError {
120
- const err = error as Error;
121
- // Sanitize the message to remove full paths
122
- const rawMessage = err?.message || String(error);
123
- const message = sanitizePath(rawMessage);
124
-
125
- // Configuration errors
126
- if (message.includes('not initialized') || message.includes('actp init')) {
127
- return {
128
- code: ErrorCode.NOT_INITIALIZED,
129
- message: 'ACTP not initialized. Run "actp init" first.',
130
- };
131
- }
132
-
133
- if (message.includes('Config file corrupted')) {
134
- return {
135
- code: ErrorCode.CONFIG_CORRUPTED,
136
- message: 'Configuration file is corrupted.',
137
- details: { suggestion: 'Run "actp init --force" to reinitialize.' },
138
- };
139
- }
140
-
141
- // Transaction errors (from SDK error classes)
142
- if (err?.name === 'TransactionNotFoundError' || message.includes('Transaction not found')) {
143
- const txIdMatch = message.match(/Transaction not found: (0x[a-fA-F0-9]+)/);
144
- return {
145
- code: ErrorCode.TX_NOT_FOUND,
146
- message: 'Transaction not found.',
147
- details: txIdMatch ? { txId: txIdMatch[1] } : undefined,
148
- };
149
- }
150
-
151
- if (err?.name === 'InvalidStateTransitionError' || message.includes('Invalid state transition')) {
152
- return {
153
- code: ErrorCode.INVALID_STATE_TRANSITION,
154
- message: 'Invalid state transition.',
155
- // SECURITY: Don't expose original message which may contain sensitive info
156
- };
157
- }
158
-
159
- if (err?.name === 'InsufficientBalanceError' || message.includes('Insufficient balance')) {
160
- return {
161
- code: ErrorCode.INSUFFICIENT_BALANCE,
162
- message: 'Insufficient balance for this operation.',
163
- // SECURITY: Don't expose balance details
164
- };
165
- }
166
-
167
- if (err?.name === 'DeadlinePassedError' || message.includes('Deadline passed')) {
168
- return {
169
- code: ErrorCode.DEADLINE_PASSED,
170
- message: 'Transaction deadline has passed.',
171
- };
172
- }
173
-
174
- if (err?.name === 'DisputeWindowActiveError' || message.includes('Dispute window')) {
175
- return {
176
- code: ErrorCode.DISPUTE_WINDOW_ACTIVE,
177
- message: 'Dispute window is still active.',
178
- // SECURITY: Don't expose window timing details
179
- };
180
- }
181
-
182
- // Validation errors
183
- if (err?.name === 'ValidationError') {
184
- if (message.includes('address')) {
185
- return {
186
- code: ErrorCode.INVALID_ADDRESS,
187
- message: sanitizePath(message),
188
- };
189
- }
190
- if (message.includes('amount') || message.includes('Amount')) {
191
- return {
192
- code: ErrorCode.INVALID_AMOUNT,
193
- message: sanitizePath(message),
194
- };
195
- }
196
- if (message.includes('deadline') || message.includes('Deadline')) {
197
- return {
198
- code: ErrorCode.INVALID_DEADLINE,
199
- message: sanitizePath(message),
200
- };
201
- }
202
- }
203
-
204
- // Lock errors
205
- if (message.includes('lock') || message.includes('ELOCKED')) {
206
- return {
207
- code: ErrorCode.FILE_LOCK_ERROR,
208
- message: 'Could not acquire lock. Another process may be using ACTP.',
209
- details: { suggestion: 'Wait a moment and try again.' },
210
- };
211
- }
212
-
213
- // Default: unknown error
214
- // SECURITY: Do NOT include stack traces in production - they reveal internal paths
215
- return {
216
- code: ErrorCode.UNKNOWN_ERROR,
217
- message: sanitizePath(message) || 'An unknown error occurred.',
218
- // SECURITY FIX: Stack traces removed to prevent information disclosure
219
- // In development mode, errors can be logged separately if needed
220
- };
221
- }
222
-
223
- // ============================================================================
224
- // Utilities
225
- // ============================================================================
226
-
227
- /**
228
- * Validate transaction ID format
229
- */
230
- export function isValidTxId(txId: string): boolean {
231
- return /^0x[a-fA-F0-9]{64}$/.test(txId);
232
- }
233
-
234
- /**
235
- * Format address for display (truncate middle)
236
- */
237
- export function formatAddress(address: string, length: number = 10): string {
238
- if (address.length <= length * 2 + 2) {
239
- return address;
240
- }
241
- return `${address.slice(0, length + 2)}...${address.slice(-length)}`;
242
- }
243
-
244
- /**
245
- * Format transaction ID for display (truncate)
246
- */
247
- export function formatTxId(txId: string, length: number = 8): string {
248
- return `${txId.slice(0, length + 2)}...`;
249
- }
@@ -1,282 +0,0 @@
1
- /**
2
- * CLI Configuration Management
3
- *
4
- * Handles reading/writing CLI configuration stored in .actp/config.json.
5
- * Supports mock, testnet, and mainnet modes with mode-specific validation.
6
- *
7
- * @module cli/utils/config
8
- */
9
-
10
- import * as fs from 'fs';
11
- import * as path from 'path';
12
-
13
- // ============================================================================
14
- // Types
15
- // ============================================================================
16
-
17
- /**
18
- * CLI operating mode
19
- */
20
- export type CLIMode = 'mock' | 'testnet' | 'mainnet';
21
-
22
- /**
23
- * CLI configuration stored in .actp/config.json
24
- */
25
- export interface CLIConfig {
26
- /** Operating mode */
27
- mode: CLIMode;
28
-
29
- /** User's Ethereum address */
30
- address: string;
31
-
32
- /** Optional: Private key for testnet/mainnet mode */
33
- privateKey?: string;
34
-
35
- /** Optional: RPC URL override */
36
- rpcUrl?: string;
37
-
38
- /** Configuration version for migrations */
39
- version: string;
40
- }
41
-
42
- /**
43
- * Default configuration values
44
- */
45
- export const CONFIG_DEFAULTS: CLIConfig = {
46
- mode: 'mock',
47
- address: '',
48
- version: '1.0',
49
- };
50
-
51
- // ============================================================================
52
- // Paths
53
- // ============================================================================
54
-
55
- /**
56
- * Get the .actp directory path
57
- */
58
- export function getActpDir(projectRoot: string = process.cwd()): string {
59
- return path.join(projectRoot, '.actp');
60
- }
61
-
62
- /**
63
- * Get the config.json path
64
- */
65
- export function getConfigPath(projectRoot: string = process.cwd()): string {
66
- return path.join(getActpDir(projectRoot), 'config.json');
67
- }
68
-
69
- // ============================================================================
70
- // Config Operations
71
- // ============================================================================
72
-
73
- /**
74
- * Check if ACTP is initialized in the current directory
75
- */
76
- export function isInitialized(projectRoot: string = process.cwd()): boolean {
77
- return fs.existsSync(getConfigPath(projectRoot));
78
- }
79
-
80
- /**
81
- * Load configuration from disk
82
- *
83
- * SECURITY: Warns about private key storage in config file.
84
- *
85
- * @throws Error if config doesn't exist or is corrupted
86
- */
87
- export function loadConfig(projectRoot: string = process.cwd()): CLIConfig {
88
- const configPath = getConfigPath(projectRoot);
89
-
90
- if (!fs.existsSync(configPath)) {
91
- throw new Error(
92
- 'ACTP not initialized in this directory.\n' +
93
- 'Run "actp init" to initialize.'
94
- );
95
- }
96
-
97
- try {
98
- const raw = fs.readFileSync(configPath, 'utf-8');
99
- const config = JSON.parse(raw) as CLIConfig;
100
-
101
- // Validate required fields
102
- if (!config.mode) {
103
- throw new Error('Config missing required field: mode');
104
- }
105
- if (!config.address) {
106
- throw new Error('Config missing required field: address');
107
- }
108
-
109
- // SECURITY FIX (L-2): Warn about private key storage in config file
110
- if (config.privateKey) {
111
- console.warn('\x1b[33m%s\x1b[0m', 'WARNING: Private key stored in config file.');
112
- console.warn('\x1b[33m%s\x1b[0m', ' Consider using ACTP_PRIVATE_KEY environment variable instead.');
113
- console.warn('\x1b[33m%s\x1b[0m', ' Run: export ACTP_PRIVATE_KEY=<your-key>');
114
- }
115
-
116
- return config;
117
- } catch (error) {
118
- if (error instanceof SyntaxError) {
119
- throw new Error(
120
- `Config file corrupted: ${configPath}\n` +
121
- 'Delete it manually or run "actp init --force"'
122
- );
123
- }
124
- throw error;
125
- }
126
- }
127
-
128
- /**
129
- * Save configuration to disk
130
- *
131
- * Creates .actp directory if it doesn't exist.
132
- * Uses atomic write (temp file + rename).
133
- */
134
- export function saveConfig(
135
- config: CLIConfig,
136
- projectRoot: string = process.cwd()
137
- ): void {
138
- const actpDir = getActpDir(projectRoot);
139
- const configPath = getConfigPath(projectRoot);
140
- const tempPath = `${configPath}.tmp`;
141
-
142
- // Ensure .actp directory exists
143
- if (!fs.existsSync(actpDir)) {
144
- fs.mkdirSync(actpDir, { recursive: true, mode: 0o755 });
145
- }
146
-
147
- try {
148
- // Atomic write: write to temp, then rename
149
- const json = JSON.stringify(config, null, 2);
150
- fs.writeFileSync(tempPath, json, { encoding: 'utf-8', mode: 0o600 }); // Secure permissions
151
- fs.renameSync(tempPath, configPath);
152
- } catch (error) {
153
- // Clean up temp file on error
154
- if (fs.existsSync(tempPath)) {
155
- try {
156
- fs.unlinkSync(tempPath);
157
- } catch {
158
- // Ignore cleanup errors
159
- }
160
- }
161
- throw error;
162
- }
163
- }
164
-
165
- /**
166
- * Update specific config values
167
- *
168
- * Loads existing config, merges updates, and saves.
169
- */
170
- export function updateConfig(
171
- updates: Partial<CLIConfig>,
172
- projectRoot: string = process.cwd()
173
- ): CLIConfig {
174
- const config = loadConfig(projectRoot);
175
- const updated = { ...config, ...updates };
176
- saveConfig(updated, projectRoot);
177
- return updated;
178
- }
179
-
180
- /**
181
- * Get a specific config value
182
- */
183
- export function getConfigValue<K extends keyof CLIConfig>(
184
- key: K,
185
- projectRoot: string = process.cwd()
186
- ): CLIConfig[K] {
187
- const config = loadConfig(projectRoot);
188
- return config[key];
189
- }
190
-
191
- /**
192
- * Set a specific config value
193
- */
194
- export function setConfigValue<K extends keyof CLIConfig>(
195
- key: K,
196
- value: CLIConfig[K],
197
- projectRoot: string = process.cwd()
198
- ): void {
199
- updateConfig({ [key]: value } as Partial<CLIConfig>, projectRoot);
200
- }
201
-
202
- // ============================================================================
203
- // Validation
204
- // ============================================================================
205
-
206
- /**
207
- * Validate Ethereum address format
208
- */
209
- export function validateAddress(address: string): boolean {
210
- return /^0x[a-fA-F0-9]{40}$/.test(address);
211
- }
212
-
213
- /**
214
- * Validate private key format (64 hex chars, optionally with 0x prefix)
215
- */
216
- export function validatePrivateKey(key: string): boolean {
217
- // Remove 0x prefix if present
218
- const normalized = key.startsWith('0x') ? key.slice(2) : key;
219
- return /^[a-fA-F0-9]{64}$/.test(normalized);
220
- }
221
-
222
- /**
223
- * Validate config for the specified mode
224
- *
225
- * @throws Error if config is invalid for the mode
226
- */
227
- export function validateConfigForMode(config: CLIConfig): void {
228
- // All modes require a valid address
229
- if (!validateAddress(config.address)) {
230
- throw new Error(
231
- `Invalid address: "${config.address}"\n` +
232
- 'Expected 0x-prefixed 40-character hex string.'
233
- );
234
- }
235
-
236
- // Testnet and mainnet require private key
237
- if (config.mode !== 'mock') {
238
- if (!config.privateKey) {
239
- throw new Error(
240
- `Private key required for ${config.mode} mode.\n` +
241
- 'Run: actp config set privateKey <your-private-key>'
242
- );
243
- }
244
-
245
- if (!validatePrivateKey(config.privateKey)) {
246
- throw new Error(
247
- 'Invalid private key format.\n' +
248
- 'Expected 64-character hex string (with or without 0x prefix).'
249
- );
250
- }
251
- }
252
- }
253
-
254
- // ============================================================================
255
- // Gitignore Management
256
- // ============================================================================
257
-
258
- /**
259
- * Add .actp to .gitignore if not already present
260
- */
261
- export function addToGitignore(projectRoot: string = process.cwd()): void {
262
- const gitignorePath = path.join(projectRoot, '.gitignore');
263
-
264
- let content = '';
265
- if (fs.existsSync(gitignorePath)) {
266
- content = fs.readFileSync(gitignorePath, 'utf-8');
267
- }
268
-
269
- // Check if .actp is already in gitignore
270
- if (content.includes('.actp')) {
271
- return;
272
- }
273
-
274
- // Add .actp to gitignore
275
- const newContent =
276
- content +
277
- (content.endsWith('\n') ? '' : '\n') +
278
- '# ACTP local state (contains mock blockchain state)\n' +
279
- '.actp/\n';
280
-
281
- fs.writeFileSync(gitignorePath, newContent, 'utf-8');
282
- }