Use a tool node to call a tool in your agentic workflow.To configure a tool node, use the tool() method in your agentic workflow. In this method, define the following parameters:
Tool nodes support four tool types: OpenAPI, Python, Flow, and MCP. The Flow runtime executes these callbacks using a fire-and-forget pattern for optimal performance.
RecommendationFor Flow callbacks, use OpenAPI tools as the preferred callback mechanism. OpenAPI tools provide a clean, stateless callback interface without the complexity of managing user interactions or correlation ID propagation.
Limitation: Flow Tools as CallbacksWhen using a Flow as a callback tool within another Flow, there is a current limitation:
Restriction: Flow callback tools must not contain user activity nodes (nodes that require user interaction or input).
Reason: If a Flow callback contains user activity nodes, the Flow runtime would need to submit user activity events to the user’s chat thread. This requires propagating correlation IDs through the Flow callback event chain, which adds significant complexity to the implementation.
Workaround: To keep the implementation simple and maintainable, Flows used as callback tools should be designed without user interaction requirements.
The following example shows how to configure a tool node in an agentic workflow:
Python
'''Build a simple flow that will sequence call an agent and a tool.'''from pydantic import BaseModel, Fieldfrom ibm_watsonx_orchestrate.flow_builder.flows import Flow, flowfrom ibm_watsonx_orchestrate.flow_builder.flows.constants import END, STARTfrom .send_emails import send_emailsclass FlowInput(BaseModel): question: str = Field(description="A topic to search for about IBM") emails: str = Field(description="a list of comman separated email address")class FlowOutput(BaseModel): question: str = Field(description="A topic to search for about IBM") answer: str = Field(description="A fact about IBM") emails: str = Field(description="The email addresse the we sent. comma separated.")class IBMAgentInput(BaseModel): question: str = Field(description="A topic to search for")class IBMAgentOutput(BaseModel): answer: str = Field(description="A fact about IBM")class EmailAgentInput(BaseModel): emails: str = Field(description="Comma separated list of email addresses") question: str = Field(description="A topic to search for about IBM") answer: str = Field(description="The email content")class EmailAgentOutput(BaseModel): message: str = Field(description="The message we sent.")@flow( name="ibm_knowledge_to_emails", description="This flow will send a random fact about IBM to a group of people", input_schema=FlowInput, output_schema=FlowOutput)def build_ibm_knowledge_to_emails(aflow: Flow) -> Flow: """ Retrieve a random fact about IBM and send it out to an email list. """ # when talking to an agent, we need to be very precise on what we want to get done. # or there is a chance the agent will not be able to response correctly. # In the message, you should refer to information that the Flow engine will send # to the agent. ask_agent_for_ibm_knowledge = aflow.agent( name="ask_agent_for_ibm_knowledge", agent="ibm_agent", description="Ask the IBM agent to get a fact based on the provided question.", message="Give an answer about IBM based on the provided question. If you don't know the answer, just say 'I do not know'", input_schema=IBMAgentInput, output_schema=IBMAgentOutput, ) send_emails_node = aflow.tool(send_emails) aflow.sequence(START, ask_agent_for_ibm_knowledge, send_emails_node, END) return aflow