@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,253 +0,0 @@
1
- /**
2
- * RateLimiter - Prevents excessive API/RPC calls
3
- *
4
- * SECURITY FIX (M-4): Rate limiting to prevent:
5
- * - API rate limit exhaustion
6
- * - Self-inflicted DoS
7
- * - Excessive RPC costs
8
- *
9
- * @module utils/RateLimiter
10
- */
11
- /**
12
- * Rate limiter configuration
13
- */
14
- export interface RateLimiterConfig {
15
- /** Maximum requests per window */
16
- maxRequests: number;
17
- /** Time window in milliseconds */
18
- windowMs: number;
19
- /** Optional: Burst allowance (extra requests allowed briefly) */
20
- burstAllowance?: number;
21
- }
22
- /**
23
- * Rate limiter result
24
- */
25
- export interface RateLimitResult {
26
- /** Whether the request is allowed */
27
- allowed: boolean;
28
- /** Remaining requests in current window */
29
- remaining: number;
30
- /** Time until window resets (ms) */
31
- resetIn: number;
32
- /** Suggested retry delay if not allowed */
33
- retryAfter?: number;
34
- }
35
- /**
36
- * Simple sliding window rate limiter
37
- *
38
- * @example
39
- * ```typescript
40
- * const limiter = new RateLimiter({ maxRequests: 10, windowMs: 1000 });
41
- *
42
- * const result = limiter.tryAcquire();
43
- * if (!result.allowed) {
44
- * console.log(`Rate limited. Retry after ${result.retryAfter}ms`);
45
- * }
46
- * ```
47
- */
48
- export declare class RateLimiter {
49
- private timestamps;
50
- private readonly config;
51
- constructor(config: RateLimiterConfig);
52
- /**
53
- * Try to acquire a rate limit slot
54
- *
55
- * @returns Rate limit result
56
- */
57
- tryAcquire(): RateLimitResult;
58
- /**
59
- * Wait until rate limit allows request
60
- *
61
- * @returns Promise that resolves when request is allowed
62
- */
63
- acquire(): Promise<void>;
64
- /**
65
- * Get current rate limit status
66
- */
67
- getStatus(): {
68
- used: number;
69
- remaining: number;
70
- resetIn: number;
71
- };
72
- /**
73
- * Reset the rate limiter
74
- */
75
- reset(): void;
76
- }
77
- /**
78
- * Circuit breaker states
79
- */
80
- export type CircuitState = 'closed' | 'open' | 'half-open';
81
- /**
82
- * Circuit breaker configuration
83
- */
84
- export interface CircuitBreakerConfig {
85
- /** Number of failures before opening circuit */
86
- failureThreshold: number;
87
- /** Time to wait before trying again (ms) */
88
- recoveryTimeout: number;
89
- /** Number of successes in half-open needed to close circuit */
90
- successThreshold?: number;
91
- /** SECURITY FIX (MEDIUM-5): Timeout for half-open test (ms). If no result reported, auto-reset. Default: 30000 */
92
- halfOpenTestTimeout?: number;
93
- }
94
- /**
95
- * Circuit breaker result
96
- */
97
- export interface CircuitBreakerResult {
98
- /** Whether the operation is allowed */
99
- allowed: boolean;
100
- /** Current circuit state */
101
- state: CircuitState;
102
- /** Number of consecutive failures */
103
- failures: number;
104
- }
105
- /**
106
- * Circuit Breaker - Prevents cascading failures
107
- *
108
- * SECURITY FIX (M-5): Circuit breaker to:
109
- * - Prevent repeated calls to failing services
110
- * - Allow systems to recover
111
- * - Provide graceful degradation
112
- *
113
- * States:
114
- * - CLOSED: Normal operation, requests pass through
115
- * - OPEN: Circuit tripped, requests fail fast
116
- * - HALF-OPEN: Testing if service recovered
117
- *
118
- * @example
119
- * ```typescript
120
- * const breaker = new CircuitBreaker({
121
- * failureThreshold: 5,
122
- * recoveryTimeout: 30000
123
- * });
124
- *
125
- * async function callService() {
126
- * const result = breaker.canExecute();
127
- * if (!result.allowed) {
128
- * throw new Error(`Circuit open. Try again later.`);
129
- * }
130
- *
131
- * try {
132
- * const response = await riskyOperation();
133
- * breaker.recordSuccess();
134
- * return response;
135
- * } catch (error) {
136
- * breaker.recordFailure();
137
- * throw error;
138
- * }
139
- * }
140
- * ```
141
- */
142
- export declare class CircuitBreaker {
143
- private state;
144
- private failures;
145
- private successes;
146
- private lastFailureTime;
147
- private readonly config;
148
- private halfOpenTestInProgress;
149
- private halfOpenTestStartTime;
150
- constructor(config: CircuitBreakerConfig);
151
- /**
152
- * Check if operation can be executed
153
- *
154
- * SECURITY FIX (CIRCUIT-HALFOPEN): In half-open state, only allow ONE request
155
- * at a time to prevent overwhelming a recovering service.
156
- */
157
- canExecute(): CircuitBreakerResult;
158
- /**
159
- * Record a successful operation
160
- *
161
- * SECURITY FIX (CIRCUIT-HALFOPEN): Clears test-in-progress flag
162
- * SECURITY FIX (MEDIUM-5): Clears test start time
163
- */
164
- recordSuccess(): void;
165
- /**
166
- * Record a failed operation
167
- *
168
- * SECURITY FIX (CIRCUIT-HALFOPEN): Clears test-in-progress flag
169
- * SECURITY FIX (MEDIUM-5): Clears test start time
170
- */
171
- recordFailure(): void;
172
- /**
173
- * Get current circuit state
174
- */
175
- getState(): CircuitState;
176
- /**
177
- * Get detailed status
178
- */
179
- getStatus(): {
180
- state: CircuitState;
181
- failures: number;
182
- timeSinceLastFailure: number;
183
- recoveryTimeRemaining: number;
184
- };
185
- /**
186
- * Manually reset the circuit breaker
187
- *
188
- * SECURITY FIX (CIRCUIT-HALFOPEN): Also clears test-in-progress flag
189
- * SECURITY FIX (MEDIUM-5): Also clears test start time
190
- */
191
- reset(): void;
192
- /**
193
- * Execute a function with circuit breaker protection
194
- *
195
- * @param fn - Async function to execute
196
- * @returns Function result or throws if circuit is open
197
- */
198
- execute<T>(fn: () => Promise<T>): Promise<T>;
199
- }
200
- /**
201
- * Combined rate limiter and circuit breaker for API protection
202
- *
203
- * @example
204
- * ```typescript
205
- * const protector = new APIProtector({
206
- * rateLimiter: { maxRequests: 100, windowMs: 60000 },
207
- * circuitBreaker: { failureThreshold: 5, recoveryTimeout: 30000 }
208
- * });
209
- *
210
- * const result = await protector.execute(async () => {
211
- * return await apiCall();
212
- * });
213
- * ```
214
- */
215
- export declare class APIProtector {
216
- private readonly rateLimiter;
217
- private readonly circuitBreaker;
218
- constructor(config: {
219
- rateLimiter: RateLimiterConfig;
220
- circuitBreaker: CircuitBreakerConfig;
221
- });
222
- /**
223
- * Check if operation is allowed (both rate limit and circuit)
224
- */
225
- canExecute(): {
226
- allowed: boolean;
227
- reason?: string;
228
- };
229
- /**
230
- * Execute with both rate limiting and circuit breaker protection
231
- */
232
- execute<T>(fn: () => Promise<T>): Promise<T>;
233
- /**
234
- * Get combined status
235
- */
236
- getStatus(): {
237
- rateLimiter: ReturnType<RateLimiter['getStatus']>;
238
- circuitBreaker: ReturnType<CircuitBreaker['getStatus']>;
239
- };
240
- /**
241
- * Record success (for circuit breaker)
242
- */
243
- recordSuccess(): void;
244
- /**
245
- * Record failure (for circuit breaker)
246
- */
247
- recordFailure(): void;
248
- /**
249
- * Reset both protections
250
- */
251
- reset(): void;
252
- }
253
- //# sourceMappingURL=RateLimiter.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"RateLimiter.d.ts","sourceRoot":"","sources":["../../src/utils/RateLimiter.ts"],"names":[],"mappings":"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"}
@@ -1,424 +0,0 @@
1
- "use strict";
2
- /**
3
- * RateLimiter - Prevents excessive API/RPC calls
4
- *
5
- * SECURITY FIX (M-4): Rate limiting to prevent:
6
- * - API rate limit exhaustion
7
- * - Self-inflicted DoS
8
- * - Excessive RPC costs
9
- *
10
- * @module utils/RateLimiter
11
- */
12
- Object.defineProperty(exports, "__esModule", { value: true });
13
- exports.APIProtector = exports.CircuitBreaker = exports.RateLimiter = void 0;
14
- /**
15
- * Simple sliding window rate limiter
16
- *
17
- * @example
18
- * ```typescript
19
- * const limiter = new RateLimiter({ maxRequests: 10, windowMs: 1000 });
20
- *
21
- * const result = limiter.tryAcquire();
22
- * if (!result.allowed) {
23
- * console.log(`Rate limited. Retry after ${result.retryAfter}ms`);
24
- * }
25
- * ```
26
- */
27
- class RateLimiter {
28
- constructor(config) {
29
- this.timestamps = [];
30
- this.config = {
31
- maxRequests: config.maxRequests,
32
- windowMs: config.windowMs,
33
- burstAllowance: config.burstAllowance ?? 0,
34
- };
35
- }
36
- /**
37
- * Try to acquire a rate limit slot
38
- *
39
- * @returns Rate limit result
40
- */
41
- tryAcquire() {
42
- const now = Date.now();
43
- const windowStart = now - this.config.windowMs;
44
- // Remove expired timestamps
45
- this.timestamps = this.timestamps.filter((ts) => ts > windowStart);
46
- const effectiveLimit = this.config.maxRequests + this.config.burstAllowance;
47
- if (this.timestamps.length < effectiveLimit) {
48
- this.timestamps.push(now);
49
- return {
50
- allowed: true,
51
- remaining: effectiveLimit - this.timestamps.length,
52
- resetIn: this.timestamps.length > 0
53
- ? this.timestamps[0] + this.config.windowMs - now
54
- : this.config.windowMs,
55
- };
56
- }
57
- // Rate limited
58
- const oldestTimestamp = this.timestamps[0];
59
- const retryAfter = oldestTimestamp + this.config.windowMs - now;
60
- return {
61
- allowed: false,
62
- remaining: 0,
63
- resetIn: retryAfter,
64
- retryAfter: Math.max(0, retryAfter),
65
- };
66
- }
67
- /**
68
- * Wait until rate limit allows request
69
- *
70
- * @returns Promise that resolves when request is allowed
71
- */
72
- async acquire() {
73
- const result = this.tryAcquire();
74
- if (result.allowed) {
75
- return;
76
- }
77
- // Wait and retry
78
- await new Promise((resolve) => setTimeout(resolve, result.retryAfter));
79
- return this.acquire();
80
- }
81
- /**
82
- * Get current rate limit status
83
- */
84
- getStatus() {
85
- const now = Date.now();
86
- const windowStart = now - this.config.windowMs;
87
- // Clean up expired timestamps
88
- this.timestamps = this.timestamps.filter((ts) => ts > windowStart);
89
- const effectiveLimit = this.config.maxRequests + this.config.burstAllowance;
90
- const used = this.timestamps.length;
91
- const remaining = Math.max(0, effectiveLimit - used);
92
- const resetIn = this.timestamps.length > 0
93
- ? this.timestamps[0] + this.config.windowMs - now
94
- : this.config.windowMs;
95
- return { used, remaining, resetIn };
96
- }
97
- /**
98
- * Reset the rate limiter
99
- */
100
- reset() {
101
- this.timestamps = [];
102
- }
103
- }
104
- exports.RateLimiter = RateLimiter;
105
- /**
106
- * Circuit Breaker - Prevents cascading failures
107
- *
108
- * SECURITY FIX (M-5): Circuit breaker to:
109
- * - Prevent repeated calls to failing services
110
- * - Allow systems to recover
111
- * - Provide graceful degradation
112
- *
113
- * States:
114
- * - CLOSED: Normal operation, requests pass through
115
- * - OPEN: Circuit tripped, requests fail fast
116
- * - HALF-OPEN: Testing if service recovered
117
- *
118
- * @example
119
- * ```typescript
120
- * const breaker = new CircuitBreaker({
121
- * failureThreshold: 5,
122
- * recoveryTimeout: 30000
123
- * });
124
- *
125
- * async function callService() {
126
- * const result = breaker.canExecute();
127
- * if (!result.allowed) {
128
- * throw new Error(`Circuit open. Try again later.`);
129
- * }
130
- *
131
- * try {
132
- * const response = await riskyOperation();
133
- * breaker.recordSuccess();
134
- * return response;
135
- * } catch (error) {
136
- * breaker.recordFailure();
137
- * throw error;
138
- * }
139
- * }
140
- * ```
141
- */
142
- class CircuitBreaker {
143
- constructor(config) {
144
- this.state = 'closed';
145
- this.failures = 0;
146
- this.successes = 0;
147
- this.lastFailureTime = 0;
148
- // SECURITY FIX (CIRCUIT-HALFOPEN): Track if a test request is in progress
149
- // Half-open state should only allow ONE request at a time to test service recovery
150
- this.halfOpenTestInProgress = false;
151
- // SECURITY FIX (MEDIUM-5): Track when half-open test started for timeout detection
152
- this.halfOpenTestStartTime = 0;
153
- this.config = {
154
- failureThreshold: config.failureThreshold,
155
- recoveryTimeout: config.recoveryTimeout,
156
- successThreshold: config.successThreshold ?? 1,
157
- // SECURITY FIX (MEDIUM-5): Default 30 second timeout for half-open tests
158
- halfOpenTestTimeout: config.halfOpenTestTimeout ?? 30000,
159
- };
160
- }
161
- /**
162
- * Check if operation can be executed
163
- *
164
- * SECURITY FIX (CIRCUIT-HALFOPEN): In half-open state, only allow ONE request
165
- * at a time to prevent overwhelming a recovering service.
166
- */
167
- canExecute() {
168
- const now = Date.now();
169
- switch (this.state) {
170
- case 'closed':
171
- return {
172
- allowed: true,
173
- state: this.state,
174
- failures: this.failures,
175
- };
176
- case 'open':
177
- // Check if recovery timeout has passed
178
- if (now - this.lastFailureTime >= this.config.recoveryTimeout) {
179
- this.state = 'half-open';
180
- this.successes = 0;
181
- // SECURITY FIX (HIGH-7): Removed duplicate assignment (was setting false then true)
182
- // SECURITY FIX (CIRCUIT-HALFOPEN): Mark test as in progress for first allowed request
183
- this.halfOpenTestInProgress = true;
184
- // SECURITY FIX (MEDIUM-5): Record when test started for timeout detection
185
- this.halfOpenTestStartTime = now;
186
- return {
187
- allowed: true,
188
- state: this.state,
189
- failures: this.failures,
190
- };
191
- }
192
- return {
193
- allowed: false,
194
- state: this.state,
195
- failures: this.failures,
196
- };
197
- case 'half-open':
198
- // SECURITY FIX (MEDIUM-5): Check if test has timed out (caller never reported result)
199
- // This prevents the circuit breaker from getting stuck if caller crashes/forgets to report
200
- if (this.halfOpenTestInProgress && this.halfOpenTestStartTime > 0) {
201
- const testDuration = now - this.halfOpenTestStartTime;
202
- if (testDuration >= this.config.halfOpenTestTimeout) {
203
- // Timeout: reset the test flag and allow a new test
204
- this.halfOpenTestInProgress = false;
205
- this.halfOpenTestStartTime = 0;
206
- }
207
- }
208
- // SECURITY FIX (CIRCUIT-HALFOPEN): Only allow if no test is in progress
209
- // This prevents multiple concurrent requests from overwhelming a recovering service
210
- if (this.halfOpenTestInProgress) {
211
- return {
212
- allowed: false,
213
- state: this.state,
214
- failures: this.failures,
215
- };
216
- }
217
- // Mark test as in progress
218
- this.halfOpenTestInProgress = true;
219
- // SECURITY FIX (MEDIUM-5): Record when test started
220
- this.halfOpenTestStartTime = now;
221
- return {
222
- allowed: true,
223
- state: this.state,
224
- failures: this.failures,
225
- };
226
- }
227
- }
228
- /**
229
- * Record a successful operation
230
- *
231
- * SECURITY FIX (CIRCUIT-HALFOPEN): Clears test-in-progress flag
232
- * SECURITY FIX (MEDIUM-5): Clears test start time
233
- */
234
- recordSuccess() {
235
- if (this.state === 'half-open') {
236
- // SECURITY FIX (CIRCUIT-HALFOPEN): Clear test flag
237
- this.halfOpenTestInProgress = false;
238
- // SECURITY FIX (MEDIUM-5): Clear test start time
239
- this.halfOpenTestStartTime = 0;
240
- this.successes++;
241
- if (this.successes >= this.config.successThreshold) {
242
- this.state = 'closed';
243
- this.failures = 0;
244
- this.successes = 0;
245
- }
246
- }
247
- else if (this.state === 'closed') {
248
- // Reset failure count on success
249
- this.failures = 0;
250
- }
251
- }
252
- /**
253
- * Record a failed operation
254
- *
255
- * SECURITY FIX (CIRCUIT-HALFOPEN): Clears test-in-progress flag
256
- * SECURITY FIX (MEDIUM-5): Clears test start time
257
- */
258
- recordFailure() {
259
- this.failures++;
260
- this.lastFailureTime = Date.now();
261
- if (this.state === 'half-open') {
262
- // SECURITY FIX (CIRCUIT-HALFOPEN): Clear test flag before opening
263
- this.halfOpenTestInProgress = false;
264
- // SECURITY FIX (MEDIUM-5): Clear test start time
265
- this.halfOpenTestStartTime = 0;
266
- // Immediately open on failure in half-open state
267
- this.state = 'open';
268
- }
269
- else if (this.state === 'closed' && this.failures >= this.config.failureThreshold) {
270
- this.state = 'open';
271
- }
272
- }
273
- /**
274
- * Get current circuit state
275
- */
276
- getState() {
277
- // Check for automatic transition from open to half-open
278
- if (this.state === 'open') {
279
- const now = Date.now();
280
- if (now - this.lastFailureTime >= this.config.recoveryTimeout) {
281
- this.state = 'half-open';
282
- this.successes = 0;
283
- }
284
- }
285
- return this.state;
286
- }
287
- /**
288
- * Get detailed status
289
- */
290
- getStatus() {
291
- const now = Date.now();
292
- const timeSinceLastFailure = this.lastFailureTime > 0
293
- ? now - this.lastFailureTime
294
- : 0;
295
- const recoveryTimeRemaining = this.state === 'open'
296
- ? Math.max(0, this.config.recoveryTimeout - timeSinceLastFailure)
297
- : 0;
298
- return {
299
- state: this.getState(),
300
- failures: this.failures,
301
- timeSinceLastFailure,
302
- recoveryTimeRemaining,
303
- };
304
- }
305
- /**
306
- * Manually reset the circuit breaker
307
- *
308
- * SECURITY FIX (CIRCUIT-HALFOPEN): Also clears test-in-progress flag
309
- * SECURITY FIX (MEDIUM-5): Also clears test start time
310
- */
311
- reset() {
312
- this.state = 'closed';
313
- this.failures = 0;
314
- this.successes = 0;
315
- this.lastFailureTime = 0;
316
- this.halfOpenTestInProgress = false;
317
- this.halfOpenTestStartTime = 0;
318
- }
319
- /**
320
- * Execute a function with circuit breaker protection
321
- *
322
- * @param fn - Async function to execute
323
- * @returns Function result or throws if circuit is open
324
- */
325
- async execute(fn) {
326
- const result = this.canExecute();
327
- if (!result.allowed) {
328
- throw new Error(`Circuit breaker is open (${this.failures} failures). ` +
329
- `Recovery in ${this.getStatus().recoveryTimeRemaining}ms.`);
330
- }
331
- try {
332
- const response = await fn();
333
- this.recordSuccess();
334
- return response;
335
- }
336
- catch (error) {
337
- this.recordFailure();
338
- throw error;
339
- }
340
- }
341
- }
342
- exports.CircuitBreaker = CircuitBreaker;
343
- /**
344
- * Combined rate limiter and circuit breaker for API protection
345
- *
346
- * @example
347
- * ```typescript
348
- * const protector = new APIProtector({
349
- * rateLimiter: { maxRequests: 100, windowMs: 60000 },
350
- * circuitBreaker: { failureThreshold: 5, recoveryTimeout: 30000 }
351
- * });
352
- *
353
- * const result = await protector.execute(async () => {
354
- * return await apiCall();
355
- * });
356
- * ```
357
- */
358
- class APIProtector {
359
- constructor(config) {
360
- this.rateLimiter = new RateLimiter(config.rateLimiter);
361
- this.circuitBreaker = new CircuitBreaker(config.circuitBreaker);
362
- }
363
- /**
364
- * Check if operation is allowed (both rate limit and circuit)
365
- */
366
- canExecute() {
367
- // Check circuit breaker first
368
- const circuitResult = this.circuitBreaker.canExecute();
369
- if (!circuitResult.allowed) {
370
- return {
371
- allowed: false,
372
- reason: `Circuit breaker open (${circuitResult.failures} failures)`,
373
- };
374
- }
375
- // Check rate limiter
376
- const rateResult = this.rateLimiter.tryAcquire();
377
- if (!rateResult.allowed) {
378
- return {
379
- allowed: false,
380
- reason: `Rate limited. Retry after ${rateResult.retryAfter}ms`,
381
- };
382
- }
383
- return { allowed: true };
384
- }
385
- /**
386
- * Execute with both rate limiting and circuit breaker protection
387
- */
388
- async execute(fn) {
389
- // Wait for rate limit
390
- await this.rateLimiter.acquire();
391
- // Execute with circuit breaker
392
- return this.circuitBreaker.execute(fn);
393
- }
394
- /**
395
- * Get combined status
396
- */
397
- getStatus() {
398
- return {
399
- rateLimiter: this.rateLimiter.getStatus(),
400
- circuitBreaker: this.circuitBreaker.getStatus(),
401
- };
402
- }
403
- /**
404
- * Record success (for circuit breaker)
405
- */
406
- recordSuccess() {
407
- this.circuitBreaker.recordSuccess();
408
- }
409
- /**
410
- * Record failure (for circuit breaker)
411
- */
412
- recordFailure() {
413
- this.circuitBreaker.recordFailure();
414
- }
415
- /**
416
- * Reset both protections
417
- */
418
- reset() {
419
- this.rateLimiter.reset();
420
- this.circuitBreaker.reset();
421
- }
422
- }
423
- exports.APIProtector = APIProtector;
424
- //# sourceMappingURL=RateLimiter.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"RateLimiter.js","sourceRoot":"","sources":["../../src/utils/RateLimiter.ts"],"names":[],"mappings":"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"}