From ae04eb761810bd4f605316e1e482a2048bdeff4e Mon Sep 17 00:00:00 2001 From: Justin Date: Fri, 20 Dec 2024 11:18:36 -0800 Subject: [PATCH 01/14] added api key to jawn --- bifrost/app/pi/first_page/page.tsx | 2 +- bifrost/lib/clients/jawn.ts | 5 ++++- bifrost/lib/clients/jawnHook.tsx | 4 ++-- 3 files changed, 7 insertions(+), 4 deletions(-) diff --git a/bifrost/app/pi/first_page/page.tsx b/bifrost/app/pi/first_page/page.tsx index b4ba9481c8..eeba331c9d 100644 --- a/bifrost/app/pi/first_page/page.tsx +++ b/bifrost/app/pi/first_page/page.tsx @@ -10,9 +10,9 @@ import { useTestAPIKey } from "./useTestApiKey"; const jetbrainsMono = JetBrains_Mono({ subsets: ["latin"] }); const FirstPageContent = () => { - const jawn = useJawnClient(); const { apiKey, sessionUUID } = useHeliconeLogin(); const { data, isLoading } = useTestAPIKey(apiKey.data ?? ""); + const jawn = useJawnClient(apiKey.data ?? ""); const router = useRouter(); if ((!data && !isLoading) || !apiKey.data) { diff --git a/bifrost/lib/clients/jawn.ts b/bifrost/lib/clients/jawn.ts index c8903e11e5..39114f488d 100644 --- a/bifrost/lib/clients/jawn.ts +++ b/bifrost/lib/clients/jawn.ts @@ -3,7 +3,7 @@ import type { paths as privatePaths } from "./jawnTypes/private"; import createClient from "openapi-fetch"; export type JawnFilterNode = any; -export function getJawnClient(orgId?: string | "none") { +export function getJawnClient(apiKey?: string) { // const jwtToken = getHeliconeCookie().data?.jwtToken; // const headers = // orgId !== "none" @@ -19,6 +19,9 @@ export function getJawnClient(orgId?: string | "none") { return createClient({ baseUrl: process.env.NEXT_PUBLIC_HELICONE_JAWN_SERVICE ?? "http://localhost:8585", + headers: { + Authorization: `Bearer ${apiKey}`, + }, }); } diff --git a/bifrost/lib/clients/jawnHook.tsx b/bifrost/lib/clients/jawnHook.tsx index 5265eb3185..ec6d63be4c 100644 --- a/bifrost/lib/clients/jawnHook.tsx +++ b/bifrost/lib/clients/jawnHook.tsx @@ -1,6 +1,6 @@ import { getJawnClient } from "./jawn"; -export const useJawnClient = () => { +export const useJawnClient = (apiKey?: string) => { // const org = useOrg(); - return getJawnClient(); + return getJawnClient(apiKey); }; From 97afdd59ad879f2d9df2856d83963dcd8ee6de40 Mon Sep 17 00:00:00 2001 From: Kavin Valli Date: Fri, 20 Dec 2024 11:38:10 -0800 Subject: [PATCH 02/14] total requests --- .../src/controllers/public/piController.ts | 50 +++++++++++++++++++ 1 file changed, 50 insertions(+) diff --git a/valhalla/jawn/src/controllers/public/piController.ts b/valhalla/jawn/src/controllers/public/piController.ts index 01df61c9d4..357865d1ee 100644 --- a/valhalla/jawn/src/controllers/public/piController.ts +++ b/valhalla/jawn/src/controllers/public/piController.ts @@ -3,6 +3,10 @@ import { Result, err, ok } from "../../lib/shared/result"; import { JawnAuthenticatedRequest } from "../../types/request"; import { supabaseServer } from "../../lib/db/supabase"; +import { RequestManager } from "../../managers/request/RequestManager"; +import { buildFilterWithAuthClickHouse } from "../../lib/shared/filters/filters"; +import { timeFilterToFilterNode } from "../../lib/shared/filters/filterDefs"; +import { dbQueryClickhouse } from "../../lib/shared/db/dbExecute"; @Route("/v1/pi") @Tags("PI") @@ -40,4 +44,50 @@ export class PiController extends Controller { return ok("success"); } } + + @Post("/total_requests") + public async getTotalRequests( + @Body() + body: { + startTime: string; + endTime: string; + }, + @Request() request: JawnAuthenticatedRequest + ): Promise> { + const reqManager = new RequestManager(request.authParams); + const { filter: filterString, argsAcc } = + await buildFilterWithAuthClickHouse({ + org_id: request.authParams.organizationId, + filter: { + left: timeFilterToFilterNode( + { + start: new Date(body.startTime), + end: new Date(body.endTime), + }, + "request_response_rmt" + ), + right: "all", + operator: "and", + }, + argsAcc: [], + }); + + const query = ` + WITH total_count AS ( + SELECT count(*) as count + FROM request_response_rmt + WHERE ( + (${filterString}) + ) + ) + SELECT coalesce(sum(count), 0) as count + FROM total_count +`; + + const result = await dbQueryClickhouse<{ + count: number; + }>(query, argsAcc); + + return ok(result.data?.[0]?.count || 0); + } } From 85d3a6d0576cddc7e3c926fb8225afc5c2d2b9c3 Mon Sep 17 00:00:00 2001 From: Justin Date: Fri, 20 Dec 2024 11:38:37 -0800 Subject: [PATCH 03/14] start button --- bifrost/app/pi/page.tsx | 10 +++++----- 1 file changed, 5 insertions(+), 5 deletions(-) diff --git a/bifrost/app/pi/page.tsx b/bifrost/app/pi/page.tsx index ac6607ad4a..1bf74da73a 100644 --- a/bifrost/app/pi/page.tsx +++ b/bifrost/app/pi/page.tsx @@ -13,10 +13,10 @@ const jetbrainsMono = JetBrains_Mono({ subsets: ["latin"] }); const PiPageContent = () => { return ( -
-

+
+

Welcome to Helicone!

@@ -31,7 +31,7 @@ const PiPageContent = () => { Start From 4c43237f5cce36874c3af254f6408c3434405ab2 Mon Sep 17 00:00:00 2001 From: Kavin Valli Date: Fri, 20 Dec 2024 12:15:22 -0800 Subject: [PATCH 04/14] changes --- bifrost/app/pi/setup/page.tsx | 2 ++ bifrost/app/pi/total-requests/page.tsx | 36 ++++++++++++++++++++++++ bifrost/public/static/pi/arrow-left.png | Bin 0 -> 1037 bytes 3 files changed, 38 insertions(+) create mode 100644 bifrost/app/pi/total-requests/page.tsx create mode 100644 bifrost/public/static/pi/arrow-left.png diff --git a/bifrost/app/pi/setup/page.tsx b/bifrost/app/pi/setup/page.tsx index d61b6a8afa..07726541df 100644 --- a/bifrost/app/pi/setup/page.tsx +++ b/bifrost/app/pi/setup/page.tsx @@ -14,10 +14,12 @@ const jetbrainsMono = JetBrains_Mono({ subsets: ["latin"] }); const PiPageContent = () => { const router = useRouter(); const searchParams = useSearchParams(); + console.log("searchParams", searchParams.get("invalid_api_key") === "true"); const { apiKey, sessionUUID, countDown } = useHeliconeLogin( searchParams.get("invalid_api_key") === "true" ); const { data, isLoading } = useTestAPIKey(apiKey.data ?? ""); + console.log("setup page", apiKey.data, data, isLoading); if (apiKey.data && data && !isLoading) { router.push("/pi/first_page"); diff --git a/bifrost/app/pi/total-requests/page.tsx b/bifrost/app/pi/total-requests/page.tsx new file mode 100644 index 0000000000..96ae878fa8 --- /dev/null +++ b/bifrost/app/pi/total-requests/page.tsx @@ -0,0 +1,36 @@ +"use client"; + +import { useRouter } from "next/navigation"; +import { useHeliconeLogin } from "../useHeliconeLogin"; + +import { JetBrains_Mono } from "next/font/google"; +import { useTestAPIKey } from "../first_page/useTestApiKey"; +const jetbrainsMono = JetBrains_Mono({ subsets: ["latin"] }); + +const PiGraphLayout = ({ children }: { children: React.ReactNode }) => { + const { apiKey } = useHeliconeLogin(); + const { data, isLoading } = useTestAPIKey(apiKey.data ?? ""); + const router = useRouter(); + + if (!data && !isLoading && !apiKey.data) { + router.push("/pi/setup?invalid_api_key=true"); + return null; + } + + return ( +
+
{children}
+
+ arrow-left +
+
+ ); +}; + +export default PiGraphLayout; diff --git a/bifrost/public/static/pi/arrow-left.png b/bifrost/public/static/pi/arrow-left.png new file mode 100644 index 0000000000000000000000000000000000000000..368fe3ae9c0949777ff8985d59e2e733fd1fc26e GIT binary patch literal 1037 zcmV+o1oHcdP)$4aGAChV)LD|&c%`1hr;SdN=KY<@P)jg-m2 zMz>bD9y2PH3SvYSHg^PVZEcDBvLgU@fJHt;%S6Ey&p<$A*U!MtWHPD6#YJ&{X=#aq zge#p<%Ph07XJ=>Y(g+$_CJH@!2Imkd_K5GWS65ff-Q8Vre{OD$dWGfoiv|FXTFb5O z_uLt^tkHr!Jw5GKe6Ywvv`iEnB{`#`qh_&K6t29swnk@XXC~~)$w@K{qvK}_g#x|2 zypUI{tgO)U^RuwqC3lWx!b7Nu_VxAEQG7sWb?Y#%(K1o6+9>#$B1UMOcW9*=Tof)xw*M%jE|3tH;`gSjYK>i-{3fr#f!tk!^lZPMax71 z0rWQq%?rG^zrRm&sb5HDeSO{c6DzlAn95>xOHH)GB$@g7`T7*T4SH^((vW9xFg=w? z*ZKMRr?IgyVejwnQxs@h=~5;0_Vz|WN6W+^or*hOq-3_Yw|}6;=yG&)L}A5NL0DFX zFuDYFIv(UHDz$g{RVb2nGBs|Y;^{&Gvv@dK0cakQ&`b5QEWk~{?v8?lmWhJvJA}CgQsBj?JnZ-P_qt>-w01*E%?t3m`?^;frwaHF z%-DV2>%HSzCJKE$e8aAnXV1vhY*U_5i##0;;#BqF8z0hFnKY4Osfho+df+DVV2`+# ziO=z5T<2h#RYsPt^1j!3hUfU{DCZypXiL~jmf0gr@&SJVqqIp5dL@fX00000NkvXX Hu0mjf+^gj; literal 0 HcmV?d00001 From b53ceef7581dc3e004e3ea15a6fb4a3c08655096 Mon Sep 17 00:00:00 2001 From: Kavin Valli Date: Fri, 20 Dec 2024 12:22:46 -0800 Subject: [PATCH 05/14] fix api key issue --- bifrost/app/pi/first_page/page.tsx | 2 +- bifrost/app/pi/setup/page.tsx | 4 +--- bifrost/app/pi/total-requests/page.tsx | 2 +- bifrost/app/pi/useHeliconeLogin.ts | 1 + 4 files changed, 4 insertions(+), 5 deletions(-) diff --git a/bifrost/app/pi/first_page/page.tsx b/bifrost/app/pi/first_page/page.tsx index eeba331c9d..878fea65b6 100644 --- a/bifrost/app/pi/first_page/page.tsx +++ b/bifrost/app/pi/first_page/page.tsx @@ -15,7 +15,7 @@ const FirstPageContent = () => { const jawn = useJawnClient(apiKey.data ?? ""); const router = useRouter(); - if ((!data && !isLoading) || !apiKey.data) { + if (!data && !isLoading && !apiKey.data && !apiKey.isLoading) { router.push("/pi/setup?invalid_api_key=true"); return
Loading...
; } diff --git a/bifrost/app/pi/setup/page.tsx b/bifrost/app/pi/setup/page.tsx index 07726541df..ba8312b03f 100644 --- a/bifrost/app/pi/setup/page.tsx +++ b/bifrost/app/pi/setup/page.tsx @@ -14,14 +14,12 @@ const jetbrainsMono = JetBrains_Mono({ subsets: ["latin"] }); const PiPageContent = () => { const router = useRouter(); const searchParams = useSearchParams(); - console.log("searchParams", searchParams.get("invalid_api_key") === "true"); const { apiKey, sessionUUID, countDown } = useHeliconeLogin( searchParams.get("invalid_api_key") === "true" ); const { data, isLoading } = useTestAPIKey(apiKey.data ?? ""); - console.log("setup page", apiKey.data, data, isLoading); - if (apiKey.data && data && !isLoading) { + if (apiKey.data && data && !isLoading && !apiKey.isLoading) { router.push("/pi/first_page"); return
Loading...
; } diff --git a/bifrost/app/pi/total-requests/page.tsx b/bifrost/app/pi/total-requests/page.tsx index 96ae878fa8..79287c0abb 100644 --- a/bifrost/app/pi/total-requests/page.tsx +++ b/bifrost/app/pi/total-requests/page.tsx @@ -12,7 +12,7 @@ const PiGraphLayout = ({ children }: { children: React.ReactNode }) => { const { data, isLoading } = useTestAPIKey(apiKey.data ?? ""); const router = useRouter(); - if (!data && !isLoading && !apiKey.data) { + if (!data && !isLoading && !apiKey.data && !apiKey.isLoading) { router.push("/pi/setup?invalid_api_key=true"); return null; } diff --git a/bifrost/app/pi/useHeliconeLogin.ts b/bifrost/app/pi/useHeliconeLogin.ts index 81cfb7f08c..0358474c6f 100644 --- a/bifrost/app/pi/useHeliconeLogin.ts +++ b/bifrost/app/pi/useHeliconeLogin.ts @@ -78,6 +78,7 @@ export const useHeliconeLogin = (invalid_api_key?: boolean) => { return apiKey.data?.data?.apiKey; }, refetchInterval: 10_000, // 1 second + staleTime: 0, }); return { From 5c0618d052d7ecc6fffcbd9fe0ac478879313f40 Mon Sep 17 00:00:00 2001 From: Justin Date: Fri, 20 Dec 2024 12:25:28 -0800 Subject: [PATCH 06/14] small changes --- bifrost/lib/clients/jawnTypes/private.ts | 422 ++-- bifrost/lib/clients/jawnTypes/public.ts | 464 ++--- docs/swagger.json | 1820 +++++++++-------- .../jawn/src/tsoa-build/private/routes.ts | 32 + .../jawn/src/tsoa-build/private/swagger.json | 48 + valhalla/jawn/src/tsoa-build/public/routes.ts | 606 +++--- .../jawn/src/tsoa-build/public/swagger.json | 1820 +++++++++-------- web/lib/clients/jawnTypes/private.ts | 422 ++-- web/lib/clients/jawnTypes/public.ts | 464 ++--- 9 files changed, 3165 insertions(+), 2933 deletions(-) diff --git a/bifrost/lib/clients/jawnTypes/private.ts b/bifrost/lib/clients/jawnTypes/private.ts index 9edb00ad0b..128dd74a79 100644 --- a/bifrost/lib/clients/jawnTypes/private.ts +++ b/bifrost/lib/clients/jawnTypes/private.ts @@ -301,27 +301,6 @@ export interface paths { "/v1/integration/slack/channels": { get: operations["GetSlackChannels"]; }; - "/v1/experiment/dataset": { - post: operations["AddDataset"]; - }; - "/v1/experiment/dataset/random": { - post: operations["AddRandomDataset"]; - }; - "/v1/experiment/dataset/query": { - post: operations["GetDatasets"]; - }; - "/v1/experiment/dataset/{datasetId}/row/insert": { - post: operations["InsertDatasetRow"]; - }; - "/v1/experiment/dataset/{datasetId}/version/{promptVersionId}/row/new": { - post: operations["CreateDatasetRow"]; - }; - "/v1/experiment/dataset/{datasetId}/inputs/query": { - post: operations["GetDataset"]; - }; - "/v1/experiment/dataset/{datasetId}/mutate": { - post: operations["MutateDataset"]; - }; "/v1/experiment/new-empty": { post: operations["CreateNewEmptyExperiment"]; }; @@ -378,6 +357,27 @@ export interface paths { "/v1/experiment/query": { post: operations["GetExperimentsOld"]; }; + "/v1/experiment/dataset": { + post: operations["AddDataset"]; + }; + "/v1/experiment/dataset/random": { + post: operations["AddRandomDataset"]; + }; + "/v1/experiment/dataset/query": { + post: operations["GetDatasets"]; + }; + "/v1/experiment/dataset/{datasetId}/row/insert": { + post: operations["InsertDatasetRow"]; + }; + "/v1/experiment/dataset/{datasetId}/version/{promptVersionId}/row/new": { + post: operations["CreateDatasetRow"]; + }; + "/v1/experiment/dataset/{datasetId}/inputs/query": { + post: operations["GetDataset"]; + }; + "/v1/experiment/dataset/{datasetId}/mutate": { + post: operations["MutateDataset"]; + }; "/v1/helicone-dataset": { post: operations["AddHeliconeDataset"]; }; @@ -523,6 +523,9 @@ export interface paths { "/v1/pi/session": { post: operations["AddSession"]; }; + "/v1/pi/total_requests": { + post: operations["GetTotalRequests"]; + }; "/v1/settings/query": { get: operations["GetSettings"]; }; @@ -2372,64 +2375,6 @@ Json: JsonObject; error: null; }; "Result_Array__id-string--name-string__.string_": components["schemas"]["ResultSuccess_Array__id-string--name-string___"] | components["schemas"]["ResultError_string_"]; - "ResultSuccess__datasetId-string__": { - data: { - datasetId: string; - }; - /** @enum {number|null} */ - error: null; - }; - "Result__datasetId-string_.string_": components["schemas"]["ResultSuccess__datasetId-string__"] | components["schemas"]["ResultError_string_"]; - DatasetMetadata: { - promptVersionId?: string; - inputRecordsIds?: string[]; - }; - NewDatasetParams: { - datasetName: string; - requestIds: string[]; - /** @enum {string} */ - datasetType: "experiment" | "helicone"; - meta?: components["schemas"]["DatasetMetadata"]; - }; - /** @description From T, pick a set of properties whose keys are in the union K */ - "Pick_FilterLeaf.request-or-prompts_versions_": { - request?: components["schemas"]["Partial_RequestTableToOperators_"]; - prompts_versions?: components["schemas"]["Partial_PromptVersionsToOperators_"]; - }; - "FilterLeafSubset_request-or-prompts_versions_": components["schemas"]["Pick_FilterLeaf.request-or-prompts_versions_"]; - DatasetFilterNode: components["schemas"]["FilterLeafSubset_request-or-prompts_versions_"] | components["schemas"]["DatasetFilterBranch"] | "all"; - DatasetFilterBranch: { - right: components["schemas"]["DatasetFilterNode"]; - /** @enum {string} */ - operator: "or" | "and"; - left: components["schemas"]["DatasetFilterNode"]; - }; - RandomDatasetParams: { - datasetName: string; - filter: components["schemas"]["DatasetFilterNode"]; - /** Format: double */ - offset?: number; - /** Format: double */ - limit?: number; - }; - DatasetResult: { - id: string; - name: string; - created_at: string; - meta?: components["schemas"]["DatasetMetadata"]; - }; - "ResultSuccess_DatasetResult-Array_": { - data: components["schemas"]["DatasetResult"][]; - /** @enum {number|null} */ - error: null; - }; - "Result_DatasetResult-Array.string_": components["schemas"]["ResultSuccess_DatasetResult-Array_"] | components["schemas"]["ResultError_string_"]; - "ResultSuccess___-Array_": { - data: Record[]; - /** @enum {number|null} */ - error: null; - }; - "Result___-Array.string_": components["schemas"]["ResultSuccess___-Array_"] | components["schemas"]["ResultError_string_"]; "ResultSuccess__tableId-string--experimentId-string__": { data: { experimentId: string; @@ -2659,6 +2604,64 @@ Json: JsonObject; /** @enum {boolean} */ score?: true; }; + "ResultSuccess__datasetId-string__": { + data: { + datasetId: string; + }; + /** @enum {number|null} */ + error: null; + }; + "Result__datasetId-string_.string_": components["schemas"]["ResultSuccess__datasetId-string__"] | components["schemas"]["ResultError_string_"]; + DatasetMetadata: { + promptVersionId?: string; + inputRecordsIds?: string[]; + }; + NewDatasetParams: { + datasetName: string; + requestIds: string[]; + /** @enum {string} */ + datasetType: "experiment" | "helicone"; + meta?: components["schemas"]["DatasetMetadata"]; + }; + /** @description From T, pick a set of properties whose keys are in the union K */ + "Pick_FilterLeaf.request-or-prompts_versions_": { + request?: components["schemas"]["Partial_RequestTableToOperators_"]; + prompts_versions?: components["schemas"]["Partial_PromptVersionsToOperators_"]; + }; + "FilterLeafSubset_request-or-prompts_versions_": components["schemas"]["Pick_FilterLeaf.request-or-prompts_versions_"]; + DatasetFilterNode: components["schemas"]["FilterLeafSubset_request-or-prompts_versions_"] | components["schemas"]["DatasetFilterBranch"] | "all"; + DatasetFilterBranch: { + right: components["schemas"]["DatasetFilterNode"]; + /** @enum {string} */ + operator: "or" | "and"; + left: components["schemas"]["DatasetFilterNode"]; + }; + RandomDatasetParams: { + datasetName: string; + filter: components["schemas"]["DatasetFilterNode"]; + /** Format: double */ + offset?: number; + /** Format: double */ + limit?: number; + }; + DatasetResult: { + id: string; + name: string; + created_at: string; + meta?: components["schemas"]["DatasetMetadata"]; + }; + "ResultSuccess_DatasetResult-Array_": { + data: components["schemas"]["DatasetResult"][]; + /** @enum {number|null} */ + error: null; + }; + "Result_DatasetResult-Array.string_": components["schemas"]["ResultSuccess_DatasetResult-Array_"] | components["schemas"]["ResultError_string_"]; + "ResultSuccess___-Array_": { + data: Record[]; + /** @enum {number|null} */ + error: null; + }; + "Result___-Array.string_": components["schemas"]["ResultSuccess___-Array_"] | components["schemas"]["ResultError_string_"]; HeliconeDatasetMetadata: { promptVersionId?: string; inputRecordsIds?: string[]; @@ -5023,134 +5026,6 @@ export interface operations { }; }; }; - AddDataset: { - requestBody: { - content: { - "application/json": components["schemas"]["NewDatasetParams"]; - }; - }; - responses: { - /** @description Ok */ - 200: { - content: { - "application/json": components["schemas"]["Result__datasetId-string_.string_"]; - }; - }; - }; - }; - AddRandomDataset: { - requestBody: { - content: { - "application/json": components["schemas"]["RandomDatasetParams"]; - }; - }; - responses: { - /** @description Ok */ - 200: { - content: { - "application/json": components["schemas"]["Result__datasetId-string_.string_"]; - }; - }; - }; - }; - GetDatasets: { - requestBody: { - content: { - "application/json": { - promptVersionId?: string; - }; - }; - }; - responses: { - /** @description Ok */ - 200: { - content: { - "application/json": components["schemas"]["Result_DatasetResult-Array.string_"]; - }; - }; - }; - }; - InsertDatasetRow: { - parameters: { - path: { - datasetId: string; - }; - }; - requestBody: { - content: { - "application/json": { - originalColumnId?: string; - inputs: components["schemas"]["Record_string.string_"]; - inputRecordId: string; - }; - }; - }; - responses: { - /** @description Ok */ - 200: { - content: { - "application/json": components["schemas"]["Result_string.string_"]; - }; - }; - }; - }; - CreateDatasetRow: { - parameters: { - path: { - datasetId: string; - promptVersionId: string; - }; - }; - requestBody: { - content: { - "application/json": { - sourceRequest?: string; - inputs: components["schemas"]["Record_string.string_"]; - }; - }; - }; - responses: { - /** @description Ok */ - 200: { - content: { - "application/json": components["schemas"]["Result_string.string_"]; - }; - }; - }; - }; - GetDataset: { - parameters: { - path: { - datasetId: string; - }; - }; - responses: { - /** @description Ok */ - 200: { - content: { - "application/json": components["schemas"]["Result_PromptInputRecord-Array.string_"]; - }; - }; - }; - }; - MutateDataset: { - requestBody: { - content: { - "application/json": { - removeRequests: string[]; - addRequests: string[]; - }; - }; - }; - responses: { - /** @description Ok */ - 200: { - content: { - "application/json": components["schemas"]["Result___-Array.string_"]; - }; - }; - }; - }; CreateNewEmptyExperiment: { requestBody: { content: { @@ -5514,6 +5389,134 @@ export interface operations { }; }; }; + AddDataset: { + requestBody: { + content: { + "application/json": components["schemas"]["NewDatasetParams"]; + }; + }; + responses: { + /** @description Ok */ + 200: { + content: { + "application/json": components["schemas"]["Result__datasetId-string_.string_"]; + }; + }; + }; + }; + AddRandomDataset: { + requestBody: { + content: { + "application/json": components["schemas"]["RandomDatasetParams"]; + }; + }; + responses: { + /** @description Ok */ + 200: { + content: { + "application/json": components["schemas"]["Result__datasetId-string_.string_"]; + }; + }; + }; + }; + GetDatasets: { + requestBody: { + content: { + "application/json": { + promptVersionId?: string; + }; + }; + }; + responses: { + /** @description Ok */ + 200: { + content: { + "application/json": components["schemas"]["Result_DatasetResult-Array.string_"]; + }; + }; + }; + }; + InsertDatasetRow: { + parameters: { + path: { + datasetId: string; + }; + }; + requestBody: { + content: { + "application/json": { + originalColumnId?: string; + inputs: components["schemas"]["Record_string.string_"]; + inputRecordId: string; + }; + }; + }; + responses: { + /** @description Ok */ + 200: { + content: { + "application/json": components["schemas"]["Result_string.string_"]; + }; + }; + }; + }; + CreateDatasetRow: { + parameters: { + path: { + datasetId: string; + promptVersionId: string; + }; + }; + requestBody: { + content: { + "application/json": { + sourceRequest?: string; + inputs: components["schemas"]["Record_string.string_"]; + }; + }; + }; + responses: { + /** @description Ok */ + 200: { + content: { + "application/json": components["schemas"]["Result_string.string_"]; + }; + }; + }; + }; + GetDataset: { + parameters: { + path: { + datasetId: string; + }; + }; + responses: { + /** @description Ok */ + 200: { + content: { + "application/json": components["schemas"]["Result_PromptInputRecord-Array.string_"]; + }; + }; + }; + }; + MutateDataset: { + requestBody: { + content: { + "application/json": { + removeRequests: string[]; + addRequests: string[]; + }; + }; + }; + responses: { + /** @description Ok */ + 200: { + content: { + "application/json": components["schemas"]["Result___-Array.string_"]; + }; + }; + }; + }; AddHeliconeDataset: { requestBody: { content: { @@ -5663,7 +5666,10 @@ export interface operations { GetTotalRequests: { requestBody: { content: { - "application/json": components["schemas"]["DataIsBeautifulRequestBody"]; + "application/json": { + endTime: string; + startTime: string; + }; }; }; responses: { diff --git a/bifrost/lib/clients/jawnTypes/public.ts b/bifrost/lib/clients/jawnTypes/public.ts index 5b20d59eef..6a0255c326 100644 --- a/bifrost/lib/clients/jawnTypes/public.ts +++ b/bifrost/lib/clients/jawnTypes/public.ts @@ -256,6 +256,27 @@ export interface paths { "/v1/integration/slack/channels": { get: operations["GetSlackChannels"]; }; + "/v1/experiment/dataset": { + post: operations["AddDataset"]; + }; + "/v1/experiment/dataset/random": { + post: operations["AddRandomDataset"]; + }; + "/v1/experiment/dataset/query": { + post: operations["GetDatasets"]; + }; + "/v1/experiment/dataset/{datasetId}/row/insert": { + post: operations["InsertDatasetRow"]; + }; + "/v1/experiment/dataset/{datasetId}/version/{promptVersionId}/row/new": { + post: operations["CreateDatasetRow"]; + }; + "/v1/experiment/dataset/{datasetId}/inputs/query": { + post: operations["GetDataset"]; + }; + "/v1/experiment/dataset/{datasetId}/mutate": { + post: operations["MutateDataset"]; + }; "/v1/experiment/new-empty": { post: operations["CreateNewEmptyExperiment"]; }; @@ -312,27 +333,6 @@ export interface paths { "/v1/experiment/query": { post: operations["GetExperimentsOld"]; }; - "/v1/experiment/dataset": { - post: operations["AddDataset"]; - }; - "/v1/experiment/dataset/random": { - post: operations["AddRandomDataset"]; - }; - "/v1/experiment/dataset/query": { - post: operations["GetDatasets"]; - }; - "/v1/experiment/dataset/{datasetId}/row/insert": { - post: operations["InsertDatasetRow"]; - }; - "/v1/experiment/dataset/{datasetId}/version/{promptVersionId}/row/new": { - post: operations["CreateDatasetRow"]; - }; - "/v1/experiment/dataset/{datasetId}/inputs/query": { - post: operations["GetDataset"]; - }; - "/v1/experiment/dataset/{datasetId}/mutate": { - post: operations["MutateDataset"]; - }; "/v1/helicone-dataset": { post: operations["AddHeliconeDataset"]; }; @@ -478,6 +478,9 @@ export interface paths { "/v1/pi/session": { post: operations["AddSession"]; }; + "/v1/pi/total_requests": { + post: operations["GetTotalRequests"]; + }; "/v1/settings/query": { get: operations["GetSettings"]; }; @@ -1943,6 +1946,85 @@ Json: JsonObject; error: null; }; "Result_Array__id-string--name-string__.string_": components["schemas"]["ResultSuccess_Array__id-string--name-string___"] | components["schemas"]["ResultError_string_"]; + "ResultSuccess__datasetId-string__": { + data: { + datasetId: string; + }; + /** @enum {number|null} */ + error: null; + }; + "Result__datasetId-string_.string_": components["schemas"]["ResultSuccess__datasetId-string__"] | components["schemas"]["ResultError_string_"]; + DatasetMetadata: { + promptVersionId?: string; + inputRecordsIds?: string[]; + }; + NewDatasetParams: { + datasetName: string; + requestIds: string[]; + /** @enum {string} */ + datasetType: "experiment" | "helicone"; + meta?: components["schemas"]["DatasetMetadata"]; + }; + /** @description Make all properties in T optional */ + Partial_TimestampOperators_: { + gte?: string; + lte?: string; + lt?: string; + gt?: string; + }; + /** @description Make all properties in T optional */ + Partial_RequestTableToOperators_: { + prompt?: components["schemas"]["Partial_TextOperators_"]; + created_at?: components["schemas"]["Partial_TimestampOperators_"]; + user_id?: components["schemas"]["Partial_TextOperators_"]; + auth_hash?: components["schemas"]["Partial_TextOperators_"]; + org_id?: components["schemas"]["Partial_TextOperators_"]; + id?: components["schemas"]["Partial_TextOperators_"]; + node_id?: components["schemas"]["Partial_TextOperators_"]; + model?: components["schemas"]["Partial_TextOperators_"]; + modelOverride?: components["schemas"]["Partial_TextOperators_"]; + path?: components["schemas"]["Partial_TextOperators_"]; + prompt_id?: components["schemas"]["Partial_TextOperators_"]; + }; + /** @description From T, pick a set of properties whose keys are in the union K */ + "Pick_FilterLeaf.request-or-prompts_versions_": { + request?: components["schemas"]["Partial_RequestTableToOperators_"]; + prompts_versions?: components["schemas"]["Partial_PromptVersionsToOperators_"]; + }; + "FilterLeafSubset_request-or-prompts_versions_": components["schemas"]["Pick_FilterLeaf.request-or-prompts_versions_"]; + DatasetFilterNode: components["schemas"]["FilterLeafSubset_request-or-prompts_versions_"] | components["schemas"]["DatasetFilterBranch"] | "all"; + DatasetFilterBranch: { + right: components["schemas"]["DatasetFilterNode"]; + /** @enum {string} */ + operator: "or" | "and"; + left: components["schemas"]["DatasetFilterNode"]; + }; + RandomDatasetParams: { + datasetName: string; + filter: components["schemas"]["DatasetFilterNode"]; + /** Format: double */ + offset?: number; + /** Format: double */ + limit?: number; + }; + DatasetResult: { + id: string; + name: string; + created_at: string; + meta?: components["schemas"]["DatasetMetadata"]; + }; + "ResultSuccess_DatasetResult-Array_": { + data: components["schemas"]["DatasetResult"][]; + /** @enum {number|null} */ + error: null; + }; + "Result_DatasetResult-Array.string_": components["schemas"]["ResultSuccess_DatasetResult-Array_"] | components["schemas"]["ResultError_string_"]; + "ResultSuccess___-Array_": { + data: Record[]; + /** @enum {number|null} */ + error: null; + }; + "Result___-Array.string_": components["schemas"]["ResultSuccess___-Array_"] | components["schemas"]["ResultError_string_"]; "ResultSuccess__tableId-string--experimentId-string__": { data: { experimentId: string; @@ -2172,85 +2254,6 @@ Json: JsonObject; /** @enum {boolean} */ score?: true; }; - "ResultSuccess__datasetId-string__": { - data: { - datasetId: string; - }; - /** @enum {number|null} */ - error: null; - }; - "Result__datasetId-string_.string_": components["schemas"]["ResultSuccess__datasetId-string__"] | components["schemas"]["ResultError_string_"]; - DatasetMetadata: { - promptVersionId?: string; - inputRecordsIds?: string[]; - }; - NewDatasetParams: { - datasetName: string; - requestIds: string[]; - /** @enum {string} */ - datasetType: "experiment" | "helicone"; - meta?: components["schemas"]["DatasetMetadata"]; - }; - /** @description Make all properties in T optional */ - Partial_TimestampOperators_: { - gte?: string; - lte?: string; - lt?: string; - gt?: string; - }; - /** @description Make all properties in T optional */ - Partial_RequestTableToOperators_: { - prompt?: components["schemas"]["Partial_TextOperators_"]; - created_at?: components["schemas"]["Partial_TimestampOperators_"]; - user_id?: components["schemas"]["Partial_TextOperators_"]; - auth_hash?: components["schemas"]["Partial_TextOperators_"]; - org_id?: components["schemas"]["Partial_TextOperators_"]; - id?: components["schemas"]["Partial_TextOperators_"]; - node_id?: components["schemas"]["Partial_TextOperators_"]; - model?: components["schemas"]["Partial_TextOperators_"]; - modelOverride?: components["schemas"]["Partial_TextOperators_"]; - path?: components["schemas"]["Partial_TextOperators_"]; - prompt_id?: components["schemas"]["Partial_TextOperators_"]; - }; - /** @description From T, pick a set of properties whose keys are in the union K */ - "Pick_FilterLeaf.request-or-prompts_versions_": { - request?: components["schemas"]["Partial_RequestTableToOperators_"]; - prompts_versions?: components["schemas"]["Partial_PromptVersionsToOperators_"]; - }; - "FilterLeafSubset_request-or-prompts_versions_": components["schemas"]["Pick_FilterLeaf.request-or-prompts_versions_"]; - DatasetFilterNode: components["schemas"]["FilterLeafSubset_request-or-prompts_versions_"] | components["schemas"]["DatasetFilterBranch"] | "all"; - DatasetFilterBranch: { - right: components["schemas"]["DatasetFilterNode"]; - /** @enum {string} */ - operator: "or" | "and"; - left: components["schemas"]["DatasetFilterNode"]; - }; - RandomDatasetParams: { - datasetName: string; - filter: components["schemas"]["DatasetFilterNode"]; - /** Format: double */ - offset?: number; - /** Format: double */ - limit?: number; - }; - DatasetResult: { - id: string; - name: string; - created_at: string; - meta?: components["schemas"]["DatasetMetadata"]; - }; - "ResultSuccess_DatasetResult-Array_": { - data: components["schemas"]["DatasetResult"][]; - /** @enum {number|null} */ - error: null; - }; - "Result_DatasetResult-Array.string_": components["schemas"]["ResultSuccess_DatasetResult-Array_"] | components["schemas"]["ResultError_string_"]; - "ResultSuccess___-Array_": { - data: Record[]; - /** @enum {number|null} */ - error: null; - }; - "Result___-Array.string_": components["schemas"]["ResultSuccess___-Array_"] | components["schemas"]["ResultError_string_"]; HeliconeDatasetMetadata: { promptVersionId?: string; inputRecordsIds?: string[]; @@ -4780,6 +4783,134 @@ export interface operations { }; }; }; + AddDataset: { + requestBody: { + content: { + "application/json": components["schemas"]["NewDatasetParams"]; + }; + }; + responses: { + /** @description Ok */ + 200: { + content: { + "application/json": components["schemas"]["Result__datasetId-string_.string_"]; + }; + }; + }; + }; + AddRandomDataset: { + requestBody: { + content: { + "application/json": components["schemas"]["RandomDatasetParams"]; + }; + }; + responses: { + /** @description Ok */ + 200: { + content: { + "application/json": components["schemas"]["Result__datasetId-string_.string_"]; + }; + }; + }; + }; + GetDatasets: { + requestBody: { + content: { + "application/json": { + promptVersionId?: string; + }; + }; + }; + responses: { + /** @description Ok */ + 200: { + content: { + "application/json": components["schemas"]["Result_DatasetResult-Array.string_"]; + }; + }; + }; + }; + InsertDatasetRow: { + parameters: { + path: { + datasetId: string; + }; + }; + requestBody: { + content: { + "application/json": { + originalColumnId?: string; + inputs: components["schemas"]["Record_string.string_"]; + inputRecordId: string; + }; + }; + }; + responses: { + /** @description Ok */ + 200: { + content: { + "application/json": components["schemas"]["Result_string.string_"]; + }; + }; + }; + }; + CreateDatasetRow: { + parameters: { + path: { + datasetId: string; + promptVersionId: string; + }; + }; + requestBody: { + content: { + "application/json": { + sourceRequest?: string; + inputs: components["schemas"]["Record_string.string_"]; + }; + }; + }; + responses: { + /** @description Ok */ + 200: { + content: { + "application/json": components["schemas"]["Result_string.string_"]; + }; + }; + }; + }; + GetDataset: { + parameters: { + path: { + datasetId: string; + }; + }; + responses: { + /** @description Ok */ + 200: { + content: { + "application/json": components["schemas"]["Result_PromptInputRecord-Array.string_"]; + }; + }; + }; + }; + MutateDataset: { + requestBody: { + content: { + "application/json": { + removeRequests: string[]; + addRequests: string[]; + }; + }; + }; + responses: { + /** @description Ok */ + 200: { + content: { + "application/json": components["schemas"]["Result___-Array.string_"]; + }; + }; + }; + }; CreateNewEmptyExperiment: { requestBody: { content: { @@ -5143,134 +5274,6 @@ export interface operations { }; }; }; - AddDataset: { - requestBody: { - content: { - "application/json": components["schemas"]["NewDatasetParams"]; - }; - }; - responses: { - /** @description Ok */ - 200: { - content: { - "application/json": components["schemas"]["Result__datasetId-string_.string_"]; - }; - }; - }; - }; - AddRandomDataset: { - requestBody: { - content: { - "application/json": components["schemas"]["RandomDatasetParams"]; - }; - }; - responses: { - /** @description Ok */ - 200: { - content: { - "application/json": components["schemas"]["Result__datasetId-string_.string_"]; - }; - }; - }; - }; - GetDatasets: { - requestBody: { - content: { - "application/json": { - promptVersionId?: string; - }; - }; - }; - responses: { - /** @description Ok */ - 200: { - content: { - "application/json": components["schemas"]["Result_DatasetResult-Array.string_"]; - }; - }; - }; - }; - InsertDatasetRow: { - parameters: { - path: { - datasetId: string; - }; - }; - requestBody: { - content: { - "application/json": { - originalColumnId?: string; - inputs: components["schemas"]["Record_string.string_"]; - inputRecordId: string; - }; - }; - }; - responses: { - /** @description Ok */ - 200: { - content: { - "application/json": components["schemas"]["Result_string.string_"]; - }; - }; - }; - }; - CreateDatasetRow: { - parameters: { - path: { - datasetId: string; - promptVersionId: string; - }; - }; - requestBody: { - content: { - "application/json": { - sourceRequest?: string; - inputs: components["schemas"]["Record_string.string_"]; - }; - }; - }; - responses: { - /** @description Ok */ - 200: { - content: { - "application/json": components["schemas"]["Result_string.string_"]; - }; - }; - }; - }; - GetDataset: { - parameters: { - path: { - datasetId: string; - }; - }; - responses: { - /** @description Ok */ - 200: { - content: { - "application/json": components["schemas"]["Result_PromptInputRecord-Array.string_"]; - }; - }; - }; - }; - MutateDataset: { - requestBody: { - content: { - "application/json": { - removeRequests: string[]; - addRequests: string[]; - }; - }; - }; - responses: { - /** @description Ok */ - 200: { - content: { - "application/json": components["schemas"]["Result___-Array.string_"]; - }; - }; - }; - }; AddHeliconeDataset: { requestBody: { content: { @@ -5420,7 +5423,10 @@ export interface operations { GetTotalRequests: { requestBody: { content: { - "application/json": components["schemas"]["DataIsBeautifulRequestBody"]; + "application/json": { + endTime: string; + startTime: string; + }; }; }; responses: { diff --git a/docs/swagger.json b/docs/swagger.json index bab2b06d5e..4078a90004 100644 --- a/docs/swagger.json +++ b/docs/swagger.json @@ -4567,20 +4567,16 @@ } ] }, - "ResultSuccess__tableId-string--experimentId-string__": { + "ResultSuccess__datasetId-string__": { "properties": { "data": { "properties": { - "experimentId": { - "type": "string" - }, - "tableId": { + "datasetId": { "type": "string" } }, "required": [ - "experimentId", - "tableId" + "datasetId" ], "type": "object" }, @@ -4599,109 +4595,197 @@ "type": "object", "additionalProperties": false }, - "Result__tableId-string--experimentId-string_.string_": { + "Result__datasetId-string_.string_": { "anyOf": [ { - "$ref": "#/components/schemas/ResultSuccess__tableId-string--experimentId-string__" + "$ref": "#/components/schemas/ResultSuccess__datasetId-string__" }, { "$ref": "#/components/schemas/ResultError_string_" } ] }, - "CreateExperimentTableParams": { + "DatasetMetadata": { "properties": { - "datasetId": { - "type": "string" - }, - "experimentMetadata": { - "$ref": "#/components/schemas/Record_string.any_" - }, "promptVersionId": { "type": "string" }, - "newHeliconeTemplate": { + "inputRecordsIds": { + "items": { + "type": "string" + }, + "type": "array" + } + }, + "type": "object", + "additionalProperties": false + }, + "NewDatasetParams": { + "properties": { + "datasetName": { "type": "string" }, - "isMajorVersion": { - "type": "boolean" + "requestIds": { + "items": { + "type": "string" + }, + "type": "array" }, - "promptSubversionMetadata": { - "$ref": "#/components/schemas/Record_string.any_" + "datasetType": { + "type": "string", + "enum": [ + "experiment", + "helicone" + ] }, - "experimentTableMetadata": { - "$ref": "#/components/schemas/Record_string.any_" + "meta": { + "$ref": "#/components/schemas/DatasetMetadata" } }, "required": [ - "datasetId", - "experimentMetadata", - "promptVersionId", - "newHeliconeTemplate", - "isMajorVersion", - "promptSubversionMetadata" + "datasetName", + "requestIds", + "datasetType" ], "type": "object", "additionalProperties": false }, - "ExperimentTableColumn": { + "Partial_TimestampOperators_": { "properties": { - "id": { + "gte": { "type": "string" }, - "columnName": { + "lte": { "type": "string" }, - "columnType": { + "lt": { "type": "string" }, - "hypothesisId": { + "gt": { "type": "string" + } + }, + "type": "object", + "description": "Make all properties in T optional" + }, + "Partial_RequestTableToOperators_": { + "properties": { + "prompt": { + "$ref": "#/components/schemas/Partial_TextOperators_" }, - "cells": { - "items": { - "properties": { - "metadata": { - "$ref": "#/components/schemas/Record_string.any_" - }, - "value": { - "type": "string", - "nullable": true - }, - "requestId": { - "type": "string" - }, - "rowIndex": { - "type": "number", - "format": "double" - }, - "id": { - "type": "string" - } - }, - "required": [ - "value", - "rowIndex", - "id" - ], - "type": "object" - }, - "type": "array" + "created_at": { + "$ref": "#/components/schemas/Partial_TimestampOperators_" }, - "metadata": { - "$ref": "#/components/schemas/Record_string.any_" + "user_id": { + "$ref": "#/components/schemas/Partial_TextOperators_" + }, + "auth_hash": { + "$ref": "#/components/schemas/Partial_TextOperators_" + }, + "org_id": { + "$ref": "#/components/schemas/Partial_TextOperators_" + }, + "id": { + "$ref": "#/components/schemas/Partial_TextOperators_" + }, + "node_id": { + "$ref": "#/components/schemas/Partial_TextOperators_" + }, + "model": { + "$ref": "#/components/schemas/Partial_TextOperators_" + }, + "modelOverride": { + "$ref": "#/components/schemas/Partial_TextOperators_" + }, + "path": { + "$ref": "#/components/schemas/Partial_TextOperators_" + }, + "prompt_id": { + "$ref": "#/components/schemas/Partial_TextOperators_" + } + }, + "type": "object", + "description": "Make all properties in T optional" + }, + "Pick_FilterLeaf.request-or-prompts_versions_": { + "properties": { + "request": { + "$ref": "#/components/schemas/Partial_RequestTableToOperators_" + }, + "prompts_versions": { + "$ref": "#/components/schemas/Partial_PromptVersionsToOperators_" + } + }, + "type": "object", + "description": "From T, pick a set of properties whose keys are in the union K" + }, + "FilterLeafSubset_request-or-prompts_versions_": { + "$ref": "#/components/schemas/Pick_FilterLeaf.request-or-prompts_versions_" + }, + "DatasetFilterNode": { + "anyOf": [ + { + "$ref": "#/components/schemas/FilterLeafSubset_request-or-prompts_versions_" + }, + { + "$ref": "#/components/schemas/DatasetFilterBranch" + }, + { + "type": "string", + "enum": [ + "all" + ] + } + ] + }, + "DatasetFilterBranch": { + "properties": { + "right": { + "$ref": "#/components/schemas/DatasetFilterNode" + }, + "operator": { + "type": "string", + "enum": [ + "or", + "and" + ] + }, + "left": { + "$ref": "#/components/schemas/DatasetFilterNode" } }, "required": [ - "id", - "columnName", - "columnType", - "cells" + "right", + "operator", + "left" + ], + "type": "object" + }, + "RandomDatasetParams": { + "properties": { + "datasetName": { + "type": "string" + }, + "filter": { + "$ref": "#/components/schemas/DatasetFilterNode" + }, + "offset": { + "type": "number", + "format": "double" + }, + "limit": { + "type": "number", + "format": "double" + } + }, + "required": [ + "datasetName", + "filter" ], "type": "object", "additionalProperties": false }, - "ExperimentTable": { + "DatasetResult": { "properties": { "id": { "type": "string" @@ -4709,32 +4793,28 @@ "name": { "type": "string" }, - "experimentId": { + "created_at": { "type": "string" }, - "columns": { - "items": { - "$ref": "#/components/schemas/ExperimentTableColumn" - }, - "type": "array" - }, - "metadata": { - "$ref": "#/components/schemas/Record_string.any_" + "meta": { + "$ref": "#/components/schemas/DatasetMetadata" } }, "required": [ "id", "name", - "experimentId", - "columns" + "created_at" ], "type": "object", "additionalProperties": false }, - "ResultSuccess_ExperimentTable_": { + "ResultSuccess_DatasetResult-Array_": { "properties": { "data": { - "$ref": "#/components/schemas/ExperimentTable" + "items": { + "$ref": "#/components/schemas/DatasetResult" + }, + "type": "array" }, "error": { "type": "number", @@ -4751,22 +4831,250 @@ "type": "object", "additionalProperties": false }, - "Result_ExperimentTable.string_": { + "Result_DatasetResult-Array.string_": { "anyOf": [ { - "$ref": "#/components/schemas/ResultSuccess_ExperimentTable_" + "$ref": "#/components/schemas/ResultSuccess_DatasetResult-Array_" }, { "$ref": "#/components/schemas/ResultError_string_" } ] }, - "ExperimentTableSimplified": { + "ResultSuccess___-Array_": { "properties": { - "id": { - "type": "string" - }, - "name": { + "data": { + "items": { + "properties": {}, + "type": "object" + }, + "type": "array" + }, + "error": { + "type": "number", + "enum": [ + null + ], + "nullable": true + } + }, + "required": [ + "data", + "error" + ], + "type": "object", + "additionalProperties": false + }, + "Result___-Array.string_": { + "anyOf": [ + { + "$ref": "#/components/schemas/ResultSuccess___-Array_" + }, + { + "$ref": "#/components/schemas/ResultError_string_" + } + ] + }, + "ResultSuccess__tableId-string--experimentId-string__": { + "properties": { + "data": { + "properties": { + "experimentId": { + "type": "string" + }, + "tableId": { + "type": "string" + } + }, + "required": [ + "experimentId", + "tableId" + ], + "type": "object" + }, + "error": { + "type": "number", + "enum": [ + null + ], + "nullable": true + } + }, + "required": [ + "data", + "error" + ], + "type": "object", + "additionalProperties": false + }, + "Result__tableId-string--experimentId-string_.string_": { + "anyOf": [ + { + "$ref": "#/components/schemas/ResultSuccess__tableId-string--experimentId-string__" + }, + { + "$ref": "#/components/schemas/ResultError_string_" + } + ] + }, + "CreateExperimentTableParams": { + "properties": { + "datasetId": { + "type": "string" + }, + "experimentMetadata": { + "$ref": "#/components/schemas/Record_string.any_" + }, + "promptVersionId": { + "type": "string" + }, + "newHeliconeTemplate": { + "type": "string" + }, + "isMajorVersion": { + "type": "boolean" + }, + "promptSubversionMetadata": { + "$ref": "#/components/schemas/Record_string.any_" + }, + "experimentTableMetadata": { + "$ref": "#/components/schemas/Record_string.any_" + } + }, + "required": [ + "datasetId", + "experimentMetadata", + "promptVersionId", + "newHeliconeTemplate", + "isMajorVersion", + "promptSubversionMetadata" + ], + "type": "object", + "additionalProperties": false + }, + "ExperimentTableColumn": { + "properties": { + "id": { + "type": "string" + }, + "columnName": { + "type": "string" + }, + "columnType": { + "type": "string" + }, + "hypothesisId": { + "type": "string" + }, + "cells": { + "items": { + "properties": { + "metadata": { + "$ref": "#/components/schemas/Record_string.any_" + }, + "value": { + "type": "string", + "nullable": true + }, + "requestId": { + "type": "string" + }, + "rowIndex": { + "type": "number", + "format": "double" + }, + "id": { + "type": "string" + } + }, + "required": [ + "value", + "rowIndex", + "id" + ], + "type": "object" + }, + "type": "array" + }, + "metadata": { + "$ref": "#/components/schemas/Record_string.any_" + } + }, + "required": [ + "id", + "columnName", + "columnType", + "cells" + ], + "type": "object", + "additionalProperties": false + }, + "ExperimentTable": { + "properties": { + "id": { + "type": "string" + }, + "name": { + "type": "string" + }, + "experimentId": { + "type": "string" + }, + "columns": { + "items": { + "$ref": "#/components/schemas/ExperimentTableColumn" + }, + "type": "array" + }, + "metadata": { + "$ref": "#/components/schemas/Record_string.any_" + } + }, + "required": [ + "id", + "name", + "experimentId", + "columns" + ], + "type": "object", + "additionalProperties": false + }, + "ResultSuccess_ExperimentTable_": { + "properties": { + "data": { + "$ref": "#/components/schemas/ExperimentTable" + }, + "error": { + "type": "number", + "enum": [ + null + ], + "nullable": true + } + }, + "required": [ + "data", + "error" + ], + "type": "object", + "additionalProperties": false + }, + "Result_ExperimentTable.string_": { + "anyOf": [ + { + "$ref": "#/components/schemas/ResultSuccess_ExperimentTable_" + }, + { + "$ref": "#/components/schemas/ResultError_string_" + } + ] + }, + "ExperimentTableSimplified": { + "properties": { + "id": { + "type": "string" + }, + "name": { "type": "string" }, "experimentId": { @@ -5466,335 +5774,27 @@ "type": "boolean", "enum": [ true - ], - "nullable": false - }, - "responseBodies": { - "type": "boolean", - "enum": [ - true - ], - "nullable": false - }, - "score": { - "type": "boolean", - "enum": [ - true - ], - "nullable": false - } - }, - "type": "object", - "additionalProperties": false - }, - "ResultSuccess__datasetId-string__": { - "properties": { - "data": { - "properties": { - "datasetId": { - "type": "string" - } - }, - "required": [ - "datasetId" - ], - "type": "object" - }, - "error": { - "type": "number", - "enum": [ - null - ], - "nullable": true - } - }, - "required": [ - "data", - "error" - ], - "type": "object", - "additionalProperties": false - }, - "Result__datasetId-string_.string_": { - "anyOf": [ - { - "$ref": "#/components/schemas/ResultSuccess__datasetId-string__" - }, - { - "$ref": "#/components/schemas/ResultError_string_" - } - ] - }, - "DatasetMetadata": { - "properties": { - "promptVersionId": { - "type": "string" - }, - "inputRecordsIds": { - "items": { - "type": "string" - }, - "type": "array" - } - }, - "type": "object", - "additionalProperties": false - }, - "NewDatasetParams": { - "properties": { - "datasetName": { - "type": "string" - }, - "requestIds": { - "items": { - "type": "string" - }, - "type": "array" - }, - "datasetType": { - "type": "string", - "enum": [ - "experiment", - "helicone" - ] - }, - "meta": { - "$ref": "#/components/schemas/DatasetMetadata" - } - }, - "required": [ - "datasetName", - "requestIds", - "datasetType" - ], - "type": "object", - "additionalProperties": false - }, - "Partial_TimestampOperators_": { - "properties": { - "gte": { - "type": "string" - }, - "lte": { - "type": "string" - }, - "lt": { - "type": "string" - }, - "gt": { - "type": "string" - } - }, - "type": "object", - "description": "Make all properties in T optional" - }, - "Partial_RequestTableToOperators_": { - "properties": { - "prompt": { - "$ref": "#/components/schemas/Partial_TextOperators_" - }, - "created_at": { - "$ref": "#/components/schemas/Partial_TimestampOperators_" - }, - "user_id": { - "$ref": "#/components/schemas/Partial_TextOperators_" - }, - "auth_hash": { - "$ref": "#/components/schemas/Partial_TextOperators_" - }, - "org_id": { - "$ref": "#/components/schemas/Partial_TextOperators_" - }, - "id": { - "$ref": "#/components/schemas/Partial_TextOperators_" - }, - "node_id": { - "$ref": "#/components/schemas/Partial_TextOperators_" - }, - "model": { - "$ref": "#/components/schemas/Partial_TextOperators_" - }, - "modelOverride": { - "$ref": "#/components/schemas/Partial_TextOperators_" - }, - "path": { - "$ref": "#/components/schemas/Partial_TextOperators_" - }, - "prompt_id": { - "$ref": "#/components/schemas/Partial_TextOperators_" - } - }, - "type": "object", - "description": "Make all properties in T optional" - }, - "Pick_FilterLeaf.request-or-prompts_versions_": { - "properties": { - "request": { - "$ref": "#/components/schemas/Partial_RequestTableToOperators_" - }, - "prompts_versions": { - "$ref": "#/components/schemas/Partial_PromptVersionsToOperators_" - } - }, - "type": "object", - "description": "From T, pick a set of properties whose keys are in the union K" - }, - "FilterLeafSubset_request-or-prompts_versions_": { - "$ref": "#/components/schemas/Pick_FilterLeaf.request-or-prompts_versions_" - }, - "DatasetFilterNode": { - "anyOf": [ - { - "$ref": "#/components/schemas/FilterLeafSubset_request-or-prompts_versions_" - }, - { - "$ref": "#/components/schemas/DatasetFilterBranch" - }, - { - "type": "string", - "enum": [ - "all" - ] - } - ] - }, - "DatasetFilterBranch": { - "properties": { - "right": { - "$ref": "#/components/schemas/DatasetFilterNode" - }, - "operator": { - "type": "string", - "enum": [ - "or", - "and" - ] - }, - "left": { - "$ref": "#/components/schemas/DatasetFilterNode" - } - }, - "required": [ - "right", - "operator", - "left" - ], - "type": "object" - }, - "RandomDatasetParams": { - "properties": { - "datasetName": { - "type": "string" - }, - "filter": { - "$ref": "#/components/schemas/DatasetFilterNode" - }, - "offset": { - "type": "number", - "format": "double" - }, - "limit": { - "type": "number", - "format": "double" - } - }, - "required": [ - "datasetName", - "filter" - ], - "type": "object", - "additionalProperties": false - }, - "DatasetResult": { - "properties": { - "id": { - "type": "string" - }, - "name": { - "type": "string" - }, - "created_at": { - "type": "string" - }, - "meta": { - "$ref": "#/components/schemas/DatasetMetadata" - } - }, - "required": [ - "id", - "name", - "created_at" - ], - "type": "object", - "additionalProperties": false - }, - "ResultSuccess_DatasetResult-Array_": { - "properties": { - "data": { - "items": { - "$ref": "#/components/schemas/DatasetResult" - }, - "type": "array" - }, - "error": { - "type": "number", - "enum": [ - null - ], - "nullable": true - } - }, - "required": [ - "data", - "error" - ], - "type": "object", - "additionalProperties": false - }, - "Result_DatasetResult-Array.string_": { - "anyOf": [ - { - "$ref": "#/components/schemas/ResultSuccess_DatasetResult-Array_" - }, - { - "$ref": "#/components/schemas/ResultError_string_" - } - ] - }, - "ResultSuccess___-Array_": { - "properties": { - "data": { - "items": { - "properties": {}, - "type": "object" - }, - "type": "array" + ], + "nullable": false }, - "error": { - "type": "number", + "responseBodies": { + "type": "boolean", "enum": [ - null + true ], - "nullable": true + "nullable": false + }, + "score": { + "type": "boolean", + "enum": [ + true + ], + "nullable": false } }, - "required": [ - "data", - "error" - ], "type": "object", "additionalProperties": false }, - "Result___-Array.string_": { - "anyOf": [ - { - "$ref": "#/components/schemas/ResultSuccess___-Array_" - }, - { - "$ref": "#/components/schemas/ResultError_string_" - } - ] - }, "HeliconeDatasetMetadata": { "properties": { "promptVersionId": { @@ -13393,23 +13393,23 @@ "parameters": [] } }, - "/v1/experiment/new-empty": { + "/v1/experiment/dataset": { "post": { - "operationId": "CreateNewEmptyExperiment", + "operationId": "AddDataset", "responses": { "200": { "description": "Ok", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Result__experimentId-string_.string_" + "$ref": "#/components/schemas/Result__datasetId-string_.string_" } } } } }, "tags": [ - "Experiment" + "Dataset" ], "security": [ { @@ -13422,42 +13422,30 @@ "content": { "application/json": { "schema": { - "properties": { - "datasetId": { - "type": "string" - }, - "metadata": { - "$ref": "#/components/schemas/Record_string.string_" - } - }, - "required": [ - "datasetId", - "metadata" - ], - "type": "object" + "$ref": "#/components/schemas/NewDatasetParams" } } } } } }, - "/v1/experiment/table/new": { + "/v1/experiment/dataset/random": { "post": { - "operationId": "CreateNewExperimentTable", + "operationId": "AddRandomDataset", "responses": { "200": { "description": "Ok", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Result__tableId-string--experimentId-string_.string_" + "$ref": "#/components/schemas/Result__datasetId-string_.string_" } } } } }, "tags": [ - "Experiment" + "Dataset" ], "security": [ { @@ -13470,65 +13458,71 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/CreateExperimentTableParams" + "$ref": "#/components/schemas/RandomDatasetParams" } } } } } }, - "/v1/experiment/table/{experimentTableId}/query": { + "/v1/experiment/dataset/query": { "post": { - "operationId": "GetExperimentTableById", + "operationId": "GetDatasets", "responses": { "200": { "description": "Ok", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Result_ExperimentTable.string_" + "$ref": "#/components/schemas/Result_DatasetResult-Array.string_" } } } } }, "tags": [ - "Experiment" + "Dataset" ], "security": [ { "api_key": [] } ], - "parameters": [ - { - "in": "path", - "name": "experimentTableId", - "required": true, - "schema": { - "type": "string" + "parameters": [], + "requestBody": { + "required": true, + "content": { + "application/json": { + "schema": { + "properties": { + "promptVersionId": { + "type": "string" + } + }, + "type": "object" + } } } - ] + } } }, - "/v1/experiment/table/{experimentTableId}/metadata/query": { + "/v1/experiment/dataset/{datasetId}/row/insert": { "post": { - "operationId": "GetExperimentTableMetadata", + "operationId": "InsertDatasetRow", "responses": { "200": { "description": "Ok", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Result_ExperimentTableSimplified.string_" + "$ref": "#/components/schemas/Result_string.string_" } } } } }, "tags": [ - "Experiment" + "Dataset" ], "security": [ { @@ -13538,58 +13532,57 @@ "parameters": [ { "in": "path", - "name": "experimentTableId", + "name": "datasetId", "required": true, "schema": { "type": "string" } } - ] - } - }, - "/v1/experiment/tables/query": { - "post": { - "operationId": "GetExperimentTables", - "responses": { - "200": { - "description": "Ok", - "content": { - "application/json": { - "schema": { - "$ref": "#/components/schemas/Result_ExperimentTableSimplified-Array.string_" - } + ], + "requestBody": { + "required": true, + "content": { + "application/json": { + "schema": { + "properties": { + "originalColumnId": { + "type": "string" + }, + "inputs": { + "$ref": "#/components/schemas/Record_string.string_" + }, + "inputRecordId": { + "type": "string" + } + }, + "required": [ + "inputs", + "inputRecordId" + ], + "type": "object" } } } - }, - "tags": [ - "Experiment" - ], - "security": [ - { - "api_key": [] - } - ], - "parameters": [] + } } }, - "/v1/experiment/table/{experimentTableId}/cell": { + "/v1/experiment/dataset/{datasetId}/version/{promptVersionId}/row/new": { "post": { - "operationId": "CreateExperimentCell", + "operationId": "CreateDatasetRow", "responses": { "200": { "description": "Ok", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Result_null.string_" + "$ref": "#/components/schemas/Result_string.string_" } } } } }, "tags": [ - "Experiment" + "Dataset" ], "security": [ { @@ -13599,7 +13592,15 @@ "parameters": [ { "in": "path", - "name": "experimentTableId", + "name": "datasetId", + "required": true, + "schema": { + "type": "string" + } + }, + { + "in": "path", + "name": "promptVersionId", "required": true, "schema": { "type": "string" @@ -13612,45 +13613,40 @@ "application/json": { "schema": { "properties": { - "value": { - "type": "string", - "nullable": true - }, - "rowIndex": { - "type": "number", - "format": "double" - }, - "columnId": { + "sourceRequest": { "type": "string" + }, + "inputs": { + "$ref": "#/components/schemas/Record_string.string_" } }, "required": [ - "value", - "rowIndex", - "columnId" + "inputs" ], "type": "object" } } } } - }, - "patch": { - "operationId": "UpdateExperimentCell", + } + }, + "/v1/experiment/dataset/{datasetId}/inputs/query": { + "post": { + "operationId": "GetDataset", "responses": { "200": { "description": "Ok", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Result_null.string_" + "$ref": "#/components/schemas/Result_PromptInputRecord-Array.string_" } } } } }, "tags": [ - "Experiment" + "Dataset" ], "security": [ { @@ -13660,106 +13656,61 @@ "parameters": [ { "in": "path", - "name": "experimentTableId", + "name": "datasetId", "required": true, "schema": { "type": "string" } } - ], - "requestBody": { - "required": true, - "content": { - "application/json": { - "schema": { - "properties": { - "updateInputs": { - "type": "boolean" - }, - "metadata": { - "type": "string" - }, - "value": { - "type": "string" - }, - "status": { - "type": "string" - }, - "cellId": { - "type": "string" - } - }, - "required": [ - "cellId" - ], - "type": "object" - } - } - } - } + ] } }, - "/v1/experiment/table/{experimentTableId}/column": { + "/v1/experiment/dataset/{datasetId}/mutate": { "post": { - "operationId": "CreateExperimentColumn", + "operationId": "MutateDataset", "responses": { "200": { "description": "Ok", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Result_null.string_" + "$ref": "#/components/schemas/Result___-Array.string_" } } } } }, "tags": [ - "Experiment" + "Dataset" ], "security": [ { "api_key": [] } ], - "parameters": [ - { - "in": "path", - "name": "experimentTableId", - "required": true, - "schema": { - "type": "string" - } - } - ], + "parameters": [], "requestBody": { "required": true, "content": { "application/json": { "schema": { "properties": { - "inputKeys": { + "removeRequests": { + "items": { + "type": "string" + }, + "type": "array" + }, + "addRequests": { "items": { "type": "string" }, "type": "array" - }, - "promptVersionId": { - "type": "string" - }, - "hypothesisId": { - "type": "string" - }, - "columnType": { - "type": "string" - }, - "columnName": { - "type": "string" } }, "required": [ - "columnType", - "columnName" + "removeRequests", + "addRequests" ], "type": "object" } @@ -13768,16 +13719,16 @@ } } }, - "/v1/experiment/table/{experimentTableId}/row/new": { + "/v1/experiment/new-empty": { "post": { - "operationId": "CreateExperimentTableRow", + "operationId": "CreateNewEmptyExperiment", "responses": { "200": { "description": "Ok", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Result_null.string_" + "$ref": "#/components/schemas/Result__experimentId-string_.string_" } } } @@ -13791,34 +13742,23 @@ "api_key": [] } ], - "parameters": [ - { - "in": "path", - "name": "experimentTableId", - "required": true, - "schema": { - "type": "string" - } - } - ], + "parameters": [], "requestBody": { "required": true, "content": { "application/json": { "schema": { "properties": { - "inputs": { - "$ref": "#/components/schemas/Record_string.string_" - }, - "sourceRequest": { + "datasetId": { "type": "string" }, - "promptVersionId": { - "type": "string" + "metadata": { + "$ref": "#/components/schemas/Record_string.string_" } }, "required": [ - "promptVersionId" + "datasetId", + "metadata" ], "type": "object" } @@ -13827,16 +13767,16 @@ } } }, - "/v1/experiment/table/{experimentTableId}/row/{rowIndex}": { - "delete": { - "operationId": "DeleteExperimentTableRow", + "/v1/experiment/table/new": { + "post": { + "operationId": "CreateNewExperimentTable", "responses": { "200": { "description": "Ok", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Result_null.string_" + "$ref": "#/components/schemas/Result__tableId-string--experimentId-string_.string_" } } } @@ -13850,37 +13790,29 @@ "api_key": [] } ], - "parameters": [ - { - "in": "path", - "name": "experimentTableId", - "required": true, - "schema": { - "type": "string" - } - }, - { - "in": "path", - "name": "rowIndex", - "required": true, - "schema": { - "format": "double", - "type": "number" + "parameters": [], + "requestBody": { + "required": true, + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/CreateExperimentTableParams" + } } } - ] + } } }, - "/v1/experiment/table/{experimentTableId}/row/insert/batch": { + "/v1/experiment/table/{experimentTableId}/query": { "post": { - "operationId": "CreateExperimentTableRowWithCellsBatch", + "operationId": "GetExperimentTableById", "responses": { "200": { "description": "Ok", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Result_null.string_" + "$ref": "#/components/schemas/Result_ExperimentTable.string_" } } } @@ -13903,87 +13835,19 @@ "type": "string" } } - ], - "requestBody": { - "required": true, - "content": { - "application/json": { - "schema": { - "properties": { - "rows": { - "items": { - "properties": { - "sourceRequest": { - "type": "string" - }, - "cells": { - "items": { - "properties": { - "metadata": {}, - "value": { - "type": "string", - "nullable": true - }, - "columnId": { - "type": "string" - } - }, - "required": [ - "value", - "columnId" - ], - "type": "object" - }, - "type": "array" - }, - "datasetId": { - "type": "string" - }, - "inputs": { - "$ref": "#/components/schemas/Record_string.string_" - }, - "inputRecordId": { - "type": "string" - } - }, - "required": [ - "cells", - "datasetId", - "inputs", - "inputRecordId" - ], - "type": "object" - }, - "type": "array" - } - }, - "required": [ - "rows" - ], - "type": "object" - } - } - } - } + ] } }, - "/v1/experiment/update-meta": { + "/v1/experiment/table/{experimentTableId}/metadata/query": { "post": { - "operationId": "UpdateExperimentMeta", + "operationId": "GetExperimentTableMetadata", "responses": { "200": { "description": "Ok", "content": { "application/json": { "schema": { - "anyOf": [ - { - "$ref": "#/components/schemas/ResultSuccess_unknown_" - }, - { - "$ref": "#/components/schemas/ResultError_PostgrestError_" - } - ] + "$ref": "#/components/schemas/Result_ExperimentTableSimplified.string_" } } } @@ -13997,41 +13861,28 @@ "api_key": [] } ], - "parameters": [], - "requestBody": { - "required": true, - "content": { - "application/json": { - "schema": { - "properties": { - "meta": { - "$ref": "#/components/schemas/Record_string.string_" - }, - "experimentId": { - "type": "string" - } - }, - "required": [ - "meta", - "experimentId" - ], - "type": "object" - } + "parameters": [ + { + "in": "path", + "name": "experimentTableId", + "required": true, + "schema": { + "type": "string" } } - } + ] } }, - "/v1/experiment": { + "/v1/experiment/tables/query": { "post": { - "operationId": "CreateNewExperimentOld", + "operationId": "GetExperimentTables", "responses": { "200": { "description": "Ok", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Result__experimentId-string_.string_" + "$ref": "#/components/schemas/Result_ExperimentTableSimplified-Array.string_" } } } @@ -14045,29 +13896,19 @@ "api_key": [] } ], - "parameters": [], - "requestBody": { - "required": true, - "content": { - "application/json": { - "schema": { - "$ref": "#/components/schemas/NewExperimentParams" - } - } - } - } + "parameters": [] } }, - "/v1/experiment/hypothesis": { + "/v1/experiment/table/{experimentTableId}/cell": { "post": { - "operationId": "CreateNewExperimentHypothesis", + "operationId": "CreateExperimentCell", "responses": { "200": { "description": "Ok", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Result__hypothesisId-string_.string_" + "$ref": "#/components/schemas/Result_null.string_" } } } @@ -14081,59 +13922,54 @@ "api_key": [] } ], - "parameters": [], + "parameters": [ + { + "in": "path", + "name": "experimentTableId", + "required": true, + "schema": { + "type": "string" + } + } + ], "requestBody": { "required": true, "content": { "application/json": { "schema": { "properties": { - "status": { + "value": { "type": "string", - "enum": [ - "PENDING", - "RUNNING", - "COMPLETED", - "FAILED" - ] - }, - "providerKeyId": { - "type": "string" - }, - "promptVersion": { - "type": "string" + "nullable": true }, - "model": { - "type": "string" + "rowIndex": { + "type": "number", + "format": "double" }, - "experimentId": { + "columnId": { "type": "string" } }, "required": [ - "status", - "providerKeyId", - "promptVersion", - "model", - "experimentId" + "value", + "rowIndex", + "columnId" ], "type": "object" } } } } - } - }, - "/v1/experiment/hypothesis/{hypothesisId}/scores/query": { - "post": { - "operationId": "GetExperimentHypothesisScores", + }, + "patch": { + "operationId": "UpdateExperimentCell", "responses": { "200": { "description": "Ok", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Result__runsCount-number--scores-Record_string.Score__.string_" + "$ref": "#/components/schemas/Result_null.string_" } } } @@ -14150,25 +13986,55 @@ "parameters": [ { "in": "path", - "name": "hypothesisId", + "name": "experimentTableId", "required": true, "schema": { "type": "string" } } - ] + ], + "requestBody": { + "required": true, + "content": { + "application/json": { + "schema": { + "properties": { + "updateInputs": { + "type": "boolean" + }, + "metadata": { + "type": "string" + }, + "value": { + "type": "string" + }, + "status": { + "type": "string" + }, + "cellId": { + "type": "string" + } + }, + "required": [ + "cellId" + ], + "type": "object" + } + } + } + } } }, - "/v1/experiment/{experimentId}/evaluators": { - "get": { - "operationId": "GetExperimentEvaluators", + "/v1/experiment/table/{experimentTableId}/column": { + "post": { + "operationId": "CreateExperimentColumn", "responses": { "200": { "description": "Ok", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Result_EvaluatorResult-Array.string_" + "$ref": "#/components/schemas/Result_null.string_" } } } @@ -14185,16 +14051,52 @@ "parameters": [ { "in": "path", - "name": "experimentId", + "name": "experimentTableId", "required": true, "schema": { "type": "string" } } - ] - }, + ], + "requestBody": { + "required": true, + "content": { + "application/json": { + "schema": { + "properties": { + "inputKeys": { + "items": { + "type": "string" + }, + "type": "array" + }, + "promptVersionId": { + "type": "string" + }, + "hypothesisId": { + "type": "string" + }, + "columnType": { + "type": "string" + }, + "columnName": { + "type": "string" + } + }, + "required": [ + "columnType", + "columnName" + ], + "type": "object" + } + } + } + } + } + }, + "/v1/experiment/table/{experimentTableId}/row/new": { "post": { - "operationId": "CreateExperimentEvaluatorOld", + "operationId": "CreateExperimentTableRow", "responses": { "200": { "description": "Ok", @@ -14218,7 +14120,7 @@ "parameters": [ { "in": "path", - "name": "experimentId", + "name": "experimentTableId", "required": true, "schema": { "type": "string" @@ -14231,12 +14133,18 @@ "application/json": { "schema": { "properties": { - "evaluatorId": { + "inputs": { + "$ref": "#/components/schemas/Record_string.string_" + }, + "sourceRequest": { + "type": "string" + }, + "promptVersionId": { "type": "string" } }, "required": [ - "evaluatorId" + "promptVersionId" ], "type": "object" } @@ -14245,9 +14153,9 @@ } } }, - "/v1/experiment/{experimentId}/evaluators/run": { - "post": { - "operationId": "RunExperimentEvaluatorsOld", + "/v1/experiment/table/{experimentTableId}/row/{rowIndex}": { + "delete": { + "operationId": "DeleteExperimentTableRow", "responses": { "200": { "description": "Ok", @@ -14271,18 +14179,27 @@ "parameters": [ { "in": "path", - "name": "experimentId", + "name": "experimentTableId", "required": true, "schema": { "type": "string" } + }, + { + "in": "path", + "name": "rowIndex", + "required": true, + "schema": { + "format": "double", + "type": "number" + } } ] } }, - "/v1/experiment/{experimentId}/evaluators/{evaluatorId}": { - "delete": { - "operationId": "DeleteExperimentEvaluatorOld", + "/v1/experiment/table/{experimentTableId}/row/insert/batch": { + "post": { + "operationId": "CreateExperimentTableRowWithCellsBatch", "responses": { "200": { "description": "Ok", @@ -14306,33 +14223,93 @@ "parameters": [ { "in": "path", - "name": "experimentId", + "name": "experimentTableId", "required": true, "schema": { "type": "string" } - }, - { - "in": "path", - "name": "evaluatorId", - "required": true, - "schema": { - "type": "string" + } + ], + "requestBody": { + "required": true, + "content": { + "application/json": { + "schema": { + "properties": { + "rows": { + "items": { + "properties": { + "sourceRequest": { + "type": "string" + }, + "cells": { + "items": { + "properties": { + "metadata": {}, + "value": { + "type": "string", + "nullable": true + }, + "columnId": { + "type": "string" + } + }, + "required": [ + "value", + "columnId" + ], + "type": "object" + }, + "type": "array" + }, + "datasetId": { + "type": "string" + }, + "inputs": { + "$ref": "#/components/schemas/Record_string.string_" + }, + "inputRecordId": { + "type": "string" + } + }, + "required": [ + "cells", + "datasetId", + "inputs", + "inputRecordId" + ], + "type": "object" + }, + "type": "array" + } + }, + "required": [ + "rows" + ], + "type": "object" + } } } - ] + } } }, - "/v1/experiment/query": { + "/v1/experiment/update-meta": { "post": { - "operationId": "GetExperimentsOld", + "operationId": "UpdateExperimentMeta", "responses": { "200": { "description": "Ok", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Result_Experiment-Array.string_" + "anyOf": [ + { + "$ref": "#/components/schemas/ResultSuccess_unknown_" + }, + { + "$ref": "#/components/schemas/ResultError_PostgrestError_" + } + ] } } } @@ -14353,15 +14330,16 @@ "application/json": { "schema": { "properties": { - "include": { - "$ref": "#/components/schemas/IncludeExperimentKeys" + "meta": { + "$ref": "#/components/schemas/Record_string.string_" }, - "filter": { - "$ref": "#/components/schemas/ExperimentFilterNode" + "experimentId": { + "type": "string" } }, "required": [ - "filter" + "meta", + "experimentId" ], "type": "object" } @@ -14370,23 +14348,59 @@ } } }, - "/v1/experiment/dataset": { + "/v1/experiment": { + "post": { + "operationId": "CreateNewExperimentOld", + "responses": { + "200": { + "description": "Ok", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/Result__experimentId-string_.string_" + } + } + } + } + }, + "tags": [ + "Experiment" + ], + "security": [ + { + "api_key": [] + } + ], + "parameters": [], + "requestBody": { + "required": true, + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/NewExperimentParams" + } + } + } + } + } + }, + "/v1/experiment/hypothesis": { "post": { - "operationId": "AddDataset", + "operationId": "CreateNewExperimentHypothesis", "responses": { "200": { "description": "Ok", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Result__datasetId-string_.string_" + "$ref": "#/components/schemas/Result__hypothesisId-string_.string_" } } } } }, "tags": [ - "Dataset" + "Experiment" ], "security": [ { @@ -14399,107 +14413,128 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/NewDatasetParams" + "properties": { + "status": { + "type": "string", + "enum": [ + "PENDING", + "RUNNING", + "COMPLETED", + "FAILED" + ] + }, + "providerKeyId": { + "type": "string" + }, + "promptVersion": { + "type": "string" + }, + "model": { + "type": "string" + }, + "experimentId": { + "type": "string" + } + }, + "required": [ + "status", + "providerKeyId", + "promptVersion", + "model", + "experimentId" + ], + "type": "object" } } } } } }, - "/v1/experiment/dataset/random": { + "/v1/experiment/hypothesis/{hypothesisId}/scores/query": { "post": { - "operationId": "AddRandomDataset", + "operationId": "GetExperimentHypothesisScores", "responses": { "200": { "description": "Ok", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Result__datasetId-string_.string_" + "$ref": "#/components/schemas/Result__runsCount-number--scores-Record_string.Score__.string_" } } } } }, "tags": [ - "Dataset" + "Experiment" ], "security": [ { "api_key": [] } ], - "parameters": [], - "requestBody": { - "required": true, - "content": { - "application/json": { - "schema": { - "$ref": "#/components/schemas/RandomDatasetParams" - } + "parameters": [ + { + "in": "path", + "name": "hypothesisId", + "required": true, + "schema": { + "type": "string" } } - } + ] } }, - "/v1/experiment/dataset/query": { - "post": { - "operationId": "GetDatasets", + "/v1/experiment/{experimentId}/evaluators": { + "get": { + "operationId": "GetExperimentEvaluators", "responses": { "200": { "description": "Ok", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Result_DatasetResult-Array.string_" + "$ref": "#/components/schemas/Result_EvaluatorResult-Array.string_" } } } } }, "tags": [ - "Dataset" + "Experiment" ], "security": [ { "api_key": [] } ], - "parameters": [], - "requestBody": { - "required": true, - "content": { - "application/json": { - "schema": { - "properties": { - "promptVersionId": { - "type": "string" - } - }, - "type": "object" - } + "parameters": [ + { + "in": "path", + "name": "experimentId", + "required": true, + "schema": { + "type": "string" } } - } - } - }, - "/v1/experiment/dataset/{datasetId}/row/insert": { + ] + }, "post": { - "operationId": "InsertDatasetRow", + "operationId": "CreateExperimentEvaluatorOld", "responses": { "200": { "description": "Ok", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Result_string.string_" + "$ref": "#/components/schemas/Result_null.string_" } } } } }, "tags": [ - "Dataset" + "Experiment" ], "security": [ { @@ -14509,7 +14544,7 @@ "parameters": [ { "in": "path", - "name": "datasetId", + "name": "experimentId", "required": true, "schema": { "type": "string" @@ -14522,19 +14557,12 @@ "application/json": { "schema": { "properties": { - "originalColumnId": { - "type": "string" - }, - "inputs": { - "$ref": "#/components/schemas/Record_string.string_" - }, - "inputRecordId": { + "evaluatorId": { "type": "string" } }, "required": [ - "inputs", - "inputRecordId" + "evaluatorId" ], "type": "object" } @@ -14543,23 +14571,23 @@ } } }, - "/v1/experiment/dataset/{datasetId}/version/{promptVersionId}/row/new": { + "/v1/experiment/{experimentId}/evaluators/run": { "post": { - "operationId": "CreateDatasetRow", + "operationId": "RunExperimentEvaluatorsOld", "responses": { "200": { "description": "Ok", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Result_string.string_" + "$ref": "#/components/schemas/Result_null.string_" } } } } }, "tags": [ - "Dataset" + "Experiment" ], "security": [ { @@ -14569,61 +14597,32 @@ "parameters": [ { "in": "path", - "name": "datasetId", - "required": true, - "schema": { - "type": "string" - } - }, - { - "in": "path", - "name": "promptVersionId", + "name": "experimentId", "required": true, "schema": { "type": "string" } } - ], - "requestBody": { - "required": true, - "content": { - "application/json": { - "schema": { - "properties": { - "sourceRequest": { - "type": "string" - }, - "inputs": { - "$ref": "#/components/schemas/Record_string.string_" - } - }, - "required": [ - "inputs" - ], - "type": "object" - } - } - } - } + ] } }, - "/v1/experiment/dataset/{datasetId}/inputs/query": { - "post": { - "operationId": "GetDataset", + "/v1/experiment/{experimentId}/evaluators/{evaluatorId}": { + "delete": { + "operationId": "DeleteExperimentEvaluatorOld", "responses": { "200": { "description": "Ok", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Result_PromptInputRecord-Array.string_" + "$ref": "#/components/schemas/Result_null.string_" } } } } }, "tags": [ - "Dataset" + "Experiment" ], "security": [ { @@ -14633,7 +14632,15 @@ "parameters": [ { "in": "path", - "name": "datasetId", + "name": "experimentId", + "required": true, + "schema": { + "type": "string" + } + }, + { + "in": "path", + "name": "evaluatorId", "required": true, "schema": { "type": "string" @@ -14642,23 +14649,23 @@ ] } }, - "/v1/experiment/dataset/{datasetId}/mutate": { + "/v1/experiment/query": { "post": { - "operationId": "MutateDataset", + "operationId": "GetExperimentsOld", "responses": { "200": { "description": "Ok", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Result___-Array.string_" + "$ref": "#/components/schemas/Result_Experiment-Array.string_" } } } } }, "tags": [ - "Dataset" + "Experiment" ], "security": [ { @@ -14672,22 +14679,15 @@ "application/json": { "schema": { "properties": { - "removeRequests": { - "items": { - "type": "string" - }, - "type": "array" + "include": { + "$ref": "#/components/schemas/IncludeExperimentKeys" }, - "addRequests": { - "items": { - "type": "string" - }, - "type": "array" + "filter": { + "$ref": "#/components/schemas/ExperimentFilterNode" } }, "required": [ - "removeRequests", - "addRequests" + "filter" ], "type": "object" } @@ -16753,6 +16753,54 @@ } } }, + "/v1/pi/total_requests": { + "post": { + "operationId": "GetTotalRequests", + "responses": { + "200": { + "description": "Ok", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/Result_number.string_" + } + } + } + } + }, + "tags": [ + "PI" + ], + "security": [ + { + "api_key": [] + } + ], + "parameters": [], + "requestBody": { + "required": true, + "content": { + "application/json": { + "schema": { + "properties": { + "endTime": { + "type": "string" + }, + "startTime": { + "type": "string" + } + }, + "required": [ + "endTime", + "startTime" + ], + "type": "object" + } + } + } + } + } + }, "/v1/settings/query": { "get": { "operationId": "GetSettings", diff --git a/valhalla/jawn/src/tsoa-build/private/routes.ts b/valhalla/jawn/src/tsoa-build/private/routes.ts index 8c93a91fbb..60f4905641 100644 --- a/valhalla/jawn/src/tsoa-build/private/routes.ts +++ b/valhalla/jawn/src/tsoa-build/private/routes.ts @@ -8930,6 +8930,38 @@ export function RegisterRoutes(app: Router) { } }); // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa + app.post('/v1/pi/total_requests', + authenticateMiddleware([{"api_key":[]}]), + ...(fetchMiddlewares(PiController)), + ...(fetchMiddlewares(PiController.prototype.getTotalRequests)), + + async function PiController_getTotalRequests(request: ExRequest, response: ExResponse, next: any) { + const args: Record = { + body: {"in":"body","name":"body","required":true,"dataType":"nestedObjectLiteral","nestedProperties":{"endTime":{"dataType":"string","required":true},"startTime":{"dataType":"string","required":true}}}, + request: {"in":"request","name":"request","required":true,"dataType":"object"}, + }; + + // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa + + let validatedArgs: any[] = []; + try { + validatedArgs = templateService.getValidatedArgs({ args, request, response }); + + const controller = new PiController(); + + await templateService.apiHandler({ + methodName: 'getTotalRequests', + controller, + response, + next, + validatedArgs, + successStatus: undefined, + }); + } catch (err) { + return next(err); + } + }); + // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa app.get('/v1/settings/query', authenticateMiddleware([{"api_key":[]}]), ...(fetchMiddlewares(SettingController)), diff --git a/valhalla/jawn/src/tsoa-build/private/swagger.json b/valhalla/jawn/src/tsoa-build/private/swagger.json index 906a5d6b46..a603b8c3b2 100644 --- a/valhalla/jawn/src/tsoa-build/private/swagger.json +++ b/valhalla/jawn/src/tsoa-build/private/swagger.json @@ -17446,6 +17446,54 @@ } } }, + "/v1/pi/total_requests": { + "post": { + "operationId": "GetTotalRequests", + "responses": { + "200": { + "description": "Ok", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/Result_number.string_" + } + } + } + } + }, + "tags": [ + "PI" + ], + "security": [ + { + "api_key": [] + } + ], + "parameters": [], + "requestBody": { + "required": true, + "content": { + "application/json": { + "schema": { + "properties": { + "endTime": { + "type": "string" + }, + "startTime": { + "type": "string" + } + }, + "required": [ + "endTime", + "startTime" + ], + "type": "object" + } + } + } + } + } + }, "/v1/settings/query": { "get": { "operationId": "GetSettings", diff --git a/valhalla/jawn/src/tsoa-build/public/routes.ts b/valhalla/jawn/src/tsoa-build/public/routes.ts index ea338fe281..fb864dee61 100644 --- a/valhalla/jawn/src/tsoa-build/public/routes.ts +++ b/valhalla/jawn/src/tsoa-build/public/routes.ts @@ -38,10 +38,10 @@ import { PropertyController } from './../../controllers/public/propertyControlle // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa import { IntegrationController } from './../../controllers/public/integrationController'; // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa -import { ExperimentController } from './../../controllers/public/experimentController'; -// WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa import { ExperimentDatasetController } from './../../controllers/public/experimentDatasetController'; // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa +import { ExperimentController } from './../../controllers/public/experimentController'; +// WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa import { HeliconeDatasetController } from './../../controllers/public/heliconeDatasetController'; // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa import { DataIsBeautifulRouter } from './../../controllers/public/dataIsBeautifulController'; @@ -1624,6 +1624,120 @@ const models: TsoaRoute.Models = { "type": {"dataType":"union","subSchemas":[{"ref":"ResultSuccess_Array__id-string--name-string___"},{"ref":"ResultError_string_"}],"validators":{}}, }, // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa + "ResultSuccess__datasetId-string__": { + "dataType": "refObject", + "properties": { + "data": {"dataType":"nestedObjectLiteral","nestedProperties":{"datasetId":{"dataType":"string","required":true}},"required":true}, + "error": {"dataType":"enum","enums":[null],"required":true}, + }, + "additionalProperties": false, + }, + // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa + "Result__datasetId-string_.string_": { + "dataType": "refAlias", + "type": {"dataType":"union","subSchemas":[{"ref":"ResultSuccess__datasetId-string__"},{"ref":"ResultError_string_"}],"validators":{}}, + }, + // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa + "DatasetMetadata": { + "dataType": "refObject", + "properties": { + "promptVersionId": {"dataType":"string"}, + "inputRecordsIds": {"dataType":"array","array":{"dataType":"string"}}, + }, + "additionalProperties": false, + }, + // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa + "NewDatasetParams": { + "dataType": "refObject", + "properties": { + "datasetName": {"dataType":"string","required":true}, + "requestIds": {"dataType":"array","array":{"dataType":"string"},"required":true}, + "datasetType": {"dataType":"union","subSchemas":[{"dataType":"enum","enums":["experiment"]},{"dataType":"enum","enums":["helicone"]}],"required":true}, + "meta": {"ref":"DatasetMetadata"}, + }, + "additionalProperties": false, + }, + // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa + "Partial_TimestampOperators_": { + "dataType": "refAlias", + "type": {"dataType":"nestedObjectLiteral","nestedProperties":{"gte":{"dataType":"string"},"lte":{"dataType":"string"},"lt":{"dataType":"string"},"gt":{"dataType":"string"}},"validators":{}}, + }, + // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa + "Partial_RequestTableToOperators_": { + "dataType": "refAlias", + "type": {"dataType":"nestedObjectLiteral","nestedProperties":{"prompt":{"ref":"Partial_TextOperators_"},"created_at":{"ref":"Partial_TimestampOperators_"},"user_id":{"ref":"Partial_TextOperators_"},"auth_hash":{"ref":"Partial_TextOperators_"},"org_id":{"ref":"Partial_TextOperators_"},"id":{"ref":"Partial_TextOperators_"},"node_id":{"ref":"Partial_TextOperators_"},"model":{"ref":"Partial_TextOperators_"},"modelOverride":{"ref":"Partial_TextOperators_"},"path":{"ref":"Partial_TextOperators_"},"prompt_id":{"ref":"Partial_TextOperators_"}},"validators":{}}, + }, + // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa + "Pick_FilterLeaf.request-or-prompts_versions_": { + "dataType": "refAlias", + "type": {"dataType":"nestedObjectLiteral","nestedProperties":{"request":{"ref":"Partial_RequestTableToOperators_"},"prompts_versions":{"ref":"Partial_PromptVersionsToOperators_"}},"validators":{}}, + }, + // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa + "FilterLeafSubset_request-or-prompts_versions_": { + "dataType": "refAlias", + "type": {"ref":"Pick_FilterLeaf.request-or-prompts_versions_","validators":{}}, + }, + // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa + "DatasetFilterNode": { + "dataType": "refAlias", + "type": {"dataType":"union","subSchemas":[{"ref":"FilterLeafSubset_request-or-prompts_versions_"},{"ref":"DatasetFilterBranch"},{"dataType":"enum","enums":["all"]}],"validators":{}}, + }, + // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa + "DatasetFilterBranch": { + "dataType": "refAlias", + "type": {"dataType":"nestedObjectLiteral","nestedProperties":{"right":{"ref":"DatasetFilterNode","required":true},"operator":{"dataType":"union","subSchemas":[{"dataType":"enum","enums":["or"]},{"dataType":"enum","enums":["and"]}],"required":true},"left":{"ref":"DatasetFilterNode","required":true}},"validators":{}}, + }, + // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa + "RandomDatasetParams": { + "dataType": "refObject", + "properties": { + "datasetName": {"dataType":"string","required":true}, + "filter": {"ref":"DatasetFilterNode","required":true}, + "offset": {"dataType":"double"}, + "limit": {"dataType":"double"}, + }, + "additionalProperties": false, + }, + // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa + "DatasetResult": { + "dataType": "refObject", + "properties": { + "id": {"dataType":"string","required":true}, + "name": {"dataType":"string","required":true}, + "created_at": {"dataType":"string","required":true}, + "meta": {"ref":"DatasetMetadata"}, + }, + "additionalProperties": false, + }, + // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa + "ResultSuccess_DatasetResult-Array_": { + "dataType": "refObject", + "properties": { + "data": {"dataType":"array","array":{"dataType":"refObject","ref":"DatasetResult"},"required":true}, + "error": {"dataType":"enum","enums":[null],"required":true}, + }, + "additionalProperties": false, + }, + // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa + "Result_DatasetResult-Array.string_": { + "dataType": "refAlias", + "type": {"dataType":"union","subSchemas":[{"ref":"ResultSuccess_DatasetResult-Array_"},{"ref":"ResultError_string_"}],"validators":{}}, + }, + // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa + "ResultSuccess___-Array_": { + "dataType": "refObject", + "properties": { + "data": {"dataType":"array","array":{"dataType":"nestedObjectLiteral","nestedProperties":{}},"required":true}, + "error": {"dataType":"enum","enums":[null],"required":true}, + }, + "additionalProperties": false, + }, + // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa + "Result___-Array.string_": { + "dataType": "refAlias", + "type": {"dataType":"union","subSchemas":[{"ref":"ResultSuccess___-Array_"},{"ref":"ResultError_string_"}],"validators":{}}, + }, + // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa "ResultSuccess__tableId-string--experimentId-string__": { "dataType": "refObject", "properties": { @@ -1916,120 +2030,6 @@ const models: TsoaRoute.Models = { "additionalProperties": false, }, // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa - "ResultSuccess__datasetId-string__": { - "dataType": "refObject", - "properties": { - "data": {"dataType":"nestedObjectLiteral","nestedProperties":{"datasetId":{"dataType":"string","required":true}},"required":true}, - "error": {"dataType":"enum","enums":[null],"required":true}, - }, - "additionalProperties": false, - }, - // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa - "Result__datasetId-string_.string_": { - "dataType": "refAlias", - "type": {"dataType":"union","subSchemas":[{"ref":"ResultSuccess__datasetId-string__"},{"ref":"ResultError_string_"}],"validators":{}}, - }, - // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa - "DatasetMetadata": { - "dataType": "refObject", - "properties": { - "promptVersionId": {"dataType":"string"}, - "inputRecordsIds": {"dataType":"array","array":{"dataType":"string"}}, - }, - "additionalProperties": false, - }, - // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa - "NewDatasetParams": { - "dataType": "refObject", - "properties": { - "datasetName": {"dataType":"string","required":true}, - "requestIds": {"dataType":"array","array":{"dataType":"string"},"required":true}, - "datasetType": {"dataType":"union","subSchemas":[{"dataType":"enum","enums":["experiment"]},{"dataType":"enum","enums":["helicone"]}],"required":true}, - "meta": {"ref":"DatasetMetadata"}, - }, - "additionalProperties": false, - }, - // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa - "Partial_TimestampOperators_": { - "dataType": "refAlias", - "type": {"dataType":"nestedObjectLiteral","nestedProperties":{"gte":{"dataType":"string"},"lte":{"dataType":"string"},"lt":{"dataType":"string"},"gt":{"dataType":"string"}},"validators":{}}, - }, - // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa - "Partial_RequestTableToOperators_": { - "dataType": "refAlias", - "type": {"dataType":"nestedObjectLiteral","nestedProperties":{"prompt":{"ref":"Partial_TextOperators_"},"created_at":{"ref":"Partial_TimestampOperators_"},"user_id":{"ref":"Partial_TextOperators_"},"auth_hash":{"ref":"Partial_TextOperators_"},"org_id":{"ref":"Partial_TextOperators_"},"id":{"ref":"Partial_TextOperators_"},"node_id":{"ref":"Partial_TextOperators_"},"model":{"ref":"Partial_TextOperators_"},"modelOverride":{"ref":"Partial_TextOperators_"},"path":{"ref":"Partial_TextOperators_"},"prompt_id":{"ref":"Partial_TextOperators_"}},"validators":{}}, - }, - // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa - "Pick_FilterLeaf.request-or-prompts_versions_": { - "dataType": "refAlias", - "type": {"dataType":"nestedObjectLiteral","nestedProperties":{"request":{"ref":"Partial_RequestTableToOperators_"},"prompts_versions":{"ref":"Partial_PromptVersionsToOperators_"}},"validators":{}}, - }, - // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa - "FilterLeafSubset_request-or-prompts_versions_": { - "dataType": "refAlias", - "type": {"ref":"Pick_FilterLeaf.request-or-prompts_versions_","validators":{}}, - }, - // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa - "DatasetFilterNode": { - "dataType": "refAlias", - "type": {"dataType":"union","subSchemas":[{"ref":"FilterLeafSubset_request-or-prompts_versions_"},{"ref":"DatasetFilterBranch"},{"dataType":"enum","enums":["all"]}],"validators":{}}, - }, - // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa - "DatasetFilterBranch": { - "dataType": "refAlias", - "type": {"dataType":"nestedObjectLiteral","nestedProperties":{"right":{"ref":"DatasetFilterNode","required":true},"operator":{"dataType":"union","subSchemas":[{"dataType":"enum","enums":["or"]},{"dataType":"enum","enums":["and"]}],"required":true},"left":{"ref":"DatasetFilterNode","required":true}},"validators":{}}, - }, - // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa - "RandomDatasetParams": { - "dataType": "refObject", - "properties": { - "datasetName": {"dataType":"string","required":true}, - "filter": {"ref":"DatasetFilterNode","required":true}, - "offset": {"dataType":"double"}, - "limit": {"dataType":"double"}, - }, - "additionalProperties": false, - }, - // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa - "DatasetResult": { - "dataType": "refObject", - "properties": { - "id": {"dataType":"string","required":true}, - "name": {"dataType":"string","required":true}, - "created_at": {"dataType":"string","required":true}, - "meta": {"ref":"DatasetMetadata"}, - }, - "additionalProperties": false, - }, - // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa - "ResultSuccess_DatasetResult-Array_": { - "dataType": "refObject", - "properties": { - "data": {"dataType":"array","array":{"dataType":"refObject","ref":"DatasetResult"},"required":true}, - "error": {"dataType":"enum","enums":[null],"required":true}, - }, - "additionalProperties": false, - }, - // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa - "Result_DatasetResult-Array.string_": { - "dataType": "refAlias", - "type": {"dataType":"union","subSchemas":[{"ref":"ResultSuccess_DatasetResult-Array_"},{"ref":"ResultError_string_"}],"validators":{}}, - }, - // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa - "ResultSuccess___-Array_": { - "dataType": "refObject", - "properties": { - "data": {"dataType":"array","array":{"dataType":"nestedObjectLiteral","nestedProperties":{}},"required":true}, - "error": {"dataType":"enum","enums":[null],"required":true}, - }, - "additionalProperties": false, - }, - // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa - "Result___-Array.string_": { - "dataType": "refAlias", - "type": {"dataType":"union","subSchemas":[{"ref":"ResultSuccess___-Array_"},{"ref":"ResultError_string_"}],"validators":{}}, - }, - // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa "HeliconeDatasetMetadata": { "dataType": "refObject", "properties": { @@ -6004,14 +6004,14 @@ export function RegisterRoutes(app: Router) { } }); // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa - app.post('/v1/experiment/new-empty', + app.post('/v1/experiment/dataset', authenticateMiddleware([{"api_key":[]}]), - ...(fetchMiddlewares(ExperimentController)), - ...(fetchMiddlewares(ExperimentController.prototype.createNewEmptyExperiment)), + ...(fetchMiddlewares(ExperimentDatasetController)), + ...(fetchMiddlewares(ExperimentDatasetController.prototype.addDataset)), - async function ExperimentController_createNewEmptyExperiment(request: ExRequest, response: ExResponse, next: any) { + async function ExperimentDatasetController_addDataset(request: ExRequest, response: ExResponse, next: any) { const args: Record = { - requestBody: {"in":"body","name":"requestBody","required":true,"dataType":"nestedObjectLiteral","nestedProperties":{"datasetId":{"dataType":"string","required":true},"metadata":{"ref":"Record_string.string_","required":true}}}, + requestBody: {"in":"body","name":"requestBody","required":true,"ref":"NewDatasetParams"}, request: {"in":"request","name":"request","required":true,"dataType":"object"}, }; @@ -6021,10 +6021,10 @@ export function RegisterRoutes(app: Router) { try { validatedArgs = templateService.getValidatedArgs({ args, request, response }); - const controller = new ExperimentController(); + const controller = new ExperimentDatasetController(); await templateService.apiHandler({ - methodName: 'createNewEmptyExperiment', + methodName: 'addDataset', controller, response, next, @@ -6036,14 +6036,14 @@ export function RegisterRoutes(app: Router) { } }); // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa - app.post('/v1/experiment/table/new', + app.post('/v1/experiment/dataset/random', authenticateMiddleware([{"api_key":[]}]), - ...(fetchMiddlewares(ExperimentController)), - ...(fetchMiddlewares(ExperimentController.prototype.createNewExperimentTable)), + ...(fetchMiddlewares(ExperimentDatasetController)), + ...(fetchMiddlewares(ExperimentDatasetController.prototype.addRandomDataset)), - async function ExperimentController_createNewExperimentTable(request: ExRequest, response: ExResponse, next: any) { + async function ExperimentDatasetController_addRandomDataset(request: ExRequest, response: ExResponse, next: any) { const args: Record = { - requestBody: {"in":"body","name":"requestBody","required":true,"ref":"CreateExperimentTableParams"}, + requestBody: {"in":"body","name":"requestBody","required":true,"ref":"RandomDatasetParams"}, request: {"in":"request","name":"request","required":true,"dataType":"object"}, }; @@ -6053,10 +6053,10 @@ export function RegisterRoutes(app: Router) { try { validatedArgs = templateService.getValidatedArgs({ args, request, response }); - const controller = new ExperimentController(); + const controller = new ExperimentDatasetController(); await templateService.apiHandler({ - methodName: 'createNewExperimentTable', + methodName: 'addRandomDataset', controller, response, next, @@ -6068,14 +6068,14 @@ export function RegisterRoutes(app: Router) { } }); // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa - app.post('/v1/experiment/table/:experimentTableId/query', + app.post('/v1/experiment/dataset/query', authenticateMiddleware([{"api_key":[]}]), - ...(fetchMiddlewares(ExperimentController)), - ...(fetchMiddlewares(ExperimentController.prototype.getExperimentTableById)), + ...(fetchMiddlewares(ExperimentDatasetController)), + ...(fetchMiddlewares(ExperimentDatasetController.prototype.getDatasets)), - async function ExperimentController_getExperimentTableById(request: ExRequest, response: ExResponse, next: any) { + async function ExperimentDatasetController_getDatasets(request: ExRequest, response: ExResponse, next: any) { const args: Record = { - experimentTableId: {"in":"path","name":"experimentTableId","required":true,"dataType":"string"}, + requestBody: {"in":"body","name":"requestBody","required":true,"dataType":"nestedObjectLiteral","nestedProperties":{"promptVersionId":{"dataType":"string"}}}, request: {"in":"request","name":"request","required":true,"dataType":"object"}, }; @@ -6085,10 +6085,10 @@ export function RegisterRoutes(app: Router) { try { validatedArgs = templateService.getValidatedArgs({ args, request, response }); - const controller = new ExperimentController(); + const controller = new ExperimentDatasetController(); await templateService.apiHandler({ - methodName: 'getExperimentTableById', + methodName: 'getDatasets', controller, response, next, @@ -6100,15 +6100,16 @@ export function RegisterRoutes(app: Router) { } }); // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa - app.post('/v1/experiment/table/:experimentTableId/metadata/query', + app.post('/v1/experiment/dataset/:datasetId/row/insert', authenticateMiddleware([{"api_key":[]}]), - ...(fetchMiddlewares(ExperimentController)), - ...(fetchMiddlewares(ExperimentController.prototype.getExperimentTableMetadata)), + ...(fetchMiddlewares(ExperimentDatasetController)), + ...(fetchMiddlewares(ExperimentDatasetController.prototype.insertDatasetRow)), - async function ExperimentController_getExperimentTableMetadata(request: ExRequest, response: ExResponse, next: any) { + async function ExperimentDatasetController_insertDatasetRow(request: ExRequest, response: ExResponse, next: any) { const args: Record = { - experimentTableId: {"in":"path","name":"experimentTableId","required":true,"dataType":"string"}, + requestBody: {"in":"body","name":"requestBody","required":true,"dataType":"nestedObjectLiteral","nestedProperties":{"originalColumnId":{"dataType":"string"},"inputs":{"ref":"Record_string.string_","required":true},"inputRecordId":{"dataType":"string","required":true}}}, request: {"in":"request","name":"request","required":true,"dataType":"object"}, + datasetId: {"in":"path","name":"datasetId","required":true,"dataType":"string"}, }; // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa @@ -6117,10 +6118,10 @@ export function RegisterRoutes(app: Router) { try { validatedArgs = templateService.getValidatedArgs({ args, request, response }); - const controller = new ExperimentController(); + const controller = new ExperimentDatasetController(); await templateService.apiHandler({ - methodName: 'getExperimentTableMetadata', + methodName: 'insertDatasetRow', controller, response, next, @@ -6132,14 +6133,17 @@ export function RegisterRoutes(app: Router) { } }); // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa - app.post('/v1/experiment/tables/query', + app.post('/v1/experiment/dataset/:datasetId/version/:promptVersionId/row/new', authenticateMiddleware([{"api_key":[]}]), - ...(fetchMiddlewares(ExperimentController)), - ...(fetchMiddlewares(ExperimentController.prototype.getExperimentTables)), + ...(fetchMiddlewares(ExperimentDatasetController)), + ...(fetchMiddlewares(ExperimentDatasetController.prototype.createDatasetRow)), - async function ExperimentController_getExperimentTables(request: ExRequest, response: ExResponse, next: any) { + async function ExperimentDatasetController_createDatasetRow(request: ExRequest, response: ExResponse, next: any) { const args: Record = { + requestBody: {"in":"body","name":"requestBody","required":true,"dataType":"nestedObjectLiteral","nestedProperties":{"sourceRequest":{"dataType":"string"},"inputs":{"ref":"Record_string.string_","required":true}}}, request: {"in":"request","name":"request","required":true,"dataType":"object"}, + datasetId: {"in":"path","name":"datasetId","required":true,"dataType":"string"}, + promptVersionId: {"in":"path","name":"promptVersionId","required":true,"dataType":"string"}, }; // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa @@ -6148,10 +6152,10 @@ export function RegisterRoutes(app: Router) { try { validatedArgs = templateService.getValidatedArgs({ args, request, response }); - const controller = new ExperimentController(); + const controller = new ExperimentDatasetController(); await templateService.apiHandler({ - methodName: 'getExperimentTables', + methodName: 'createDatasetRow', controller, response, next, @@ -6163,16 +6167,15 @@ export function RegisterRoutes(app: Router) { } }); // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa - app.post('/v1/experiment/table/:experimentTableId/cell', + app.post('/v1/experiment/dataset/:datasetId/inputs/query', authenticateMiddleware([{"api_key":[]}]), - ...(fetchMiddlewares(ExperimentController)), - ...(fetchMiddlewares(ExperimentController.prototype.createExperimentCell)), + ...(fetchMiddlewares(ExperimentDatasetController)), + ...(fetchMiddlewares(ExperimentDatasetController.prototype.getDataset)), - async function ExperimentController_createExperimentCell(request: ExRequest, response: ExResponse, next: any) { + async function ExperimentDatasetController_getDataset(request: ExRequest, response: ExResponse, next: any) { const args: Record = { - experimentTableId: {"in":"path","name":"experimentTableId","required":true,"dataType":"string"}, - requestBody: {"in":"body","name":"requestBody","required":true,"dataType":"nestedObjectLiteral","nestedProperties":{"value":{"dataType":"union","subSchemas":[{"dataType":"string"},{"dataType":"enum","enums":[null]}],"required":true},"rowIndex":{"dataType":"double","required":true},"columnId":{"dataType":"string","required":true}}}, request: {"in":"request","name":"request","required":true,"dataType":"object"}, + datasetId: {"in":"path","name":"datasetId","required":true,"dataType":"string"}, }; // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa @@ -6181,10 +6184,10 @@ export function RegisterRoutes(app: Router) { try { validatedArgs = templateService.getValidatedArgs({ args, request, response }); - const controller = new ExperimentController(); + const controller = new ExperimentDatasetController(); await templateService.apiHandler({ - methodName: 'createExperimentCell', + methodName: 'getDataset', controller, response, next, @@ -6196,15 +6199,14 @@ export function RegisterRoutes(app: Router) { } }); // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa - app.patch('/v1/experiment/table/:experimentTableId/cell', + app.post('/v1/experiment/dataset/:datasetId/mutate', authenticateMiddleware([{"api_key":[]}]), - ...(fetchMiddlewares(ExperimentController)), - ...(fetchMiddlewares(ExperimentController.prototype.updateExperimentCell)), + ...(fetchMiddlewares(ExperimentDatasetController)), + ...(fetchMiddlewares(ExperimentDatasetController.prototype.mutateDataset)), - async function ExperimentController_updateExperimentCell(request: ExRequest, response: ExResponse, next: any) { + async function ExperimentDatasetController_mutateDataset(request: ExRequest, response: ExResponse, next: any) { const args: Record = { - experimentTableId: {"in":"path","name":"experimentTableId","required":true,"dataType":"string"}, - requestBody: {"in":"body","name":"requestBody","required":true,"dataType":"nestedObjectLiteral","nestedProperties":{"updateInputs":{"dataType":"boolean"},"metadata":{"dataType":"string"},"value":{"dataType":"string"},"status":{"dataType":"string"},"cellId":{"dataType":"string","required":true}}}, + requestBody: {"in":"body","name":"requestBody","required":true,"dataType":"nestedObjectLiteral","nestedProperties":{"removeRequests":{"dataType":"array","array":{"dataType":"string"},"required":true},"addRequests":{"dataType":"array","array":{"dataType":"string"},"required":true}}}, request: {"in":"request","name":"request","required":true,"dataType":"object"}, }; @@ -6214,10 +6216,10 @@ export function RegisterRoutes(app: Router) { try { validatedArgs = templateService.getValidatedArgs({ args, request, response }); - const controller = new ExperimentController(); + const controller = new ExperimentDatasetController(); await templateService.apiHandler({ - methodName: 'updateExperimentCell', + methodName: 'mutateDataset', controller, response, next, @@ -6229,15 +6231,14 @@ export function RegisterRoutes(app: Router) { } }); // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa - app.post('/v1/experiment/table/:experimentTableId/column', + app.post('/v1/experiment/new-empty', authenticateMiddleware([{"api_key":[]}]), ...(fetchMiddlewares(ExperimentController)), - ...(fetchMiddlewares(ExperimentController.prototype.createExperimentColumn)), + ...(fetchMiddlewares(ExperimentController.prototype.createNewEmptyExperiment)), - async function ExperimentController_createExperimentColumn(request: ExRequest, response: ExResponse, next: any) { + async function ExperimentController_createNewEmptyExperiment(request: ExRequest, response: ExResponse, next: any) { const args: Record = { - experimentTableId: {"in":"path","name":"experimentTableId","required":true,"dataType":"string"}, - requestBody: {"in":"body","name":"requestBody","required":true,"dataType":"nestedObjectLiteral","nestedProperties":{"inputKeys":{"dataType":"array","array":{"dataType":"string"}},"promptVersionId":{"dataType":"string"},"hypothesisId":{"dataType":"string"},"columnType":{"dataType":"string","required":true},"columnName":{"dataType":"string","required":true}}}, + requestBody: {"in":"body","name":"requestBody","required":true,"dataType":"nestedObjectLiteral","nestedProperties":{"datasetId":{"dataType":"string","required":true},"metadata":{"ref":"Record_string.string_","required":true}}}, request: {"in":"request","name":"request","required":true,"dataType":"object"}, }; @@ -6250,7 +6251,7 @@ export function RegisterRoutes(app: Router) { const controller = new ExperimentController(); await templateService.apiHandler({ - methodName: 'createExperimentColumn', + methodName: 'createNewEmptyExperiment', controller, response, next, @@ -6262,15 +6263,14 @@ export function RegisterRoutes(app: Router) { } }); // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa - app.post('/v1/experiment/table/:experimentTableId/row/new', + app.post('/v1/experiment/table/new', authenticateMiddleware([{"api_key":[]}]), ...(fetchMiddlewares(ExperimentController)), - ...(fetchMiddlewares(ExperimentController.prototype.createExperimentTableRow)), + ...(fetchMiddlewares(ExperimentController.prototype.createNewExperimentTable)), - async function ExperimentController_createExperimentTableRow(request: ExRequest, response: ExResponse, next: any) { + async function ExperimentController_createNewExperimentTable(request: ExRequest, response: ExResponse, next: any) { const args: Record = { - experimentTableId: {"in":"path","name":"experimentTableId","required":true,"dataType":"string"}, - requestBody: {"in":"body","name":"requestBody","required":true,"dataType":"nestedObjectLiteral","nestedProperties":{"inputs":{"ref":"Record_string.string_"},"sourceRequest":{"dataType":"string"},"promptVersionId":{"dataType":"string","required":true}}}, + requestBody: {"in":"body","name":"requestBody","required":true,"ref":"CreateExperimentTableParams"}, request: {"in":"request","name":"request","required":true,"dataType":"object"}, }; @@ -6283,7 +6283,7 @@ export function RegisterRoutes(app: Router) { const controller = new ExperimentController(); await templateService.apiHandler({ - methodName: 'createExperimentTableRow', + methodName: 'createNewExperimentTable', controller, response, next, @@ -6295,15 +6295,14 @@ export function RegisterRoutes(app: Router) { } }); // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa - app.delete('/v1/experiment/table/:experimentTableId/row/:rowIndex', + app.post('/v1/experiment/table/:experimentTableId/query', authenticateMiddleware([{"api_key":[]}]), ...(fetchMiddlewares(ExperimentController)), - ...(fetchMiddlewares(ExperimentController.prototype.deleteExperimentTableRow)), + ...(fetchMiddlewares(ExperimentController.prototype.getExperimentTableById)), - async function ExperimentController_deleteExperimentTableRow(request: ExRequest, response: ExResponse, next: any) { + async function ExperimentController_getExperimentTableById(request: ExRequest, response: ExResponse, next: any) { const args: Record = { experimentTableId: {"in":"path","name":"experimentTableId","required":true,"dataType":"string"}, - rowIndex: {"in":"path","name":"rowIndex","required":true,"dataType":"double"}, request: {"in":"request","name":"request","required":true,"dataType":"object"}, }; @@ -6316,7 +6315,7 @@ export function RegisterRoutes(app: Router) { const controller = new ExperimentController(); await templateService.apiHandler({ - methodName: 'deleteExperimentTableRow', + methodName: 'getExperimentTableById', controller, response, next, @@ -6328,15 +6327,14 @@ export function RegisterRoutes(app: Router) { } }); // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa - app.post('/v1/experiment/table/:experimentTableId/row/insert/batch', + app.post('/v1/experiment/table/:experimentTableId/metadata/query', authenticateMiddleware([{"api_key":[]}]), ...(fetchMiddlewares(ExperimentController)), - ...(fetchMiddlewares(ExperimentController.prototype.createExperimentTableRowWithCellsBatch)), + ...(fetchMiddlewares(ExperimentController.prototype.getExperimentTableMetadata)), - async function ExperimentController_createExperimentTableRowWithCellsBatch(request: ExRequest, response: ExResponse, next: any) { + async function ExperimentController_getExperimentTableMetadata(request: ExRequest, response: ExResponse, next: any) { const args: Record = { experimentTableId: {"in":"path","name":"experimentTableId","required":true,"dataType":"string"}, - requestBody: {"in":"body","name":"requestBody","required":true,"dataType":"nestedObjectLiteral","nestedProperties":{"rows":{"dataType":"array","array":{"dataType":"nestedObjectLiteral","nestedProperties":{"sourceRequest":{"dataType":"string"},"cells":{"dataType":"array","array":{"dataType":"nestedObjectLiteral","nestedProperties":{"metadata":{"dataType":"any"},"value":{"dataType":"union","subSchemas":[{"dataType":"string"},{"dataType":"enum","enums":[null]}],"required":true},"columnId":{"dataType":"string","required":true}}},"required":true},"datasetId":{"dataType":"string","required":true},"inputs":{"ref":"Record_string.string_","required":true},"inputRecordId":{"dataType":"string","required":true}}},"required":true}}}, request: {"in":"request","name":"request","required":true,"dataType":"object"}, }; @@ -6349,7 +6347,7 @@ export function RegisterRoutes(app: Router) { const controller = new ExperimentController(); await templateService.apiHandler({ - methodName: 'createExperimentTableRowWithCellsBatch', + methodName: 'getExperimentTableMetadata', controller, response, next, @@ -6361,14 +6359,13 @@ export function RegisterRoutes(app: Router) { } }); // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa - app.post('/v1/experiment/update-meta', + app.post('/v1/experiment/tables/query', authenticateMiddleware([{"api_key":[]}]), ...(fetchMiddlewares(ExperimentController)), - ...(fetchMiddlewares(ExperimentController.prototype.updateExperimentMeta)), + ...(fetchMiddlewares(ExperimentController.prototype.getExperimentTables)), - async function ExperimentController_updateExperimentMeta(request: ExRequest, response: ExResponse, next: any) { + async function ExperimentController_getExperimentTables(request: ExRequest, response: ExResponse, next: any) { const args: Record = { - requestBody: {"in":"body","name":"requestBody","required":true,"dataType":"nestedObjectLiteral","nestedProperties":{"meta":{"ref":"Record_string.string_","required":true},"experimentId":{"dataType":"string","required":true}}}, request: {"in":"request","name":"request","required":true,"dataType":"object"}, }; @@ -6381,7 +6378,7 @@ export function RegisterRoutes(app: Router) { const controller = new ExperimentController(); await templateService.apiHandler({ - methodName: 'updateExperimentMeta', + methodName: 'getExperimentTables', controller, response, next, @@ -6393,14 +6390,15 @@ export function RegisterRoutes(app: Router) { } }); // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa - app.post('/v1/experiment', + app.post('/v1/experiment/table/:experimentTableId/cell', authenticateMiddleware([{"api_key":[]}]), ...(fetchMiddlewares(ExperimentController)), - ...(fetchMiddlewares(ExperimentController.prototype.createNewExperimentOld)), + ...(fetchMiddlewares(ExperimentController.prototype.createExperimentCell)), - async function ExperimentController_createNewExperimentOld(request: ExRequest, response: ExResponse, next: any) { + async function ExperimentController_createExperimentCell(request: ExRequest, response: ExResponse, next: any) { const args: Record = { - requestBody: {"in":"body","name":"requestBody","required":true,"ref":"NewExperimentParams"}, + experimentTableId: {"in":"path","name":"experimentTableId","required":true,"dataType":"string"}, + requestBody: {"in":"body","name":"requestBody","required":true,"dataType":"nestedObjectLiteral","nestedProperties":{"value":{"dataType":"union","subSchemas":[{"dataType":"string"},{"dataType":"enum","enums":[null]}],"required":true},"rowIndex":{"dataType":"double","required":true},"columnId":{"dataType":"string","required":true}}}, request: {"in":"request","name":"request","required":true,"dataType":"object"}, }; @@ -6413,7 +6411,7 @@ export function RegisterRoutes(app: Router) { const controller = new ExperimentController(); await templateService.apiHandler({ - methodName: 'createNewExperimentOld', + methodName: 'createExperimentCell', controller, response, next, @@ -6425,14 +6423,15 @@ export function RegisterRoutes(app: Router) { } }); // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa - app.post('/v1/experiment/hypothesis', + app.patch('/v1/experiment/table/:experimentTableId/cell', authenticateMiddleware([{"api_key":[]}]), ...(fetchMiddlewares(ExperimentController)), - ...(fetchMiddlewares(ExperimentController.prototype.createNewExperimentHypothesis)), + ...(fetchMiddlewares(ExperimentController.prototype.updateExperimentCell)), - async function ExperimentController_createNewExperimentHypothesis(request: ExRequest, response: ExResponse, next: any) { + async function ExperimentController_updateExperimentCell(request: ExRequest, response: ExResponse, next: any) { const args: Record = { - requestBody: {"in":"body","name":"requestBody","required":true,"dataType":"nestedObjectLiteral","nestedProperties":{"status":{"dataType":"union","subSchemas":[{"dataType":"enum","enums":["PENDING"]},{"dataType":"enum","enums":["RUNNING"]},{"dataType":"enum","enums":["COMPLETED"]},{"dataType":"enum","enums":["FAILED"]}],"required":true},"providerKeyId":{"dataType":"string","required":true},"promptVersion":{"dataType":"string","required":true},"model":{"dataType":"string","required":true},"experimentId":{"dataType":"string","required":true}}}, + experimentTableId: {"in":"path","name":"experimentTableId","required":true,"dataType":"string"}, + requestBody: {"in":"body","name":"requestBody","required":true,"dataType":"nestedObjectLiteral","nestedProperties":{"updateInputs":{"dataType":"boolean"},"metadata":{"dataType":"string"},"value":{"dataType":"string"},"status":{"dataType":"string"},"cellId":{"dataType":"string","required":true}}}, request: {"in":"request","name":"request","required":true,"dataType":"object"}, }; @@ -6445,7 +6444,7 @@ export function RegisterRoutes(app: Router) { const controller = new ExperimentController(); await templateService.apiHandler({ - methodName: 'createNewExperimentHypothesis', + methodName: 'updateExperimentCell', controller, response, next, @@ -6457,14 +6456,15 @@ export function RegisterRoutes(app: Router) { } }); // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa - app.post('/v1/experiment/hypothesis/:hypothesisId/scores/query', + app.post('/v1/experiment/table/:experimentTableId/column', authenticateMiddleware([{"api_key":[]}]), ...(fetchMiddlewares(ExperimentController)), - ...(fetchMiddlewares(ExperimentController.prototype.getExperimentHypothesisScores)), + ...(fetchMiddlewares(ExperimentController.prototype.createExperimentColumn)), - async function ExperimentController_getExperimentHypothesisScores(request: ExRequest, response: ExResponse, next: any) { + async function ExperimentController_createExperimentColumn(request: ExRequest, response: ExResponse, next: any) { const args: Record = { - hypothesisId: {"in":"path","name":"hypothesisId","required":true,"dataType":"string"}, + experimentTableId: {"in":"path","name":"experimentTableId","required":true,"dataType":"string"}, + requestBody: {"in":"body","name":"requestBody","required":true,"dataType":"nestedObjectLiteral","nestedProperties":{"inputKeys":{"dataType":"array","array":{"dataType":"string"}},"promptVersionId":{"dataType":"string"},"hypothesisId":{"dataType":"string"},"columnType":{"dataType":"string","required":true},"columnName":{"dataType":"string","required":true}}}, request: {"in":"request","name":"request","required":true,"dataType":"object"}, }; @@ -6477,7 +6477,7 @@ export function RegisterRoutes(app: Router) { const controller = new ExperimentController(); await templateService.apiHandler({ - methodName: 'getExperimentHypothesisScores', + methodName: 'createExperimentColumn', controller, response, next, @@ -6489,14 +6489,15 @@ export function RegisterRoutes(app: Router) { } }); // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa - app.get('/v1/experiment/:experimentId/evaluators', + app.post('/v1/experiment/table/:experimentTableId/row/new', authenticateMiddleware([{"api_key":[]}]), ...(fetchMiddlewares(ExperimentController)), - ...(fetchMiddlewares(ExperimentController.prototype.getExperimentEvaluators)), + ...(fetchMiddlewares(ExperimentController.prototype.createExperimentTableRow)), - async function ExperimentController_getExperimentEvaluators(request: ExRequest, response: ExResponse, next: any) { + async function ExperimentController_createExperimentTableRow(request: ExRequest, response: ExResponse, next: any) { const args: Record = { - experimentId: {"in":"path","name":"experimentId","required":true,"dataType":"string"}, + experimentTableId: {"in":"path","name":"experimentTableId","required":true,"dataType":"string"}, + requestBody: {"in":"body","name":"requestBody","required":true,"dataType":"nestedObjectLiteral","nestedProperties":{"inputs":{"ref":"Record_string.string_"},"sourceRequest":{"dataType":"string"},"promptVersionId":{"dataType":"string","required":true}}}, request: {"in":"request","name":"request","required":true,"dataType":"object"}, }; @@ -6509,7 +6510,7 @@ export function RegisterRoutes(app: Router) { const controller = new ExperimentController(); await templateService.apiHandler({ - methodName: 'getExperimentEvaluators', + methodName: 'createExperimentTableRow', controller, response, next, @@ -6521,14 +6522,15 @@ export function RegisterRoutes(app: Router) { } }); // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa - app.post('/v1/experiment/:experimentId/evaluators/run', + app.delete('/v1/experiment/table/:experimentTableId/row/:rowIndex', authenticateMiddleware([{"api_key":[]}]), ...(fetchMiddlewares(ExperimentController)), - ...(fetchMiddlewares(ExperimentController.prototype.runExperimentEvaluatorsOld)), + ...(fetchMiddlewares(ExperimentController.prototype.deleteExperimentTableRow)), - async function ExperimentController_runExperimentEvaluatorsOld(request: ExRequest, response: ExResponse, next: any) { + async function ExperimentController_deleteExperimentTableRow(request: ExRequest, response: ExResponse, next: any) { const args: Record = { - experimentId: {"in":"path","name":"experimentId","required":true,"dataType":"string"}, + experimentTableId: {"in":"path","name":"experimentTableId","required":true,"dataType":"string"}, + rowIndex: {"in":"path","name":"rowIndex","required":true,"dataType":"double"}, request: {"in":"request","name":"request","required":true,"dataType":"object"}, }; @@ -6541,7 +6543,7 @@ export function RegisterRoutes(app: Router) { const controller = new ExperimentController(); await templateService.apiHandler({ - methodName: 'runExperimentEvaluatorsOld', + methodName: 'deleteExperimentTableRow', controller, response, next, @@ -6553,15 +6555,15 @@ export function RegisterRoutes(app: Router) { } }); // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa - app.post('/v1/experiment/:experimentId/evaluators', + app.post('/v1/experiment/table/:experimentTableId/row/insert/batch', authenticateMiddleware([{"api_key":[]}]), ...(fetchMiddlewares(ExperimentController)), - ...(fetchMiddlewares(ExperimentController.prototype.createExperimentEvaluatorOld)), + ...(fetchMiddlewares(ExperimentController.prototype.createExperimentTableRowWithCellsBatch)), - async function ExperimentController_createExperimentEvaluatorOld(request: ExRequest, response: ExResponse, next: any) { + async function ExperimentController_createExperimentTableRowWithCellsBatch(request: ExRequest, response: ExResponse, next: any) { const args: Record = { - experimentId: {"in":"path","name":"experimentId","required":true,"dataType":"string"}, - requestBody: {"in":"body","name":"requestBody","required":true,"dataType":"nestedObjectLiteral","nestedProperties":{"evaluatorId":{"dataType":"string","required":true}}}, + experimentTableId: {"in":"path","name":"experimentTableId","required":true,"dataType":"string"}, + requestBody: {"in":"body","name":"requestBody","required":true,"dataType":"nestedObjectLiteral","nestedProperties":{"rows":{"dataType":"array","array":{"dataType":"nestedObjectLiteral","nestedProperties":{"sourceRequest":{"dataType":"string"},"cells":{"dataType":"array","array":{"dataType":"nestedObjectLiteral","nestedProperties":{"metadata":{"dataType":"any"},"value":{"dataType":"union","subSchemas":[{"dataType":"string"},{"dataType":"enum","enums":[null]}],"required":true},"columnId":{"dataType":"string","required":true}}},"required":true},"datasetId":{"dataType":"string","required":true},"inputs":{"ref":"Record_string.string_","required":true},"inputRecordId":{"dataType":"string","required":true}}},"required":true}}}, request: {"in":"request","name":"request","required":true,"dataType":"object"}, }; @@ -6574,7 +6576,7 @@ export function RegisterRoutes(app: Router) { const controller = new ExperimentController(); await templateService.apiHandler({ - methodName: 'createExperimentEvaluatorOld', + methodName: 'createExperimentTableRowWithCellsBatch', controller, response, next, @@ -6586,15 +6588,14 @@ export function RegisterRoutes(app: Router) { } }); // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa - app.delete('/v1/experiment/:experimentId/evaluators/:evaluatorId', + app.post('/v1/experiment/update-meta', authenticateMiddleware([{"api_key":[]}]), ...(fetchMiddlewares(ExperimentController)), - ...(fetchMiddlewares(ExperimentController.prototype.deleteExperimentEvaluatorOld)), + ...(fetchMiddlewares(ExperimentController.prototype.updateExperimentMeta)), - async function ExperimentController_deleteExperimentEvaluatorOld(request: ExRequest, response: ExResponse, next: any) { + async function ExperimentController_updateExperimentMeta(request: ExRequest, response: ExResponse, next: any) { const args: Record = { - experimentId: {"in":"path","name":"experimentId","required":true,"dataType":"string"}, - evaluatorId: {"in":"path","name":"evaluatorId","required":true,"dataType":"string"}, + requestBody: {"in":"body","name":"requestBody","required":true,"dataType":"nestedObjectLiteral","nestedProperties":{"meta":{"ref":"Record_string.string_","required":true},"experimentId":{"dataType":"string","required":true}}}, request: {"in":"request","name":"request","required":true,"dataType":"object"}, }; @@ -6607,7 +6608,7 @@ export function RegisterRoutes(app: Router) { const controller = new ExperimentController(); await templateService.apiHandler({ - methodName: 'deleteExperimentEvaluatorOld', + methodName: 'updateExperimentMeta', controller, response, next, @@ -6619,14 +6620,14 @@ export function RegisterRoutes(app: Router) { } }); // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa - app.post('/v1/experiment/query', + app.post('/v1/experiment', authenticateMiddleware([{"api_key":[]}]), ...(fetchMiddlewares(ExperimentController)), - ...(fetchMiddlewares(ExperimentController.prototype.getExperimentsOld)), + ...(fetchMiddlewares(ExperimentController.prototype.createNewExperimentOld)), - async function ExperimentController_getExperimentsOld(request: ExRequest, response: ExResponse, next: any) { + async function ExperimentController_createNewExperimentOld(request: ExRequest, response: ExResponse, next: any) { const args: Record = { - requestBody: {"in":"body","name":"requestBody","required":true,"dataType":"nestedObjectLiteral","nestedProperties":{"include":{"ref":"IncludeExperimentKeys"},"filter":{"ref":"ExperimentFilterNode","required":true}}}, + requestBody: {"in":"body","name":"requestBody","required":true,"ref":"NewExperimentParams"}, request: {"in":"request","name":"request","required":true,"dataType":"object"}, }; @@ -6639,7 +6640,7 @@ export function RegisterRoutes(app: Router) { const controller = new ExperimentController(); await templateService.apiHandler({ - methodName: 'getExperimentsOld', + methodName: 'createNewExperimentOld', controller, response, next, @@ -6651,14 +6652,14 @@ export function RegisterRoutes(app: Router) { } }); // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa - app.post('/v1/experiment/dataset', + app.post('/v1/experiment/hypothesis', authenticateMiddleware([{"api_key":[]}]), - ...(fetchMiddlewares(ExperimentDatasetController)), - ...(fetchMiddlewares(ExperimentDatasetController.prototype.addDataset)), + ...(fetchMiddlewares(ExperimentController)), + ...(fetchMiddlewares(ExperimentController.prototype.createNewExperimentHypothesis)), - async function ExperimentDatasetController_addDataset(request: ExRequest, response: ExResponse, next: any) { + async function ExperimentController_createNewExperimentHypothesis(request: ExRequest, response: ExResponse, next: any) { const args: Record = { - requestBody: {"in":"body","name":"requestBody","required":true,"ref":"NewDatasetParams"}, + requestBody: {"in":"body","name":"requestBody","required":true,"dataType":"nestedObjectLiteral","nestedProperties":{"status":{"dataType":"union","subSchemas":[{"dataType":"enum","enums":["PENDING"]},{"dataType":"enum","enums":["RUNNING"]},{"dataType":"enum","enums":["COMPLETED"]},{"dataType":"enum","enums":["FAILED"]}],"required":true},"providerKeyId":{"dataType":"string","required":true},"promptVersion":{"dataType":"string","required":true},"model":{"dataType":"string","required":true},"experimentId":{"dataType":"string","required":true}}}, request: {"in":"request","name":"request","required":true,"dataType":"object"}, }; @@ -6668,10 +6669,10 @@ export function RegisterRoutes(app: Router) { try { validatedArgs = templateService.getValidatedArgs({ args, request, response }); - const controller = new ExperimentDatasetController(); + const controller = new ExperimentController(); await templateService.apiHandler({ - methodName: 'addDataset', + methodName: 'createNewExperimentHypothesis', controller, response, next, @@ -6683,14 +6684,14 @@ export function RegisterRoutes(app: Router) { } }); // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa - app.post('/v1/experiment/dataset/random', + app.post('/v1/experiment/hypothesis/:hypothesisId/scores/query', authenticateMiddleware([{"api_key":[]}]), - ...(fetchMiddlewares(ExperimentDatasetController)), - ...(fetchMiddlewares(ExperimentDatasetController.prototype.addRandomDataset)), + ...(fetchMiddlewares(ExperimentController)), + ...(fetchMiddlewares(ExperimentController.prototype.getExperimentHypothesisScores)), - async function ExperimentDatasetController_addRandomDataset(request: ExRequest, response: ExResponse, next: any) { + async function ExperimentController_getExperimentHypothesisScores(request: ExRequest, response: ExResponse, next: any) { const args: Record = { - requestBody: {"in":"body","name":"requestBody","required":true,"ref":"RandomDatasetParams"}, + hypothesisId: {"in":"path","name":"hypothesisId","required":true,"dataType":"string"}, request: {"in":"request","name":"request","required":true,"dataType":"object"}, }; @@ -6700,10 +6701,10 @@ export function RegisterRoutes(app: Router) { try { validatedArgs = templateService.getValidatedArgs({ args, request, response }); - const controller = new ExperimentDatasetController(); + const controller = new ExperimentController(); await templateService.apiHandler({ - methodName: 'addRandomDataset', + methodName: 'getExperimentHypothesisScores', controller, response, next, @@ -6715,14 +6716,14 @@ export function RegisterRoutes(app: Router) { } }); // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa - app.post('/v1/experiment/dataset/query', + app.get('/v1/experiment/:experimentId/evaluators', authenticateMiddleware([{"api_key":[]}]), - ...(fetchMiddlewares(ExperimentDatasetController)), - ...(fetchMiddlewares(ExperimentDatasetController.prototype.getDatasets)), + ...(fetchMiddlewares(ExperimentController)), + ...(fetchMiddlewares(ExperimentController.prototype.getExperimentEvaluators)), - async function ExperimentDatasetController_getDatasets(request: ExRequest, response: ExResponse, next: any) { + async function ExperimentController_getExperimentEvaluators(request: ExRequest, response: ExResponse, next: any) { const args: Record = { - requestBody: {"in":"body","name":"requestBody","required":true,"dataType":"nestedObjectLiteral","nestedProperties":{"promptVersionId":{"dataType":"string"}}}, + experimentId: {"in":"path","name":"experimentId","required":true,"dataType":"string"}, request: {"in":"request","name":"request","required":true,"dataType":"object"}, }; @@ -6732,10 +6733,10 @@ export function RegisterRoutes(app: Router) { try { validatedArgs = templateService.getValidatedArgs({ args, request, response }); - const controller = new ExperimentDatasetController(); + const controller = new ExperimentController(); await templateService.apiHandler({ - methodName: 'getDatasets', + methodName: 'getExperimentEvaluators', controller, response, next, @@ -6747,16 +6748,15 @@ export function RegisterRoutes(app: Router) { } }); // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa - app.post('/v1/experiment/dataset/:datasetId/row/insert', + app.post('/v1/experiment/:experimentId/evaluators/run', authenticateMiddleware([{"api_key":[]}]), - ...(fetchMiddlewares(ExperimentDatasetController)), - ...(fetchMiddlewares(ExperimentDatasetController.prototype.insertDatasetRow)), + ...(fetchMiddlewares(ExperimentController)), + ...(fetchMiddlewares(ExperimentController.prototype.runExperimentEvaluatorsOld)), - async function ExperimentDatasetController_insertDatasetRow(request: ExRequest, response: ExResponse, next: any) { + async function ExperimentController_runExperimentEvaluatorsOld(request: ExRequest, response: ExResponse, next: any) { const args: Record = { - requestBody: {"in":"body","name":"requestBody","required":true,"dataType":"nestedObjectLiteral","nestedProperties":{"originalColumnId":{"dataType":"string"},"inputs":{"ref":"Record_string.string_","required":true},"inputRecordId":{"dataType":"string","required":true}}}, + experimentId: {"in":"path","name":"experimentId","required":true,"dataType":"string"}, request: {"in":"request","name":"request","required":true,"dataType":"object"}, - datasetId: {"in":"path","name":"datasetId","required":true,"dataType":"string"}, }; // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa @@ -6765,10 +6765,10 @@ export function RegisterRoutes(app: Router) { try { validatedArgs = templateService.getValidatedArgs({ args, request, response }); - const controller = new ExperimentDatasetController(); + const controller = new ExperimentController(); await templateService.apiHandler({ - methodName: 'insertDatasetRow', + methodName: 'runExperimentEvaluatorsOld', controller, response, next, @@ -6780,17 +6780,16 @@ export function RegisterRoutes(app: Router) { } }); // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa - app.post('/v1/experiment/dataset/:datasetId/version/:promptVersionId/row/new', + app.post('/v1/experiment/:experimentId/evaluators', authenticateMiddleware([{"api_key":[]}]), - ...(fetchMiddlewares(ExperimentDatasetController)), - ...(fetchMiddlewares(ExperimentDatasetController.prototype.createDatasetRow)), + ...(fetchMiddlewares(ExperimentController)), + ...(fetchMiddlewares(ExperimentController.prototype.createExperimentEvaluatorOld)), - async function ExperimentDatasetController_createDatasetRow(request: ExRequest, response: ExResponse, next: any) { + async function ExperimentController_createExperimentEvaluatorOld(request: ExRequest, response: ExResponse, next: any) { const args: Record = { - requestBody: {"in":"body","name":"requestBody","required":true,"dataType":"nestedObjectLiteral","nestedProperties":{"sourceRequest":{"dataType":"string"},"inputs":{"ref":"Record_string.string_","required":true}}}, + experimentId: {"in":"path","name":"experimentId","required":true,"dataType":"string"}, + requestBody: {"in":"body","name":"requestBody","required":true,"dataType":"nestedObjectLiteral","nestedProperties":{"evaluatorId":{"dataType":"string","required":true}}}, request: {"in":"request","name":"request","required":true,"dataType":"object"}, - datasetId: {"in":"path","name":"datasetId","required":true,"dataType":"string"}, - promptVersionId: {"in":"path","name":"promptVersionId","required":true,"dataType":"string"}, }; // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa @@ -6799,10 +6798,10 @@ export function RegisterRoutes(app: Router) { try { validatedArgs = templateService.getValidatedArgs({ args, request, response }); - const controller = new ExperimentDatasetController(); + const controller = new ExperimentController(); await templateService.apiHandler({ - methodName: 'createDatasetRow', + methodName: 'createExperimentEvaluatorOld', controller, response, next, @@ -6814,15 +6813,16 @@ export function RegisterRoutes(app: Router) { } }); // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa - app.post('/v1/experiment/dataset/:datasetId/inputs/query', + app.delete('/v1/experiment/:experimentId/evaluators/:evaluatorId', authenticateMiddleware([{"api_key":[]}]), - ...(fetchMiddlewares(ExperimentDatasetController)), - ...(fetchMiddlewares(ExperimentDatasetController.prototype.getDataset)), + ...(fetchMiddlewares(ExperimentController)), + ...(fetchMiddlewares(ExperimentController.prototype.deleteExperimentEvaluatorOld)), - async function ExperimentDatasetController_getDataset(request: ExRequest, response: ExResponse, next: any) { + async function ExperimentController_deleteExperimentEvaluatorOld(request: ExRequest, response: ExResponse, next: any) { const args: Record = { + experimentId: {"in":"path","name":"experimentId","required":true,"dataType":"string"}, + evaluatorId: {"in":"path","name":"evaluatorId","required":true,"dataType":"string"}, request: {"in":"request","name":"request","required":true,"dataType":"object"}, - datasetId: {"in":"path","name":"datasetId","required":true,"dataType":"string"}, }; // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa @@ -6831,10 +6831,10 @@ export function RegisterRoutes(app: Router) { try { validatedArgs = templateService.getValidatedArgs({ args, request, response }); - const controller = new ExperimentDatasetController(); + const controller = new ExperimentController(); await templateService.apiHandler({ - methodName: 'getDataset', + methodName: 'deleteExperimentEvaluatorOld', controller, response, next, @@ -6846,14 +6846,14 @@ export function RegisterRoutes(app: Router) { } }); // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa - app.post('/v1/experiment/dataset/:datasetId/mutate', + app.post('/v1/experiment/query', authenticateMiddleware([{"api_key":[]}]), - ...(fetchMiddlewares(ExperimentDatasetController)), - ...(fetchMiddlewares(ExperimentDatasetController.prototype.mutateDataset)), + ...(fetchMiddlewares(ExperimentController)), + ...(fetchMiddlewares(ExperimentController.prototype.getExperimentsOld)), - async function ExperimentDatasetController_mutateDataset(request: ExRequest, response: ExResponse, next: any) { + async function ExperimentController_getExperimentsOld(request: ExRequest, response: ExResponse, next: any) { const args: Record = { - requestBody: {"in":"body","name":"requestBody","required":true,"dataType":"nestedObjectLiteral","nestedProperties":{"removeRequests":{"dataType":"array","array":{"dataType":"string"},"required":true},"addRequests":{"dataType":"array","array":{"dataType":"string"},"required":true}}}, + requestBody: {"in":"body","name":"requestBody","required":true,"dataType":"nestedObjectLiteral","nestedProperties":{"include":{"ref":"IncludeExperimentKeys"},"filter":{"ref":"ExperimentFilterNode","required":true}}}, request: {"in":"request","name":"request","required":true,"dataType":"object"}, }; @@ -6863,10 +6863,10 @@ export function RegisterRoutes(app: Router) { try { validatedArgs = templateService.getValidatedArgs({ args, request, response }); - const controller = new ExperimentDatasetController(); + const controller = new ExperimentController(); await templateService.apiHandler({ - methodName: 'mutateDataset', + methodName: 'getExperimentsOld', controller, response, next, @@ -8445,6 +8445,38 @@ export function RegisterRoutes(app: Router) { } }); // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa + app.post('/v1/pi/total_requests', + authenticateMiddleware([{"api_key":[]}]), + ...(fetchMiddlewares(PiController)), + ...(fetchMiddlewares(PiController.prototype.getTotalRequests)), + + async function PiController_getTotalRequests(request: ExRequest, response: ExResponse, next: any) { + const args: Record = { + body: {"in":"body","name":"body","required":true,"dataType":"nestedObjectLiteral","nestedProperties":{"endTime":{"dataType":"string","required":true},"startTime":{"dataType":"string","required":true}}}, + request: {"in":"request","name":"request","required":true,"dataType":"object"}, + }; + + // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa + + let validatedArgs: any[] = []; + try { + validatedArgs = templateService.getValidatedArgs({ args, request, response }); + + const controller = new PiController(); + + await templateService.apiHandler({ + methodName: 'getTotalRequests', + controller, + response, + next, + validatedArgs, + successStatus: undefined, + }); + } catch (err) { + return next(err); + } + }); + // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa app.get('/v1/settings/query', authenticateMiddleware([{"api_key":[]}]), ...(fetchMiddlewares(SettingController)), diff --git a/valhalla/jawn/src/tsoa-build/public/swagger.json b/valhalla/jawn/src/tsoa-build/public/swagger.json index bab2b06d5e..4078a90004 100644 --- a/valhalla/jawn/src/tsoa-build/public/swagger.json +++ b/valhalla/jawn/src/tsoa-build/public/swagger.json @@ -4567,20 +4567,16 @@ } ] }, - "ResultSuccess__tableId-string--experimentId-string__": { + "ResultSuccess__datasetId-string__": { "properties": { "data": { "properties": { - "experimentId": { - "type": "string" - }, - "tableId": { + "datasetId": { "type": "string" } }, "required": [ - "experimentId", - "tableId" + "datasetId" ], "type": "object" }, @@ -4599,109 +4595,197 @@ "type": "object", "additionalProperties": false }, - "Result__tableId-string--experimentId-string_.string_": { + "Result__datasetId-string_.string_": { "anyOf": [ { - "$ref": "#/components/schemas/ResultSuccess__tableId-string--experimentId-string__" + "$ref": "#/components/schemas/ResultSuccess__datasetId-string__" }, { "$ref": "#/components/schemas/ResultError_string_" } ] }, - "CreateExperimentTableParams": { + "DatasetMetadata": { "properties": { - "datasetId": { - "type": "string" - }, - "experimentMetadata": { - "$ref": "#/components/schemas/Record_string.any_" - }, "promptVersionId": { "type": "string" }, - "newHeliconeTemplate": { + "inputRecordsIds": { + "items": { + "type": "string" + }, + "type": "array" + } + }, + "type": "object", + "additionalProperties": false + }, + "NewDatasetParams": { + "properties": { + "datasetName": { "type": "string" }, - "isMajorVersion": { - "type": "boolean" + "requestIds": { + "items": { + "type": "string" + }, + "type": "array" }, - "promptSubversionMetadata": { - "$ref": "#/components/schemas/Record_string.any_" + "datasetType": { + "type": "string", + "enum": [ + "experiment", + "helicone" + ] }, - "experimentTableMetadata": { - "$ref": "#/components/schemas/Record_string.any_" + "meta": { + "$ref": "#/components/schemas/DatasetMetadata" } }, "required": [ - "datasetId", - "experimentMetadata", - "promptVersionId", - "newHeliconeTemplate", - "isMajorVersion", - "promptSubversionMetadata" + "datasetName", + "requestIds", + "datasetType" ], "type": "object", "additionalProperties": false }, - "ExperimentTableColumn": { + "Partial_TimestampOperators_": { "properties": { - "id": { + "gte": { "type": "string" }, - "columnName": { + "lte": { "type": "string" }, - "columnType": { + "lt": { "type": "string" }, - "hypothesisId": { + "gt": { "type": "string" + } + }, + "type": "object", + "description": "Make all properties in T optional" + }, + "Partial_RequestTableToOperators_": { + "properties": { + "prompt": { + "$ref": "#/components/schemas/Partial_TextOperators_" }, - "cells": { - "items": { - "properties": { - "metadata": { - "$ref": "#/components/schemas/Record_string.any_" - }, - "value": { - "type": "string", - "nullable": true - }, - "requestId": { - "type": "string" - }, - "rowIndex": { - "type": "number", - "format": "double" - }, - "id": { - "type": "string" - } - }, - "required": [ - "value", - "rowIndex", - "id" - ], - "type": "object" - }, - "type": "array" + "created_at": { + "$ref": "#/components/schemas/Partial_TimestampOperators_" }, - "metadata": { - "$ref": "#/components/schemas/Record_string.any_" + "user_id": { + "$ref": "#/components/schemas/Partial_TextOperators_" + }, + "auth_hash": { + "$ref": "#/components/schemas/Partial_TextOperators_" + }, + "org_id": { + "$ref": "#/components/schemas/Partial_TextOperators_" + }, + "id": { + "$ref": "#/components/schemas/Partial_TextOperators_" + }, + "node_id": { + "$ref": "#/components/schemas/Partial_TextOperators_" + }, + "model": { + "$ref": "#/components/schemas/Partial_TextOperators_" + }, + "modelOverride": { + "$ref": "#/components/schemas/Partial_TextOperators_" + }, + "path": { + "$ref": "#/components/schemas/Partial_TextOperators_" + }, + "prompt_id": { + "$ref": "#/components/schemas/Partial_TextOperators_" + } + }, + "type": "object", + "description": "Make all properties in T optional" + }, + "Pick_FilterLeaf.request-or-prompts_versions_": { + "properties": { + "request": { + "$ref": "#/components/schemas/Partial_RequestTableToOperators_" + }, + "prompts_versions": { + "$ref": "#/components/schemas/Partial_PromptVersionsToOperators_" + } + }, + "type": "object", + "description": "From T, pick a set of properties whose keys are in the union K" + }, + "FilterLeafSubset_request-or-prompts_versions_": { + "$ref": "#/components/schemas/Pick_FilterLeaf.request-or-prompts_versions_" + }, + "DatasetFilterNode": { + "anyOf": [ + { + "$ref": "#/components/schemas/FilterLeafSubset_request-or-prompts_versions_" + }, + { + "$ref": "#/components/schemas/DatasetFilterBranch" + }, + { + "type": "string", + "enum": [ + "all" + ] + } + ] + }, + "DatasetFilterBranch": { + "properties": { + "right": { + "$ref": "#/components/schemas/DatasetFilterNode" + }, + "operator": { + "type": "string", + "enum": [ + "or", + "and" + ] + }, + "left": { + "$ref": "#/components/schemas/DatasetFilterNode" } }, "required": [ - "id", - "columnName", - "columnType", - "cells" + "right", + "operator", + "left" + ], + "type": "object" + }, + "RandomDatasetParams": { + "properties": { + "datasetName": { + "type": "string" + }, + "filter": { + "$ref": "#/components/schemas/DatasetFilterNode" + }, + "offset": { + "type": "number", + "format": "double" + }, + "limit": { + "type": "number", + "format": "double" + } + }, + "required": [ + "datasetName", + "filter" ], "type": "object", "additionalProperties": false }, - "ExperimentTable": { + "DatasetResult": { "properties": { "id": { "type": "string" @@ -4709,32 +4793,28 @@ "name": { "type": "string" }, - "experimentId": { + "created_at": { "type": "string" }, - "columns": { - "items": { - "$ref": "#/components/schemas/ExperimentTableColumn" - }, - "type": "array" - }, - "metadata": { - "$ref": "#/components/schemas/Record_string.any_" + "meta": { + "$ref": "#/components/schemas/DatasetMetadata" } }, "required": [ "id", "name", - "experimentId", - "columns" + "created_at" ], "type": "object", "additionalProperties": false }, - "ResultSuccess_ExperimentTable_": { + "ResultSuccess_DatasetResult-Array_": { "properties": { "data": { - "$ref": "#/components/schemas/ExperimentTable" + "items": { + "$ref": "#/components/schemas/DatasetResult" + }, + "type": "array" }, "error": { "type": "number", @@ -4751,22 +4831,250 @@ "type": "object", "additionalProperties": false }, - "Result_ExperimentTable.string_": { + "Result_DatasetResult-Array.string_": { "anyOf": [ { - "$ref": "#/components/schemas/ResultSuccess_ExperimentTable_" + "$ref": "#/components/schemas/ResultSuccess_DatasetResult-Array_" }, { "$ref": "#/components/schemas/ResultError_string_" } ] }, - "ExperimentTableSimplified": { + "ResultSuccess___-Array_": { "properties": { - "id": { - "type": "string" - }, - "name": { + "data": { + "items": { + "properties": {}, + "type": "object" + }, + "type": "array" + }, + "error": { + "type": "number", + "enum": [ + null + ], + "nullable": true + } + }, + "required": [ + "data", + "error" + ], + "type": "object", + "additionalProperties": false + }, + "Result___-Array.string_": { + "anyOf": [ + { + "$ref": "#/components/schemas/ResultSuccess___-Array_" + }, + { + "$ref": "#/components/schemas/ResultError_string_" + } + ] + }, + "ResultSuccess__tableId-string--experimentId-string__": { + "properties": { + "data": { + "properties": { + "experimentId": { + "type": "string" + }, + "tableId": { + "type": "string" + } + }, + "required": [ + "experimentId", + "tableId" + ], + "type": "object" + }, + "error": { + "type": "number", + "enum": [ + null + ], + "nullable": true + } + }, + "required": [ + "data", + "error" + ], + "type": "object", + "additionalProperties": false + }, + "Result__tableId-string--experimentId-string_.string_": { + "anyOf": [ + { + "$ref": "#/components/schemas/ResultSuccess__tableId-string--experimentId-string__" + }, + { + "$ref": "#/components/schemas/ResultError_string_" + } + ] + }, + "CreateExperimentTableParams": { + "properties": { + "datasetId": { + "type": "string" + }, + "experimentMetadata": { + "$ref": "#/components/schemas/Record_string.any_" + }, + "promptVersionId": { + "type": "string" + }, + "newHeliconeTemplate": { + "type": "string" + }, + "isMajorVersion": { + "type": "boolean" + }, + "promptSubversionMetadata": { + "$ref": "#/components/schemas/Record_string.any_" + }, + "experimentTableMetadata": { + "$ref": "#/components/schemas/Record_string.any_" + } + }, + "required": [ + "datasetId", + "experimentMetadata", + "promptVersionId", + "newHeliconeTemplate", + "isMajorVersion", + "promptSubversionMetadata" + ], + "type": "object", + "additionalProperties": false + }, + "ExperimentTableColumn": { + "properties": { + "id": { + "type": "string" + }, + "columnName": { + "type": "string" + }, + "columnType": { + "type": "string" + }, + "hypothesisId": { + "type": "string" + }, + "cells": { + "items": { + "properties": { + "metadata": { + "$ref": "#/components/schemas/Record_string.any_" + }, + "value": { + "type": "string", + "nullable": true + }, + "requestId": { + "type": "string" + }, + "rowIndex": { + "type": "number", + "format": "double" + }, + "id": { + "type": "string" + } + }, + "required": [ + "value", + "rowIndex", + "id" + ], + "type": "object" + }, + "type": "array" + }, + "metadata": { + "$ref": "#/components/schemas/Record_string.any_" + } + }, + "required": [ + "id", + "columnName", + "columnType", + "cells" + ], + "type": "object", + "additionalProperties": false + }, + "ExperimentTable": { + "properties": { + "id": { + "type": "string" + }, + "name": { + "type": "string" + }, + "experimentId": { + "type": "string" + }, + "columns": { + "items": { + "$ref": "#/components/schemas/ExperimentTableColumn" + }, + "type": "array" + }, + "metadata": { + "$ref": "#/components/schemas/Record_string.any_" + } + }, + "required": [ + "id", + "name", + "experimentId", + "columns" + ], + "type": "object", + "additionalProperties": false + }, + "ResultSuccess_ExperimentTable_": { + "properties": { + "data": { + "$ref": "#/components/schemas/ExperimentTable" + }, + "error": { + "type": "number", + "enum": [ + null + ], + "nullable": true + } + }, + "required": [ + "data", + "error" + ], + "type": "object", + "additionalProperties": false + }, + "Result_ExperimentTable.string_": { + "anyOf": [ + { + "$ref": "#/components/schemas/ResultSuccess_ExperimentTable_" + }, + { + "$ref": "#/components/schemas/ResultError_string_" + } + ] + }, + "ExperimentTableSimplified": { + "properties": { + "id": { + "type": "string" + }, + "name": { "type": "string" }, "experimentId": { @@ -5466,335 +5774,27 @@ "type": "boolean", "enum": [ true - ], - "nullable": false - }, - "responseBodies": { - "type": "boolean", - "enum": [ - true - ], - "nullable": false - }, - "score": { - "type": "boolean", - "enum": [ - true - ], - "nullable": false - } - }, - "type": "object", - "additionalProperties": false - }, - "ResultSuccess__datasetId-string__": { - "properties": { - "data": { - "properties": { - "datasetId": { - "type": "string" - } - }, - "required": [ - "datasetId" - ], - "type": "object" - }, - "error": { - "type": "number", - "enum": [ - null - ], - "nullable": true - } - }, - "required": [ - "data", - "error" - ], - "type": "object", - "additionalProperties": false - }, - "Result__datasetId-string_.string_": { - "anyOf": [ - { - "$ref": "#/components/schemas/ResultSuccess__datasetId-string__" - }, - { - "$ref": "#/components/schemas/ResultError_string_" - } - ] - }, - "DatasetMetadata": { - "properties": { - "promptVersionId": { - "type": "string" - }, - "inputRecordsIds": { - "items": { - "type": "string" - }, - "type": "array" - } - }, - "type": "object", - "additionalProperties": false - }, - "NewDatasetParams": { - "properties": { - "datasetName": { - "type": "string" - }, - "requestIds": { - "items": { - "type": "string" - }, - "type": "array" - }, - "datasetType": { - "type": "string", - "enum": [ - "experiment", - "helicone" - ] - }, - "meta": { - "$ref": "#/components/schemas/DatasetMetadata" - } - }, - "required": [ - "datasetName", - "requestIds", - "datasetType" - ], - "type": "object", - "additionalProperties": false - }, - "Partial_TimestampOperators_": { - "properties": { - "gte": { - "type": "string" - }, - "lte": { - "type": "string" - }, - "lt": { - "type": "string" - }, - "gt": { - "type": "string" - } - }, - "type": "object", - "description": "Make all properties in T optional" - }, - "Partial_RequestTableToOperators_": { - "properties": { - "prompt": { - "$ref": "#/components/schemas/Partial_TextOperators_" - }, - "created_at": { - "$ref": "#/components/schemas/Partial_TimestampOperators_" - }, - "user_id": { - "$ref": "#/components/schemas/Partial_TextOperators_" - }, - "auth_hash": { - "$ref": "#/components/schemas/Partial_TextOperators_" - }, - "org_id": { - "$ref": "#/components/schemas/Partial_TextOperators_" - }, - "id": { - "$ref": "#/components/schemas/Partial_TextOperators_" - }, - "node_id": { - "$ref": "#/components/schemas/Partial_TextOperators_" - }, - "model": { - "$ref": "#/components/schemas/Partial_TextOperators_" - }, - "modelOverride": { - "$ref": "#/components/schemas/Partial_TextOperators_" - }, - "path": { - "$ref": "#/components/schemas/Partial_TextOperators_" - }, - "prompt_id": { - "$ref": "#/components/schemas/Partial_TextOperators_" - } - }, - "type": "object", - "description": "Make all properties in T optional" - }, - "Pick_FilterLeaf.request-or-prompts_versions_": { - "properties": { - "request": { - "$ref": "#/components/schemas/Partial_RequestTableToOperators_" - }, - "prompts_versions": { - "$ref": "#/components/schemas/Partial_PromptVersionsToOperators_" - } - }, - "type": "object", - "description": "From T, pick a set of properties whose keys are in the union K" - }, - "FilterLeafSubset_request-or-prompts_versions_": { - "$ref": "#/components/schemas/Pick_FilterLeaf.request-or-prompts_versions_" - }, - "DatasetFilterNode": { - "anyOf": [ - { - "$ref": "#/components/schemas/FilterLeafSubset_request-or-prompts_versions_" - }, - { - "$ref": "#/components/schemas/DatasetFilterBranch" - }, - { - "type": "string", - "enum": [ - "all" - ] - } - ] - }, - "DatasetFilterBranch": { - "properties": { - "right": { - "$ref": "#/components/schemas/DatasetFilterNode" - }, - "operator": { - "type": "string", - "enum": [ - "or", - "and" - ] - }, - "left": { - "$ref": "#/components/schemas/DatasetFilterNode" - } - }, - "required": [ - "right", - "operator", - "left" - ], - "type": "object" - }, - "RandomDatasetParams": { - "properties": { - "datasetName": { - "type": "string" - }, - "filter": { - "$ref": "#/components/schemas/DatasetFilterNode" - }, - "offset": { - "type": "number", - "format": "double" - }, - "limit": { - "type": "number", - "format": "double" - } - }, - "required": [ - "datasetName", - "filter" - ], - "type": "object", - "additionalProperties": false - }, - "DatasetResult": { - "properties": { - "id": { - "type": "string" - }, - "name": { - "type": "string" - }, - "created_at": { - "type": "string" - }, - "meta": { - "$ref": "#/components/schemas/DatasetMetadata" - } - }, - "required": [ - "id", - "name", - "created_at" - ], - "type": "object", - "additionalProperties": false - }, - "ResultSuccess_DatasetResult-Array_": { - "properties": { - "data": { - "items": { - "$ref": "#/components/schemas/DatasetResult" - }, - "type": "array" - }, - "error": { - "type": "number", - "enum": [ - null - ], - "nullable": true - } - }, - "required": [ - "data", - "error" - ], - "type": "object", - "additionalProperties": false - }, - "Result_DatasetResult-Array.string_": { - "anyOf": [ - { - "$ref": "#/components/schemas/ResultSuccess_DatasetResult-Array_" - }, - { - "$ref": "#/components/schemas/ResultError_string_" - } - ] - }, - "ResultSuccess___-Array_": { - "properties": { - "data": { - "items": { - "properties": {}, - "type": "object" - }, - "type": "array" + ], + "nullable": false }, - "error": { - "type": "number", + "responseBodies": { + "type": "boolean", "enum": [ - null + true ], - "nullable": true + "nullable": false + }, + "score": { + "type": "boolean", + "enum": [ + true + ], + "nullable": false } }, - "required": [ - "data", - "error" - ], "type": "object", "additionalProperties": false }, - "Result___-Array.string_": { - "anyOf": [ - { - "$ref": "#/components/schemas/ResultSuccess___-Array_" - }, - { - "$ref": "#/components/schemas/ResultError_string_" - } - ] - }, "HeliconeDatasetMetadata": { "properties": { "promptVersionId": { @@ -13393,23 +13393,23 @@ "parameters": [] } }, - "/v1/experiment/new-empty": { + "/v1/experiment/dataset": { "post": { - "operationId": "CreateNewEmptyExperiment", + "operationId": "AddDataset", "responses": { "200": { "description": "Ok", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Result__experimentId-string_.string_" + "$ref": "#/components/schemas/Result__datasetId-string_.string_" } } } } }, "tags": [ - "Experiment" + "Dataset" ], "security": [ { @@ -13422,42 +13422,30 @@ "content": { "application/json": { "schema": { - "properties": { - "datasetId": { - "type": "string" - }, - "metadata": { - "$ref": "#/components/schemas/Record_string.string_" - } - }, - "required": [ - "datasetId", - "metadata" - ], - "type": "object" + "$ref": "#/components/schemas/NewDatasetParams" } } } } } }, - "/v1/experiment/table/new": { + "/v1/experiment/dataset/random": { "post": { - "operationId": "CreateNewExperimentTable", + "operationId": "AddRandomDataset", "responses": { "200": { "description": "Ok", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Result__tableId-string--experimentId-string_.string_" + "$ref": "#/components/schemas/Result__datasetId-string_.string_" } } } } }, "tags": [ - "Experiment" + "Dataset" ], "security": [ { @@ -13470,65 +13458,71 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/CreateExperimentTableParams" + "$ref": "#/components/schemas/RandomDatasetParams" } } } } } }, - "/v1/experiment/table/{experimentTableId}/query": { + "/v1/experiment/dataset/query": { "post": { - "operationId": "GetExperimentTableById", + "operationId": "GetDatasets", "responses": { "200": { "description": "Ok", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Result_ExperimentTable.string_" + "$ref": "#/components/schemas/Result_DatasetResult-Array.string_" } } } } }, "tags": [ - "Experiment" + "Dataset" ], "security": [ { "api_key": [] } ], - "parameters": [ - { - "in": "path", - "name": "experimentTableId", - "required": true, - "schema": { - "type": "string" + "parameters": [], + "requestBody": { + "required": true, + "content": { + "application/json": { + "schema": { + "properties": { + "promptVersionId": { + "type": "string" + } + }, + "type": "object" + } } } - ] + } } }, - "/v1/experiment/table/{experimentTableId}/metadata/query": { + "/v1/experiment/dataset/{datasetId}/row/insert": { "post": { - "operationId": "GetExperimentTableMetadata", + "operationId": "InsertDatasetRow", "responses": { "200": { "description": "Ok", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Result_ExperimentTableSimplified.string_" + "$ref": "#/components/schemas/Result_string.string_" } } } } }, "tags": [ - "Experiment" + "Dataset" ], "security": [ { @@ -13538,58 +13532,57 @@ "parameters": [ { "in": "path", - "name": "experimentTableId", + "name": "datasetId", "required": true, "schema": { "type": "string" } } - ] - } - }, - "/v1/experiment/tables/query": { - "post": { - "operationId": "GetExperimentTables", - "responses": { - "200": { - "description": "Ok", - "content": { - "application/json": { - "schema": { - "$ref": "#/components/schemas/Result_ExperimentTableSimplified-Array.string_" - } + ], + "requestBody": { + "required": true, + "content": { + "application/json": { + "schema": { + "properties": { + "originalColumnId": { + "type": "string" + }, + "inputs": { + "$ref": "#/components/schemas/Record_string.string_" + }, + "inputRecordId": { + "type": "string" + } + }, + "required": [ + "inputs", + "inputRecordId" + ], + "type": "object" } } } - }, - "tags": [ - "Experiment" - ], - "security": [ - { - "api_key": [] - } - ], - "parameters": [] + } } }, - "/v1/experiment/table/{experimentTableId}/cell": { + "/v1/experiment/dataset/{datasetId}/version/{promptVersionId}/row/new": { "post": { - "operationId": "CreateExperimentCell", + "operationId": "CreateDatasetRow", "responses": { "200": { "description": "Ok", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Result_null.string_" + "$ref": "#/components/schemas/Result_string.string_" } } } } }, "tags": [ - "Experiment" + "Dataset" ], "security": [ { @@ -13599,7 +13592,15 @@ "parameters": [ { "in": "path", - "name": "experimentTableId", + "name": "datasetId", + "required": true, + "schema": { + "type": "string" + } + }, + { + "in": "path", + "name": "promptVersionId", "required": true, "schema": { "type": "string" @@ -13612,45 +13613,40 @@ "application/json": { "schema": { "properties": { - "value": { - "type": "string", - "nullable": true - }, - "rowIndex": { - "type": "number", - "format": "double" - }, - "columnId": { + "sourceRequest": { "type": "string" + }, + "inputs": { + "$ref": "#/components/schemas/Record_string.string_" } }, "required": [ - "value", - "rowIndex", - "columnId" + "inputs" ], "type": "object" } } } } - }, - "patch": { - "operationId": "UpdateExperimentCell", + } + }, + "/v1/experiment/dataset/{datasetId}/inputs/query": { + "post": { + "operationId": "GetDataset", "responses": { "200": { "description": "Ok", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Result_null.string_" + "$ref": "#/components/schemas/Result_PromptInputRecord-Array.string_" } } } } }, "tags": [ - "Experiment" + "Dataset" ], "security": [ { @@ -13660,106 +13656,61 @@ "parameters": [ { "in": "path", - "name": "experimentTableId", + "name": "datasetId", "required": true, "schema": { "type": "string" } } - ], - "requestBody": { - "required": true, - "content": { - "application/json": { - "schema": { - "properties": { - "updateInputs": { - "type": "boolean" - }, - "metadata": { - "type": "string" - }, - "value": { - "type": "string" - }, - "status": { - "type": "string" - }, - "cellId": { - "type": "string" - } - }, - "required": [ - "cellId" - ], - "type": "object" - } - } - } - } + ] } }, - "/v1/experiment/table/{experimentTableId}/column": { + "/v1/experiment/dataset/{datasetId}/mutate": { "post": { - "operationId": "CreateExperimentColumn", + "operationId": "MutateDataset", "responses": { "200": { "description": "Ok", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Result_null.string_" + "$ref": "#/components/schemas/Result___-Array.string_" } } } } }, "tags": [ - "Experiment" + "Dataset" ], "security": [ { "api_key": [] } ], - "parameters": [ - { - "in": "path", - "name": "experimentTableId", - "required": true, - "schema": { - "type": "string" - } - } - ], + "parameters": [], "requestBody": { "required": true, "content": { "application/json": { "schema": { "properties": { - "inputKeys": { + "removeRequests": { + "items": { + "type": "string" + }, + "type": "array" + }, + "addRequests": { "items": { "type": "string" }, "type": "array" - }, - "promptVersionId": { - "type": "string" - }, - "hypothesisId": { - "type": "string" - }, - "columnType": { - "type": "string" - }, - "columnName": { - "type": "string" } }, "required": [ - "columnType", - "columnName" + "removeRequests", + "addRequests" ], "type": "object" } @@ -13768,16 +13719,16 @@ } } }, - "/v1/experiment/table/{experimentTableId}/row/new": { + "/v1/experiment/new-empty": { "post": { - "operationId": "CreateExperimentTableRow", + "operationId": "CreateNewEmptyExperiment", "responses": { "200": { "description": "Ok", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Result_null.string_" + "$ref": "#/components/schemas/Result__experimentId-string_.string_" } } } @@ -13791,34 +13742,23 @@ "api_key": [] } ], - "parameters": [ - { - "in": "path", - "name": "experimentTableId", - "required": true, - "schema": { - "type": "string" - } - } - ], + "parameters": [], "requestBody": { "required": true, "content": { "application/json": { "schema": { "properties": { - "inputs": { - "$ref": "#/components/schemas/Record_string.string_" - }, - "sourceRequest": { + "datasetId": { "type": "string" }, - "promptVersionId": { - "type": "string" + "metadata": { + "$ref": "#/components/schemas/Record_string.string_" } }, "required": [ - "promptVersionId" + "datasetId", + "metadata" ], "type": "object" } @@ -13827,16 +13767,16 @@ } } }, - "/v1/experiment/table/{experimentTableId}/row/{rowIndex}": { - "delete": { - "operationId": "DeleteExperimentTableRow", + "/v1/experiment/table/new": { + "post": { + "operationId": "CreateNewExperimentTable", "responses": { "200": { "description": "Ok", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Result_null.string_" + "$ref": "#/components/schemas/Result__tableId-string--experimentId-string_.string_" } } } @@ -13850,37 +13790,29 @@ "api_key": [] } ], - "parameters": [ - { - "in": "path", - "name": "experimentTableId", - "required": true, - "schema": { - "type": "string" - } - }, - { - "in": "path", - "name": "rowIndex", - "required": true, - "schema": { - "format": "double", - "type": "number" + "parameters": [], + "requestBody": { + "required": true, + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/CreateExperimentTableParams" + } } } - ] + } } }, - "/v1/experiment/table/{experimentTableId}/row/insert/batch": { + "/v1/experiment/table/{experimentTableId}/query": { "post": { - "operationId": "CreateExperimentTableRowWithCellsBatch", + "operationId": "GetExperimentTableById", "responses": { "200": { "description": "Ok", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Result_null.string_" + "$ref": "#/components/schemas/Result_ExperimentTable.string_" } } } @@ -13903,87 +13835,19 @@ "type": "string" } } - ], - "requestBody": { - "required": true, - "content": { - "application/json": { - "schema": { - "properties": { - "rows": { - "items": { - "properties": { - "sourceRequest": { - "type": "string" - }, - "cells": { - "items": { - "properties": { - "metadata": {}, - "value": { - "type": "string", - "nullable": true - }, - "columnId": { - "type": "string" - } - }, - "required": [ - "value", - "columnId" - ], - "type": "object" - }, - "type": "array" - }, - "datasetId": { - "type": "string" - }, - "inputs": { - "$ref": "#/components/schemas/Record_string.string_" - }, - "inputRecordId": { - "type": "string" - } - }, - "required": [ - "cells", - "datasetId", - "inputs", - "inputRecordId" - ], - "type": "object" - }, - "type": "array" - } - }, - "required": [ - "rows" - ], - "type": "object" - } - } - } - } + ] } }, - "/v1/experiment/update-meta": { + "/v1/experiment/table/{experimentTableId}/metadata/query": { "post": { - "operationId": "UpdateExperimentMeta", + "operationId": "GetExperimentTableMetadata", "responses": { "200": { "description": "Ok", "content": { "application/json": { "schema": { - "anyOf": [ - { - "$ref": "#/components/schemas/ResultSuccess_unknown_" - }, - { - "$ref": "#/components/schemas/ResultError_PostgrestError_" - } - ] + "$ref": "#/components/schemas/Result_ExperimentTableSimplified.string_" } } } @@ -13997,41 +13861,28 @@ "api_key": [] } ], - "parameters": [], - "requestBody": { - "required": true, - "content": { - "application/json": { - "schema": { - "properties": { - "meta": { - "$ref": "#/components/schemas/Record_string.string_" - }, - "experimentId": { - "type": "string" - } - }, - "required": [ - "meta", - "experimentId" - ], - "type": "object" - } + "parameters": [ + { + "in": "path", + "name": "experimentTableId", + "required": true, + "schema": { + "type": "string" } } - } + ] } }, - "/v1/experiment": { + "/v1/experiment/tables/query": { "post": { - "operationId": "CreateNewExperimentOld", + "operationId": "GetExperimentTables", "responses": { "200": { "description": "Ok", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Result__experimentId-string_.string_" + "$ref": "#/components/schemas/Result_ExperimentTableSimplified-Array.string_" } } } @@ -14045,29 +13896,19 @@ "api_key": [] } ], - "parameters": [], - "requestBody": { - "required": true, - "content": { - "application/json": { - "schema": { - "$ref": "#/components/schemas/NewExperimentParams" - } - } - } - } + "parameters": [] } }, - "/v1/experiment/hypothesis": { + "/v1/experiment/table/{experimentTableId}/cell": { "post": { - "operationId": "CreateNewExperimentHypothesis", + "operationId": "CreateExperimentCell", "responses": { "200": { "description": "Ok", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Result__hypothesisId-string_.string_" + "$ref": "#/components/schemas/Result_null.string_" } } } @@ -14081,59 +13922,54 @@ "api_key": [] } ], - "parameters": [], + "parameters": [ + { + "in": "path", + "name": "experimentTableId", + "required": true, + "schema": { + "type": "string" + } + } + ], "requestBody": { "required": true, "content": { "application/json": { "schema": { "properties": { - "status": { + "value": { "type": "string", - "enum": [ - "PENDING", - "RUNNING", - "COMPLETED", - "FAILED" - ] - }, - "providerKeyId": { - "type": "string" - }, - "promptVersion": { - "type": "string" + "nullable": true }, - "model": { - "type": "string" + "rowIndex": { + "type": "number", + "format": "double" }, - "experimentId": { + "columnId": { "type": "string" } }, "required": [ - "status", - "providerKeyId", - "promptVersion", - "model", - "experimentId" + "value", + "rowIndex", + "columnId" ], "type": "object" } } } } - } - }, - "/v1/experiment/hypothesis/{hypothesisId}/scores/query": { - "post": { - "operationId": "GetExperimentHypothesisScores", + }, + "patch": { + "operationId": "UpdateExperimentCell", "responses": { "200": { "description": "Ok", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Result__runsCount-number--scores-Record_string.Score__.string_" + "$ref": "#/components/schemas/Result_null.string_" } } } @@ -14150,25 +13986,55 @@ "parameters": [ { "in": "path", - "name": "hypothesisId", + "name": "experimentTableId", "required": true, "schema": { "type": "string" } } - ] + ], + "requestBody": { + "required": true, + "content": { + "application/json": { + "schema": { + "properties": { + "updateInputs": { + "type": "boolean" + }, + "metadata": { + "type": "string" + }, + "value": { + "type": "string" + }, + "status": { + "type": "string" + }, + "cellId": { + "type": "string" + } + }, + "required": [ + "cellId" + ], + "type": "object" + } + } + } + } } }, - "/v1/experiment/{experimentId}/evaluators": { - "get": { - "operationId": "GetExperimentEvaluators", + "/v1/experiment/table/{experimentTableId}/column": { + "post": { + "operationId": "CreateExperimentColumn", "responses": { "200": { "description": "Ok", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Result_EvaluatorResult-Array.string_" + "$ref": "#/components/schemas/Result_null.string_" } } } @@ -14185,16 +14051,52 @@ "parameters": [ { "in": "path", - "name": "experimentId", + "name": "experimentTableId", "required": true, "schema": { "type": "string" } } - ] - }, + ], + "requestBody": { + "required": true, + "content": { + "application/json": { + "schema": { + "properties": { + "inputKeys": { + "items": { + "type": "string" + }, + "type": "array" + }, + "promptVersionId": { + "type": "string" + }, + "hypothesisId": { + "type": "string" + }, + "columnType": { + "type": "string" + }, + "columnName": { + "type": "string" + } + }, + "required": [ + "columnType", + "columnName" + ], + "type": "object" + } + } + } + } + } + }, + "/v1/experiment/table/{experimentTableId}/row/new": { "post": { - "operationId": "CreateExperimentEvaluatorOld", + "operationId": "CreateExperimentTableRow", "responses": { "200": { "description": "Ok", @@ -14218,7 +14120,7 @@ "parameters": [ { "in": "path", - "name": "experimentId", + "name": "experimentTableId", "required": true, "schema": { "type": "string" @@ -14231,12 +14133,18 @@ "application/json": { "schema": { "properties": { - "evaluatorId": { + "inputs": { + "$ref": "#/components/schemas/Record_string.string_" + }, + "sourceRequest": { + "type": "string" + }, + "promptVersionId": { "type": "string" } }, "required": [ - "evaluatorId" + "promptVersionId" ], "type": "object" } @@ -14245,9 +14153,9 @@ } } }, - "/v1/experiment/{experimentId}/evaluators/run": { - "post": { - "operationId": "RunExperimentEvaluatorsOld", + "/v1/experiment/table/{experimentTableId}/row/{rowIndex}": { + "delete": { + "operationId": "DeleteExperimentTableRow", "responses": { "200": { "description": "Ok", @@ -14271,18 +14179,27 @@ "parameters": [ { "in": "path", - "name": "experimentId", + "name": "experimentTableId", "required": true, "schema": { "type": "string" } + }, + { + "in": "path", + "name": "rowIndex", + "required": true, + "schema": { + "format": "double", + "type": "number" + } } ] } }, - "/v1/experiment/{experimentId}/evaluators/{evaluatorId}": { - "delete": { - "operationId": "DeleteExperimentEvaluatorOld", + "/v1/experiment/table/{experimentTableId}/row/insert/batch": { + "post": { + "operationId": "CreateExperimentTableRowWithCellsBatch", "responses": { "200": { "description": "Ok", @@ -14306,33 +14223,93 @@ "parameters": [ { "in": "path", - "name": "experimentId", + "name": "experimentTableId", "required": true, "schema": { "type": "string" } - }, - { - "in": "path", - "name": "evaluatorId", - "required": true, - "schema": { - "type": "string" + } + ], + "requestBody": { + "required": true, + "content": { + "application/json": { + "schema": { + "properties": { + "rows": { + "items": { + "properties": { + "sourceRequest": { + "type": "string" + }, + "cells": { + "items": { + "properties": { + "metadata": {}, + "value": { + "type": "string", + "nullable": true + }, + "columnId": { + "type": "string" + } + }, + "required": [ + "value", + "columnId" + ], + "type": "object" + }, + "type": "array" + }, + "datasetId": { + "type": "string" + }, + "inputs": { + "$ref": "#/components/schemas/Record_string.string_" + }, + "inputRecordId": { + "type": "string" + } + }, + "required": [ + "cells", + "datasetId", + "inputs", + "inputRecordId" + ], + "type": "object" + }, + "type": "array" + } + }, + "required": [ + "rows" + ], + "type": "object" + } } } - ] + } } }, - "/v1/experiment/query": { + "/v1/experiment/update-meta": { "post": { - "operationId": "GetExperimentsOld", + "operationId": "UpdateExperimentMeta", "responses": { "200": { "description": "Ok", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Result_Experiment-Array.string_" + "anyOf": [ + { + "$ref": "#/components/schemas/ResultSuccess_unknown_" + }, + { + "$ref": "#/components/schemas/ResultError_PostgrestError_" + } + ] } } } @@ -14353,15 +14330,16 @@ "application/json": { "schema": { "properties": { - "include": { - "$ref": "#/components/schemas/IncludeExperimentKeys" + "meta": { + "$ref": "#/components/schemas/Record_string.string_" }, - "filter": { - "$ref": "#/components/schemas/ExperimentFilterNode" + "experimentId": { + "type": "string" } }, "required": [ - "filter" + "meta", + "experimentId" ], "type": "object" } @@ -14370,23 +14348,59 @@ } } }, - "/v1/experiment/dataset": { + "/v1/experiment": { + "post": { + "operationId": "CreateNewExperimentOld", + "responses": { + "200": { + "description": "Ok", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/Result__experimentId-string_.string_" + } + } + } + } + }, + "tags": [ + "Experiment" + ], + "security": [ + { + "api_key": [] + } + ], + "parameters": [], + "requestBody": { + "required": true, + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/NewExperimentParams" + } + } + } + } + } + }, + "/v1/experiment/hypothesis": { "post": { - "operationId": "AddDataset", + "operationId": "CreateNewExperimentHypothesis", "responses": { "200": { "description": "Ok", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Result__datasetId-string_.string_" + "$ref": "#/components/schemas/Result__hypothesisId-string_.string_" } } } } }, "tags": [ - "Dataset" + "Experiment" ], "security": [ { @@ -14399,107 +14413,128 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/NewDatasetParams" + "properties": { + "status": { + "type": "string", + "enum": [ + "PENDING", + "RUNNING", + "COMPLETED", + "FAILED" + ] + }, + "providerKeyId": { + "type": "string" + }, + "promptVersion": { + "type": "string" + }, + "model": { + "type": "string" + }, + "experimentId": { + "type": "string" + } + }, + "required": [ + "status", + "providerKeyId", + "promptVersion", + "model", + "experimentId" + ], + "type": "object" } } } } } }, - "/v1/experiment/dataset/random": { + "/v1/experiment/hypothesis/{hypothesisId}/scores/query": { "post": { - "operationId": "AddRandomDataset", + "operationId": "GetExperimentHypothesisScores", "responses": { "200": { "description": "Ok", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Result__datasetId-string_.string_" + "$ref": "#/components/schemas/Result__runsCount-number--scores-Record_string.Score__.string_" } } } } }, "tags": [ - "Dataset" + "Experiment" ], "security": [ { "api_key": [] } ], - "parameters": [], - "requestBody": { - "required": true, - "content": { - "application/json": { - "schema": { - "$ref": "#/components/schemas/RandomDatasetParams" - } + "parameters": [ + { + "in": "path", + "name": "hypothesisId", + "required": true, + "schema": { + "type": "string" } } - } + ] } }, - "/v1/experiment/dataset/query": { - "post": { - "operationId": "GetDatasets", + "/v1/experiment/{experimentId}/evaluators": { + "get": { + "operationId": "GetExperimentEvaluators", "responses": { "200": { "description": "Ok", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Result_DatasetResult-Array.string_" + "$ref": "#/components/schemas/Result_EvaluatorResult-Array.string_" } } } } }, "tags": [ - "Dataset" + "Experiment" ], "security": [ { "api_key": [] } ], - "parameters": [], - "requestBody": { - "required": true, - "content": { - "application/json": { - "schema": { - "properties": { - "promptVersionId": { - "type": "string" - } - }, - "type": "object" - } + "parameters": [ + { + "in": "path", + "name": "experimentId", + "required": true, + "schema": { + "type": "string" } } - } - } - }, - "/v1/experiment/dataset/{datasetId}/row/insert": { + ] + }, "post": { - "operationId": "InsertDatasetRow", + "operationId": "CreateExperimentEvaluatorOld", "responses": { "200": { "description": "Ok", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Result_string.string_" + "$ref": "#/components/schemas/Result_null.string_" } } } } }, "tags": [ - "Dataset" + "Experiment" ], "security": [ { @@ -14509,7 +14544,7 @@ "parameters": [ { "in": "path", - "name": "datasetId", + "name": "experimentId", "required": true, "schema": { "type": "string" @@ -14522,19 +14557,12 @@ "application/json": { "schema": { "properties": { - "originalColumnId": { - "type": "string" - }, - "inputs": { - "$ref": "#/components/schemas/Record_string.string_" - }, - "inputRecordId": { + "evaluatorId": { "type": "string" } }, "required": [ - "inputs", - "inputRecordId" + "evaluatorId" ], "type": "object" } @@ -14543,23 +14571,23 @@ } } }, - "/v1/experiment/dataset/{datasetId}/version/{promptVersionId}/row/new": { + "/v1/experiment/{experimentId}/evaluators/run": { "post": { - "operationId": "CreateDatasetRow", + "operationId": "RunExperimentEvaluatorsOld", "responses": { "200": { "description": "Ok", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Result_string.string_" + "$ref": "#/components/schemas/Result_null.string_" } } } } }, "tags": [ - "Dataset" + "Experiment" ], "security": [ { @@ -14569,61 +14597,32 @@ "parameters": [ { "in": "path", - "name": "datasetId", - "required": true, - "schema": { - "type": "string" - } - }, - { - "in": "path", - "name": "promptVersionId", + "name": "experimentId", "required": true, "schema": { "type": "string" } } - ], - "requestBody": { - "required": true, - "content": { - "application/json": { - "schema": { - "properties": { - "sourceRequest": { - "type": "string" - }, - "inputs": { - "$ref": "#/components/schemas/Record_string.string_" - } - }, - "required": [ - "inputs" - ], - "type": "object" - } - } - } - } + ] } }, - "/v1/experiment/dataset/{datasetId}/inputs/query": { - "post": { - "operationId": "GetDataset", + "/v1/experiment/{experimentId}/evaluators/{evaluatorId}": { + "delete": { + "operationId": "DeleteExperimentEvaluatorOld", "responses": { "200": { "description": "Ok", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Result_PromptInputRecord-Array.string_" + "$ref": "#/components/schemas/Result_null.string_" } } } } }, "tags": [ - "Dataset" + "Experiment" ], "security": [ { @@ -14633,7 +14632,15 @@ "parameters": [ { "in": "path", - "name": "datasetId", + "name": "experimentId", + "required": true, + "schema": { + "type": "string" + } + }, + { + "in": "path", + "name": "evaluatorId", "required": true, "schema": { "type": "string" @@ -14642,23 +14649,23 @@ ] } }, - "/v1/experiment/dataset/{datasetId}/mutate": { + "/v1/experiment/query": { "post": { - "operationId": "MutateDataset", + "operationId": "GetExperimentsOld", "responses": { "200": { "description": "Ok", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Result___-Array.string_" + "$ref": "#/components/schemas/Result_Experiment-Array.string_" } } } } }, "tags": [ - "Dataset" + "Experiment" ], "security": [ { @@ -14672,22 +14679,15 @@ "application/json": { "schema": { "properties": { - "removeRequests": { - "items": { - "type": "string" - }, - "type": "array" + "include": { + "$ref": "#/components/schemas/IncludeExperimentKeys" }, - "addRequests": { - "items": { - "type": "string" - }, - "type": "array" + "filter": { + "$ref": "#/components/schemas/ExperimentFilterNode" } }, "required": [ - "removeRequests", - "addRequests" + "filter" ], "type": "object" } @@ -16753,6 +16753,54 @@ } } }, + "/v1/pi/total_requests": { + "post": { + "operationId": "GetTotalRequests", + "responses": { + "200": { + "description": "Ok", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/Result_number.string_" + } + } + } + } + }, + "tags": [ + "PI" + ], + "security": [ + { + "api_key": [] + } + ], + "parameters": [], + "requestBody": { + "required": true, + "content": { + "application/json": { + "schema": { + "properties": { + "endTime": { + "type": "string" + }, + "startTime": { + "type": "string" + } + }, + "required": [ + "endTime", + "startTime" + ], + "type": "object" + } + } + } + } + } + }, "/v1/settings/query": { "get": { "operationId": "GetSettings", diff --git a/web/lib/clients/jawnTypes/private.ts b/web/lib/clients/jawnTypes/private.ts index 9edb00ad0b..128dd74a79 100644 --- a/web/lib/clients/jawnTypes/private.ts +++ b/web/lib/clients/jawnTypes/private.ts @@ -301,27 +301,6 @@ export interface paths { "/v1/integration/slack/channels": { get: operations["GetSlackChannels"]; }; - "/v1/experiment/dataset": { - post: operations["AddDataset"]; - }; - "/v1/experiment/dataset/random": { - post: operations["AddRandomDataset"]; - }; - "/v1/experiment/dataset/query": { - post: operations["GetDatasets"]; - }; - "/v1/experiment/dataset/{datasetId}/row/insert": { - post: operations["InsertDatasetRow"]; - }; - "/v1/experiment/dataset/{datasetId}/version/{promptVersionId}/row/new": { - post: operations["CreateDatasetRow"]; - }; - "/v1/experiment/dataset/{datasetId}/inputs/query": { - post: operations["GetDataset"]; - }; - "/v1/experiment/dataset/{datasetId}/mutate": { - post: operations["MutateDataset"]; - }; "/v1/experiment/new-empty": { post: operations["CreateNewEmptyExperiment"]; }; @@ -378,6 +357,27 @@ export interface paths { "/v1/experiment/query": { post: operations["GetExperimentsOld"]; }; + "/v1/experiment/dataset": { + post: operations["AddDataset"]; + }; + "/v1/experiment/dataset/random": { + post: operations["AddRandomDataset"]; + }; + "/v1/experiment/dataset/query": { + post: operations["GetDatasets"]; + }; + "/v1/experiment/dataset/{datasetId}/row/insert": { + post: operations["InsertDatasetRow"]; + }; + "/v1/experiment/dataset/{datasetId}/version/{promptVersionId}/row/new": { + post: operations["CreateDatasetRow"]; + }; + "/v1/experiment/dataset/{datasetId}/inputs/query": { + post: operations["GetDataset"]; + }; + "/v1/experiment/dataset/{datasetId}/mutate": { + post: operations["MutateDataset"]; + }; "/v1/helicone-dataset": { post: operations["AddHeliconeDataset"]; }; @@ -523,6 +523,9 @@ export interface paths { "/v1/pi/session": { post: operations["AddSession"]; }; + "/v1/pi/total_requests": { + post: operations["GetTotalRequests"]; + }; "/v1/settings/query": { get: operations["GetSettings"]; }; @@ -2372,64 +2375,6 @@ Json: JsonObject; error: null; }; "Result_Array__id-string--name-string__.string_": components["schemas"]["ResultSuccess_Array__id-string--name-string___"] | components["schemas"]["ResultError_string_"]; - "ResultSuccess__datasetId-string__": { - data: { - datasetId: string; - }; - /** @enum {number|null} */ - error: null; - }; - "Result__datasetId-string_.string_": components["schemas"]["ResultSuccess__datasetId-string__"] | components["schemas"]["ResultError_string_"]; - DatasetMetadata: { - promptVersionId?: string; - inputRecordsIds?: string[]; - }; - NewDatasetParams: { - datasetName: string; - requestIds: string[]; - /** @enum {string} */ - datasetType: "experiment" | "helicone"; - meta?: components["schemas"]["DatasetMetadata"]; - }; - /** @description From T, pick a set of properties whose keys are in the union K */ - "Pick_FilterLeaf.request-or-prompts_versions_": { - request?: components["schemas"]["Partial_RequestTableToOperators_"]; - prompts_versions?: components["schemas"]["Partial_PromptVersionsToOperators_"]; - }; - "FilterLeafSubset_request-or-prompts_versions_": components["schemas"]["Pick_FilterLeaf.request-or-prompts_versions_"]; - DatasetFilterNode: components["schemas"]["FilterLeafSubset_request-or-prompts_versions_"] | components["schemas"]["DatasetFilterBranch"] | "all"; - DatasetFilterBranch: { - right: components["schemas"]["DatasetFilterNode"]; - /** @enum {string} */ - operator: "or" | "and"; - left: components["schemas"]["DatasetFilterNode"]; - }; - RandomDatasetParams: { - datasetName: string; - filter: components["schemas"]["DatasetFilterNode"]; - /** Format: double */ - offset?: number; - /** Format: double */ - limit?: number; - }; - DatasetResult: { - id: string; - name: string; - created_at: string; - meta?: components["schemas"]["DatasetMetadata"]; - }; - "ResultSuccess_DatasetResult-Array_": { - data: components["schemas"]["DatasetResult"][]; - /** @enum {number|null} */ - error: null; - }; - "Result_DatasetResult-Array.string_": components["schemas"]["ResultSuccess_DatasetResult-Array_"] | components["schemas"]["ResultError_string_"]; - "ResultSuccess___-Array_": { - data: Record[]; - /** @enum {number|null} */ - error: null; - }; - "Result___-Array.string_": components["schemas"]["ResultSuccess___-Array_"] | components["schemas"]["ResultError_string_"]; "ResultSuccess__tableId-string--experimentId-string__": { data: { experimentId: string; @@ -2659,6 +2604,64 @@ Json: JsonObject; /** @enum {boolean} */ score?: true; }; + "ResultSuccess__datasetId-string__": { + data: { + datasetId: string; + }; + /** @enum {number|null} */ + error: null; + }; + "Result__datasetId-string_.string_": components["schemas"]["ResultSuccess__datasetId-string__"] | components["schemas"]["ResultError_string_"]; + DatasetMetadata: { + promptVersionId?: string; + inputRecordsIds?: string[]; + }; + NewDatasetParams: { + datasetName: string; + requestIds: string[]; + /** @enum {string} */ + datasetType: "experiment" | "helicone"; + meta?: components["schemas"]["DatasetMetadata"]; + }; + /** @description From T, pick a set of properties whose keys are in the union K */ + "Pick_FilterLeaf.request-or-prompts_versions_": { + request?: components["schemas"]["Partial_RequestTableToOperators_"]; + prompts_versions?: components["schemas"]["Partial_PromptVersionsToOperators_"]; + }; + "FilterLeafSubset_request-or-prompts_versions_": components["schemas"]["Pick_FilterLeaf.request-or-prompts_versions_"]; + DatasetFilterNode: components["schemas"]["FilterLeafSubset_request-or-prompts_versions_"] | components["schemas"]["DatasetFilterBranch"] | "all"; + DatasetFilterBranch: { + right: components["schemas"]["DatasetFilterNode"]; + /** @enum {string} */ + operator: "or" | "and"; + left: components["schemas"]["DatasetFilterNode"]; + }; + RandomDatasetParams: { + datasetName: string; + filter: components["schemas"]["DatasetFilterNode"]; + /** Format: double */ + offset?: number; + /** Format: double */ + limit?: number; + }; + DatasetResult: { + id: string; + name: string; + created_at: string; + meta?: components["schemas"]["DatasetMetadata"]; + }; + "ResultSuccess_DatasetResult-Array_": { + data: components["schemas"]["DatasetResult"][]; + /** @enum {number|null} */ + error: null; + }; + "Result_DatasetResult-Array.string_": components["schemas"]["ResultSuccess_DatasetResult-Array_"] | components["schemas"]["ResultError_string_"]; + "ResultSuccess___-Array_": { + data: Record[]; + /** @enum {number|null} */ + error: null; + }; + "Result___-Array.string_": components["schemas"]["ResultSuccess___-Array_"] | components["schemas"]["ResultError_string_"]; HeliconeDatasetMetadata: { promptVersionId?: string; inputRecordsIds?: string[]; @@ -5023,134 +5026,6 @@ export interface operations { }; }; }; - AddDataset: { - requestBody: { - content: { - "application/json": components["schemas"]["NewDatasetParams"]; - }; - }; - responses: { - /** @description Ok */ - 200: { - content: { - "application/json": components["schemas"]["Result__datasetId-string_.string_"]; - }; - }; - }; - }; - AddRandomDataset: { - requestBody: { - content: { - "application/json": components["schemas"]["RandomDatasetParams"]; - }; - }; - responses: { - /** @description Ok */ - 200: { - content: { - "application/json": components["schemas"]["Result__datasetId-string_.string_"]; - }; - }; - }; - }; - GetDatasets: { - requestBody: { - content: { - "application/json": { - promptVersionId?: string; - }; - }; - }; - responses: { - /** @description Ok */ - 200: { - content: { - "application/json": components["schemas"]["Result_DatasetResult-Array.string_"]; - }; - }; - }; - }; - InsertDatasetRow: { - parameters: { - path: { - datasetId: string; - }; - }; - requestBody: { - content: { - "application/json": { - originalColumnId?: string; - inputs: components["schemas"]["Record_string.string_"]; - inputRecordId: string; - }; - }; - }; - responses: { - /** @description Ok */ - 200: { - content: { - "application/json": components["schemas"]["Result_string.string_"]; - }; - }; - }; - }; - CreateDatasetRow: { - parameters: { - path: { - datasetId: string; - promptVersionId: string; - }; - }; - requestBody: { - content: { - "application/json": { - sourceRequest?: string; - inputs: components["schemas"]["Record_string.string_"]; - }; - }; - }; - responses: { - /** @description Ok */ - 200: { - content: { - "application/json": components["schemas"]["Result_string.string_"]; - }; - }; - }; - }; - GetDataset: { - parameters: { - path: { - datasetId: string; - }; - }; - responses: { - /** @description Ok */ - 200: { - content: { - "application/json": components["schemas"]["Result_PromptInputRecord-Array.string_"]; - }; - }; - }; - }; - MutateDataset: { - requestBody: { - content: { - "application/json": { - removeRequests: string[]; - addRequests: string[]; - }; - }; - }; - responses: { - /** @description Ok */ - 200: { - content: { - "application/json": components["schemas"]["Result___-Array.string_"]; - }; - }; - }; - }; CreateNewEmptyExperiment: { requestBody: { content: { @@ -5514,6 +5389,134 @@ export interface operations { }; }; }; + AddDataset: { + requestBody: { + content: { + "application/json": components["schemas"]["NewDatasetParams"]; + }; + }; + responses: { + /** @description Ok */ + 200: { + content: { + "application/json": components["schemas"]["Result__datasetId-string_.string_"]; + }; + }; + }; + }; + AddRandomDataset: { + requestBody: { + content: { + "application/json": components["schemas"]["RandomDatasetParams"]; + }; + }; + responses: { + /** @description Ok */ + 200: { + content: { + "application/json": components["schemas"]["Result__datasetId-string_.string_"]; + }; + }; + }; + }; + GetDatasets: { + requestBody: { + content: { + "application/json": { + promptVersionId?: string; + }; + }; + }; + responses: { + /** @description Ok */ + 200: { + content: { + "application/json": components["schemas"]["Result_DatasetResult-Array.string_"]; + }; + }; + }; + }; + InsertDatasetRow: { + parameters: { + path: { + datasetId: string; + }; + }; + requestBody: { + content: { + "application/json": { + originalColumnId?: string; + inputs: components["schemas"]["Record_string.string_"]; + inputRecordId: string; + }; + }; + }; + responses: { + /** @description Ok */ + 200: { + content: { + "application/json": components["schemas"]["Result_string.string_"]; + }; + }; + }; + }; + CreateDatasetRow: { + parameters: { + path: { + datasetId: string; + promptVersionId: string; + }; + }; + requestBody: { + content: { + "application/json": { + sourceRequest?: string; + inputs: components["schemas"]["Record_string.string_"]; + }; + }; + }; + responses: { + /** @description Ok */ + 200: { + content: { + "application/json": components["schemas"]["Result_string.string_"]; + }; + }; + }; + }; + GetDataset: { + parameters: { + path: { + datasetId: string; + }; + }; + responses: { + /** @description Ok */ + 200: { + content: { + "application/json": components["schemas"]["Result_PromptInputRecord-Array.string_"]; + }; + }; + }; + }; + MutateDataset: { + requestBody: { + content: { + "application/json": { + removeRequests: string[]; + addRequests: string[]; + }; + }; + }; + responses: { + /** @description Ok */ + 200: { + content: { + "application/json": components["schemas"]["Result___-Array.string_"]; + }; + }; + }; + }; AddHeliconeDataset: { requestBody: { content: { @@ -5663,7 +5666,10 @@ export interface operations { GetTotalRequests: { requestBody: { content: { - "application/json": components["schemas"]["DataIsBeautifulRequestBody"]; + "application/json": { + endTime: string; + startTime: string; + }; }; }; responses: { diff --git a/web/lib/clients/jawnTypes/public.ts b/web/lib/clients/jawnTypes/public.ts index 5b20d59eef..6a0255c326 100644 --- a/web/lib/clients/jawnTypes/public.ts +++ b/web/lib/clients/jawnTypes/public.ts @@ -256,6 +256,27 @@ export interface paths { "/v1/integration/slack/channels": { get: operations["GetSlackChannels"]; }; + "/v1/experiment/dataset": { + post: operations["AddDataset"]; + }; + "/v1/experiment/dataset/random": { + post: operations["AddRandomDataset"]; + }; + "/v1/experiment/dataset/query": { + post: operations["GetDatasets"]; + }; + "/v1/experiment/dataset/{datasetId}/row/insert": { + post: operations["InsertDatasetRow"]; + }; + "/v1/experiment/dataset/{datasetId}/version/{promptVersionId}/row/new": { + post: operations["CreateDatasetRow"]; + }; + "/v1/experiment/dataset/{datasetId}/inputs/query": { + post: operations["GetDataset"]; + }; + "/v1/experiment/dataset/{datasetId}/mutate": { + post: operations["MutateDataset"]; + }; "/v1/experiment/new-empty": { post: operations["CreateNewEmptyExperiment"]; }; @@ -312,27 +333,6 @@ export interface paths { "/v1/experiment/query": { post: operations["GetExperimentsOld"]; }; - "/v1/experiment/dataset": { - post: operations["AddDataset"]; - }; - "/v1/experiment/dataset/random": { - post: operations["AddRandomDataset"]; - }; - "/v1/experiment/dataset/query": { - post: operations["GetDatasets"]; - }; - "/v1/experiment/dataset/{datasetId}/row/insert": { - post: operations["InsertDatasetRow"]; - }; - "/v1/experiment/dataset/{datasetId}/version/{promptVersionId}/row/new": { - post: operations["CreateDatasetRow"]; - }; - "/v1/experiment/dataset/{datasetId}/inputs/query": { - post: operations["GetDataset"]; - }; - "/v1/experiment/dataset/{datasetId}/mutate": { - post: operations["MutateDataset"]; - }; "/v1/helicone-dataset": { post: operations["AddHeliconeDataset"]; }; @@ -478,6 +478,9 @@ export interface paths { "/v1/pi/session": { post: operations["AddSession"]; }; + "/v1/pi/total_requests": { + post: operations["GetTotalRequests"]; + }; "/v1/settings/query": { get: operations["GetSettings"]; }; @@ -1943,6 +1946,85 @@ Json: JsonObject; error: null; }; "Result_Array__id-string--name-string__.string_": components["schemas"]["ResultSuccess_Array__id-string--name-string___"] | components["schemas"]["ResultError_string_"]; + "ResultSuccess__datasetId-string__": { + data: { + datasetId: string; + }; + /** @enum {number|null} */ + error: null; + }; + "Result__datasetId-string_.string_": components["schemas"]["ResultSuccess__datasetId-string__"] | components["schemas"]["ResultError_string_"]; + DatasetMetadata: { + promptVersionId?: string; + inputRecordsIds?: string[]; + }; + NewDatasetParams: { + datasetName: string; + requestIds: string[]; + /** @enum {string} */ + datasetType: "experiment" | "helicone"; + meta?: components["schemas"]["DatasetMetadata"]; + }; + /** @description Make all properties in T optional */ + Partial_TimestampOperators_: { + gte?: string; + lte?: string; + lt?: string; + gt?: string; + }; + /** @description Make all properties in T optional */ + Partial_RequestTableToOperators_: { + prompt?: components["schemas"]["Partial_TextOperators_"]; + created_at?: components["schemas"]["Partial_TimestampOperators_"]; + user_id?: components["schemas"]["Partial_TextOperators_"]; + auth_hash?: components["schemas"]["Partial_TextOperators_"]; + org_id?: components["schemas"]["Partial_TextOperators_"]; + id?: components["schemas"]["Partial_TextOperators_"]; + node_id?: components["schemas"]["Partial_TextOperators_"]; + model?: components["schemas"]["Partial_TextOperators_"]; + modelOverride?: components["schemas"]["Partial_TextOperators_"]; + path?: components["schemas"]["Partial_TextOperators_"]; + prompt_id?: components["schemas"]["Partial_TextOperators_"]; + }; + /** @description From T, pick a set of properties whose keys are in the union K */ + "Pick_FilterLeaf.request-or-prompts_versions_": { + request?: components["schemas"]["Partial_RequestTableToOperators_"]; + prompts_versions?: components["schemas"]["Partial_PromptVersionsToOperators_"]; + }; + "FilterLeafSubset_request-or-prompts_versions_": components["schemas"]["Pick_FilterLeaf.request-or-prompts_versions_"]; + DatasetFilterNode: components["schemas"]["FilterLeafSubset_request-or-prompts_versions_"] | components["schemas"]["DatasetFilterBranch"] | "all"; + DatasetFilterBranch: { + right: components["schemas"]["DatasetFilterNode"]; + /** @enum {string} */ + operator: "or" | "and"; + left: components["schemas"]["DatasetFilterNode"]; + }; + RandomDatasetParams: { + datasetName: string; + filter: components["schemas"]["DatasetFilterNode"]; + /** Format: double */ + offset?: number; + /** Format: double */ + limit?: number; + }; + DatasetResult: { + id: string; + name: string; + created_at: string; + meta?: components["schemas"]["DatasetMetadata"]; + }; + "ResultSuccess_DatasetResult-Array_": { + data: components["schemas"]["DatasetResult"][]; + /** @enum {number|null} */ + error: null; + }; + "Result_DatasetResult-Array.string_": components["schemas"]["ResultSuccess_DatasetResult-Array_"] | components["schemas"]["ResultError_string_"]; + "ResultSuccess___-Array_": { + data: Record[]; + /** @enum {number|null} */ + error: null; + }; + "Result___-Array.string_": components["schemas"]["ResultSuccess___-Array_"] | components["schemas"]["ResultError_string_"]; "ResultSuccess__tableId-string--experimentId-string__": { data: { experimentId: string; @@ -2172,85 +2254,6 @@ Json: JsonObject; /** @enum {boolean} */ score?: true; }; - "ResultSuccess__datasetId-string__": { - data: { - datasetId: string; - }; - /** @enum {number|null} */ - error: null; - }; - "Result__datasetId-string_.string_": components["schemas"]["ResultSuccess__datasetId-string__"] | components["schemas"]["ResultError_string_"]; - DatasetMetadata: { - promptVersionId?: string; - inputRecordsIds?: string[]; - }; - NewDatasetParams: { - datasetName: string; - requestIds: string[]; - /** @enum {string} */ - datasetType: "experiment" | "helicone"; - meta?: components["schemas"]["DatasetMetadata"]; - }; - /** @description Make all properties in T optional */ - Partial_TimestampOperators_: { - gte?: string; - lte?: string; - lt?: string; - gt?: string; - }; - /** @description Make all properties in T optional */ - Partial_RequestTableToOperators_: { - prompt?: components["schemas"]["Partial_TextOperators_"]; - created_at?: components["schemas"]["Partial_TimestampOperators_"]; - user_id?: components["schemas"]["Partial_TextOperators_"]; - auth_hash?: components["schemas"]["Partial_TextOperators_"]; - org_id?: components["schemas"]["Partial_TextOperators_"]; - id?: components["schemas"]["Partial_TextOperators_"]; - node_id?: components["schemas"]["Partial_TextOperators_"]; - model?: components["schemas"]["Partial_TextOperators_"]; - modelOverride?: components["schemas"]["Partial_TextOperators_"]; - path?: components["schemas"]["Partial_TextOperators_"]; - prompt_id?: components["schemas"]["Partial_TextOperators_"]; - }; - /** @description From T, pick a set of properties whose keys are in the union K */ - "Pick_FilterLeaf.request-or-prompts_versions_": { - request?: components["schemas"]["Partial_RequestTableToOperators_"]; - prompts_versions?: components["schemas"]["Partial_PromptVersionsToOperators_"]; - }; - "FilterLeafSubset_request-or-prompts_versions_": components["schemas"]["Pick_FilterLeaf.request-or-prompts_versions_"]; - DatasetFilterNode: components["schemas"]["FilterLeafSubset_request-or-prompts_versions_"] | components["schemas"]["DatasetFilterBranch"] | "all"; - DatasetFilterBranch: { - right: components["schemas"]["DatasetFilterNode"]; - /** @enum {string} */ - operator: "or" | "and"; - left: components["schemas"]["DatasetFilterNode"]; - }; - RandomDatasetParams: { - datasetName: string; - filter: components["schemas"]["DatasetFilterNode"]; - /** Format: double */ - offset?: number; - /** Format: double */ - limit?: number; - }; - DatasetResult: { - id: string; - name: string; - created_at: string; - meta?: components["schemas"]["DatasetMetadata"]; - }; - "ResultSuccess_DatasetResult-Array_": { - data: components["schemas"]["DatasetResult"][]; - /** @enum {number|null} */ - error: null; - }; - "Result_DatasetResult-Array.string_": components["schemas"]["ResultSuccess_DatasetResult-Array_"] | components["schemas"]["ResultError_string_"]; - "ResultSuccess___-Array_": { - data: Record[]; - /** @enum {number|null} */ - error: null; - }; - "Result___-Array.string_": components["schemas"]["ResultSuccess___-Array_"] | components["schemas"]["ResultError_string_"]; HeliconeDatasetMetadata: { promptVersionId?: string; inputRecordsIds?: string[]; @@ -4780,6 +4783,134 @@ export interface operations { }; }; }; + AddDataset: { + requestBody: { + content: { + "application/json": components["schemas"]["NewDatasetParams"]; + }; + }; + responses: { + /** @description Ok */ + 200: { + content: { + "application/json": components["schemas"]["Result__datasetId-string_.string_"]; + }; + }; + }; + }; + AddRandomDataset: { + requestBody: { + content: { + "application/json": components["schemas"]["RandomDatasetParams"]; + }; + }; + responses: { + /** @description Ok */ + 200: { + content: { + "application/json": components["schemas"]["Result__datasetId-string_.string_"]; + }; + }; + }; + }; + GetDatasets: { + requestBody: { + content: { + "application/json": { + promptVersionId?: string; + }; + }; + }; + responses: { + /** @description Ok */ + 200: { + content: { + "application/json": components["schemas"]["Result_DatasetResult-Array.string_"]; + }; + }; + }; + }; + InsertDatasetRow: { + parameters: { + path: { + datasetId: string; + }; + }; + requestBody: { + content: { + "application/json": { + originalColumnId?: string; + inputs: components["schemas"]["Record_string.string_"]; + inputRecordId: string; + }; + }; + }; + responses: { + /** @description Ok */ + 200: { + content: { + "application/json": components["schemas"]["Result_string.string_"]; + }; + }; + }; + }; + CreateDatasetRow: { + parameters: { + path: { + datasetId: string; + promptVersionId: string; + }; + }; + requestBody: { + content: { + "application/json": { + sourceRequest?: string; + inputs: components["schemas"]["Record_string.string_"]; + }; + }; + }; + responses: { + /** @description Ok */ + 200: { + content: { + "application/json": components["schemas"]["Result_string.string_"]; + }; + }; + }; + }; + GetDataset: { + parameters: { + path: { + datasetId: string; + }; + }; + responses: { + /** @description Ok */ + 200: { + content: { + "application/json": components["schemas"]["Result_PromptInputRecord-Array.string_"]; + }; + }; + }; + }; + MutateDataset: { + requestBody: { + content: { + "application/json": { + removeRequests: string[]; + addRequests: string[]; + }; + }; + }; + responses: { + /** @description Ok */ + 200: { + content: { + "application/json": components["schemas"]["Result___-Array.string_"]; + }; + }; + }; + }; CreateNewEmptyExperiment: { requestBody: { content: { @@ -5143,134 +5274,6 @@ export interface operations { }; }; }; - AddDataset: { - requestBody: { - content: { - "application/json": components["schemas"]["NewDatasetParams"]; - }; - }; - responses: { - /** @description Ok */ - 200: { - content: { - "application/json": components["schemas"]["Result__datasetId-string_.string_"]; - }; - }; - }; - }; - AddRandomDataset: { - requestBody: { - content: { - "application/json": components["schemas"]["RandomDatasetParams"]; - }; - }; - responses: { - /** @description Ok */ - 200: { - content: { - "application/json": components["schemas"]["Result__datasetId-string_.string_"]; - }; - }; - }; - }; - GetDatasets: { - requestBody: { - content: { - "application/json": { - promptVersionId?: string; - }; - }; - }; - responses: { - /** @description Ok */ - 200: { - content: { - "application/json": components["schemas"]["Result_DatasetResult-Array.string_"]; - }; - }; - }; - }; - InsertDatasetRow: { - parameters: { - path: { - datasetId: string; - }; - }; - requestBody: { - content: { - "application/json": { - originalColumnId?: string; - inputs: components["schemas"]["Record_string.string_"]; - inputRecordId: string; - }; - }; - }; - responses: { - /** @description Ok */ - 200: { - content: { - "application/json": components["schemas"]["Result_string.string_"]; - }; - }; - }; - }; - CreateDatasetRow: { - parameters: { - path: { - datasetId: string; - promptVersionId: string; - }; - }; - requestBody: { - content: { - "application/json": { - sourceRequest?: string; - inputs: components["schemas"]["Record_string.string_"]; - }; - }; - }; - responses: { - /** @description Ok */ - 200: { - content: { - "application/json": components["schemas"]["Result_string.string_"]; - }; - }; - }; - }; - GetDataset: { - parameters: { - path: { - datasetId: string; - }; - }; - responses: { - /** @description Ok */ - 200: { - content: { - "application/json": components["schemas"]["Result_PromptInputRecord-Array.string_"]; - }; - }; - }; - }; - MutateDataset: { - requestBody: { - content: { - "application/json": { - removeRequests: string[]; - addRequests: string[]; - }; - }; - }; - responses: { - /** @description Ok */ - 200: { - content: { - "application/json": components["schemas"]["Result___-Array.string_"]; - }; - }; - }; - }; AddHeliconeDataset: { requestBody: { content: { @@ -5420,7 +5423,10 @@ export interface operations { GetTotalRequests: { requestBody: { content: { - "application/json": components["schemas"]["DataIsBeautifulRequestBody"]; + "application/json": { + endTime: string; + startTime: string; + }; }; }; responses: { From 84078ac2d7ee83b3e9c07db3b566105846fd9b2c Mon Sep 17 00:00:00 2001 From: Justin Date: Fri, 20 Dec 2024 12:26:46 -0800 Subject: [PATCH 07/14] total requests --- bifrost/app/pi/total-requests/page.tsx | 9 + bifrost/lib/clients/jawnTypes/private.ts | 8 - bifrost/lib/clients/jawnTypes/public.ts | 8 - docs/swagger.json | 24 +- .../src/controllers/public/piController.ts | 13 +- .../jawn/src/tsoa-build/private/routes.ts | 555 ++++--- .../jawn/src/tsoa-build/private/swagger.json | 1468 ++++++++--------- valhalla/jawn/src/tsoa-build/public/routes.ts | 1 - .../jawn/src/tsoa-build/public/swagger.json | 24 +- web/lib/clients/jawnTypes/private.ts | 8 - web/lib/clients/jawnTypes/public.ts | 8 - 11 files changed, 1016 insertions(+), 1110 deletions(-) diff --git a/bifrost/app/pi/total-requests/page.tsx b/bifrost/app/pi/total-requests/page.tsx index 79287c0abb..7c391b92bf 100644 --- a/bifrost/app/pi/total-requests/page.tsx +++ b/bifrost/app/pi/total-requests/page.tsx @@ -5,6 +5,8 @@ import { useHeliconeLogin } from "../useHeliconeLogin"; import { JetBrains_Mono } from "next/font/google"; import { useTestAPIKey } from "../first_page/useTestApiKey"; +import { useJawnClient } from "@/lib/clients/jawnHook"; +import { useQuery } from "@tanstack/react-query"; const jetbrainsMono = JetBrains_Mono({ subsets: ["latin"] }); const PiGraphLayout = ({ children }: { children: React.ReactNode }) => { @@ -12,6 +14,13 @@ const PiGraphLayout = ({ children }: { children: React.ReactNode }) => { const { data, isLoading } = useTestAPIKey(apiKey.data ?? ""); const router = useRouter(); + const jawn = useJawnClient(apiKey.data ?? ""); + + const totalRequests = useQuery({ + queryKey: ["total-requests", apiKey.data], + queryFn: () => jawn.POST("/v1/pi/total_requests"), + }); + if (!data && !isLoading && !apiKey.data && !apiKey.isLoading) { router.push("/pi/setup?invalid_api_key=true"); return null; diff --git a/bifrost/lib/clients/jawnTypes/private.ts b/bifrost/lib/clients/jawnTypes/private.ts index 128dd74a79..f97a51371a 100644 --- a/bifrost/lib/clients/jawnTypes/private.ts +++ b/bifrost/lib/clients/jawnTypes/private.ts @@ -5664,14 +5664,6 @@ export interface operations { }; }; GetTotalRequests: { - requestBody: { - content: { - "application/json": { - endTime: string; - startTime: string; - }; - }; - }; responses: { /** @description Ok */ 200: { diff --git a/bifrost/lib/clients/jawnTypes/public.ts b/bifrost/lib/clients/jawnTypes/public.ts index 6a0255c326..82c6fa6df9 100644 --- a/bifrost/lib/clients/jawnTypes/public.ts +++ b/bifrost/lib/clients/jawnTypes/public.ts @@ -5421,14 +5421,6 @@ export interface operations { }; }; GetTotalRequests: { - requestBody: { - content: { - "application/json": { - endTime: string; - startTime: string; - }; - }; - }; responses: { /** @description Ok */ 200: { diff --git a/docs/swagger.json b/docs/swagger.json index 4078a90004..5add5a5dcf 100644 --- a/docs/swagger.json +++ b/docs/swagger.json @@ -16776,29 +16776,7 @@ "api_key": [] } ], - "parameters": [], - "requestBody": { - "required": true, - "content": { - "application/json": { - "schema": { - "properties": { - "endTime": { - "type": "string" - }, - "startTime": { - "type": "string" - } - }, - "required": [ - "endTime", - "startTime" - ], - "type": "object" - } - } - } - } + "parameters": [] } }, "/v1/settings/query": { diff --git a/valhalla/jawn/src/controllers/public/piController.ts b/valhalla/jawn/src/controllers/public/piController.ts index 357865d1ee..70b2903091 100644 --- a/valhalla/jawn/src/controllers/public/piController.ts +++ b/valhalla/jawn/src/controllers/public/piController.ts @@ -47,22 +47,19 @@ export class PiController extends Controller { @Post("/total_requests") public async getTotalRequests( - @Body() - body: { - startTime: string; - endTime: string; - }, @Request() request: JawnAuthenticatedRequest ): Promise> { - const reqManager = new RequestManager(request.authParams); + const startTime = new Date(Date.now() - 30 * 24 * 60 * 60 * 1000); // 30 days ago + const endTime = new Date(Date.now()); + const { filter: filterString, argsAcc } = await buildFilterWithAuthClickHouse({ org_id: request.authParams.organizationId, filter: { left: timeFilterToFilterNode( { - start: new Date(body.startTime), - end: new Date(body.endTime), + start: startTime, + end: endTime, }, "request_response_rmt" ), diff --git a/valhalla/jawn/src/tsoa-build/private/routes.ts b/valhalla/jawn/src/tsoa-build/private/routes.ts index 60f4905641..bb6ffed183 100644 --- a/valhalla/jawn/src/tsoa-build/private/routes.ts +++ b/valhalla/jawn/src/tsoa-build/private/routes.ts @@ -44,10 +44,10 @@ import { PropertyController } from './../../controllers/public/propertyControlle // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa import { IntegrationController } from './../../controllers/public/integrationController'; // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa -import { ExperimentDatasetController } from './../../controllers/public/experimentDatasetController'; -// WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa import { ExperimentController } from './../../controllers/public/experimentController'; // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa +import { ExperimentDatasetController } from './../../controllers/public/experimentDatasetController'; +// WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa import { HeliconeDatasetController } from './../../controllers/public/heliconeDatasetController'; // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa import { DataIsBeautifulRouter } from './../../controllers/public/dataIsBeautifulController'; @@ -2145,110 +2145,6 @@ const models: TsoaRoute.Models = { "type": {"dataType":"union","subSchemas":[{"ref":"ResultSuccess_Array__id-string--name-string___"},{"ref":"ResultError_string_"}],"validators":{}}, }, // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa - "ResultSuccess__datasetId-string__": { - "dataType": "refObject", - "properties": { - "data": {"dataType":"nestedObjectLiteral","nestedProperties":{"datasetId":{"dataType":"string","required":true}},"required":true}, - "error": {"dataType":"enum","enums":[null],"required":true}, - }, - "additionalProperties": false, - }, - // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa - "Result__datasetId-string_.string_": { - "dataType": "refAlias", - "type": {"dataType":"union","subSchemas":[{"ref":"ResultSuccess__datasetId-string__"},{"ref":"ResultError_string_"}],"validators":{}}, - }, - // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa - "DatasetMetadata": { - "dataType": "refObject", - "properties": { - "promptVersionId": {"dataType":"string"}, - "inputRecordsIds": {"dataType":"array","array":{"dataType":"string"}}, - }, - "additionalProperties": false, - }, - // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa - "NewDatasetParams": { - "dataType": "refObject", - "properties": { - "datasetName": {"dataType":"string","required":true}, - "requestIds": {"dataType":"array","array":{"dataType":"string"},"required":true}, - "datasetType": {"dataType":"union","subSchemas":[{"dataType":"enum","enums":["experiment"]},{"dataType":"enum","enums":["helicone"]}],"required":true}, - "meta": {"ref":"DatasetMetadata"}, - }, - "additionalProperties": false, - }, - // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa - "Pick_FilterLeaf.request-or-prompts_versions_": { - "dataType": "refAlias", - "type": {"dataType":"nestedObjectLiteral","nestedProperties":{"request":{"ref":"Partial_RequestTableToOperators_"},"prompts_versions":{"ref":"Partial_PromptVersionsToOperators_"}},"validators":{}}, - }, - // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa - "FilterLeafSubset_request-or-prompts_versions_": { - "dataType": "refAlias", - "type": {"ref":"Pick_FilterLeaf.request-or-prompts_versions_","validators":{}}, - }, - // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa - "DatasetFilterNode": { - "dataType": "refAlias", - "type": {"dataType":"union","subSchemas":[{"ref":"FilterLeafSubset_request-or-prompts_versions_"},{"ref":"DatasetFilterBranch"},{"dataType":"enum","enums":["all"]}],"validators":{}}, - }, - // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa - "DatasetFilterBranch": { - "dataType": "refAlias", - "type": {"dataType":"nestedObjectLiteral","nestedProperties":{"right":{"ref":"DatasetFilterNode","required":true},"operator":{"dataType":"union","subSchemas":[{"dataType":"enum","enums":["or"]},{"dataType":"enum","enums":["and"]}],"required":true},"left":{"ref":"DatasetFilterNode","required":true}},"validators":{}}, - }, - // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa - "RandomDatasetParams": { - "dataType": "refObject", - "properties": { - "datasetName": {"dataType":"string","required":true}, - "filter": {"ref":"DatasetFilterNode","required":true}, - "offset": {"dataType":"double"}, - "limit": {"dataType":"double"}, - }, - "additionalProperties": false, - }, - // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa - "DatasetResult": { - "dataType": "refObject", - "properties": { - "id": {"dataType":"string","required":true}, - "name": {"dataType":"string","required":true}, - "created_at": {"dataType":"string","required":true}, - "meta": {"ref":"DatasetMetadata"}, - }, - "additionalProperties": false, - }, - // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa - "ResultSuccess_DatasetResult-Array_": { - "dataType": "refObject", - "properties": { - "data": {"dataType":"array","array":{"dataType":"refObject","ref":"DatasetResult"},"required":true}, - "error": {"dataType":"enum","enums":[null],"required":true}, - }, - "additionalProperties": false, - }, - // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa - "Result_DatasetResult-Array.string_": { - "dataType": "refAlias", - "type": {"dataType":"union","subSchemas":[{"ref":"ResultSuccess_DatasetResult-Array_"},{"ref":"ResultError_string_"}],"validators":{}}, - }, - // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa - "ResultSuccess___-Array_": { - "dataType": "refObject", - "properties": { - "data": {"dataType":"array","array":{"dataType":"nestedObjectLiteral","nestedProperties":{}},"required":true}, - "error": {"dataType":"enum","enums":[null],"required":true}, - }, - "additionalProperties": false, - }, - // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa - "Result___-Array.string_": { - "dataType": "refAlias", - "type": {"dataType":"union","subSchemas":[{"ref":"ResultSuccess___-Array_"},{"ref":"ResultError_string_"}],"validators":{}}, - }, - // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa "ResultSuccess__tableId-string--experimentId-string__": { "dataType": "refObject", "properties": { @@ -2541,6 +2437,110 @@ const models: TsoaRoute.Models = { "additionalProperties": false, }, // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa + "ResultSuccess__datasetId-string__": { + "dataType": "refObject", + "properties": { + "data": {"dataType":"nestedObjectLiteral","nestedProperties":{"datasetId":{"dataType":"string","required":true}},"required":true}, + "error": {"dataType":"enum","enums":[null],"required":true}, + }, + "additionalProperties": false, + }, + // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa + "Result__datasetId-string_.string_": { + "dataType": "refAlias", + "type": {"dataType":"union","subSchemas":[{"ref":"ResultSuccess__datasetId-string__"},{"ref":"ResultError_string_"}],"validators":{}}, + }, + // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa + "DatasetMetadata": { + "dataType": "refObject", + "properties": { + "promptVersionId": {"dataType":"string"}, + "inputRecordsIds": {"dataType":"array","array":{"dataType":"string"}}, + }, + "additionalProperties": false, + }, + // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa + "NewDatasetParams": { + "dataType": "refObject", + "properties": { + "datasetName": {"dataType":"string","required":true}, + "requestIds": {"dataType":"array","array":{"dataType":"string"},"required":true}, + "datasetType": {"dataType":"union","subSchemas":[{"dataType":"enum","enums":["experiment"]},{"dataType":"enum","enums":["helicone"]}],"required":true}, + "meta": {"ref":"DatasetMetadata"}, + }, + "additionalProperties": false, + }, + // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa + "Pick_FilterLeaf.request-or-prompts_versions_": { + "dataType": "refAlias", + "type": {"dataType":"nestedObjectLiteral","nestedProperties":{"request":{"ref":"Partial_RequestTableToOperators_"},"prompts_versions":{"ref":"Partial_PromptVersionsToOperators_"}},"validators":{}}, + }, + // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa + "FilterLeafSubset_request-or-prompts_versions_": { + "dataType": "refAlias", + "type": {"ref":"Pick_FilterLeaf.request-or-prompts_versions_","validators":{}}, + }, + // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa + "DatasetFilterNode": { + "dataType": "refAlias", + "type": {"dataType":"union","subSchemas":[{"ref":"FilterLeafSubset_request-or-prompts_versions_"},{"ref":"DatasetFilterBranch"},{"dataType":"enum","enums":["all"]}],"validators":{}}, + }, + // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa + "DatasetFilterBranch": { + "dataType": "refAlias", + "type": {"dataType":"nestedObjectLiteral","nestedProperties":{"right":{"ref":"DatasetFilterNode","required":true},"operator":{"dataType":"union","subSchemas":[{"dataType":"enum","enums":["or"]},{"dataType":"enum","enums":["and"]}],"required":true},"left":{"ref":"DatasetFilterNode","required":true}},"validators":{}}, + }, + // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa + "RandomDatasetParams": { + "dataType": "refObject", + "properties": { + "datasetName": {"dataType":"string","required":true}, + "filter": {"ref":"DatasetFilterNode","required":true}, + "offset": {"dataType":"double"}, + "limit": {"dataType":"double"}, + }, + "additionalProperties": false, + }, + // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa + "DatasetResult": { + "dataType": "refObject", + "properties": { + "id": {"dataType":"string","required":true}, + "name": {"dataType":"string","required":true}, + "created_at": {"dataType":"string","required":true}, + "meta": {"ref":"DatasetMetadata"}, + }, + "additionalProperties": false, + }, + // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa + "ResultSuccess_DatasetResult-Array_": { + "dataType": "refObject", + "properties": { + "data": {"dataType":"array","array":{"dataType":"refObject","ref":"DatasetResult"},"required":true}, + "error": {"dataType":"enum","enums":[null],"required":true}, + }, + "additionalProperties": false, + }, + // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa + "Result_DatasetResult-Array.string_": { + "dataType": "refAlias", + "type": {"dataType":"union","subSchemas":[{"ref":"ResultSuccess_DatasetResult-Array_"},{"ref":"ResultError_string_"}],"validators":{}}, + }, + // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa + "ResultSuccess___-Array_": { + "dataType": "refObject", + "properties": { + "data": {"dataType":"array","array":{"dataType":"nestedObjectLiteral","nestedProperties":{}},"required":true}, + "error": {"dataType":"enum","enums":[null],"required":true}, + }, + "additionalProperties": false, + }, + // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa + "Result___-Array.string_": { + "dataType": "refAlias", + "type": {"dataType":"union","subSchemas":[{"ref":"ResultSuccess___-Array_"},{"ref":"ResultError_string_"}],"validators":{}}, + }, + // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa "HeliconeDatasetMetadata": { "dataType": "refObject", "properties": { @@ -6489,14 +6489,14 @@ export function RegisterRoutes(app: Router) { } }); // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa - app.post('/v1/experiment/dataset', + app.post('/v1/experiment/new-empty', authenticateMiddleware([{"api_key":[]}]), - ...(fetchMiddlewares(ExperimentDatasetController)), - ...(fetchMiddlewares(ExperimentDatasetController.prototype.addDataset)), + ...(fetchMiddlewares(ExperimentController)), + ...(fetchMiddlewares(ExperimentController.prototype.createNewEmptyExperiment)), - async function ExperimentDatasetController_addDataset(request: ExRequest, response: ExResponse, next: any) { + async function ExperimentController_createNewEmptyExperiment(request: ExRequest, response: ExResponse, next: any) { const args: Record = { - requestBody: {"in":"body","name":"requestBody","required":true,"ref":"NewDatasetParams"}, + requestBody: {"in":"body","name":"requestBody","required":true,"dataType":"nestedObjectLiteral","nestedProperties":{"datasetId":{"dataType":"string","required":true},"metadata":{"ref":"Record_string.string_","required":true}}}, request: {"in":"request","name":"request","required":true,"dataType":"object"}, }; @@ -6506,10 +6506,10 @@ export function RegisterRoutes(app: Router) { try { validatedArgs = templateService.getValidatedArgs({ args, request, response }); - const controller = new ExperimentDatasetController(); + const controller = new ExperimentController(); await templateService.apiHandler({ - methodName: 'addDataset', + methodName: 'createNewEmptyExperiment', controller, response, next, @@ -6521,14 +6521,14 @@ export function RegisterRoutes(app: Router) { } }); // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa - app.post('/v1/experiment/dataset/random', + app.post('/v1/experiment/table/new', authenticateMiddleware([{"api_key":[]}]), - ...(fetchMiddlewares(ExperimentDatasetController)), - ...(fetchMiddlewares(ExperimentDatasetController.prototype.addRandomDataset)), + ...(fetchMiddlewares(ExperimentController)), + ...(fetchMiddlewares(ExperimentController.prototype.createNewExperimentTable)), - async function ExperimentDatasetController_addRandomDataset(request: ExRequest, response: ExResponse, next: any) { + async function ExperimentController_createNewExperimentTable(request: ExRequest, response: ExResponse, next: any) { const args: Record = { - requestBody: {"in":"body","name":"requestBody","required":true,"ref":"RandomDatasetParams"}, + requestBody: {"in":"body","name":"requestBody","required":true,"ref":"CreateExperimentTableParams"}, request: {"in":"request","name":"request","required":true,"dataType":"object"}, }; @@ -6538,10 +6538,10 @@ export function RegisterRoutes(app: Router) { try { validatedArgs = templateService.getValidatedArgs({ args, request, response }); - const controller = new ExperimentDatasetController(); + const controller = new ExperimentController(); await templateService.apiHandler({ - methodName: 'addRandomDataset', + methodName: 'createNewExperimentTable', controller, response, next, @@ -6553,14 +6553,14 @@ export function RegisterRoutes(app: Router) { } }); // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa - app.post('/v1/experiment/dataset/query', + app.post('/v1/experiment/table/:experimentTableId/query', authenticateMiddleware([{"api_key":[]}]), - ...(fetchMiddlewares(ExperimentDatasetController)), - ...(fetchMiddlewares(ExperimentDatasetController.prototype.getDatasets)), + ...(fetchMiddlewares(ExperimentController)), + ...(fetchMiddlewares(ExperimentController.prototype.getExperimentTableById)), - async function ExperimentDatasetController_getDatasets(request: ExRequest, response: ExResponse, next: any) { + async function ExperimentController_getExperimentTableById(request: ExRequest, response: ExResponse, next: any) { const args: Record = { - requestBody: {"in":"body","name":"requestBody","required":true,"dataType":"nestedObjectLiteral","nestedProperties":{"promptVersionId":{"dataType":"string"}}}, + experimentTableId: {"in":"path","name":"experimentTableId","required":true,"dataType":"string"}, request: {"in":"request","name":"request","required":true,"dataType":"object"}, }; @@ -6570,10 +6570,10 @@ export function RegisterRoutes(app: Router) { try { validatedArgs = templateService.getValidatedArgs({ args, request, response }); - const controller = new ExperimentDatasetController(); + const controller = new ExperimentController(); await templateService.apiHandler({ - methodName: 'getDatasets', + methodName: 'getExperimentTableById', controller, response, next, @@ -6585,16 +6585,15 @@ export function RegisterRoutes(app: Router) { } }); // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa - app.post('/v1/experiment/dataset/:datasetId/row/insert', + app.post('/v1/experiment/table/:experimentTableId/metadata/query', authenticateMiddleware([{"api_key":[]}]), - ...(fetchMiddlewares(ExperimentDatasetController)), - ...(fetchMiddlewares(ExperimentDatasetController.prototype.insertDatasetRow)), + ...(fetchMiddlewares(ExperimentController)), + ...(fetchMiddlewares(ExperimentController.prototype.getExperimentTableMetadata)), - async function ExperimentDatasetController_insertDatasetRow(request: ExRequest, response: ExResponse, next: any) { + async function ExperimentController_getExperimentTableMetadata(request: ExRequest, response: ExResponse, next: any) { const args: Record = { - requestBody: {"in":"body","name":"requestBody","required":true,"dataType":"nestedObjectLiteral","nestedProperties":{"originalColumnId":{"dataType":"string"},"inputs":{"ref":"Record_string.string_","required":true},"inputRecordId":{"dataType":"string","required":true}}}, + experimentTableId: {"in":"path","name":"experimentTableId","required":true,"dataType":"string"}, request: {"in":"request","name":"request","required":true,"dataType":"object"}, - datasetId: {"in":"path","name":"datasetId","required":true,"dataType":"string"}, }; // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa @@ -6603,10 +6602,10 @@ export function RegisterRoutes(app: Router) { try { validatedArgs = templateService.getValidatedArgs({ args, request, response }); - const controller = new ExperimentDatasetController(); + const controller = new ExperimentController(); await templateService.apiHandler({ - methodName: 'insertDatasetRow', + methodName: 'getExperimentTableMetadata', controller, response, next, @@ -6618,17 +6617,14 @@ export function RegisterRoutes(app: Router) { } }); // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa - app.post('/v1/experiment/dataset/:datasetId/version/:promptVersionId/row/new', + app.post('/v1/experiment/tables/query', authenticateMiddleware([{"api_key":[]}]), - ...(fetchMiddlewares(ExperimentDatasetController)), - ...(fetchMiddlewares(ExperimentDatasetController.prototype.createDatasetRow)), + ...(fetchMiddlewares(ExperimentController)), + ...(fetchMiddlewares(ExperimentController.prototype.getExperimentTables)), - async function ExperimentDatasetController_createDatasetRow(request: ExRequest, response: ExResponse, next: any) { + async function ExperimentController_getExperimentTables(request: ExRequest, response: ExResponse, next: any) { const args: Record = { - requestBody: {"in":"body","name":"requestBody","required":true,"dataType":"nestedObjectLiteral","nestedProperties":{"sourceRequest":{"dataType":"string"},"inputs":{"ref":"Record_string.string_","required":true}}}, request: {"in":"request","name":"request","required":true,"dataType":"object"}, - datasetId: {"in":"path","name":"datasetId","required":true,"dataType":"string"}, - promptVersionId: {"in":"path","name":"promptVersionId","required":true,"dataType":"string"}, }; // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa @@ -6637,10 +6633,10 @@ export function RegisterRoutes(app: Router) { try { validatedArgs = templateService.getValidatedArgs({ args, request, response }); - const controller = new ExperimentDatasetController(); + const controller = new ExperimentController(); await templateService.apiHandler({ - methodName: 'createDatasetRow', + methodName: 'getExperimentTables', controller, response, next, @@ -6652,15 +6648,16 @@ export function RegisterRoutes(app: Router) { } }); // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa - app.post('/v1/experiment/dataset/:datasetId/inputs/query', + app.post('/v1/experiment/table/:experimentTableId/cell', authenticateMiddleware([{"api_key":[]}]), - ...(fetchMiddlewares(ExperimentDatasetController)), - ...(fetchMiddlewares(ExperimentDatasetController.prototype.getDataset)), + ...(fetchMiddlewares(ExperimentController)), + ...(fetchMiddlewares(ExperimentController.prototype.createExperimentCell)), - async function ExperimentDatasetController_getDataset(request: ExRequest, response: ExResponse, next: any) { + async function ExperimentController_createExperimentCell(request: ExRequest, response: ExResponse, next: any) { const args: Record = { + experimentTableId: {"in":"path","name":"experimentTableId","required":true,"dataType":"string"}, + requestBody: {"in":"body","name":"requestBody","required":true,"dataType":"nestedObjectLiteral","nestedProperties":{"value":{"dataType":"union","subSchemas":[{"dataType":"string"},{"dataType":"enum","enums":[null]}],"required":true},"rowIndex":{"dataType":"double","required":true},"columnId":{"dataType":"string","required":true}}}, request: {"in":"request","name":"request","required":true,"dataType":"object"}, - datasetId: {"in":"path","name":"datasetId","required":true,"dataType":"string"}, }; // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa @@ -6669,10 +6666,10 @@ export function RegisterRoutes(app: Router) { try { validatedArgs = templateService.getValidatedArgs({ args, request, response }); - const controller = new ExperimentDatasetController(); + const controller = new ExperimentController(); await templateService.apiHandler({ - methodName: 'getDataset', + methodName: 'createExperimentCell', controller, response, next, @@ -6684,14 +6681,15 @@ export function RegisterRoutes(app: Router) { } }); // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa - app.post('/v1/experiment/dataset/:datasetId/mutate', + app.patch('/v1/experiment/table/:experimentTableId/cell', authenticateMiddleware([{"api_key":[]}]), - ...(fetchMiddlewares(ExperimentDatasetController)), - ...(fetchMiddlewares(ExperimentDatasetController.prototype.mutateDataset)), + ...(fetchMiddlewares(ExperimentController)), + ...(fetchMiddlewares(ExperimentController.prototype.updateExperimentCell)), - async function ExperimentDatasetController_mutateDataset(request: ExRequest, response: ExResponse, next: any) { + async function ExperimentController_updateExperimentCell(request: ExRequest, response: ExResponse, next: any) { const args: Record = { - requestBody: {"in":"body","name":"requestBody","required":true,"dataType":"nestedObjectLiteral","nestedProperties":{"removeRequests":{"dataType":"array","array":{"dataType":"string"},"required":true},"addRequests":{"dataType":"array","array":{"dataType":"string"},"required":true}}}, + experimentTableId: {"in":"path","name":"experimentTableId","required":true,"dataType":"string"}, + requestBody: {"in":"body","name":"requestBody","required":true,"dataType":"nestedObjectLiteral","nestedProperties":{"updateInputs":{"dataType":"boolean"},"metadata":{"dataType":"string"},"value":{"dataType":"string"},"status":{"dataType":"string"},"cellId":{"dataType":"string","required":true}}}, request: {"in":"request","name":"request","required":true,"dataType":"object"}, }; @@ -6701,10 +6699,10 @@ export function RegisterRoutes(app: Router) { try { validatedArgs = templateService.getValidatedArgs({ args, request, response }); - const controller = new ExperimentDatasetController(); + const controller = new ExperimentController(); await templateService.apiHandler({ - methodName: 'mutateDataset', + methodName: 'updateExperimentCell', controller, response, next, @@ -6716,14 +6714,15 @@ export function RegisterRoutes(app: Router) { } }); // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa - app.post('/v1/experiment/new-empty', + app.post('/v1/experiment/table/:experimentTableId/column', authenticateMiddleware([{"api_key":[]}]), ...(fetchMiddlewares(ExperimentController)), - ...(fetchMiddlewares(ExperimentController.prototype.createNewEmptyExperiment)), + ...(fetchMiddlewares(ExperimentController.prototype.createExperimentColumn)), - async function ExperimentController_createNewEmptyExperiment(request: ExRequest, response: ExResponse, next: any) { + async function ExperimentController_createExperimentColumn(request: ExRequest, response: ExResponse, next: any) { const args: Record = { - requestBody: {"in":"body","name":"requestBody","required":true,"dataType":"nestedObjectLiteral","nestedProperties":{"datasetId":{"dataType":"string","required":true},"metadata":{"ref":"Record_string.string_","required":true}}}, + experimentTableId: {"in":"path","name":"experimentTableId","required":true,"dataType":"string"}, + requestBody: {"in":"body","name":"requestBody","required":true,"dataType":"nestedObjectLiteral","nestedProperties":{"inputKeys":{"dataType":"array","array":{"dataType":"string"}},"promptVersionId":{"dataType":"string"},"hypothesisId":{"dataType":"string"},"columnType":{"dataType":"string","required":true},"columnName":{"dataType":"string","required":true}}}, request: {"in":"request","name":"request","required":true,"dataType":"object"}, }; @@ -6736,7 +6735,7 @@ export function RegisterRoutes(app: Router) { const controller = new ExperimentController(); await templateService.apiHandler({ - methodName: 'createNewEmptyExperiment', + methodName: 'createExperimentColumn', controller, response, next, @@ -6748,14 +6747,15 @@ export function RegisterRoutes(app: Router) { } }); // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa - app.post('/v1/experiment/table/new', + app.post('/v1/experiment/table/:experimentTableId/row/new', authenticateMiddleware([{"api_key":[]}]), ...(fetchMiddlewares(ExperimentController)), - ...(fetchMiddlewares(ExperimentController.prototype.createNewExperimentTable)), + ...(fetchMiddlewares(ExperimentController.prototype.createExperimentTableRow)), - async function ExperimentController_createNewExperimentTable(request: ExRequest, response: ExResponse, next: any) { + async function ExperimentController_createExperimentTableRow(request: ExRequest, response: ExResponse, next: any) { const args: Record = { - requestBody: {"in":"body","name":"requestBody","required":true,"ref":"CreateExperimentTableParams"}, + experimentTableId: {"in":"path","name":"experimentTableId","required":true,"dataType":"string"}, + requestBody: {"in":"body","name":"requestBody","required":true,"dataType":"nestedObjectLiteral","nestedProperties":{"inputs":{"ref":"Record_string.string_"},"sourceRequest":{"dataType":"string"},"promptVersionId":{"dataType":"string","required":true}}}, request: {"in":"request","name":"request","required":true,"dataType":"object"}, }; @@ -6768,7 +6768,7 @@ export function RegisterRoutes(app: Router) { const controller = new ExperimentController(); await templateService.apiHandler({ - methodName: 'createNewExperimentTable', + methodName: 'createExperimentTableRow', controller, response, next, @@ -6780,14 +6780,15 @@ export function RegisterRoutes(app: Router) { } }); // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa - app.post('/v1/experiment/table/:experimentTableId/query', + app.delete('/v1/experiment/table/:experimentTableId/row/:rowIndex', authenticateMiddleware([{"api_key":[]}]), ...(fetchMiddlewares(ExperimentController)), - ...(fetchMiddlewares(ExperimentController.prototype.getExperimentTableById)), + ...(fetchMiddlewares(ExperimentController.prototype.deleteExperimentTableRow)), - async function ExperimentController_getExperimentTableById(request: ExRequest, response: ExResponse, next: any) { + async function ExperimentController_deleteExperimentTableRow(request: ExRequest, response: ExResponse, next: any) { const args: Record = { experimentTableId: {"in":"path","name":"experimentTableId","required":true,"dataType":"string"}, + rowIndex: {"in":"path","name":"rowIndex","required":true,"dataType":"double"}, request: {"in":"request","name":"request","required":true,"dataType":"object"}, }; @@ -6800,7 +6801,7 @@ export function RegisterRoutes(app: Router) { const controller = new ExperimentController(); await templateService.apiHandler({ - methodName: 'getExperimentTableById', + methodName: 'deleteExperimentTableRow', controller, response, next, @@ -6812,14 +6813,15 @@ export function RegisterRoutes(app: Router) { } }); // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa - app.post('/v1/experiment/table/:experimentTableId/metadata/query', + app.post('/v1/experiment/table/:experimentTableId/row/insert/batch', authenticateMiddleware([{"api_key":[]}]), ...(fetchMiddlewares(ExperimentController)), - ...(fetchMiddlewares(ExperimentController.prototype.getExperimentTableMetadata)), + ...(fetchMiddlewares(ExperimentController.prototype.createExperimentTableRowWithCellsBatch)), - async function ExperimentController_getExperimentTableMetadata(request: ExRequest, response: ExResponse, next: any) { + async function ExperimentController_createExperimentTableRowWithCellsBatch(request: ExRequest, response: ExResponse, next: any) { const args: Record = { experimentTableId: {"in":"path","name":"experimentTableId","required":true,"dataType":"string"}, + requestBody: {"in":"body","name":"requestBody","required":true,"dataType":"nestedObjectLiteral","nestedProperties":{"rows":{"dataType":"array","array":{"dataType":"nestedObjectLiteral","nestedProperties":{"sourceRequest":{"dataType":"string"},"cells":{"dataType":"array","array":{"dataType":"nestedObjectLiteral","nestedProperties":{"metadata":{"dataType":"any"},"value":{"dataType":"union","subSchemas":[{"dataType":"string"},{"dataType":"enum","enums":[null]}],"required":true},"columnId":{"dataType":"string","required":true}}},"required":true},"datasetId":{"dataType":"string","required":true},"inputs":{"ref":"Record_string.string_","required":true},"inputRecordId":{"dataType":"string","required":true}}},"required":true}}}, request: {"in":"request","name":"request","required":true,"dataType":"object"}, }; @@ -6832,7 +6834,7 @@ export function RegisterRoutes(app: Router) { const controller = new ExperimentController(); await templateService.apiHandler({ - methodName: 'getExperimentTableMetadata', + methodName: 'createExperimentTableRowWithCellsBatch', controller, response, next, @@ -6844,13 +6846,14 @@ export function RegisterRoutes(app: Router) { } }); // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa - app.post('/v1/experiment/tables/query', + app.post('/v1/experiment/update-meta', authenticateMiddleware([{"api_key":[]}]), ...(fetchMiddlewares(ExperimentController)), - ...(fetchMiddlewares(ExperimentController.prototype.getExperimentTables)), + ...(fetchMiddlewares(ExperimentController.prototype.updateExperimentMeta)), - async function ExperimentController_getExperimentTables(request: ExRequest, response: ExResponse, next: any) { + async function ExperimentController_updateExperimentMeta(request: ExRequest, response: ExResponse, next: any) { const args: Record = { + requestBody: {"in":"body","name":"requestBody","required":true,"dataType":"nestedObjectLiteral","nestedProperties":{"meta":{"ref":"Record_string.string_","required":true},"experimentId":{"dataType":"string","required":true}}}, request: {"in":"request","name":"request","required":true,"dataType":"object"}, }; @@ -6863,7 +6866,7 @@ export function RegisterRoutes(app: Router) { const controller = new ExperimentController(); await templateService.apiHandler({ - methodName: 'getExperimentTables', + methodName: 'updateExperimentMeta', controller, response, next, @@ -6875,15 +6878,14 @@ export function RegisterRoutes(app: Router) { } }); // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa - app.post('/v1/experiment/table/:experimentTableId/cell', + app.post('/v1/experiment', authenticateMiddleware([{"api_key":[]}]), ...(fetchMiddlewares(ExperimentController)), - ...(fetchMiddlewares(ExperimentController.prototype.createExperimentCell)), + ...(fetchMiddlewares(ExperimentController.prototype.createNewExperimentOld)), - async function ExperimentController_createExperimentCell(request: ExRequest, response: ExResponse, next: any) { + async function ExperimentController_createNewExperimentOld(request: ExRequest, response: ExResponse, next: any) { const args: Record = { - experimentTableId: {"in":"path","name":"experimentTableId","required":true,"dataType":"string"}, - requestBody: {"in":"body","name":"requestBody","required":true,"dataType":"nestedObjectLiteral","nestedProperties":{"value":{"dataType":"union","subSchemas":[{"dataType":"string"},{"dataType":"enum","enums":[null]}],"required":true},"rowIndex":{"dataType":"double","required":true},"columnId":{"dataType":"string","required":true}}}, + requestBody: {"in":"body","name":"requestBody","required":true,"ref":"NewExperimentParams"}, request: {"in":"request","name":"request","required":true,"dataType":"object"}, }; @@ -6896,7 +6898,7 @@ export function RegisterRoutes(app: Router) { const controller = new ExperimentController(); await templateService.apiHandler({ - methodName: 'createExperimentCell', + methodName: 'createNewExperimentOld', controller, response, next, @@ -6908,15 +6910,14 @@ export function RegisterRoutes(app: Router) { } }); // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa - app.patch('/v1/experiment/table/:experimentTableId/cell', + app.post('/v1/experiment/hypothesis', authenticateMiddleware([{"api_key":[]}]), ...(fetchMiddlewares(ExperimentController)), - ...(fetchMiddlewares(ExperimentController.prototype.updateExperimentCell)), + ...(fetchMiddlewares(ExperimentController.prototype.createNewExperimentHypothesis)), - async function ExperimentController_updateExperimentCell(request: ExRequest, response: ExResponse, next: any) { + async function ExperimentController_createNewExperimentHypothesis(request: ExRequest, response: ExResponse, next: any) { const args: Record = { - experimentTableId: {"in":"path","name":"experimentTableId","required":true,"dataType":"string"}, - requestBody: {"in":"body","name":"requestBody","required":true,"dataType":"nestedObjectLiteral","nestedProperties":{"updateInputs":{"dataType":"boolean"},"metadata":{"dataType":"string"},"value":{"dataType":"string"},"status":{"dataType":"string"},"cellId":{"dataType":"string","required":true}}}, + requestBody: {"in":"body","name":"requestBody","required":true,"dataType":"nestedObjectLiteral","nestedProperties":{"status":{"dataType":"union","subSchemas":[{"dataType":"enum","enums":["PENDING"]},{"dataType":"enum","enums":["RUNNING"]},{"dataType":"enum","enums":["COMPLETED"]},{"dataType":"enum","enums":["FAILED"]}],"required":true},"providerKeyId":{"dataType":"string","required":true},"promptVersion":{"dataType":"string","required":true},"model":{"dataType":"string","required":true},"experimentId":{"dataType":"string","required":true}}}, request: {"in":"request","name":"request","required":true,"dataType":"object"}, }; @@ -6929,7 +6930,7 @@ export function RegisterRoutes(app: Router) { const controller = new ExperimentController(); await templateService.apiHandler({ - methodName: 'updateExperimentCell', + methodName: 'createNewExperimentHypothesis', controller, response, next, @@ -6941,15 +6942,14 @@ export function RegisterRoutes(app: Router) { } }); // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa - app.post('/v1/experiment/table/:experimentTableId/column', + app.post('/v1/experiment/hypothesis/:hypothesisId/scores/query', authenticateMiddleware([{"api_key":[]}]), ...(fetchMiddlewares(ExperimentController)), - ...(fetchMiddlewares(ExperimentController.prototype.createExperimentColumn)), + ...(fetchMiddlewares(ExperimentController.prototype.getExperimentHypothesisScores)), - async function ExperimentController_createExperimentColumn(request: ExRequest, response: ExResponse, next: any) { + async function ExperimentController_getExperimentHypothesisScores(request: ExRequest, response: ExResponse, next: any) { const args: Record = { - experimentTableId: {"in":"path","name":"experimentTableId","required":true,"dataType":"string"}, - requestBody: {"in":"body","name":"requestBody","required":true,"dataType":"nestedObjectLiteral","nestedProperties":{"inputKeys":{"dataType":"array","array":{"dataType":"string"}},"promptVersionId":{"dataType":"string"},"hypothesisId":{"dataType":"string"},"columnType":{"dataType":"string","required":true},"columnName":{"dataType":"string","required":true}}}, + hypothesisId: {"in":"path","name":"hypothesisId","required":true,"dataType":"string"}, request: {"in":"request","name":"request","required":true,"dataType":"object"}, }; @@ -6962,7 +6962,7 @@ export function RegisterRoutes(app: Router) { const controller = new ExperimentController(); await templateService.apiHandler({ - methodName: 'createExperimentColumn', + methodName: 'getExperimentHypothesisScores', controller, response, next, @@ -6974,15 +6974,14 @@ export function RegisterRoutes(app: Router) { } }); // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa - app.post('/v1/experiment/table/:experimentTableId/row/new', + app.get('/v1/experiment/:experimentId/evaluators', authenticateMiddleware([{"api_key":[]}]), ...(fetchMiddlewares(ExperimentController)), - ...(fetchMiddlewares(ExperimentController.prototype.createExperimentTableRow)), + ...(fetchMiddlewares(ExperimentController.prototype.getExperimentEvaluators)), - async function ExperimentController_createExperimentTableRow(request: ExRequest, response: ExResponse, next: any) { + async function ExperimentController_getExperimentEvaluators(request: ExRequest, response: ExResponse, next: any) { const args: Record = { - experimentTableId: {"in":"path","name":"experimentTableId","required":true,"dataType":"string"}, - requestBody: {"in":"body","name":"requestBody","required":true,"dataType":"nestedObjectLiteral","nestedProperties":{"inputs":{"ref":"Record_string.string_"},"sourceRequest":{"dataType":"string"},"promptVersionId":{"dataType":"string","required":true}}}, + experimentId: {"in":"path","name":"experimentId","required":true,"dataType":"string"}, request: {"in":"request","name":"request","required":true,"dataType":"object"}, }; @@ -6995,7 +6994,7 @@ export function RegisterRoutes(app: Router) { const controller = new ExperimentController(); await templateService.apiHandler({ - methodName: 'createExperimentTableRow', + methodName: 'getExperimentEvaluators', controller, response, next, @@ -7007,15 +7006,14 @@ export function RegisterRoutes(app: Router) { } }); // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa - app.delete('/v1/experiment/table/:experimentTableId/row/:rowIndex', + app.post('/v1/experiment/:experimentId/evaluators/run', authenticateMiddleware([{"api_key":[]}]), ...(fetchMiddlewares(ExperimentController)), - ...(fetchMiddlewares(ExperimentController.prototype.deleteExperimentTableRow)), + ...(fetchMiddlewares(ExperimentController.prototype.runExperimentEvaluatorsOld)), - async function ExperimentController_deleteExperimentTableRow(request: ExRequest, response: ExResponse, next: any) { + async function ExperimentController_runExperimentEvaluatorsOld(request: ExRequest, response: ExResponse, next: any) { const args: Record = { - experimentTableId: {"in":"path","name":"experimentTableId","required":true,"dataType":"string"}, - rowIndex: {"in":"path","name":"rowIndex","required":true,"dataType":"double"}, + experimentId: {"in":"path","name":"experimentId","required":true,"dataType":"string"}, request: {"in":"request","name":"request","required":true,"dataType":"object"}, }; @@ -7028,7 +7026,7 @@ export function RegisterRoutes(app: Router) { const controller = new ExperimentController(); await templateService.apiHandler({ - methodName: 'deleteExperimentTableRow', + methodName: 'runExperimentEvaluatorsOld', controller, response, next, @@ -7040,15 +7038,15 @@ export function RegisterRoutes(app: Router) { } }); // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa - app.post('/v1/experiment/table/:experimentTableId/row/insert/batch', + app.post('/v1/experiment/:experimentId/evaluators', authenticateMiddleware([{"api_key":[]}]), ...(fetchMiddlewares(ExperimentController)), - ...(fetchMiddlewares(ExperimentController.prototype.createExperimentTableRowWithCellsBatch)), + ...(fetchMiddlewares(ExperimentController.prototype.createExperimentEvaluatorOld)), - async function ExperimentController_createExperimentTableRowWithCellsBatch(request: ExRequest, response: ExResponse, next: any) { + async function ExperimentController_createExperimentEvaluatorOld(request: ExRequest, response: ExResponse, next: any) { const args: Record = { - experimentTableId: {"in":"path","name":"experimentTableId","required":true,"dataType":"string"}, - requestBody: {"in":"body","name":"requestBody","required":true,"dataType":"nestedObjectLiteral","nestedProperties":{"rows":{"dataType":"array","array":{"dataType":"nestedObjectLiteral","nestedProperties":{"sourceRequest":{"dataType":"string"},"cells":{"dataType":"array","array":{"dataType":"nestedObjectLiteral","nestedProperties":{"metadata":{"dataType":"any"},"value":{"dataType":"union","subSchemas":[{"dataType":"string"},{"dataType":"enum","enums":[null]}],"required":true},"columnId":{"dataType":"string","required":true}}},"required":true},"datasetId":{"dataType":"string","required":true},"inputs":{"ref":"Record_string.string_","required":true},"inputRecordId":{"dataType":"string","required":true}}},"required":true}}}, + experimentId: {"in":"path","name":"experimentId","required":true,"dataType":"string"}, + requestBody: {"in":"body","name":"requestBody","required":true,"dataType":"nestedObjectLiteral","nestedProperties":{"evaluatorId":{"dataType":"string","required":true}}}, request: {"in":"request","name":"request","required":true,"dataType":"object"}, }; @@ -7061,7 +7059,7 @@ export function RegisterRoutes(app: Router) { const controller = new ExperimentController(); await templateService.apiHandler({ - methodName: 'createExperimentTableRowWithCellsBatch', + methodName: 'createExperimentEvaluatorOld', controller, response, next, @@ -7073,14 +7071,15 @@ export function RegisterRoutes(app: Router) { } }); // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa - app.post('/v1/experiment/update-meta', + app.delete('/v1/experiment/:experimentId/evaluators/:evaluatorId', authenticateMiddleware([{"api_key":[]}]), ...(fetchMiddlewares(ExperimentController)), - ...(fetchMiddlewares(ExperimentController.prototype.updateExperimentMeta)), + ...(fetchMiddlewares(ExperimentController.prototype.deleteExperimentEvaluatorOld)), - async function ExperimentController_updateExperimentMeta(request: ExRequest, response: ExResponse, next: any) { + async function ExperimentController_deleteExperimentEvaluatorOld(request: ExRequest, response: ExResponse, next: any) { const args: Record = { - requestBody: {"in":"body","name":"requestBody","required":true,"dataType":"nestedObjectLiteral","nestedProperties":{"meta":{"ref":"Record_string.string_","required":true},"experimentId":{"dataType":"string","required":true}}}, + experimentId: {"in":"path","name":"experimentId","required":true,"dataType":"string"}, + evaluatorId: {"in":"path","name":"evaluatorId","required":true,"dataType":"string"}, request: {"in":"request","name":"request","required":true,"dataType":"object"}, }; @@ -7093,7 +7092,7 @@ export function RegisterRoutes(app: Router) { const controller = new ExperimentController(); await templateService.apiHandler({ - methodName: 'updateExperimentMeta', + methodName: 'deleteExperimentEvaluatorOld', controller, response, next, @@ -7105,14 +7104,14 @@ export function RegisterRoutes(app: Router) { } }); // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa - app.post('/v1/experiment', + app.post('/v1/experiment/query', authenticateMiddleware([{"api_key":[]}]), ...(fetchMiddlewares(ExperimentController)), - ...(fetchMiddlewares(ExperimentController.prototype.createNewExperimentOld)), + ...(fetchMiddlewares(ExperimentController.prototype.getExperimentsOld)), - async function ExperimentController_createNewExperimentOld(request: ExRequest, response: ExResponse, next: any) { + async function ExperimentController_getExperimentsOld(request: ExRequest, response: ExResponse, next: any) { const args: Record = { - requestBody: {"in":"body","name":"requestBody","required":true,"ref":"NewExperimentParams"}, + requestBody: {"in":"body","name":"requestBody","required":true,"dataType":"nestedObjectLiteral","nestedProperties":{"include":{"ref":"IncludeExperimentKeys"},"filter":{"ref":"ExperimentFilterNode","required":true}}}, request: {"in":"request","name":"request","required":true,"dataType":"object"}, }; @@ -7125,7 +7124,7 @@ export function RegisterRoutes(app: Router) { const controller = new ExperimentController(); await templateService.apiHandler({ - methodName: 'createNewExperimentOld', + methodName: 'getExperimentsOld', controller, response, next, @@ -7137,14 +7136,14 @@ export function RegisterRoutes(app: Router) { } }); // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa - app.post('/v1/experiment/hypothesis', + app.post('/v1/experiment/dataset', authenticateMiddleware([{"api_key":[]}]), - ...(fetchMiddlewares(ExperimentController)), - ...(fetchMiddlewares(ExperimentController.prototype.createNewExperimentHypothesis)), + ...(fetchMiddlewares(ExperimentDatasetController)), + ...(fetchMiddlewares(ExperimentDatasetController.prototype.addDataset)), - async function ExperimentController_createNewExperimentHypothesis(request: ExRequest, response: ExResponse, next: any) { + async function ExperimentDatasetController_addDataset(request: ExRequest, response: ExResponse, next: any) { const args: Record = { - requestBody: {"in":"body","name":"requestBody","required":true,"dataType":"nestedObjectLiteral","nestedProperties":{"status":{"dataType":"union","subSchemas":[{"dataType":"enum","enums":["PENDING"]},{"dataType":"enum","enums":["RUNNING"]},{"dataType":"enum","enums":["COMPLETED"]},{"dataType":"enum","enums":["FAILED"]}],"required":true},"providerKeyId":{"dataType":"string","required":true},"promptVersion":{"dataType":"string","required":true},"model":{"dataType":"string","required":true},"experimentId":{"dataType":"string","required":true}}}, + requestBody: {"in":"body","name":"requestBody","required":true,"ref":"NewDatasetParams"}, request: {"in":"request","name":"request","required":true,"dataType":"object"}, }; @@ -7154,10 +7153,10 @@ export function RegisterRoutes(app: Router) { try { validatedArgs = templateService.getValidatedArgs({ args, request, response }); - const controller = new ExperimentController(); + const controller = new ExperimentDatasetController(); await templateService.apiHandler({ - methodName: 'createNewExperimentHypothesis', + methodName: 'addDataset', controller, response, next, @@ -7169,14 +7168,14 @@ export function RegisterRoutes(app: Router) { } }); // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa - app.post('/v1/experiment/hypothesis/:hypothesisId/scores/query', + app.post('/v1/experiment/dataset/random', authenticateMiddleware([{"api_key":[]}]), - ...(fetchMiddlewares(ExperimentController)), - ...(fetchMiddlewares(ExperimentController.prototype.getExperimentHypothesisScores)), + ...(fetchMiddlewares(ExperimentDatasetController)), + ...(fetchMiddlewares(ExperimentDatasetController.prototype.addRandomDataset)), - async function ExperimentController_getExperimentHypothesisScores(request: ExRequest, response: ExResponse, next: any) { + async function ExperimentDatasetController_addRandomDataset(request: ExRequest, response: ExResponse, next: any) { const args: Record = { - hypothesisId: {"in":"path","name":"hypothesisId","required":true,"dataType":"string"}, + requestBody: {"in":"body","name":"requestBody","required":true,"ref":"RandomDatasetParams"}, request: {"in":"request","name":"request","required":true,"dataType":"object"}, }; @@ -7186,10 +7185,10 @@ export function RegisterRoutes(app: Router) { try { validatedArgs = templateService.getValidatedArgs({ args, request, response }); - const controller = new ExperimentController(); + const controller = new ExperimentDatasetController(); await templateService.apiHandler({ - methodName: 'getExperimentHypothesisScores', + methodName: 'addRandomDataset', controller, response, next, @@ -7201,14 +7200,14 @@ export function RegisterRoutes(app: Router) { } }); // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa - app.get('/v1/experiment/:experimentId/evaluators', + app.post('/v1/experiment/dataset/query', authenticateMiddleware([{"api_key":[]}]), - ...(fetchMiddlewares(ExperimentController)), - ...(fetchMiddlewares(ExperimentController.prototype.getExperimentEvaluators)), + ...(fetchMiddlewares(ExperimentDatasetController)), + ...(fetchMiddlewares(ExperimentDatasetController.prototype.getDatasets)), - async function ExperimentController_getExperimentEvaluators(request: ExRequest, response: ExResponse, next: any) { + async function ExperimentDatasetController_getDatasets(request: ExRequest, response: ExResponse, next: any) { const args: Record = { - experimentId: {"in":"path","name":"experimentId","required":true,"dataType":"string"}, + requestBody: {"in":"body","name":"requestBody","required":true,"dataType":"nestedObjectLiteral","nestedProperties":{"promptVersionId":{"dataType":"string"}}}, request: {"in":"request","name":"request","required":true,"dataType":"object"}, }; @@ -7218,10 +7217,10 @@ export function RegisterRoutes(app: Router) { try { validatedArgs = templateService.getValidatedArgs({ args, request, response }); - const controller = new ExperimentController(); + const controller = new ExperimentDatasetController(); await templateService.apiHandler({ - methodName: 'getExperimentEvaluators', + methodName: 'getDatasets', controller, response, next, @@ -7233,15 +7232,16 @@ export function RegisterRoutes(app: Router) { } }); // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa - app.post('/v1/experiment/:experimentId/evaluators/run', + app.post('/v1/experiment/dataset/:datasetId/row/insert', authenticateMiddleware([{"api_key":[]}]), - ...(fetchMiddlewares(ExperimentController)), - ...(fetchMiddlewares(ExperimentController.prototype.runExperimentEvaluatorsOld)), + ...(fetchMiddlewares(ExperimentDatasetController)), + ...(fetchMiddlewares(ExperimentDatasetController.prototype.insertDatasetRow)), - async function ExperimentController_runExperimentEvaluatorsOld(request: ExRequest, response: ExResponse, next: any) { + async function ExperimentDatasetController_insertDatasetRow(request: ExRequest, response: ExResponse, next: any) { const args: Record = { - experimentId: {"in":"path","name":"experimentId","required":true,"dataType":"string"}, + requestBody: {"in":"body","name":"requestBody","required":true,"dataType":"nestedObjectLiteral","nestedProperties":{"originalColumnId":{"dataType":"string"},"inputs":{"ref":"Record_string.string_","required":true},"inputRecordId":{"dataType":"string","required":true}}}, request: {"in":"request","name":"request","required":true,"dataType":"object"}, + datasetId: {"in":"path","name":"datasetId","required":true,"dataType":"string"}, }; // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa @@ -7250,10 +7250,10 @@ export function RegisterRoutes(app: Router) { try { validatedArgs = templateService.getValidatedArgs({ args, request, response }); - const controller = new ExperimentController(); + const controller = new ExperimentDatasetController(); await templateService.apiHandler({ - methodName: 'runExperimentEvaluatorsOld', + methodName: 'insertDatasetRow', controller, response, next, @@ -7265,16 +7265,17 @@ export function RegisterRoutes(app: Router) { } }); // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa - app.post('/v1/experiment/:experimentId/evaluators', + app.post('/v1/experiment/dataset/:datasetId/version/:promptVersionId/row/new', authenticateMiddleware([{"api_key":[]}]), - ...(fetchMiddlewares(ExperimentController)), - ...(fetchMiddlewares(ExperimentController.prototype.createExperimentEvaluatorOld)), + ...(fetchMiddlewares(ExperimentDatasetController)), + ...(fetchMiddlewares(ExperimentDatasetController.prototype.createDatasetRow)), - async function ExperimentController_createExperimentEvaluatorOld(request: ExRequest, response: ExResponse, next: any) { + async function ExperimentDatasetController_createDatasetRow(request: ExRequest, response: ExResponse, next: any) { const args: Record = { - experimentId: {"in":"path","name":"experimentId","required":true,"dataType":"string"}, - requestBody: {"in":"body","name":"requestBody","required":true,"dataType":"nestedObjectLiteral","nestedProperties":{"evaluatorId":{"dataType":"string","required":true}}}, + requestBody: {"in":"body","name":"requestBody","required":true,"dataType":"nestedObjectLiteral","nestedProperties":{"sourceRequest":{"dataType":"string"},"inputs":{"ref":"Record_string.string_","required":true}}}, request: {"in":"request","name":"request","required":true,"dataType":"object"}, + datasetId: {"in":"path","name":"datasetId","required":true,"dataType":"string"}, + promptVersionId: {"in":"path","name":"promptVersionId","required":true,"dataType":"string"}, }; // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa @@ -7283,10 +7284,10 @@ export function RegisterRoutes(app: Router) { try { validatedArgs = templateService.getValidatedArgs({ args, request, response }); - const controller = new ExperimentController(); + const controller = new ExperimentDatasetController(); await templateService.apiHandler({ - methodName: 'createExperimentEvaluatorOld', + methodName: 'createDatasetRow', controller, response, next, @@ -7298,16 +7299,15 @@ export function RegisterRoutes(app: Router) { } }); // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa - app.delete('/v1/experiment/:experimentId/evaluators/:evaluatorId', + app.post('/v1/experiment/dataset/:datasetId/inputs/query', authenticateMiddleware([{"api_key":[]}]), - ...(fetchMiddlewares(ExperimentController)), - ...(fetchMiddlewares(ExperimentController.prototype.deleteExperimentEvaluatorOld)), + ...(fetchMiddlewares(ExperimentDatasetController)), + ...(fetchMiddlewares(ExperimentDatasetController.prototype.getDataset)), - async function ExperimentController_deleteExperimentEvaluatorOld(request: ExRequest, response: ExResponse, next: any) { + async function ExperimentDatasetController_getDataset(request: ExRequest, response: ExResponse, next: any) { const args: Record = { - experimentId: {"in":"path","name":"experimentId","required":true,"dataType":"string"}, - evaluatorId: {"in":"path","name":"evaluatorId","required":true,"dataType":"string"}, request: {"in":"request","name":"request","required":true,"dataType":"object"}, + datasetId: {"in":"path","name":"datasetId","required":true,"dataType":"string"}, }; // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa @@ -7316,10 +7316,10 @@ export function RegisterRoutes(app: Router) { try { validatedArgs = templateService.getValidatedArgs({ args, request, response }); - const controller = new ExperimentController(); + const controller = new ExperimentDatasetController(); await templateService.apiHandler({ - methodName: 'deleteExperimentEvaluatorOld', + methodName: 'getDataset', controller, response, next, @@ -7331,14 +7331,14 @@ export function RegisterRoutes(app: Router) { } }); // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa - app.post('/v1/experiment/query', + app.post('/v1/experiment/dataset/:datasetId/mutate', authenticateMiddleware([{"api_key":[]}]), - ...(fetchMiddlewares(ExperimentController)), - ...(fetchMiddlewares(ExperimentController.prototype.getExperimentsOld)), + ...(fetchMiddlewares(ExperimentDatasetController)), + ...(fetchMiddlewares(ExperimentDatasetController.prototype.mutateDataset)), - async function ExperimentController_getExperimentsOld(request: ExRequest, response: ExResponse, next: any) { + async function ExperimentDatasetController_mutateDataset(request: ExRequest, response: ExResponse, next: any) { const args: Record = { - requestBody: {"in":"body","name":"requestBody","required":true,"dataType":"nestedObjectLiteral","nestedProperties":{"include":{"ref":"IncludeExperimentKeys"},"filter":{"ref":"ExperimentFilterNode","required":true}}}, + requestBody: {"in":"body","name":"requestBody","required":true,"dataType":"nestedObjectLiteral","nestedProperties":{"removeRequests":{"dataType":"array","array":{"dataType":"string"},"required":true},"addRequests":{"dataType":"array","array":{"dataType":"string"},"required":true}}}, request: {"in":"request","name":"request","required":true,"dataType":"object"}, }; @@ -7348,10 +7348,10 @@ export function RegisterRoutes(app: Router) { try { validatedArgs = templateService.getValidatedArgs({ args, request, response }); - const controller = new ExperimentController(); + const controller = new ExperimentDatasetController(); await templateService.apiHandler({ - methodName: 'getExperimentsOld', + methodName: 'mutateDataset', controller, response, next, @@ -8937,7 +8937,6 @@ export function RegisterRoutes(app: Router) { async function PiController_getTotalRequests(request: ExRequest, response: ExResponse, next: any) { const args: Record = { - body: {"in":"body","name":"body","required":true,"dataType":"nestedObjectLiteral","nestedProperties":{"endTime":{"dataType":"string","required":true},"startTime":{"dataType":"string","required":true}}}, request: {"in":"request","name":"request","required":true,"dataType":"object"}, }; diff --git a/valhalla/jawn/src/tsoa-build/private/swagger.json b/valhalla/jawn/src/tsoa-build/private/swagger.json index a603b8c3b2..b19a07b6c8 100644 --- a/valhalla/jawn/src/tsoa-build/private/swagger.json +++ b/valhalla/jawn/src/tsoa-build/private/swagger.json @@ -6105,257 +6105,6 @@ } ] }, - "ResultSuccess__datasetId-string__": { - "properties": { - "data": { - "properties": { - "datasetId": { - "type": "string" - } - }, - "required": [ - "datasetId" - ], - "type": "object" - }, - "error": { - "type": "number", - "enum": [ - null - ], - "nullable": true - } - }, - "required": [ - "data", - "error" - ], - "type": "object", - "additionalProperties": false - }, - "Result__datasetId-string_.string_": { - "anyOf": [ - { - "$ref": "#/components/schemas/ResultSuccess__datasetId-string__" - }, - { - "$ref": "#/components/schemas/ResultError_string_" - } - ] - }, - "DatasetMetadata": { - "properties": { - "promptVersionId": { - "type": "string" - }, - "inputRecordsIds": { - "items": { - "type": "string" - }, - "type": "array" - } - }, - "type": "object", - "additionalProperties": false - }, - "NewDatasetParams": { - "properties": { - "datasetName": { - "type": "string" - }, - "requestIds": { - "items": { - "type": "string" - }, - "type": "array" - }, - "datasetType": { - "type": "string", - "enum": [ - "experiment", - "helicone" - ] - }, - "meta": { - "$ref": "#/components/schemas/DatasetMetadata" - } - }, - "required": [ - "datasetName", - "requestIds", - "datasetType" - ], - "type": "object", - "additionalProperties": false - }, - "Pick_FilterLeaf.request-or-prompts_versions_": { - "properties": { - "request": { - "$ref": "#/components/schemas/Partial_RequestTableToOperators_" - }, - "prompts_versions": { - "$ref": "#/components/schemas/Partial_PromptVersionsToOperators_" - } - }, - "type": "object", - "description": "From T, pick a set of properties whose keys are in the union K" - }, - "FilterLeafSubset_request-or-prompts_versions_": { - "$ref": "#/components/schemas/Pick_FilterLeaf.request-or-prompts_versions_" - }, - "DatasetFilterNode": { - "anyOf": [ - { - "$ref": "#/components/schemas/FilterLeafSubset_request-or-prompts_versions_" - }, - { - "$ref": "#/components/schemas/DatasetFilterBranch" - }, - { - "type": "string", - "enum": [ - "all" - ] - } - ] - }, - "DatasetFilterBranch": { - "properties": { - "right": { - "$ref": "#/components/schemas/DatasetFilterNode" - }, - "operator": { - "type": "string", - "enum": [ - "or", - "and" - ] - }, - "left": { - "$ref": "#/components/schemas/DatasetFilterNode" - } - }, - "required": [ - "right", - "operator", - "left" - ], - "type": "object" - }, - "RandomDatasetParams": { - "properties": { - "datasetName": { - "type": "string" - }, - "filter": { - "$ref": "#/components/schemas/DatasetFilterNode" - }, - "offset": { - "type": "number", - "format": "double" - }, - "limit": { - "type": "number", - "format": "double" - } - }, - "required": [ - "datasetName", - "filter" - ], - "type": "object", - "additionalProperties": false - }, - "DatasetResult": { - "properties": { - "id": { - "type": "string" - }, - "name": { - "type": "string" - }, - "created_at": { - "type": "string" - }, - "meta": { - "$ref": "#/components/schemas/DatasetMetadata" - } - }, - "required": [ - "id", - "name", - "created_at" - ], - "type": "object", - "additionalProperties": false - }, - "ResultSuccess_DatasetResult-Array_": { - "properties": { - "data": { - "items": { - "$ref": "#/components/schemas/DatasetResult" - }, - "type": "array" - }, - "error": { - "type": "number", - "enum": [ - null - ], - "nullable": true - } - }, - "required": [ - "data", - "error" - ], - "type": "object", - "additionalProperties": false - }, - "Result_DatasetResult-Array.string_": { - "anyOf": [ - { - "$ref": "#/components/schemas/ResultSuccess_DatasetResult-Array_" - }, - { - "$ref": "#/components/schemas/ResultError_string_" - } - ] - }, - "ResultSuccess___-Array_": { - "properties": { - "data": { - "items": { - "properties": {}, - "type": "object" - }, - "type": "array" - }, - "error": { - "type": "number", - "enum": [ - null - ], - "nullable": true - } - }, - "required": [ - "data", - "error" - ], - "type": "object", - "additionalProperties": false - }, - "Result___-Array.string_": { - "anyOf": [ - { - "$ref": "#/components/schemas/ResultSuccess___-Array_" - }, - { - "$ref": "#/components/schemas/ResultError_string_" - } - ] - }, "ResultSuccess__tableId-string--experimentId-string__": { "properties": { "data": { @@ -7276,11 +7025,262 @@ "type": "object", "additionalProperties": false }, - "HeliconeDatasetMetadata": { + "ResultSuccess__datasetId-string__": { "properties": { - "promptVersionId": { - "type": "string" - }, + "data": { + "properties": { + "datasetId": { + "type": "string" + } + }, + "required": [ + "datasetId" + ], + "type": "object" + }, + "error": { + "type": "number", + "enum": [ + null + ], + "nullable": true + } + }, + "required": [ + "data", + "error" + ], + "type": "object", + "additionalProperties": false + }, + "Result__datasetId-string_.string_": { + "anyOf": [ + { + "$ref": "#/components/schemas/ResultSuccess__datasetId-string__" + }, + { + "$ref": "#/components/schemas/ResultError_string_" + } + ] + }, + "DatasetMetadata": { + "properties": { + "promptVersionId": { + "type": "string" + }, + "inputRecordsIds": { + "items": { + "type": "string" + }, + "type": "array" + } + }, + "type": "object", + "additionalProperties": false + }, + "NewDatasetParams": { + "properties": { + "datasetName": { + "type": "string" + }, + "requestIds": { + "items": { + "type": "string" + }, + "type": "array" + }, + "datasetType": { + "type": "string", + "enum": [ + "experiment", + "helicone" + ] + }, + "meta": { + "$ref": "#/components/schemas/DatasetMetadata" + } + }, + "required": [ + "datasetName", + "requestIds", + "datasetType" + ], + "type": "object", + "additionalProperties": false + }, + "Pick_FilterLeaf.request-or-prompts_versions_": { + "properties": { + "request": { + "$ref": "#/components/schemas/Partial_RequestTableToOperators_" + }, + "prompts_versions": { + "$ref": "#/components/schemas/Partial_PromptVersionsToOperators_" + } + }, + "type": "object", + "description": "From T, pick a set of properties whose keys are in the union K" + }, + "FilterLeafSubset_request-or-prompts_versions_": { + "$ref": "#/components/schemas/Pick_FilterLeaf.request-or-prompts_versions_" + }, + "DatasetFilterNode": { + "anyOf": [ + { + "$ref": "#/components/schemas/FilterLeafSubset_request-or-prompts_versions_" + }, + { + "$ref": "#/components/schemas/DatasetFilterBranch" + }, + { + "type": "string", + "enum": [ + "all" + ] + } + ] + }, + "DatasetFilterBranch": { + "properties": { + "right": { + "$ref": "#/components/schemas/DatasetFilterNode" + }, + "operator": { + "type": "string", + "enum": [ + "or", + "and" + ] + }, + "left": { + "$ref": "#/components/schemas/DatasetFilterNode" + } + }, + "required": [ + "right", + "operator", + "left" + ], + "type": "object" + }, + "RandomDatasetParams": { + "properties": { + "datasetName": { + "type": "string" + }, + "filter": { + "$ref": "#/components/schemas/DatasetFilterNode" + }, + "offset": { + "type": "number", + "format": "double" + }, + "limit": { + "type": "number", + "format": "double" + } + }, + "required": [ + "datasetName", + "filter" + ], + "type": "object", + "additionalProperties": false + }, + "DatasetResult": { + "properties": { + "id": { + "type": "string" + }, + "name": { + "type": "string" + }, + "created_at": { + "type": "string" + }, + "meta": { + "$ref": "#/components/schemas/DatasetMetadata" + } + }, + "required": [ + "id", + "name", + "created_at" + ], + "type": "object", + "additionalProperties": false + }, + "ResultSuccess_DatasetResult-Array_": { + "properties": { + "data": { + "items": { + "$ref": "#/components/schemas/DatasetResult" + }, + "type": "array" + }, + "error": { + "type": "number", + "enum": [ + null + ], + "nullable": true + } + }, + "required": [ + "data", + "error" + ], + "type": "object", + "additionalProperties": false + }, + "Result_DatasetResult-Array.string_": { + "anyOf": [ + { + "$ref": "#/components/schemas/ResultSuccess_DatasetResult-Array_" + }, + { + "$ref": "#/components/schemas/ResultError_string_" + } + ] + }, + "ResultSuccess___-Array_": { + "properties": { + "data": { + "items": { + "properties": {}, + "type": "object" + }, + "type": "array" + }, + "error": { + "type": "number", + "enum": [ + null + ], + "nullable": true + } + }, + "required": [ + "data", + "error" + ], + "type": "object", + "additionalProperties": false + }, + "Result___-Array.string_": { + "anyOf": [ + { + "$ref": "#/components/schemas/ResultSuccess___-Array_" + }, + { + "$ref": "#/components/schemas/ResultError_string_" + } + ] + }, + "HeliconeDatasetMetadata": { + "properties": { + "promptVersionId": { + "type": "string" + }, "inputRecordsIds": { "items": { "type": "string" @@ -14086,23 +14086,23 @@ "parameters": [] } }, - "/v1/experiment/dataset": { + "/v1/experiment/new-empty": { "post": { - "operationId": "AddDataset", + "operationId": "CreateNewEmptyExperiment", "responses": { "200": { "description": "Ok", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Result__datasetId-string_.string_" + "$ref": "#/components/schemas/Result__experimentId-string_.string_" } } } } }, "tags": [ - "Dataset" + "Experiment" ], "security": [ { @@ -14115,30 +14115,42 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/NewDatasetParams" + "properties": { + "datasetId": { + "type": "string" + }, + "metadata": { + "$ref": "#/components/schemas/Record_string.string_" + } + }, + "required": [ + "datasetId", + "metadata" + ], + "type": "object" } } } } } }, - "/v1/experiment/dataset/random": { + "/v1/experiment/table/new": { "post": { - "operationId": "AddRandomDataset", + "operationId": "CreateNewExperimentTable", "responses": { "200": { "description": "Ok", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Result__datasetId-string_.string_" + "$ref": "#/components/schemas/Result__tableId-string--experimentId-string_.string_" } } } } }, "tags": [ - "Dataset" + "Experiment" ], "security": [ { @@ -14151,71 +14163,65 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/RandomDatasetParams" + "$ref": "#/components/schemas/CreateExperimentTableParams" } } } } } }, - "/v1/experiment/dataset/query": { + "/v1/experiment/table/{experimentTableId}/query": { "post": { - "operationId": "GetDatasets", + "operationId": "GetExperimentTableById", "responses": { "200": { "description": "Ok", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Result_DatasetResult-Array.string_" + "$ref": "#/components/schemas/Result_ExperimentTable.string_" } } } } }, "tags": [ - "Dataset" + "Experiment" ], "security": [ { "api_key": [] } ], - "parameters": [], - "requestBody": { - "required": true, - "content": { - "application/json": { - "schema": { - "properties": { - "promptVersionId": { - "type": "string" - } - }, - "type": "object" - } + "parameters": [ + { + "in": "path", + "name": "experimentTableId", + "required": true, + "schema": { + "type": "string" } } - } + ] } }, - "/v1/experiment/dataset/{datasetId}/row/insert": { + "/v1/experiment/table/{experimentTableId}/metadata/query": { "post": { - "operationId": "InsertDatasetRow", + "operationId": "GetExperimentTableMetadata", "responses": { "200": { "description": "Ok", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Result_string.string_" + "$ref": "#/components/schemas/Result_ExperimentTableSimplified.string_" } } } } }, "tags": [ - "Dataset" + "Experiment" ], "security": [ { @@ -14225,57 +14231,58 @@ "parameters": [ { "in": "path", - "name": "datasetId", + "name": "experimentTableId", "required": true, "schema": { "type": "string" } } - ], - "requestBody": { - "required": true, - "content": { - "application/json": { - "schema": { - "properties": { - "originalColumnId": { - "type": "string" - }, - "inputs": { - "$ref": "#/components/schemas/Record_string.string_" - }, - "inputRecordId": { - "type": "string" - } - }, - "required": [ - "inputs", - "inputRecordId" - ], - "type": "object" + ] + } + }, + "/v1/experiment/tables/query": { + "post": { + "operationId": "GetExperimentTables", + "responses": { + "200": { + "description": "Ok", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/Result_ExperimentTableSimplified-Array.string_" + } } } } - } + }, + "tags": [ + "Experiment" + ], + "security": [ + { + "api_key": [] + } + ], + "parameters": [] } }, - "/v1/experiment/dataset/{datasetId}/version/{promptVersionId}/row/new": { + "/v1/experiment/table/{experimentTableId}/cell": { "post": { - "operationId": "CreateDatasetRow", + "operationId": "CreateExperimentCell", "responses": { "200": { "description": "Ok", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Result_string.string_" + "$ref": "#/components/schemas/Result_null.string_" } } } } }, "tags": [ - "Dataset" + "Experiment" ], "security": [ { @@ -14285,15 +14292,7 @@ "parameters": [ { "in": "path", - "name": "datasetId", - "required": true, - "schema": { - "type": "string" - } - }, - { - "in": "path", - "name": "promptVersionId", + "name": "experimentTableId", "required": true, "schema": { "type": "string" @@ -14306,40 +14305,45 @@ "application/json": { "schema": { "properties": { - "sourceRequest": { - "type": "string" + "value": { + "type": "string", + "nullable": true }, - "inputs": { - "$ref": "#/components/schemas/Record_string.string_" + "rowIndex": { + "type": "number", + "format": "double" + }, + "columnId": { + "type": "string" } }, "required": [ - "inputs" + "value", + "rowIndex", + "columnId" ], "type": "object" } } } } - } - }, - "/v1/experiment/dataset/{datasetId}/inputs/query": { - "post": { - "operationId": "GetDataset", + }, + "patch": { + "operationId": "UpdateExperimentCell", "responses": { "200": { "description": "Ok", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Result_PromptInputRecord-Array.string_" + "$ref": "#/components/schemas/Result_null.string_" } } } } }, "tags": [ - "Dataset" + "Experiment" ], "security": [ { @@ -14349,61 +14353,106 @@ "parameters": [ { "in": "path", - "name": "datasetId", + "name": "experimentTableId", "required": true, "schema": { "type": "string" } } - ] + ], + "requestBody": { + "required": true, + "content": { + "application/json": { + "schema": { + "properties": { + "updateInputs": { + "type": "boolean" + }, + "metadata": { + "type": "string" + }, + "value": { + "type": "string" + }, + "status": { + "type": "string" + }, + "cellId": { + "type": "string" + } + }, + "required": [ + "cellId" + ], + "type": "object" + } + } + } + } } }, - "/v1/experiment/dataset/{datasetId}/mutate": { + "/v1/experiment/table/{experimentTableId}/column": { "post": { - "operationId": "MutateDataset", + "operationId": "CreateExperimentColumn", "responses": { "200": { "description": "Ok", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Result___-Array.string_" + "$ref": "#/components/schemas/Result_null.string_" } } } } }, "tags": [ - "Dataset" + "Experiment" ], "security": [ { "api_key": [] } ], - "parameters": [], + "parameters": [ + { + "in": "path", + "name": "experimentTableId", + "required": true, + "schema": { + "type": "string" + } + } + ], "requestBody": { "required": true, "content": { "application/json": { "schema": { "properties": { - "removeRequests": { + "inputKeys": { "items": { "type": "string" }, "type": "array" }, - "addRequests": { - "items": { - "type": "string" - }, - "type": "array" + "promptVersionId": { + "type": "string" + }, + "hypothesisId": { + "type": "string" + }, + "columnType": { + "type": "string" + }, + "columnName": { + "type": "string" } }, "required": [ - "removeRequests", - "addRequests" + "columnType", + "columnName" ], "type": "object" } @@ -14412,16 +14461,16 @@ } } }, - "/v1/experiment/new-empty": { + "/v1/experiment/table/{experimentTableId}/row/new": { "post": { - "operationId": "CreateNewEmptyExperiment", + "operationId": "CreateExperimentTableRow", "responses": { "200": { "description": "Ok", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Result__experimentId-string_.string_" + "$ref": "#/components/schemas/Result_null.string_" } } } @@ -14435,23 +14484,34 @@ "api_key": [] } ], - "parameters": [], + "parameters": [ + { + "in": "path", + "name": "experimentTableId", + "required": true, + "schema": { + "type": "string" + } + } + ], "requestBody": { "required": true, "content": { "application/json": { "schema": { "properties": { - "datasetId": { + "inputs": { + "$ref": "#/components/schemas/Record_string.string_" + }, + "sourceRequest": { "type": "string" }, - "metadata": { - "$ref": "#/components/schemas/Record_string.string_" + "promptVersionId": { + "type": "string" } }, "required": [ - "datasetId", - "metadata" + "promptVersionId" ], "type": "object" } @@ -14460,16 +14520,16 @@ } } }, - "/v1/experiment/table/new": { - "post": { - "operationId": "CreateNewExperimentTable", + "/v1/experiment/table/{experimentTableId}/row/{rowIndex}": { + "delete": { + "operationId": "DeleteExperimentTableRow", "responses": { "200": { "description": "Ok", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Result__tableId-string--experimentId-string_.string_" + "$ref": "#/components/schemas/Result_null.string_" } } } @@ -14483,29 +14543,37 @@ "api_key": [] } ], - "parameters": [], - "requestBody": { - "required": true, - "content": { - "application/json": { - "schema": { - "$ref": "#/components/schemas/CreateExperimentTableParams" - } + "parameters": [ + { + "in": "path", + "name": "experimentTableId", + "required": true, + "schema": { + "type": "string" + } + }, + { + "in": "path", + "name": "rowIndex", + "required": true, + "schema": { + "format": "double", + "type": "number" } } - } + ] } }, - "/v1/experiment/table/{experimentTableId}/query": { + "/v1/experiment/table/{experimentTableId}/row/insert/batch": { "post": { - "operationId": "GetExperimentTableById", + "operationId": "CreateExperimentTableRowWithCellsBatch", "responses": { "200": { "description": "Ok", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Result_ExperimentTable.string_" + "$ref": "#/components/schemas/Result_null.string_" } } } @@ -14528,19 +14596,87 @@ "type": "string" } } - ] + ], + "requestBody": { + "required": true, + "content": { + "application/json": { + "schema": { + "properties": { + "rows": { + "items": { + "properties": { + "sourceRequest": { + "type": "string" + }, + "cells": { + "items": { + "properties": { + "metadata": {}, + "value": { + "type": "string", + "nullable": true + }, + "columnId": { + "type": "string" + } + }, + "required": [ + "value", + "columnId" + ], + "type": "object" + }, + "type": "array" + }, + "datasetId": { + "type": "string" + }, + "inputs": { + "$ref": "#/components/schemas/Record_string.string_" + }, + "inputRecordId": { + "type": "string" + } + }, + "required": [ + "cells", + "datasetId", + "inputs", + "inputRecordId" + ], + "type": "object" + }, + "type": "array" + } + }, + "required": [ + "rows" + ], + "type": "object" + } + } + } + } } }, - "/v1/experiment/table/{experimentTableId}/metadata/query": { + "/v1/experiment/update-meta": { "post": { - "operationId": "GetExperimentTableMetadata", + "operationId": "UpdateExperimentMeta", "responses": { "200": { "description": "Ok", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Result_ExperimentTableSimplified.string_" + "anyOf": [ + { + "$ref": "#/components/schemas/ResultSuccess_unknown_" + }, + { + "$ref": "#/components/schemas/ResultError_PostgrestError_" + } + ] } } } @@ -14554,28 +14690,41 @@ "api_key": [] } ], - "parameters": [ - { - "in": "path", - "name": "experimentTableId", - "required": true, - "schema": { - "type": "string" + "parameters": [], + "requestBody": { + "required": true, + "content": { + "application/json": { + "schema": { + "properties": { + "meta": { + "$ref": "#/components/schemas/Record_string.string_" + }, + "experimentId": { + "type": "string" + } + }, + "required": [ + "meta", + "experimentId" + ], + "type": "object" + } } } - ] + } } }, - "/v1/experiment/tables/query": { + "/v1/experiment": { "post": { - "operationId": "GetExperimentTables", + "operationId": "CreateNewExperimentOld", "responses": { "200": { "description": "Ok", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Result_ExperimentTableSimplified-Array.string_" + "$ref": "#/components/schemas/Result__experimentId-string_.string_" } } } @@ -14589,19 +14738,29 @@ "api_key": [] } ], - "parameters": [] + "parameters": [], + "requestBody": { + "required": true, + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/NewExperimentParams" + } + } + } + } } }, - "/v1/experiment/table/{experimentTableId}/cell": { + "/v1/experiment/hypothesis": { "post": { - "operationId": "CreateExperimentCell", + "operationId": "CreateNewExperimentHypothesis", "responses": { "200": { "description": "Ok", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Result_null.string_" + "$ref": "#/components/schemas/Result__hypothesisId-string_.string_" } } } @@ -14615,54 +14774,59 @@ "api_key": [] } ], - "parameters": [ - { - "in": "path", - "name": "experimentTableId", - "required": true, - "schema": { - "type": "string" - } - } - ], + "parameters": [], "requestBody": { "required": true, "content": { "application/json": { "schema": { "properties": { - "value": { + "status": { "type": "string", - "nullable": true + "enum": [ + "PENDING", + "RUNNING", + "COMPLETED", + "FAILED" + ] }, - "rowIndex": { - "type": "number", - "format": "double" + "providerKeyId": { + "type": "string" }, - "columnId": { + "promptVersion": { + "type": "string" + }, + "model": { + "type": "string" + }, + "experimentId": { "type": "string" } }, "required": [ - "value", - "rowIndex", - "columnId" + "status", + "providerKeyId", + "promptVersion", + "model", + "experimentId" ], "type": "object" } } } } - }, - "patch": { - "operationId": "UpdateExperimentCell", + } + }, + "/v1/experiment/hypothesis/{hypothesisId}/scores/query": { + "post": { + "operationId": "GetExperimentHypothesisScores", "responses": { "200": { "description": "Ok", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Result_null.string_" + "$ref": "#/components/schemas/Result__runsCount-number--scores-Record_string.Score__.string_" } } } @@ -14679,55 +14843,25 @@ "parameters": [ { "in": "path", - "name": "experimentTableId", + "name": "hypothesisId", "required": true, "schema": { "type": "string" } } - ], - "requestBody": { - "required": true, - "content": { - "application/json": { - "schema": { - "properties": { - "updateInputs": { - "type": "boolean" - }, - "metadata": { - "type": "string" - }, - "value": { - "type": "string" - }, - "status": { - "type": "string" - }, - "cellId": { - "type": "string" - } - }, - "required": [ - "cellId" - ], - "type": "object" - } - } - } - } + ] } }, - "/v1/experiment/table/{experimentTableId}/column": { - "post": { - "operationId": "CreateExperimentColumn", + "/v1/experiment/{experimentId}/evaluators": { + "get": { + "operationId": "GetExperimentEvaluators", "responses": { "200": { "description": "Ok", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Result_null.string_" + "$ref": "#/components/schemas/Result_EvaluatorResult-Array.string_" } } } @@ -14744,52 +14878,16 @@ "parameters": [ { "in": "path", - "name": "experimentTableId", + "name": "experimentId", "required": true, "schema": { "type": "string" } } - ], - "requestBody": { - "required": true, - "content": { - "application/json": { - "schema": { - "properties": { - "inputKeys": { - "items": { - "type": "string" - }, - "type": "array" - }, - "promptVersionId": { - "type": "string" - }, - "hypothesisId": { - "type": "string" - }, - "columnType": { - "type": "string" - }, - "columnName": { - "type": "string" - } - }, - "required": [ - "columnType", - "columnName" - ], - "type": "object" - } - } - } - } - } - }, - "/v1/experiment/table/{experimentTableId}/row/new": { + ] + }, "post": { - "operationId": "CreateExperimentTableRow", + "operationId": "CreateExperimentEvaluatorOld", "responses": { "200": { "description": "Ok", @@ -14813,7 +14911,7 @@ "parameters": [ { "in": "path", - "name": "experimentTableId", + "name": "experimentId", "required": true, "schema": { "type": "string" @@ -14826,18 +14924,12 @@ "application/json": { "schema": { "properties": { - "inputs": { - "$ref": "#/components/schemas/Record_string.string_" - }, - "sourceRequest": { - "type": "string" - }, - "promptVersionId": { + "evaluatorId": { "type": "string" } }, "required": [ - "promptVersionId" + "evaluatorId" ], "type": "object" } @@ -14846,9 +14938,9 @@ } } }, - "/v1/experiment/table/{experimentTableId}/row/{rowIndex}": { - "delete": { - "operationId": "DeleteExperimentTableRow", + "/v1/experiment/{experimentId}/evaluators/run": { + "post": { + "operationId": "RunExperimentEvaluatorsOld", "responses": { "200": { "description": "Ok", @@ -14872,27 +14964,18 @@ "parameters": [ { "in": "path", - "name": "experimentTableId", + "name": "experimentId", "required": true, "schema": { "type": "string" } - }, - { - "in": "path", - "name": "rowIndex", - "required": true, - "schema": { - "format": "double", - "type": "number" - } } ] } }, - "/v1/experiment/table/{experimentTableId}/row/insert/batch": { - "post": { - "operationId": "CreateExperimentTableRowWithCellsBatch", + "/v1/experiment/{experimentId}/evaluators/{evaluatorId}": { + "delete": { + "operationId": "DeleteExperimentEvaluatorOld", "responses": { "200": { "description": "Ok", @@ -14916,93 +14999,33 @@ "parameters": [ { "in": "path", - "name": "experimentTableId", + "name": "experimentId", "required": true, "schema": { "type": "string" } - } - ], - "requestBody": { - "required": true, - "content": { - "application/json": { - "schema": { - "properties": { - "rows": { - "items": { - "properties": { - "sourceRequest": { - "type": "string" - }, - "cells": { - "items": { - "properties": { - "metadata": {}, - "value": { - "type": "string", - "nullable": true - }, - "columnId": { - "type": "string" - } - }, - "required": [ - "value", - "columnId" - ], - "type": "object" - }, - "type": "array" - }, - "datasetId": { - "type": "string" - }, - "inputs": { - "$ref": "#/components/schemas/Record_string.string_" - }, - "inputRecordId": { - "type": "string" - } - }, - "required": [ - "cells", - "datasetId", - "inputs", - "inputRecordId" - ], - "type": "object" - }, - "type": "array" - } - }, - "required": [ - "rows" - ], - "type": "object" - } + }, + { + "in": "path", + "name": "evaluatorId", + "required": true, + "schema": { + "type": "string" } } - } + ] } }, - "/v1/experiment/update-meta": { + "/v1/experiment/query": { "post": { - "operationId": "UpdateExperimentMeta", + "operationId": "GetExperimentsOld", "responses": { "200": { - "description": "Ok", - "content": { - "application/json": { - "schema": { - "anyOf": [ - { - "$ref": "#/components/schemas/ResultSuccess_unknown_" - }, - { - "$ref": "#/components/schemas/ResultError_PostgrestError_" - } - ] + "description": "Ok", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/Result_Experiment-Array.string_" } } } @@ -15023,16 +15046,15 @@ "application/json": { "schema": { "properties": { - "meta": { - "$ref": "#/components/schemas/Record_string.string_" + "include": { + "$ref": "#/components/schemas/IncludeExperimentKeys" }, - "experimentId": { - "type": "string" + "filter": { + "$ref": "#/components/schemas/ExperimentFilterNode" } }, "required": [ - "meta", - "experimentId" + "filter" ], "type": "object" } @@ -15041,23 +15063,23 @@ } } }, - "/v1/experiment": { + "/v1/experiment/dataset": { "post": { - "operationId": "CreateNewExperimentOld", + "operationId": "AddDataset", "responses": { "200": { "description": "Ok", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Result__experimentId-string_.string_" + "$ref": "#/components/schemas/Result__datasetId-string_.string_" } } } } }, "tags": [ - "Experiment" + "Dataset" ], "security": [ { @@ -15070,30 +15092,30 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/NewExperimentParams" + "$ref": "#/components/schemas/NewDatasetParams" } } } } } }, - "/v1/experiment/hypothesis": { + "/v1/experiment/dataset/random": { "post": { - "operationId": "CreateNewExperimentHypothesis", + "operationId": "AddRandomDataset", "responses": { "200": { "description": "Ok", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Result__hypothesisId-string_.string_" + "$ref": "#/components/schemas/Result__datasetId-string_.string_" } } } } }, "tags": [ - "Experiment" + "Dataset" ], "security": [ { @@ -15106,128 +15128,71 @@ "content": { "application/json": { "schema": { - "properties": { - "status": { - "type": "string", - "enum": [ - "PENDING", - "RUNNING", - "COMPLETED", - "FAILED" - ] - }, - "providerKeyId": { - "type": "string" - }, - "promptVersion": { - "type": "string" - }, - "model": { - "type": "string" - }, - "experimentId": { - "type": "string" - } - }, - "required": [ - "status", - "providerKeyId", - "promptVersion", - "model", - "experimentId" - ], - "type": "object" + "$ref": "#/components/schemas/RandomDatasetParams" } } } } } }, - "/v1/experiment/hypothesis/{hypothesisId}/scores/query": { + "/v1/experiment/dataset/query": { "post": { - "operationId": "GetExperimentHypothesisScores", + "operationId": "GetDatasets", "responses": { "200": { "description": "Ok", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Result__runsCount-number--scores-Record_string.Score__.string_" + "$ref": "#/components/schemas/Result_DatasetResult-Array.string_" } } } } }, "tags": [ - "Experiment" + "Dataset" ], "security": [ { "api_key": [] } ], - "parameters": [ - { - "in": "path", - "name": "hypothesisId", - "required": true, - "schema": { - "type": "string" + "parameters": [], + "requestBody": { + "required": true, + "content": { + "application/json": { + "schema": { + "properties": { + "promptVersionId": { + "type": "string" + } + }, + "type": "object" + } } } - ] + } } }, - "/v1/experiment/{experimentId}/evaluators": { - "get": { - "operationId": "GetExperimentEvaluators", - "responses": { - "200": { - "description": "Ok", - "content": { - "application/json": { - "schema": { - "$ref": "#/components/schemas/Result_EvaluatorResult-Array.string_" - } - } - } - } - }, - "tags": [ - "Experiment" - ], - "security": [ - { - "api_key": [] - } - ], - "parameters": [ - { - "in": "path", - "name": "experimentId", - "required": true, - "schema": { - "type": "string" - } - } - ] - }, + "/v1/experiment/dataset/{datasetId}/row/insert": { "post": { - "operationId": "CreateExperimentEvaluatorOld", + "operationId": "InsertDatasetRow", "responses": { "200": { "description": "Ok", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Result_null.string_" + "$ref": "#/components/schemas/Result_string.string_" } } } } }, "tags": [ - "Experiment" + "Dataset" ], "security": [ { @@ -15237,7 +15202,7 @@ "parameters": [ { "in": "path", - "name": "experimentId", + "name": "datasetId", "required": true, "schema": { "type": "string" @@ -15250,12 +15215,19 @@ "application/json": { "schema": { "properties": { - "evaluatorId": { + "originalColumnId": { + "type": "string" + }, + "inputs": { + "$ref": "#/components/schemas/Record_string.string_" + }, + "inputRecordId": { "type": "string" } }, "required": [ - "evaluatorId" + "inputs", + "inputRecordId" ], "type": "object" } @@ -15264,23 +15236,23 @@ } } }, - "/v1/experiment/{experimentId}/evaluators/run": { + "/v1/experiment/dataset/{datasetId}/version/{promptVersionId}/row/new": { "post": { - "operationId": "RunExperimentEvaluatorsOld", + "operationId": "CreateDatasetRow", "responses": { "200": { "description": "Ok", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Result_null.string_" + "$ref": "#/components/schemas/Result_string.string_" } } } } }, "tags": [ - "Experiment" + "Dataset" ], "security": [ { @@ -15290,32 +15262,61 @@ "parameters": [ { "in": "path", - "name": "experimentId", + "name": "datasetId", + "required": true, + "schema": { + "type": "string" + } + }, + { + "in": "path", + "name": "promptVersionId", "required": true, "schema": { "type": "string" } } - ] + ], + "requestBody": { + "required": true, + "content": { + "application/json": { + "schema": { + "properties": { + "sourceRequest": { + "type": "string" + }, + "inputs": { + "$ref": "#/components/schemas/Record_string.string_" + } + }, + "required": [ + "inputs" + ], + "type": "object" + } + } + } + } } }, - "/v1/experiment/{experimentId}/evaluators/{evaluatorId}": { - "delete": { - "operationId": "DeleteExperimentEvaluatorOld", + "/v1/experiment/dataset/{datasetId}/inputs/query": { + "post": { + "operationId": "GetDataset", "responses": { "200": { "description": "Ok", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Result_null.string_" + "$ref": "#/components/schemas/Result_PromptInputRecord-Array.string_" } } } } }, "tags": [ - "Experiment" + "Dataset" ], "security": [ { @@ -15325,15 +15326,7 @@ "parameters": [ { "in": "path", - "name": "experimentId", - "required": true, - "schema": { - "type": "string" - } - }, - { - "in": "path", - "name": "evaluatorId", + "name": "datasetId", "required": true, "schema": { "type": "string" @@ -15342,23 +15335,23 @@ ] } }, - "/v1/experiment/query": { + "/v1/experiment/dataset/{datasetId}/mutate": { "post": { - "operationId": "GetExperimentsOld", + "operationId": "MutateDataset", "responses": { "200": { "description": "Ok", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Result_Experiment-Array.string_" + "$ref": "#/components/schemas/Result___-Array.string_" } } } } }, "tags": [ - "Experiment" + "Dataset" ], "security": [ { @@ -15372,15 +15365,22 @@ "application/json": { "schema": { "properties": { - "include": { - "$ref": "#/components/schemas/IncludeExperimentKeys" + "removeRequests": { + "items": { + "type": "string" + }, + "type": "array" }, - "filter": { - "$ref": "#/components/schemas/ExperimentFilterNode" + "addRequests": { + "items": { + "type": "string" + }, + "type": "array" } }, "required": [ - "filter" + "removeRequests", + "addRequests" ], "type": "object" } @@ -17469,29 +17469,7 @@ "api_key": [] } ], - "parameters": [], - "requestBody": { - "required": true, - "content": { - "application/json": { - "schema": { - "properties": { - "endTime": { - "type": "string" - }, - "startTime": { - "type": "string" - } - }, - "required": [ - "endTime", - "startTime" - ], - "type": "object" - } - } - } - } + "parameters": [] } }, "/v1/settings/query": { diff --git a/valhalla/jawn/src/tsoa-build/public/routes.ts b/valhalla/jawn/src/tsoa-build/public/routes.ts index fb864dee61..21e6fee904 100644 --- a/valhalla/jawn/src/tsoa-build/public/routes.ts +++ b/valhalla/jawn/src/tsoa-build/public/routes.ts @@ -8452,7 +8452,6 @@ export function RegisterRoutes(app: Router) { async function PiController_getTotalRequests(request: ExRequest, response: ExResponse, next: any) { const args: Record = { - body: {"in":"body","name":"body","required":true,"dataType":"nestedObjectLiteral","nestedProperties":{"endTime":{"dataType":"string","required":true},"startTime":{"dataType":"string","required":true}}}, request: {"in":"request","name":"request","required":true,"dataType":"object"}, }; diff --git a/valhalla/jawn/src/tsoa-build/public/swagger.json b/valhalla/jawn/src/tsoa-build/public/swagger.json index 4078a90004..5add5a5dcf 100644 --- a/valhalla/jawn/src/tsoa-build/public/swagger.json +++ b/valhalla/jawn/src/tsoa-build/public/swagger.json @@ -16776,29 +16776,7 @@ "api_key": [] } ], - "parameters": [], - "requestBody": { - "required": true, - "content": { - "application/json": { - "schema": { - "properties": { - "endTime": { - "type": "string" - }, - "startTime": { - "type": "string" - } - }, - "required": [ - "endTime", - "startTime" - ], - "type": "object" - } - } - } - } + "parameters": [] } }, "/v1/settings/query": { diff --git a/web/lib/clients/jawnTypes/private.ts b/web/lib/clients/jawnTypes/private.ts index 128dd74a79..f97a51371a 100644 --- a/web/lib/clients/jawnTypes/private.ts +++ b/web/lib/clients/jawnTypes/private.ts @@ -5664,14 +5664,6 @@ export interface operations { }; }; GetTotalRequests: { - requestBody: { - content: { - "application/json": { - endTime: string; - startTime: string; - }; - }; - }; responses: { /** @description Ok */ 200: { diff --git a/web/lib/clients/jawnTypes/public.ts b/web/lib/clients/jawnTypes/public.ts index 6a0255c326..82c6fa6df9 100644 --- a/web/lib/clients/jawnTypes/public.ts +++ b/web/lib/clients/jawnTypes/public.ts @@ -5421,14 +5421,6 @@ export interface operations { }; }; GetTotalRequests: { - requestBody: { - content: { - "application/json": { - endTime: string; - startTime: string; - }; - }; - }; responses: { /** @description Ok */ 200: { From 099bbf451c351d4579ab0a5989c43eeebf121871 Mon Sep 17 00:00:00 2001 From: Justin Date: Fri, 20 Dec 2024 12:27:39 -0800 Subject: [PATCH 08/14] numbers --- bifrost/app/pi/total-requests/page.tsx | 1 + 1 file changed, 1 insertion(+) diff --git a/bifrost/app/pi/total-requests/page.tsx b/bifrost/app/pi/total-requests/page.tsx index 7c391b92bf..78f0ec77ff 100644 --- a/bifrost/app/pi/total-requests/page.tsx +++ b/bifrost/app/pi/total-requests/page.tsx @@ -30,6 +30,7 @@ const PiGraphLayout = ({ children }: { children: React.ReactNode }) => {
+ {totalRequests.data?.data?.data}
{children}
Date: Fri, 20 Dec 2024 12:52:14 -0800 Subject: [PATCH 09/14] total cost over time --- bifrost/app/pi/first_page/page.tsx | 39 +++-- bifrost/lib/clients/jawnTypes/private.ts | 54 +++++++ bifrost/lib/clients/jawnTypes/public.ts | 54 +++++++ docs/swagger.json | 147 ++++++++++++++++++ .../src/controllers/public/piController.ts | 109 ++++++++++++- .../jawn/src/tsoa-build/private/routes.ts | 108 +++++++++++++ .../jawn/src/tsoa-build/private/swagger.json | 147 ++++++++++++++++++ valhalla/jawn/src/tsoa-build/public/routes.ts | 108 +++++++++++++ .../jawn/src/tsoa-build/public/swagger.json | 147 ++++++++++++++++++ web/lib/clients/jawnTypes/private.ts | 54 +++++++ web/lib/clients/jawnTypes/public.ts | 54 +++++++ 11 files changed, 1010 insertions(+), 11 deletions(-) diff --git a/bifrost/app/pi/first_page/page.tsx b/bifrost/app/pi/first_page/page.tsx index 878fea65b6..f8ed905f45 100644 --- a/bifrost/app/pi/first_page/page.tsx +++ b/bifrost/app/pi/first_page/page.tsx @@ -6,6 +6,7 @@ import { useRouter } from "next/navigation"; import { Suspense } from "react"; import { useHeliconeLogin } from "./../useHeliconeLogin"; import { useTestAPIKey } from "./useTestApiKey"; +import { useQuery } from "@tanstack/react-query"; const jetbrainsMono = JetBrains_Mono({ subsets: ["latin"] }); @@ -14,22 +15,40 @@ const FirstPageContent = () => { const { data, isLoading } = useTestAPIKey(apiKey.data ?? ""); const jawn = useJawnClient(apiKey.data ?? ""); const router = useRouter(); + const orgName = useQuery({ + queryKey: ["org-name", apiKey.data], + queryFn: () => jawn.POST("/v1/pi/org-name/query"), + }); + + const totalCosts = useQuery({ + queryKey: ["total-costs", apiKey.data], + queryFn: () => jawn.POST("/v1/pi/total-costs"), + }); + + const costsOverTime = useQuery({ + queryKey: ["costs-over-time", apiKey.data], + queryFn: () => + jawn.POST("/v1/pi/costs-over-time/query", { + body: { + userFilter: "all", + dbIncrement: "day", + timeZoneDifference: new Date().getTimezoneOffset(), + timeFilter: { + start: new Date( + Date.now() - 30 * 24 * 60 * 60 * 1000 + ).toISOString(), + end: new Date().toISOString(), + }, + }, + }), + }); if (!data && !isLoading && !apiKey.data && !apiKey.isLoading) { router.push("/pi/setup?invalid_api_key=true"); return
Loading...
; } - return ( -
-

- LOGGED IN! WOOOHOO -

- {data && JSON.stringify(data).slice(0, 100)} -
- ); + return
; }; const PiPage = () => { diff --git a/bifrost/lib/clients/jawnTypes/private.ts b/bifrost/lib/clients/jawnTypes/private.ts index f97a51371a..1ae4e696aa 100644 --- a/bifrost/lib/clients/jawnTypes/private.ts +++ b/bifrost/lib/clients/jawnTypes/private.ts @@ -523,9 +523,18 @@ export interface paths { "/v1/pi/session": { post: operations["AddSession"]; }; + "/v1/pi/org-name/query": { + post: operations["GetOrgName"]; + }; + "/v1/pi/total-costs": { + post: operations["GetTotalCosts"]; + }; "/v1/pi/total_requests": { post: operations["GetTotalRequests"]; }; + "/v1/pi/costs-over-time/query": { + post: operations["GetCostsOverTime"]; + }; "/v1/settings/query": { get: operations["GetSettings"]; }; @@ -3141,6 +3150,16 @@ Json: JsonObject; error: null; }; "Result__apiKey-string_.string_": components["schemas"]["ResultSuccess__apiKey-string__"] | components["schemas"]["ResultError_string_"]; + "ResultSuccess__cost-number--created_at_trunc-string_-Array_": { + data: { + created_at_trunc: string; + /** Format: double */ + cost: number; + }[]; + /** @enum {number|null} */ + error: null; + }; + "Result__cost-number--created_at_trunc-string_-Array.string_": components["schemas"]["ResultSuccess__cost-number--created_at_trunc-string_-Array_"] | components["schemas"]["ResultError_string_"]; }; responses: { }; @@ -6302,6 +6321,41 @@ export interface operations { }; }; }; + GetOrgName: { + responses: { + /** @description Ok */ + 200: { + content: { + "application/json": components["schemas"]["Result_string.string_"]; + }; + }; + }; + }; + GetTotalCosts: { + responses: { + /** @description Ok */ + 200: { + content: { + "application/json": components["schemas"]["Result_number.string_"]; + }; + }; + }; + }; + GetCostsOverTime: { + requestBody: { + content: { + "application/json": components["schemas"]["DataOverTimeRequest"]; + }; + }; + responses: { + /** @description Ok */ + 200: { + content: { + "application/json": components["schemas"]["Result__cost-number--created_at_trunc-string_-Array.string_"]; + }; + }; + }; + }; GetSettings: { responses: { /** @description Ok */ diff --git a/bifrost/lib/clients/jawnTypes/public.ts b/bifrost/lib/clients/jawnTypes/public.ts index 82c6fa6df9..0f7b89456e 100644 --- a/bifrost/lib/clients/jawnTypes/public.ts +++ b/bifrost/lib/clients/jawnTypes/public.ts @@ -478,9 +478,18 @@ export interface paths { "/v1/pi/session": { post: operations["AddSession"]; }; + "/v1/pi/org-name/query": { + post: operations["GetOrgName"]; + }; + "/v1/pi/total-costs": { + post: operations["GetTotalCosts"]; + }; "/v1/pi/total_requests": { post: operations["GetTotalRequests"]; }; + "/v1/pi/costs-over-time/query": { + post: operations["GetCostsOverTime"]; + }; "/v1/settings/query": { get: operations["GetSettings"]; }; @@ -2733,6 +2742,16 @@ Json: JsonObject; error: null; }; "Result__apiKey-string_.string_": components["schemas"]["ResultSuccess__apiKey-string__"] | components["schemas"]["ResultError_string_"]; + "ResultSuccess__cost-number--created_at_trunc-string_-Array_": { + data: { + created_at_trunc: string; + /** Format: double */ + cost: number; + }[]; + /** @enum {number|null} */ + error: null; + }; + "Result__cost-number--created_at_trunc-string_-Array.string_": components["schemas"]["ResultSuccess__cost-number--created_at_trunc-string_-Array_"] | components["schemas"]["ResultError_string_"]; /** @enum {string} */ LlmType: "chat" | "completion"; FunctionCall: { @@ -6059,6 +6078,41 @@ export interface operations { }; }; }; + GetOrgName: { + responses: { + /** @description Ok */ + 200: { + content: { + "application/json": components["schemas"]["Result_string.string_"]; + }; + }; + }; + }; + GetTotalCosts: { + responses: { + /** @description Ok */ + 200: { + content: { + "application/json": components["schemas"]["Result_number.string_"]; + }; + }; + }; + }; + GetCostsOverTime: { + requestBody: { + content: { + "application/json": components["schemas"]["DataOverTimeRequest"]; + }; + }; + responses: { + /** @description Ok */ + 200: { + content: { + "application/json": components["schemas"]["Result__cost-number--created_at_trunc-string_-Array.string_"]; + }; + }; + }; + }; GetSettings: { responses: { /** @description Ok */ diff --git a/docs/swagger.json b/docs/swagger.json index 5add5a5dcf..bde361282f 100644 --- a/docs/swagger.json +++ b/docs/swagger.json @@ -7713,6 +7713,52 @@ } ] }, + "ResultSuccess__cost-number--created_at_trunc-string_-Array_": { + "properties": { + "data": { + "items": { + "properties": { + "created_at_trunc": { + "type": "string" + }, + "cost": { + "type": "number", + "format": "double" + } + }, + "required": [ + "created_at_trunc", + "cost" + ], + "type": "object" + }, + "type": "array" + }, + "error": { + "type": "number", + "enum": [ + null + ], + "nullable": true + } + }, + "required": [ + "data", + "error" + ], + "type": "object", + "additionalProperties": false + }, + "Result__cost-number--created_at_trunc-string_-Array.string_": { + "anyOf": [ + { + "$ref": "#/components/schemas/ResultSuccess__cost-number--created_at_trunc-string_-Array_" + }, + { + "$ref": "#/components/schemas/ResultError_string_" + } + ] + }, "LlmType": { "type": "string", "enum": [ @@ -16753,6 +16799,58 @@ } } }, + "/v1/pi/org-name/query": { + "post": { + "operationId": "GetOrgName", + "responses": { + "200": { + "description": "Ok", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/Result_string.string_" + } + } + } + } + }, + "tags": [ + "PI" + ], + "security": [ + { + "api_key": [] + } + ], + "parameters": [] + } + }, + "/v1/pi/total-costs": { + "post": { + "operationId": "GetTotalCosts", + "responses": { + "200": { + "description": "Ok", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/Result_number.string_" + } + } + } + } + }, + "tags": [ + "PI" + ], + "security": [ + { + "api_key": [] + } + ], + "parameters": [] + } + }, "/v1/pi/total_requests": { "post": { "operationId": "GetTotalRequests", @@ -16779,6 +16877,55 @@ "parameters": [] } }, + "/v1/pi/costs-over-time/query": { + "post": { + "operationId": "GetCostsOverTime", + "responses": { + "200": { + "description": "Ok", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/Result__cost-number--created_at_trunc-string_-Array.string_" + }, + "examples": { + "Example 1": { + "value": { + "userFilter": "all", + "timeFilter": { + "start": "2024-01-01", + "end": "2024-01-31" + }, + "dbIncrement": "day", + "timeZoneDifference": 0 + } + } + } + } + } + } + }, + "tags": [ + "PI" + ], + "security": [ + { + "api_key": [] + } + ], + "parameters": [], + "requestBody": { + "required": true, + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/DataOverTimeRequest" + } + } + } + } + } + }, "/v1/settings/query": { "get": { "operationId": "GetSettings", diff --git a/valhalla/jawn/src/controllers/public/piController.ts b/valhalla/jawn/src/controllers/public/piController.ts index 70b2903091..e21f4f1d41 100644 --- a/valhalla/jawn/src/controllers/public/piController.ts +++ b/valhalla/jawn/src/controllers/public/piController.ts @@ -1,4 +1,13 @@ -import { Body, Controller, Post, Request, Route, Security, Tags } from "tsoa"; +import { + Body, + Controller, + Example, + Post, + Request, + Route, + Security, + Tags, +} from "tsoa"; import { Result, err, ok } from "../../lib/shared/result"; import { JawnAuthenticatedRequest } from "../../types/request"; @@ -7,6 +16,11 @@ import { RequestManager } from "../../managers/request/RequestManager"; import { buildFilterWithAuthClickHouse } from "../../lib/shared/filters/filters"; import { timeFilterToFilterNode } from "../../lib/shared/filters/filterDefs"; import { dbQueryClickhouse } from "../../lib/shared/db/dbExecute"; +import { clickhousePriceCalc } from "../../packages/cost"; +import { + DataOverTimeRequest, + getXOverTime, +} from "../../managers/helpers/getXOverTime"; @Route("/v1/pi") @Tags("PI") @@ -45,6 +59,67 @@ export class PiController extends Controller { } } + @Post("/org-name/query") + public async getOrgName( + @Request() request: JawnAuthenticatedRequest + ): Promise> { + const result = await supabaseServer.client + .from("organization") + .select("*") + .eq("id", request.authParams.organizationId); + + if (result.error) { + this.setStatus(500); + console.error(result.error); + return err(result.error?.message || "Failed to fetch evals"); + } + + return ok(result.data?.[0]?.name || "Unknown"); + } + + @Post("/total-costs") + public async getTotalCosts( + @Request() request: JawnAuthenticatedRequest + ): Promise> { + const startTime = new Date(Date.now() - 30 * 24 * 60 * 60 * 1000); // 30 days ago + const endTime = new Date(Date.now()); + + const { filter: filterString, argsAcc } = + await buildFilterWithAuthClickHouse({ + org_id: request.authParams.organizationId, + filter: { + left: timeFilterToFilterNode( + { + start: startTime, + end: endTime, + }, + "request_response_rmt" + ), + right: "all", + operator: "and", + }, + argsAcc: [], + }); + + const query = ` + WITH total_cost AS ( + SELECT ${clickhousePriceCalc("request_response_rmt")} as cost + FROM request_response_rmt + WHERE ( + (${filterString}) + ) + ) + SELECT coalesce(sum(cost), 0) as cost + FROM total_cost +`; + + const result = await dbQueryClickhouse<{ + cost: number; + }>(query, argsAcc); + + return ok(result.data?.[0]?.cost || 0); + } + @Post("/total_requests") public async getTotalRequests( @Request() request: JawnAuthenticatedRequest @@ -87,4 +162,36 @@ export class PiController extends Controller { return ok(result.data?.[0]?.count || 0); } + + @Post("/costs-over-time/query") + @Example({ + userFilter: "all", + timeFilter: { + start: "2024-01-01", + end: "2024-01-31", + }, + dbIncrement: "day", + timeZoneDifference: 0, + }) + public async getCostsOverTime( + @Body() + requestBody: DataOverTimeRequest, + @Request() request: JawnAuthenticatedRequest + ): Promise< + Result< + { + cost: number; + created_at_trunc: string; + }[], + string + > + > { + return await getXOverTime<{ + cost: number; + }>(requestBody, { + orgId: request.authParams.organizationId, + countColumn: `${clickhousePriceCalc("request_response_rmt")} as cost`, + groupByColumns: ["created_at_trunc"], + }); + } } diff --git a/valhalla/jawn/src/tsoa-build/private/routes.ts b/valhalla/jawn/src/tsoa-build/private/routes.ts index bb6ffed183..65950358e0 100644 --- a/valhalla/jawn/src/tsoa-build/private/routes.ts +++ b/valhalla/jawn/src/tsoa-build/private/routes.ts @@ -3125,6 +3125,20 @@ const models: TsoaRoute.Models = { "type": {"dataType":"union","subSchemas":[{"ref":"ResultSuccess__apiKey-string__"},{"ref":"ResultError_string_"}],"validators":{}}, }, // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa + "ResultSuccess__cost-number--created_at_trunc-string_-Array_": { + "dataType": "refObject", + "properties": { + "data": {"dataType":"array","array":{"dataType":"nestedObjectLiteral","nestedProperties":{"created_at_trunc":{"dataType":"string","required":true},"cost":{"dataType":"double","required":true}}},"required":true}, + "error": {"dataType":"enum","enums":[null],"required":true}, + }, + "additionalProperties": false, + }, + // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa + "Result__cost-number--created_at_trunc-string_-Array.string_": { + "dataType": "refAlias", + "type": {"dataType":"union","subSchemas":[{"ref":"ResultSuccess__cost-number--created_at_trunc-string_-Array_"},{"ref":"ResultError_string_"}],"validators":{}}, + }, + // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa }; const templateService = new ExpressTemplateService(models, {"noImplicitAdditionalProperties":"throw-on-extras","bodyCoercion":true}); @@ -8930,6 +8944,68 @@ export function RegisterRoutes(app: Router) { } }); // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa + app.post('/v1/pi/org-name/query', + authenticateMiddleware([{"api_key":[]}]), + ...(fetchMiddlewares(PiController)), + ...(fetchMiddlewares(PiController.prototype.getOrgName)), + + async function PiController_getOrgName(request: ExRequest, response: ExResponse, next: any) { + const args: Record = { + request: {"in":"request","name":"request","required":true,"dataType":"object"}, + }; + + // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa + + let validatedArgs: any[] = []; + try { + validatedArgs = templateService.getValidatedArgs({ args, request, response }); + + const controller = new PiController(); + + await templateService.apiHandler({ + methodName: 'getOrgName', + controller, + response, + next, + validatedArgs, + successStatus: undefined, + }); + } catch (err) { + return next(err); + } + }); + // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa + app.post('/v1/pi/total-costs', + authenticateMiddleware([{"api_key":[]}]), + ...(fetchMiddlewares(PiController)), + ...(fetchMiddlewares(PiController.prototype.getTotalCosts)), + + async function PiController_getTotalCosts(request: ExRequest, response: ExResponse, next: any) { + const args: Record = { + request: {"in":"request","name":"request","required":true,"dataType":"object"}, + }; + + // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa + + let validatedArgs: any[] = []; + try { + validatedArgs = templateService.getValidatedArgs({ args, request, response }); + + const controller = new PiController(); + + await templateService.apiHandler({ + methodName: 'getTotalCosts', + controller, + response, + next, + validatedArgs, + successStatus: undefined, + }); + } catch (err) { + return next(err); + } + }); + // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa app.post('/v1/pi/total_requests', authenticateMiddleware([{"api_key":[]}]), ...(fetchMiddlewares(PiController)), @@ -8961,6 +9037,38 @@ export function RegisterRoutes(app: Router) { } }); // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa + app.post('/v1/pi/costs-over-time/query', + authenticateMiddleware([{"api_key":[]}]), + ...(fetchMiddlewares(PiController)), + ...(fetchMiddlewares(PiController.prototype.getCostsOverTime)), + + async function PiController_getCostsOverTime(request: ExRequest, response: ExResponse, next: any) { + const args: Record = { + requestBody: {"in":"body","name":"requestBody","required":true,"ref":"DataOverTimeRequest"}, + request: {"in":"request","name":"request","required":true,"dataType":"object"}, + }; + + // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa + + let validatedArgs: any[] = []; + try { + validatedArgs = templateService.getValidatedArgs({ args, request, response }); + + const controller = new PiController(); + + await templateService.apiHandler({ + methodName: 'getCostsOverTime', + controller, + response, + next, + validatedArgs, + successStatus: undefined, + }); + } catch (err) { + return next(err); + } + }); + // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa app.get('/v1/settings/query', authenticateMiddleware([{"api_key":[]}]), ...(fetchMiddlewares(SettingController)), diff --git a/valhalla/jawn/src/tsoa-build/private/swagger.json b/valhalla/jawn/src/tsoa-build/private/swagger.json index b19a07b6c8..3ee4c99cd7 100644 --- a/valhalla/jawn/src/tsoa-build/private/swagger.json +++ b/valhalla/jawn/src/tsoa-build/private/swagger.json @@ -9193,6 +9193,52 @@ "$ref": "#/components/schemas/ResultError_string_" } ] + }, + "ResultSuccess__cost-number--created_at_trunc-string_-Array_": { + "properties": { + "data": { + "items": { + "properties": { + "created_at_trunc": { + "type": "string" + }, + "cost": { + "type": "number", + "format": "double" + } + }, + "required": [ + "created_at_trunc", + "cost" + ], + "type": "object" + }, + "type": "array" + }, + "error": { + "type": "number", + "enum": [ + null + ], + "nullable": true + } + }, + "required": [ + "data", + "error" + ], + "type": "object", + "additionalProperties": false + }, + "Result__cost-number--created_at_trunc-string_-Array.string_": { + "anyOf": [ + { + "$ref": "#/components/schemas/ResultSuccess__cost-number--created_at_trunc-string_-Array_" + }, + { + "$ref": "#/components/schemas/ResultError_string_" + } + ] } }, "securitySchemes": { @@ -17446,6 +17492,58 @@ } } }, + "/v1/pi/org-name/query": { + "post": { + "operationId": "GetOrgName", + "responses": { + "200": { + "description": "Ok", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/Result_string.string_" + } + } + } + } + }, + "tags": [ + "PI" + ], + "security": [ + { + "api_key": [] + } + ], + "parameters": [] + } + }, + "/v1/pi/total-costs": { + "post": { + "operationId": "GetTotalCosts", + "responses": { + "200": { + "description": "Ok", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/Result_number.string_" + } + } + } + } + }, + "tags": [ + "PI" + ], + "security": [ + { + "api_key": [] + } + ], + "parameters": [] + } + }, "/v1/pi/total_requests": { "post": { "operationId": "GetTotalRequests", @@ -17472,6 +17570,55 @@ "parameters": [] } }, + "/v1/pi/costs-over-time/query": { + "post": { + "operationId": "GetCostsOverTime", + "responses": { + "200": { + "description": "Ok", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/Result__cost-number--created_at_trunc-string_-Array.string_" + }, + "examples": { + "Example 1": { + "value": { + "userFilter": "all", + "timeFilter": { + "start": "2024-01-01", + "end": "2024-01-31" + }, + "dbIncrement": "day", + "timeZoneDifference": 0 + } + } + } + } + } + } + }, + "tags": [ + "PI" + ], + "security": [ + { + "api_key": [] + } + ], + "parameters": [], + "requestBody": { + "required": true, + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/DataOverTimeRequest" + } + } + } + } + } + }, "/v1/settings/query": { "get": { "operationId": "GetSettings", diff --git a/valhalla/jawn/src/tsoa-build/public/routes.ts b/valhalla/jawn/src/tsoa-build/public/routes.ts index 21e6fee904..722d791dc4 100644 --- a/valhalla/jawn/src/tsoa-build/public/routes.ts +++ b/valhalla/jawn/src/tsoa-build/public/routes.ts @@ -2614,6 +2614,20 @@ const models: TsoaRoute.Models = { "type": {"dataType":"union","subSchemas":[{"ref":"ResultSuccess__apiKey-string__"},{"ref":"ResultError_string_"}],"validators":{}}, }, // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa + "ResultSuccess__cost-number--created_at_trunc-string_-Array_": { + "dataType": "refObject", + "properties": { + "data": {"dataType":"array","array":{"dataType":"nestedObjectLiteral","nestedProperties":{"created_at_trunc":{"dataType":"string","required":true},"cost":{"dataType":"double","required":true}}},"required":true}, + "error": {"dataType":"enum","enums":[null],"required":true}, + }, + "additionalProperties": false, + }, + // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa + "Result__cost-number--created_at_trunc-string_-Array.string_": { + "dataType": "refAlias", + "type": {"dataType":"union","subSchemas":[{"ref":"ResultSuccess__cost-number--created_at_trunc-string_-Array_"},{"ref":"ResultError_string_"}],"validators":{}}, + }, + // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa "LlmType": { "dataType": "refAlias", "type": {"dataType":"union","subSchemas":[{"dataType":"enum","enums":["chat"]},{"dataType":"enum","enums":["completion"]}],"validators":{}}, @@ -8445,6 +8459,68 @@ export function RegisterRoutes(app: Router) { } }); // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa + app.post('/v1/pi/org-name/query', + authenticateMiddleware([{"api_key":[]}]), + ...(fetchMiddlewares(PiController)), + ...(fetchMiddlewares(PiController.prototype.getOrgName)), + + async function PiController_getOrgName(request: ExRequest, response: ExResponse, next: any) { + const args: Record = { + request: {"in":"request","name":"request","required":true,"dataType":"object"}, + }; + + // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa + + let validatedArgs: any[] = []; + try { + validatedArgs = templateService.getValidatedArgs({ args, request, response }); + + const controller = new PiController(); + + await templateService.apiHandler({ + methodName: 'getOrgName', + controller, + response, + next, + validatedArgs, + successStatus: undefined, + }); + } catch (err) { + return next(err); + } + }); + // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa + app.post('/v1/pi/total-costs', + authenticateMiddleware([{"api_key":[]}]), + ...(fetchMiddlewares(PiController)), + ...(fetchMiddlewares(PiController.prototype.getTotalCosts)), + + async function PiController_getTotalCosts(request: ExRequest, response: ExResponse, next: any) { + const args: Record = { + request: {"in":"request","name":"request","required":true,"dataType":"object"}, + }; + + // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa + + let validatedArgs: any[] = []; + try { + validatedArgs = templateService.getValidatedArgs({ args, request, response }); + + const controller = new PiController(); + + await templateService.apiHandler({ + methodName: 'getTotalCosts', + controller, + response, + next, + validatedArgs, + successStatus: undefined, + }); + } catch (err) { + return next(err); + } + }); + // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa app.post('/v1/pi/total_requests', authenticateMiddleware([{"api_key":[]}]), ...(fetchMiddlewares(PiController)), @@ -8476,6 +8552,38 @@ export function RegisterRoutes(app: Router) { } }); // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa + app.post('/v1/pi/costs-over-time/query', + authenticateMiddleware([{"api_key":[]}]), + ...(fetchMiddlewares(PiController)), + ...(fetchMiddlewares(PiController.prototype.getCostsOverTime)), + + async function PiController_getCostsOverTime(request: ExRequest, response: ExResponse, next: any) { + const args: Record = { + requestBody: {"in":"body","name":"requestBody","required":true,"ref":"DataOverTimeRequest"}, + request: {"in":"request","name":"request","required":true,"dataType":"object"}, + }; + + // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa + + let validatedArgs: any[] = []; + try { + validatedArgs = templateService.getValidatedArgs({ args, request, response }); + + const controller = new PiController(); + + await templateService.apiHandler({ + methodName: 'getCostsOverTime', + controller, + response, + next, + validatedArgs, + successStatus: undefined, + }); + } catch (err) { + return next(err); + } + }); + // WARNING: This file was auto-generated with tsoa. Please do not modify it. Re-run tsoa to re-generate this file: https://github.com/lukeautry/tsoa app.get('/v1/settings/query', authenticateMiddleware([{"api_key":[]}]), ...(fetchMiddlewares(SettingController)), diff --git a/valhalla/jawn/src/tsoa-build/public/swagger.json b/valhalla/jawn/src/tsoa-build/public/swagger.json index 5add5a5dcf..bde361282f 100644 --- a/valhalla/jawn/src/tsoa-build/public/swagger.json +++ b/valhalla/jawn/src/tsoa-build/public/swagger.json @@ -7713,6 +7713,52 @@ } ] }, + "ResultSuccess__cost-number--created_at_trunc-string_-Array_": { + "properties": { + "data": { + "items": { + "properties": { + "created_at_trunc": { + "type": "string" + }, + "cost": { + "type": "number", + "format": "double" + } + }, + "required": [ + "created_at_trunc", + "cost" + ], + "type": "object" + }, + "type": "array" + }, + "error": { + "type": "number", + "enum": [ + null + ], + "nullable": true + } + }, + "required": [ + "data", + "error" + ], + "type": "object", + "additionalProperties": false + }, + "Result__cost-number--created_at_trunc-string_-Array.string_": { + "anyOf": [ + { + "$ref": "#/components/schemas/ResultSuccess__cost-number--created_at_trunc-string_-Array_" + }, + { + "$ref": "#/components/schemas/ResultError_string_" + } + ] + }, "LlmType": { "type": "string", "enum": [ @@ -16753,6 +16799,58 @@ } } }, + "/v1/pi/org-name/query": { + "post": { + "operationId": "GetOrgName", + "responses": { + "200": { + "description": "Ok", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/Result_string.string_" + } + } + } + } + }, + "tags": [ + "PI" + ], + "security": [ + { + "api_key": [] + } + ], + "parameters": [] + } + }, + "/v1/pi/total-costs": { + "post": { + "operationId": "GetTotalCosts", + "responses": { + "200": { + "description": "Ok", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/Result_number.string_" + } + } + } + } + }, + "tags": [ + "PI" + ], + "security": [ + { + "api_key": [] + } + ], + "parameters": [] + } + }, "/v1/pi/total_requests": { "post": { "operationId": "GetTotalRequests", @@ -16779,6 +16877,55 @@ "parameters": [] } }, + "/v1/pi/costs-over-time/query": { + "post": { + "operationId": "GetCostsOverTime", + "responses": { + "200": { + "description": "Ok", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/Result__cost-number--created_at_trunc-string_-Array.string_" + }, + "examples": { + "Example 1": { + "value": { + "userFilter": "all", + "timeFilter": { + "start": "2024-01-01", + "end": "2024-01-31" + }, + "dbIncrement": "day", + "timeZoneDifference": 0 + } + } + } + } + } + } + }, + "tags": [ + "PI" + ], + "security": [ + { + "api_key": [] + } + ], + "parameters": [], + "requestBody": { + "required": true, + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/DataOverTimeRequest" + } + } + } + } + } + }, "/v1/settings/query": { "get": { "operationId": "GetSettings", diff --git a/web/lib/clients/jawnTypes/private.ts b/web/lib/clients/jawnTypes/private.ts index f97a51371a..1ae4e696aa 100644 --- a/web/lib/clients/jawnTypes/private.ts +++ b/web/lib/clients/jawnTypes/private.ts @@ -523,9 +523,18 @@ export interface paths { "/v1/pi/session": { post: operations["AddSession"]; }; + "/v1/pi/org-name/query": { + post: operations["GetOrgName"]; + }; + "/v1/pi/total-costs": { + post: operations["GetTotalCosts"]; + }; "/v1/pi/total_requests": { post: operations["GetTotalRequests"]; }; + "/v1/pi/costs-over-time/query": { + post: operations["GetCostsOverTime"]; + }; "/v1/settings/query": { get: operations["GetSettings"]; }; @@ -3141,6 +3150,16 @@ Json: JsonObject; error: null; }; "Result__apiKey-string_.string_": components["schemas"]["ResultSuccess__apiKey-string__"] | components["schemas"]["ResultError_string_"]; + "ResultSuccess__cost-number--created_at_trunc-string_-Array_": { + data: { + created_at_trunc: string; + /** Format: double */ + cost: number; + }[]; + /** @enum {number|null} */ + error: null; + }; + "Result__cost-number--created_at_trunc-string_-Array.string_": components["schemas"]["ResultSuccess__cost-number--created_at_trunc-string_-Array_"] | components["schemas"]["ResultError_string_"]; }; responses: { }; @@ -6302,6 +6321,41 @@ export interface operations { }; }; }; + GetOrgName: { + responses: { + /** @description Ok */ + 200: { + content: { + "application/json": components["schemas"]["Result_string.string_"]; + }; + }; + }; + }; + GetTotalCosts: { + responses: { + /** @description Ok */ + 200: { + content: { + "application/json": components["schemas"]["Result_number.string_"]; + }; + }; + }; + }; + GetCostsOverTime: { + requestBody: { + content: { + "application/json": components["schemas"]["DataOverTimeRequest"]; + }; + }; + responses: { + /** @description Ok */ + 200: { + content: { + "application/json": components["schemas"]["Result__cost-number--created_at_trunc-string_-Array.string_"]; + }; + }; + }; + }; GetSettings: { responses: { /** @description Ok */ diff --git a/web/lib/clients/jawnTypes/public.ts b/web/lib/clients/jawnTypes/public.ts index 82c6fa6df9..0f7b89456e 100644 --- a/web/lib/clients/jawnTypes/public.ts +++ b/web/lib/clients/jawnTypes/public.ts @@ -478,9 +478,18 @@ export interface paths { "/v1/pi/session": { post: operations["AddSession"]; }; + "/v1/pi/org-name/query": { + post: operations["GetOrgName"]; + }; + "/v1/pi/total-costs": { + post: operations["GetTotalCosts"]; + }; "/v1/pi/total_requests": { post: operations["GetTotalRequests"]; }; + "/v1/pi/costs-over-time/query": { + post: operations["GetCostsOverTime"]; + }; "/v1/settings/query": { get: operations["GetSettings"]; }; @@ -2733,6 +2742,16 @@ Json: JsonObject; error: null; }; "Result__apiKey-string_.string_": components["schemas"]["ResultSuccess__apiKey-string__"] | components["schemas"]["ResultError_string_"]; + "ResultSuccess__cost-number--created_at_trunc-string_-Array_": { + data: { + created_at_trunc: string; + /** Format: double */ + cost: number; + }[]; + /** @enum {number|null} */ + error: null; + }; + "Result__cost-number--created_at_trunc-string_-Array.string_": components["schemas"]["ResultSuccess__cost-number--created_at_trunc-string_-Array_"] | components["schemas"]["ResultError_string_"]; /** @enum {string} */ LlmType: "chat" | "completion"; FunctionCall: { @@ -6059,6 +6078,41 @@ export interface operations { }; }; }; + GetOrgName: { + responses: { + /** @description Ok */ + 200: { + content: { + "application/json": components["schemas"]["Result_string.string_"]; + }; + }; + }; + }; + GetTotalCosts: { + responses: { + /** @description Ok */ + 200: { + content: { + "application/json": components["schemas"]["Result_number.string_"]; + }; + }; + }; + }; + GetCostsOverTime: { + requestBody: { + content: { + "application/json": components["schemas"]["DataOverTimeRequest"]; + }; + }; + responses: { + /** @description Ok */ + 200: { + content: { + "application/json": components["schemas"]["Result__cost-number--created_at_trunc-string_-Array.string_"]; + }; + }; + }; + }; GetSettings: { responses: { /** @description Ok */ From 28f4cb40273bb3992a9a4a0ad90b560468619a3d Mon Sep 17 00:00:00 2001 From: Kavin Valli Date: Fri, 20 Dec 2024 13:09:50 -0800 Subject: [PATCH 10/14] fix number format --- bifrost/app/pi/total-requests/page.tsx | 134 ++++++++++++++++++++++++- 1 file changed, 130 insertions(+), 4 deletions(-) diff --git a/bifrost/app/pi/total-requests/page.tsx b/bifrost/app/pi/total-requests/page.tsx index 78f0ec77ff..b7d688845d 100644 --- a/bifrost/app/pi/total-requests/page.tsx +++ b/bifrost/app/pi/total-requests/page.tsx @@ -9,7 +9,110 @@ import { useJawnClient } from "@/lib/clients/jawnHook"; import { useQuery } from "@tanstack/react-query"; const jetbrainsMono = JetBrains_Mono({ subsets: ["latin"] }); -const PiGraphLayout = ({ children }: { children: React.ReactNode }) => { +const formatNumber = ( + number: number +): [ + number | null, + number | null, + "." | "," | number | null, + number | null | ".", + number | null, + number | null | "B" | "M" +] => { + if (number < 10) { + return [null, null, null, null, null, number]; + } else if (number < 100) { + return [ + null, + null, + null, + null, + Number(number.toString().split("")[0]), + Number(number.toString().split("")[1]), + ]; + } else if (number < 1000) { + return [ + null, + null, + null, + Number(number.toString().split("")[0]), + Number(number.toString().split("")[1]), + Number(number.toString().split("")[2]), + ]; + } else if (number < 10000) { + return [ + null, + Number(number.toString().split("")[0]), + ",", + Number(number.toString().split("")[1]), + Number(number.toString().split("")[2]), + Number(number.toString().split("")[3]), + ]; + } else if (number < 100_000) { + return [ + Number(number.toString().split("")[0]), + Number(number.toString().split("")[1]), + ",", + Number(number.toString().split("")[2]), + Number(number.toString().split("")[3]), + Number(number.toString().split("")[4]), + ]; + } else if (number < 1_000_000) { + // 2,345,678 = _,2,.,3,4,M + return [ + null, + Number(number.toString().split("")[0]), + ".", + Number(number.toString().split("")[1]), + Number(number.toString().split("")[2]), + "M", + ]; + } else if (number < 10_000_000) { + // 23,456,789 = 2,3,.,4,5,M + return [ + Number(number.toString().split("")[0]), + Number(number.toString().split("")[1]), + ".", + Number(number.toString().split("")[2]), + Number(number.toString().split("")[3]), + "M", + ]; + } else if (number < 100_000_000) { + // 234,567,890 = 2,3,4,.,5,M + return [ + Number(number.toString().split("")[0]), + Number(number.toString().split("")[1]), + Number(number.toString().split("")[2]), + ".", + Number(number.toString().split("")[3]), + "M", + ]; + } else if (number < 1_000_000_000) { + // 245,678,901 = _,_,2,4,5,M + return [ + null, + null, + Number(number.toString().split("")[0]), + Number(number.toString().split("")[1]), + Number(number.toString().split("")[2]), + "M", + ]; + } else if (number < 10_000_000_000) { + // 1,234,567,890 = _,1,.,2,3,B + return [ + null, + Number(number.toString().split("")[0]), + ".", + Number(number.toString().split("")[1]), + Number(number.toString().split("")[2]), + "B", + ]; + } else { + return [null, null, null, null, null, null]; + } +}; + +const TotalRequestsPage = () => { const { apiKey } = useHeliconeLogin(); const { data, isLoading } = useTestAPIKey(apiKey.data ?? ""); const router = useRouter(); @@ -30,17 +133,40 @@ const PiGraphLayout = ({ children }: { children: React.ReactNode }) => {
- {totalRequests.data?.data?.data} -
{children}
+
+
+ Total Requests +
{" "} +
+ {formatNumber(totalRequests.data?.data?.data ?? 0).map( + (num, index) => ( +
+ {num} +
+ ) + )} +
+ {/* {JSON.stringify(formatNumber(totalRequests.data?.data?.data ?? 0))} */} +
arrow-left +
+ arrow-left +
); }; -export default PiGraphLayout; +export default TotalRequestsPage; From 9540488f8f499c4c2192dc99cb66a1f3dbaa957f Mon Sep 17 00:00:00 2001 From: Kavin Valli Date: Fri, 20 Dec 2024 13:46:45 -0800 Subject: [PATCH 11/14] total requests page --- bifrost/app/pi/total-requests/page.tsx | 9 ++++++--- bifrost/public/static/pi/arrow-right.png | Bin 0 -> 1001 bytes 2 files changed, 6 insertions(+), 3 deletions(-) create mode 100644 bifrost/public/static/pi/arrow-right.png diff --git a/bifrost/app/pi/total-requests/page.tsx b/bifrost/app/pi/total-requests/page.tsx index b7d688845d..a33247eb26 100644 --- a/bifrost/app/pi/total-requests/page.tsx +++ b/bifrost/app/pi/total-requests/page.tsx @@ -131,7 +131,7 @@ const TotalRequestsPage = () => { return (
@@ -149,9 +149,12 @@ const TotalRequestsPage = () => { ) )}
+
+ Last 30 days +
{/* {JSON.stringify(formatNumber(totalRequests.data?.data?.data ?? 0))} */}
-
+
arrow-left { />
arrow-left diff --git a/bifrost/public/static/pi/arrow-right.png b/bifrost/public/static/pi/arrow-right.png new file mode 100644 index 0000000000000000000000000000000000000000..29a745e8d145d0df256b0e9c39deb0190c5dbd94 GIT binary patch literal 1001 zcmVIjJmq!u<7QY7}kR3?%) zFbhKY?Ei1&MoAQ7J8|&W{Yh6oNsO_t&;Q(db{1ON}5<$ zSSaQ5`Ch->NC;#l<>VwpaMz7)xBG)OBp}&r_5)fOw$bbL{z=jqlfa-A3WZMP1F2J8v)Zn5VHd%P?iWoIk1t_)6-S;J!Dal07$(AG7LRw zu$Ql|uO&>>op!>qEO~x@w(Z^BUF+iF!lDg1thZXNnoL37&k2MLgC#byxVUIAX`&4| zxQ-=Gq+SBC?EnT!2#V~6S>i@zlFTsu97o3ik^qLMN<@w&c!6!hJL+zKn?Zd2gu$f5 z13W%HO59mqUS=oQHUcfzqOX>KBn%c-lpJnvZ_Da?r;>Z(BruE`3%KThKb}-yhs{RWp2p8cJvfeY;Kx#J&TN z^w`ZK7FL){^+8KOVhTt5%gamKet39r+nv+GIt@sEWQvGw2i)J^dv<$XG}7Vfq~G+) zkXjicVJ?geKNH}@&d$!j?K#@J1w6R6K@r5MKsq7;KLJG0c=_MFU_a;Rr7EmfhFCft zZ^Nz=HVkr@)v>Ac_APks>N>;&Iu4KsGQ14#C9^|lTbC(`WCvVbUCGwgmgoI3&wo>e zPK3GQ2Q2}oA7*hYKd>CfEnVJ6Mn^21qt!o#OiQS5jBqUZ zhA&Tge+X?)=7^SnM3DYyuO5c3${dO6EWkDVJ$VPhes_2n1A4a~hhJJ+s#$&(_-5cg Xh)RT+IrYRG00000NkvXXu0mjfgMGYV literal 0 HcmV?d00001 From 26fe125faf88c1236c94758a179d1b44fc9e1478 Mon Sep 17 00:00:00 2001 From: Justin Date: Fri, 20 Dec 2024 14:35:01 -0800 Subject: [PATCH 12/14] cost --- bifrost/app/pi/total-cost/page.tsx | 110 +++++++++++++++++++++++++++++ 1 file changed, 110 insertions(+) create mode 100644 bifrost/app/pi/total-cost/page.tsx diff --git a/bifrost/app/pi/total-cost/page.tsx b/bifrost/app/pi/total-cost/page.tsx new file mode 100644 index 0000000000..a6c1056762 --- /dev/null +++ b/bifrost/app/pi/total-cost/page.tsx @@ -0,0 +1,110 @@ +"use client"; + +import { useRouter } from "next/navigation"; +import { useHeliconeLogin } from "../useHeliconeLogin"; +import Link from "next/link"; + +import { JetBrains_Mono } from "next/font/google"; +import { useTestAPIKey } from "../first_page/useTestApiKey"; +import { useJawnClient } from "@/lib/clients/jawnHook"; +import { useQuery } from "@tanstack/react-query"; +import { Bar, BarChart, ResponsiveContainer, XAxis, YAxis } from "recharts"; +const jetbrainsMono = JetBrains_Mono({ subsets: ["latin"] }); + +const PiGraphLayout = ({ children }: { children: React.ReactNode }) => { + const { apiKey } = useHeliconeLogin(); + const { data, isLoading } = useTestAPIKey(apiKey.data ?? ""); + const router = useRouter(); + + const jawn = useJawnClient(apiKey.data ?? ""); + + const totalRequests = useQuery({ + queryKey: ["total-requests", apiKey.data], + queryFn: () => jawn.POST("/v1/pi/total_requests"), + }); + + const costsOverTime = useQuery({ + queryKey: ["costs-over-time", apiKey.data], + queryFn: () => + jawn.POST("/v1/pi/costs-over-time/query", { + body: { + userFilter: "all", + dbIncrement: "day", + timeZoneDifference: new Date().getTimezoneOffset(), + timeFilter: { + start: new Date( + Date.now() - 30 * 24 * 60 * 60 * 1000 + ).toISOString(), + end: new Date().toISOString(), + }, + }, + }), + }); + const costsOverTimeData = costsOverTime.data?.data?.data; + + if (!data && !isLoading && !apiKey.data && !apiKey.isLoading) { + router.push("/pi/setup?invalid_api_key=true"); + return null; + } + + return ( +
+
+

Costs

+
+ $ + {costsOverTimeData + ?.reduce((sum, item) => sum + item.cost, 0) + ?.toFixed(2) ?? "0.00"} +
+ + + + new Date(value).toLocaleDateString(undefined, { + month: "numeric", + day: "numeric", + }) + } + fontSize={12} + interval={4} // Show every 4th tick + /> + + + + +
+
{children}
+
+ + {/* eslint-disable-next-line @next/next/no-img-element */} + arrow-left + + + + {/* eslint-disable-next-line @next/next/no-img-element */} + arrow-right + +
+
+ ); +}; + +export default PiGraphLayout; From 03cb439503e89d7e8486ca2089abaee07040e5a4 Mon Sep 17 00:00:00 2001 From: Justin Date: Fri, 20 Dec 2024 14:39:42 -0800 Subject: [PATCH 13/14] redirect --- bifrost/app/pi/first_page/page.tsx | 2 ++ 1 file changed, 2 insertions(+) diff --git a/bifrost/app/pi/first_page/page.tsx b/bifrost/app/pi/first_page/page.tsx index f8ed905f45..5132be0a4e 100644 --- a/bifrost/app/pi/first_page/page.tsx +++ b/bifrost/app/pi/first_page/page.tsx @@ -15,6 +15,8 @@ const FirstPageContent = () => { const { data, isLoading } = useTestAPIKey(apiKey.data ?? ""); const jawn = useJawnClient(apiKey.data ?? ""); const router = useRouter(); + + router.push("/pi/total-requests"); const orgName = useQuery({ queryKey: ["org-name", apiKey.data], queryFn: () => jawn.POST("/v1/pi/org-name/query"), From c6cb6d5c9b1db087af063ec43312c7befa6e20e2 Mon Sep 17 00:00:00 2001 From: Kavin Valli Date: Fri, 20 Dec 2024 15:07:05 -0800 Subject: [PATCH 14/14] ready for mvp --- bifrost/app/pi/page.tsx | 2 +- bifrost/app/pi/setup/page.tsx | 4 +- bifrost/app/pi/total-cost/page.tsx | 63 +++++++++++++++------- bifrost/app/pi/total-requests/page.tsx | 21 +++++--- bifrost/public/static/pi/arrow-left.png | Bin 1037 -> 0 bytes bifrost/public/static/pi/arrow-left.webp | Bin 0 -> 618 bytes bifrost/public/static/pi/arrow-right.png | Bin 1001 -> 0 bytes bifrost/public/static/pi/arrow-right.webp | Bin 0 -> 610 bytes bifrost/public/static/pi/intro-image.png | Bin 34814 -> 0 bytes bifrost/public/static/pi/intro-image.webp | Bin 0 -> 23586 bytes 10 files changed, 60 insertions(+), 30 deletions(-) delete mode 100644 bifrost/public/static/pi/arrow-left.png create mode 100644 bifrost/public/static/pi/arrow-left.webp delete mode 100644 bifrost/public/static/pi/arrow-right.png create mode 100644 bifrost/public/static/pi/arrow-right.webp delete mode 100644 bifrost/public/static/pi/intro-image.png create mode 100644 bifrost/public/static/pi/intro-image.webp diff --git a/bifrost/app/pi/page.tsx b/bifrost/app/pi/page.tsx index 1bf74da73a..42b9e4d829 100644 --- a/bifrost/app/pi/page.tsx +++ b/bifrost/app/pi/page.tsx @@ -22,7 +22,7 @@ const PiPageContent = () => {
Helicone Logo { const { data, isLoading } = useTestAPIKey(apiKey.data ?? ""); if (apiKey.data && data && !isLoading && !apiKey.isLoading) { - router.push("/pi/first_page"); + router.push("/pi/total-requests"); return
Loading...
; } @@ -34,7 +34,7 @@ const PiPageContent = () => {
Helicone Logo { +const TotalCost = () => { const { apiKey } = useHeliconeLogin(); const { data, isLoading } = useTestAPIKey(apiKey.data ?? ""); const router = useRouter(); @@ -49,46 +56,64 @@ const PiGraphLayout = ({ children }: { children: React.ReactNode }) => { return (
-
-

Costs

-
- $ - {costsOverTimeData - ?.reduce((sum, item) => sum + item.cost, 0) - ?.toFixed(2) ?? "0.00"} +
+
+
Total Cost
+
+ $ + {costsOverTimeData + ?.reduce((sum, item) => sum + item.cost, 0) + ?.toFixed(2) ?? "0.00"} +
- - +
+
+
costs
+
+ + + new Date(value).toLocaleDateString(undefined, { month: "numeric", day: "numeric", + year: "2-digit", }) } + includeHidden + interval={6} + tickSize={14} + padding={{ left: 16, right: 16 }} + tickMargin={8} fontSize={12} - interval={4} // Show every 4th tick + strokeWidth={1.52} + stroke="#000000" /> - + {/* */}
-
{children}
{/* eslint-disable-next-line @next/next/no-img-element */} arrow-left @@ -97,7 +122,7 @@ const PiGraphLayout = ({ children }: { children: React.ReactNode }) => { {/* eslint-disable-next-line @next/next/no-img-element */} arrow-right @@ -107,4 +132,4 @@ const PiGraphLayout = ({ children }: { children: React.ReactNode }) => { ); }; -export default PiGraphLayout; +export default TotalCost; diff --git a/bifrost/app/pi/total-requests/page.tsx b/bifrost/app/pi/total-requests/page.tsx index a33247eb26..f427a4cbf0 100644 --- a/bifrost/app/pi/total-requests/page.tsx +++ b/bifrost/app/pi/total-requests/page.tsx @@ -7,6 +7,7 @@ import { JetBrains_Mono } from "next/font/google"; import { useTestAPIKey } from "../first_page/useTestApiKey"; import { useJawnClient } from "@/lib/clients/jawnHook"; import { useQuery } from "@tanstack/react-query"; +import Link from "next/link"; const jetbrainsMono = JetBrains_Mono({ subsets: ["latin"] }); const formatNumber = ( @@ -155,18 +156,22 @@ const TotalRequestsPage = () => { {/* {JSON.stringify(formatNumber(totalRequests.data?.data?.data ?? 0))} */}
- arrow-left -
+ + {/* eslint-disable-next-line @next/next/no-img-element */} arrow-left -
+ + + {/* eslint-disable-next-line @next/next/no-img-element */} + arrow-left +
); diff --git a/bifrost/public/static/pi/arrow-left.png b/bifrost/public/static/pi/arrow-left.png deleted file mode 100644 index 368fe3ae9c0949777ff8985d59e2e733fd1fc26e..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1037 zcmV+o1oHcdP)$4aGAChV)LD|&c%`1hr;SdN=KY<@P)jg-m2 zMz>bD9y2PH3SvYSHg^PVZEcDBvLgU@fJHt;%S6Ey&p<$A*U!MtWHPD6#YJ&{X=#aq zge#p<%Ph07XJ=>Y(g+$_CJH@!2Imkd_K5GWS65ff-Q8Vre{OD$dWGfoiv|FXTFb5O z_uLt^tkHr!Jw5GKe6Ywvv`iEnB{`#`qh_&K6t29swnk@XXC~~)$w@K{qvK}_g#x|2 zypUI{tgO)U^RuwqC3lWx!b7Nu_VxAEQG7sWb?Y#%(K1o6+9>#$B1UMOcW9*=Tof)xw*M%jE|3tH;`gSjYK>i-{3fr#f!tk!^lZPMax71 z0rWQq%?rG^zrRm&sb5HDeSO{c6DzlAn95>xOHH)GB$@g7`T7*T4SH^((vW9xFg=w? z*ZKMRr?IgyVejwnQxs@h=~5;0_Vz|WN6W+^or*hOq-3_Yw|}6;=yG&)L}A5NL0DFX zFuDYFIv(UHDz$g{RVb2nGBs|Y;^{&Gvv@dK0cakQ&`b5QEWk~{?v8?lmWhJvJA}CgQsBj?JnZ-P_qt>-w01*E%?t3m`?^;frwaHF z%-DV2>%HSzCJKE$e8aAnXV1vhY*U_5i##0;;#BqF8z0hFnKY4Osfho+df+DVV2`+# ziO=z5T<2h#RYsPt^1j!3hUfU{DCZypXiL~jmf0gr@&SJVqqIp5dL@fX00000NkvXX Hu0mjf+^gj; diff --git a/bifrost/public/static/pi/arrow-left.webp b/bifrost/public/static/pi/arrow-left.webp new file mode 100644 index 0000000000000000000000000000000000000000..76223ec3e04d1a9a52ea8b3894a07ac070fd370a GIT binary patch literal 618 zcmV-w0+szzNk&Fu0ssJ4MM6+kP&il$0000G0000&002Dz06|PpNWcI9009P9wQa>s zBve8qL;@0!fP_fE32{&fNQi_d0STSQOZYx7A|`;ohr~&4yATd9X5XKz?lRluF-+Kn z!-@raQVUHbUp_phP}t?tRM z5${7xG`Vuo@55SXaue7ftl66!V1p17dcY_ITo2|!z&+_f7z7{XJAgqadGBVUFx1T{~Ue_rFxv-+Y{~wNb@gLms zG4$$k_lW=C&q5R1MEaK<+?_TpJfaGV%$0%v5j#+FMLX#30cLD!NKNjVW!@L63 zr_fA5F!?Y3t!Kx7)8?@?Ow&AC?TcVK>)dU*|4jRBO(BpvU7GL& z!PBL042T`$n;=)z`MT#^Cjo_NW}GO@kIf(J=1c7nZ|HvBQ|ojISQ{}9)euI;Gt>Y8 E0K7R8%m4rY literal 0 HcmV?d00001 diff --git a/bifrost/public/static/pi/arrow-right.png b/bifrost/public/static/pi/arrow-right.png deleted file mode 100644 index 29a745e8d145d0df256b0e9c39deb0190c5dbd94..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1001 zcmVIjJmq!u<7QY7}kR3?%) zFbhKY?Ei1&MoAQ7J8|&W{Yh6oNsO_t&;Q(db{1ON}5<$ zSSaQ5`Ch->NC;#l<>VwpaMz7)xBG)OBp}&r_5)fOw$bbL{z=jqlfa-A3WZMP1F2J8v)Zn5VHd%P?iWoIk1t_)6-S;J!Dal07$(AG7LRw zu$Ql|uO&>>op!>qEO~x@w(Z^BUF+iF!lDg1thZXNnoL37&k2MLgC#byxVUIAX`&4| zxQ-=Gq+SBC?EnT!2#V~6S>i@zlFTsu97o3ik^qLMN<@w&c!6!hJL+zKn?Zd2gu$f5 z13W%HO59mqUS=oQHUcfzqOX>KBn%c-lpJnvZ_Da?r;>Z(BruE`3%KThKb}-yhs{RWp2p8cJvfeY;Kx#J&TN z^w`ZK7FL){^+8KOVhTt5%gamKet39r+nv+GIt@sEWQvGw2i)J^dv<$XG}7Vfq~G+) zkXjicVJ?geKNH}@&d$!j?K#@J1w6R6K@r5MKsq7;KLJG0c=_MFU_a;Rr7EmfhFCft zZ^Nz=HVkr@)v>Ac_APks>N>;&Iu4KsGQ14#C9^|lTbC(`WCvVbUCGwgmgoI3&wo>e zPK3GQ2Q2}oA7*hYKd>CfEnVJ6Mn^21qt!o#OiQS5jBqUZ zhA&Tge+X?)=7^SnM3DYyuO5c3${dO6EWkDVJ$VPhes_2n1A4a~hhJJ+s#$&(_-5cg Xh)RT+IrYRG00000NkvXXu0mjfgMGYV diff --git a/bifrost/public/static/pi/arrow-right.webp b/bifrost/public/static/pi/arrow-right.webp new file mode 100644 index 0000000000000000000000000000000000000000..0ca8e9d7bceebc1200b2bc89238764774fd20f72 GIT binary patch literal 610 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 diff --git a/bifrost/public/static/pi/intro-image.webp b/bifrost/public/static/pi/intro-image.webp new file mode 100644 index 0000000000000000000000000000000000000000..c62fd9ba8c263c9da3f1c00c3eced1119834e918 GIT binary patch literal 23586 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 literal 0 HcmV?d00001