discourse-ai/lib/inference/gemini_embeddings.rb

37 lines
1.1 KiB
Ruby
Raw Normal View History

# frozen_string_literal: true
module ::DiscourseAi
module Inference
class GeminiEmbeddings
def initialize(embedding_url, api_key, referer = Discourse.base_url)
@api_key = api_key
@embedding_url = embedding_url
@referer = referer
end
attr_reader :embedding_url, :api_key, :referer
def perform!(content)
headers = { "Referer" => referer, "Content-Type" => "application/json" }
url = "#{embedding_url}\?key\=#{api_key}"
body = { content: { parts: [{ text: content }] } }
conn = Faraday.new { |f| f.adapter FinalDestination::FaradayAdapter }
response = conn.post(url, body.to_json, headers)
case response.status
when 200
JSON.parse(response.body, symbolize_names: true).dig(:embedding, :values)
when 429
# TODO add a AdminDashboard Problem?
else
Rails.logger.warn(
"Google Gemini Embeddings failed with status: #{response.status} body: #{response.body}",
)
raise Net::HTTPBadResponse.new(response.body.to_s)
end
end
end
end
end