AIAgentNodeBase

abstract class AIAgentNodeBase<in TInput, TOutput>(source)

Represents an abstract node in an AI agent strategy graph, responsible for executing a specific operation and managing directed edges to other nodes.

Type Parameters

TInput

The type of input data this node processes.

TOutput

The type of output data this node produces.

Inheritors

Types

Link copied to clipboard
data class ResolvedEdge(val edge: AIAgentEdge<*, *>, val output: Any?)

Represents a resolved edge in the context of an AI agent strategy graph, combining an edge and its corresponding resolved output.

Properties

Link copied to clipboard

The directed edges connecting this node to other nodes in the AI agent strategy graph. Each edge defines the flow and optional transformation of output data from this node to another.

Link copied to clipboard
val id: String

Represents the unique identifier of the AI agent node.

Link copied to clipboard
abstract val inputType: TypeToken

The TypeToken of the TInput

Link copied to clipboard
abstract val name: String

The name of the AI agent node. This property serves as a unique identifier for the node within the strategy graph and is used to distinguish and reference nodes in the graph structure.

Link copied to clipboard
abstract val outputType: TypeToken

The TypeToken of the TOutput

Functions

Link copied to clipboard
open fun addEdge(edge: AIAgentEdge<TOutput, *>)

Adds a directed edge from the current node, enabling connections between this node and other nodes in the AI agent strategy graph.

Link copied to clipboard
abstract suspend fun execute(context: AIAgentGraphContextBase, input: TInput): TOutput?

Executes a specific operation based on the given context and input.

Link copied to clipboard
suspend fun executeUnsafe(context: AIAgentGraphContextBase, input: Any?): Any?

Executes the node operation using the provided execution context and input, bypassing static type checks. This method internally performs an unchecked cast of input to TInput and delegates to execute. The caller is responsible for ensuring that input is actually assignable to TInput; otherwise a ClassCastException may be thrown at the call site or later during execution.

Link copied to clipboard

Creates a directed edge from this AIAgentNodeBase to another AIAgentNodeBase, allowing data to flow from the output of the current node to the input of the specified node.

Link copied to clipboard

Resolves the edge associated with the provided node output and execution context. Iterates through available edges and identifies the first edge that can successfully process the given node output within the provided context. If a resolvable edge is found, it returns a ResolvedEdge containing the edge and its output. Otherwise, returns null.