mindcraft/src/models/gemini.js

78 lines
2.5 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 {
2024-04-24 11:28:04 -07:00
constructor(model_name, url) {
this.model_name = model_name;
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;
2024-04-24 11:28:04 -07:00
if (this.url) {
model = this.genAI.getGenerativeModel(
2024-11-02 22:24:23 +01:00
{ model: this.model_name || "gemini-1.5-flash" },
{ baseUrl: this.url },
{ safetySettings: this.safetySettings }
2024-04-24 11:28:04 -07:00
);
} else {
model = this.genAI.getGenerativeModel(
2024-11-02 22:24:23 +01:00
{ model: this.model_name || "gemini-1.5-flash" },
{ 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...');
2024-04-24 11:28:04 -07:00
const result = await model.generateContent(prompt);
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);
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
}
}