Skip to main content

Workers

Introduction

Workers serve as the fundamental building block of the Agent First Organization framework and responsible for the "execution" of the tasks and its subtasks. Unlike some frameworks which differentiates between workers and tools, Agent First Organization combines both into an Worker component. Responsible for the execution and managed by the orchestrator, each Worker are designed to convert instructions into results. Although structured, Workers can be designed to do high level complicated tasks and can call other workers itself, greatly enhancing its ability to address.

Implementation

Technical Details

Each Worker represent a group of GraphNodes on a LangGraph and can be subgraphed.

BaseWorker is the parent class of all workers is the BaseWorker and consists of a description attribute and execute() abstract method. Each node consists of a chain of relevants Workers by the orchestrator on execution which the on execution, processes the MessageState input into an MessageState output.

Attributes

Description

description is a string that describes the task that the BaseWorker is meant to handle. This is used by the Generator to assign the right task for the worker when generating the TaskGraph.

Some examples:

  • "The worker that used to deliver the message to the user, either a question or provide some information." (MessageWorker)
  • ""Answer the user's questions based on the company's internal documentations (unstructured text data), such as the policies, FAQs, and product information" (RAGWorker)

Execute

execute() takes in MessageState and returns an invoke'd LangChain StateGraph. This is crucial to connect various Workers (through LangChain subgraph behavior) and is called by the Orchestrator during runtime.

An example:

def execute(self, msg_state: MessageState):
graph = self.action_graph.compile()
result = graph.invoke(msg_state)
return result

Code

class BaseWorker(ABC):

description = None

def __str__(self):
return f"{self.__class__.__name__}"

def __repr__(self):
return f"{self.__class__.__name__}"

@abstractmethod
def execute(self, msg_state: MessageState):
pass