Crolia
Crolia
Crolia is a wrapper around Algolia.com's api allowing you to use most of their REST api features from inserting/deleting/updating and searching data.
Installation
Add this to your application's shard.yml
:
dependencies:
Crolia:
github: exts/Crolia
Done
- List indices
- Search an index
- Search an index (alternative)
- Search multiple indices
- Delete an index
- Clear an index
- Add an object without ID
- Add/update an object by ID
- Partially update an object
- Retrieve an object
- Retrieve multiple objects
- Delete an object
TODO
- Batch write operations
- Batch write operations (multiple indices)
- Browse all index content
- Browse all index content (alternative)
- Get index settings
- Change index settings
- Copy/move an index
- Get a task’s status
- Add an index-specific API key
- Update an index-specific API key
- List index-specific API keys
- List index-specific API keys (for all indices)
- Retrieve an index-specific API key
- Delete an index-specific API key
- Search for facet values
Usage
Connecting to api
require "Crolia"
api = Crolia::Api.new "API_KEY", "API_ID"
Search Index by keyword
index = api.index "example_index"
results = index.find_by "example_search_term"
puts results.data # returns algolia response message/results
Search multiple indices by keywords
index = api.index "example_index"
results = index.find_multiple([
{"params" => "query=data"}
])
puts results.data # returns algolia response message/results
List all Indexes
index = api.index "example_index"
results = index.find_all
puts results.data
Find object by id
object = api.objects "example_index"
results = object.find("1") # you can pass attributes as the 2nd parameter using a Hash(String, String)
puts results.data
Find multiple objects
object = api.objects "example_index"
results = object.find_all([
{"objectID" => "1"},
{"objectID" => "2"},
])
puts results.data
Insert or Update an object
object = api.objects "example_index"
# first paramter just pass a has and convert it to json using .to_json, 2nd parameter is optional it's he id, if you leave it blank it'll create an objectId for you
results = object.add_or_update({"title" => "Custom Title", "tags" => ["custom_tag_1", "custom_tag_2"]}.to_json, "3")
puts results.data
Partial Update an object
object = api.objects "example_index"
# first parameter is the id you want to pass, 2nd parameter is the data you want to partially update (convert to json)
# and the last field that's optional is a boolean which forces the creating of the object if it doesn't exist, disabled by default
object.partial_update("5", {"title" => "Updated Title", "shouldnt_get_created" => true}.to_json)
puts results.data
Delete an object
object = api.objects "example_index"
# as simple as passing the object id to be deleted
objects.delete("4")
puts results.data
Contributors
- [exts] exts - creator, maintainer
Repository
Crolia
Owner
Statistic
- 0
- 0
- 0
- 0
- 0
- over 7 years ago
- April 20, 2017
License
Other
Links
Synced at
Fri, 22 Nov 2024 03:09:08 GMT
Languages