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, #embed, #images, #inspect, #moderations, #respond, #responses, #schema, #server_tool, #vector_stores, #with
Constructor Details
Instance Method Details
#assistant_role ⇒ String
Returns the role of the assistant in the conversation. Usually “assistant” or “model”
76 77 78 |
# File 'lib/llm/providers/anthropic.rb', line 76 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 51 52 53 54 55 56 |
# File 'lib/llm/providers/anthropic.rb', line 43 def complete(prompt, params = {}) params = {role: :user, model: default_model, max_tokens: 1024}.merge!(params) tools = resolve_tools(params.delete(:tools)) params = [params, adapt_tools(tools)].inject({}, &:merge!).compact role, stream = params.delete(:role), params.delete(:stream) params[:stream] = true if stream.respond_to?(:<<) || stream == true req = Net::HTTP::Post.new("/v1/messages", headers) = [*(params.delete(:messages) || []), Message.new(role, prompt)] body = LLM.json.dump({messages: [adapt()].flatten}.merge!(params)) set_body_stream(req, StringIO.new(body)) res = execute(request: req, stream:) ResponseAdapter.adapt(res, type: :completion) .extend(Module.new { define_method(:__tools__) { tools } }) end |
#default_model ⇒ String
Returns the default model for chat completions
84 85 86 |
# File 'lib/llm/providers/anthropic.rb', line 84 def default_model "claude-sonnet-4-20250514" end |
#files ⇒ LLM::Anthropic::Files
Provides an interface to Anthropic’s files API
70 71 72 |
# File 'lib/llm/providers/anthropic.rb', line 70 def files LLM::Anthropic::Files.new(self) end |
#models ⇒ LLM::Anthropic::Models
Provides an interface to Anthropic’s models API
62 63 64 |
# File 'lib/llm/providers/anthropic.rb', line 62 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.
95 96 97 98 99 100 101 |
# File 'lib/llm/providers/anthropic.rb', line 95 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.
112 113 114 |
# File 'lib/llm/providers/anthropic.rb', line 112 def web_search(query:) ResponseAdapter.adapt(complete(query, tools: [server_tools[:web_search]]), type: :web_search) end |