PrivacyJailbreak/easyjailbreak/models/gemini_model.py
2025-05-15 14:10:22 +08:00

53 lines
2.4 KiB
Python

import os
import logging
import warnings
import google.generativeai as genai
from .model_base import BlackBoxModelBase
from fastchat.conversation import get_conv_template
from httpx import URL
class GenaiModel(BlackBoxModelBase):
def __init__(self, model_name: str, api_keys: str, generation_config=None):
"""
Initializes the OpenAI model with necessary parameters.
:param str model_name: The name of the model to use.
:param str api_keys: API keys for accessing the OpenAI service.
:param str template_name: The name of the conversation template, defaults to 'chatgpt'.
:param dict generation_config: Configuration settings for generation, defaults to an empty dictionary.
:param str|URL base_url: The base URL for the OpenAI API, defaults to None.
"""
genai.configure(api_key=api_keys)
self.model_name = model_name
self.model = genai.GenerativeModel(self.model_name)
self.conversation = get_conv_template('gemini')
self.generation_config = generation_config if generation_config is not None else {}
def set_system_message(self, system_message: str):
"""
Sets a system message for the conversation.
:param str system_message: The system message to set.
"""
self.conversation.system_message = system_message
def generate(self, messages, clear_old_history=True, **kwargs):
"""
Generates a response based on messages that include conversation history.
:param list[str]|str messages: A list of messages or a single message string.
User and assistant messages should alternate.
:param bool clear_old_history: If True, clears the old conversation history before adding new messages.
:return str: The response generated by the OpenAI model based on the conversation history.
"""
if clear_old_history:
self.conversation.messages = []
if isinstance(messages, str):
messages = [messages]
for index, message in enumerate(messages):
self.conversation.append_message(self.conversation.roles[index % 2], message)
messages = self.conversation.to_gemini_api_messages()
print(messages)
chat = self.model.start_chat()
response = chat.send_message("hello")
print(response)
return response.text