Class: LLM::Response
- Inherits:
-
Object
- Object
- LLM::Response
- Defined in:
- lib/llm/response.rb
Overview
LLM::Response is the normalized base shape for provider and endpoint responses in llm.rb.
Provider calls return an instance of this class, then extend it with provider-, endpoint-, or context-specific modules so response handling can share one common surface without flattening away specialized behavior.
The normalized response keeps the transport response available through #res. When the default net/http transport is in use, LLM::Transport::Response::HTTP keeps the original Net::HTTPResponse available through its own #res.
Instance Attribute Summary collapse
-
#res ⇒ LLM::Transport::Response
readonly
Returns the HTTP response.
Instance Method Summary collapse
-
#body ⇒ LLM::Object, String
Returns the response body.
-
#file? ⇒ Boolean
Returns true if the response is from the Files API.
-
#initialize(res) ⇒ LLM::Response
constructor
Returns an instance of LLM::Response.
-
#inspect ⇒ String
Returns an inspection of the response object.
-
#ok? ⇒ Boolean
Returns true if the response is successful.
Constructor Details
#initialize(res) ⇒ LLM::Response
Returns an instance of LLM::Response
32 33 34 |
# File 'lib/llm/response.rb', line 32 def initialize(res) @res = LLM::Transport::Response.from(res) end |
Dynamic Method Handling
This class handles dynamic methods through the method_missing method
Instance Attribute Details
#res ⇒ LLM::Transport::Response (readonly)
Returns the HTTP response
25 26 27 |
# File 'lib/llm/response.rb', line 25 def res @res end |
Instance Method Details
#body ⇒ LLM::Object, String
Returns the response body
41 42 43 |
# File 'lib/llm/response.rb', line 41 def body @res.body end |
#file? ⇒ Boolean
Returns true if the response is from the Files API
62 63 64 |
# File 'lib/llm/response.rb', line 62 def file? false end |
#inspect ⇒ String
Returns an inspection of the response object
48 49 50 |
# File 'lib/llm/response.rb', line 48 def inspect "#<#{self.class.name}:0x#{object_id.to_s(16)} @body=#{body.inspect} @res=#{@res.inspect}>" end |
#ok? ⇒ Boolean
Returns true if the response is successful
55 56 57 |
# File 'lib/llm/response.rb', line 55 def ok? @res.success? end |