@evalstudio/api 0.1.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/dist/cli.d.ts +3 -0
- package/dist/cli.d.ts.map +1 -0
- package/dist/cli.js +4 -0
- package/dist/cli.js.map +1 -0
- package/dist/index.d.ts +18 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +104 -0
- package/dist/index.js.map +1 -0
- package/dist/routes/connectors.d.ts +3 -0
- package/dist/routes/connectors.d.ts.map +1 -0
- package/dist/routes/connectors.js +109 -0
- package/dist/routes/connectors.js.map +1 -0
- package/dist/routes/evals.d.ts +3 -0
- package/dist/routes/evals.d.ts.map +1 -0
- package/dist/routes/evals.js +103 -0
- package/dist/routes/evals.js.map +1 -0
- package/dist/routes/llm-providers.d.ts +3 -0
- package/dist/routes/llm-providers.d.ts.map +1 -0
- package/dist/routes/llm-providers.js +110 -0
- package/dist/routes/llm-providers.js.map +1 -0
- package/dist/routes/personas.d.ts +3 -0
- package/dist/routes/personas.d.ts.map +1 -0
- package/dist/routes/personas.js +79 -0
- package/dist/routes/personas.js.map +1 -0
- package/dist/routes/projects.d.ts +3 -0
- package/dist/routes/projects.d.ts.map +1 -0
- package/dist/routes/projects.js +65 -0
- package/dist/routes/projects.js.map +1 -0
- package/dist/routes/runs.d.ts +3 -0
- package/dist/routes/runs.d.ts.map +1 -0
- package/dist/routes/runs.js +127 -0
- package/dist/routes/runs.js.map +1 -0
- package/dist/routes/scenarios.d.ts +3 -0
- package/dist/routes/scenarios.d.ts.map +1 -0
- package/dist/routes/scenarios.js +113 -0
- package/dist/routes/scenarios.js.map +1 -0
- package/dist/routes/status.d.ts +3 -0
- package/dist/routes/status.d.ts.map +1 -0
- package/dist/routes/status.js +7 -0
- package/dist/routes/status.js.map +1 -0
- package/package.json +56 -0
package/dist/cli.d.ts
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"cli.d.ts","sourceRoot":"","sources":["../src/cli.ts"],"names":[],"mappings":""}
|
package/dist/cli.js
ADDED
package/dist/cli.js.map
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"cli.js","sourceRoot":"","sources":["../src/cli.ts"],"names":[],"mappings":";AACA,OAAO,EAAE,WAAW,EAAE,MAAM,YAAY,CAAC;AAEzC,WAAW,EAAE,CAAC"}
|
package/dist/index.d.ts
ADDED
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import Fastify from "fastify";
|
|
2
|
+
import { RunProcessor } from "evalstudio";
|
|
3
|
+
export interface ServerOptions {
|
|
4
|
+
logger?: boolean;
|
|
5
|
+
/** Enable background run processing (default: true) */
|
|
6
|
+
runProcessor?: boolean;
|
|
7
|
+
/** Run processor polling interval in ms (default: 5000) */
|
|
8
|
+
runProcessorPollMs?: number;
|
|
9
|
+
/** Maximum concurrent runs (default: 3) */
|
|
10
|
+
runProcessorMaxConcurrent?: number;
|
|
11
|
+
/** Path to built web UI files (enables static file serving) */
|
|
12
|
+
webDistPath?: string;
|
|
13
|
+
}
|
|
14
|
+
export declare function createServer(options?: ServerOptions): Promise<Fastify.FastifyInstance<import("http").Server<typeof import("http").IncomingMessage, typeof import("http").ServerResponse>, import("http").IncomingMessage, import("http").ServerResponse<import("http").IncomingMessage>, Fastify.FastifyBaseLogger, Fastify.FastifyTypeProviderDefault>>;
|
|
15
|
+
export declare function startServer(port?: number): Promise<Fastify.FastifyInstance<import("http").Server<typeof import("http").IncomingMessage, typeof import("http").ServerResponse>, import("http").IncomingMessage, import("http").ServerResponse<import("http").IncomingMessage>, Fastify.FastifyBaseLogger, Fastify.FastifyTypeProviderDefault>>;
|
|
16
|
+
/** Get the current run processor instance (for testing/monitoring) */
|
|
17
|
+
export declare function getRunProcessor(): RunProcessor | null;
|
|
18
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAEA,OAAO,OAAO,MAAM,SAAS,CAAC;AAE9B,OAAO,EAAE,YAAY,EAAE,MAAM,YAAY,CAAC;AAU1C,MAAM,WAAW,aAAa;IAC5B,MAAM,CAAC,EAAE,OAAO,CAAC;IACjB,uDAAuD;IACvD,YAAY,CAAC,EAAE,OAAO,CAAC;IACvB,2DAA2D;IAC3D,kBAAkB,CAAC,EAAE,MAAM,CAAC;IAC5B,2CAA2C;IAC3C,yBAAyB,CAAC,EAAE,MAAM,CAAC;IACnC,+DAA+D;IAC/D,WAAW,CAAC,EAAE,MAAM,CAAC;CACtB;AAKD,wBAAsB,YAAY,CAAC,OAAO,GAAE,aAAkB,sSA6E7D;AAED,wBAAsB,WAAW,CAAC,IAAI,SAAsD,sSAqB3F;AAED,sEAAsE;AACtE,wBAAgB,eAAe,IAAI,YAAY,GAAG,IAAI,CAErD"}
|
package/dist/index.js
ADDED
|
@@ -0,0 +1,104 @@
|
|
|
1
|
+
import { readFileSync } from "node:fs";
|
|
2
|
+
import { join } from "node:path";
|
|
3
|
+
import Fastify from "fastify";
|
|
4
|
+
import fastifyStatic from "@fastify/static";
|
|
5
|
+
import { RunProcessor } from "evalstudio";
|
|
6
|
+
import { connectorsRoute } from "./routes/connectors.js";
|
|
7
|
+
import { evalsRoute } from "./routes/evals.js";
|
|
8
|
+
import { llmProvidersRoute } from "./routes/llm-providers.js";
|
|
9
|
+
import { personasRoute } from "./routes/personas.js";
|
|
10
|
+
import { projectsRoute } from "./routes/projects.js";
|
|
11
|
+
import { runsRoute } from "./routes/runs.js";
|
|
12
|
+
import { scenariosRoute } from "./routes/scenarios.js";
|
|
13
|
+
import { statusRoute } from "./routes/status.js";
|
|
14
|
+
// Global processor instance for graceful shutdown
|
|
15
|
+
let runProcessor = null;
|
|
16
|
+
export async function createServer(options = {}) {
|
|
17
|
+
const fastify = Fastify({
|
|
18
|
+
logger: options.logger ?? false,
|
|
19
|
+
});
|
|
20
|
+
// Register all API routes under /api prefix
|
|
21
|
+
await fastify.register(async (api) => {
|
|
22
|
+
await api.register(connectorsRoute);
|
|
23
|
+
await api.register(evalsRoute);
|
|
24
|
+
await api.register(llmProvidersRoute);
|
|
25
|
+
await api.register(personasRoute);
|
|
26
|
+
await api.register(projectsRoute);
|
|
27
|
+
await api.register(runsRoute);
|
|
28
|
+
await api.register(scenariosRoute);
|
|
29
|
+
await api.register(statusRoute);
|
|
30
|
+
}, { prefix: "/api" });
|
|
31
|
+
// Serve static web UI files if webDistPath is provided
|
|
32
|
+
if (options.webDistPath) {
|
|
33
|
+
await fastify.register(fastifyStatic, {
|
|
34
|
+
root: options.webDistPath,
|
|
35
|
+
wildcard: false,
|
|
36
|
+
});
|
|
37
|
+
// SPA fallback: non-API, non-static routes return index.html
|
|
38
|
+
fastify.setNotFoundHandler((request, reply) => {
|
|
39
|
+
if (request.url.startsWith("/api/")) {
|
|
40
|
+
reply.code(404).send({ error: "Not found" });
|
|
41
|
+
}
|
|
42
|
+
else {
|
|
43
|
+
const indexPath = join(options.webDistPath, "index.html");
|
|
44
|
+
const html = readFileSync(indexPath, "utf-8");
|
|
45
|
+
reply.type("text/html").send(html);
|
|
46
|
+
}
|
|
47
|
+
});
|
|
48
|
+
}
|
|
49
|
+
// Start the run processor if enabled (default: true)
|
|
50
|
+
const enableProcessor = options.runProcessor ?? true;
|
|
51
|
+
if (enableProcessor) {
|
|
52
|
+
const pollMs = options.runProcessorPollMs ?? 5000;
|
|
53
|
+
const maxConcurrent = options.runProcessorMaxConcurrent ?? 3;
|
|
54
|
+
runProcessor = new RunProcessor({
|
|
55
|
+
pollIntervalMs: pollMs,
|
|
56
|
+
maxConcurrent,
|
|
57
|
+
onRunStart: (run) => {
|
|
58
|
+
console.log(`[RunProcessor] Starting run ${run.id}`);
|
|
59
|
+
},
|
|
60
|
+
onRunComplete: (run, result) => {
|
|
61
|
+
console.log(`[RunProcessor] Run ${run.id} completed (${result.latencyMs}ms)`);
|
|
62
|
+
},
|
|
63
|
+
onRunError: (run, error) => {
|
|
64
|
+
console.error(`[RunProcessor] Run ${run.id} failed: ${error.message}`);
|
|
65
|
+
},
|
|
66
|
+
});
|
|
67
|
+
runProcessor.start();
|
|
68
|
+
console.log(`[RunProcessor] Started (poll: ${pollMs}ms, concurrency: ${maxConcurrent})`);
|
|
69
|
+
}
|
|
70
|
+
// Register shutdown hook
|
|
71
|
+
fastify.addHook("onClose", async () => {
|
|
72
|
+
if (runProcessor) {
|
|
73
|
+
console.log("[RunProcessor] Stopping...");
|
|
74
|
+
await runProcessor.stop();
|
|
75
|
+
console.log("[RunProcessor] Stopped");
|
|
76
|
+
}
|
|
77
|
+
});
|
|
78
|
+
return fastify;
|
|
79
|
+
}
|
|
80
|
+
export async function startServer(port = parseInt(process.env.EVALSTUDIO_PORT || "3000", 10)) {
|
|
81
|
+
const server = await createServer({ logger: true });
|
|
82
|
+
// Handle graceful shutdown
|
|
83
|
+
const shutdown = async (signal) => {
|
|
84
|
+
console.log(`\n${signal} received, shutting down gracefully...`);
|
|
85
|
+
await server.close();
|
|
86
|
+
process.exit(0);
|
|
87
|
+
};
|
|
88
|
+
process.on("SIGTERM", () => shutdown("SIGTERM"));
|
|
89
|
+
process.on("SIGINT", () => shutdown("SIGINT"));
|
|
90
|
+
try {
|
|
91
|
+
const address = await server.listen({ port, host: "0.0.0.0" });
|
|
92
|
+
console.log(`Server listening at ${address}`);
|
|
93
|
+
return server;
|
|
94
|
+
}
|
|
95
|
+
catch (err) {
|
|
96
|
+
server.log.error(err);
|
|
97
|
+
process.exit(1);
|
|
98
|
+
}
|
|
99
|
+
}
|
|
100
|
+
/** Get the current run processor instance (for testing/monitoring) */
|
|
101
|
+
export function getRunProcessor() {
|
|
102
|
+
return runProcessor;
|
|
103
|
+
}
|
|
104
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"connectors.d.ts","sourceRoot":"","sources":["../../src/routes/connectors.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,SAAS,CAAC;AA2C/C,wBAAsB,eAAe,CAAC,OAAO,EAAE,eAAe,iBAqJ7D"}
|
|
@@ -0,0 +1,109 @@
|
|
|
1
|
+
import { createConnector, deleteConnector, getConnector, getConnectorTypes, invokeConnector, listConnectors, testConnector, updateConnector, } from "evalstudio";
|
|
2
|
+
export async function connectorsRoute(fastify) {
|
|
3
|
+
fastify.get("/connectors", async (request) => {
|
|
4
|
+
return listConnectors(request.query.projectId);
|
|
5
|
+
});
|
|
6
|
+
fastify.get("/connectors/types", async () => {
|
|
7
|
+
return getConnectorTypes();
|
|
8
|
+
});
|
|
9
|
+
fastify.get("/connectors/:id", async (request, reply) => {
|
|
10
|
+
const connector = getConnector(request.params.id);
|
|
11
|
+
if (!connector) {
|
|
12
|
+
reply.code(404);
|
|
13
|
+
return { error: "Connector not found" };
|
|
14
|
+
}
|
|
15
|
+
return connector;
|
|
16
|
+
});
|
|
17
|
+
fastify.post("/connectors", async (request, reply) => {
|
|
18
|
+
const { projectId, name, type, baseUrl, authType, authValue, config } = request.body;
|
|
19
|
+
if (!projectId) {
|
|
20
|
+
reply.code(400);
|
|
21
|
+
return { error: "Project ID is required" };
|
|
22
|
+
}
|
|
23
|
+
if (!name) {
|
|
24
|
+
reply.code(400);
|
|
25
|
+
return { error: "Name is required" };
|
|
26
|
+
}
|
|
27
|
+
if (!type) {
|
|
28
|
+
reply.code(400);
|
|
29
|
+
return { error: "Type is required" };
|
|
30
|
+
}
|
|
31
|
+
if (!baseUrl) {
|
|
32
|
+
reply.code(400);
|
|
33
|
+
return { error: "Base URL is required" };
|
|
34
|
+
}
|
|
35
|
+
try {
|
|
36
|
+
const connector = createConnector({
|
|
37
|
+
projectId,
|
|
38
|
+
name,
|
|
39
|
+
type,
|
|
40
|
+
baseUrl,
|
|
41
|
+
authType,
|
|
42
|
+
authValue,
|
|
43
|
+
config,
|
|
44
|
+
});
|
|
45
|
+
reply.code(201);
|
|
46
|
+
return connector;
|
|
47
|
+
}
|
|
48
|
+
catch (error) {
|
|
49
|
+
if (error instanceof Error) {
|
|
50
|
+
if (error.message.includes("not found")) {
|
|
51
|
+
reply.code(404);
|
|
52
|
+
}
|
|
53
|
+
else {
|
|
54
|
+
reply.code(409);
|
|
55
|
+
}
|
|
56
|
+
return { error: error.message };
|
|
57
|
+
}
|
|
58
|
+
throw error;
|
|
59
|
+
}
|
|
60
|
+
});
|
|
61
|
+
fastify.put("/connectors/:id", async (request, reply) => {
|
|
62
|
+
const { name, type, baseUrl, authType, authValue, config } = request.body;
|
|
63
|
+
try {
|
|
64
|
+
const connector = updateConnector(request.params.id, {
|
|
65
|
+
name,
|
|
66
|
+
type,
|
|
67
|
+
baseUrl,
|
|
68
|
+
authType,
|
|
69
|
+
authValue,
|
|
70
|
+
config,
|
|
71
|
+
});
|
|
72
|
+
if (!connector) {
|
|
73
|
+
reply.code(404);
|
|
74
|
+
return { error: "Connector not found" };
|
|
75
|
+
}
|
|
76
|
+
return connector;
|
|
77
|
+
}
|
|
78
|
+
catch (error) {
|
|
79
|
+
if (error instanceof Error) {
|
|
80
|
+
reply.code(409);
|
|
81
|
+
return { error: error.message };
|
|
82
|
+
}
|
|
83
|
+
throw error;
|
|
84
|
+
}
|
|
85
|
+
});
|
|
86
|
+
fastify.delete("/connectors/:id", async (request, reply) => {
|
|
87
|
+
const deleted = deleteConnector(request.params.id);
|
|
88
|
+
if (!deleted) {
|
|
89
|
+
reply.code(404);
|
|
90
|
+
return { error: "Connector not found" };
|
|
91
|
+
}
|
|
92
|
+
reply.code(204);
|
|
93
|
+
return;
|
|
94
|
+
});
|
|
95
|
+
fastify.post("/connectors/:id/test", async (request) => {
|
|
96
|
+
const result = await testConnector(request.params.id);
|
|
97
|
+
return result;
|
|
98
|
+
});
|
|
99
|
+
fastify.post("/connectors/:id/invoke", async (request, reply) => {
|
|
100
|
+
const { messages } = request.body;
|
|
101
|
+
if (!messages || !Array.isArray(messages) || messages.length === 0) {
|
|
102
|
+
reply.code(400);
|
|
103
|
+
return { error: "Messages array is required" };
|
|
104
|
+
}
|
|
105
|
+
const result = await invokeConnector(request.params.id, { messages });
|
|
106
|
+
return result;
|
|
107
|
+
});
|
|
108
|
+
}
|
|
109
|
+
//# sourceMappingURL=connectors.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"connectors.js","sourceRoot":"","sources":["../../src/routes/connectors.ts"],"names":[],"mappings":"AACA,OAAO,EACL,eAAe,EACf,eAAe,EACf,YAAY,EACZ,iBAAiB,EACjB,eAAe,EACf,cAAc,EACd,aAAa,EACb,eAAe,GAKhB,MAAM,YAAY,CAAC;AA6BpB,MAAM,CAAC,KAAK,UAAU,eAAe,CAAC,OAAwB;IAC5D,OAAO,CAAC,GAAG,CACT,aAAa,EACb,KAAK,EAAE,OAAO,EAAE,EAAE;QAChB,OAAO,cAAc,CAAC,OAAO,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC;IACjD,CAAC,CACF,CAAC;IAEF,OAAO,CAAC,GAAG,CAAC,mBAAmB,EAAE,KAAK,IAAI,EAAE;QAC1C,OAAO,iBAAiB,EAAE,CAAC;IAC7B,CAAC,CAAC,CAAC;IAEH,OAAO,CAAC,GAAG,CACT,iBAAiB,EACjB,KAAK,EAAE,OAAO,EAAE,KAAK,EAAE,EAAE;QACvB,MAAM,SAAS,GAAG,YAAY,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC;QAElD,IAAI,CAAC,SAAS,EAAE,CAAC;YACf,KAAK,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;YAChB,OAAO,EAAE,KAAK,EAAE,qBAAqB,EAAE,CAAC;QAC1C,CAAC;QAED,OAAO,SAAS,CAAC;IACnB,CAAC,CACF,CAAC;IAEF,OAAO,CAAC,IAAI,CACV,aAAa,EACb,KAAK,EAAE,OAAO,EAAE,KAAK,EAAE,EAAE;QACvB,MAAM,EAAE,SAAS,EAAE,IAAI,EAAE,IAAI,EAAE,OAAO,EAAE,QAAQ,EAAE,SAAS,EAAE,MAAM,EAAE,GAAG,OAAO,CAAC,IAAI,CAAC;QAErF,IAAI,CAAC,SAAS,EAAE,CAAC;YACf,KAAK,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;YAChB,OAAO,EAAE,KAAK,EAAE,wBAAwB,EAAE,CAAC;QAC7C,CAAC;QAED,IAAI,CAAC,IAAI,EAAE,CAAC;YACV,KAAK,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;YAChB,OAAO,EAAE,KAAK,EAAE,kBAAkB,EAAE,CAAC;QACvC,CAAC;QAED,IAAI,CAAC,IAAI,EAAE,CAAC;YACV,KAAK,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;YAChB,OAAO,EAAE,KAAK,EAAE,kBAAkB,EAAE,CAAC;QACvC,CAAC;QAED,IAAI,CAAC,OAAO,EAAE,CAAC;YACb,KAAK,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;YAChB,OAAO,EAAE,KAAK,EAAE,sBAAsB,EAAE,CAAC;QAC3C,CAAC;QAED,IAAI,CAAC;YACH,MAAM,SAAS,GAAG,eAAe,CAAC;gBAChC,SAAS;gBACT,IAAI;gBACJ,IAAI;gBACJ,OAAO;gBACP,QAAQ;gBACR,SAAS;gBACT,MAAM;aACP,CAAC,CAAC;YACH,KAAK,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;YAChB,OAAO,SAAS,CAAC;QACnB,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,IAAI,KAAK,YAAY,KAAK,EAAE,CAAC;gBAC3B,IAAI,KAAK,CAAC,OAAO,CAAC,QAAQ,CAAC,WAAW,CAAC,EAAE,CAAC;oBACxC,KAAK,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;gBAClB,CAAC;qBAAM,CAAC;oBACN,KAAK,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;gBAClB,CAAC;gBACD,OAAO,EAAE,KAAK,EAAE,KAAK,CAAC,OAAO,EAAE,CAAC;YAClC,CAAC;YACD,MAAM,KAAK,CAAC;QACd,CAAC;IACH,CAAC,CACF,CAAC;IAEF,OAAO,CAAC,GAAG,CACT,iBAAiB,EACjB,KAAK,EAAE,OAAO,EAAE,KAAK,EAAE,EAAE;QACvB,MAAM,EAAE,IAAI,EAAE,IAAI,EAAE,OAAO,EAAE,QAAQ,EAAE,SAAS,EAAE,MAAM,EAAE,GAAG,OAAO,CAAC,IAAI,CAAC;QAE1E,IAAI,CAAC;YACH,MAAM,SAAS,GAAG,eAAe,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE,EAAE;gBACnD,IAAI;gBACJ,IAAI;gBACJ,OAAO;gBACP,QAAQ;gBACR,SAAS;gBACT,MAAM;aACP,CAAC,CAAC;YAEH,IAAI,CAAC,SAAS,EAAE,CAAC;gBACf,KAAK,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;gBAChB,OAAO,EAAE,KAAK,EAAE,qBAAqB,EAAE,CAAC;YAC1C,CAAC;YAED,OAAO,SAAS,CAAC;QACnB,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,IAAI,KAAK,YAAY,KAAK,EAAE,CAAC;gBAC3B,KAAK,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;gBAChB,OAAO,EAAE,KAAK,EAAE,KAAK,CAAC,OAAO,EAAE,CAAC;YAClC,CAAC;YACD,MAAM,KAAK,CAAC;QACd,CAAC;IACH,CAAC,CACF,CAAC;IAEF,OAAO,CAAC,MAAM,CACZ,iBAAiB,EACjB,KAAK,EAAE,OAAO,EAAE,KAAK,EAAE,EAAE;QACvB,MAAM,OAAO,GAAG,eAAe,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC;QAEnD,IAAI,CAAC,OAAO,EAAE,CAAC;YACb,KAAK,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;YAChB,OAAO,EAAE,KAAK,EAAE,qBAAqB,EAAE,CAAC;QAC1C,CAAC;QAED,KAAK,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;QAChB,OAAO;IACT,CAAC,CACF,CAAC;IAEF,OAAO,CAAC,IAAI,CACV,sBAAsB,EACtB,KAAK,EAAE,OAAO,EAAE,EAAE;QAChB,MAAM,MAAM,GAAG,MAAM,aAAa,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC;QACtD,OAAO,MAAM,CAAC;IAChB,CAAC,CACF,CAAC;IAMF,OAAO,CAAC,IAAI,CACV,wBAAwB,EACxB,KAAK,EAAE,OAAO,EAAE,KAAK,EAAE,EAAE;QACvB,MAAM,EAAE,QAAQ,EAAE,GAAG,OAAO,CAAC,IAAI,CAAC;QAElC,IAAI,CAAC,QAAQ,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,QAAQ,CAAC,IAAI,QAAQ,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;YACnE,KAAK,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;YAChB,OAAO,EAAE,KAAK,EAAE,4BAA4B,EAAE,CAAC;QACjD,CAAC;QAED,MAAM,MAAM,GAAG,MAAM,eAAe,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE,EAAE,EAAE,QAAQ,EAAE,CAAC,CAAC;QACtE,OAAO,MAAM,CAAC;IAChB,CAAC,CACF,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"evals.d.ts","sourceRoot":"","sources":["../../src/routes/evals.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,SAAS,CAAC;AAyC/C,wBAAsB,UAAU,CAAC,OAAO,EAAE,eAAe,iBAyIxD"}
|
|
@@ -0,0 +1,103 @@
|
|
|
1
|
+
import { createEval, deleteEval, getEval, getEvalWithRelations, listEvals, updateEval, } from "evalstudio";
|
|
2
|
+
export async function evalsRoute(fastify) {
|
|
3
|
+
fastify.get("/evals", async (request) => {
|
|
4
|
+
return listEvals(request.query.projectId);
|
|
5
|
+
});
|
|
6
|
+
fastify.get("/evals/:id", async (request, reply) => {
|
|
7
|
+
const expand = request.query.expand === "true";
|
|
8
|
+
const evalItem = expand
|
|
9
|
+
? getEvalWithRelations(request.params.id)
|
|
10
|
+
: getEval(request.params.id);
|
|
11
|
+
if (!evalItem) {
|
|
12
|
+
reply.code(404);
|
|
13
|
+
return { error: "Eval not found" };
|
|
14
|
+
}
|
|
15
|
+
return evalItem;
|
|
16
|
+
});
|
|
17
|
+
fastify.post("/evals", async (request, reply) => {
|
|
18
|
+
const { projectId, name, input, scenarioIds, connectorId, } = request.body;
|
|
19
|
+
if (!projectId) {
|
|
20
|
+
reply.code(400);
|
|
21
|
+
return { error: "Project ID is required" };
|
|
22
|
+
}
|
|
23
|
+
if (!name) {
|
|
24
|
+
reply.code(400);
|
|
25
|
+
return { error: "Name is required" };
|
|
26
|
+
}
|
|
27
|
+
if (!scenarioIds || scenarioIds.length === 0) {
|
|
28
|
+
reply.code(400);
|
|
29
|
+
return { error: "At least one Scenario ID is required" };
|
|
30
|
+
}
|
|
31
|
+
if (!connectorId) {
|
|
32
|
+
reply.code(400);
|
|
33
|
+
return { error: "Connector ID is required" };
|
|
34
|
+
}
|
|
35
|
+
try {
|
|
36
|
+
const evalItem = createEval({
|
|
37
|
+
projectId,
|
|
38
|
+
name,
|
|
39
|
+
input,
|
|
40
|
+
scenarioIds,
|
|
41
|
+
connectorId,
|
|
42
|
+
});
|
|
43
|
+
reply.code(201);
|
|
44
|
+
return evalItem;
|
|
45
|
+
}
|
|
46
|
+
catch (error) {
|
|
47
|
+
if (error instanceof Error) {
|
|
48
|
+
if (error.message.includes("not found")) {
|
|
49
|
+
reply.code(404);
|
|
50
|
+
}
|
|
51
|
+
else if (error.message.includes("does not belong")) {
|
|
52
|
+
reply.code(400);
|
|
53
|
+
}
|
|
54
|
+
else {
|
|
55
|
+
reply.code(409);
|
|
56
|
+
}
|
|
57
|
+
return { error: error.message };
|
|
58
|
+
}
|
|
59
|
+
throw error;
|
|
60
|
+
}
|
|
61
|
+
});
|
|
62
|
+
fastify.put("/evals/:id", async (request, reply) => {
|
|
63
|
+
const { name, input, scenarioIds, connectorId, } = request.body;
|
|
64
|
+
try {
|
|
65
|
+
const evalItem = updateEval(request.params.id, {
|
|
66
|
+
name,
|
|
67
|
+
input,
|
|
68
|
+
scenarioIds,
|
|
69
|
+
connectorId,
|
|
70
|
+
});
|
|
71
|
+
if (!evalItem) {
|
|
72
|
+
reply.code(404);
|
|
73
|
+
return { error: "Eval not found" };
|
|
74
|
+
}
|
|
75
|
+
return evalItem;
|
|
76
|
+
}
|
|
77
|
+
catch (error) {
|
|
78
|
+
if (error instanceof Error) {
|
|
79
|
+
if (error.message.includes("not found")) {
|
|
80
|
+
reply.code(404);
|
|
81
|
+
}
|
|
82
|
+
else if (error.message.includes("does not belong")) {
|
|
83
|
+
reply.code(400);
|
|
84
|
+
}
|
|
85
|
+
else {
|
|
86
|
+
reply.code(409);
|
|
87
|
+
}
|
|
88
|
+
return { error: error.message };
|
|
89
|
+
}
|
|
90
|
+
throw error;
|
|
91
|
+
}
|
|
92
|
+
});
|
|
93
|
+
fastify.delete("/evals/:id", async (request, reply) => {
|
|
94
|
+
const deleted = deleteEval(request.params.id);
|
|
95
|
+
if (!deleted) {
|
|
96
|
+
reply.code(404);
|
|
97
|
+
return { error: "Eval not found" };
|
|
98
|
+
}
|
|
99
|
+
reply.code(204);
|
|
100
|
+
return;
|
|
101
|
+
});
|
|
102
|
+
}
|
|
103
|
+
//# sourceMappingURL=evals.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"evals.js","sourceRoot":"","sources":["../../src/routes/evals.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"llm-providers.d.ts","sourceRoot":"","sources":["../../src/routes/llm-providers.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,SAAS,CAAC;AAoC/C,wBAAsB,iBAAiB,CAAC,OAAO,EAAE,eAAe,iBA2I/D"}
|
|
@@ -0,0 +1,110 @@
|
|
|
1
|
+
import { createLLMProvider, deleteLLMProvider, fetchProviderModels, getDefaultModels, getLLMProvider, listLLMProviders, updateLLMProvider, } from "evalstudio";
|
|
2
|
+
export async function llmProvidersRoute(fastify) {
|
|
3
|
+
fastify.get("/llm-providers", async (request) => {
|
|
4
|
+
return listLLMProviders(request.query.projectId);
|
|
5
|
+
});
|
|
6
|
+
fastify.get("/llm-providers/models", async () => {
|
|
7
|
+
return getDefaultModels();
|
|
8
|
+
});
|
|
9
|
+
// Fetch models dynamically from provider's API
|
|
10
|
+
fastify.get("/llm-providers/:id/models", async (request, reply) => {
|
|
11
|
+
try {
|
|
12
|
+
const models = await fetchProviderModels(request.params.id);
|
|
13
|
+
return { models };
|
|
14
|
+
}
|
|
15
|
+
catch (error) {
|
|
16
|
+
if (error instanceof Error) {
|
|
17
|
+
if (error.message.includes("not found")) {
|
|
18
|
+
reply.code(404);
|
|
19
|
+
return { error: error.message };
|
|
20
|
+
}
|
|
21
|
+
reply.code(500);
|
|
22
|
+
return { error: error.message };
|
|
23
|
+
}
|
|
24
|
+
throw error;
|
|
25
|
+
}
|
|
26
|
+
});
|
|
27
|
+
fastify.get("/llm-providers/:id", async (request, reply) => {
|
|
28
|
+
const provider = getLLMProvider(request.params.id);
|
|
29
|
+
if (!provider) {
|
|
30
|
+
reply.code(404);
|
|
31
|
+
return { error: "LLM Provider not found" };
|
|
32
|
+
}
|
|
33
|
+
return provider;
|
|
34
|
+
});
|
|
35
|
+
fastify.post("/llm-providers", async (request, reply) => {
|
|
36
|
+
const { projectId, name, provider, apiKey, config } = request.body;
|
|
37
|
+
if (!projectId) {
|
|
38
|
+
reply.code(400);
|
|
39
|
+
return { error: "Project ID is required" };
|
|
40
|
+
}
|
|
41
|
+
if (!name) {
|
|
42
|
+
reply.code(400);
|
|
43
|
+
return { error: "Name is required" };
|
|
44
|
+
}
|
|
45
|
+
if (!provider) {
|
|
46
|
+
reply.code(400);
|
|
47
|
+
return { error: "Provider is required" };
|
|
48
|
+
}
|
|
49
|
+
if (!apiKey) {
|
|
50
|
+
reply.code(400);
|
|
51
|
+
return { error: "API key is required" };
|
|
52
|
+
}
|
|
53
|
+
try {
|
|
54
|
+
const llmProvider = createLLMProvider({
|
|
55
|
+
projectId,
|
|
56
|
+
name,
|
|
57
|
+
provider,
|
|
58
|
+
apiKey,
|
|
59
|
+
config,
|
|
60
|
+
});
|
|
61
|
+
reply.code(201);
|
|
62
|
+
return llmProvider;
|
|
63
|
+
}
|
|
64
|
+
catch (error) {
|
|
65
|
+
if (error instanceof Error) {
|
|
66
|
+
if (error.message.includes("not found")) {
|
|
67
|
+
reply.code(404);
|
|
68
|
+
}
|
|
69
|
+
else {
|
|
70
|
+
reply.code(409);
|
|
71
|
+
}
|
|
72
|
+
return { error: error.message };
|
|
73
|
+
}
|
|
74
|
+
throw error;
|
|
75
|
+
}
|
|
76
|
+
});
|
|
77
|
+
fastify.put("/llm-providers/:id", async (request, reply) => {
|
|
78
|
+
const { name, provider, apiKey, config } = request.body;
|
|
79
|
+
try {
|
|
80
|
+
const llmProvider = updateLLMProvider(request.params.id, {
|
|
81
|
+
name,
|
|
82
|
+
provider,
|
|
83
|
+
apiKey,
|
|
84
|
+
config,
|
|
85
|
+
});
|
|
86
|
+
if (!llmProvider) {
|
|
87
|
+
reply.code(404);
|
|
88
|
+
return { error: "LLM Provider not found" };
|
|
89
|
+
}
|
|
90
|
+
return llmProvider;
|
|
91
|
+
}
|
|
92
|
+
catch (error) {
|
|
93
|
+
if (error instanceof Error) {
|
|
94
|
+
reply.code(409);
|
|
95
|
+
return { error: error.message };
|
|
96
|
+
}
|
|
97
|
+
throw error;
|
|
98
|
+
}
|
|
99
|
+
});
|
|
100
|
+
fastify.delete("/llm-providers/:id", async (request, reply) => {
|
|
101
|
+
const deleted = deleteLLMProvider(request.params.id);
|
|
102
|
+
if (!deleted) {
|
|
103
|
+
reply.code(404);
|
|
104
|
+
return { error: "LLM Provider not found" };
|
|
105
|
+
}
|
|
106
|
+
reply.code(204);
|
|
107
|
+
return;
|
|
108
|
+
});
|
|
109
|
+
}
|
|
110
|
+
//# sourceMappingURL=llm-providers.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"llm-providers.js","sourceRoot":"","sources":["../../src/routes/llm-providers.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"personas.d.ts","sourceRoot":"","sources":["../../src/routes/personas.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,SAAS,CAAC;AA8B/C,wBAAsB,aAAa,CAAC,OAAO,EAAE,eAAe,iBAsG3D"}
|
|
@@ -0,0 +1,79 @@
|
|
|
1
|
+
import { createPersona, deletePersona, getPersona, listPersonas, updatePersona, } from "evalstudio";
|
|
2
|
+
export async function personasRoute(fastify) {
|
|
3
|
+
fastify.get("/personas", async (request) => {
|
|
4
|
+
return listPersonas(request.query.projectId);
|
|
5
|
+
});
|
|
6
|
+
fastify.get("/personas/:id", async (request, reply) => {
|
|
7
|
+
const persona = getPersona(request.params.id);
|
|
8
|
+
if (!persona) {
|
|
9
|
+
reply.code(404);
|
|
10
|
+
return { error: "Persona not found" };
|
|
11
|
+
}
|
|
12
|
+
return persona;
|
|
13
|
+
});
|
|
14
|
+
fastify.post("/personas", async (request, reply) => {
|
|
15
|
+
const { projectId, name, description, systemPrompt } = request.body;
|
|
16
|
+
if (!projectId) {
|
|
17
|
+
reply.code(400);
|
|
18
|
+
return { error: "Project ID is required" };
|
|
19
|
+
}
|
|
20
|
+
if (!name) {
|
|
21
|
+
reply.code(400);
|
|
22
|
+
return { error: "Name is required" };
|
|
23
|
+
}
|
|
24
|
+
try {
|
|
25
|
+
const persona = createPersona({
|
|
26
|
+
projectId,
|
|
27
|
+
name,
|
|
28
|
+
description,
|
|
29
|
+
systemPrompt,
|
|
30
|
+
});
|
|
31
|
+
reply.code(201);
|
|
32
|
+
return persona;
|
|
33
|
+
}
|
|
34
|
+
catch (error) {
|
|
35
|
+
if (error instanceof Error) {
|
|
36
|
+
if (error.message.includes("not found")) {
|
|
37
|
+
reply.code(404);
|
|
38
|
+
}
|
|
39
|
+
else {
|
|
40
|
+
reply.code(409);
|
|
41
|
+
}
|
|
42
|
+
return { error: error.message };
|
|
43
|
+
}
|
|
44
|
+
throw error;
|
|
45
|
+
}
|
|
46
|
+
});
|
|
47
|
+
fastify.put("/personas/:id", async (request, reply) => {
|
|
48
|
+
const { name, description, systemPrompt } = request.body;
|
|
49
|
+
try {
|
|
50
|
+
const persona = updatePersona(request.params.id, {
|
|
51
|
+
name,
|
|
52
|
+
description,
|
|
53
|
+
systemPrompt,
|
|
54
|
+
});
|
|
55
|
+
if (!persona) {
|
|
56
|
+
reply.code(404);
|
|
57
|
+
return { error: "Persona not found" };
|
|
58
|
+
}
|
|
59
|
+
return persona;
|
|
60
|
+
}
|
|
61
|
+
catch (error) {
|
|
62
|
+
if (error instanceof Error) {
|
|
63
|
+
reply.code(409);
|
|
64
|
+
return { error: error.message };
|
|
65
|
+
}
|
|
66
|
+
throw error;
|
|
67
|
+
}
|
|
68
|
+
});
|
|
69
|
+
fastify.delete("/personas/:id", async (request, reply) => {
|
|
70
|
+
const deleted = deletePersona(request.params.id);
|
|
71
|
+
if (!deleted) {
|
|
72
|
+
reply.code(404);
|
|
73
|
+
return { error: "Persona not found" };
|
|
74
|
+
}
|
|
75
|
+
reply.code(204);
|
|
76
|
+
return;
|
|
77
|
+
});
|
|
78
|
+
}
|
|
79
|
+
//# sourceMappingURL=personas.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"personas.js","sourceRoot":"","sources":["../../src/routes/personas.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"projects.d.ts","sourceRoot":"","sources":["../../src/routes/projects.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,SAAS,CAAC;AA0B/C,wBAAsB,aAAa,CAAC,OAAO,EAAE,eAAe,iBAqF3D"}
|
|
@@ -0,0 +1,65 @@
|
|
|
1
|
+
import { createProject, deleteProject, getProject, listProjects, updateProject, } from "evalstudio";
|
|
2
|
+
export async function projectsRoute(fastify) {
|
|
3
|
+
fastify.get("/projects", async () => {
|
|
4
|
+
return listProjects();
|
|
5
|
+
});
|
|
6
|
+
fastify.get("/projects/:id", async (request, reply) => {
|
|
7
|
+
const project = getProject(request.params.id);
|
|
8
|
+
if (!project) {
|
|
9
|
+
reply.code(404);
|
|
10
|
+
return { error: "Project not found" };
|
|
11
|
+
}
|
|
12
|
+
return project;
|
|
13
|
+
});
|
|
14
|
+
fastify.post("/projects", async (request, reply) => {
|
|
15
|
+
const { name, description, llmSettings } = request.body;
|
|
16
|
+
if (!name) {
|
|
17
|
+
reply.code(400);
|
|
18
|
+
return { error: "Name is required" };
|
|
19
|
+
}
|
|
20
|
+
try {
|
|
21
|
+
const project = createProject({ name, description, llmSettings });
|
|
22
|
+
reply.code(201);
|
|
23
|
+
return project;
|
|
24
|
+
}
|
|
25
|
+
catch (error) {
|
|
26
|
+
if (error instanceof Error) {
|
|
27
|
+
reply.code(409);
|
|
28
|
+
return { error: error.message };
|
|
29
|
+
}
|
|
30
|
+
throw error;
|
|
31
|
+
}
|
|
32
|
+
});
|
|
33
|
+
fastify.put("/projects/:id", async (request, reply) => {
|
|
34
|
+
const { name, description, llmSettings } = request.body;
|
|
35
|
+
try {
|
|
36
|
+
const project = updateProject(request.params.id, {
|
|
37
|
+
name,
|
|
38
|
+
description,
|
|
39
|
+
llmSettings,
|
|
40
|
+
});
|
|
41
|
+
if (!project) {
|
|
42
|
+
reply.code(404);
|
|
43
|
+
return { error: "Project not found" };
|
|
44
|
+
}
|
|
45
|
+
return project;
|
|
46
|
+
}
|
|
47
|
+
catch (error) {
|
|
48
|
+
if (error instanceof Error) {
|
|
49
|
+
reply.code(400);
|
|
50
|
+
return { error: error.message };
|
|
51
|
+
}
|
|
52
|
+
throw error;
|
|
53
|
+
}
|
|
54
|
+
});
|
|
55
|
+
fastify.delete("/projects/:id", async (request, reply) => {
|
|
56
|
+
const deleted = deleteProject(request.params.id);
|
|
57
|
+
if (!deleted) {
|
|
58
|
+
reply.code(404);
|
|
59
|
+
return { error: "Project not found" };
|
|
60
|
+
}
|
|
61
|
+
reply.code(204);
|
|
62
|
+
return;
|
|
63
|
+
});
|
|
64
|
+
}
|
|
65
|
+
//# sourceMappingURL=projects.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"projects.js","sourceRoot":"","sources":["../../src/routes/projects.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"runs.d.ts","sourceRoot":"","sources":["../../src/routes/runs.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,SAAS,CAAC;AAkD/C,wBAAsB,SAAS,CAAC,OAAO,EAAE,eAAe,iBAoKvD"}
|
|
@@ -0,0 +1,127 @@
|
|
|
1
|
+
import { createPlaygroundRun, createRuns, deleteRun, getRun, listRuns, listRunsByEval, listRunsByScenario, listRunsByPersona, retryRun, updateRun, } from "evalstudio";
|
|
2
|
+
export async function runsRoute(fastify) {
|
|
3
|
+
fastify.get("/runs", async (request) => {
|
|
4
|
+
const { evalId, projectId, scenarioId, personaId } = request.query;
|
|
5
|
+
if (evalId) {
|
|
6
|
+
return listRunsByEval(evalId);
|
|
7
|
+
}
|
|
8
|
+
if (scenarioId) {
|
|
9
|
+
return listRunsByScenario(scenarioId);
|
|
10
|
+
}
|
|
11
|
+
if (personaId) {
|
|
12
|
+
return listRunsByPersona(personaId);
|
|
13
|
+
}
|
|
14
|
+
return listRuns(undefined, projectId);
|
|
15
|
+
});
|
|
16
|
+
fastify.get("/runs/:id", async (request, reply) => {
|
|
17
|
+
const run = getRun(request.params.id);
|
|
18
|
+
if (!run) {
|
|
19
|
+
reply.code(404);
|
|
20
|
+
return { error: "Run not found" };
|
|
21
|
+
}
|
|
22
|
+
return run;
|
|
23
|
+
});
|
|
24
|
+
fastify.post("/runs", async (request, reply) => {
|
|
25
|
+
const { evalId } = request.body;
|
|
26
|
+
if (!evalId) {
|
|
27
|
+
reply.code(400);
|
|
28
|
+
return { error: "Eval ID is required" };
|
|
29
|
+
}
|
|
30
|
+
try {
|
|
31
|
+
const runs = createRuns({ evalId });
|
|
32
|
+
reply.code(201);
|
|
33
|
+
return runs;
|
|
34
|
+
}
|
|
35
|
+
catch (error) {
|
|
36
|
+
if (error instanceof Error) {
|
|
37
|
+
if (error.message.includes("not found")) {
|
|
38
|
+
reply.code(404);
|
|
39
|
+
}
|
|
40
|
+
else {
|
|
41
|
+
reply.code(400);
|
|
42
|
+
}
|
|
43
|
+
return { error: error.message };
|
|
44
|
+
}
|
|
45
|
+
throw error;
|
|
46
|
+
}
|
|
47
|
+
});
|
|
48
|
+
// Create a playground run (without eval)
|
|
49
|
+
fastify.post("/runs/playground", async (request, reply) => {
|
|
50
|
+
const { scenarioId, connectorId, personaId } = request.body;
|
|
51
|
+
if (!scenarioId) {
|
|
52
|
+
reply.code(400);
|
|
53
|
+
return { error: "Scenario ID is required" };
|
|
54
|
+
}
|
|
55
|
+
if (!connectorId) {
|
|
56
|
+
reply.code(400);
|
|
57
|
+
return { error: "Connector ID is required" };
|
|
58
|
+
}
|
|
59
|
+
try {
|
|
60
|
+
const run = createPlaygroundRun({
|
|
61
|
+
scenarioId,
|
|
62
|
+
connectorId,
|
|
63
|
+
personaId,
|
|
64
|
+
});
|
|
65
|
+
reply.code(201);
|
|
66
|
+
return run;
|
|
67
|
+
}
|
|
68
|
+
catch (error) {
|
|
69
|
+
if (error instanceof Error) {
|
|
70
|
+
if (error.message.includes("not found")) {
|
|
71
|
+
reply.code(404);
|
|
72
|
+
}
|
|
73
|
+
else {
|
|
74
|
+
reply.code(400);
|
|
75
|
+
}
|
|
76
|
+
return { error: error.message };
|
|
77
|
+
}
|
|
78
|
+
throw error;
|
|
79
|
+
}
|
|
80
|
+
});
|
|
81
|
+
fastify.put("/runs/:id", async (request, reply) => {
|
|
82
|
+
const { status, startedAt, completedAt, messages, output, result, error, metadata, } = request.body;
|
|
83
|
+
const run = updateRun(request.params.id, {
|
|
84
|
+
status,
|
|
85
|
+
startedAt,
|
|
86
|
+
completedAt,
|
|
87
|
+
messages,
|
|
88
|
+
output,
|
|
89
|
+
result,
|
|
90
|
+
error,
|
|
91
|
+
metadata,
|
|
92
|
+
});
|
|
93
|
+
if (!run) {
|
|
94
|
+
reply.code(404);
|
|
95
|
+
return { error: "Run not found" };
|
|
96
|
+
}
|
|
97
|
+
return run;
|
|
98
|
+
});
|
|
99
|
+
// Retry a failed run
|
|
100
|
+
fastify.post("/runs/:id/retry", async (request, reply) => {
|
|
101
|
+
try {
|
|
102
|
+
const run = retryRun(request.params.id);
|
|
103
|
+
if (!run) {
|
|
104
|
+
reply.code(404);
|
|
105
|
+
return { error: "Run not found" };
|
|
106
|
+
}
|
|
107
|
+
return run;
|
|
108
|
+
}
|
|
109
|
+
catch (error) {
|
|
110
|
+
if (error instanceof Error) {
|
|
111
|
+
reply.code(400);
|
|
112
|
+
return { error: error.message };
|
|
113
|
+
}
|
|
114
|
+
throw error;
|
|
115
|
+
}
|
|
116
|
+
});
|
|
117
|
+
fastify.delete("/runs/:id", async (request, reply) => {
|
|
118
|
+
const deleted = deleteRun(request.params.id);
|
|
119
|
+
if (!deleted) {
|
|
120
|
+
reply.code(404);
|
|
121
|
+
return { error: "Run not found" };
|
|
122
|
+
}
|
|
123
|
+
reply.code(204);
|
|
124
|
+
return;
|
|
125
|
+
});
|
|
126
|
+
}
|
|
127
|
+
//# sourceMappingURL=runs.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"runs.js","sourceRoot":"","sources":["../../src/routes/runs.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"scenarios.d.ts","sourceRoot":"","sources":["../../src/routes/scenarios.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,SAAS,CAAC;AAiD/C,wBAAsB,cAAc,CAAC,OAAO,EAAE,eAAe,iBAiJ5D"}
|
|
@@ -0,0 +1,113 @@
|
|
|
1
|
+
import { buildTestAgentMessages, buildTestAgentSystemPrompt, createScenario, deleteScenario, getPersona, getScenario, listScenarios, updateScenario, } from "evalstudio";
|
|
2
|
+
export async function scenariosRoute(fastify) {
|
|
3
|
+
fastify.get("/scenarios", async (request) => {
|
|
4
|
+
return listScenarios(request.query.projectId);
|
|
5
|
+
});
|
|
6
|
+
fastify.get("/scenarios/:id", async (request, reply) => {
|
|
7
|
+
const scenario = getScenario(request.params.id);
|
|
8
|
+
if (!scenario) {
|
|
9
|
+
reply.code(404);
|
|
10
|
+
return { error: "Scenario not found" };
|
|
11
|
+
}
|
|
12
|
+
return scenario;
|
|
13
|
+
});
|
|
14
|
+
// Get the test agent prompt and messages for a scenario with optional persona
|
|
15
|
+
fastify.get("/scenarios/:id/prompt", async (request, reply) => {
|
|
16
|
+
const scenario = getScenario(request.params.id);
|
|
17
|
+
if (!scenario) {
|
|
18
|
+
reply.code(404);
|
|
19
|
+
return { error: "Scenario not found" };
|
|
20
|
+
}
|
|
21
|
+
// Get persona if provided
|
|
22
|
+
let persona = null;
|
|
23
|
+
if (request.query.personaId) {
|
|
24
|
+
persona = getPersona(request.query.personaId);
|
|
25
|
+
if (!persona) {
|
|
26
|
+
reply.code(404);
|
|
27
|
+
return { error: "Persona not found" };
|
|
28
|
+
}
|
|
29
|
+
}
|
|
30
|
+
const promptInput = {
|
|
31
|
+
persona,
|
|
32
|
+
scenario,
|
|
33
|
+
};
|
|
34
|
+
const systemPrompt = buildTestAgentSystemPrompt(promptInput);
|
|
35
|
+
const messages = buildTestAgentMessages(promptInput);
|
|
36
|
+
return { systemPrompt, messages };
|
|
37
|
+
});
|
|
38
|
+
fastify.post("/scenarios", async (request, reply) => {
|
|
39
|
+
const { projectId, name, instructions, messages, maxMessages, successCriteria, failureCriteria, failureCriteriaMode, personaIds } = request.body;
|
|
40
|
+
if (!projectId) {
|
|
41
|
+
reply.code(400);
|
|
42
|
+
return { error: "Project ID is required" };
|
|
43
|
+
}
|
|
44
|
+
if (!name) {
|
|
45
|
+
reply.code(400);
|
|
46
|
+
return { error: "Name is required" };
|
|
47
|
+
}
|
|
48
|
+
try {
|
|
49
|
+
const scenario = createScenario({
|
|
50
|
+
projectId,
|
|
51
|
+
name,
|
|
52
|
+
instructions,
|
|
53
|
+
messages,
|
|
54
|
+
maxMessages,
|
|
55
|
+
successCriteria,
|
|
56
|
+
failureCriteria,
|
|
57
|
+
failureCriteriaMode,
|
|
58
|
+
personaIds,
|
|
59
|
+
});
|
|
60
|
+
reply.code(201);
|
|
61
|
+
return scenario;
|
|
62
|
+
}
|
|
63
|
+
catch (error) {
|
|
64
|
+
if (error instanceof Error) {
|
|
65
|
+
if (error.message.includes("not found")) {
|
|
66
|
+
reply.code(404);
|
|
67
|
+
}
|
|
68
|
+
else {
|
|
69
|
+
reply.code(409);
|
|
70
|
+
}
|
|
71
|
+
return { error: error.message };
|
|
72
|
+
}
|
|
73
|
+
throw error;
|
|
74
|
+
}
|
|
75
|
+
});
|
|
76
|
+
fastify.put("/scenarios/:id", async (request, reply) => {
|
|
77
|
+
const { name, instructions, messages, maxMessages, successCriteria, failureCriteria, failureCriteriaMode, personaIds } = request.body;
|
|
78
|
+
try {
|
|
79
|
+
const scenario = updateScenario(request.params.id, {
|
|
80
|
+
name,
|
|
81
|
+
instructions,
|
|
82
|
+
messages,
|
|
83
|
+
maxMessages,
|
|
84
|
+
successCriteria,
|
|
85
|
+
failureCriteria,
|
|
86
|
+
failureCriteriaMode,
|
|
87
|
+
personaIds,
|
|
88
|
+
});
|
|
89
|
+
if (!scenario) {
|
|
90
|
+
reply.code(404);
|
|
91
|
+
return { error: "Scenario not found" };
|
|
92
|
+
}
|
|
93
|
+
return scenario;
|
|
94
|
+
}
|
|
95
|
+
catch (error) {
|
|
96
|
+
if (error instanceof Error) {
|
|
97
|
+
reply.code(409);
|
|
98
|
+
return { error: error.message };
|
|
99
|
+
}
|
|
100
|
+
throw error;
|
|
101
|
+
}
|
|
102
|
+
});
|
|
103
|
+
fastify.delete("/scenarios/:id", async (request, reply) => {
|
|
104
|
+
const deleted = deleteScenario(request.params.id);
|
|
105
|
+
if (!deleted) {
|
|
106
|
+
reply.code(404);
|
|
107
|
+
return { error: "Scenario not found" };
|
|
108
|
+
}
|
|
109
|
+
reply.code(204);
|
|
110
|
+
return;
|
|
111
|
+
});
|
|
112
|
+
}
|
|
113
|
+
//# sourceMappingURL=scenarios.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"scenarios.js","sourceRoot":"","sources":["../../src/routes/scenarios.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"status.d.ts","sourceRoot":"","sources":["../../src/routes/status.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,SAAS,CAAC;AAG/C,wBAAsB,WAAW,CAAC,OAAO,EAAE,eAAe,iBAIzD"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"status.js","sourceRoot":"","sources":["../../src/routes/status.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,SAAS,EAAE,MAAM,YAAY,CAAC;AAEvC,MAAM,CAAC,KAAK,UAAU,WAAW,CAAC,OAAwB;IACxD,OAAO,CAAC,GAAG,CAAC,SAAS,EAAE,KAAK,IAAI,EAAE;QAChC,OAAO,SAAS,EAAE,CAAC;IACrB,CAAC,CAAC,CAAC;AACL,CAAC"}
|
package/package.json
ADDED
|
@@ -0,0 +1,56 @@
|
|
|
1
|
+
{
|
|
2
|
+
"name": "@evalstudio/api",
|
|
3
|
+
"version": "0.1.0",
|
|
4
|
+
"description": "REST API server for EvalStudio",
|
|
5
|
+
"type": "module",
|
|
6
|
+
"main": "./dist/index.js",
|
|
7
|
+
"types": "./dist/index.d.ts",
|
|
8
|
+
"exports": {
|
|
9
|
+
".": {
|
|
10
|
+
"types": "./dist/index.d.ts",
|
|
11
|
+
"import": "./dist/index.js"
|
|
12
|
+
}
|
|
13
|
+
},
|
|
14
|
+
"publishConfig": {
|
|
15
|
+
"access": "public"
|
|
16
|
+
},
|
|
17
|
+
"keywords": [
|
|
18
|
+
"eval",
|
|
19
|
+
"evaluation",
|
|
20
|
+
"testing",
|
|
21
|
+
"api",
|
|
22
|
+
"fastify"
|
|
23
|
+
],
|
|
24
|
+
"repository": {
|
|
25
|
+
"type": "git",
|
|
26
|
+
"url": "https://github.com/Treatwell-AI/evalstudio.git",
|
|
27
|
+
"directory": "packages/api"
|
|
28
|
+
},
|
|
29
|
+
"files": [
|
|
30
|
+
"dist"
|
|
31
|
+
],
|
|
32
|
+
"dependencies": {
|
|
33
|
+
"@fastify/static": "^9.0.0",
|
|
34
|
+
"fastify": "^5.2.1",
|
|
35
|
+
"evalstudio": "0.1.0"
|
|
36
|
+
},
|
|
37
|
+
"devDependencies": {
|
|
38
|
+
"@types/node": "^22.10.10",
|
|
39
|
+
"typescript": "^5.7.3",
|
|
40
|
+
"vitest": "^3.0.4"
|
|
41
|
+
},
|
|
42
|
+
"engines": {
|
|
43
|
+
"node": ">=20"
|
|
44
|
+
},
|
|
45
|
+
"license": "MIT",
|
|
46
|
+
"scripts": {
|
|
47
|
+
"build": "tsc",
|
|
48
|
+
"dev": "tsc --watch",
|
|
49
|
+
"start": "node dist/cli.js",
|
|
50
|
+
"test": "vitest run",
|
|
51
|
+
"test:watch": "vitest",
|
|
52
|
+
"typecheck": "tsc --noEmit",
|
|
53
|
+
"lint": "eslint src",
|
|
54
|
+
"clean": "rm -rf dist"
|
|
55
|
+
}
|
|
56
|
+
}
|