ai-functions 0.2.19 → 0.3.0

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 (313) hide show
  1. package/LICENSE +1 -1
  2. package/README.md +112 -21
  3. package/bin/cli.js +5 -0
  4. package/dist/cli/index.d.ts +10 -0
  5. package/dist/cli/index.d.ts.map +1 -0
  6. package/dist/cli/index.js +38 -0
  7. package/dist/cli/index.js.map +1 -0
  8. package/dist/cli/index.test.d.ts +2 -0
  9. package/dist/cli/index.test.d.ts.map +1 -0
  10. package/dist/cli/index.test.js +35 -0
  11. package/dist/cli/index.test.js.map +1 -0
  12. package/dist/constants/models.d.ts +10 -0
  13. package/dist/constants/models.d.ts.map +1 -0
  14. package/dist/constants/models.js +12 -0
  15. package/dist/constants/models.js.map +1 -0
  16. package/dist/converters/index.d.ts +3 -0
  17. package/dist/converters/index.d.ts.map +1 -0
  18. package/dist/converters/index.js +3 -0
  19. package/dist/converters/index.js.map +1 -0
  20. package/dist/converters/model.d.ts +4 -0
  21. package/dist/converters/model.d.ts.map +1 -0
  22. package/dist/converters/model.js +19 -0
  23. package/dist/converters/model.js.map +1 -0
  24. package/dist/converters/schema.d.ts +4 -0
  25. package/dist/converters/schema.d.ts.map +1 -0
  26. package/dist/converters/schema.js +25 -0
  27. package/dist/converters/schema.js.map +1 -0
  28. package/dist/core/responses.d.ts +5 -0
  29. package/dist/core/responses.d.ts.map +1 -0
  30. package/dist/core/responses.js +16 -0
  31. package/dist/core/responses.js.map +1 -0
  32. package/dist/core/responses.test.d.ts +2 -0
  33. package/dist/core/responses.test.d.ts.map +1 -0
  34. package/dist/core/responses.test.js +31 -0
  35. package/dist/core/responses.test.js.map +1 -0
  36. package/dist/errors.d.ts +6 -0
  37. package/dist/errors.d.ts.map +1 -0
  38. package/dist/errors.js +9 -0
  39. package/dist/errors.js.map +1 -0
  40. package/dist/examples/streaming.test.d.ts +2 -0
  41. package/dist/examples/streaming.test.d.ts.map +1 -0
  42. package/dist/examples/streaming.test.js +176 -0
  43. package/dist/examples/streaming.test.js.map +1 -0
  44. package/dist/factory/__tests__/index.test.d.ts +2 -0
  45. package/dist/factory/__tests__/index.test.d.ts.map +1 -0
  46. package/dist/factory/__tests__/index.test.js +430 -0
  47. package/dist/factory/__tests__/index.test.js.map +1 -0
  48. package/dist/factory/__tests__/list.test.d.ts +2 -0
  49. package/dist/factory/__tests__/list.test.d.ts.map +1 -0
  50. package/dist/factory/__tests__/list.test.js +92 -0
  51. package/dist/factory/__tests__/list.test.js.map +1 -0
  52. package/dist/factory/index.d.ts +20 -0
  53. package/dist/factory/index.d.ts.map +1 -0
  54. package/dist/factory/index.js +287 -0
  55. package/dist/factory/index.js.map +1 -0
  56. package/dist/factory/index.test.d.ts +2 -0
  57. package/dist/factory/index.test.d.ts.map +1 -0
  58. package/dist/factory/index.test.js +287 -0
  59. package/dist/factory/index.test.js.map +1 -0
  60. package/dist/factory/list.d.ts +3 -0
  61. package/dist/factory/list.d.ts.map +1 -0
  62. package/dist/factory/list.js +221 -0
  63. package/dist/factory/list.js.map +1 -0
  64. package/dist/factory/list.test.d.ts +2 -0
  65. package/dist/factory/list.test.d.ts.map +1 -0
  66. package/dist/factory/list.test.js +84 -0
  67. package/dist/factory/list.test.js.map +1 -0
  68. package/dist/generate/index.d.ts +5 -0
  69. package/dist/generate/index.d.ts.map +1 -0
  70. package/dist/generate/index.js +17 -0
  71. package/dist/generate/index.js.map +1 -0
  72. package/dist/index.d.ts +5 -0
  73. package/dist/index.d.ts.map +1 -0
  74. package/dist/index.js +53 -0
  75. package/dist/index.js.map +1 -0
  76. package/dist/index.test.d.ts +2 -0
  77. package/dist/index.test.d.ts.map +1 -0
  78. package/dist/index.test.js +59 -0
  79. package/dist/index.test.js.map +1 -0
  80. package/dist/list/await.d.ts +3 -0
  81. package/dist/list/await.d.ts.map +1 -0
  82. package/dist/list/await.js +28 -0
  83. package/dist/list/await.js.map +1 -0
  84. package/dist/list/constants.d.ts +4 -0
  85. package/dist/list/constants.d.ts.map +1 -0
  86. package/dist/list/constants.js +5 -0
  87. package/dist/list/constants.js.map +1 -0
  88. package/dist/list/create-function.d.ts +3 -0
  89. package/dist/list/create-function.d.ts.map +1 -0
  90. package/dist/list/create-function.js +11 -0
  91. package/dist/list/create-function.js.map +1 -0
  92. package/dist/list/index.d.ts +4 -0
  93. package/dist/list/index.d.ts.map +1 -0
  94. package/dist/list/index.js +5 -0
  95. package/dist/list/index.js.map +1 -0
  96. package/dist/list/prompt.d.ts +3 -0
  97. package/dist/list/prompt.d.ts.map +1 -0
  98. package/dist/list/prompt.js +6 -0
  99. package/dist/list/prompt.js.map +1 -0
  100. package/dist/list/schemas.d.ts +4 -0
  101. package/dist/list/schemas.d.ts.map +1 -0
  102. package/dist/list/schemas.js +8 -0
  103. package/dist/list/schemas.js.map +1 -0
  104. package/dist/list/stream.d.ts +3 -0
  105. package/dist/list/stream.d.ts.map +1 -0
  106. package/dist/list/stream.js +33 -0
  107. package/dist/list/stream.js.map +1 -0
  108. package/dist/list/types.d.ts +11 -0
  109. package/dist/list/types.d.ts.map +1 -0
  110. package/dist/list/types.js +2 -0
  111. package/dist/list/types.js.map +1 -0
  112. package/dist/list/validation.d.ts +3 -0
  113. package/dist/list/validation.d.ts.map +1 -0
  114. package/dist/list/validation.js +12 -0
  115. package/dist/list/validation.js.map +1 -0
  116. package/dist/providers/config.d.ts +4 -0
  117. package/dist/providers/config.d.ts.map +1 -0
  118. package/dist/providers/config.js +21 -0
  119. package/dist/providers/config.js.map +1 -0
  120. package/dist/providers/config.test.d.ts +2 -0
  121. package/dist/providers/config.test.d.ts.map +1 -0
  122. package/dist/providers/config.test.js +37 -0
  123. package/dist/providers/config.test.js.map +1 -0
  124. package/dist/proxy/constants.d.ts +4 -0
  125. package/dist/proxy/constants.d.ts.map +1 -0
  126. package/dist/proxy/constants.js +5 -0
  127. package/dist/proxy/constants.js.map +1 -0
  128. package/dist/proxy/create-function.d.ts +4 -0
  129. package/dist/proxy/create-function.d.ts.map +1 -0
  130. package/dist/proxy/create-function.js +24 -0
  131. package/dist/proxy/create-function.js.map +1 -0
  132. package/dist/proxy/create-proxy.d.ts +2 -0
  133. package/dist/proxy/create-proxy.d.ts.map +1 -0
  134. package/dist/proxy/create-proxy.js +11 -0
  135. package/dist/proxy/create-proxy.js.map +1 -0
  136. package/dist/proxy/function-generator.d.ts +9 -0
  137. package/dist/proxy/function-generator.d.ts.map +1 -0
  138. package/dist/proxy/function-generator.js +29 -0
  139. package/dist/proxy/function-generator.js.map +1 -0
  140. package/dist/proxy/index.d.ts +4 -0
  141. package/dist/proxy/index.d.ts.map +1 -0
  142. package/dist/proxy/index.js +4 -0
  143. package/dist/proxy/index.js.map +1 -0
  144. package/dist/proxy/prompt.d.ts +2 -0
  145. package/dist/proxy/prompt.d.ts.map +1 -0
  146. package/dist/proxy/prompt.js +6 -0
  147. package/dist/proxy/prompt.js.map +1 -0
  148. package/dist/proxy/types.d.ts +7 -0
  149. package/dist/proxy/types.d.ts.map +1 -0
  150. package/dist/proxy/types.js +2 -0
  151. package/dist/proxy/types.js.map +1 -0
  152. package/dist/queue/manager.d.ts +5 -0
  153. package/dist/queue/manager.d.ts.map +1 -0
  154. package/dist/queue/manager.js +37 -0
  155. package/dist/queue/manager.js.map +1 -0
  156. package/dist/queue/manager.test.d.ts +2 -0
  157. package/dist/queue/manager.test.d.ts.map +1 -0
  158. package/dist/queue/manager.test.js +52 -0
  159. package/dist/queue/manager.test.js.map +1 -0
  160. package/dist/schema-converter.d.ts +4 -0
  161. package/dist/schema-converter.d.ts.map +1 -0
  162. package/dist/schema-converter.js +30 -0
  163. package/dist/schema-converter.js.map +1 -0
  164. package/dist/stream/index.d.ts +7 -0
  165. package/dist/stream/index.d.ts.map +1 -0
  166. package/dist/stream/index.js +23 -0
  167. package/dist/stream/index.js.map +1 -0
  168. package/dist/streaming/utils.d.ts +4 -0
  169. package/dist/streaming/utils.d.ts.map +1 -0
  170. package/dist/streaming/utils.js +131 -0
  171. package/dist/streaming/utils.js.map +1 -0
  172. package/dist/streaming/utils.test.d.ts +2 -0
  173. package/dist/streaming/utils.test.d.ts.map +1 -0
  174. package/dist/streaming/utils.test.js +84 -0
  175. package/dist/streaming/utils.test.js.map +1 -0
  176. package/dist/templates/result.d.ts +7 -0
  177. package/dist/templates/result.d.ts.map +1 -0
  178. package/dist/templates/result.js +40 -0
  179. package/dist/templates/result.js.map +1 -0
  180. package/dist/templates/result.test.d.ts +2 -0
  181. package/dist/templates/result.test.d.ts.map +1 -0
  182. package/dist/templates/result.test.js +75 -0
  183. package/dist/templates/result.test.js.map +1 -0
  184. package/dist/test/setup.d.ts +2 -0
  185. package/dist/test/setup.d.ts.map +1 -0
  186. package/dist/test/setup.js +21 -0
  187. package/dist/test/setup.js.map +1 -0
  188. package/dist/test-types.d.ts +13 -0
  189. package/dist/test-types.d.ts.map +1 -0
  190. package/dist/test-types.js +55 -0
  191. package/dist/test-types.js.map +1 -0
  192. package/dist/types/index.d.ts +4 -0
  193. package/dist/types/index.d.ts.map +1 -0
  194. package/dist/types/index.js +4 -0
  195. package/dist/types/index.js.map +1 -0
  196. package/dist/types/list.d.ts +10 -0
  197. package/dist/types/list.d.ts.map +1 -0
  198. package/dist/types/list.js +2 -0
  199. package/dist/types/list.js.map +1 -0
  200. package/dist/types/model.d.ts +7 -0
  201. package/dist/types/model.d.ts.map +1 -0
  202. package/dist/types/model.js +2 -0
  203. package/dist/types/model.js.map +1 -0
  204. package/dist/types/options.d.ts +25 -0
  205. package/dist/types/options.d.ts.map +1 -0
  206. package/dist/types/options.js +2 -0
  207. package/dist/types/options.js.map +1 -0
  208. package/dist/types/schema.d.ts +5 -0
  209. package/dist/types/schema.d.ts.map +1 -0
  210. package/dist/types/schema.js +2 -0
  211. package/dist/types/schema.js.map +1 -0
  212. package/dist/types.d.ts +113 -0
  213. package/dist/types.d.ts.map +1 -0
  214. package/dist/types.js +9 -0
  215. package/dist/types.js.map +1 -0
  216. package/dist/utils/__tests__/request-handler.test.d.ts +2 -0
  217. package/dist/utils/__tests__/request-handler.test.d.ts.map +1 -0
  218. package/dist/utils/__tests__/request-handler.test.js +134 -0
  219. package/dist/utils/__tests__/request-handler.test.js.map +1 -0
  220. package/dist/utils/__tests__/schema.test.d.ts +2 -0
  221. package/dist/utils/__tests__/schema.test.d.ts.map +1 -0
  222. package/dist/utils/__tests__/schema.test.js +49 -0
  223. package/dist/utils/__tests__/schema.test.js.map +1 -0
  224. package/dist/utils/__tests__/stream-progress.test.d.ts +2 -0
  225. package/dist/utils/__tests__/stream-progress.test.d.ts.map +1 -0
  226. package/dist/utils/__tests__/stream-progress.test.js +85 -0
  227. package/dist/utils/__tests__/stream-progress.test.js.map +1 -0
  228. package/dist/utils/index.d.ts +2 -0
  229. package/dist/utils/index.d.ts.map +1 -0
  230. package/dist/utils/index.js +2 -0
  231. package/dist/utils/index.js.map +1 -0
  232. package/dist/utils/request-handler.d.ts +17 -0
  233. package/dist/utils/request-handler.d.ts.map +1 -0
  234. package/dist/utils/request-handler.js +105 -0
  235. package/dist/utils/request-handler.js.map +1 -0
  236. package/dist/utils/schema.d.ts +11 -0
  237. package/dist/utils/schema.d.ts.map +1 -0
  238. package/dist/utils/schema.js +51 -0
  239. package/dist/utils/schema.js.map +1 -0
  240. package/dist/utils/stream-progress.d.ts +17 -0
  241. package/dist/utils/stream-progress.d.ts.map +1 -0
  242. package/dist/utils/stream-progress.js +86 -0
  243. package/dist/utils/stream-progress.js.map +1 -0
  244. package/dist/utils/validation.d.ts +3 -0
  245. package/dist/utils/validation.d.ts.map +1 -0
  246. package/dist/utils/validation.js +30 -0
  247. package/dist/utils/validation.js.map +1 -0
  248. package/package.json +56 -40
  249. package/db/cache.ts +0 -6
  250. package/db/mongo.ts +0 -75
  251. package/dist/mjs/db/cache.d.ts +0 -1
  252. package/dist/mjs/db/cache.js +0 -5
  253. package/dist/mjs/db/mongo.d.ts +0 -31
  254. package/dist/mjs/db/mongo.js +0 -48
  255. package/dist/mjs/examples/data.d.ts +0 -1105
  256. package/dist/mjs/examples/data.js +0 -1105
  257. package/dist/mjs/functions/ai.d.ts +0 -20
  258. package/dist/mjs/functions/ai.js +0 -83
  259. package/dist/mjs/functions/ai.test.d.ts +0 -1
  260. package/dist/mjs/functions/ai.test.js +0 -29
  261. package/dist/mjs/functions/gpt.d.ts +0 -4
  262. package/dist/mjs/functions/gpt.js +0 -10
  263. package/dist/mjs/functions/list.d.ts +0 -7
  264. package/dist/mjs/functions/list.js +0 -72
  265. package/dist/mjs/index.d.ts +0 -3
  266. package/dist/mjs/index.js +0 -3
  267. package/dist/mjs/queue/kafka.d.ts +0 -0
  268. package/dist/mjs/queue/kafka.js +0 -1
  269. package/dist/mjs/queue/memory.d.ts +0 -0
  270. package/dist/mjs/queue/memory.js +0 -1
  271. package/dist/mjs/queue/mongo.d.ts +0 -30
  272. package/dist/mjs/queue/mongo.js +0 -42
  273. package/dist/mjs/streams/kafka.d.ts +0 -0
  274. package/dist/mjs/streams/kafka.js +0 -1
  275. package/dist/mjs/streams/memory.d.ts +0 -0
  276. package/dist/mjs/streams/memory.js +0 -1
  277. package/dist/mjs/streams/mongo.d.ts +0 -0
  278. package/dist/mjs/streams/mongo.js +0 -1
  279. package/dist/mjs/streams/types.d.ts +0 -0
  280. package/dist/mjs/streams/types.js +0 -1
  281. package/dist/mjs/types.d.ts +0 -11
  282. package/dist/mjs/types.js +0 -1
  283. package/dist/mjs/utils/completion.d.ts +0 -9
  284. package/dist/mjs/utils/completion.js +0 -20
  285. package/dist/mjs/utils/schema.d.ts +0 -10
  286. package/dist/mjs/utils/schema.js +0 -72
  287. package/dist/mjs/utils/schema.test.d.ts +0 -1
  288. package/dist/mjs/utils/schema.test.js +0 -60
  289. package/dist/mjs/utils/state.d.ts +0 -1
  290. package/dist/mjs/utils/state.js +0 -19
  291. package/examples/data.ts +0 -1105
  292. package/fixup +0 -11
  293. package/functions/ai.test.ts +0 -41
  294. package/functions/ai.ts +0 -115
  295. package/functions/gpt.ts +0 -12
  296. package/functions/list.ts +0 -84
  297. package/index.ts +0 -3
  298. package/queue/kafka.ts +0 -0
  299. package/queue/memory.ts +0 -0
  300. package/queue/mongo.ts +0 -88
  301. package/streams/kafka.ts +0 -0
  302. package/streams/memory.ts +0 -0
  303. package/streams/mongo.ts +0 -0
  304. package/streams/types.ts +0 -0
  305. package/tsconfig-backup.json +0 -105
  306. package/tsconfig-base.json +0 -26
  307. package/tsconfig-cjs.json +0 -8
  308. package/tsconfig.json +0 -8
  309. package/types.ts +0 -12
  310. package/utils/completion.ts +0 -28
  311. package/utils/schema.test.ts +0 -69
  312. package/utils/schema.ts +0 -74
  313. package/utils/state.ts +0 -23
@@ -0,0 +1,49 @@
1
+ import { describe, it, expect } from 'vitest';
2
+ import { createSchemaFromTemplate } from '../schema';
3
+ describe('createSchemaFromTemplate', () => {
4
+ it('should create enum schema for pipe-separated values', () => {
5
+ const template = {
6
+ productType: 'App | API | Marketplace',
7
+ };
8
+ const schema = createSchemaFromTemplate(template);
9
+ const result = schema.safeParse({ productType: 'App' });
10
+ expect(result.success).toBe(true);
11
+ const productTypeField = schema._def.shape().productType;
12
+ expect(productTypeField._def.description).toBe('App | API | Marketplace');
13
+ expect(productTypeField.options).toContain('App');
14
+ expect(productTypeField.options).toContain('API');
15
+ expect(productTypeField.options).toContain('Marketplace');
16
+ });
17
+ it('should create string schema with description', () => {
18
+ const template = {
19
+ description: 'website meta description',
20
+ };
21
+ const schema = createSchemaFromTemplate(template);
22
+ const result = schema.safeParse({ description: 'A great website' });
23
+ expect(result.success).toBe(true);
24
+ const descriptionField = schema._def.shape().description;
25
+ expect(descriptionField._def.description).toBe('website meta description');
26
+ });
27
+ it('should enforce word count constraints', () => {
28
+ const template = {
29
+ customer: 'ideal customer profile in 3-5 words',
30
+ };
31
+ const schema = createSchemaFromTemplate(template);
32
+ // Valid case
33
+ const validResult = schema.safeParse({ customer: 'small business tech startups' });
34
+ expect(validResult.success).toBe(true);
35
+ // Too few words
36
+ const tooFewResult = schema.safeParse({ customer: 'small businesses' });
37
+ expect(tooFewResult.success).toBe(false);
38
+ if (!tooFewResult.success) {
39
+ expect(tooFewResult.error.errors[0].message).toBe('Must be between 3 and 5 words');
40
+ }
41
+ // Too many words
42
+ const tooManyResult = schema.safeParse({ customer: 'small business tech startups in California' });
43
+ expect(tooManyResult.success).toBe(false);
44
+ if (!tooManyResult.success) {
45
+ expect(tooManyResult.error.errors[0].message).toBe('Must be between 3 and 5 words');
46
+ }
47
+ });
48
+ });
49
+ //# sourceMappingURL=schema.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"schema.test.js","sourceRoot":"","sources":["../../../src/utils/__tests__/schema.test.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=stream-progress.test.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"stream-progress.test.d.ts","sourceRoot":"","sources":["../../../src/utils/__tests__/stream-progress.test.ts"],"names":[],"mappings":""}
@@ -0,0 +1,85 @@
1
+ import { describe, it, expect, vi, beforeEach } from 'vitest';
2
+ import { StreamProgressTracker } from '../stream-progress';
3
+ describe('StreamProgressTracker', () => {
4
+ beforeEach(() => {
5
+ vi.useFakeTimers();
6
+ });
7
+ it('should track basic progress', () => {
8
+ const onProgress = vi.fn();
9
+ const tracker = new StreamProgressTracker({
10
+ onProgress,
11
+ enableTokenCounting: true,
12
+ });
13
+ tracker.onChunk('Hello');
14
+ expect(onProgress).toHaveBeenCalledWith(expect.objectContaining({
15
+ type: 'chunk',
16
+ chunk: 'Hello',
17
+ tokensGenerated: expect.any(Number),
18
+ }));
19
+ tracker.onComplete();
20
+ expect(onProgress).toHaveBeenLastCalledWith(expect.objectContaining({
21
+ type: 'complete',
22
+ tokensGenerated: expect.any(Number),
23
+ totalTokens: expect.any(Number),
24
+ }));
25
+ });
26
+ it('should estimate time remaining', async () => {
27
+ const onProgress = vi.fn();
28
+ const tracker = new StreamProgressTracker({
29
+ onProgress,
30
+ enableTokenCounting: true,
31
+ estimateTimeRemaining: true,
32
+ });
33
+ // First chunk
34
+ tracker.onChunk('Hello');
35
+ // Advance time and send another chunk
36
+ await vi.advanceTimersByTimeAsync(1000);
37
+ tracker.onChunk('World');
38
+ expect(onProgress).toHaveBeenLastCalledWith(expect.objectContaining({
39
+ type: 'chunk',
40
+ chunk: 'World',
41
+ estimatedTimeRemaining: expect.any(Number),
42
+ }));
43
+ });
44
+ it('should track token-level progress', () => {
45
+ const onProgress = vi.fn();
46
+ const tracker = new StreamProgressTracker({
47
+ onProgress,
48
+ enableTokenCounting: true,
49
+ });
50
+ tracker.onToken('Hello');
51
+ expect(onProgress).toHaveBeenCalledWith(expect.objectContaining({
52
+ type: 'token',
53
+ chunk: 'Hello',
54
+ tokensGenerated: 1,
55
+ }));
56
+ });
57
+ it('should not include token counts when disabled', () => {
58
+ const onProgress = vi.fn();
59
+ const tracker = new StreamProgressTracker({
60
+ onProgress,
61
+ enableTokenCounting: false,
62
+ });
63
+ tracker.onChunk('Hello');
64
+ expect(onProgress).toHaveBeenCalledWith(expect.objectContaining({
65
+ type: 'chunk',
66
+ chunk: 'Hello',
67
+ }));
68
+ expect(onProgress).not.toHaveBeenCalledWith(expect.objectContaining({
69
+ tokensGenerated: expect.any(Number),
70
+ }));
71
+ });
72
+ it('should not estimate time when disabled', () => {
73
+ const onProgress = vi.fn();
74
+ const tracker = new StreamProgressTracker({
75
+ onProgress,
76
+ enableTokenCounting: true,
77
+ estimateTimeRemaining: false,
78
+ });
79
+ tracker.onChunk('Hello');
80
+ expect(onProgress).not.toHaveBeenCalledWith(expect.objectContaining({
81
+ estimatedTimeRemaining: expect.any(Number),
82
+ }));
83
+ });
84
+ });
85
+ //# sourceMappingURL=stream-progress.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"stream-progress.test.js","sourceRoot":"","sources":["../../../src/utils/__tests__/stream-progress.test.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export * from './validation';
2
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/utils/index.ts"],"names":[],"mappings":"AAAA,cAAc,cAAc,CAAA"}
@@ -0,0 +1,2 @@
1
+ export * from './validation';
2
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/utils/index.ts"],"names":[],"mappings":"AAAA,cAAc,cAAc,CAAA"}
@@ -0,0 +1,17 @@
1
+ import type { RequestHandlingOptions } from '../types';
2
+ export declare class RequestHandler {
3
+ private retryOptions;
4
+ private queue;
5
+ private streamingTimeout;
6
+ constructor(options?: RequestHandlingOptions);
7
+ executeWithRetry<T>(operation: () => Promise<T> | AsyncGenerator<T>, retryable?: boolean, isStreaming?: boolean): Promise<T>;
8
+ execute<T>(operation: () => Promise<T> | AsyncGenerator<T>, retryable?: boolean, isStreaming?: boolean): Promise<T>;
9
+ get concurrency(): number | undefined;
10
+ get size(): number;
11
+ get pending(): number;
12
+ clear(): void;
13
+ pause(): void;
14
+ resume(): void;
15
+ }
16
+ export declare function createRequestHandler(options?: RequestHandlingOptions): RequestHandler;
17
+ //# sourceMappingURL=request-handler.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"request-handler.d.ts","sourceRoot":"","sources":["../../src/utils/request-handler.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,sBAAsB,EAAE,MAAM,UAAU,CAAA;AAItD,qBAAa,cAAc;IACzB,OAAO,CAAC,YAAY,CAKnB;IACD,OAAO,CAAC,KAAK,CAAQ;IACrB,OAAO,CAAC,gBAAgB,CAAQ;gBAEpB,OAAO,GAAE,sBAA2B;IAW1C,gBAAgB,CAAC,CAAC,EAAE,SAAS,EAAE,MAAM,OAAO,CAAC,CAAC,CAAC,GAAG,cAAc,CAAC,CAAC,CAAC,EAAE,SAAS,UAAO,EAAE,WAAW,UAAQ,GAAG,OAAO,CAAC,CAAC,CAAC;IAuE7H,OAAO,CAAC,CAAC,EAAE,SAAS,EAAE,MAAM,OAAO,CAAC,CAAC,CAAC,GAAG,cAAc,CAAC,CAAC,CAAC,EAAE,SAAS,UAAO,EAAE,WAAW,UAAQ,GAAG,OAAO,CAAC,CAAC,CAAC;IAW9G,IAAI,WAAW,IAAI,MAAM,GAAG,SAAS,CAEpC;IAED,IAAI,IAAI,IAAI,MAAM,CAEjB;IAED,IAAI,OAAO,IAAI,MAAM,CAEpB;IAED,KAAK,IAAI,IAAI;IAIb,KAAK,IAAI,IAAI;IAIb,MAAM,IAAI,IAAI;CAGf;AAED,wBAAgB,oBAAoB,CAAC,OAAO,GAAE,sBAA2B,GAAG,cAAc,CAEzF"}
@@ -0,0 +1,105 @@
1
+ import { AIRequestError } from '../types';
2
+ import PQueue from 'p-queue';
3
+ export class RequestHandler {
4
+ constructor(options = {}) {
5
+ this.retryOptions = {
6
+ maxRetries: options.maxRetries ?? 2,
7
+ initialDelay: options.retryDelay ?? 100,
8
+ maxDelay: options.timeout ?? 1000,
9
+ backoffFactor: 2
10
+ };
11
+ this.queue = new PQueue({ concurrency: 1 });
12
+ this.streamingTimeout = options.streamingTimeout ?? 30000;
13
+ }
14
+ async executeWithRetry(operation, retryable = true, isStreaming = false) {
15
+ let lastError;
16
+ let attempt = 0;
17
+ const maxAttempts = retryable ? this.retryOptions.maxRetries : 0;
18
+ const timeoutMs = isStreaming ? this.streamingTimeout : this.retryOptions.maxDelay;
19
+ const executeWithTimeout = async (op) => {
20
+ const abortController = new AbortController();
21
+ const timeoutId = setTimeout(() => {
22
+ abortController.abort();
23
+ }, timeoutMs);
24
+ try {
25
+ if (op instanceof Promise) {
26
+ const result = await Promise.race([
27
+ op,
28
+ new Promise((_, reject) => {
29
+ abortController.signal.addEventListener('abort', () => {
30
+ reject(new AIRequestError(`Request timed out after ${timeoutMs}ms`));
31
+ });
32
+ })
33
+ ]);
34
+ return result;
35
+ }
36
+ else {
37
+ const chunks = [];
38
+ for await (const chunk of op) {
39
+ if (abortController.signal.aborted) {
40
+ throw new AIRequestError(`Stream timed out after ${timeoutMs}ms`);
41
+ }
42
+ chunks.push(chunk);
43
+ }
44
+ if (chunks.length === 0) {
45
+ throw new AIRequestError('No chunks received from stream');
46
+ }
47
+ return chunks[chunks.length - 1];
48
+ }
49
+ }
50
+ finally {
51
+ clearTimeout(timeoutId);
52
+ }
53
+ };
54
+ while (attempt <= maxAttempts) {
55
+ try {
56
+ return await executeWithTimeout(operation());
57
+ }
58
+ catch (error) {
59
+ lastError = error;
60
+ if (!retryable || error instanceof AIRequestError && !error.retryable) {
61
+ throw error;
62
+ }
63
+ if (attempt >= maxAttempts) {
64
+ throw new AIRequestError(`Failed after ${attempt + 1} attempts: ${lastError?.message || 'Unknown error'}`, undefined, false);
65
+ }
66
+ const delay = Math.min(this.retryOptions.initialDelay * Math.pow(this.retryOptions.backoffFactor, attempt), this.retryOptions.maxDelay);
67
+ await new Promise(resolve => setTimeout(resolve, delay));
68
+ attempt++;
69
+ }
70
+ }
71
+ throw lastError || new AIRequestError('Operation failed with no error details');
72
+ }
73
+ execute(operation, retryable = true, isStreaming = false) {
74
+ const executeOperation = async () => {
75
+ const result = await this.executeWithRetry(operation, retryable, isStreaming);
76
+ if (result === undefined) {
77
+ throw new AIRequestError('Operation returned undefined result');
78
+ }
79
+ return result;
80
+ };
81
+ return this.queue.add(executeOperation);
82
+ }
83
+ get concurrency() {
84
+ return this.queue?.concurrency;
85
+ }
86
+ get size() {
87
+ return this.queue?.size ?? 0;
88
+ }
89
+ get pending() {
90
+ return this.queue?.pending ?? 0;
91
+ }
92
+ clear() {
93
+ this.queue?.clear();
94
+ }
95
+ pause() {
96
+ this.queue?.pause();
97
+ }
98
+ resume() {
99
+ this.queue?.start();
100
+ }
101
+ }
102
+ export function createRequestHandler(options = {}) {
103
+ return new RequestHandler(options);
104
+ }
105
+ //# sourceMappingURL=request-handler.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"request-handler.js","sourceRoot":"","sources":["../../src/utils/request-handler.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,11 @@
1
+ import { z } from 'zod';
2
+ /**
3
+ * Creates a Zod schema from a template object where:
4
+ * - String values become descriptions
5
+ * - Pipe-separated values become enums
6
+ * - Word count constraints (e.g. "3-5 words") are enforced
7
+ */
8
+ export declare function createSchemaFromTemplate<T extends Record<string, string>>(template: T): z.ZodObject<{
9
+ [K in keyof T]: z.ZodString | z.ZodEnum<[string, ...string[]]> | z.ZodEffects<z.ZodString>;
10
+ }>;
11
+ //# sourceMappingURL=schema.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"schema.d.ts","sourceRoot":"","sources":["../../src/utils/schema.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAA;AAEvB;;;;;GAKG;AACH,wBAAgB,wBAAwB,CAAC,CAAC,SAAS,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,EACvE,QAAQ,EAAE,CAAC,GACV,CAAC,CAAC,SAAS,CAAC;KACZ,CAAC,IAAI,MAAM,CAAC,GAAG,CAAC,CAAC,SAAS,GAAG,CAAC,CAAC,OAAO,CAAC,CAAC,MAAM,EAAE,GAAG,MAAM,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,SAAS,CAAC;CAC3F,CAAC,CA8CD"}
@@ -0,0 +1,51 @@
1
+ import { z } from 'zod';
2
+ /**
3
+ * Creates a Zod schema from a template object where:
4
+ * - String values become descriptions
5
+ * - Pipe-separated values become enums
6
+ * - Word count constraints (e.g. "3-5 words") are enforced
7
+ */
8
+ export function createSchemaFromTemplate(template) {
9
+ const shape = Object.entries(template).reduce((acc, [key, value]) => {
10
+ // Check if value contains pipe-separated options
11
+ if (value.includes('|')) {
12
+ const options = value
13
+ .split('|')
14
+ .map((opt) => opt.trim())
15
+ .filter(Boolean); // Remove empty strings
16
+ if (options.length >= 1) {
17
+ acc[key] = z.enum([options[0], ...options.slice(1)]).describe(value);
18
+ }
19
+ else {
20
+ acc[key] = z.string().describe(value);
21
+ }
22
+ }
23
+ else {
24
+ // Check for word count constraints
25
+ const wordCountMatch = value.match(/(\d+)-(\d+)\s+words/);
26
+ if (wordCountMatch) {
27
+ const [, minStr, maxStr] = wordCountMatch;
28
+ const min = parseInt(minStr, 10);
29
+ const max = parseInt(maxStr, 10);
30
+ acc[key] = z
31
+ .string()
32
+ .min(1)
33
+ .refine((val) => {
34
+ const words = val.trim().split(/\s+/).length;
35
+ return words >= min && words <= max;
36
+ }, {
37
+ message: `Must be between ${min} and ${max} words`,
38
+ params: { min, max },
39
+ })
40
+ .describe(value);
41
+ }
42
+ else {
43
+ // Regular string field with description
44
+ acc[key] = z.string().describe(value);
45
+ }
46
+ }
47
+ return acc;
48
+ }, {});
49
+ return z.object(shape);
50
+ }
51
+ //# sourceMappingURL=schema.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"schema.js","sourceRoot":"","sources":["../../src/utils/schema.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAA;AAEvB;;;;;GAKG;AACH,MAAM,UAAU,wBAAwB,CACtC,QAAW;IAOX,MAAM,KAAK,GAAG,MAAM,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,MAAM,CAAuB,CAAC,GAAG,EAAE,CAAC,GAAG,EAAE,KAAK,CAAC,EAAE,EAAE;QACxF,iDAAiD;QACjD,IAAI,KAAK,CAAC,QAAQ,CAAC,GAAG,CAAC,EAAE,CAAC;YACxB,MAAM,OAAO,GAAG,KAAK;iBAClB,KAAK,CAAC,GAAG,CAAC;iBACV,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,GAAG,CAAC,IAAI,EAAE,CAAC;iBACxB,MAAM,CAAC,OAAO,CAAC,CAAA,CAAC,uBAAuB;YAC1C,IAAI,OAAO,CAAC,MAAM,IAAI,CAAC,EAAE,CAAC;gBACxB,GAAG,CAAC,GAAc,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,GAAG,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC,CAA0B,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAA;YAC1G,CAAC;iBAAM,CAAC;gBACN,GAAG,CAAC,GAAc,CAAC,GAAG,CAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAA;YAClD,CAAC;QACH,CAAC;aAAM,CAAC;YACN,mCAAmC;YACnC,MAAM,cAAc,GAAG,KAAK,CAAC,KAAK,CAAC,qBAAqB,CAAC,CAAA;YACzD,IAAI,cAAc,EAAE,CAAC;gBACnB,MAAM,CAAC,EAAE,MAAM,EAAE,MAAM,CAAC,GAAG,cAAc,CAAA;gBACzC,MAAM,GAAG,GAAG,QAAQ,CAAC,MAAM,EAAE,EAAE,CAAC,CAAA;gBAChC,MAAM,GAAG,GAAG,QAAQ,CAAC,MAAM,EAAE,EAAE,CAAC,CAAA;gBAChC,GAAG,CAAC,GAAc,CAAC,GAAG,CAAC;qBACpB,MAAM,EAAE;qBACR,GAAG,CAAC,CAAC,CAAC;qBACN,MAAM,CACL,CAAC,GAAG,EAAE,EAAE;oBACN,MAAM,KAAK,GAAG,GAAG,CAAC,IAAI,EAAE,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,MAAM,CAAA;oBAC5C,OAAO,KAAK,IAAI,GAAG,IAAI,KAAK,IAAI,GAAG,CAAA;gBACrC,CAAC,EACD;oBACE,OAAO,EAAE,mBAAmB,GAAG,QAAQ,GAAG,QAAQ;oBAClD,MAAM,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE;iBACrB,CACF;qBACA,QAAQ,CAAC,KAAK,CAAC,CAAA;YACpB,CAAC;iBAAM,CAAC;gBACN,wCAAwC;gBACxC,GAAG,CAAC,GAAc,CAAC,GAAG,CAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAA;YAClD,CAAC;QACH,CAAC;QACD,OAAO,GAAG,CAAA;IACZ,CAAC,EAAE,EAAE,CAAC,CAAA;IAEN,OAAO,CAAC,CAAC,MAAM,CAAC,KAAoB,CAAC,CAAA;AACvC,CAAC"}
@@ -0,0 +1,17 @@
1
+ import { StreamingOptions } from '../types';
2
+ export declare class StreamProgressTracker {
3
+ private tokensGenerated;
4
+ private startTime;
5
+ private lastUpdateTime;
6
+ private tokenRate;
7
+ private readonly options;
8
+ private readonly callback;
9
+ private readonly alpha;
10
+ constructor(options: StreamingOptions);
11
+ private updateTokenRate;
12
+ private estimateTimeRemaining;
13
+ onChunk(chunk: string): void;
14
+ onToken(token: string): void;
15
+ onComplete(): void;
16
+ }
17
+ //# sourceMappingURL=stream-progress.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"stream-progress.d.ts","sourceRoot":"","sources":["../../src/utils/stream-progress.ts"],"names":[],"mappings":"AAAA,OAAO,EAAoC,gBAAgB,EAAE,MAAM,UAAU,CAAC;AAE9E,qBAAa,qBAAqB;IAChC,OAAO,CAAC,eAAe,CAAa;IACpC,OAAO,CAAC,SAAS,CAAsB;IACvC,OAAO,CAAC,cAAc,CAAsB;IAC5C,OAAO,CAAC,SAAS,CAAa;IAC9B,OAAO,CAAC,QAAQ,CAAC,OAAO,CAAmB;IAC3C,OAAO,CAAC,QAAQ,CAAC,QAAQ,CAAmB;IAC5C,OAAO,CAAC,QAAQ,CAAC,KAAK,CAAe;gBAEzB,OAAO,EAAE,gBAAgB;IAKrC,OAAO,CAAC,eAAe;IAmBvB,OAAO,CAAC,qBAAqB;IAmBtB,OAAO,CAAC,KAAK,EAAE,MAAM;IAuBrB,OAAO,CAAC,KAAK,EAAE,MAAM;IAqBrB,UAAU;CAWlB"}
@@ -0,0 +1,86 @@
1
+ export class StreamProgressTracker {
2
+ constructor(options) {
3
+ this.tokensGenerated = 0;
4
+ this.startTime = Date.now();
5
+ this.lastUpdateTime = Date.now();
6
+ this.tokenRate = 0;
7
+ this.alpha = 0.3; // EMA smoothing factor
8
+ this.options = options;
9
+ this.callback = options.onProgress || (() => { });
10
+ }
11
+ updateTokenRate(newTokens) {
12
+ const now = Date.now();
13
+ const timeDiff = now - this.lastUpdateTime;
14
+ if (timeDiff > 0) {
15
+ // Calculate instantaneous rate
16
+ const instantRate = newTokens / timeDiff;
17
+ // Apply exponential moving average for smoother rate
18
+ if (this.tokenRate === 0) {
19
+ this.tokenRate = instantRate;
20
+ }
21
+ else {
22
+ this.tokenRate = (this.alpha * instantRate) + ((1 - this.alpha) * this.tokenRate);
23
+ }
24
+ this.lastUpdateTime = now;
25
+ }
26
+ }
27
+ estimateTimeRemaining() {
28
+ if (!this.options.estimateTimeRemaining || this.tokenRate === 0) {
29
+ return undefined;
30
+ }
31
+ // Use dynamic estimation based on current progress
32
+ const progressRatio = this.tokensGenerated / Math.max(100, this.tokensGenerated * 2);
33
+ const estimatedTotalTokens = Math.max(this.tokensGenerated * (1 + (1 - progressRatio)), this.tokensGenerated + 100);
34
+ const remainingTokens = estimatedTotalTokens - this.tokensGenerated;
35
+ const estimatedMs = remainingTokens / this.tokenRate;
36
+ // Return undefined if estimate is unreasonable
37
+ return estimatedMs > 0 && estimatedMs < 3600000 ? estimatedMs : undefined;
38
+ }
39
+ onChunk(chunk) {
40
+ // Rough token count estimation (can be replaced with more accurate counting)
41
+ const estimatedTokens = Math.ceil(chunk.length / 4);
42
+ this.tokensGenerated += estimatedTokens;
43
+ if (this.options.enableTokenCounting) {
44
+ this.updateTokenRate(estimatedTokens);
45
+ }
46
+ const progress = {
47
+ type: 'chunk',
48
+ chunk,
49
+ ...(this.options.enableTokenCounting && {
50
+ tokensGenerated: this.tokensGenerated,
51
+ }),
52
+ ...(this.options.estimateTimeRemaining && {
53
+ estimatedTimeRemaining: this.estimateTimeRemaining(),
54
+ }),
55
+ };
56
+ this.callback(progress);
57
+ }
58
+ onToken(token) {
59
+ this.tokensGenerated += 1;
60
+ if (this.options.enableTokenCounting) {
61
+ this.updateTokenRate(1);
62
+ }
63
+ const progress = {
64
+ type: 'token',
65
+ chunk: token,
66
+ ...(this.options.enableTokenCounting && {
67
+ tokensGenerated: this.tokensGenerated,
68
+ }),
69
+ ...(this.options.estimateTimeRemaining && {
70
+ estimatedTimeRemaining: this.estimateTimeRemaining(),
71
+ }),
72
+ };
73
+ this.callback(progress);
74
+ }
75
+ onComplete() {
76
+ const progress = {
77
+ type: 'complete',
78
+ ...(this.options.enableTokenCounting && {
79
+ tokensGenerated: this.tokensGenerated,
80
+ totalTokens: this.tokensGenerated,
81
+ }),
82
+ };
83
+ this.callback(progress);
84
+ }
85
+ }
86
+ //# sourceMappingURL=stream-progress.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"stream-progress.js","sourceRoot":"","sources":["../../src/utils/stream-progress.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,3 @@
1
+ import { SimpleSchema } from '../types';
2
+ export declare function validateSchema(schema: SimpleSchema): void;
3
+ //# sourceMappingURL=validation.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"validation.d.ts","sourceRoot":"","sources":["../../src/utils/validation.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,UAAU,CAAA;AAEvC,wBAAgB,cAAc,CAAC,MAAM,EAAE,YAAY,GAAG,IAAI,CAWzD"}
@@ -0,0 +1,30 @@
1
+ export function validateSchema(schema) {
2
+ if (!schema || typeof schema !== 'object') {
3
+ throw new Error('Schema must be a valid object');
4
+ }
5
+ Object.entries(schema).forEach(([key, value]) => {
6
+ if (!key || typeof key !== 'string') {
7
+ throw new Error('Schema keys must be non-empty strings');
8
+ }
9
+ validateSchemaValue(value);
10
+ });
11
+ }
12
+ function validateSchemaValue(value) {
13
+ if (Array.isArray(value)) {
14
+ if (value.length === 0) {
15
+ throw new Error('Array schema values must not be empty');
16
+ }
17
+ value.forEach(item => {
18
+ if (typeof item !== 'string') {
19
+ throw new Error('Array schema values must contain only strings');
20
+ }
21
+ });
22
+ }
23
+ else if (typeof value === 'object' && value !== null) {
24
+ validateSchema(value);
25
+ }
26
+ else if (typeof value !== 'string') {
27
+ throw new Error('Schema values must be strings, arrays of strings, or nested objects');
28
+ }
29
+ }
30
+ //# sourceMappingURL=validation.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"validation.js","sourceRoot":"","sources":["../../src/utils/validation.ts"],"names":[],"mappings":"AAEA,MAAM,UAAU,cAAc,CAAC,MAAoB;IACjD,IAAI,CAAC,MAAM,IAAI,OAAO,MAAM,KAAK,QAAQ,EAAE,CAAC;QAC1C,MAAM,IAAI,KAAK,CAAC,+BAA+B,CAAC,CAAA;IAClD,CAAC;IAED,MAAM,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,GAAG,EAAE,KAAK,CAAC,EAAE,EAAE;QAC9C,IAAI,CAAC,GAAG,IAAI,OAAO,GAAG,KAAK,QAAQ,EAAE,CAAC;YACpC,MAAM,IAAI,KAAK,CAAC,uCAAuC,CAAC,CAAA;QAC1D,CAAC;QACD,mBAAmB,CAAC,KAAK,CAAC,CAAA;IAC5B,CAAC,CAAC,CAAA;AACJ,CAAC;AAED,SAAS,mBAAmB,CAAC,KAAc;IACzC,IAAI,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE,CAAC;QACzB,IAAI,KAAK,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;YACvB,MAAM,IAAI,KAAK,CAAC,uCAAuC,CAAC,CAAA;QAC1D,CAAC;QACD,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE;YACnB,IAAI,OAAO,IAAI,KAAK,QAAQ,EAAE,CAAC;gBAC7B,MAAM,IAAI,KAAK,CAAC,+CAA+C,CAAC,CAAA;YAClE,CAAC;QACH,CAAC,CAAC,CAAA;IACJ,CAAC;SAAM,IAAI,OAAO,KAAK,KAAK,QAAQ,IAAI,KAAK,KAAK,IAAI,EAAE,CAAC;QACvD,cAAc,CAAC,KAAqB,CAAC,CAAA;IACvC,CAAC;SAAM,IAAI,OAAO,KAAK,KAAK,QAAQ,EAAE,CAAC;QACrC,MAAM,IAAI,KAAK,CAAC,qEAAqE,CAAC,CAAA;IACxF,CAAC;AACH,CAAC"}