Class: CompletionKit::OpenAiClient

Inherits:
LlmClient
  • Object
show all
Defined in:
app/services/completion_kit/open_ai_client.rb

Constant Summary collapse

STATIC_MODELS =
[
  { id: "gpt-5.4-mini", name: "GPT-5.4 Mini" },
  { id: "gpt-4.1-mini", name: "GPT-4.1 Mini" },
  { id: "gpt-4o-mini", name: "GPT-4o Mini" }
].freeze

Instance Method Summary collapse

Methods inherited from LlmClient

for_model, for_provider, #initialize

Constructor Details

This class inherits a constructor from CompletionKit::LlmClient

Instance Method Details

#available_modelsObject



53
54
55
# File 'app/services/completion_kit/open_ai_client.rb', line 53

def available_models
  STATIC_MODELS
end

#configuration_errorsObject



61
62
63
64
65
# File 'app/services/completion_kit/open_ai_client.rb', line 61

def configuration_errors
  errors = []
  errors << "OpenAI API key is not configured" unless api_key.present?
  errors
end

#configured?Boolean

Returns:

  • (Boolean)


57
58
59
# File 'app/services/completion_kit/open_ai_client.rb', line 57

def configured?
  api_key.present?
end

#generate_completion(prompt, options = {}) ⇒ Object



9
10
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
48
49
50
51
# File 'app/services/completion_kit/open_ai_client.rb', line 9

def generate_completion(prompt, options = {})
  return "Error: API key not configured" unless configured?

  model = options[:model] || "gpt-4.1-mini"
  max_tokens = options[:max_tokens] || 1000
  temperature = options[:temperature] || 0.7

  response = build_connection("https://api.openai.com").post do |req|
    req.url "/v1/responses"
    req.headers["Content-Type"] = "application/json"
    req.headers["Authorization"] = "Bearer #{api_key}"
    req.body = {
      model: model,
      input: prompt,
      instructions: "You are a helpful assistant.",
      max_output_tokens: max_tokens,
      temperature: temperature,
      store: false
    }.to_json
  end

  if response.status == 429
    raise CompletionKit::RateLimitError.new(
      response.body.to_s.truncate(500),
      provider: "openai",
      status: 429,
      retry_after: response.headers && response.headers["Retry-After"]&.to_i
    )
  end

  if response.success?
    data = JSON.parse(response.body)
    data["output"][0]["content"][0]["text"].strip
  else
    "Error: #{response.status} - #{response.body}"
  end
rescue CompletionKit::RateLimitError
  raise
rescue Faraday::Error => e
  raise
rescue => e
  "Error: #{e.message}"
end