Class: LLM::Response

Inherits:
Object
  • Object
show all
Defined in:
lib/llm/response.rb

Overview

LLM::Response encapsulates a response from an LLM provider. It is returned by all methods that make requests to a provider, and sometimes extended with provider-specific functionality.

Instance Attribute Summary collapse

Instance Method Summary collapse

Constructor Details

#initialize(res) ⇒ LLM::Response

Returns an instance of LLM::Response

Parameters:

  • HTTP response



22
23
24
# File 'lib/llm/response.rb', line 22

def initialize(res)
  @res = res
end

Dynamic Method Handling

This class handles dynamic methods through the method_missing method

#method_missing(m, *args, **kwargs, &b) ⇒ Object (private)



58
59
60
61
62
63
64
# File 'lib/llm/response.rb', line 58

def method_missing(m, *args, **kwargs, &b)
  if LLM::Object === body
    body.respond_to?(m) ? body[m.to_s] : super
  else
    super
  end
end

Instance Attribute Details

#resNet::HTTPResponse (readonly)

Returns the HTTP response

Returns:



15
16
17
# File 'lib/llm/response.rb', line 15

def res
  @res
end

Instance Method Details

#bodyLLM::Object, String

Returns the response body

Returns:

  • Returns an LLM::Object when the response body is JSON, otherwise returns a raw string.



31
32
33
# File 'lib/llm/response.rb', line 31

def body
  @res.body
end

#file?Boolean

Returns true if the response is from the Files API

Returns:



52
53
54
# File 'lib/llm/response.rb', line 52

def file?
  false
end

#inspectString

Returns an inspection of the response object

Returns:



38
39
40
# File 'lib/llm/response.rb', line 38

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

Returns:



45
46
47
# File 'lib/llm/response.rb', line 45

def ok?
  Net::HTTPSuccess === @res
end