Class: Ask::Providers::OpenAI
- Inherits:
-
Ask::Provider
- Object
- Ask::Provider
- Ask::Providers::OpenAI
- Defined in:
- lib/ask/provider/openai.rb
Overview
OpenAI API provider. Also handles all OpenAI-compatible providers (OpenRouter, DeepSeek, Azure, XAI, Perplexity, GPUStack, etc.) via base_url override.
Direct Known Subclasses
Class Method Summary collapse
- .assume_models_exist? ⇒ Boolean
- .capabilities ⇒ Object
- .configuration_options ⇒ Object
- .configuration_requirements ⇒ Object
- .slug ⇒ Object
Instance Method Summary collapse
- #api_base ⇒ Object
- #chat(messages, model:, tools: nil, temperature: nil, stream: nil, schema: nil, **params, &block) ⇒ Object
- #embed(texts, model:) ⇒ Object
- #headers ⇒ Object
-
#initialize(config = {}) ⇒ OpenAI
constructor
A new instance of OpenAI.
- #list_models ⇒ Object
- #parse_error(response) ⇒ Object
Constructor Details
#initialize(config = {}) ⇒ OpenAI
Returns a new instance of OpenAI.
9 10 11 12 13 14 |
# File 'lib/ask/provider/openai.rb', line 9 def initialize(config = {}) @provider_keys = extract_provider_keys(config) config = normalize_config(config) super(config) @http = build_http end |
Class Method Details
.assume_models_exist? ⇒ Boolean
61 |
# File 'lib/ask/provider/openai.rb', line 61 def assume_models_exist?; false; end |
.capabilities ⇒ Object
56 57 58 |
# File 'lib/ask/provider/openai.rb', line 56 def capabilities { chat: true, streaming: true, tool_calls: true, vision: true, thinking: true, structured_output: true, embed: true, transcribe: true, paint: true, moderate: true } end |
.configuration_options ⇒ Object
59 |
# File 'lib/ask/provider/openai.rb', line 59 def ; %i[api_key base_url organization_id project_id]; end |
.configuration_requirements ⇒ Object
60 |
# File 'lib/ask/provider/openai.rb', line 60 def configuration_requirements; %i[api_key]; end |
.slug ⇒ Object
55 |
# File 'lib/ask/provider/openai.rb', line 55 def slug; "openai"; end |
Instance Method Details
#api_base ⇒ Object
16 17 18 |
# File 'lib/ask/provider/openai.rb', line 16 def api_base @config.base_url || "https://api.openai.com/v1" end |
#chat(messages, model:, tools: nil, temperature: nil, stream: nil, schema: nil, **params, &block) ⇒ Object
29 30 31 32 33 |
# File 'lib/ask/provider/openai.rb', line 29 def chat(, model:, tools: nil, temperature: nil, stream: nil, schema: nil, **params, &block) msgs = .is_a?(Ask::Conversation) ? .to_a : payload = build_chat_payload(msgs, model, tools, temperature, stream, schema, **params) stream ? chat_stream(payload, model, &block) : chat_nonstream(payload, model) end |
#embed(texts, model:) ⇒ Object
35 36 37 38 39 40 41 |
# File 'lib/ask/provider/openai.rb', line 35 def (texts, model:) texts = Array(texts) response = @http.post("embeddings") { |r| r.body = { model: model, input: texts } } raise LLM::HTTP.map_error(response.status, response.body, provider: "OpenAI") unless response.success? = response.body["data"].map { |d| d["embedding"] } Ask::Result.success(.one? ? .first : ) end |
#headers ⇒ Object
20 21 22 23 24 25 26 27 |
# File 'lib/ask/provider/openai.rb', line 20 def headers key = @config.api_key || @config.openai_api_key h = { "Content-Type" => "application/json" } h["Authorization"] = "Bearer #{key}" if key h["OpenAI-Organization"] = @config.organization_id if @config.organization_id h["OpenAI-Project"] = @config.project_id if @config.project_id h end |
#list_models ⇒ Object
43 44 45 46 47 |
# File 'lib/ask/provider/openai.rb', line 43 def list_models response = @http.get("models") return [] unless response.success? response.body["data"].map { |m| Ask::ModelInfo.new(id: m["id"], provider: slug, metadata: { owned_by: m["owned_by"] }) } end |
#parse_error(response) ⇒ Object
49 50 51 52 |
# File 'lib/ask/provider/openai.rb', line 49 def parse_error(response) body = response.body rescue nil body&.dig("error", "message") || body&.dig("error", "code") end |