Skip to main content

Client

Struct Client 

Source
pub struct Client { /* private fields */ }
Expand description

Claude Messages API client.

Implementations§

Source§

impl Client

Source

pub fn with_token(_token: impl Into<String>) -> Self

Create a new client with a single token (no pool/rotation).

Source

pub fn builder() -> ClientBuilder

Create a client builder.

Source

pub async fn message( &self, model: &str, messages: &[Message], max_tokens: u32, ) -> Result<MessagesResponse>

Send a Messages API request.

Source

pub async fn message_with_system( &self, model: &str, messages: &[Message], max_tokens: u32, system: Option<&str>, ) -> Result<MessagesResponse>

Send a Messages API request with system prompt.

Source

pub async fn message_with_tools( &self, model: &str, messages: &[Message], max_tokens: u32, system: Option<&str>, tools: Option<&[Tool]>, ) -> Result<MessagesResponse>

Send a Messages API request with system prompt and tools.

Source

pub async fn run_agent_loop( &self, model: &str, system: &str, initial_message: &str, tools: &[Tool], max_turns: u32, tool_handler: &dyn ToolHandler, ) -> Result<AgentLoopResult>

Run an agent loop with tool use support.

This method sends the initial message, handles tool calls via the handler, and continues the conversation until Claude stops calling tools or max_turns is reached.

§Arguments
  • model: The model to use (e.g., “claude-sonnet-4-5”)
  • system: System prompt
  • initial_message: The user’s initial request
  • tools: Tool definitions
  • max_turns: Maximum conversation turns (each turn = one API call)
  • tool_handler: Handler for executing tools
§Returns

An AgentLoopResult with final text, total tokens, turns used, and tool calls.

Trait Implementations§

Source§

impl Debug for Client

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more

Auto Trait Implementations§

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T> Instrument for T

Source§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more
Source§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> PolicyExt for T
where T: ?Sized,

Source§

fn and<P, B, E>(self, other: P) -> And<T, P>
where T: Policy<B, E>, P: Policy<B, E>,

Create a new Policy that returns Action::Follow only if self and other return Action::Follow. Read more
Source§

fn or<P, B, E>(self, other: P) -> Or<T, P>
where T: Policy<B, E>, P: Policy<B, E>,

Create a new Policy that returns Action::Follow if either self or other returns Action::Follow. Read more
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
Source§

impl<T> WithSubscriber for T

Source§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more
Source§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more