Skip to content

Commit

Permalink
feat: Implement direct API call with structured output
Browse files Browse the repository at this point in the history
  • Loading branch information
nadeesha committed Nov 12, 2024
1 parent 7dcc6f2 commit a8fc02f
Show file tree
Hide file tree
Showing 3 changed files with 61 additions and 6 deletions.
29 changes: 29 additions & 0 deletions sdk-node/src/Inferable.test.ts
Original file line number Diff line number Diff line change
Expand Up @@ -289,4 +289,33 @@ describe("Inferable SDK End to End Test", () => {
await client.default.stop();
}
});

describe("api", () => {
it("should be able to call the api directly", async () => {
const client = inferableInstance();

expect(
await client.api.createStructuredOutput({
params: {
clusterId: TEST_CLUSTER_ID,
},
body: {
prompt: "What is the capital of France?",
modelId: "claude-3-5-sonnet",
resultSchema: {
type: "object",
properties: {
capital: { type: "string" },
},
},
},
}),
).toEqual({
success: true,
result: {
capital: "Paris",
},
});
});
});
});
12 changes: 6 additions & 6 deletions sdk-node/src/Inferable.ts
Original file line number Diff line number Diff line change
Expand Up @@ -110,10 +110,7 @@ export class Inferable {
* const client = new Inferable();
* ```
*/
constructor(options?: {
apiSecret?: string;
endpoint?: string;
}) {
constructor(options?: { apiSecret?: string; endpoint?: string }) {
if (options?.apiSecret && process.env.INFERABLE_API_SECRET) {
log(
"API Secret was provided as an option and environment variable. Constructor argument will be used.",
Expand Down Expand Up @@ -217,7 +214,6 @@ export class Inferable {
* ```
*/
public async run(input: RunInput) {

let resultSchema: JsonSchemaInput | undefined;

if (!!input.resultSchema && isZodType(input.resultSchema)) {
Expand Down Expand Up @@ -494,13 +490,17 @@ export class Inferable {
this.functionRegistry[registration.name] = registration;
}

public get api() {
return this.client;
}

private async getClusterId() {
if (!this.clusterId) {
// Call register machine without any services to test API key and get clusterId
const registerResult = await registerMachine(this.client);
this.clusterId = registerResult.clusterId;
}

return this.clusterId!
return this.clusterId!;
}
}
26 changes: 26 additions & 0 deletions sdk-node/src/contract.ts
Original file line number Diff line number Diff line change
Expand Up @@ -1424,6 +1424,32 @@ export const definition = {
artifactId: z.string(),
}),
},
createStructuredOutput: {
method: "POST",
path: "/clusters/:clusterId/structured-output",
headers: z.object({ authorization: z.string() }),
body: z.object({
prompt: z.string(),
resultSchema: anyObject
.optional()
.describe(
"A JSON schema definition which the result object should conform to. By default the result will be a JSON object which does not conform to any schema",
),
modelId: z.enum(["claude-3-5-sonnet", "claude-3-haiku"]),
temperature: z
.number()
.optional()
.describe("The temperature to use for the model")
.default(0.5),
}),
responses: {
200: z.unknown(),
401: z.undefined(),
},
pathParams: z.object({
clusterId: z.string(),
}),
},
} as const;

export const contract = c.router(definition);

0 comments on commit a8fc02f

Please sign in to comment.