pub struct StatefulTool<S: Send + Sync + 'static> { /* private fields */ }Expand description
A generic tool wrapper that manages shared state for stateful closures.
StatefulTool<S> accepts an Arc<S> and a handler closure that receives
the state alongside the tool context and arguments. The Arc<S> is cloned
(cheap reference count bump) on each invocation, so all executions share
the same underlying state.
§Example
ⓘ
use adk_tool::StatefulTool;
use adk_core::{ToolContext, Result};
use serde_json::{json, Value};
use std::sync::Arc;
use tokio::sync::RwLock;
struct Counter { count: RwLock<u64> }
let state = Arc::new(Counter { count: RwLock::new(0) });
let tool = StatefulTool::new(
"increment",
"Increment a counter",
state,
|s, _ctx, _args| async move {
let mut count = s.count.write().await;
*count += 1;
Ok(json!({ "count": *count }))
},
);Implementations§
Source§impl<S: Send + Sync + 'static> StatefulTool<S>
impl<S: Send + Sync + 'static> StatefulTool<S>
Sourcepub fn new<F, Fut>(
name: impl Into<String>,
description: impl Into<String>,
state: Arc<S>,
handler: F,
) -> Self
pub fn new<F, Fut>( name: impl Into<String>, description: impl Into<String>, state: Arc<S>, handler: F, ) -> Self
Create a new stateful tool.
§Arguments
name- Tool name exposed to the LLMdescription- Human-readable description of what the tool doesstate- Shared state wrapped inArc<S>handler- Async closure receiving(Arc<S>, Arc<dyn ToolContext>, Value)
pub fn with_long_running(self, long_running: bool) -> Self
pub fn with_read_only(self, read_only: bool) -> Self
pub fn with_concurrency_safe(self, concurrency_safe: bool) -> Self
pub fn with_parameters_schema<T>(self) -> Selfwhere
T: JsonSchema + Serialize,
pub fn with_response_schema<T>(self) -> Selfwhere
T: JsonSchema + Serialize,
Sourcepub fn with_scopes(self, scopes: &[&'static str]) -> Self
pub fn with_scopes(self, scopes: &[&'static str]) -> Self
Declare the scopes required to execute this tool.
When set, the framework will enforce that the calling user possesses
all listed scopes before dispatching execute().
pub fn parameters_schema(&self) -> Option<&Value>
pub fn response_schema(&self) -> Option<&Value>
Trait Implementations§
Source§impl<S: Send + Sync + 'static> Tool for StatefulTool<S>
impl<S: Send + Sync + 'static> Tool for StatefulTool<S>
fn name(&self) -> &str
fn description(&self) -> &str
Source§fn enhanced_description(&self) -> String
fn enhanced_description(&self) -> String
Returns an enhanced description that may include additional notes.
For long-running tools, this includes a warning not to call the tool
again if it has already returned a pending status.
Default implementation returns the base description.
Source§fn is_long_running(&self) -> bool
fn is_long_running(&self) -> bool
Indicates whether the tool is a long-running operation.
Long-running tools typically return a task ID immediately and
complete the operation asynchronously.
Source§fn is_read_only(&self) -> bool
fn is_read_only(&self) -> bool
Indicates whether this tool performs no side effects.
Read-only tools may be executed concurrently in Auto mode.
Source§fn is_concurrency_safe(&self) -> bool
fn is_concurrency_safe(&self) -> bool
Indicates whether this tool is safe for concurrent execution.
Used by the Parallel strategy to validate dispatch safety.
fn parameters_schema(&self) -> Option<Value>
fn response_schema(&self) -> Option<Value>
Source§fn required_scopes(&self) -> &[&str]
fn required_scopes(&self) -> &[&str]
Returns the scopes required to execute this tool. Read more
fn execute<'life0, 'async_trait>(
&'life0 self,
ctx: Arc<dyn ToolContext>,
args: Value,
) -> Pin<Box<dyn Future<Output = Result<Value>> + Send + 'async_trait>>where
Self: 'async_trait,
'life0: 'async_trait,
Source§fn declaration(&self) -> Value
fn declaration(&self) -> Value
Returns the tool declaration that should be exposed to model providers. Read more
Source§fn is_builtin(&self) -> bool
fn is_builtin(&self) -> bool
Indicates whether this tool is a built-in server-side tool (e.g.,
google_search, url_context). Read moreAuto Trait Implementations§
impl<S> Freeze for StatefulTool<S>
impl<S> !RefUnwindSafe for StatefulTool<S>
impl<S> Send for StatefulTool<S>
impl<S> Sync for StatefulTool<S>
impl<S> Unpin for StatefulTool<S>
impl<S> UnsafeUnpin for StatefulTool<S>
impl<S> !UnwindSafe for StatefulTool<S>
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
Source§impl<T> FutureExt for T
impl<T> FutureExt for T
Source§fn with_context(self, otel_cx: Context) -> WithContext<Self>
fn with_context(self, otel_cx: Context) -> WithContext<Self>
Source§fn with_current_context(self) -> WithContext<Self>
fn with_current_context(self) -> WithContext<Self>
Source§impl<T> Instrument for T
impl<T> Instrument for T
Source§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
Source§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
Source§impl<T> IntoRequest<T> for T
impl<T> IntoRequest<T> for T
Source§fn into_request(self) -> Request<T>
fn into_request(self) -> Request<T>
Wrap the input message
T in a tonic::Request