Class: CompletionKit::OpenRouterClient
- Defined in:
- app/services/completion_kit/open_router_client.rb
Constant Summary collapse
- BASE_URL =
"https://openrouter.ai".freeze
- REFERER =
"https://completionkit.com".freeze
- APP_TITLE =
"CompletionKit".freeze
Instance Method Summary collapse
- #available_models ⇒ Object
- #configuration_errors ⇒ Object
- #configured? ⇒ Boolean
- #generate_completion(prompt, options = {}) ⇒ Object
- #temperature_dropped? ⇒ Boolean
Methods inherited from LlmClient
for_model, for_provider, #initialize
Constructor Details
This class inherits a constructor from CompletionKit::LlmClient
Instance Method Details
#available_models ⇒ Object
49 50 51 |
# File 'app/services/completion_kit/open_router_client.rb', line 49 def available_models [] end |
#configuration_errors ⇒ Object
57 58 59 60 61 |
# File 'app/services/completion_kit/open_router_client.rb', line 57 def configuration_errors errors = [] errors << "OpenRouter API key is not configured" unless api_key.present? errors end |
#configured? ⇒ Boolean
53 54 55 |
# File 'app/services/completion_kit/open_router_client.rb', line 53 def configured? api_key.present? end |
#generate_completion(prompt, options = {}) ⇒ Object
11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 |
# File 'app/services/completion_kit/open_router_client.rb', line 11 def generate_completion(prompt, = {}) @temperature_dropped = false return "Error: API key not configured" unless configured? model = [:model] || "openai/gpt-4o-mini" max_tokens = [:max_tokens] || 1000 temperature = [:temperature] || 0.7 response = post_chat(model: model, prompt: prompt, max_tokens: max_tokens, temperature: temperature) if response.status == 400 && temperature_unsupported?(response.body) @temperature_dropped = true response = post_chat(model: model, prompt: prompt, max_tokens: max_tokens, temperature: nil) end if response.status == 429 raise CompletionKit::RateLimitError.new( response.body.to_s.truncate(500), provider: "openrouter", status: 429, retry_after: response.headers && response.headers["Retry-After"]&.to_i ) end if response.success? data = JSON.parse(response.body) data.dig("choices", 0, "message", "content").to_s.strip else "Error: #{response.status} - #{response.body}" end rescue CompletionKit::RateLimitError raise rescue Faraday::Error raise rescue => e "Error: #{e.}" end |
#temperature_dropped? ⇒ Boolean
7 8 9 |
# File 'app/services/completion_kit/open_router_client.rb', line 7 def temperature_dropped? @temperature_dropped == true end |