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.
- package/LICENSE +21 -0
- package/README.md +236 -0
- package/dist/agent.d.ts +17 -0
- package/dist/agent.d.ts.map +1 -0
- package/dist/agent.js +131 -0
- package/dist/agent.js.map +1 -0
- package/dist/context/assembler.d.ts +19 -0
- package/dist/context/assembler.d.ts.map +1 -0
- package/dist/context/assembler.js +87 -0
- package/dist/context/assembler.js.map +1 -0
- package/dist/context/budget.d.ts +10 -0
- package/dist/context/budget.d.ts.map +1 -0
- package/dist/context/budget.js +13 -0
- package/dist/context/budget.js.map +1 -0
- package/dist/context/tokenizer.d.ts +6 -0
- package/dist/context/tokenizer.d.ts.map +1 -0
- package/dist/context/tokenizer.js +34 -0
- package/dist/context/tokenizer.js.map +1 -0
- package/dist/errors.d.ts +29 -0
- package/dist/errors.d.ts.map +1 -0
- package/dist/errors.js +44 -0
- package/dist/errors.js.map +1 -0
- package/dist/index.d.ts +9 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +8 -0
- package/dist/index.js.map +1 -0
- package/dist/oauth/anthropic.d.ts +5 -0
- package/dist/oauth/anthropic.d.ts.map +1 -0
- package/dist/oauth/anthropic.js +84 -0
- package/dist/oauth/anthropic.js.map +1 -0
- package/dist/oauth/index.d.ts +18 -0
- package/dist/oauth/index.d.ts.map +1 -0
- package/dist/oauth/index.js +44 -0
- package/dist/oauth/index.js.map +1 -0
- package/dist/oauth/openai.d.ts +14 -0
- package/dist/oauth/openai.d.ts.map +1 -0
- package/dist/oauth/openai.js +328 -0
- package/dist/oauth/openai.js.map +1 -0
- package/dist/oauth/pkce.d.ts +9 -0
- package/dist/oauth/pkce.d.ts.map +1 -0
- package/dist/oauth/pkce.js +22 -0
- package/dist/oauth/pkce.js.map +1 -0
- package/dist/oauth/token-store.d.ts +10 -0
- package/dist/oauth/token-store.d.ts.map +1 -0
- package/dist/oauth/token-store.js +36 -0
- package/dist/oauth/token-store.js.map +1 -0
- package/dist/oauth/types.d.ts +32 -0
- package/dist/oauth/types.d.ts.map +1 -0
- package/dist/oauth/types.js +2 -0
- package/dist/oauth/types.js.map +1 -0
- package/dist/providers/anthropic.d.ts +9 -0
- package/dist/providers/anthropic.d.ts.map +1 -0
- package/dist/providers/anthropic.js +101 -0
- package/dist/providers/anthropic.js.map +1 -0
- package/dist/providers/factory.d.ts +4 -0
- package/dist/providers/factory.d.ts.map +1 -0
- package/dist/providers/factory.js +25 -0
- package/dist/providers/factory.js.map +1 -0
- package/dist/providers/openai.d.ts +9 -0
- package/dist/providers/openai.d.ts.map +1 -0
- package/dist/providers/openai.js +57 -0
- package/dist/providers/openai.js.map +1 -0
- package/dist/providers/parse-action.d.ts +3 -0
- package/dist/providers/parse-action.d.ts.map +1 -0
- package/dist/providers/parse-action.js +18 -0
- package/dist/providers/parse-action.js.map +1 -0
- package/dist/providers/types.d.ts +22 -0
- package/dist/providers/types.d.ts.map +1 -0
- package/dist/providers/types.js +2 -0
- package/dist/providers/types.js.map +1 -0
- package/dist/schema/action-schema.d.ts +9 -0
- package/dist/schema/action-schema.d.ts.map +1 -0
- package/dist/schema/action-schema.js +33 -0
- package/dist/schema/action-schema.js.map +1 -0
- package/dist/schema/history-schema.d.ts +11 -0
- package/dist/schema/history-schema.d.ts.map +1 -0
- package/dist/schema/history-schema.js +18 -0
- package/dist/schema/history-schema.js.map +1 -0
- package/dist/types.d.ts +75 -0
- package/dist/types.d.ts.map +1 -0
- package/dist/types.js +2 -0
- package/dist/types.js.map +1 -0
- 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 @@
|
|
|
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":"AAAA,OAAO,EAAE,WAAW,EAAE,aAAa,EAAE,MAAM,WAAW,CAAC;AAEvD,OAAO,EAAE,mBAAmB,EAAE,MAAM,gBAAgB,CAAC;AAGrD,MAAM,kBAAkB,GAAG,2BAA2B,CAAC;AACvD,MAAM,iBAAiB,GAAG,YAAY,CAAC;AAEvC,MAAM,kBAAkB,GAAG,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC,CAAC;AACrD,MAAM,WAAW,GAAG,CAAC,CAAC;AACtB,MAAM,aAAa,GAAG,IAAI,CAAC;AAE3B,KAAK,UAAU,KAAK,CAAC,EAAU;IAC9B,OAAO,IAAI,OAAO,CAAC,CAAC,OAAO,EAAE,EAAE,CAAC,UAAU,CAAC,OAAO,EAAE,EAAE,CAAC,CAAC,CAAC;AAC1D,CAAC;AAOD,MAAM,OAAO,iBAAiB;IACrB,MAAM,CAAiB;IACvB,OAAO,CAAS;IAExB,YAAY,MAAsB;QACjC,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC;QACrB,IAAI,CAAC,OAAO,GAAG,MAAM,CAAC,OAAO,IAAI,kBAAkB,CAAC;IACrD,CAAC;IAED,KAAK,CAAC,WAAW,CAAC,OAAwB;QACzC,MAAM,QAAQ,GAAG,OAAO,CAAC,QAAqD,CAAC;QAC/E,IAAI,MAA0B,CAAC;QAC/B,MAAM,iBAAiB,GAAuB,EAAE,CAAC;QAEjD,KAAK,MAAM,GAAG,IAAI,QAAQ,EAAE,CAAC;YAC5B,IAAI,GAAG,CAAC,IAAI,KAAK,QAAQ,EAAE,CAAC;gBAC3B,MAAM,GAAG,GAAG,CAAC,OAAiB,CAAC;YAChC,CAAC;iBAAM,CAAC;gBACP,iBAAiB,CAAC,IAAI,CAAC;oBACtB,IAAI,EAAE,GAAG,CAAC,IAA4B;oBACtC,OAAO,EAAE,GAAG,CAAC,OAAsC;iBACnD,CAAC,CAAC;YACJ,CAAC;QACF,CAAC;QAED,MAAM,IAAI,GAA4B;YACrC,KAAK,EAAE,OAAO,CAAC,KAAK;YACpB,QAAQ,EAAE,iBAAiB;YAC3B,UAAU,EAAE,IAAI;YAChB,aAAa,EAAE;gBACd,MAAM,EAAE;oBACP,IAAI,EAAE,aAAa;oBACnB,MAAM,EAAE,OAAO,CAAC,YAAY;iBAC5B;aACD;YACD,GAAG,OAAO,CAAC,OAAO;SAClB,CAAC;QAEF,IAAI,MAAM,EAAE,CAAC;YACZ,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC;QACtB,CAAC;QAED,MAAM,OAAO,GAA2B;YACvC,cAAc,EAAE,kBAAkB;YAClC,WAAW,EAAE,IAAI,CAAC,MAAM,CAAC,MAAM,IAAI,EAAE;YACrC,mBAAmB,EAAE,iBAAiB;SACtC,CAAC;QAEF,IAAI,SAA4B,CAAC;QAEjC,KAAK,IAAI,OAAO,GAAG,CAAC,EAAE,OAAO,IAAI,WAAW,EAAE,OAAO,EAAE,EAAE,CAAC;YACzD,IAAI,OAAO,CAAC,MAAM,EAAE,OAAO,EAAE,CAAC;gBAC7B,MAAM,IAAI,aAAa,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI,EAAE,qBAAqB,CAAC,CAAC;YAClE,CAAC;YAED,IAAI,CAAC;gBACJ,MAAM,QAAQ,GAAG,MAAM,KAAK,CAAC,GAAG,IAAI,CAAC,OAAO,cAAc,EAAE;oBAC3D,MAAM,EAAE,MAAM;oBACd,OAAO;oBACP,IAAI,EAAE,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC;oBAC1B,MAAM,EAAE,OAAO,CAAC,MAAM;iBACtB,CAAC,CAAC;gBAEH,IAAI,CAAC,QAAQ,CAAC,EAAE,EAAE,CAAC;oBAClB,MAAM,SAAS,GAAG,MAAM,QAAQ,CAAC,IAAI,EAAE,CAAC;oBACxC,IAAI,kBAAkB,CAAC,QAAQ,CAAC,QAAQ,CAAC,MAAM,CAAC,IAAI,OAAO,GAAG,WAAW,EAAE,CAAC;wBAC3E,MAAM,KAAK,GAAG,aAAa,GAAG,CAAC,IAAI,OAAO,CAAC;wBAC3C,MAAM,KAAK,CAAC,KAAK,CAAC,CAAC;wBACnB,SAAS,GAAG,IAAI,aAAa,CAC5B,IAAI,CAAC,MAAM,CAAC,IAAI,EAChB,QAAQ,QAAQ,CAAC,MAAM,KAAK,SAAS,EAAE,CACvC,CAAC;wBACF,SAAS;oBACV,CAAC;oBACD,MAAM,IAAI,aAAa,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI,EAAE,QAAQ,QAAQ,CAAC,MAAM,KAAK,SAAS,EAAE,CAAC,CAAC;gBACpF,CAAC;gBAED,MAAM,IAAI,GAAG,CAAC,MAAM,QAAQ,CAAC,IAAI,EAAE,CAIlC,CAAC;gBAEF,MAAM,SAAS,GAAG,IAAI,CAAC,OAAO,EAAE,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,MAAM,CAAC,CAAC;gBAC/D,IAAI,CAAC,SAAS,EAAE,IAAI,EAAE,CAAC;oBACtB,MAAM,IAAI,WAAW,CACpB,uCAAuC,EACvC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,OAAO,CAAC,CAC5B,CAAC;gBACH,CAAC;gBAED,MAAM,MAAM,GAAG,mBAAmB,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;gBAEnD,OAAO;oBACN,MAAM;oBACN,IAAI,EAAE;wBACL,UAAU,EAAE;4BACX,KAAK,EAAE,IAAI,CAAC,KAAK,EAAE,YAAY,IAAI,CAAC;4BACpC,MAAM,EAAE,IAAI,CAAC,KAAK,EAAE,aAAa,IAAI,CAAC;yBACtC;wBACD,KAAK,EAAE,IAAI,CAAC,KAAK,IAAI,OAAO,CAAC,KAAK;qBAClC;iBACD,CAAC;YACH,CAAC;YAAC,OAAO,GAAG,EAAE,CAAC;gBACd,IAAI,GAAG,YAAY,aAAa,IAAI,GAAG,YAAY,WAAW;oBAAE,MAAM,GAAG,CAAC;gBAC1E,MAAM,IAAI,aAAa,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI,EAAG,GAAa,CAAC,OAAO,CAAC,CAAC;YACnE,CAAC;QACF,CAAC;QAED,MAAM,SAAS,IAAI,IAAI,aAAa,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI,EAAE,sBAAsB,CAAC,CAAC;IAChF,CAAC;CACD"}
|
|
@@ -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 @@
|
|
|
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 @@
|
|
|
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"}
|
package/dist/types.d.ts
ADDED
|
@@ -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 @@
|
|
|
1
|
+
{"version":3,"file":"types.js","sourceRoot":"","sources":["../src/types.ts"],"names":[],"mappings":""}
|