determinate 0.0.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 (83) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +236 -0
  3. package/dist/agent.d.ts +17 -0
  4. package/dist/agent.d.ts.map +1 -0
  5. package/dist/agent.js +131 -0
  6. package/dist/agent.js.map +1 -0
  7. package/dist/context/assembler.d.ts +19 -0
  8. package/dist/context/assembler.d.ts.map +1 -0
  9. package/dist/context/assembler.js +87 -0
  10. package/dist/context/assembler.js.map +1 -0
  11. package/dist/context/budget.d.ts +10 -0
  12. package/dist/context/budget.d.ts.map +1 -0
  13. package/dist/context/budget.js +13 -0
  14. package/dist/context/budget.js.map +1 -0
  15. package/dist/context/tokenizer.d.ts +6 -0
  16. package/dist/context/tokenizer.d.ts.map +1 -0
  17. package/dist/context/tokenizer.js +34 -0
  18. package/dist/context/tokenizer.js.map +1 -0
  19. package/dist/errors.d.ts +29 -0
  20. package/dist/errors.d.ts.map +1 -0
  21. package/dist/errors.js +44 -0
  22. package/dist/errors.js.map +1 -0
  23. package/dist/index.d.ts +9 -0
  24. package/dist/index.d.ts.map +1 -0
  25. package/dist/index.js +8 -0
  26. package/dist/index.js.map +1 -0
  27. package/dist/oauth/anthropic.d.ts +5 -0
  28. package/dist/oauth/anthropic.d.ts.map +1 -0
  29. package/dist/oauth/anthropic.js +84 -0
  30. package/dist/oauth/anthropic.js.map +1 -0
  31. package/dist/oauth/index.d.ts +18 -0
  32. package/dist/oauth/index.d.ts.map +1 -0
  33. package/dist/oauth/index.js +44 -0
  34. package/dist/oauth/index.js.map +1 -0
  35. package/dist/oauth/openai.d.ts +14 -0
  36. package/dist/oauth/openai.d.ts.map +1 -0
  37. package/dist/oauth/openai.js +328 -0
  38. package/dist/oauth/openai.js.map +1 -0
  39. package/dist/oauth/pkce.d.ts +9 -0
  40. package/dist/oauth/pkce.d.ts.map +1 -0
  41. package/dist/oauth/pkce.js +22 -0
  42. package/dist/oauth/pkce.js.map +1 -0
  43. package/dist/oauth/token-store.d.ts +10 -0
  44. package/dist/oauth/token-store.d.ts.map +1 -0
  45. package/dist/oauth/token-store.js +36 -0
  46. package/dist/oauth/token-store.js.map +1 -0
  47. package/dist/oauth/types.d.ts +32 -0
  48. package/dist/oauth/types.d.ts.map +1 -0
  49. package/dist/oauth/types.js +2 -0
  50. package/dist/oauth/types.js.map +1 -0
  51. package/dist/providers/anthropic.d.ts +9 -0
  52. package/dist/providers/anthropic.d.ts.map +1 -0
  53. package/dist/providers/anthropic.js +101 -0
  54. package/dist/providers/anthropic.js.map +1 -0
  55. package/dist/providers/factory.d.ts +4 -0
  56. package/dist/providers/factory.d.ts.map +1 -0
  57. package/dist/providers/factory.js +25 -0
  58. package/dist/providers/factory.js.map +1 -0
  59. package/dist/providers/openai.d.ts +9 -0
  60. package/dist/providers/openai.d.ts.map +1 -0
  61. package/dist/providers/openai.js +57 -0
  62. package/dist/providers/openai.js.map +1 -0
  63. package/dist/providers/parse-action.d.ts +3 -0
  64. package/dist/providers/parse-action.d.ts.map +1 -0
  65. package/dist/providers/parse-action.js +18 -0
  66. package/dist/providers/parse-action.js.map +1 -0
  67. package/dist/providers/types.d.ts +22 -0
  68. package/dist/providers/types.d.ts.map +1 -0
  69. package/dist/providers/types.js +2 -0
  70. package/dist/providers/types.js.map +1 -0
  71. package/dist/schema/action-schema.d.ts +9 -0
  72. package/dist/schema/action-schema.d.ts.map +1 -0
  73. package/dist/schema/action-schema.js +33 -0
  74. package/dist/schema/action-schema.js.map +1 -0
  75. package/dist/schema/history-schema.d.ts +11 -0
  76. package/dist/schema/history-schema.d.ts.map +1 -0
  77. package/dist/schema/history-schema.js +18 -0
  78. package/dist/schema/history-schema.js.map +1 -0
  79. package/dist/types.d.ts +75 -0
  80. package/dist/types.d.ts.map +1 -0
  81. package/dist/types.js +2 -0
  82. package/dist/types.js.map +1 -0
  83. package/package.json +61 -0
@@ -0,0 +1 @@
1
+ {"version":3,"file":"pkce.js","sourceRoot":"","sources":["../../src/oauth/pkce.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,SAAS,eAAe,CAAC,KAAiB;IACzC,IAAI,MAAM,GAAG,EAAE,CAAC;IAChB,KAAK,MAAM,IAAI,IAAI,KAAK,EAAE,CAAC;QAC1B,MAAM,IAAI,MAAM,CAAC,YAAY,CAAC,IAAI,CAAC,CAAC;IACrC,CAAC;IACD,OAAO,IAAI,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,KAAK,EAAE,GAAG,CAAC,CAAC,OAAO,CAAC,KAAK,EAAE,GAAG,CAAC,CAAC,OAAO,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC;AAC/E,CAAC;AAED,MAAM,CAAC,KAAK,UAAU,YAAY;IACjC,MAAM,aAAa,GAAG,IAAI,UAAU,CAAC,EAAE,CAAC,CAAC;IACzC,MAAM,CAAC,eAAe,CAAC,aAAa,CAAC,CAAC;IACtC,MAAM,QAAQ,GAAG,eAAe,CAAC,aAAa,CAAC,CAAC;IAEhD,MAAM,OAAO,GAAG,IAAI,WAAW,EAAE,CAAC;IAClC,MAAM,IAAI,GAAG,OAAO,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC;IACtC,MAAM,UAAU,GAAG,MAAM,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,SAAS,EAAE,IAAI,CAAC,CAAC;IAC/D,MAAM,SAAS,GAAG,eAAe,CAAC,IAAI,UAAU,CAAC,UAAU,CAAC,CAAC,CAAC;IAE9D,OAAO,EAAE,QAAQ,EAAE,SAAS,EAAE,CAAC;AAChC,CAAC"}
@@ -0,0 +1,10 @@
1
+ import type { OAuthCredentials } from "./types";
2
+ export declare class TokenStore {
3
+ private dir;
4
+ constructor(dir?: string);
5
+ private path;
6
+ load(providerId: string): Promise<OAuthCredentials | null>;
7
+ save(providerId: string, credentials: OAuthCredentials): Promise<void>;
8
+ clear(providerId: string): Promise<void>;
9
+ }
10
+ //# sourceMappingURL=token-store.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"token-store.d.ts","sourceRoot":"","sources":["../../src/oauth/token-store.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,SAAS,CAAC;AAIhD,qBAAa,UAAU;IACtB,OAAO,CAAC,GAAG,CAAS;gBAER,GAAG,CAAC,EAAE,MAAM;IAIxB,OAAO,CAAC,IAAI;IAIN,IAAI,CAAC,UAAU,EAAE,MAAM,GAAG,OAAO,CAAC,gBAAgB,GAAG,IAAI,CAAC;IAS1D,IAAI,CAAC,UAAU,EAAE,MAAM,EAAE,WAAW,EAAE,gBAAgB,GAAG,OAAO,CAAC,IAAI,CAAC;IAMtE,KAAK,CAAC,UAAU,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;CAO9C"}
@@ -0,0 +1,36 @@
1
+ import { mkdir, readFile, unlink, writeFile } from "node:fs/promises";
2
+ import { homedir } from "node:os";
3
+ import { dirname, join } from "node:path";
4
+ const DEFAULT_DIR = join(homedir(), ".determinate");
5
+ export class TokenStore {
6
+ dir;
7
+ constructor(dir) {
8
+ this.dir = dir ?? DEFAULT_DIR;
9
+ }
10
+ path(providerId) {
11
+ return join(this.dir, `${providerId}-credentials.json`);
12
+ }
13
+ async load(providerId) {
14
+ try {
15
+ const raw = await readFile(this.path(providerId), "utf-8");
16
+ return JSON.parse(raw);
17
+ }
18
+ catch {
19
+ return null;
20
+ }
21
+ }
22
+ async save(providerId, credentials) {
23
+ const filePath = this.path(providerId);
24
+ await mkdir(dirname(filePath), { recursive: true });
25
+ await writeFile(filePath, JSON.stringify(credentials, null, 2), { mode: 0o600 });
26
+ }
27
+ async clear(providerId) {
28
+ try {
29
+ await unlink(this.path(providerId));
30
+ }
31
+ catch {
32
+ // File may not exist
33
+ }
34
+ }
35
+ }
36
+ //# sourceMappingURL=token-store.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"token-store.js","sourceRoot":"","sources":["../../src/oauth/token-store.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,EAAE,QAAQ,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,kBAAkB,CAAC;AACtE,OAAO,EAAE,OAAO,EAAE,MAAM,SAAS,CAAC;AAClC,OAAO,EAAE,OAAO,EAAE,IAAI,EAAE,MAAM,WAAW,CAAC;AAG1C,MAAM,WAAW,GAAG,IAAI,CAAC,OAAO,EAAE,EAAE,cAAc,CAAC,CAAC;AAEpD,MAAM,OAAO,UAAU;IACd,GAAG,CAAS;IAEpB,YAAY,GAAY;QACvB,IAAI,CAAC,GAAG,GAAG,GAAG,IAAI,WAAW,CAAC;IAC/B,CAAC;IAEO,IAAI,CAAC,UAAkB;QAC9B,OAAO,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,GAAG,UAAU,mBAAmB,CAAC,CAAC;IACzD,CAAC;IAED,KAAK,CAAC,IAAI,CAAC,UAAkB;QAC5B,IAAI,CAAC;YACJ,MAAM,GAAG,GAAG,MAAM,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,EAAE,OAAO,CAAC,CAAC;YAC3D,OAAO,IAAI,CAAC,KAAK,CAAC,GAAG,CAAqB,CAAC;QAC5C,CAAC;QAAC,MAAM,CAAC;YACR,OAAO,IAAI,CAAC;QACb,CAAC;IACF,CAAC;IAED,KAAK,CAAC,IAAI,CAAC,UAAkB,EAAE,WAA6B;QAC3D,MAAM,QAAQ,GAAG,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;QACvC,MAAM,KAAK,CAAC,OAAO,CAAC,QAAQ,CAAC,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC,CAAC;QACpD,MAAM,SAAS,CAAC,QAAQ,EAAE,IAAI,CAAC,SAAS,CAAC,WAAW,EAAE,IAAI,EAAE,CAAC,CAAC,EAAE,EAAE,IAAI,EAAE,KAAK,EAAE,CAAC,CAAC;IAClF,CAAC;IAED,KAAK,CAAC,KAAK,CAAC,UAAkB;QAC7B,IAAI,CAAC;YACJ,MAAM,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC;QACrC,CAAC;QAAC,MAAM,CAAC;YACR,qBAAqB;QACtB,CAAC;IACF,CAAC;CACD"}
@@ -0,0 +1,32 @@
1
+ export type OAuthCredentials = {
2
+ refresh: string;
3
+ access: string;
4
+ expires: number;
5
+ [key: string]: unknown;
6
+ };
7
+ export type OAuthProviderId = string;
8
+ export type OAuthPrompt = {
9
+ message: string;
10
+ placeholder?: string;
11
+ allowEmpty?: boolean;
12
+ };
13
+ export type OAuthAuthInfo = {
14
+ url: string;
15
+ instructions?: string;
16
+ };
17
+ export interface OAuthLoginCallbacks {
18
+ onAuth: (info: OAuthAuthInfo) => void;
19
+ onPrompt: (prompt: OAuthPrompt) => Promise<string>;
20
+ onProgress?: (message: string) => void;
21
+ onManualCodeInput?: () => Promise<string>;
22
+ signal?: AbortSignal;
23
+ }
24
+ export interface OAuthProviderInterface {
25
+ readonly id: OAuthProviderId;
26
+ readonly name: string;
27
+ login(callbacks: OAuthLoginCallbacks): Promise<OAuthCredentials>;
28
+ usesCallbackServer?: boolean;
29
+ refreshToken(credentials: OAuthCredentials): Promise<OAuthCredentials>;
30
+ getApiKey(credentials: OAuthCredentials): string;
31
+ }
32
+ //# sourceMappingURL=types.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../src/oauth/types.ts"],"names":[],"mappings":"AAAA,MAAM,MAAM,gBAAgB,GAAG;IAC9B,OAAO,EAAE,MAAM,CAAC;IAChB,MAAM,EAAE,MAAM,CAAC;IACf,OAAO,EAAE,MAAM,CAAC;IAChB,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC;CACvB,CAAC;AAEF,MAAM,MAAM,eAAe,GAAG,MAAM,CAAC;AAErC,MAAM,MAAM,WAAW,GAAG;IACzB,OAAO,EAAE,MAAM,CAAC;IAChB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,UAAU,CAAC,EAAE,OAAO,CAAC;CACrB,CAAC;AAEF,MAAM,MAAM,aAAa,GAAG;IAC3B,GAAG,EAAE,MAAM,CAAC;IACZ,YAAY,CAAC,EAAE,MAAM,CAAC;CACtB,CAAC;AAEF,MAAM,WAAW,mBAAmB;IACnC,MAAM,EAAE,CAAC,IAAI,EAAE,aAAa,KAAK,IAAI,CAAC;IACtC,QAAQ,EAAE,CAAC,MAAM,EAAE,WAAW,KAAK,OAAO,CAAC,MAAM,CAAC,CAAC;IACnD,UAAU,CAAC,EAAE,CAAC,OAAO,EAAE,MAAM,KAAK,IAAI,CAAC;IACvC,iBAAiB,CAAC,EAAE,MAAM,OAAO,CAAC,MAAM,CAAC,CAAC;IAC1C,MAAM,CAAC,EAAE,WAAW,CAAC;CACrB;AAED,MAAM,WAAW,sBAAsB;IACtC,QAAQ,CAAC,EAAE,EAAE,eAAe,CAAC;IAC7B,QAAQ,CAAC,IAAI,EAAE,MAAM,CAAC;IACtB,KAAK,CAAC,SAAS,EAAE,mBAAmB,GAAG,OAAO,CAAC,gBAAgB,CAAC,CAAC;IACjE,kBAAkB,CAAC,EAAE,OAAO,CAAC;IAC7B,YAAY,CAAC,WAAW,EAAE,gBAAgB,GAAG,OAAO,CAAC,gBAAgB,CAAC,CAAC;IACvE,SAAS,CAAC,WAAW,EAAE,gBAAgB,GAAG,MAAM,CAAC;CACjD"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=types.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.js","sourceRoot":"","sources":["../../src/oauth/types.ts"],"names":[],"mappings":""}
@@ -0,0 +1,9 @@
1
+ import type { ProviderConfig } from "../types";
2
+ import type { Provider, ProviderRequest, ProviderResponse } from "./types";
3
+ export declare class AnthropicProvider implements Provider {
4
+ private config;
5
+ private baseUrl;
6
+ constructor(config: ProviderConfig);
7
+ sendRequest(request: ProviderRequest): Promise<ProviderResponse>;
8
+ }
9
+ //# sourceMappingURL=anthropic.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"anthropic.d.ts","sourceRoot":"","sources":["../../src/providers/anthropic.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,UAAU,CAAC;AAE/C,OAAO,KAAK,EAAE,QAAQ,EAAE,eAAe,EAAE,gBAAgB,EAAE,MAAM,SAAS,CAAC;AAkB3E,qBAAa,iBAAkB,YAAW,QAAQ;IACjD,OAAO,CAAC,MAAM,CAAiB;IAC/B,OAAO,CAAC,OAAO,CAAS;gBAEZ,MAAM,EAAE,cAAc;IAK5B,WAAW,CAAC,OAAO,EAAE,eAAe,GAAG,OAAO,CAAC,gBAAgB,CAAC;CAsGtE"}
@@ -0,0 +1,101 @@
1
+ import { OutputError, ProviderError } from "../errors";
2
+ import { parseActionFromJson } from "./parse-action";
3
+ const ANTHROPIC_API_BASE = "https://api.anthropic.com";
4
+ const ANTHROPIC_VERSION = "2023-06-01";
5
+ const RETRY_STATUS_CODES = [429, 500, 502, 503, 529];
6
+ const MAX_RETRIES = 3;
7
+ const BASE_DELAY_MS = 1000;
8
+ async function sleep(ms) {
9
+ return new Promise((resolve) => setTimeout(resolve, ms));
10
+ }
11
+ export class AnthropicProvider {
12
+ config;
13
+ baseUrl;
14
+ constructor(config) {
15
+ this.config = config;
16
+ this.baseUrl = config.baseUrl ?? ANTHROPIC_API_BASE;
17
+ }
18
+ async sendRequest(request) {
19
+ const messages = request.messages;
20
+ let system;
21
+ const anthropicMessages = [];
22
+ for (const msg of messages) {
23
+ if (msg.role === "system") {
24
+ system = msg.content;
25
+ }
26
+ else {
27
+ anthropicMessages.push({
28
+ role: msg.role,
29
+ content: msg.content,
30
+ });
31
+ }
32
+ }
33
+ const body = {
34
+ model: request.model,
35
+ messages: anthropicMessages,
36
+ max_tokens: 4096,
37
+ output_config: {
38
+ format: {
39
+ type: "json_schema",
40
+ schema: request.outputSchema,
41
+ },
42
+ },
43
+ ...request.options,
44
+ };
45
+ if (system) {
46
+ body.system = system;
47
+ }
48
+ const headers = {
49
+ "Content-Type": "application/json",
50
+ "x-api-key": this.config.apiKey ?? "",
51
+ "anthropic-version": ANTHROPIC_VERSION,
52
+ };
53
+ let lastError;
54
+ for (let attempt = 0; attempt <= MAX_RETRIES; attempt++) {
55
+ if (request.signal?.aborted) {
56
+ throw new ProviderError(this.config.type, "Request was aborted");
57
+ }
58
+ try {
59
+ const response = await fetch(`${this.baseUrl}/v1/messages`, {
60
+ method: "POST",
61
+ headers,
62
+ body: JSON.stringify(body),
63
+ signal: request.signal,
64
+ });
65
+ if (!response.ok) {
66
+ const errorBody = await response.text();
67
+ if (RETRY_STATUS_CODES.includes(response.status) && attempt < MAX_RETRIES) {
68
+ const delay = BASE_DELAY_MS * 2 ** attempt;
69
+ await sleep(delay);
70
+ lastError = new ProviderError(this.config.type, `HTTP ${response.status}: ${errorBody}`);
71
+ continue;
72
+ }
73
+ throw new ProviderError(this.config.type, `HTTP ${response.status}: ${errorBody}`);
74
+ }
75
+ const data = (await response.json());
76
+ const textBlock = data.content?.find((b) => b.type === "text");
77
+ if (!textBlock?.text) {
78
+ throw new OutputError("No text content in Anthropic response", JSON.stringify(data.content));
79
+ }
80
+ const action = parseActionFromJson(textBlock.text);
81
+ return {
82
+ action,
83
+ meta: {
84
+ tokensUsed: {
85
+ input: data.usage?.input_tokens ?? 0,
86
+ output: data.usage?.output_tokens ?? 0,
87
+ },
88
+ model: data.model ?? request.model,
89
+ },
90
+ };
91
+ }
92
+ catch (err) {
93
+ if (err instanceof ProviderError || err instanceof OutputError)
94
+ throw err;
95
+ throw new ProviderError(this.config.type, err.message);
96
+ }
97
+ }
98
+ throw lastError ?? new ProviderError(this.config.type, "Max retries exceeded");
99
+ }
100
+ }
101
+ //# sourceMappingURL=anthropic.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"anthropic.js","sourceRoot":"","sources":["../../src/providers/anthropic.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,4 @@
1
+ import type { ProviderConfig } from "../types";
2
+ import type { Provider } from "./types";
3
+ export declare function createProvider(config: ProviderConfig): Provider;
4
+ //# sourceMappingURL=factory.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"factory.d.ts","sourceRoot":"","sources":["../../src/providers/factory.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,UAAU,CAAC;AAG/C,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,SAAS,CAAC;AAExC,wBAAgB,cAAc,CAAC,MAAM,EAAE,cAAc,GAAG,QAAQ,CAqB/D"}
@@ -0,0 +1,25 @@
1
+ import { AnthropicProvider } from "./anthropic";
2
+ import { OpenAIProvider } from "./openai";
3
+ export function createProvider(config) {
4
+ switch (config.type) {
5
+ case "openai":
6
+ return new OpenAIProvider(config);
7
+ case "vllm":
8
+ return new OpenAIProvider({
9
+ ...config,
10
+ baseUrl: config.baseUrl ?? "http://localhost:8000/v1",
11
+ });
12
+ case "openrouter":
13
+ return new OpenAIProvider({
14
+ ...config,
15
+ baseUrl: config.baseUrl ?? "https://openrouter.ai/api/v1",
16
+ });
17
+ case "anthropic":
18
+ return new AnthropicProvider(config);
19
+ default: {
20
+ const exhaustive = config.type;
21
+ throw new Error(`Unknown provider type: ${exhaustive}`);
22
+ }
23
+ }
24
+ }
25
+ //# sourceMappingURL=factory.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"factory.js","sourceRoot":"","sources":["../../src/providers/factory.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,iBAAiB,EAAE,MAAM,aAAa,CAAC;AAChD,OAAO,EAAE,cAAc,EAAE,MAAM,UAAU,CAAC;AAG1C,MAAM,UAAU,cAAc,CAAC,MAAsB;IACpD,QAAQ,MAAM,CAAC,IAAI,EAAE,CAAC;QACrB,KAAK,QAAQ;YACZ,OAAO,IAAI,cAAc,CAAC,MAAM,CAAC,CAAC;QACnC,KAAK,MAAM;YACV,OAAO,IAAI,cAAc,CAAC;gBACzB,GAAG,MAAM;gBACT,OAAO,EAAE,MAAM,CAAC,OAAO,IAAI,0BAA0B;aACrD,CAAC,CAAC;QACJ,KAAK,YAAY;YAChB,OAAO,IAAI,cAAc,CAAC;gBACzB,GAAG,MAAM;gBACT,OAAO,EAAE,MAAM,CAAC,OAAO,IAAI,8BAA8B;aACzD,CAAC,CAAC;QACJ,KAAK,WAAW;YACf,OAAO,IAAI,iBAAiB,CAAC,MAAM,CAAC,CAAC;QACtC,OAAO,CAAC,CAAC,CAAC;YACT,MAAM,UAAU,GAAU,MAAM,CAAC,IAAI,CAAC;YACtC,MAAM,IAAI,KAAK,CAAC,0BAA0B,UAAU,EAAE,CAAC,CAAC;QACzD,CAAC;IACF,CAAC;AACF,CAAC"}
@@ -0,0 +1,9 @@
1
+ import type { ProviderConfig } from "../types";
2
+ import type { Provider, ProviderRequest, ProviderResponse } from "./types";
3
+ export declare class OpenAIProvider implements Provider {
4
+ private client;
5
+ private config;
6
+ constructor(config: ProviderConfig);
7
+ sendRequest(request: ProviderRequest): Promise<ProviderResponse>;
8
+ }
9
+ //# sourceMappingURL=openai.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"openai.d.ts","sourceRoot":"","sources":["../../src/providers/openai.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,UAAU,CAAC;AAE/C,OAAO,KAAK,EAAE,QAAQ,EAAE,eAAe,EAAE,gBAAgB,EAAE,MAAM,SAAS,CAAC;AAE3E,qBAAa,cAAe,YAAW,QAAQ;IAC9C,OAAO,CAAC,MAAM,CAAS;IACvB,OAAO,CAAC,MAAM,CAAiB;gBAEnB,MAAM,EAAE,cAAc;IAQ5B,WAAW,CAAC,OAAO,EAAE,eAAe,GAAG,OAAO,CAAC,gBAAgB,CAAC;CA8CtE"}
@@ -0,0 +1,57 @@
1
+ import OpenAI from "openai";
2
+ import { OutputError, ProviderError } from "../errors";
3
+ import { parseActionFromJson } from "./parse-action";
4
+ export class OpenAIProvider {
5
+ client;
6
+ config;
7
+ constructor(config) {
8
+ this.config = config;
9
+ this.client = new OpenAI({
10
+ apiKey: config.apiKey ?? "",
11
+ baseURL: config.baseUrl,
12
+ });
13
+ }
14
+ async sendRequest(request) {
15
+ try {
16
+ const response = await this.client.chat.completions.create({
17
+ model: request.model,
18
+ messages: request.messages,
19
+ response_format: {
20
+ type: "json_schema",
21
+ json_schema: {
22
+ name: "action",
23
+ strict: true,
24
+ schema: request.outputSchema,
25
+ },
26
+ },
27
+ ...request.options,
28
+ }, {
29
+ signal: request.signal,
30
+ });
31
+ const content = response.choices[0]?.message?.content;
32
+ if (!content) {
33
+ throw new OutputError("No content in response", "");
34
+ }
35
+ const action = parseActionFromJson(content);
36
+ return {
37
+ action,
38
+ meta: {
39
+ tokensUsed: {
40
+ input: response.usage?.prompt_tokens ?? 0,
41
+ output: response.usage?.completion_tokens ?? 0,
42
+ },
43
+ model: response.model,
44
+ },
45
+ };
46
+ }
47
+ catch (err) {
48
+ if (err instanceof OutputError)
49
+ throw err;
50
+ if (err instanceof OpenAI.APIError) {
51
+ throw new ProviderError(this.config.type, err.message);
52
+ }
53
+ throw err;
54
+ }
55
+ }
56
+ }
57
+ //# sourceMappingURL=openai.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"openai.js","sourceRoot":"","sources":["../../src/providers/openai.ts"],"names":[],"mappings":"AAAA,OAAO,MAAM,MAAM,QAAQ,CAAC;AAC5B,OAAO,EAAE,WAAW,EAAE,aAAa,EAAE,MAAM,WAAW,CAAC;AAEvD,OAAO,EAAE,mBAAmB,EAAE,MAAM,gBAAgB,CAAC;AAGrD,MAAM,OAAO,cAAc;IAClB,MAAM,CAAS;IACf,MAAM,CAAiB;IAE/B,YAAY,MAAsB;QACjC,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC;QACrB,IAAI,CAAC,MAAM,GAAG,IAAI,MAAM,CAAC;YACxB,MAAM,EAAE,MAAM,CAAC,MAAM,IAAI,EAAE;YAC3B,OAAO,EAAE,MAAM,CAAC,OAAO;SACvB,CAAC,CAAC;IACJ,CAAC;IAED,KAAK,CAAC,WAAW,CAAC,OAAwB;QACzC,IAAI,CAAC;YACJ,MAAM,QAAQ,GAAG,MAAM,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,WAAW,CAAC,MAAM,CACzD;gBACC,KAAK,EAAE,OAAO,CAAC,KAAK;gBACpB,QAAQ,EAAE,OAAO,CAAC,QAA+C;gBACjE,eAAe,EAAE;oBAChB,IAAI,EAAE,aAAa;oBACnB,WAAW,EAAE;wBACZ,IAAI,EAAE,QAAQ;wBACd,MAAM,EAAE,IAAI;wBACZ,MAAM,EAAE,OAAO,CAAC,YAAY;qBAC5B;iBACD;gBACD,GAAG,OAAO,CAAC,OAAO;aAClB,EACD;gBACC,MAAM,EAAE,OAAO,CAAC,MAAM;aACtB,CACD,CAAC;YAEF,MAAM,OAAO,GAAG,QAAQ,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,OAAO,EAAE,OAAO,CAAC;YACtD,IAAI,CAAC,OAAO,EAAE,CAAC;gBACd,MAAM,IAAI,WAAW,CAAC,wBAAwB,EAAE,EAAE,CAAC,CAAC;YACrD,CAAC;YAED,MAAM,MAAM,GAAG,mBAAmB,CAAC,OAAO,CAAC,CAAC;YAE5C,OAAO;gBACN,MAAM;gBACN,IAAI,EAAE;oBACL,UAAU,EAAE;wBACX,KAAK,EAAE,QAAQ,CAAC,KAAK,EAAE,aAAa,IAAI,CAAC;wBACzC,MAAM,EAAE,QAAQ,CAAC,KAAK,EAAE,iBAAiB,IAAI,CAAC;qBAC9C;oBACD,KAAK,EAAE,QAAQ,CAAC,KAAK;iBACrB;aACD,CAAC;QACH,CAAC;QAAC,OAAO,GAAG,EAAE,CAAC;YACd,IAAI,GAAG,YAAY,WAAW;gBAAE,MAAM,GAAG,CAAC;YAC1C,IAAI,GAAG,YAAY,MAAM,CAAC,QAAQ,EAAE,CAAC;gBACpC,MAAM,IAAI,aAAa,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI,EAAE,GAAG,CAAC,OAAO,CAAC,CAAC;YACxD,CAAC;YACD,MAAM,GAAG,CAAC;QACX,CAAC;IACF,CAAC;CACD"}
@@ -0,0 +1,3 @@
1
+ import type { Action } from "../types";
2
+ export declare function parseActionFromJson(raw: string): Action;
3
+ //# sourceMappingURL=parse-action.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"parse-action.d.ts","sourceRoot":"","sources":["../../src/providers/parse-action.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,UAAU,CAAC;AAEvC,wBAAgB,mBAAmB,CAAC,GAAG,EAAE,MAAM,GAAG,MAAM,CAkBvD"}
@@ -0,0 +1,18 @@
1
+ import { OutputError } from "../errors";
2
+ export function parseActionFromJson(raw) {
3
+ let parsed;
4
+ try {
5
+ parsed = JSON.parse(raw);
6
+ }
7
+ catch {
8
+ throw new OutputError("Failed to parse response as JSON", raw);
9
+ }
10
+ const action = parsed;
11
+ if (typeof action.tool !== "string" ||
12
+ typeof action.params !== "object" ||
13
+ action.params === null) {
14
+ throw new OutputError("Response missing required 'tool' or 'params' fields", raw);
15
+ }
16
+ return { tool: action.tool, params: action.params };
17
+ }
18
+ //# sourceMappingURL=parse-action.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"parse-action.js","sourceRoot":"","sources":["../../src/providers/parse-action.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,WAAW,CAAC;AAGxC,MAAM,UAAU,mBAAmB,CAAC,GAAW;IAC9C,IAAI,MAAe,CAAC;IACpB,IAAI,CAAC;QACJ,MAAM,GAAG,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;IAC1B,CAAC;IAAC,MAAM,CAAC;QACR,MAAM,IAAI,WAAW,CAAC,kCAAkC,EAAE,GAAG,CAAC,CAAC;IAChE,CAAC;IAED,MAAM,MAAM,GAAG,MAA6D,CAAC;IAC7E,IACC,OAAO,MAAM,CAAC,IAAI,KAAK,QAAQ;QAC/B,OAAO,MAAM,CAAC,MAAM,KAAK,QAAQ;QACjC,MAAM,CAAC,MAAM,KAAK,IAAI,EACrB,CAAC;QACF,MAAM,IAAI,WAAW,CAAC,qDAAqD,EAAE,GAAG,CAAC,CAAC;IACnF,CAAC;IAED,OAAO,EAAE,IAAI,EAAE,MAAM,CAAC,IAAI,EAAE,MAAM,EAAE,MAAM,CAAC,MAAiC,EAAE,CAAC;AAChF,CAAC"}
@@ -0,0 +1,22 @@
1
+ import type { Action } from "../types";
2
+ export interface ProviderRequest {
3
+ messages: unknown[];
4
+ outputSchema: Record<string, unknown>;
5
+ model: string;
6
+ options?: Record<string, unknown>;
7
+ signal?: AbortSignal;
8
+ }
9
+ export interface ProviderResponse {
10
+ action: Action;
11
+ meta: {
12
+ tokensUsed: {
13
+ input: number;
14
+ output: number;
15
+ };
16
+ model: string;
17
+ };
18
+ }
19
+ export interface Provider {
20
+ sendRequest(request: ProviderRequest): Promise<ProviderResponse>;
21
+ }
22
+ //# sourceMappingURL=types.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../src/providers/types.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,UAAU,CAAC;AAEvC,MAAM,WAAW,eAAe;IAC/B,QAAQ,EAAE,OAAO,EAAE,CAAC;IACpB,YAAY,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;IACtC,KAAK,EAAE,MAAM,CAAC;IACd,OAAO,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;IAClC,MAAM,CAAC,EAAE,WAAW,CAAC;CACrB;AAED,MAAM,WAAW,gBAAgB;IAChC,MAAM,EAAE,MAAM,CAAC;IACf,IAAI,EAAE;QACL,UAAU,EAAE;YAAE,KAAK,EAAE,MAAM,CAAC;YAAC,MAAM,EAAE,MAAM,CAAA;SAAE,CAAC;QAC9C,KAAK,EAAE,MAAM,CAAC;KACd,CAAC;CACF;AAED,MAAM,WAAW,QAAQ;IACxB,WAAW,CAAC,OAAO,EAAE,eAAe,GAAG,OAAO,CAAC,gBAAgB,CAAC,CAAC;CACjE"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=types.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.js","sourceRoot":"","sources":["../../src/providers/types.ts"],"names":[],"mappings":""}
@@ -0,0 +1,9 @@
1
+ import { z } from "zod";
2
+ interface ToolForSchema {
3
+ name: string;
4
+ description: string;
5
+ params: z.ZodType;
6
+ }
7
+ export declare function generateActionSchema(tools: ToolForSchema[]): Record<string, unknown>;
8
+ export {};
9
+ //# sourceMappingURL=action-schema.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"action-schema.d.ts","sourceRoot":"","sources":["../../src/schema/action-schema.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAExB,UAAU,aAAa;IACtB,IAAI,EAAE,MAAM,CAAC;IACb,WAAW,EAAE,MAAM,CAAC;IACpB,MAAM,EAAE,CAAC,CAAC,OAAO,CAAC;CAClB;AAQD,wBAAgB,oBAAoB,CAAC,KAAK,EAAE,aAAa,EAAE,GAAG,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAmCpF"}
@@ -0,0 +1,33 @@
1
+ import { z } from "zod";
2
+ export function generateActionSchema(tools) {
3
+ if (tools.length === 0) {
4
+ throw new Error("Cannot generate action schema with zero tools");
5
+ }
6
+ const toolNames = tools.map((t) => t.name);
7
+ const paramBranches = tools.map((tool) => {
8
+ const baseSchema = z.toJSONSchema(tool.params);
9
+ return {
10
+ type: "object",
11
+ properties: {
12
+ tool_name: { type: "string", enum: [tool.name] },
13
+ ...(baseSchema.properties ?? {}),
14
+ },
15
+ required: ["tool_name", ...(baseSchema.required ?? [])],
16
+ additionalProperties: false,
17
+ };
18
+ });
19
+ const paramsProperty = paramBranches.length === 1 ? paramBranches[0] : { anyOf: paramBranches };
20
+ return {
21
+ type: "object",
22
+ properties: {
23
+ tool: {
24
+ type: "string",
25
+ enum: toolNames,
26
+ },
27
+ params: paramsProperty,
28
+ },
29
+ required: ["tool", "params"],
30
+ additionalProperties: false,
31
+ };
32
+ }
33
+ //# sourceMappingURL=action-schema.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"action-schema.js","sourceRoot":"","sources":["../../src/schema/action-schema.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAcxB,MAAM,UAAU,oBAAoB,CAAC,KAAsB;IAC1D,IAAI,KAAK,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;QACxB,MAAM,IAAI,KAAK,CAAC,+CAA+C,CAAC,CAAC;IAClE,CAAC;IAED,MAAM,SAAS,GAAG,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC;IAE3C,MAAM,aAAa,GAAG,KAAK,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE;QACxC,MAAM,UAAU,GAAG,CAAC,CAAC,YAAY,CAAC,IAAI,CAAC,MAAM,CAAqB,CAAC;QAEnE,OAAO;YACN,IAAI,EAAE,QAAQ;YACd,UAAU,EAAE;gBACX,SAAS,EAAE,EAAE,IAAI,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE;gBAChD,GAAG,CAAC,UAAU,CAAC,UAAU,IAAI,EAAE,CAAC;aAChC;YACD,QAAQ,EAAE,CAAC,WAAW,EAAE,GAAG,CAAC,UAAU,CAAC,QAAQ,IAAI,EAAE,CAAC,CAAC;YACvD,oBAAoB,EAAE,KAAK;SAC3B,CAAC;IACH,CAAC,CAAC,CAAC;IAEH,MAAM,cAAc,GAAG,aAAa,CAAC,MAAM,KAAK,CAAC,CAAC,CAAC,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,KAAK,EAAE,aAAa,EAAE,CAAC;IAEhG,OAAO;QACN,IAAI,EAAE,QAAQ;QACd,UAAU,EAAE;YACX,IAAI,EAAE;gBACL,IAAI,EAAE,QAAQ;gBACd,IAAI,EAAE,SAAS;aACf;YACD,MAAM,EAAE,cAAc;SACtB;QACD,QAAQ,EAAE,CAAC,MAAM,EAAE,QAAQ,CAAC;QAC5B,oBAAoB,EAAE,KAAK;KAC3B,CAAC;AACH,CAAC"}
@@ -0,0 +1,11 @@
1
+ import { z } from "zod";
2
+ export declare const historyEntrySchema: z.ZodObject<{
3
+ tool: z.ZodString;
4
+ params: z.ZodRecord<z.ZodString, z.ZodUnknown>;
5
+ result: z.ZodString;
6
+ success: z.ZodDefault<z.ZodBoolean>;
7
+ timestamp: z.ZodOptional<z.ZodString>;
8
+ }, z.core.$strip>;
9
+ export type ValidatedHistoryEntry = z.output<typeof historyEntrySchema>;
10
+ export declare function validateHistory(input: unknown): ValidatedHistoryEntry[];
11
+ //# sourceMappingURL=history-schema.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"history-schema.d.ts","sourceRoot":"","sources":["../../src/schema/history-schema.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAGxB,eAAO,MAAM,kBAAkB;;;;;;iBAM7B,CAAC;AAEH,MAAM,MAAM,qBAAqB,GAAG,CAAC,CAAC,MAAM,CAAC,OAAO,kBAAkB,CAAC,CAAC;AAIxE,wBAAgB,eAAe,CAAC,KAAK,EAAE,OAAO,GAAG,qBAAqB,EAAE,CAQvE"}
@@ -0,0 +1,18 @@
1
+ import { z } from "zod";
2
+ import { ValidationError } from "../errors";
3
+ export const historyEntrySchema = z.object({
4
+ tool: z.string(),
5
+ params: z.record(z.string(), z.unknown()),
6
+ result: z.string(),
7
+ success: z.boolean().default(true),
8
+ timestamp: z.string().optional(),
9
+ });
10
+ const historyArraySchema = z.array(historyEntrySchema);
11
+ export function validateHistory(input) {
12
+ const result = historyArraySchema.safeParse(input);
13
+ if (!result.success) {
14
+ throw new ValidationError(`Invalid history format: ${result.error.issues.map((i) => i.message).join(", ")}`);
15
+ }
16
+ return result.data;
17
+ }
18
+ //# sourceMappingURL=history-schema.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"history-schema.js","sourceRoot":"","sources":["../../src/schema/history-schema.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AACxB,OAAO,EAAE,eAAe,EAAE,MAAM,WAAW,CAAC;AAE5C,MAAM,CAAC,MAAM,kBAAkB,GAAG,CAAC,CAAC,MAAM,CAAC;IAC1C,IAAI,EAAE,CAAC,CAAC,MAAM,EAAE;IAChB,MAAM,EAAE,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,MAAM,EAAE,EAAE,CAAC,CAAC,OAAO,EAAE,CAAC;IACzC,MAAM,EAAE,CAAC,CAAC,MAAM,EAAE;IAClB,OAAO,EAAE,CAAC,CAAC,OAAO,EAAE,CAAC,OAAO,CAAC,IAAI,CAAC;IAClC,SAAS,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;CAChC,CAAC,CAAC;AAIH,MAAM,kBAAkB,GAAG,CAAC,CAAC,KAAK,CAAC,kBAAkB,CAAC,CAAC;AAEvD,MAAM,UAAU,eAAe,CAAC,KAAc;IAC7C,MAAM,MAAM,GAAG,kBAAkB,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC;IACnD,IAAI,CAAC,MAAM,CAAC,OAAO,EAAE,CAAC;QACrB,MAAM,IAAI,eAAe,CACxB,2BAA2B,MAAM,CAAC,KAAK,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CACjF,CAAC;IACH,CAAC;IACD,OAAO,MAAM,CAAC,IAAI,CAAC;AACpB,CAAC"}
@@ -0,0 +1,75 @@
1
+ import type { z } from "zod";
2
+ export interface ProviderConfig {
3
+ type: "openai" | "anthropic" | "vllm" | "openrouter";
4
+ model: string;
5
+ apiKey?: string;
6
+ baseUrl?: string;
7
+ oauth?: boolean;
8
+ options?: Record<string, unknown>;
9
+ }
10
+ export interface TokenBudgets {
11
+ instructions: number;
12
+ state: number;
13
+ history: number;
14
+ tools: number;
15
+ }
16
+ export interface ToolDefinition<TState> {
17
+ name: string;
18
+ description: string;
19
+ params: z.ZodType;
20
+ validWhen: (state: TState) => boolean;
21
+ instructions?: string;
22
+ }
23
+ export interface ModelPricing {
24
+ input: number;
25
+ output: number;
26
+ }
27
+ export interface AgentConfig<TState> {
28
+ provider: ProviderConfig;
29
+ state: z.ZodType<TState>;
30
+ tools: ToolDefinition<TState>[];
31
+ instructions: (state: TState) => string;
32
+ context: {
33
+ budgets: TokenBudgets;
34
+ };
35
+ pricing?: ModelPricing;
36
+ }
37
+ export interface HistoryEntry {
38
+ tool: string;
39
+ params: Record<string, unknown>;
40
+ result: string;
41
+ success?: boolean;
42
+ timestamp?: string;
43
+ }
44
+ export interface Action {
45
+ tool: string;
46
+ params: Record<string, unknown>;
47
+ }
48
+ export interface TokenUsage {
49
+ input: number;
50
+ output: number;
51
+ }
52
+ export interface ActionMeta {
53
+ tokensUsed: TokenUsage;
54
+ cost?: number;
55
+ model: string;
56
+ latency: number;
57
+ }
58
+ export interface ActionResult {
59
+ action: Action;
60
+ meta: ActionMeta;
61
+ }
62
+ export interface VerboseActionResult extends ActionResult {
63
+ context: AssembledContext;
64
+ }
65
+ export interface AssembledContext {
66
+ messages: unknown[];
67
+ outputSchema: Record<string, unknown>;
68
+ validTools: string[];
69
+ }
70
+ export interface NextActionOptions {
71
+ verbose?: boolean;
72
+ signal?: AbortSignal;
73
+ timeout?: number;
74
+ }
75
+ //# sourceMappingURL=types.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../src/types.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAI7B,MAAM,WAAW,cAAc;IAC9B,IAAI,EAAE,QAAQ,GAAG,WAAW,GAAG,MAAM,GAAG,YAAY,CAAC;IACrD,KAAK,EAAE,MAAM,CAAC;IACd,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,KAAK,CAAC,EAAE,OAAO,CAAC;IAChB,OAAO,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;CAClC;AAED,MAAM,WAAW,YAAY;IAC5B,YAAY,EAAE,MAAM,CAAC;IACrB,KAAK,EAAE,MAAM,CAAC;IACd,OAAO,EAAE,MAAM,CAAC;IAChB,KAAK,EAAE,MAAM,CAAC;CACd;AAED,MAAM,WAAW,cAAc,CAAC,MAAM;IACrC,IAAI,EAAE,MAAM,CAAC;IACb,WAAW,EAAE,MAAM,CAAC;IACpB,MAAM,EAAE,CAAC,CAAC,OAAO,CAAC;IAClB,SAAS,EAAE,CAAC,KAAK,EAAE,MAAM,KAAK,OAAO,CAAC;IACtC,YAAY,CAAC,EAAE,MAAM,CAAC;CACtB;AAED,MAAM,WAAW,YAAY;IAC5B,KAAK,EAAE,MAAM,CAAC;IACd,MAAM,EAAE,MAAM,CAAC;CACf;AAED,MAAM,WAAW,WAAW,CAAC,MAAM;IAClC,QAAQ,EAAE,cAAc,CAAC;IACzB,KAAK,EAAE,CAAC,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC;IACzB,KAAK,EAAE,cAAc,CAAC,MAAM,CAAC,EAAE,CAAC;IAChC,YAAY,EAAE,CAAC,KAAK,EAAE,MAAM,KAAK,MAAM,CAAC;IACxC,OAAO,EAAE;QACR,OAAO,EAAE,YAAY,CAAC;KACtB,CAAC;IACF,OAAO,CAAC,EAAE,YAAY,CAAC;CACvB;AAID,MAAM,WAAW,YAAY;IAC5B,IAAI,EAAE,MAAM,CAAC;IACb,MAAM,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;IAChC,MAAM,EAAE,MAAM,CAAC;IACf,OAAO,CAAC,EAAE,OAAO,CAAC;IAClB,SAAS,CAAC,EAAE,MAAM,CAAC;CACnB;AAID,MAAM,WAAW,MAAM;IACtB,IAAI,EAAE,MAAM,CAAC;IACb,MAAM,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;CAChC;AAED,MAAM,WAAW,UAAU;IAC1B,KAAK,EAAE,MAAM,CAAC;IACd,MAAM,EAAE,MAAM,CAAC;CACf;AAED,MAAM,WAAW,UAAU;IAC1B,UAAU,EAAE,UAAU,CAAC;IACvB,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,KAAK,EAAE,MAAM,CAAC;IACd,OAAO,EAAE,MAAM,CAAC;CAChB;AAED,MAAM,WAAW,YAAY;IAC5B,MAAM,EAAE,MAAM,CAAC;IACf,IAAI,EAAE,UAAU,CAAC;CACjB;AAED,MAAM,WAAW,mBAAoB,SAAQ,YAAY;IACxD,OAAO,EAAE,gBAAgB,CAAC;CAC1B;AAED,MAAM,WAAW,gBAAgB;IAChC,QAAQ,EAAE,OAAO,EAAE,CAAC;IACpB,YAAY,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;IACtC,UAAU,EAAE,MAAM,EAAE,CAAC;CACrB;AAID,MAAM,WAAW,iBAAiB;IACjC,OAAO,CAAC,EAAE,OAAO,CAAC;IAClB,MAAM,CAAC,EAAE,WAAW,CAAC;IACrB,OAAO,CAAC,EAAE,MAAM,CAAC;CACjB"}
package/dist/types.js ADDED
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=types.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.js","sourceRoot":"","sources":["../src/types.ts"],"names":[],"mappings":""}