rach 0.2.9 → 0.2.11

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: d38fee5588b8410bd344b1848429f4cd5534dbfc46bdb3c7c55193156b3f78b5
4
- data.tar.gz: 8a8b353426c367c4b0a7663d66a0a82a91c594a23384f12ed17f3484513aa105
3
+ metadata.gz: abe9277687df73a293f283e8f5f0b0740046f10a8fa94c9734afdf1d401cd166
4
+ data.tar.gz: 6b66d2598552b7bfaff52a8bca9dbd8dbd3420417de5e05d26d981852010fe00
5
5
  SHA512:
6
- metadata.gz: 0c963bd5389c85b39ac2f2fb8ef94f3e35167bd265e2dfa77c6a63642ae42d156954e9d151fbea994b3c12fe5d5a7db15f2671501449a74df17e4e26a1e3383d
7
- data.tar.gz: 8f3e9700244b3fc29414a512b1cbf84818b72d73cc44d60a6dc581835a77d680f0616008477bbaf54f68e2fcf2dbfa540fc104aa346cd3882c47826c578a90d9
6
+ metadata.gz: ac70abf3662cd65d303a5ee1ef112315e0029a003c3df302fe35cd74a745ad29d2d6c99e642a76afdc6764dd7a8814bd4fc74575bff67a907ccce41f4f65e536
7
+ data.tar.gz: 90159e32b77b0699e600b1b8f57156df56990a0eabf23c7b83b430347c31c9babf69ca14456c4e178198fe82d63847a40a2c652341bef8b24c8d26b81b77c635
data/lib/rach/client.rb CHANGED
@@ -13,7 +13,7 @@ module Rach
13
13
  setup_providers(providers)
14
14
  elsif access_token && model
15
15
  provider = Provider.for(model)
16
- setup_providers({ provider.key => { access_token: access_token } })
16
+ setup_providers({ provider.key => { access_token: access_token, model: model } })
17
17
  else
18
18
  raise ArgumentError, "Either (providers) or (access_token AND model) must be provided"
19
19
  end
@@ -0,0 +1,15 @@
1
+ module Gemini
2
+ module Controllers
3
+ class Client
4
+ attr_accessor :model_address
5
+
6
+ def model
7
+ @model_address.split('models/').last
8
+ end
9
+
10
+ def model=(new_model)
11
+ @model_address = "models/#{new_model}"
12
+ end
13
+ end
14
+ end
15
+ end
@@ -10,6 +10,12 @@ module Rach
10
10
  end
11
11
 
12
12
  def chat(**parameters)
13
+ # Update the client's model if it differs from the request
14
+ if parameters.dig(:parameters, :model) != @client.model
15
+ @client.model = parameters.dig(:parameters, :model)
16
+ # @client = create_client(@client.credentials[:api_key], model: parameters.dig(:parameters, :model))
17
+ end
18
+
13
19
  messages = parameters.dig(:parameters, :messages) || []
14
20
  system_message = messages.find { |msg| msg[:role] == "system" }
15
21
  messages = messages.reject { |msg| msg[:role] == "system" } if system_message
@@ -30,12 +36,27 @@ module Rach
30
36
  end
31
37
  end
32
38
 
39
+ request_params = { contents: contents }
40
+
41
+ # Handle response format if provided
42
+ if response_format = parameters.dig(:parameters, :response_format)
43
+ request_params[:generation_config] = {
44
+ response_mime_type: 'application/json',
45
+ response_schema: convert_response_format(response_format)
46
+ }
47
+ end
48
+
49
+ if request_params.dig(:generation_config, :response_schema)
50
+ request_params[:generation_config][:response_schema].delete(:additionalProperties)
51
+ request_params[:generation_config][:response_schema].delete(:required)
52
+ end
53
+
33
54
  if @logger
34
55
  @logger.info("Making API call to Google Gemini")
35
- @logger.info("Request parameters: #{contents.inspect}")
56
+ @logger.info("Request parameters: #{request_params.inspect}")
36
57
  end
37
58
 
38
- raw_response = @client.generate_content({ contents: contents })
59
+ raw_response = @client.generate_content(request_params)
39
60
 
40
61
  if @logger
41
62
  @logger.info("Response: #{raw_response.inspect}")
@@ -66,11 +87,24 @@ module Rach
66
87
  service: 'generative-language-api',
67
88
  api_key: access_token
68
89
  },
69
- options: { model: 'gemini-pro' }
90
+ options: { model: config[:model] }
70
91
  }
71
- client_config[:options].merge!(config)
92
+
93
+ # Only merge additional options that aren't already set
94
+ client_config[:options].merge!(config.except(:model))
95
+
96
+ # Function calling and structured output are broken in this gem
97
+ gemini = ::Gemini.new(**client_config)
98
+ base_address = gemini.instance_variable_get(:@base_address)
99
+ base_address.gsub!('v1', 'v1beta') if base_address
100
+ gemini
101
+ end
102
+
103
+ def convert_response_format(format)
104
+ return unless format[:type] == "json_schema"
72
105
 
73
- ::Gemini.new(**client_config)
106
+ schema = format.dig(:json_schema, :schema)
107
+ schema.deep_symbolize_keys
74
108
  end
75
109
  end
76
110
  end
data/lib/rach/version.rb CHANGED
@@ -1,4 +1,4 @@
1
1
  module Rach
2
- VERSION = "0.2.9"
2
+ VERSION = "0.2.11"
3
3
  end
4
4
 
data/lib/rach.rb CHANGED
@@ -11,6 +11,7 @@ require_relative "rach/response_format"
11
11
  require_relative "rach/conversation"
12
12
  require_relative "rach/usage_tracker"
13
13
  require_relative "rach/function"
14
+ require_relative "rach/initializers/google_client"
14
15
  require_relative "rach/provider/base"
15
16
  require_relative "rach/provider/openai"
16
17
  require_relative "rach/provider/anthropic"
metadata CHANGED
@@ -1,14 +1,14 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: rach
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.2.9
4
+ version: 0.2.11
5
5
  platform: ruby
6
6
  authors:
7
7
  - Roger Garcia
8
8
  autorequire:
9
9
  bindir: bin
10
10
  cert_chain: []
11
- date: 2025-02-05 00:00:00.000000000 Z
11
+ date: 2025-02-10 00:00:00.000000000 Z
12
12
  dependencies:
13
13
  - !ruby/object:Gem::Dependency
14
14
  name: rspec
@@ -127,6 +127,7 @@ files:
127
127
  - lib/rach/conversation.rb
128
128
  - lib/rach/errors.rb
129
129
  - lib/rach/function.rb
130
+ - lib/rach/initializers/google_client.rb
130
131
  - lib/rach/message.rb
131
132
  - lib/rach/message_template.rb
132
133
  - lib/rach/prompt.rb