Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

feat: add algolia to cohere chat demo #1210

Merged
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
27 commits
Select commit Hold shift + click to select a range
d815de1
ready to try to test
RohinBhargava Jul 26, 2024
f8b2038
add comment
RohinBhargava Jul 26, 2024
5ffdd78
add lockfile
RohinBhargava Jul 26, 2024
9f9a5ea
need to figure out how to populate url
RohinBhargava Jul 27, 2024
b443f49
pnpm-lock revert
RohinBhargava Jul 27, 2024
3ab5279
proper pnpm-lock
RohinBhargava Jul 27, 2024
3d2739e
main pnpm
Jul 29, 2024
f2382f7
reset pnpm-lock
Jul 29, 2024
14f82ee
lockfile
Jul 29, 2024
ee41049
merge from upstream
Jul 29, 2024
37326e8
update hack with getting the right docs url
Jul 29, 2024
21e7026
test
RohinBhargava Jul 29, 2024
be46882
remove kv
RohinBhargava Jul 29, 2024
a51b4b1
lockfile
RohinBhargava Jul 29, 2024
63daf56
prettier
RohinBhargava Jul 29, 2024
32797ca
proper import
RohinBhargava Jul 29, 2024
52d7dc1
Merge remote-tracking branch 'origin/main' into rohin/add-algolia-to-…
RohinBhargava Jul 30, 2024
dc97d0c
working example
RohinBhargava Jul 30, 2024
57a920a
prefer private docs
RohinBhargava Jul 30, 2024
0c43f54
pnpm format
RohinBhargava Jul 30, 2024
8835846
chat history added back, maximum of 10
RohinBhargava Jul 30, 2024
0a7107a
add comments
RohinBhargava Jul 30, 2024
e6bd21c
get rid of print
RohinBhargava Jul 30, 2024
3350fc2
Merge remote-tracking branch 'origin/main' into rohin/add-algolia-to-…
RohinBhargava Jul 30, 2024
76d4a0b
Merge branch 'ajiang/cohere-stream' into rohin/add-algolia-to-cohere-…
RohinBhargava Jul 30, 2024
7ffb3ee
remove algoliasearch dep
RohinBhargava Jul 30, 2024
1309cbb
comment out console log for CI
RohinBhargava Jul 30, 2024
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
5 changes: 4 additions & 1 deletion packages/ui/docs-bundle/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -50,6 +50,7 @@
"@fern-ui/ui": "workspace:*",
"@sentry/nextjs": "^7.112.2",
"@vercel/edge-config": "^1.1.0",
"@vercel/kv": "^2.0.0",
"@workos-inc/node": "^6.1.0",
"cohere-ai": "^7.9.5",
"cssnano": "^6.0.3",
Expand All @@ -65,7 +66,8 @@
"react-dom": "^18.2.0",
"sharp": "^0.33.3",
"ts-essentials": "^10.0.1",
"url-join": "5.0.0"
"url-join": "5.0.0",
"uuid": "^9.0.0"
},
"devDependencies": {
"@fern-platform/configs": "workspace:*",
Expand All @@ -76,6 +78,7 @@
"@types/node-fetch": "2.6.9",
"@types/react": "^18.0.20",
"@types/react-dom": "^18.2.18",
"@types/uuid": "^9.0.1",
"autoprefixer": "^10.4.16",
"depcheck": "^1.4.3",
"env-cmd": "toddbluhm/env-cmd",
Expand Down
Original file line number Diff line number Diff line change
@@ -1,11 +1,13 @@
import { FdrClient } from "@fern-api/fdr-sdk";
import { kv } from "@vercel/kv";
import { Cohere, CohereClient } from "cohere-ai";
import { ChatMessage } from "cohere-ai/api";
import { NextRequest } from "next/server";
import { v4 } from "uuid";
import { getXFernHostEdge } from "../../../../utils/xFernHost";

export const runtime = "edge";

const cohere = new CohereClient({
token: process.env.COHERE_API_KEY,
});

const PREAMBLE = `
You are an expert AI assistant called Fernie that helps developers answer questions about Cohere's APIs and SDKs.
The user asking questions is a developer, technical writer, or product manager. Your tone is friendly and helpful, and you can provide code snippets.
Expand All @@ -26,19 +28,49 @@ export default async function handler(req: Request): Promise<Response> {
return new Response(null, { status: 405 });
}

const cohere = new CohereClient({
token: process.env.COHERE_API_KEY,
});

const docsUrl = getXFernHostEdge(req as NextRequest);

const body = await req.json();

let conversationId = body.conversationId;

if (!body.conversationId) {
conversationId = v4();
}

const frc = new FdrClient();

const docsUrlResponse = await frc.docs.v2.read.getDocsForUrl({ url: docsUrl });

const docsSearchHits = docsUrlResponse.ok ? docsUrlResponse.body.definition.pages : {};

const transformedDocuments = docsSearchHits
? Object.entries(docsSearchHits).map(([title, text]) => {
return { title, text: text.markdown };
})
: [];

const chatHistory = (await kv.get<ChatMessage[]>(conversationId)) ?? [];
const response = await cohere.chatStream({
preamble: PREAMBLE,
conversationId: body.conversationId,
chatHistory,
message: body.message,
documents: transformedDocuments.slice(0, 20),
});

const stream = convertAsyncIterableToStream(response).pipeThrough(getCohereStreamTransformer());
chatHistory.push({ role: "USER", message: body.message });

const stream = convertAsyncIterableToStream(response).pipeThrough(
getCohereStreamTransformer(conversationId, chatHistory),
);

return new Response(stream, {
status: 200,
headers: { "Content-Type": "text/plain; charset=utf-8" },
headers: { "Content-Type": "text/plain; charset=utf-8", "X-Conversation-Id": conversationId },
});
}

Expand All @@ -53,13 +85,30 @@ function convertAsyncIterableToStream<T>(iterable: AsyncIterable<T>): ReadableSt
});
}

function getCohereStreamTransformer() {
function getCohereStreamTransformer(
conversationId: string,
chatHistory: ChatMessage[],
): TransformStream<Cohere.StreamedChatResponse, Uint8Array> {
const encoder = new TextEncoder();
let reply: string = "";
return new TransformStream<Cohere.StreamedChatResponse, Uint8Array>({
async transform(chunk, controller) {
if (chunk.eventType === "text-generation") {
reply += chunk.text;
controller.enqueue(encoder.encode(chunk.text));
}
if (chunk.eventType === "citation-generation") {
// might want to use this somewhere?
// console.log(chunk.citations);
}
if (chunk.eventType === "stream-end") {
// not sure what magic number is appropriate here
while (chatHistory.length >= 10) {
chatHistory.shift();
}
chatHistory.push({ role: "CHATBOT", message: reply });
await kv.set(conversationId, chatHistory);
}
},
});
}
Loading
Loading