ai-manga-factory / src /app /queries /predictWithGroq.ts
jbilcke-hf's picture
jbilcke-hf HF staff
refactoring for OpenAI and Groq
ba986c0
raw
history blame
934 Bytes
"use server"
import Groq from "groq-sdk"
export async function predict({
systemPrompt,
userPrompt,
nbMaxNewTokens,
}: {
systemPrompt: string
userPrompt: string
nbMaxNewTokens: number
}): Promise<string> {
const groqApiKey = `${process.env.AUTH_GROQ_API_KEY || ""}`
const groqApiModel = `${process.env.LLM_GROQ_API_MODEL || "mixtral-8x7b-32768"}`
const groq = new Groq({
apiKey: groqApiKey,
})
const messages: Groq.Chat.Completions.CompletionCreateParams.Message[] = [
{ role: "system", content: systemPrompt },
{ role: "user", content: userPrompt },
]
try {
const res = await groq.chat.completions.create({
messages: messages,
model: groqApiModel,
stream: false,
temperature: 0.5,
max_tokens: nbMaxNewTokens,
})
return res.choices[0].message.content || ""
} catch (err) {
console.error(`error during generation: ${err}`)
return ""
}
}