Class: LLM::Anthropic
- Includes:
- RequestAdapter
- Defined in:
- lib/llm/providers/anthropic.rb,
lib/llm/providers/anthropic/files.rb,
lib/llm/providers/anthropic/models.rb,
lib/llm/providers/anthropic/error_handler.rb,
lib/llm/providers/anthropic/stream_parser.rb,
lib/llm/providers/anthropic/request_adapter.rb,
lib/llm/providers/anthropic/response_adapter.rb
Overview
The Anthropic class implements a provider for [Anthropic](www.anthropic.com).
Defined Under Namespace
Modules: RequestAdapter, ResponseAdapter Classes: ErrorHandler, Files, Models, StreamParser
Constant Summary collapse
- HOST =
"api.anthropic.com"
Instance Method Summary collapse
-
#assistant_role ⇒ String
Returns the role of the assistant in the conversation.
-
#complete(prompt, params = {}) ⇒ LLM::Response
Provides an interface to the chat completions API.
-
#default_model ⇒ String
Returns the default model for chat completions.
-
#files ⇒ LLM::Anthropic::Files
Provides an interface to Anthropic’s files API.
-
#initialize ⇒ Anthropic
constructor
A new instance of Anthropic.
-
#models ⇒ LLM::Anthropic::Models
Provides an interface to Anthropic’s models API.
- #server_tools ⇒ String => LLM::ServerTool
-
#web_search(query:) ⇒ LLM::Response
A convenience method for performing a web search using the Anthropic web search tool.
Methods included from RequestAdapter
Methods inherited from Provider
#audio, #chat, clients, #developer_role, #embed, #images, #inspect, #moderations, #respond, #responses, #schema, #server_tool, #system_role, #tool_role, #tracer, #tracer=, #user_role, #vector_stores, #with
Constructor Details
Instance Method Details
#assistant_role ⇒ String
Returns the role of the assistant in the conversation. Usually “assistant” or “model”
70 71 72 |
# File 'lib/llm/providers/anthropic.rb', line 70 def assistant_role "assistant" end |
#complete(prompt, params = {}) ⇒ LLM::Response
Provides an interface to the chat completions API
43 44 45 46 47 48 49 50 |
# File 'lib/llm/providers/anthropic.rb', line 43 def complete(prompt, params = {}) params, stream, tools, role = normalize_complete_params(params) req = build_complete_request(prompt, params, role) res, span = execute(request: req, stream: stream, operation: "chat", model: params[:model]) res = ResponseAdapter.adapt(res, type: :completion) .extend(Module.new { define_method(:__tools__) { tools } }) finish_trace(operation: "chat", model: params[:model], res:, span:) end |
#default_model ⇒ String
Returns the default model for chat completions
78 79 80 |
# File 'lib/llm/providers/anthropic.rb', line 78 def default_model "claude-sonnet-4-20250514" end |
#files ⇒ LLM::Anthropic::Files
Provides an interface to Anthropic’s files API
64 65 66 |
# File 'lib/llm/providers/anthropic.rb', line 64 def files LLM::Anthropic::Files.new(self) end |
#models ⇒ LLM::Anthropic::Models
Provides an interface to Anthropic’s models API
56 57 58 |
# File 'lib/llm/providers/anthropic.rb', line 56 def models LLM::Anthropic::Models.new(self) end |
#server_tools ⇒ String => LLM::ServerTool
This method includes certain tools that require configuration through a set of options that are easier to set through the LLM::Provider#server_tool method.
89 90 91 92 93 94 95 |
# File 'lib/llm/providers/anthropic.rb', line 89 def server_tools { bash: server_tool(:bash, type: "bash_20250124"), web_search: server_tool(:web_search, type: "web_search_20250305", max_uses: 5), text_editor: server_tool(:str_replace_based_edit_tool, type: "text_editor_20250728", max_characters: 10_000) } end |
#web_search(query:) ⇒ LLM::Response
A convenience method for performing a web search using the Anthropic web search tool.
106 107 108 |
# File 'lib/llm/providers/anthropic.rb', line 106 def web_search(query:) ResponseAdapter.adapt(complete(query, tools: [server_tools[:web_search]]), type: :web_search) end |