mirror of
https://github.com/aljazceru/Auto-GPT.git
synced 2026-01-31 11:54:30 +01:00
* Feature/tighten up ci pipeline (#3700) * Fix docker volume mounts (#3710) Co-authored-by: Reinier van der Leer <github@pwuts.nl> Co-authored-by: Nicholas Tindle <nick@ntindle.com> * Feature/enable intuitive logs for community challenge step 1 (#3695) * Feature/enable intuitive logs summarization (#3697) * Move task_complete command out of prompt (#3663) * feat: move task_complete command out of prompt * fix: formatting fixes * Add the shutdown command to the test agents * tests: update test vcrs --------- Co-authored-by: James Collins <collijk@uw.edu> * Allow users to Disable Commands via the .env (#3667) * Document Disabling command categories (#3669) * feat: move task_complete command out of prompt * fix: formatting fixes * feat: add command disabling * docs: document how to disable command categories * Enable denylist handling for plugins (#3688) Co-authored-by: Luke Kyohere <lkyohere@mfsafrica.com> Co-authored-by: Nicholas Tindle <nick@ntindle.com> * Fix call to `plugin.post_planning` (#3414) Co-authored-by: Nicholas Tindle <nick@ntindle.com> * create information retrieval challenge a (#3770) Co-authored-by: Richard Beales <rich@richbeales.net> * fix typos (#3798) * Update run.bat (#3783) Co-authored-by: Richard Beales <rich@richbeales.net> * Update run.sh (#3752) Co-authored-by: Richard Beales <rich@richbeales.net> * ADD: Bash block in the contributing markdown (#3701) Co-authored-by: Richard Beales <rich@richbeales.net> * BUGFIX: Selenium Driver object reference was included in the browsing results for some reason (#3642) * * there is really no need to return the reference to the Selenium driver along with the text summary and list of links. * * removing unused second return value from browse_website() * * updated cassette * * updated YAML cassette for test_browse_website * * after requirements reinstall, another update YAML cassette for test_browse_website * * another update YAML cassette for test_browse_website, only as a placholder commit to trigger re-testing due to some docker TCP timeout issue * * another update YAML cassette for test_browse_website --------- Co-authored-by: batyu <batyu@localhost> * Update CONTRIBUTING.md * Self feedback Improvement (#3680) * Improved `Self-Feedback` * minor tweak * Test: Updated `test_get_self_feedback.py` * community challenges in the wiki (#3764) * Update README.md * Update PULL_REQUEST_TEMPLATE.md Added link to wiki Contributing page * Add link to wiki Contributing page * fix * Add link to wiki page on Contributing * Implement Logging of User Input in logs/Debug Folder (#3867) * Adds USER_INPUT_FILE_NAME * Update agent.py * Update agent.py Log only if console_input is not the authorise_key * Reformatting * add information retrieval challenge to the wiki (#3876) * add code owners policy (#3981) * add code owners * added @ to codeowners * switched to team ownership * Memory Challenge C (#3908) * Memory Challenge C * Working cassettes * Doc fixes * Linting and doc fix * Updated cassette * One more cassette try --------- Co-authored-by: merwanehamadi <merwanehamadi@gmail.com> * memory challenge c inconsistent (#3985) * Improve & fix memory challenge docs. (#3989) Co-authored-by: Kaan Osmanagaoglu <kaano@questps.com.au> * Feature/centralize prompt (#3990) Co-authored-by: xiao.hu <454292663@qq.com> * Use correct reference to prompt_generator in autogpt/llm/chat.py (#4011) * fix typos (#3998) Co-authored-by: Minfeng Lu <minfenglu@Minfengs-MacBook-Pro.local> Co-authored-by: Richard Beales <rich@richbeales.net> * fix typo in the getting started docs (#3997) Co-authored-by: Richard Beales <rich@richbeales.net> * Fix path to workspace directory in setup guide (#3927) Co-authored-by: Nicholas Tindle <nick@ntindle.com> * document that docker-compose 1.29.0 is minimally required (#3963) Co-authored-by: Nicholas Tindle <nick@ntindle.com> * Integrate pytest-xdist Plugin for Parallel and Concurrent Testing (#3870) * Adds pytest-parallel dependencies * Implement pytest-parallel for faster tests * Uses pytest-xdist * Auto number of workers processes * Update ci.yml --------- Co-authored-by: Nicholas Tindle <nick@ntindle.com> * explain temperature setting in env file (#4140) Co-authored-by: Richard Beales <rich@richbeales.net> * Catch JSON error in summary_memory.py (#3996) Co-authored-by: k-boikov <64261260+k-boikov@users.noreply.github.com> * Update duckduckgo dependency - min should be 2.9.5 (#4142) Co-authored-by: k-boikov <64261260+k-boikov@users.noreply.github.com> * Update Dockerfile - add missing scripts and plugins directories. (#3706) Co-authored-by: k-boikov <64261260+k-boikov@users.noreply.github.com> * Updated memory setup links (#3829) Co-authored-by: k-boikov <64261260+k-boikov@users.noreply.github.com> * Parse package versions so upgrades can be forced (#4149) * parse package versions so upgrades can be forced * better version from @collijk * fix typo in autopgt/agent/agent.py (#3747) Co-authored-by: merwanehamadi <merwanehamadi@gmail.com> Co-authored-by: Richard Beales <rich@richbeales.net> Co-authored-by: k-boikov <64261260+k-boikov@users.noreply.github.com> * Fix `milvus_memory_test.py` mock `Config` (#3424) Co-authored-by: k-boikov <64261260+k-boikov@users.noreply.github.com> * Implemented showing the number of preauthorised commands left. #1035 (#3322) Co-authored-by: mayubi <marwand@ayubi-it.de> Co-authored-by: Nicholas Tindle <nick@ntindle.com> Co-authored-by: k-boikov <64261260+k-boikov@users.noreply.github.com> * Challenge: Kubernetes and documentation (#4121) * challenge_kubes_and_readme * docs * testing * black and isort * revision * lint * comments * blackisort * docs * docs * deleting_cassette * suggestions * misspelling_errors --------- Co-authored-by: merwanehamadi <merwanehamadi@gmail.com> * Make sdwebui tests pass (when SD is running) (#3721) Co-authored-by: Nicholas Tindle <nick@ntindle.com> * Add Edge browser support using EdgeChromiumDriverManager (#3058) Co-authored-by: Nicholas Tindle <nick@ntindle.com> Co-authored-by: k-boikov <64261260+k-boikov@users.noreply.github.com> * Added --install-plugin-deps to Docker (#4151) Co-authored-by: Nicholas Tindle <nick@ntindle.com> * Feature/basic proxy (#4164) * basic proxy (#54) * basic proxy (#55) * basic proxy * basic proxy * basic proxy * basic proxy * add back double quotes * add more specific files * write file * basic proxy * Put back double quotes * test new CI (#4168) * test new CI * test new CI * remove double quotes * Feature/test new ci pipeline 2 (#4169) * test new CI * remove double quotes * make it a variable * make it a variable * Test New CI Pipeline (#4170) * introduce dummy prompt change * introduce dummy prompt change * empty commit * empty commit * empty commit * push to origin repo * add s to quote * Feature/fix rate limiting issue Step 1 (#4173) * temporarilly remove 3.11 * add back 3.11 (#4185) * Revert "Put back 3.11 until it's removed as a requirement" (#4191) --------- Co-authored-by: Reinier van der Leer <github@pwuts.nl> Co-authored-by: merwanehamadi <merwanehamadi@gmail.com> Co-authored-by: Peter Petermann <ppetermann80@googlemail.com> Co-authored-by: Nicholas Tindle <nick@ntindle.com> Co-authored-by: James Collins <collijk@uw.edu> Co-authored-by: Luke K <2609441+pr-0f3t@users.noreply.github.com> Co-authored-by: Luke Kyohere <lkyohere@mfsafrica.com> Co-authored-by: Robin Richtsfeld <robin.richtsfeld@gmail.com> Co-authored-by: RainRat <rainrat78@yahoo.ca> Co-authored-by: itsmarble <130370814+itsmarble@users.noreply.github.com> Co-authored-by: Ambuj Pawar <pawar.ambuj@gmail.com> Co-authored-by: bszollosinagy <4211175+bszollosinagy@users.noreply.github.com> Co-authored-by: batyu <batyu@localhost> Co-authored-by: Pi <sunfish7@gmail.com> Co-authored-by: AbTrax <45964236+AbTrax@users.noreply.github.com> Co-authored-by: Andres Caicedo <73312784+AndresCdo@users.noreply.github.com> Co-authored-by: Douglas Schonholtz <15002691+dschonholtz@users.noreply.github.com> Co-authored-by: Kaan <kaanixir@gmail.com> Co-authored-by: Kaan Osmanagaoglu <kaano@questps.com.au> Co-authored-by: xiao.hu <454292663@qq.com> Co-authored-by: Tomasz Kasperczyk <tomaszikasperczyk@gmail.com> Co-authored-by: minfeng-ai <42948406+minfenglu@users.noreply.github.com> Co-authored-by: Minfeng Lu <minfenglu@Minfengs-MacBook-Pro.local> Co-authored-by: Shlomi <81581678+jit-shlomi@users.noreply.github.com> Co-authored-by: Itai Steinherz <itaisteinherz@gmail.com> Co-authored-by: Boostrix <119627414+Boostrix@users.noreply.github.com> Co-authored-by: Kristian Jackson <kristian.jackson@gmail.com> Co-authored-by: k-boikov <64261260+k-boikov@users.noreply.github.com> Co-authored-by: Eduardo Salinas <edus@microsoft.com> Co-authored-by: prom3theu5 <dave@simcube.co.uk> Co-authored-by: dominic-ks <contact@bedevious.co.uk> Co-authored-by: andrey13771 <51243350+andrey13771@users.noreply.github.com> Co-authored-by: Marwand Ayubi <98717667+xhypeDE@users.noreply.github.com> Co-authored-by: mayubi <marwand@ayubi-it.de> Co-authored-by: Media <12145726+rihp@users.noreply.github.com> Co-authored-by: Cenny <cwenner@gmail.com> Co-authored-by: Abdelkarim Habouch <37211852+karimhabush@users.noreply.github.com>
208 lines
6.2 KiB
Python
208 lines
6.2 KiB
Python
"""Set up the AI and its goals"""
|
|
import re
|
|
|
|
from colorama import Fore, Style
|
|
from jinja2 import Template
|
|
|
|
from autogpt import utils
|
|
from autogpt.config import Config
|
|
from autogpt.config.ai_config import AIConfig
|
|
from autogpt.llm import create_chat_completion
|
|
from autogpt.logs import logger
|
|
from autogpt.prompts.default_prompts import (
|
|
DEFAULT_SYSTEM_PROMPT_AICONFIG_AUTOMATIC,
|
|
DEFAULT_TASK_PROMPT_AICONFIG_AUTOMATIC,
|
|
DEFAULT_USER_DESIRE_PROMPT,
|
|
)
|
|
|
|
CFG = Config()
|
|
|
|
|
|
def prompt_user() -> AIConfig:
|
|
"""Prompt the user for input
|
|
|
|
Returns:
|
|
AIConfig: The AIConfig object tailored to the user's input
|
|
"""
|
|
ai_name = ""
|
|
ai_config = None
|
|
|
|
# Construct the prompt
|
|
logger.typewriter_log(
|
|
"Welcome to Auto-GPT! ",
|
|
Fore.GREEN,
|
|
"run with '--help' for more information.",
|
|
speak_text=True,
|
|
)
|
|
|
|
# Get user desire
|
|
logger.typewriter_log(
|
|
"Create an AI-Assistant:",
|
|
Fore.GREEN,
|
|
"input '--manual' to enter manual mode.",
|
|
speak_text=True,
|
|
)
|
|
|
|
user_desire = utils.clean_input(
|
|
f"{Fore.LIGHTBLUE_EX}I want Auto-GPT to{Style.RESET_ALL}: "
|
|
)
|
|
|
|
if user_desire == "":
|
|
user_desire = DEFAULT_USER_DESIRE_PROMPT # Default prompt
|
|
|
|
# If user desire contains "--manual"
|
|
if "--manual" in user_desire:
|
|
logger.typewriter_log(
|
|
"Manual Mode Selected",
|
|
Fore.GREEN,
|
|
speak_text=True,
|
|
)
|
|
return generate_aiconfig_manual()
|
|
|
|
else:
|
|
try:
|
|
return generate_aiconfig_automatic(user_desire)
|
|
except Exception as e:
|
|
logger.typewriter_log(
|
|
"Unable to automatically generate AI Config based on user desire.",
|
|
Fore.RED,
|
|
"Falling back to manual mode.",
|
|
speak_text=True,
|
|
)
|
|
|
|
return generate_aiconfig_manual()
|
|
|
|
|
|
def generate_aiconfig_manual() -> AIConfig:
|
|
"""
|
|
Interactively create an AI configuration by prompting the user to provide the name, role, and goals of the AI.
|
|
|
|
This function guides the user through a series of prompts to collect the necessary information to create
|
|
an AIConfig object. The user will be asked to provide a name and role for the AI, as well as up to five
|
|
goals. If the user does not provide a value for any of the fields, default values will be used.
|
|
|
|
Returns:
|
|
AIConfig: An AIConfig object containing the user-defined or default AI name, role, and goals.
|
|
"""
|
|
|
|
# Manual Setup Intro
|
|
logger.typewriter_log(
|
|
"Create an AI-Assistant:",
|
|
Fore.GREEN,
|
|
"Enter the name of your AI and its role below. Entering nothing will load"
|
|
" defaults.",
|
|
speak_text=True,
|
|
)
|
|
|
|
# Get AI Name from User
|
|
logger.typewriter_log(
|
|
"Name your AI: ", Fore.GREEN, "For example, 'Entrepreneur-GPT'"
|
|
)
|
|
ai_name = utils.clean_input("AI Name: ")
|
|
if ai_name == "":
|
|
ai_name = "Entrepreneur-GPT"
|
|
|
|
logger.typewriter_log(
|
|
f"{ai_name} here!", Fore.LIGHTBLUE_EX, "I am at your service.", speak_text=True
|
|
)
|
|
|
|
# Get AI Role from User
|
|
logger.typewriter_log(
|
|
"Describe your AI's role: ",
|
|
Fore.GREEN,
|
|
"For example, 'an AI designed to autonomously develop and run businesses with"
|
|
" the sole goal of increasing your net worth.'",
|
|
)
|
|
ai_role = utils.clean_input(f"{ai_name} is: ")
|
|
if ai_role == "":
|
|
ai_role = "an AI designed to autonomously develop and run businesses with the"
|
|
" sole goal of increasing your net worth."
|
|
|
|
# Enter up to 5 goals for the AI
|
|
logger.typewriter_log(
|
|
"Enter up to 5 goals for your AI: ",
|
|
Fore.GREEN,
|
|
"For example: \nIncrease net worth, Grow Twitter Account, Develop and manage"
|
|
" multiple businesses autonomously'",
|
|
)
|
|
logger.info("Enter nothing to load defaults, enter nothing when finished.")
|
|
ai_goals = []
|
|
for i in range(5):
|
|
ai_goal = utils.clean_input(f"{Fore.LIGHTBLUE_EX}Goal{Style.RESET_ALL} {i+1}: ")
|
|
if ai_goal == "":
|
|
break
|
|
ai_goals.append(ai_goal)
|
|
if not ai_goals:
|
|
ai_goals = [
|
|
"Increase net worth",
|
|
"Grow Twitter Account",
|
|
"Develop and manage multiple businesses autonomously",
|
|
]
|
|
|
|
# Get API Budget from User
|
|
logger.typewriter_log(
|
|
"Enter your budget for API calls: ",
|
|
Fore.GREEN,
|
|
"For example: $1.50",
|
|
)
|
|
logger.info("Enter nothing to let the AI run without monetary limit")
|
|
api_budget_input = utils.clean_input(
|
|
f"{Fore.LIGHTBLUE_EX}Budget{Style.RESET_ALL}: $"
|
|
)
|
|
if api_budget_input == "":
|
|
api_budget = 0.0
|
|
else:
|
|
try:
|
|
api_budget = float(api_budget_input.replace("$", ""))
|
|
except ValueError:
|
|
logger.typewriter_log(
|
|
"Invalid budget input. Setting budget to unlimited.", Fore.RED
|
|
)
|
|
api_budget = 0.0
|
|
|
|
return AIConfig(ai_name, ai_role, ai_goals, api_budget)
|
|
|
|
|
|
def generate_aiconfig_automatic(user_prompt) -> AIConfig:
|
|
"""Generates an AIConfig object from the given string.
|
|
|
|
Returns:
|
|
AIConfig: The AIConfig object tailored to the user's input
|
|
"""
|
|
|
|
system_prompt = DEFAULT_SYSTEM_PROMPT_AICONFIG_AUTOMATIC
|
|
prompt_ai_config_automatic = Template(
|
|
DEFAULT_TASK_PROMPT_AICONFIG_AUTOMATIC
|
|
).render(user_prompt=user_prompt)
|
|
# Call LLM with the string as user input
|
|
messages = [
|
|
{
|
|
"role": "system",
|
|
"content": system_prompt,
|
|
},
|
|
{
|
|
"role": "user",
|
|
"content": prompt_ai_config_automatic,
|
|
},
|
|
]
|
|
output = create_chat_completion(messages, CFG.fast_llm_model)
|
|
|
|
# Debug LLM Output
|
|
logger.debug(f"AI Config Generator Raw Output: {output}")
|
|
|
|
# Parse the output
|
|
ai_name = re.search(r"Name(?:\s*):(?:\s*)(.*)", output, re.IGNORECASE).group(1)
|
|
ai_role = (
|
|
re.search(
|
|
r"Description(?:\s*):(?:\s*)(.*?)(?:(?:\n)|Goals)",
|
|
output,
|
|
re.IGNORECASE | re.DOTALL,
|
|
)
|
|
.group(1)
|
|
.strip()
|
|
)
|
|
ai_goals = re.findall(r"(?<=\n)-\s*(.*)", output)
|
|
api_budget = 0.0 # TODO: parse api budget using a regular expression
|
|
|
|
return AIConfig(ai_name, ai_role, ai_goals, api_budget)
|