6500db9c1c
* move index to home folder, create state and context files and barrell folder * Sanity Check Commit: reducer added to home.tsx manual QA all working * WIP: promptBar * fix missing json parse on folders and prompts * split context and add promptbar context * add context to nested prompt componets and componetize Folder componet * remove log * Create buttons folder and componetize sidebar action button * tidy up prompt handlers * componetized sidebar * added back chatbar componet to left side sidebar * monster commit: Componetized the common code between chatbar and promptbar into new componet Sidebar and added context to both bars * add useFetch service * added prettier import sort to keep imports ordered and easier to indentify * added react query and useFetch to work with RQ * added apiService, errorService and reactQuery * add callback and tidy up error service * refactor chat and child componets to useContext * fix extra calls and bad calls to mel endpoint * minor import cleanup --------- Co-authored-by: jc.durbin <jc.durbin@ardanis.com>
62 lines
1.6 KiB
TypeScript
62 lines
1.6 KiB
TypeScript
import { OPENAI_API_HOST } from '@/utils/app/const';
|
|
|
|
import { OpenAIModel, OpenAIModelID, OpenAIModels } from '@/types/openai';
|
|
|
|
export const config = {
|
|
runtime: 'edge',
|
|
};
|
|
|
|
const handler = async (req: Request): Promise<Response> => {
|
|
try {
|
|
const { key } = (await req.json()) as {
|
|
key: string;
|
|
};
|
|
|
|
const response = await fetch(`${OPENAI_API_HOST}/v1/models`, {
|
|
headers: {
|
|
'Content-Type': 'application/json',
|
|
Authorization: `Bearer ${key ? key : process.env.OPENAI_API_KEY}`,
|
|
...(process.env.OPENAI_ORGANIZATION && {
|
|
'OpenAI-Organization': process.env.OPENAI_ORGANIZATION,
|
|
}),
|
|
},
|
|
});
|
|
|
|
if (response.status === 401) {
|
|
return new Response(response.body, {
|
|
status: 500,
|
|
headers: response.headers,
|
|
});
|
|
} else if (response.status !== 200) {
|
|
console.error(
|
|
`OpenAI API returned an error ${
|
|
response.status
|
|
}: ${await response.text()}`,
|
|
);
|
|
throw new Error('OpenAI API returned an error');
|
|
}
|
|
|
|
const json = await response.json();
|
|
|
|
const models: OpenAIModel[] = json.data
|
|
.map((model: any) => {
|
|
for (const [key, value] of Object.entries(OpenAIModelID)) {
|
|
if (value === model.id) {
|
|
return {
|
|
id: model.id,
|
|
name: OpenAIModels[value].name,
|
|
};
|
|
}
|
|
}
|
|
})
|
|
.filter(Boolean);
|
|
|
|
return new Response(JSON.stringify(models), { status: 200 });
|
|
} catch (error) {
|
|
console.error(error);
|
|
return new Response('Error', { status: 500 });
|
|
}
|
|
};
|
|
|
|
export default handler;
|