mindcraft/src/models/gemini.js

99 lines
2.9 KiB
JavaScript
Raw Normal View History

2024-02-18 22:56:38 -06:00
import { GoogleGenerativeAI } from '@google/generative-ai';
2024-05-10 13:41:29 -05:00
import { toSinglePrompt } from '../utils/text.js';
2024-05-30 18:00:48 -05:00
import { getKey } from '../utils/keys.js';
2024-04-24 11:28:04 -07:00
2024-02-18 22:56:38 -06:00
export class Gemini {
2025-02-04 13:02:57 -06:00
constructor(model_name, url, params) {
2024-04-24 11:28:04 -07:00
this.model_name = model_name;
2025-02-04 13:02:57 -06:00
this.params = params;
2024-04-24 11:28:04 -07:00
this.url = url;
2024-11-02 22:24:23 +01:00
this.safetySettings = [
{
"category": "HARM_CATEGORY_DANGEROUS",
"threshold": "BLOCK_NONE",
},
{
"category": "HARM_CATEGORY_HARASSMENT",
"threshold": "BLOCK_NONE",
},
{
"category": "HARM_CATEGORY_HATE_SPEECH",
"threshold": "BLOCK_NONE",
},
{
"category": "HARM_CATEGORY_SEXUALLY_EXPLICIT",
"threshold": "BLOCK_NONE",
},
{
"category": "HARM_CATEGORY_DANGEROUS_CONTENT",
"threshold": "BLOCK_NONE",
},
];
2024-04-24 11:28:04 -07:00
2024-05-30 18:00:48 -05:00
this.genAI = new GoogleGenerativeAI(getKey('GEMINI_API_KEY'));
2024-02-18 22:56:38 -06:00
}
async sendRequest(turns, systemMessage) {
let model;
2025-02-04 13:02:57 -06:00
const modelConfig = {
model: this.model_name || "gemini-1.5-flash",
...(this.params || {})
};
2024-04-24 11:28:04 -07:00
if (this.url) {
model = this.genAI.getGenerativeModel(
2025-02-04 13:02:57 -06:00
modelConfig,
2024-11-02 22:24:23 +01:00
{ baseUrl: this.url },
{ safetySettings: this.safetySettings }
2024-04-24 11:28:04 -07:00
);
} else {
model = this.genAI.getGenerativeModel(
2025-02-04 13:02:57 -06:00
modelConfig,
2024-11-02 22:24:23 +01:00
{ safetySettings: this.safetySettings }
2024-04-24 11:28:04 -07:00
);
}
const stop_seq = '***';
const prompt = toSinglePrompt(turns, systemMessage, stop_seq, 'model');
2024-06-01 16:05:59 -05:00
console.log('Awaiting Google API response...');
2025-02-04 13:02:57 -06:00
const result = await model.generateContent({
contents: [
{
role: 'user',
parts: [
{
text: "Explain how AI works",
}
],
}
],
generateConfig: {
...(this.params || {})
}
});
2024-02-18 22:56:38 -06:00
const response = await result.response;
const text = response.text();
2024-06-01 16:05:59 -05:00
console.log('Received.');
if (!text.includes(stop_seq)) return text;
const idx = text.indexOf(stop_seq);
2025-02-04 13:02:57 -06:00
return text.slice(0, idx);
2024-02-18 22:56:38 -06:00
}
async embed(text) {
let model;
2024-04-24 11:28:04 -07:00
if (this.url) {
model = this.genAI.getGenerativeModel(
2024-11-02 22:24:23 +01:00
{ model: "text-embedding-004" },
{ baseUrl: this.url }
2024-04-24 11:28:04 -07:00
);
} else {
model = this.genAI.getGenerativeModel(
2024-11-02 22:24:23 +01:00
{ model: "text-embedding-004" }
2024-04-24 11:28:04 -07:00
);
}
const result = await model.embedContent(text);
2024-11-02 22:24:23 +01:00
return result.embedding.values;
2024-02-18 22:56:38 -06:00
}
}