Class: LLM::OpenAI::VectorStores
- Inherits:
-
Object
- Object
- LLM::OpenAI::VectorStores
- Defined in:
- lib/llm/providers/openai/vector_stores.rb
Overview
The LLM::OpenAI::VectorStores class provides an interface for OpenAI's vector stores API.
Constant Summary collapse
Instance Method Summary collapse
-
#poll(vector:, file:
nil, attempts: 0, max: 50, interval: INTERVAL) ⇒
LLM::Response
Poll a vector store or file until its status is "completed".
-
#all(**params) ⇒
LLM::Response
List all vector stores.
-
#create(name:,
file_ids: nil, **params) ⇒ LLM::Response
Create a vector store.
-
#create_and_poll(interval:
INTERVAL, **rest) ⇒ LLM::Response
Create a vector store and poll until its status is "completed".
-
#get(vector:) ⇒
LLM::Response
Get a vector store.
-
#modify(vector:,
name: nil, **params) ⇒ LLM::Response
Modify an existing vector store.
-
#delete(vector:) ⇒
LLM::Response
Delete a vector store.
-
#search(vector:,
query:, **params) ⇒ LLM::Response
Search a vector store.
-
#all_files(vector:,
**params) ⇒ LLM::Response
List all files in a vector store.
-
#add_file(vector:,
file:, attributes: nil, **params) ⇒ LLM::Response (also:
#create_file)
Add a file to a vector store.
-
#add_file_and_poll(vector:,
file:, interval: INTERVAL, **rest) ⇒ LLM::Response (also:
#create_file_and_poll)
Add a file to a vector store and poll until its status is "completed".
-
#update_file(vector:,
file:, attributes:, **params) ⇒ LLM::Response
Update a file in a vector store.
-
#get_file(vector:,
file:, **params) ⇒ LLM::Response
Get a file from a vector store.
-
#delete_file(vector:,
file:) ⇒ LLM::Response
Delete a file from a vector store.
-
#initialize(provider)
⇒ VectorStores constructor
A new instance of VectorStores.
Constructor Details
#initialize(provider) ⇒ VectorStores
Returns a new instance of VectorStores.
24 25 26 |
# File 'lib/llm/providers/openai/vector_stores.rb', line 24 def initialize(provider) @provider = provider end |
Instance Method Details
#poll(vector:, file: nil, attempts: 0, max: 50, interval: INTERVAL) ⇒ LLM::Response
Poll a vector store or file until its status is "completed"
234 235 236 237 238 239 240 241 242 243 244 245 246 247 |
# File 'lib/llm/providers/openai/vector_stores.rb', line 234 def poll(vector:, file: nil, attempts: 0, max: 50, interval: INTERVAL) target = file || vector if attempts == max raise LLM::PollError, "'#{target.id}' has status '#{target.status}' after #{max} attempts" elsif target.status == "expired" raise LLM::PollError, "#{target.id}' has expired" elsif target.status != "completed" file ? (file = get_file(vector:, file:)) : (vector = get(vector:)) sleep(interval * (2**attempts)) unless interval.zero? poll(vector:, file:, attempts: attempts + 1, max:, interval:) else target end end |
#all(**params) ⇒ LLM::Response
List all vector stores
32 33 34 35 36 37 38 |
# File 'lib/llm/providers/openai/vector_stores.rb', line 32 def all(**params) query = URI.encode_www_form(params) req = Net::HTTP::Get.new("/v1/vector_stores?#{query}", headers) res, span = execute(request: req, operation: "request") res = ResponseAdapter.adapt(res, type: :enumerable) finish_trace(operation: "request", res:, span:) end |
#create(name:, file_ids: nil, **params) ⇒ LLM::Response
Create a vector store
48 49 50 51 52 53 54 |
# File 'lib/llm/providers/openai/vector_stores.rb', line 48 def create(name:, file_ids: nil, **params) req = Net::HTTP::Post.new("/v1/vector_stores", headers) req.body = LLM.json.dump(params.merge({name:, file_ids:}).compact) res, span = execute(request: req, operation: "request") res = LLM::Response.new(res) finish_trace(operation: "request", res:, span:) end |
#create_and_poll(interval: INTERVAL, **rest) ⇒ LLM::Response
Create a vector store and poll until its status is "completed"
61 62 63 |
# File 'lib/llm/providers/openai/vector_stores.rb', line 61 def create_and_poll(interval: INTERVAL, **rest) poll(interval:, vector: create(**rest)) end |
#get(vector:) ⇒ LLM::Response
Get a vector store
71 72 73 74 75 76 77 |
# File 'lib/llm/providers/openai/vector_stores.rb', line 71 def get(vector:) vector_id = vector.respond_to?(:id) ? vector.id : vector req = Net::HTTP::Get.new("/v1/vector_stores/#{vector_id}", headers) res, span = execute(request: req, operation: "request") res = LLM::Response.new(res) finish_trace(operation: "request", res:, span:) end |
#modify(vector:, name: nil, **params) ⇒ LLM::Response
Modify an existing vector store
87 88 89 90 91 92 93 94 |
# File 'lib/llm/providers/openai/vector_stores.rb', line 87 def modify(vector:, name: nil, **params) vector_id = vector.respond_to?(:id) ? vector.id : vector req = Net::HTTP::Post.new("/v1/vector_stores/#{vector_id}", headers) req.body = LLM.json.dump(params.merge({name:}).compact) res, span = execute(request: req, operation: "request") res = LLM::Response.new(res) finish_trace(operation: "request", res:, span:) end |
#delete(vector:) ⇒ LLM::Response
Delete a vector store
102 103 104 105 106 107 108 |
# File 'lib/llm/providers/openai/vector_stores.rb', line 102 def delete(vector:) vector_id = vector.respond_to?(:id) ? vector.id : vector req = Net::HTTP::Delete.new("/v1/vector_stores/#{vector_id}", headers) res, span = execute(request: req, operation: "request") res = LLM::Response.new(res) finish_trace(operation: "request", res:, span:) end |
#search(vector:, query:, **params) ⇒ LLM::Response
Search a vector store
118 119 120 121 122 123 124 125 |
# File 'lib/llm/providers/openai/vector_stores.rb', line 118 def search(vector:, query:, **params) vector_id = vector.respond_to?(:id) ? vector.id : vector req = Net::HTTP::Post.new("/v1/vector_stores/#{vector_id}/search", headers) req.body = LLM.json.dump(params.merge({query:}).compact) res, span = execute(request: req, operation: "retrieval") res = ResponseAdapter.adapt(res, type: :enumerable) finish_trace(operation: "retrieval", res:, span:) end |
#all_files(vector:, **params) ⇒ LLM::Response
List all files in a vector store
134 135 136 137 138 139 140 141 |
# File 'lib/llm/providers/openai/vector_stores.rb', line 134 def all_files(vector:, **params) vector_id = vector.respond_to?(:id) ? vector.id : vector query = URI.encode_www_form(params) req = Net::HTTP::Get.new("/v1/vector_stores/#{vector_id}/files?#{query}", headers) res, span = execute(request: req, operation: "request") res = ResponseAdapter.adapt(res, type: :enumerable) finish_trace(operation: "request", res:, span:) end |
#add_file(vector:, file:, attributes: nil, **params) ⇒ LLM::Response Also known as: create_file
Add a file to a vector store
152 153 154 155 156 157 158 159 160 |
# File 'lib/llm/providers/openai/vector_stores.rb', line 152 def add_file(vector:, file:, attributes: nil, **params) vector_id = vector.respond_to?(:id) ? vector.id : vector file_id = file.respond_to?(:id) ? file.id : file req = Net::HTTP::Post.new("/v1/vector_stores/#{vector_id}/files", headers) req.body = LLM.json.dump(params.merge({file_id:, attributes:}).compact) res, span = execute(request: req, operation: "request") res = LLM::Response.new(res) finish_trace(operation: "request", res:, span:) end |
#add_file_and_poll(vector:, file:, interval: INTERVAL, **rest) ⇒ LLM::Response Also known as: create_file_and_poll
Add a file to a vector store and poll until its status is "completed"
168 169 170 |
# File 'lib/llm/providers/openai/vector_stores.rb', line 168 def add_file_and_poll(vector:, file:, interval: INTERVAL, **rest) poll(vector:, interval:, file: add_file(vector:, file:, **rest)) end |
#update_file(vector:, file:, attributes:, **params) ⇒ LLM::Response
Update a file in a vector store
182 183 184 185 186 187 188 189 190 |
# File 'lib/llm/providers/openai/vector_stores.rb', line 182 def update_file(vector:, file:, attributes:, **params) vector_id = vector.respond_to?(:id) ? vector.id : vector file_id = file.respond_to?(:id) ? file.id : file req = Net::HTTP::Post.new("/v1/vector_stores/#{vector_id}/files/#{file_id}", headers) req.body = LLM.json.dump(params.merge({attributes:}).compact) res, span = execute(request: req, operation: "request") res = LLM::Response.new(res) finish_trace(operation: "request", res:, span:) end |
#get_file(vector:, file:, **params) ⇒ LLM::Response
Get a file from a vector store
199 200 201 202 203 204 205 206 207 |
# File 'lib/llm/providers/openai/vector_stores.rb', line 199 def get_file(vector:, file:, **params) vector_id = vector.respond_to?(:id) ? vector.id : vector file_id = file.respond_to?(:id) ? file.id : file query = URI.encode_www_form(params) req = Net::HTTP::Get.new("/v1/vector_stores/#{vector_id}/files/#{file_id}?#{query}", headers) res, span = execute(request: req, operation: "request") res = LLM::Response.new(res) finish_trace(operation: "request", res:, span:) end |
#delete_file(vector:, file:) ⇒ LLM::Response
Delete a file from a vector store
216 217 218 219 220 221 222 223 |
# File 'lib/llm/providers/openai/vector_stores.rb', line 216 def delete_file(vector:, file:) vector_id = vector.respond_to?(:id) ? vector.id : vector file_id = file.respond_to?(:id) ? file.id : file req = Net::HTTP::Delete.new("/v1/vector_stores/#{vector_id}/files/#{file_id}", headers) res, span = execute(request: req, operation: "request") res = LLM::Response.new(res) finish_trace(operation: "request", res:, span:) end |