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"
245 246 247 248 249 250 251 252 253 254 255 256 257 258 |
# File 'lib/llm/providers/openai/vector_stores.rb', line 245 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 39 |
# 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, tracer = execute(request: req, operation: "request") res = ResponseAdapter.adapt(res, type: :enumerable) tracer.on_request_finish(operation: "request", res:, span:) res end |
#create(name:, file_ids: nil, **params) ⇒ LLM::Response
Create a vector store
49 50 51 52 53 54 55 56 |
# File 'lib/llm/providers/openai/vector_stores.rb', line 49 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, tracer = execute(request: req, operation: "request") res = LLM::Response.new(res) tracer.on_request_finish(operation: "request", res:, span:) res end |
#create_and_poll(interval: INTERVAL, **rest) ⇒ LLM::Response
Create a vector store and poll until its status is "completed"
63 64 65 |
# File 'lib/llm/providers/openai/vector_stores.rb', line 63 def create_and_poll(interval: INTERVAL, **rest) poll(interval:, vector: create(**rest)) end |
#get(vector:) ⇒ LLM::Response
Get a vector store
73 74 75 76 77 78 79 80 |
# File 'lib/llm/providers/openai/vector_stores.rb', line 73 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, tracer = execute(request: req, operation: "request") res = LLM::Response.new(res) tracer.on_request_finish(operation: "request", res:, span:) res end |
#modify(vector:, name: nil, **params) ⇒ LLM::Response
Modify an existing vector store
90 91 92 93 94 95 96 97 98 |
# File 'lib/llm/providers/openai/vector_stores.rb', line 90 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, tracer = execute(request: req, operation: "request") res = LLM::Response.new(res) tracer.on_request_finish(operation: "request", res:, span:) res end |
#delete(vector:) ⇒ LLM::Response
Delete a vector store
106 107 108 109 110 111 112 113 |
# File 'lib/llm/providers/openai/vector_stores.rb', line 106 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, tracer = execute(request: req, operation: "request") res = LLM::Response.new(res) tracer.on_request_finish(operation: "request", res:, span:) res end |
#search(vector:, query:, **params) ⇒ LLM::Response
Search a vector store
123 124 125 126 127 128 129 130 131 |
# File 'lib/llm/providers/openai/vector_stores.rb', line 123 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, tracer = execute(request: req, operation: "retrieval") res = ResponseAdapter.adapt(res, type: :enumerable) tracer.on_request_finish(operation: "retrieval", res:, span:) res end |
#all_files(vector:, **params) ⇒ LLM::Response
List all files in a vector store
140 141 142 143 144 145 146 147 148 |
# File 'lib/llm/providers/openai/vector_stores.rb', line 140 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, tracer = execute(request: req, operation: "request") res = ResponseAdapter.adapt(res, type: :enumerable) tracer.on_request_finish(operation: "request", res:, span:) res end |
#add_file(vector:, file:, attributes: nil, **params) ⇒ LLM::Response Also known as: create_file
Add a file to a vector store
159 160 161 162 163 164 165 166 167 168 |
# File 'lib/llm/providers/openai/vector_stores.rb', line 159 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, tracer = execute(request: req, operation: "request") res = LLM::Response.new(res) tracer.on_request_finish(operation: "request", res:, span:) res 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"
176 177 178 |
# File 'lib/llm/providers/openai/vector_stores.rb', line 176 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
190 191 192 193 194 195 196 197 198 199 |
# File 'lib/llm/providers/openai/vector_stores.rb', line 190 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, tracer = execute(request: req, operation: "request") res = LLM::Response.new(res) tracer.on_request_finish(operation: "request", res:, span:) res end |
#get_file(vector:, file:, **params) ⇒ LLM::Response
Get a file from a vector store
208 209 210 211 212 213 214 215 216 217 |
# File 'lib/llm/providers/openai/vector_stores.rb', line 208 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, tracer = execute(request: req, operation: "request") res = LLM::Response.new(res) tracer.on_request_finish(operation: "request", res:, span:) res end |
#delete_file(vector:, file:) ⇒ LLM::Response
Delete a file from a vector store
226 227 228 229 230 231 232 233 234 |
# File 'lib/llm/providers/openai/vector_stores.rb', line 226 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, tracer = execute(request: req, operation: "request") res = LLM::Response.new(res) tracer.on_request_finish(operation: "request", res:, span:) res end |