Skip to content

Commit

Permalink
more cleanups
Browse files Browse the repository at this point in the history
  • Loading branch information
eladb committed Mar 19, 2024
1 parent d4fb8ed commit de79e2d
Show file tree
Hide file tree
Showing 7 changed files with 45 additions and 60 deletions.
9 changes: 0 additions & 9 deletions openai/api.w

This file was deleted.

2 changes: 1 addition & 1 deletion openai/example.main.w
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,6 @@ let key = new cloud.Secret(name: "my-openai-key");
let oai = new openai.OpenAI(apiKeySecret: key);

new cloud.Function(inflight () => {
let answer = oai.createCompletion("tell me a short joke", model: "gpt-3.5-turbo", max_tokens: 2048);
let answer = oai.createCompletion("tell me a short joke", model: "gpt-3.5-turbo", maxTokens: 2048);
log(answer);
}) as "tell me a joke";
10 changes: 3 additions & 7 deletions openai/openai.extern.d.ts
Original file line number Diff line number Diff line change
@@ -1,10 +1,6 @@
export default interface extern {
createNewInflightClient: (apiKey: string, org?: (string) | undefined) => Promise<IOpenAI$Inflight>,
createNewInflightClient: (apiKey: string, org?: (string) | undefined) => Promise<IClient$Inflight>,
}
export interface CompletionParams {
readonly max_tokens: number;
readonly model: string;
}
export interface IOpenAI$Inflight {
readonly createCompletion: (prompt: string, params?: (CompletionParams) | undefined) => Promise<string>;
export interface IClient$Inflight {
readonly createCompletion: (params: Readonly<any>) => Promise<Readonly<any>>;
}
25 changes: 2 additions & 23 deletions openai/openai.js
Original file line number Diff line number Diff line change
Expand Up @@ -9,30 +9,9 @@ exports.createNewInflightClient = (apiKey, org) => {

let client = new openai.OpenAI(config);

// TODO: this is a hack for now, we should model the openai api in the api.w file with more fidelity
// and then we can just return the client itself, like we do in redis
return {
createCompletion: async (prompt, params = {}) => {
if (!prompt) {
throw new Error("Prompt is required");
};

if (typeof prompt !== "string") {
throw new Error("Prompt must be a string");
}

if (!params.model) {
params.model = "gpt-3.5-turbo";
};

if (!params.max_tokens) {
params.max_tokens = 2048;
}

params.messages = [ { role: 'user', content: prompt } ];

const response = await client.chat.completions.create(params);
return response.choices[0]?.message?.content;
createCompletion: async params => {
return await client.chat.completions.create(params);
}
};
};
7 changes: 4 additions & 3 deletions openai/openai.test.w
Original file line number Diff line number Diff line change
Expand Up @@ -7,13 +7,14 @@ let key = new cloud.Secret(name: "my-openai-key");
let oai = new openai.OpenAI(apiKeySecret: key);

test "basic completion" {
let answer = oai.createCompletion("tell me a short joke", max_tokens: 1024);
let answer = oai.createCompletion("tell me a short joke", maxTokens: 1024);

// in tests, the response is just an echo of the request
expect.equal(answer, Json.stringify({
mock: {
prompt:"tell me a short joke",
params:{"model":"gpt-3.5-turbo","max_tokens":1024}
"max_tokens":1024,
"model":"gpt-3.5-turbo",
"messages":[{"role":"user","content":"tell me a short joke"}]
}
}));
}
47 changes: 35 additions & 12 deletions openai/openai.w
Original file line number Diff line number Diff line change
@@ -1,7 +1,10 @@
bring util;
bring "./api.w" as api;
bring "./utils.w" as utils;
bring cloud;
bring util;

pub struct CompletionParams {
model: str?;
maxTokens: num?;
}

pub struct OpenAIProps {
apiKey: str?;
Expand All @@ -10,21 +13,33 @@ pub struct OpenAIProps {
orgSecret: cloud.Secret?;
}

inflight class Sim impl api.IOpenAI {
pub createCompletion(prompt: str, params: api.CompletionParams?): str {
return Json.stringify({ mock: { prompt: prompt, params: params } });
interface IClient {
inflight createCompletion(params: Json): Json;
}

inflight class Sim impl IClient {
pub createCompletion(req: Json): Json {
return {
choices: [
{
message: {
content: Json.stringify({ mock: req })
}
}
]
};
}
}

pub class OpenAI impl api.IOpenAI {
pub class OpenAI {
apiKey: cloud.Secret?;
org: cloud.Secret?;
keyOverride: str?;
orgOverride: str?;

mock: bool;

inflight openai: api.IOpenAI;
inflight openai: IClient;

new(props: OpenAIProps?) {
this.apiKey = props?.apiKeySecret;
Expand All @@ -50,11 +65,19 @@ pub class OpenAI impl api.IOpenAI {
if this.mock {
this.openai = new Sim();
} else {
this.openai = utils.createNewInflightClient(apiKey, org);
this.openai = OpenAI.createNewInflightClient(apiKey, org);
}
}

pub inflight createCompletion(prompt: str, params: api.CompletionParams?): str {
return this.openai.createCompletion(prompt, params);
pub inflight createCompletion(prompt: str, params: CompletionParams?): str {
let resp = this.openai.createCompletion({
max_tokens: params?.maxTokens ?? 2048,
model: params?.model ?? "gpt-3.5-turbo",
messages: [ { role: "user", content: prompt } ]
});

return resp.get("choices").getAt(0).get("message").get("content").asStr();
}
}

extern "./openai.js" pub static inflight createNewInflightClient(apiKey: str, org: str?): IClient;
}
5 changes: 0 additions & 5 deletions openai/utils.w

This file was deleted.

0 comments on commit de79e2d

Please sign in to comment.