mindcraft/src/models/gemini.js

97 lines
2.9 KiB
JavaScript
Raw Normal View History

2024-02-18 22:56:38 -06:00
import { GoogleGenerativeAI } from '@google/generative-ai';
2025-02-04 14:41:57 -06:00
import { toSinglePrompt, strictFormat } 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",
2025-02-04 14:41:57 -06:00
// systemInstruction does not work bc google is trash
2025-02-04 13:02:57 -06:00
};
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
);
}
2024-06-01 16:05:59 -05:00
console.log('Awaiting Google API response...');
2025-02-04 14:41:57 -06:00
turns.unshift({ role: 'system', content: systemMessage });
turns = strictFormat(turns);
let contents = [];
for (let turn of turns) {
contents.push({
role: turn.role === 'assistant' ? 'model' : 'user',
parts: [{ text: turn.content }]
});
}
2025-02-04 13:02:57 -06:00
const result = await model.generateContent({
2025-02-04 14:41:57 -06:00
contents,
generationConfig: {
2025-02-04 13:02:57 -06:00
...(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.');
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
}
}