mirror of
https://github.com/aljazceru/Auto-GPT.git
synced 2026-01-09 09:14:19 +01:00
* Organize the configuration args * Remove duplication in setting config defaults --------- Co-authored-by: Reinier van der Leer <github@pwuts.nl>
363 lines
14 KiB
Python
363 lines
14 KiB
Python
"""Configuration class to store the state of bools for different scripts access."""
|
|
from __future__ import annotations
|
|
|
|
import contextlib
|
|
import os
|
|
import re
|
|
from typing import Dict, Optional, Union
|
|
|
|
import yaml
|
|
from colorama import Fore
|
|
from pydantic import Field
|
|
|
|
from autogpt.core.configuration.schema import Configurable, SystemSettings
|
|
from autogpt.plugins.plugins_config import PluginsConfig
|
|
|
|
AZURE_CONFIG_FILE = os.path.join(os.path.dirname(__file__), "../..", "azure.yaml")
|
|
PLUGINS_CONFIG_FILE = os.path.join(
|
|
os.path.dirname(__file__), "../..", "plugins_config.yaml"
|
|
)
|
|
GPT_4_MODEL = "gpt-4"
|
|
GPT_3_MODEL = "gpt-3.5-turbo"
|
|
|
|
|
|
class Config(SystemSettings):
|
|
name: str = "Auto-GPT configuration"
|
|
description: str = "Default configuration for the Auto-GPT application."
|
|
########################
|
|
# Application Settings #
|
|
########################
|
|
skip_news: bool = False
|
|
skip_reprompt: bool = False
|
|
authorise_key: str = "y"
|
|
exit_key: str = "n"
|
|
debug_mode: bool = False
|
|
plain_output: bool = False
|
|
chat_messages_enabled: bool = True
|
|
# TTS configuration
|
|
speak_mode: bool = False
|
|
text_to_speech_provider: str = "gtts"
|
|
streamelements_voice: str = "Brian"
|
|
elevenlabs_voice_id: Optional[str] = None
|
|
|
|
##########################
|
|
# Agent Control Settings #
|
|
##########################
|
|
# Paths
|
|
ai_settings_file: str = "ai_settings.yaml"
|
|
prompt_settings_file: str = "prompt_settings.yaml"
|
|
workspace_path: Optional[str] = None
|
|
file_logger_path: Optional[str] = None
|
|
# Model configuration
|
|
fast_llm: str = "gpt-3.5-turbo"
|
|
smart_llm: str = "gpt-4"
|
|
temperature: float = 0
|
|
openai_functions: bool = False
|
|
embedding_model: str = "text-embedding-ada-002"
|
|
browse_spacy_language_model: str = "en_core_web_sm"
|
|
# Run loop configuration
|
|
continuous_mode: bool = False
|
|
continuous_limit: int = 0
|
|
|
|
##########
|
|
# Memory #
|
|
##########
|
|
memory_backend: str = "json_file"
|
|
memory_index: str = "auto-gpt-memory"
|
|
redis_host: str = "localhost"
|
|
redis_port: int = 6379
|
|
redis_password: str = ""
|
|
wipe_redis_on_start: bool = True
|
|
|
|
############
|
|
# Commands #
|
|
############
|
|
# General
|
|
disabled_command_categories: list[str] = Field(default_factory=list)
|
|
# File ops
|
|
restrict_to_workspace: bool = True
|
|
allow_downloads: bool = False
|
|
# Shell commands
|
|
shell_command_control: str = "denylist"
|
|
execute_local_commands: bool = False
|
|
shell_denylist: list[str] = Field(default_factory=lambda: ["sudo", "su"])
|
|
shell_allowlist: list[str] = Field(default_factory=list)
|
|
# Text to image
|
|
image_provider: Optional[str] = None
|
|
huggingface_image_model: str = "CompVis/stable-diffusion-v1-4"
|
|
sd_webui_url: Optional[str] = "http://localhost:7860"
|
|
image_size: int = 256
|
|
# Audio to text
|
|
audio_to_text_provider: str = "huggingface"
|
|
huggingface_audio_to_text_model: Optional[str] = None
|
|
# Web browsing
|
|
selenium_web_browser: str = "chrome"
|
|
selenium_headless: bool = True
|
|
user_agent: str = "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_4) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/83.0.4103.97 Safari/537.36"
|
|
|
|
###################
|
|
# Plugin Settings #
|
|
###################
|
|
plugins_dir: str = "plugins"
|
|
plugins_config_file: str = PLUGINS_CONFIG_FILE
|
|
plugins_config: PluginsConfig = Field(
|
|
default_factory=lambda: PluginsConfig(plugins={})
|
|
)
|
|
plugins: list[str] = Field(default_factory=list)
|
|
plugins_allowlist: list[str] = Field(default_factory=list)
|
|
plugins_denylist: list[str] = Field(default_factory=list)
|
|
plugins_openai: list[str] = Field(default_factory=list)
|
|
|
|
###############
|
|
# Credentials #
|
|
###############
|
|
# OpenAI
|
|
openai_api_key: Optional[str] = None
|
|
openai_api_type: Optional[str] = None
|
|
openai_api_base: Optional[str] = None
|
|
openai_api_version: Optional[str] = None
|
|
openai_organization: Optional[str] = None
|
|
use_azure: bool = False
|
|
azure_config_file: Optional[str] = AZURE_CONFIG_FILE
|
|
azure_model_to_deployment_id_map: Optional[Dict[str, str]] = None
|
|
# Elevenlabs
|
|
elevenlabs_api_key: Optional[str] = None
|
|
# Github
|
|
github_api_key: Optional[str] = None
|
|
github_username: Optional[str] = None
|
|
# Google
|
|
google_api_key: Optional[str] = None
|
|
google_custom_search_engine_id: Optional[str] = None
|
|
# Huggingface
|
|
huggingface_api_token: Optional[str] = None
|
|
# Stable Diffusion
|
|
sd_webui_auth: Optional[str] = None
|
|
|
|
def get_azure_kwargs(self, model: str) -> dict[str, str]:
|
|
"""Get the kwargs for the Azure API."""
|
|
|
|
# Fix --gpt3only and --gpt4only in combination with Azure
|
|
fast_llm = (
|
|
self.fast_llm
|
|
if not (
|
|
self.fast_llm == self.smart_llm
|
|
and self.fast_llm.startswith(GPT_4_MODEL)
|
|
)
|
|
else f"not_{self.fast_llm}"
|
|
)
|
|
smart_llm = (
|
|
self.smart_llm
|
|
if not (
|
|
self.smart_llm == self.fast_llm
|
|
and self.smart_llm.startswith(GPT_3_MODEL)
|
|
)
|
|
else f"not_{self.smart_llm}"
|
|
)
|
|
|
|
deployment_id = {
|
|
fast_llm: self.azure_model_to_deployment_id_map.get(
|
|
"fast_llm_deployment_id",
|
|
self.azure_model_to_deployment_id_map.get(
|
|
"fast_llm_model_deployment_id" # backwards compatibility
|
|
),
|
|
),
|
|
smart_llm: self.azure_model_to_deployment_id_map.get(
|
|
"smart_llm_deployment_id",
|
|
self.azure_model_to_deployment_id_map.get(
|
|
"smart_llm_model_deployment_id" # backwards compatibility
|
|
),
|
|
),
|
|
self.embedding_model: self.azure_model_to_deployment_id_map.get(
|
|
"embedding_model_deployment_id"
|
|
),
|
|
}.get(model, None)
|
|
|
|
kwargs = {
|
|
"api_type": self.openai_api_type,
|
|
"api_base": self.openai_api_base,
|
|
"api_version": self.openai_api_version,
|
|
}
|
|
if model == self.embedding_model:
|
|
kwargs["engine"] = deployment_id
|
|
else:
|
|
kwargs["deployment_id"] = deployment_id
|
|
return kwargs
|
|
|
|
|
|
class ConfigBuilder(Configurable[Config]):
|
|
default_settings = Config()
|
|
|
|
@classmethod
|
|
def build_config_from_env(cls) -> Config:
|
|
"""Initialize the Config class"""
|
|
config_dict = {
|
|
"authorise_key": os.getenv("AUTHORISE_COMMAND_KEY"),
|
|
"exit_key": os.getenv("EXIT_KEY"),
|
|
"plain_output": os.getenv("PLAIN_OUTPUT", "False") == "True",
|
|
"shell_command_control": os.getenv("SHELL_COMMAND_CONTROL"),
|
|
"ai_settings_file": os.getenv("AI_SETTINGS_FILE"),
|
|
"prompt_settings_file": os.getenv("PROMPT_SETTINGS_FILE"),
|
|
"fast_llm": os.getenv("FAST_LLM", os.getenv("FAST_LLM_MODEL")),
|
|
"smart_llm": os.getenv("SMART_LLM", os.getenv("SMART_LLM_MODEL")),
|
|
"embedding_model": os.getenv("EMBEDDING_MODEL"),
|
|
"browse_spacy_language_model": os.getenv("BROWSE_SPACY_LANGUAGE_MODEL"),
|
|
"openai_api_key": os.getenv("OPENAI_API_KEY"),
|
|
"use_azure": os.getenv("USE_AZURE") == "True",
|
|
"azure_config_file": os.getenv("AZURE_CONFIG_FILE", AZURE_CONFIG_FILE),
|
|
"execute_local_commands": os.getenv("EXECUTE_LOCAL_COMMANDS", "False")
|
|
== "True",
|
|
"restrict_to_workspace": os.getenv("RESTRICT_TO_WORKSPACE", "True")
|
|
== "True",
|
|
"openai_functions": os.getenv("OPENAI_FUNCTIONS", "False") == "True",
|
|
"elevenlabs_api_key": os.getenv("ELEVENLABS_API_KEY"),
|
|
"streamelements_voice": os.getenv("STREAMELEMENTS_VOICE"),
|
|
"text_to_speech_provider": os.getenv("TEXT_TO_SPEECH_PROVIDER"),
|
|
"github_api_key": os.getenv("GITHUB_API_KEY"),
|
|
"github_username": os.getenv("GITHUB_USERNAME"),
|
|
"google_api_key": os.getenv("GOOGLE_API_KEY"),
|
|
"image_provider": os.getenv("IMAGE_PROVIDER"),
|
|
"huggingface_api_token": os.getenv("HUGGINGFACE_API_TOKEN"),
|
|
"huggingface_image_model": os.getenv("HUGGINGFACE_IMAGE_MODEL"),
|
|
"audio_to_text_provider": os.getenv("AUDIO_TO_TEXT_PROVIDER"),
|
|
"huggingface_audio_to_text_model": os.getenv(
|
|
"HUGGINGFACE_AUDIO_TO_TEXT_MODEL"
|
|
),
|
|
"sd_webui_url": os.getenv("SD_WEBUI_URL"),
|
|
"sd_webui_auth": os.getenv("SD_WEBUI_AUTH"),
|
|
"selenium_web_browser": os.getenv("USE_WEB_BROWSER"),
|
|
"selenium_headless": os.getenv("HEADLESS_BROWSER", "True") == "True",
|
|
"user_agent": os.getenv("USER_AGENT"),
|
|
"memory_backend": os.getenv("MEMORY_BACKEND"),
|
|
"memory_index": os.getenv("MEMORY_INDEX"),
|
|
"redis_host": os.getenv("REDIS_HOST"),
|
|
"redis_password": os.getenv("REDIS_PASSWORD"),
|
|
"wipe_redis_on_start": os.getenv("WIPE_REDIS_ON_START", "True") == "True",
|
|
"plugins_dir": os.getenv("PLUGINS_DIR"),
|
|
"plugins_config_file": os.getenv("PLUGINS_CONFIG_FILE"),
|
|
"chat_messages_enabled": os.getenv("CHAT_MESSAGES_ENABLED") == "True",
|
|
}
|
|
|
|
config_dict["disabled_command_categories"] = _safe_split(
|
|
os.getenv("DISABLED_COMMAND_CATEGORIES")
|
|
)
|
|
|
|
config_dict["shell_denylist"] = _safe_split(
|
|
os.getenv("SHELL_DENYLIST", os.getenv("DENY_COMMANDS"))
|
|
)
|
|
config_dict["shell_allowlist"] = _safe_split(
|
|
os.getenv("SHELL_ALLOWLIST", os.getenv("ALLOW_COMMANDS"))
|
|
)
|
|
|
|
config_dict["google_custom_search_engine_id"] = os.getenv(
|
|
"GOOGLE_CUSTOM_SEARCH_ENGINE_ID", os.getenv("CUSTOM_SEARCH_ENGINE_ID")
|
|
)
|
|
|
|
config_dict["elevenlabs_voice_id"] = os.getenv(
|
|
"ELEVENLABS_VOICE_ID", os.getenv("ELEVENLABS_VOICE_1_ID")
|
|
)
|
|
elevenlabs_api_key = os.getenv("ELEVENLABS_API_KEY")
|
|
if os.getenv("USE_MAC_OS_TTS"):
|
|
default_tts_provider = "macos"
|
|
elif elevenlabs_api_key:
|
|
default_tts_provider = "elevenlabs"
|
|
elif os.getenv("USE_BRIAN_TTS"):
|
|
default_tts_provider = "streamelements"
|
|
else:
|
|
default_tts_provider = "gtts"
|
|
config_dict["text_to_speech_provider"] = default_tts_provider
|
|
|
|
config_dict["plugins_allowlist"] = _safe_split(os.getenv("ALLOWLISTED_PLUGINS"))
|
|
config_dict["plugins_denylist"] = _safe_split(os.getenv("DENYLISTED_PLUGINS"))
|
|
config_dict["plugins_config"] = PluginsConfig.load_config(
|
|
config_dict["plugins_config_file"],
|
|
config_dict["plugins_denylist"],
|
|
config_dict["plugins_allowlist"],
|
|
)
|
|
|
|
with contextlib.suppress(TypeError):
|
|
config_dict["image_size"] = int(os.getenv("IMAGE_SIZE"))
|
|
with contextlib.suppress(TypeError):
|
|
config_dict["redis_port"] = int(os.getenv("REDIS_PORT"))
|
|
with contextlib.suppress(TypeError):
|
|
config_dict["temperature"] = float(os.getenv("TEMPERATURE"))
|
|
|
|
if config_dict["use_azure"]:
|
|
azure_config = cls.load_azure_config(config_dict["azure_config_file"])
|
|
config_dict.update(azure_config)
|
|
|
|
elif os.getenv("OPENAI_API_BASE_URL"):
|
|
config_dict["openai_api_base"] = os.getenv("OPENAI_API_BASE_URL")
|
|
|
|
openai_organization = os.getenv("OPENAI_ORGANIZATION")
|
|
if openai_organization is not None:
|
|
config_dict["openai_organization"] = openai_organization
|
|
|
|
config_dict_without_none_values = {
|
|
k: v for k, v in config_dict.items() if v is not None
|
|
}
|
|
|
|
return cls.build_agent_configuration(config_dict_without_none_values)
|
|
|
|
@classmethod
|
|
def load_azure_config(cls, config_file: str = AZURE_CONFIG_FILE) -> Dict[str, str]:
|
|
"""
|
|
Loads the configuration parameters for Azure hosting from the specified file
|
|
path as a yaml file.
|
|
|
|
Parameters:
|
|
config_file(str): The path to the config yaml file. DEFAULT: "../azure.yaml"
|
|
|
|
Returns:
|
|
Dict
|
|
"""
|
|
with open(config_file) as file:
|
|
config_params = yaml.load(file, Loader=yaml.FullLoader) or {}
|
|
|
|
return {
|
|
"openai_api_type": config_params.get("azure_api_type", "azure"),
|
|
"openai_api_base": config_params.get("azure_api_base", ""),
|
|
"openai_api_version": config_params.get(
|
|
"azure_api_version", "2023-03-15-preview"
|
|
),
|
|
"azure_model_to_deployment_id_map": config_params.get(
|
|
"azure_model_map", {}
|
|
),
|
|
}
|
|
|
|
|
|
def check_openai_api_key(config: Config) -> None:
|
|
"""Check if the OpenAI API key is set in config.py or as an environment variable."""
|
|
if not config.openai_api_key:
|
|
print(
|
|
Fore.RED
|
|
+ "Please set your OpenAI API key in .env or as an environment variable."
|
|
+ Fore.RESET
|
|
)
|
|
print("You can get your key from https://platform.openai.com/account/api-keys")
|
|
openai_api_key = input(
|
|
"If you do have the key, please enter your OpenAI API key now:\n"
|
|
)
|
|
key_pattern = r"^sk-\w{48}"
|
|
openai_api_key = openai_api_key.strip()
|
|
if re.search(key_pattern, openai_api_key):
|
|
os.environ["OPENAI_API_KEY"] = openai_api_key
|
|
config.openai_api_key = openai_api_key
|
|
print(
|
|
Fore.GREEN
|
|
+ "OpenAI API key successfully set!\n"
|
|
+ Fore.ORANGE
|
|
+ "NOTE: The API key you've set is only temporary.\n"
|
|
+ "For longer sessions, please set it in .env file"
|
|
+ Fore.RESET
|
|
)
|
|
else:
|
|
print("Invalid OpenAI API key!")
|
|
exit(1)
|
|
|
|
|
|
def _safe_split(s: Union[str, None], sep: str = ",") -> list[str]:
|
|
"""Split a string by a separator. Return an empty list if the string is None."""
|
|
if s is None:
|
|
return []
|
|
return s.split(sep)
|