@illalabs/sdk 0.0.0 → 0.1.0-canary.dcf8499b

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 (213) hide show
  1. package/LICENSE +17 -2
  2. package/README.md +141 -1
  3. package/dist/src/asyncToolChecker/AsyncToolChecker.d.ts +39 -0
  4. package/dist/src/asyncToolChecker/AsyncToolChecker.d.ts.map +1 -0
  5. package/dist/src/asyncToolChecker/AsyncToolChecker.js +209 -0
  6. package/dist/src/asyncToolChecker/AsyncToolChecker.js.map +1 -0
  7. package/dist/src/asyncToolChecker/errors/AsyncToolCheckerMaxRetriesExceeded.d.ts +23 -0
  8. package/dist/src/asyncToolChecker/errors/AsyncToolCheckerMaxRetriesExceeded.d.ts.map +1 -0
  9. package/dist/src/asyncToolChecker/errors/AsyncToolCheckerMaxRetriesExceeded.js +30 -0
  10. package/dist/src/asyncToolChecker/errors/AsyncToolCheckerMaxRetriesExceeded.js.map +1 -0
  11. package/dist/src/asyncToolChecker/errors/AsyncToolCheckerMethodNotImplemented.d.ts +17 -0
  12. package/dist/src/asyncToolChecker/errors/AsyncToolCheckerMethodNotImplemented.d.ts.map +1 -0
  13. package/dist/src/asyncToolChecker/errors/AsyncToolCheckerMethodNotImplemented.js +26 -0
  14. package/dist/src/asyncToolChecker/errors/AsyncToolCheckerMethodNotImplemented.js.map +1 -0
  15. package/dist/src/asyncToolChecker/errors/AsyncToolCheckerTimeout.d.ts +17 -0
  16. package/dist/src/asyncToolChecker/errors/AsyncToolCheckerTimeout.d.ts.map +1 -0
  17. package/dist/src/asyncToolChecker/errors/AsyncToolCheckerTimeout.js +21 -0
  18. package/dist/src/asyncToolChecker/errors/AsyncToolCheckerTimeout.js.map +1 -0
  19. package/dist/src/asyncToolChecker/errors/index.d.ts +4 -0
  20. package/dist/src/asyncToolChecker/errors/index.d.ts.map +1 -0
  21. package/dist/src/asyncToolChecker/errors/index.js +4 -0
  22. package/dist/src/asyncToolChecker/errors/index.js.map +1 -0
  23. package/dist/src/asyncToolChecker/index.d.ts +6 -0
  24. package/dist/src/asyncToolChecker/index.d.ts.map +1 -0
  25. package/dist/src/asyncToolChecker/index.js +5 -0
  26. package/dist/src/asyncToolChecker/index.js.map +1 -0
  27. package/dist/src/asyncToolChecker/types.d.ts +24 -0
  28. package/dist/src/asyncToolChecker/types.d.ts.map +1 -0
  29. package/dist/src/asyncToolChecker/types.js +2 -0
  30. package/dist/src/asyncToolChecker/types.js.map +1 -0
  31. package/dist/src/asyncToolChecker/utils/index.d.ts +3 -0
  32. package/dist/src/asyncToolChecker/utils/index.d.ts.map +1 -0
  33. package/dist/src/asyncToolChecker/utils/index.js +3 -0
  34. package/dist/src/asyncToolChecker/utils/index.js.map +1 -0
  35. package/dist/src/asyncToolChecker/utils/isErrorResponse.d.ts +11 -0
  36. package/dist/src/asyncToolChecker/utils/isErrorResponse.d.ts.map +1 -0
  37. package/dist/src/asyncToolChecker/utils/isErrorResponse.js +12 -0
  38. package/dist/src/asyncToolChecker/utils/isErrorResponse.js.map +1 -0
  39. package/dist/src/asyncToolChecker/utils/normalizeTimeout.d.ts +9 -0
  40. package/dist/src/asyncToolChecker/utils/normalizeTimeout.d.ts.map +1 -0
  41. package/dist/src/asyncToolChecker/utils/normalizeTimeout.js +14 -0
  42. package/dist/src/asyncToolChecker/utils/normalizeTimeout.js.map +1 -0
  43. package/dist/src/caching/InMemoryCache.d.ts +14 -0
  44. package/dist/src/caching/InMemoryCache.d.ts.map +1 -0
  45. package/dist/src/caching/InMemoryCache.js +31 -0
  46. package/dist/src/caching/InMemoryCache.js.map +1 -0
  47. package/dist/src/caching/index.d.ts +3 -0
  48. package/dist/src/caching/index.d.ts.map +1 -0
  49. package/dist/src/caching/index.js +2 -0
  50. package/dist/src/caching/index.js.map +1 -0
  51. package/dist/src/chat/Chat.d.ts +62 -0
  52. package/dist/src/chat/Chat.d.ts.map +1 -0
  53. package/dist/src/chat/Chat.js +126 -0
  54. package/dist/src/chat/Chat.js.map +1 -0
  55. package/dist/src/chat/errors/ChatAsyncToolCheckerUnavailable.d.ts +19 -0
  56. package/dist/src/chat/errors/ChatAsyncToolCheckerUnavailable.d.ts.map +1 -0
  57. package/dist/src/chat/errors/ChatAsyncToolCheckerUnavailable.js +28 -0
  58. package/dist/src/chat/errors/ChatAsyncToolCheckerUnavailable.js.map +1 -0
  59. package/dist/src/chat/errors/index.d.ts +2 -0
  60. package/dist/src/chat/errors/index.d.ts.map +1 -0
  61. package/dist/src/chat/errors/index.js +2 -0
  62. package/dist/src/chat/errors/index.js.map +1 -0
  63. package/dist/src/chat/index.d.ts +5 -0
  64. package/dist/src/chat/index.d.ts.map +1 -0
  65. package/dist/src/chat/index.js +3 -0
  66. package/dist/src/chat/index.js.map +1 -0
  67. package/dist/src/chat/types.d.ts +9 -0
  68. package/dist/src/chat/types.d.ts.map +1 -0
  69. package/dist/src/chat/types.js +2 -0
  70. package/dist/src/chat/types.js.map +1 -0
  71. package/dist/src/chat/utils/index.d.ts +2 -0
  72. package/dist/src/chat/utils/index.d.ts.map +1 -0
  73. package/dist/src/chat/utils/index.js +2 -0
  74. package/dist/src/chat/utils/index.js.map +1 -0
  75. package/dist/src/chat/utils/uuid.d.ts +12 -0
  76. package/dist/src/chat/utils/uuid.d.ts.map +1 -0
  77. package/dist/src/chat/utils/uuid.js +19 -0
  78. package/dist/src/chat/utils/uuid.js.map +1 -0
  79. package/dist/src/context/ContextManager.d.ts +26 -0
  80. package/dist/src/context/ContextManager.d.ts.map +1 -0
  81. package/dist/src/context/ContextManager.js +93 -0
  82. package/dist/src/context/ContextManager.js.map +1 -0
  83. package/dist/src/context/index.d.ts +2 -0
  84. package/dist/src/context/index.d.ts.map +1 -0
  85. package/dist/src/context/index.js +2 -0
  86. package/dist/src/context/index.js.map +1 -0
  87. package/dist/src/context/types.d.ts +17 -0
  88. package/dist/src/context/types.d.ts.map +1 -0
  89. package/dist/src/context/types.js +2 -0
  90. package/dist/src/context/types.js.map +1 -0
  91. package/dist/src/external.d.ts +14 -0
  92. package/dist/src/external.d.ts.map +1 -0
  93. package/dist/src/external.js +13 -0
  94. package/dist/src/external.js.map +1 -0
  95. package/dist/src/index.d.ts +8 -0
  96. package/dist/src/index.d.ts.map +1 -0
  97. package/dist/src/index.js +8 -0
  98. package/dist/src/index.js.map +1 -0
  99. package/dist/src/interfaces/asyncToolChecker.interface.d.ts +85 -0
  100. package/dist/src/interfaces/asyncToolChecker.interface.d.ts.map +1 -0
  101. package/dist/src/interfaces/asyncToolChecker.interface.js +2 -0
  102. package/dist/src/interfaces/asyncToolChecker.interface.js.map +1 -0
  103. package/dist/src/interfaces/cache.interface.d.ts +35 -0
  104. package/dist/src/interfaces/cache.interface.d.ts.map +1 -0
  105. package/dist/src/interfaces/cache.interface.js +2 -0
  106. package/dist/src/interfaces/cache.interface.js.map +1 -0
  107. package/dist/src/interfaces/chat.interface.d.ts +84 -0
  108. package/dist/src/interfaces/chat.interface.d.ts.map +1 -0
  109. package/dist/src/interfaces/chat.interface.js +2 -0
  110. package/dist/src/interfaces/chat.interface.js.map +1 -0
  111. package/dist/src/interfaces/contextManager.interface.d.ts +86 -0
  112. package/dist/src/interfaces/contextManager.interface.d.ts.map +1 -0
  113. package/dist/src/interfaces/contextManager.interface.js +2 -0
  114. package/dist/src/interfaces/contextManager.interface.js.map +1 -0
  115. package/dist/src/interfaces/coreApiProvider.interface.d.ts +32 -0
  116. package/dist/src/interfaces/coreApiProvider.interface.d.ts.map +1 -0
  117. package/dist/src/interfaces/coreApiProvider.interface.js +2 -0
  118. package/dist/src/interfaces/coreApiProvider.interface.js.map +1 -0
  119. package/dist/src/interfaces/index.d.ts +7 -0
  120. package/dist/src/interfaces/index.d.ts.map +1 -0
  121. package/dist/src/interfaces/index.js +2 -0
  122. package/dist/src/interfaces/index.js.map +1 -0
  123. package/dist/src/internal.d.ts +14 -0
  124. package/dist/src/internal.d.ts.map +1 -0
  125. package/dist/src/internal.js +14 -0
  126. package/dist/src/internal.js.map +1 -0
  127. package/dist/src/prompt/Prompt.d.ts +61 -0
  128. package/dist/src/prompt/Prompt.d.ts.map +1 -0
  129. package/dist/src/prompt/Prompt.js +118 -0
  130. package/dist/src/prompt/Prompt.js.map +1 -0
  131. package/dist/src/prompt/errors/PromptConfigurationConflict.d.ts +10 -0
  132. package/dist/src/prompt/errors/PromptConfigurationConflict.d.ts.map +1 -0
  133. package/dist/src/prompt/errors/PromptConfigurationConflict.js +13 -0
  134. package/dist/src/prompt/errors/PromptConfigurationConflict.js.map +1 -0
  135. package/dist/src/prompt/errors/index.d.ts +2 -0
  136. package/dist/src/prompt/errors/index.d.ts.map +1 -0
  137. package/dist/src/prompt/errors/index.js +2 -0
  138. package/dist/src/prompt/errors/index.js.map +1 -0
  139. package/dist/src/prompt/index.d.ts +4 -0
  140. package/dist/src/prompt/index.d.ts.map +1 -0
  141. package/dist/src/prompt/index.js +3 -0
  142. package/dist/src/prompt/index.js.map +1 -0
  143. package/dist/src/prompt/types.d.ts +57 -0
  144. package/dist/src/prompt/types.d.ts.map +1 -0
  145. package/dist/src/prompt/types.js +2 -0
  146. package/dist/src/prompt/types.js.map +1 -0
  147. package/dist/src/prompt/utils/cloneToolResult.d.ts +12 -0
  148. package/dist/src/prompt/utils/cloneToolResult.d.ts.map +1 -0
  149. package/dist/src/prompt/utils/cloneToolResult.js +28 -0
  150. package/dist/src/prompt/utils/cloneToolResult.js.map +1 -0
  151. package/dist/src/prompt/utils/deepClone.d.ts +9 -0
  152. package/dist/src/prompt/utils/deepClone.d.ts.map +1 -0
  153. package/dist/src/prompt/utils/deepClone.js +15 -0
  154. package/dist/src/prompt/utils/deepClone.js.map +1 -0
  155. package/dist/src/prompt/utils/index.d.ts +5 -0
  156. package/dist/src/prompt/utils/index.d.ts.map +1 -0
  157. package/dist/src/prompt/utils/index.js +5 -0
  158. package/dist/src/prompt/utils/index.js.map +1 -0
  159. package/dist/src/prompt/utils/normalizeTextPrompt.d.ts +14 -0
  160. package/dist/src/prompt/utils/normalizeTextPrompt.d.ts.map +1 -0
  161. package/dist/src/prompt/utils/normalizeTextPrompt.js +22 -0
  162. package/dist/src/prompt/utils/normalizeTextPrompt.js.map +1 -0
  163. package/dist/src/prompt/utils/normalizeToolResult.d.ts +14 -0
  164. package/dist/src/prompt/utils/normalizeToolResult.d.ts.map +1 -0
  165. package/dist/src/prompt/utils/normalizeToolResult.js +27 -0
  166. package/dist/src/prompt/utils/normalizeToolResult.js.map +1 -0
  167. package/dist/src/providers/coreApiProvider/CoreApiErrorHandler.d.ts +13 -0
  168. package/dist/src/providers/coreApiProvider/CoreApiErrorHandler.d.ts.map +1 -0
  169. package/dist/src/providers/coreApiProvider/CoreApiErrorHandler.js +67 -0
  170. package/dist/src/providers/coreApiProvider/CoreApiErrorHandler.js.map +1 -0
  171. package/dist/src/providers/coreApiProvider/CoreApiProvider.d.ts +42 -0
  172. package/dist/src/providers/coreApiProvider/CoreApiProvider.d.ts.map +1 -0
  173. package/dist/src/providers/coreApiProvider/CoreApiProvider.js +97 -0
  174. package/dist/src/providers/coreApiProvider/CoreApiProvider.js.map +1 -0
  175. package/dist/src/providers/coreApiProvider/errors/CoreApiAuthenticationMissing.d.ts +8 -0
  176. package/dist/src/providers/coreApiProvider/errors/CoreApiAuthenticationMissing.d.ts.map +1 -0
  177. package/dist/src/providers/coreApiProvider/errors/CoreApiAuthenticationMissing.js +15 -0
  178. package/dist/src/providers/coreApiProvider/errors/CoreApiAuthenticationMissing.js.map +1 -0
  179. package/dist/src/providers/coreApiProvider/errors/CoreApiMethodNotImplemented.d.ts +9 -0
  180. package/dist/src/providers/coreApiProvider/errors/CoreApiMethodNotImplemented.d.ts.map +1 -0
  181. package/dist/src/providers/coreApiProvider/errors/CoreApiMethodNotImplemented.js +19 -0
  182. package/dist/src/providers/coreApiProvider/errors/CoreApiMethodNotImplemented.js.map +1 -0
  183. package/dist/src/providers/coreApiProvider/errors/index.d.ts +3 -0
  184. package/dist/src/providers/coreApiProvider/errors/index.d.ts.map +1 -0
  185. package/dist/src/providers/coreApiProvider/errors/index.js +3 -0
  186. package/dist/src/providers/coreApiProvider/errors/index.js.map +1 -0
  187. package/dist/src/providers/coreApiProvider/index.d.ts +6 -0
  188. package/dist/src/providers/coreApiProvider/index.d.ts.map +1 -0
  189. package/dist/src/providers/coreApiProvider/index.js +3 -0
  190. package/dist/src/providers/coreApiProvider/index.js.map +1 -0
  191. package/dist/src/providers/coreApiProvider/interfaces/CoreApiProviderConfig.interface.d.ts +29 -0
  192. package/dist/src/providers/coreApiProvider/interfaces/CoreApiProviderConfig.interface.d.ts.map +1 -0
  193. package/dist/src/providers/coreApiProvider/interfaces/CoreApiProviderConfig.interface.js +2 -0
  194. package/dist/src/providers/coreApiProvider/interfaces/CoreApiProviderConfig.interface.js.map +1 -0
  195. package/dist/src/providers/coreApiProvider/interfaces/CoreApiProviderRoutes.interface.d.ts +14 -0
  196. package/dist/src/providers/coreApiProvider/interfaces/CoreApiProviderRoutes.interface.d.ts.map +1 -0
  197. package/dist/src/providers/coreApiProvider/interfaces/CoreApiProviderRoutes.interface.js +2 -0
  198. package/dist/src/providers/coreApiProvider/interfaces/CoreApiProviderRoutes.interface.js.map +1 -0
  199. package/dist/src/providers/coreApiProvider/interfaces/index.d.ts +3 -0
  200. package/dist/src/providers/coreApiProvider/interfaces/index.d.ts.map +1 -0
  201. package/dist/src/providers/coreApiProvider/interfaces/index.js +2 -0
  202. package/dist/src/providers/coreApiProvider/interfaces/index.js.map +1 -0
  203. package/dist/src/providers/coreApiProvider/types.d.ts +16 -0
  204. package/dist/src/providers/coreApiProvider/types.d.ts.map +1 -0
  205. package/dist/src/providers/coreApiProvider/types.js +2 -0
  206. package/dist/src/providers/coreApiProvider/types.js.map +1 -0
  207. package/dist/src/providers/index.d.ts +2 -0
  208. package/dist/src/providers/index.d.ts.map +1 -0
  209. package/dist/src/providers/index.js +2 -0
  210. package/dist/src/providers/index.js.map +1 -0
  211. package/package.json +42 -5
  212. package/index.d.ts +0 -1
  213. package/index.js +0 -1
package/LICENSE CHANGED
@@ -1,6 +1,21 @@
1
1
  MIT License
2
2
 
3
- Copyright (c) 2025
3
+ Copyright (c) 2025 Wonderland
4
+
4
5
  Permission is hereby granted, free of charge, to any person obtaining a copy
5
6
  of this software and associated documentation files (the "Software"), to deal
6
- in the Software without restriction...
7
+ in the Software without restriction, including without limitation the rights
8
+ to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
9
+ copies of the Software, and to permit persons to whom the Software is
10
+ furnished to do so, subject to the following conditions:
11
+
12
+ The above copyright notice and this permission notice shall be included in all
13
+ copies or substantial portions of the Software.
14
+
15
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16
+ IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17
+ FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
18
+ AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19
+ LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
20
+ OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
21
+ SOFTWARE.
package/README.md CHANGED
@@ -1,3 +1,143 @@
1
1
  # @illalabs/sdk
2
2
 
3
- Reserved package name. Actual code will be published in a later version.
3
+ TypeScript SDK for building chat-based blockchain interactions with Illa's Core API.
4
+
5
+ ## 🚀 Installation
6
+
7
+ ```bash
8
+ npm install @illalabs/sdk
9
+ # or
10
+ pnpm add @illalabs/sdk
11
+ ```
12
+
13
+ ## 📖 Quick Start
14
+
15
+ ```typescript
16
+ import { Chat, ContextManager, CoreApiProvider, InMemoryCache, Prompt } from "@illalabs/sdk";
17
+
18
+ // Configure the API provider
19
+ const provider = new CoreApiProvider({
20
+ baseURL: "https://api-dev.illalabs.io",
21
+ headers: {
22
+ "x-api-key": "your-api-key",
23
+ },
24
+ });
25
+
26
+ // Set up context management with caching
27
+ const cache = new InMemoryCache();
28
+ const contextManager = new ContextManager(cache);
29
+
30
+ // Create a chat instance
31
+ const chat = new Chat({
32
+ coreApiProvider: provider,
33
+ contextManager,
34
+ userContext: {
35
+ address: "0x...", // User's wallet address
36
+ },
37
+ });
38
+
39
+ // Send a message
40
+ const prompt = new Prompt({ text: "What is my wallet balance on Base?" });
41
+ const result = await chat.sendMessage(prompt);
42
+
43
+ console.log("Response:", result.response.text);
44
+ ```
45
+
46
+ ## 🧪 Testing
47
+
48
+ ### Unit Tests
49
+
50
+ ```bash
51
+ pnpm test # Run unit tests
52
+ pnpm test:cov # Run with coverage
53
+ ```
54
+
55
+ ### E2E Tests
56
+
57
+ The SDK provides comprehensive E2E testing using Anvil to fork Base mainnet. This ensures tests run against a realistic blockchain environment that's compatible with the Core API (chain ID 8453).
58
+
59
+ #### Prerequisites
60
+
61
+ E2E tests **require** a Base RPC URL for forking:
62
+
63
+ ```bash
64
+ # Set Base fork URL (required for E2E tests)
65
+ export E2E_FORK_BASE_RPC_URL="https://mainnet.base.org"
66
+
67
+ # Get a faster RPC from:
68
+ # - Alchemy: https://www.alchemy.com/
69
+ # - Infura: https://www.infura.io/
70
+ # - QuickNode: https://www.quicknode.com/
71
+ ```
72
+
73
+ #### Quick Start
74
+
75
+ ```bash
76
+ # Mocked API + Anvil (Base fork)
77
+ E2E_FORK_BASE_RPC_URL="https://mainnet.base.org" pnpm test:e2e:anvil
78
+
79
+ # Real API + Anvil (Base fork) - full integration
80
+ E2E_API_KEY=your-api-key E2E_FORK_BASE_RPC_URL="https://mainnet.base.org" pnpm test:e2e:anvil
81
+ ```
82
+
83
+ #### Configuration Options
84
+
85
+ **Required:**
86
+
87
+ - `E2E_FORK_BASE_RPC_URL`: Base mainnet RPC URL for forking (required for all E2E tests)
88
+
89
+ **Optional:**
90
+
91
+ - `E2E_API_KEY`: API key for authentication (if not provided, uses mocked API)
92
+ - `E2E_BASE_URL`: Base URL for the API endpoint (default: `https://api-dev.illalabs.io`)
93
+ - `E2E_TEST_ADDRESS`: Test wallet address (default: `0x5527E7744df42A56ABE7451cbFEDa1601Fa35196`)
94
+
95
+ **Note:** Environment variables use the `E2E_` prefix to avoid conflicts with vitest/vite built-in variables.
96
+
97
+ ## 📚 Documentation
98
+
99
+ - [Introduction](./docs/introduction.mdx)
100
+ - [Authentication](./docs/authentication.mdx)
101
+ - [Quickstart](./docs/quickstart.mdx)
102
+ - [Configuration](./docs/concepts/configuration.mdx)
103
+ - [Error Handling](./docs/concepts/error-handling.mdx)
104
+ - [TypeScript Support](./docs/concepts/typescript-support.mdx)
105
+ - [Testing Guide](./docs/testing.mdx)
106
+
107
+ ## Features
108
+
109
+ - **Chat-based Interface**: Intuitive conversational API for blockchain interactions
110
+ - **Context Management**: Automatic conversation history and state management
111
+ - **Multi-turn Conversations**: Seamless context preservation across messages
112
+ - **Session Persistence**: Resume conversations across different instances
113
+ - **Async Tool Monitoring**: Built-in support for long-running blockchain operations
114
+ - **TypeScript-first**: Full type safety with comprehensive type definitions
115
+ - **Flexible Caching**: Pluggable cache implementations (in-memory, Redis, etc.)
116
+
117
+ ## 📦 Project Structure
118
+
119
+ ```plaintext
120
+ src/
121
+ ├── chat/ # Chat class and related utilities
122
+ ├── context/ # Context management
123
+ ├── caching/ # Cache implementations
124
+ ├── prompt/ # Prompt creation and formatting
125
+ ├── providers/ # API provider implementations
126
+ ├── interfaces/ # TypeScript interfaces
127
+ └── asyncToolChecker/ # Tool execution monitoring
128
+
129
+ test/
130
+ ├── unit/ # Unit tests
131
+ ├── e2e/ # End-to-end tests organized by class
132
+ └── utils/ # Shared test utilities and helpers
133
+ ```
134
+
135
+ ## Contributing
136
+
137
+ Wonderland is a team of top Web3 researchers, developers, and operators who believe that the future needs to be open-source, permissionless, and decentralized
138
+
139
+ [DeFi sucks](https://defi.sucks), but Wonderland is here to make it better
140
+
141
+ ## 📄 License
142
+
143
+ MIT - See [LICENSE](../../LICENSE) for details.
@@ -0,0 +1,39 @@
1
+ import type { AsyncCheckerEvents, AsyncToolCheckerCheckParams, AsyncToolCheckerOptions, EventSubscription, PollingConfig } from "../interfaces/index.js";
2
+ import type { AwaitActionResult } from "./types.js";
3
+ /**
4
+ * Provides high level tooling to monitor asynchronous Core API executions.
5
+ */
6
+ export declare class AsyncToolChecker {
7
+ private readonly coreApiProvider;
8
+ /**
9
+ * Creates a new {@link AsyncToolChecker} instance.
10
+ *
11
+ * @param options Dependencies required to perform asynchronous checks.
12
+ */
13
+ constructor(options: AsyncToolCheckerOptions);
14
+ /**
15
+ * Retrieves the latest status for a specific tool execution.
16
+ *
17
+ * The method delegates the long polling request to the injected {@link ICoreApiProvider}
18
+ * and normalizes the resulting payload into an {@link AwaitActionResult} discriminated union
19
+ * to simplify downstream handling.
20
+ *
21
+ * @param params Parameters describing the tool execution to inspect.
22
+ *
23
+ * @returns Latest status returned by the Core API.
24
+ */
25
+ check(params: AsyncToolCheckerCheckParams): Promise<AwaitActionResult>;
26
+ /**
27
+ * Subscribes to status updates for a tool execution using a polling strategy.
28
+ *
29
+ * TODO: Implement polling orchestration and event dispatch once the execution
30
+ * checker workflow is defined.
31
+ *
32
+ * @param events Callback handlers invoked during the subscription lifecycle.
33
+ * @param pollingConfig Configuration that controls polling cadence and retries.
34
+ *
35
+ * @returns Subscription handle that allows callers to cancel the polling loop.
36
+ */
37
+ subscribe<TPayload, TError>(params: AsyncToolCheckerCheckParams, events: AsyncCheckerEvents<TPayload, TError>, pollingConfig: PollingConfig): EventSubscription;
38
+ }
39
+ //# sourceMappingURL=AsyncToolChecker.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"AsyncToolChecker.d.ts","sourceRoot":"","sources":["../../../src/asyncToolChecker/AsyncToolChecker.ts"],"names":[],"mappings":"AAMA,OAAO,KAAK,EACR,kBAAkB,EAClB,2BAA2B,EAC3B,uBAAuB,EACvB,iBAAiB,EAEjB,aAAa,EAEhB,MAAM,wBAAwB,CAAC;AAChC,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,YAAY,CAAC;AAIpD;;GAEG;AACH,qBAAa,gBAAgB;IACzB,OAAO,CAAC,QAAQ,CAAC,eAAe,CAAmB;IAEnD;;;;OAIG;gBACgB,OAAO,EAAE,uBAAuB;IAInD;;;;;;;;;;OAUG;IACU,KAAK,CAAC,MAAM,EAAE,2BAA2B,GAAG,OAAO,CAAC,iBAAiB,CAAC;IAoBnF;;;;;;;;;;OAUG;IACI,SAAS,CAAC,QAAQ,EAAE,MAAM,EAC7B,MAAM,EAAE,2BAA2B,EACnC,MAAM,EAAE,kBAAkB,CAAC,QAAQ,EAAE,MAAM,CAAC,EAC5C,aAAa,EAAE,aAAa,GAC7B,iBAAiB;CAqMvB"}
@@ -0,0 +1,209 @@
1
+ import { AsyncToolCheckerMaxRetriesExceeded, AsyncToolCheckerTimeout } from "./errors/index.js";
2
+ import { isErrorResponse, normalizeTimeout } from "./utils/index.js";
3
+ /**
4
+ * Provides high level tooling to monitor asynchronous Core API executions.
5
+ */
6
+ export class AsyncToolChecker {
7
+ coreApiProvider;
8
+ /**
9
+ * Creates a new {@link AsyncToolChecker} instance.
10
+ *
11
+ * @param options Dependencies required to perform asynchronous checks.
12
+ */
13
+ constructor(options) {
14
+ this.coreApiProvider = options.coreApiProvider;
15
+ }
16
+ /**
17
+ * Retrieves the latest status for a specific tool execution.
18
+ *
19
+ * The method delegates the long polling request to the injected {@link ICoreApiProvider}
20
+ * and normalizes the resulting payload into an {@link AwaitActionResult} discriminated union
21
+ * to simplify downstream handling.
22
+ *
23
+ * @param params Parameters describing the tool execution to inspect.
24
+ *
25
+ * @returns Latest status returned by the Core API.
26
+ */
27
+ async check(params) {
28
+ const response = await this.coreApiProvider.awaitTransaction({
29
+ toolName: params.toolName,
30
+ protocol: params.protocol,
31
+ args: params.descriptor,
32
+ });
33
+ if (isErrorResponse(response)) {
34
+ return {
35
+ isError: true,
36
+ error: response,
37
+ };
38
+ }
39
+ return {
40
+ isError: false,
41
+ response,
42
+ };
43
+ }
44
+ /**
45
+ * Subscribes to status updates for a tool execution using a polling strategy.
46
+ *
47
+ * TODO: Implement polling orchestration and event dispatch once the execution
48
+ * checker workflow is defined.
49
+ *
50
+ * @param events Callback handlers invoked during the subscription lifecycle.
51
+ * @param pollingConfig Configuration that controls polling cadence and retries.
52
+ *
53
+ * @returns Subscription handle that allows callers to cancel the polling loop.
54
+ */
55
+ subscribe(params, events, pollingConfig) {
56
+ const intervalMs = normalizeTimeout(pollingConfig.interval);
57
+ const retryThresholdMs = normalizeTimeout(pollingConfig.retryThreshold);
58
+ const maxRetries = Math.max(0, Math.floor(pollingConfig.maxRetries));
59
+ const maxDurationSeconds = Math.max(0, pollingConfig.maxDuration);
60
+ const maxDurationMs = maxDurationSeconds > 0 ? normalizeTimeout(maxDurationSeconds) : undefined;
61
+ let retries = 0;
62
+ let isActive = true;
63
+ let previous = null;
64
+ let pollingTimer;
65
+ let maxDurationTimer;
66
+ let inFlightController = null;
67
+ const clearTimer = (timer) => {
68
+ if (timer !== undefined) {
69
+ clearTimeout(timer);
70
+ }
71
+ };
72
+ const finalize = (error, notifyError = error !== undefined) => {
73
+ if (!isActive) {
74
+ return;
75
+ }
76
+ isActive = false;
77
+ clearTimer(pollingTimer);
78
+ pollingTimer = undefined;
79
+ clearTimer(maxDurationTimer);
80
+ maxDurationTimer = undefined;
81
+ if (inFlightController !== null) {
82
+ inFlightController.abort();
83
+ inFlightController = null;
84
+ }
85
+ if (notifyError && error !== undefined) {
86
+ events.onError?.(error);
87
+ }
88
+ };
89
+ if (maxDurationMs !== undefined) {
90
+ maxDurationTimer = setTimeout(() => {
91
+ finalize(new AsyncToolCheckerTimeout(maxDurationSeconds));
92
+ }, maxDurationMs);
93
+ }
94
+ const emitStatus = (current) => {
95
+ if (!isActive) {
96
+ return false;
97
+ }
98
+ // Avoids duplicate notifications when no state transition occurred.
99
+ if (previous === current) {
100
+ return true;
101
+ }
102
+ const event = {
103
+ previous,
104
+ current,
105
+ };
106
+ try {
107
+ events.onStatusChange(event);
108
+ }
109
+ catch (handlerError) {
110
+ finalize(handlerError);
111
+ return false;
112
+ }
113
+ previous = current;
114
+ return true;
115
+ };
116
+ const scheduleNext = (delayMs) => {
117
+ if (!isActive) {
118
+ return;
119
+ }
120
+ clearTimer(pollingTimer);
121
+ pollingTimer = setTimeout(() => {
122
+ pollingTimer = undefined;
123
+ void tick();
124
+ }, delayMs);
125
+ };
126
+ const handleRetryableError = (error) => {
127
+ retries += 1;
128
+ if (retries > maxRetries) {
129
+ finalize(new AsyncToolCheckerMaxRetriesExceeded(maxRetries, error));
130
+ return;
131
+ }
132
+ scheduleNext(retryThresholdMs);
133
+ };
134
+ const handleSuccessResponse = (response) => {
135
+ retries = 0;
136
+ if (!emitStatus(response)) {
137
+ return;
138
+ }
139
+ if (response.pollStatus === "pending") {
140
+ scheduleNext(intervalMs);
141
+ return;
142
+ }
143
+ finalize();
144
+ };
145
+ /**
146
+ * Normalizes successful polling responses by preserving pending and completed states.
147
+ */
148
+ const normalizeSuccessResponse = (response) => {
149
+ if (response.pollStatus !== "failed") {
150
+ return response;
151
+ }
152
+ return {
153
+ ...response,
154
+ error: response.error,
155
+ };
156
+ };
157
+ const tick = async () => {
158
+ if (!isActive) {
159
+ return;
160
+ }
161
+ const controller = new AbortController();
162
+ inFlightController = controller;
163
+ let response;
164
+ try {
165
+ response = await this.coreApiProvider.awaitTransaction({
166
+ toolName: params.toolName,
167
+ protocol: params.protocol,
168
+ args: params.descriptor,
169
+ }, { signal: controller.signal });
170
+ }
171
+ catch (error) {
172
+ if (!isActive) {
173
+ return;
174
+ }
175
+ if (controller.signal.aborted) {
176
+ finalize(undefined, false);
177
+ return;
178
+ }
179
+ finalize(error);
180
+ return;
181
+ }
182
+ finally {
183
+ if (inFlightController === controller) {
184
+ inFlightController = null;
185
+ }
186
+ }
187
+ if (!isActive) {
188
+ return;
189
+ }
190
+ if (isErrorResponse(response)) {
191
+ const statusCode = response.statusCode;
192
+ if (statusCode === 400 || statusCode === 429) {
193
+ handleRetryableError(response);
194
+ return;
195
+ }
196
+ finalize(response);
197
+ return;
198
+ }
199
+ handleSuccessResponse(normalizeSuccessResponse(response));
200
+ };
201
+ void tick();
202
+ return {
203
+ unsubscribe: () => {
204
+ finalize(undefined, false);
205
+ },
206
+ };
207
+ }
208
+ }
209
+ //# sourceMappingURL=AsyncToolChecker.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"AsyncToolChecker.js","sourceRoot":"","sources":["../../../src/asyncToolChecker/AsyncToolChecker.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,23 @@
1
+ import type { LongPollingActionErrorResponse } from "@illalabs/interfaces";
2
+ /**
3
+ * Error emitted when the async tool checker exhausts the configured retry attempts for recoverable errors.
4
+ */
5
+ export declare class AsyncToolCheckerMaxRetriesExceeded extends Error {
6
+ /**
7
+ * Number of retry attempts that were configured.
8
+ */
9
+ readonly maxRetries: number;
10
+ /**
11
+ * Last error response received from the Core API.
12
+ */
13
+ readonly lastError: LongPollingActionErrorResponse;
14
+ /**
15
+ * Creates a new {@link AsyncToolCheckerMaxRetriesExceeded} instance.
16
+ *
17
+ * @param maxRetries Maximum number of retries allowed before failing.
18
+ * @param lastError Last error emitted by the Core API.
19
+ * @param options Error options.
20
+ */
21
+ constructor(maxRetries: number, lastError: LongPollingActionErrorResponse, options?: ErrorOptions);
22
+ }
23
+ //# sourceMappingURL=AsyncToolCheckerMaxRetriesExceeded.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"AsyncToolCheckerMaxRetriesExceeded.d.ts","sourceRoot":"","sources":["../../../../src/asyncToolChecker/errors/AsyncToolCheckerMaxRetriesExceeded.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,8BAA8B,EAAE,MAAM,sBAAsB,CAAC;AAE3E;;GAEG;AACH,qBAAa,kCAAmC,SAAQ,KAAK;IACzD;;OAEG;IACH,SAAgB,UAAU,EAAE,MAAM,CAAC;IAEnC;;OAEG;IACH,SAAgB,SAAS,EAAE,8BAA8B,CAAC;IAE1D;;;;;;OAMG;gBAEC,UAAU,EAAE,MAAM,EAClB,SAAS,EAAE,8BAA8B,EACzC,OAAO,CAAC,EAAE,YAAY;CAU7B"}
@@ -0,0 +1,30 @@
1
+ /**
2
+ * Error emitted when the async tool checker exhausts the configured retry attempts for recoverable errors.
3
+ */
4
+ export class AsyncToolCheckerMaxRetriesExceeded extends Error {
5
+ /**
6
+ * Number of retry attempts that were configured.
7
+ */
8
+ maxRetries;
9
+ /**
10
+ * Last error response received from the Core API.
11
+ */
12
+ lastError;
13
+ /**
14
+ * Creates a new {@link AsyncToolCheckerMaxRetriesExceeded} instance.
15
+ *
16
+ * @param maxRetries Maximum number of retries allowed before failing.
17
+ * @param lastError Last error emitted by the Core API.
18
+ * @param options Error options.
19
+ */
20
+ constructor(maxRetries, lastError, options) {
21
+ super(`Async tool checker exceeded maximum retry attempts (${maxRetries}).`, {
22
+ cause: lastError,
23
+ ...options,
24
+ });
25
+ this.name = "AsyncToolCheckerMaxRetriesExceeded";
26
+ this.maxRetries = maxRetries;
27
+ this.lastError = lastError;
28
+ }
29
+ }
30
+ //# sourceMappingURL=AsyncToolCheckerMaxRetriesExceeded.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"AsyncToolCheckerMaxRetriesExceeded.js","sourceRoot":"","sources":["../../../../src/asyncToolChecker/errors/AsyncToolCheckerMaxRetriesExceeded.ts"],"names":[],"mappings":"AAEA;;GAEG;AACH,MAAM,OAAO,kCAAmC,SAAQ,KAAK;IACzD;;OAEG;IACa,UAAU,CAAS;IAEnC;;OAEG;IACa,SAAS,CAAiC;IAE1D;;;;;;OAMG;IACH,YACI,UAAkB,EAClB,SAAyC,EACzC,OAAsB;QAEtB,KAAK,CAAC,uDAAuD,UAAU,IAAI,EAAE;YACzE,KAAK,EAAE,SAAS;YAChB,GAAG,OAAO;SACb,CAAC,CAAC;QACH,IAAI,CAAC,IAAI,GAAG,oCAAoC,CAAC;QACjD,IAAI,CAAC,UAAU,GAAG,UAAU,CAAC;QAC7B,IAAI,CAAC,SAAS,GAAG,SAAS,CAAC;IAC/B,CAAC;CACJ"}
@@ -0,0 +1,17 @@
1
+ /**
2
+ * Error thrown when an {@link AsyncToolChecker} method is invoked prior to its implementation.
3
+ */
4
+ export declare class AsyncToolCheckerMethodNotImplemented extends Error {
5
+ /**
6
+ * Additional context useful for debugging the method invocation.
7
+ */
8
+ readonly context?: unknown;
9
+ /**
10
+ * Creates a new {@link AsyncToolCheckerMethodNotImplemented} instance.
11
+ *
12
+ * @param methodName Name of the method that is not implemented.
13
+ * @param context Optional contextual information describing the invocation.
14
+ */
15
+ constructor(methodName: string, context?: unknown);
16
+ }
17
+ //# sourceMappingURL=AsyncToolCheckerMethodNotImplemented.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"AsyncToolCheckerMethodNotImplemented.d.ts","sourceRoot":"","sources":["../../../../src/asyncToolChecker/errors/AsyncToolCheckerMethodNotImplemented.ts"],"names":[],"mappings":"AAAA;;GAEG;AACH,qBAAa,oCAAqC,SAAQ,KAAK;IAC3D;;OAEG;IACH,SAAgB,OAAO,CAAC,EAAE,OAAO,CAAC;IAElC;;;;;OAKG;gBACgB,UAAU,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,OAAO;CAU3D"}
@@ -0,0 +1,26 @@
1
+ /**
2
+ * Error thrown when an {@link AsyncToolChecker} method is invoked prior to its implementation.
3
+ */
4
+ export class AsyncToolCheckerMethodNotImplemented extends Error {
5
+ /**
6
+ * Additional context useful for debugging the method invocation.
7
+ */
8
+ context;
9
+ /**
10
+ * Creates a new {@link AsyncToolCheckerMethodNotImplemented} instance.
11
+ *
12
+ * @param methodName Name of the method that is not implemented.
13
+ * @param context Optional contextual information describing the invocation.
14
+ */
15
+ constructor(methodName, context) {
16
+ super(`AsyncToolChecker method "${methodName}" is not implemented.`);
17
+ this.name = "AsyncToolCheckerMethodNotImplemented";
18
+ if (context !== undefined) {
19
+ Object.defineProperty(this, "context", {
20
+ value: context,
21
+ enumerable: true,
22
+ });
23
+ }
24
+ }
25
+ }
26
+ //# sourceMappingURL=AsyncToolCheckerMethodNotImplemented.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"AsyncToolCheckerMethodNotImplemented.js","sourceRoot":"","sources":["../../../../src/asyncToolChecker/errors/AsyncToolCheckerMethodNotImplemented.ts"],"names":[],"mappings":"AAAA;;GAEG;AACH,MAAM,OAAO,oCAAqC,SAAQ,KAAK;IAC3D;;OAEG;IACa,OAAO,CAAW;IAElC;;;;;OAKG;IACH,YAAmB,UAAkB,EAAE,OAAiB;QACpD,KAAK,CAAC,4BAA4B,UAAU,uBAAuB,CAAC,CAAC;QACrE,IAAI,CAAC,IAAI,GAAG,sCAAsC,CAAC;QACnD,IAAI,OAAO,KAAK,SAAS,EAAE,CAAC;YACxB,MAAM,CAAC,cAAc,CAAC,IAAI,EAAE,SAAS,EAAE;gBACnC,KAAK,EAAE,OAAO;gBACd,UAAU,EAAE,IAAI;aACnB,CAAC,CAAC;QACP,CAAC;IACL,CAAC;CACJ"}
@@ -0,0 +1,17 @@
1
+ /**
2
+ * Error emitted when an asynchronous polling operation exceeds the configured maximum duration.
3
+ */
4
+ export declare class AsyncToolCheckerTimeout extends Error {
5
+ /**
6
+ * Maximum duration, expressed in seconds, that was exceeded.
7
+ */
8
+ readonly maxDuration: number;
9
+ /**
10
+ * Creates a new {@link AsyncToolCheckerTimeout} instance.
11
+ *
12
+ * @param maxDuration Maximum duration, in seconds, permitted for the polling loop.
13
+ * @param options Error options.
14
+ */
15
+ constructor(maxDuration: number, options?: ErrorOptions);
16
+ }
17
+ //# sourceMappingURL=AsyncToolCheckerTimeout.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"AsyncToolCheckerTimeout.d.ts","sourceRoot":"","sources":["../../../../src/asyncToolChecker/errors/AsyncToolCheckerTimeout.ts"],"names":[],"mappings":"AAAA;;GAEG;AACH,qBAAa,uBAAwB,SAAQ,KAAK;IAC9C;;OAEG;IACH,SAAgB,WAAW,EAAE,MAAM,CAAC;IAEpC;;;;;OAKG;gBACgB,WAAW,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,YAAY;CAKjE"}
@@ -0,0 +1,21 @@
1
+ /**
2
+ * Error emitted when an asynchronous polling operation exceeds the configured maximum duration.
3
+ */
4
+ export class AsyncToolCheckerTimeout extends Error {
5
+ /**
6
+ * Maximum duration, expressed in seconds, that was exceeded.
7
+ */
8
+ maxDuration;
9
+ /**
10
+ * Creates a new {@link AsyncToolCheckerTimeout} instance.
11
+ *
12
+ * @param maxDuration Maximum duration, in seconds, permitted for the polling loop.
13
+ * @param options Error options.
14
+ */
15
+ constructor(maxDuration, options) {
16
+ super(`Async tool checker exceeded maximum duration of ${maxDuration} seconds.`, options);
17
+ this.name = "AsyncToolCheckerTimeout";
18
+ this.maxDuration = maxDuration;
19
+ }
20
+ }
21
+ //# sourceMappingURL=AsyncToolCheckerTimeout.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"AsyncToolCheckerTimeout.js","sourceRoot":"","sources":["../../../../src/asyncToolChecker/errors/AsyncToolCheckerTimeout.ts"],"names":[],"mappings":"AAAA;;GAEG;AACH,MAAM,OAAO,uBAAwB,SAAQ,KAAK;IAC9C;;OAEG;IACa,WAAW,CAAS;IAEpC;;;;;OAKG;IACH,YAAmB,WAAmB,EAAE,OAAsB;QAC1D,KAAK,CAAC,mDAAmD,WAAW,WAAW,EAAE,OAAO,CAAC,CAAC;QAC1F,IAAI,CAAC,IAAI,GAAG,yBAAyB,CAAC;QACtC,IAAI,CAAC,WAAW,GAAG,WAAW,CAAC;IACnC,CAAC;CACJ"}
@@ -0,0 +1,4 @@
1
+ export { AsyncToolCheckerMethodNotImplemented } from "./AsyncToolCheckerMethodNotImplemented.js";
2
+ export { AsyncToolCheckerTimeout } from "./AsyncToolCheckerTimeout.js";
3
+ export { AsyncToolCheckerMaxRetriesExceeded } from "./AsyncToolCheckerMaxRetriesExceeded.js";
4
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/asyncToolChecker/errors/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,oCAAoC,EAAE,MAAM,2CAA2C,CAAC;AACjG,OAAO,EAAE,uBAAuB,EAAE,MAAM,8BAA8B,CAAC;AACvE,OAAO,EAAE,kCAAkC,EAAE,MAAM,yCAAyC,CAAC"}
@@ -0,0 +1,4 @@
1
+ export { AsyncToolCheckerMethodNotImplemented } from "./AsyncToolCheckerMethodNotImplemented.js";
2
+ export { AsyncToolCheckerTimeout } from "./AsyncToolCheckerTimeout.js";
3
+ export { AsyncToolCheckerMaxRetriesExceeded } from "./AsyncToolCheckerMaxRetriesExceeded.js";
4
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/asyncToolChecker/errors/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,oCAAoC,EAAE,MAAM,2CAA2C,CAAC;AACjG,OAAO,EAAE,uBAAuB,EAAE,MAAM,8BAA8B,CAAC;AACvE,OAAO,EAAE,kCAAkC,EAAE,MAAM,yCAAyC,CAAC"}
@@ -0,0 +1,6 @@
1
+ export { AsyncToolChecker } from "./AsyncToolChecker.js";
2
+ export type { AsyncCheckerEvents, AsyncToolCheckerCheckParams, AsyncToolCheckerOptions, EventSubscription, PollingConfig, StatusChangedEvent, } from "../interfaces/index.js";
3
+ export { AsyncToolCheckerMaxRetriesExceeded, AsyncToolCheckerMethodNotImplemented, AsyncToolCheckerTimeout, } from "./errors/index.js";
4
+ export * from "./types.js";
5
+ export * from "./utils/index.js";
6
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/asyncToolChecker/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,gBAAgB,EAAE,MAAM,uBAAuB,CAAC;AACzD,YAAY,EACR,kBAAkB,EAClB,2BAA2B,EAC3B,uBAAuB,EACvB,iBAAiB,EACjB,aAAa,EACb,kBAAkB,GACrB,MAAM,wBAAwB,CAAC;AAChC,OAAO,EACH,kCAAkC,EAClC,oCAAoC,EACpC,uBAAuB,GAC1B,MAAM,mBAAmB,CAAC;AAC3B,cAAc,YAAY,CAAC;AAC3B,cAAc,kBAAkB,CAAC"}
@@ -0,0 +1,5 @@
1
+ export { AsyncToolChecker } from "./AsyncToolChecker.js";
2
+ export { AsyncToolCheckerMaxRetriesExceeded, AsyncToolCheckerMethodNotImplemented, AsyncToolCheckerTimeout, } from "./errors/index.js";
3
+ export * from "./types.js";
4
+ export * from "./utils/index.js";
5
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/asyncToolChecker/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,gBAAgB,EAAE,MAAM,uBAAuB,CAAC;AASzD,OAAO,EACH,kCAAkC,EAClC,oCAAoC,EACpC,uBAAuB,GAC1B,MAAM,mBAAmB,CAAC;AAC3B,cAAc,YAAY,CAAC;AAC3B,cAAc,kBAAkB,CAAC"}