GeminiFlash is a Node.js library that leverages a Rust backend for generating content using Google's Gemini-1.5-Flash Generative AI Model. This library is designed to be efficient and easy to use, thanks to the power of Rust and the simplicity of JavaScript.
To install the GeminiFlash library, you can use npm:
npm install gemini_flash
Here's a basic example of how to use the GeminiFlash library:
const GeminiFlash = require('gemini_flash');
const gemini_flash = new GeminiFlash('api-key-here');
(async () => {
try {
const prompt = "what is a computer?";
const content = await gemini_flash.generate_content(prompt);
console.log("Generated Content:", content.text);
} catch (error) {
console.error("Error:", error);
}
})();
Creates a new instance of the GeminiFlash
class.
api_key
: Your API key for the Gemini API.
Generates content based on the given prompt.
prompt
: The prompt string to generate content for.
Returns: A Promise that resolves to an object containing the generated content.
const GeminiFlash = require('gemini_flash');
const gemini_flash = new GeminiFlash('your-api-key');
(async () => {
try {
const prompt = "Explain the concept of artificial intelligence.";
const content = await gemini_flash.generate_content(prompt);
console.log("Generated Content:", content.text);
} catch (error) {
console.error("Error:", error);
}
})();
const fs = require('fs').promises;
const GeminiFlash = require('gemini_flash');
const gemini_flash = new GeminiFlash('your-api-key');
async function imageToBase64(imagePath) {
try {
const imageBuffer = await fs.readFile(imagePath);
const base64Image = imageBuffer.toString('base64');
return base64Image;
} catch (err) {
console.error("Error reading the image file:", err);
throw err;
}
}
(async () => {
try {
const prompt = "Explain this image";
const imagePath = './image.jpeg';
const base64String = await imageToBase64(imagePath);
const content = await gemini_flash.image_search(prompt, base64String);
console.log("Generated Content:", content.text);
} catch (error) {
console.error("Error:", error);
}
})();
To build the project, run:
npm run build
To run the tests, use:
npm test
- Debug build:
npm run debug
- Release build:
npm run build
- Cross build:
npm run cross
Contributions are welcome! Please feel free to submit a pull request or open an issue if you find a bug or have a feature request.
This project is licensed under the MIT License - see the LICENSE file for details.