mirror of
https://github.com/crewAIInc/crewAI.git
synced 2026-01-11 09:08:31 +00:00
* better spacing * works with llama index * works on langchain custom just need delegation to work * cleanup for custom_agent class * works with different argument expectations for agent_executor * cleanup for hierarchial process, better agent_executor args handler and added to the crew agent doc page * removed code examples for langchain + llama index, added to docs instead * added key output if return is not a str for and added some tests * added hinting for CustomAgent class * removed pass as it was not needed * closer just need to figuire ou agentTools * running agents - llamaindex and langchain with base agent * some cleanup on baseAgent * minimum for agent to run for base class and ensure it works with hierarchical process * cleanup for original agent to take on BaseAgent class * Agent takes on langchainagent and cleanup across * token handling working for usage_metrics to continue working * installed llama-index, updated docs and added better name * fixed some type errors * base agent holds token_process * heirarchail process uses proper tools and no longer relies on hasattr for token_processes * removal of test_custom_agent_executions * this fixes copying agents * leveraging an executor class for trigger llamaindex agent * llama index now has ask_human * executor mixins added * added output converter base class * type listed * cleanup for output conversions and tokenprocess eliminated redundancy * properly handling tokens * simplified token calc handling * original agent with base agent builder structure setup * better docs * no more llama-index dep * cleaner docs * test fixes * poetry reverts and better docs * base_agent_tools set for third party agents * updated task and test fix
82 lines
3.2 KiB
Python
82 lines
3.2 KiB
Python
from abc import ABC, abstractmethod
|
|
from typing import List, Optional, Union
|
|
from pydantic import BaseModel, Field
|
|
from crewai.agents.agent_builder.base_agent import BaseAgent
|
|
from crewai.task import Task
|
|
from crewai.utilities import I18N
|
|
|
|
|
|
class BaseAgentTools(BaseModel, ABC):
|
|
"""Default tools around agent delegation"""
|
|
|
|
agents: List[BaseAgent] = Field(description="List of agents in this crew.")
|
|
i18n: I18N = Field(default=I18N(), description="Internationalization settings.")
|
|
|
|
@abstractmethod
|
|
def tools(self):
|
|
pass
|
|
|
|
def _get_coworker(self, coworker: Optional[str], **kwargs) -> Optional[str]:
|
|
coworker = coworker or kwargs.get("co_worker") or kwargs.get("coworker")
|
|
if coworker:
|
|
is_list = coworker.startswith("[") and coworker.endswith("]")
|
|
if is_list:
|
|
coworker = coworker[1:-1].split(",")[0]
|
|
return coworker
|
|
|
|
def delegate_work(
|
|
self, task: str, context: str, coworker: Optional[str] = None, **kwargs
|
|
):
|
|
"""Useful to delegate a specific task to a coworker passing all necessary context and names."""
|
|
coworker = self._get_coworker(coworker, **kwargs)
|
|
return self._execute(coworker, task, context)
|
|
|
|
def ask_question(
|
|
self, question: str, context: str, coworker: Optional[str] = None, **kwargs
|
|
):
|
|
"""Useful to ask a question, opinion or take from a coworker passing all necessary context and names."""
|
|
coworker = self._get_coworker(coworker, **kwargs)
|
|
return self._execute(coworker, question, context)
|
|
|
|
def _execute(self, agent: Union[str, None], task: str, context: Union[str, None]):
|
|
"""Execute the command."""
|
|
try:
|
|
if agent is None:
|
|
agent = ""
|
|
|
|
# It is important to remove the quotes from the agent name.
|
|
# The reason we have to do this is because less-powerful LLM's
|
|
# have difficulty producing valid JSON.
|
|
# As a result, we end up with invalid JSON that is truncated like this:
|
|
# {"task": "....", "coworker": "....
|
|
# when it should look like this:
|
|
# {"task": "....", "coworker": "...."}
|
|
agent_name = agent.casefold().replace('"', "").replace("\n", "")
|
|
|
|
agent = [
|
|
available_agent
|
|
for available_agent in self.agents
|
|
if available_agent.role.casefold().replace("\n", "") == agent_name
|
|
]
|
|
except Exception as _:
|
|
return self.i18n.errors("agent_tool_unexsiting_coworker").format(
|
|
coworkers="\n".join(
|
|
[f"- {agent.role.casefold()}" for agent in self.agents]
|
|
)
|
|
)
|
|
|
|
if not agent:
|
|
return self.i18n.errors("agent_tool_unexsiting_coworker").format(
|
|
coworkers="\n".join(
|
|
[f"- {agent.role.casefold()}" for agent in self.agents]
|
|
)
|
|
)
|
|
|
|
agent = agent[0]
|
|
task = Task(
|
|
description=task,
|
|
agent=agent,
|
|
expected_output="Your best answer to your coworker asking you this, accounting for the context shared.",
|
|
)
|
|
return agent.execute_task(task, context)
|