Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/paractmol/tagliani
Blazing fast ActiveRecord library to create tags using ElasticSearch
https://github.com/paractmol/tagliani
activerecord elasticsearch rails redis ruby tags
Last synced: about 1 month ago
JSON representation
Blazing fast ActiveRecord library to create tags using ElasticSearch
- Host: GitHub
- URL: https://github.com/paractmol/tagliani
- Owner: paractmol
- License: mit
- Created: 2019-05-16T17:47:54.000Z (over 5 years ago)
- Default Branch: master
- Last Pushed: 2023-01-20T03:42:29.000Z (almost 2 years ago)
- Last Synced: 2024-05-18T22:42:19.485Z (7 months ago)
- Topics: activerecord, elasticsearch, rails, redis, ruby, tags
- Language: Ruby
- Homepage: https://fadein.xyz/
- Size: 49.8 KB
- Stars: 0
- Watchers: 1
- Forks: 0
- Open Issues: 2
-
Metadata Files:
- Readme: README.md
- License: LICENSE
- Code of conduct: CODE_OF_CONDUCT.md
Awesome Lists containing this project
- awesome-blazingly-fast - tagliani - Blazing fast ActiveRecord library to create tags using ElasticSearch (Ruby)
README
# Tagliani
Blazing fast Ruby alternative to `acts-as-taggable-on` and other similar gems. Instead of million of records in the database it uses powerful ElasticSearch, which gives a very fast and scalable solution with a search capabilities of ElasticSearch.
## Installation
All you need is to add in your `Gemfile` the follwing line.
```ruby
gem 'tagliani'
```And run `bundle install` command.
### Requirements
* ActiveRecord
* redis-client
* elasticsearchTo run this gem it is required to have ActiveRecord.
## Configuration
In your rails app `config/initializers` create `tagliani.rb` with the following content
```ruby
Tagliani.configure do |config|
config.elasticsearch.url = "http://localhost:9200" # URL of your ElasticSearch service, by default set to this endpoint
config.elasticsearch.index = "tagliani_#{Rails.env}" # Index name
config.elasticsearch.refresh = true # false by default
config.elasticsearch.log = true # false by default
config.redis.url = "redis://localhost:6379/tagliani" # By default set to this endpoint
config.redis.queue = "tagliani" # By default set to this queue name
config.redis.length = 200 # By default set to 200. It is a queue length per bulk that is going to be sent to ElasticSearch
end
```## Search
Let's say inside the Rails application you have a model with a name "Hashtag", that represents all the tags attached to the model "Tweet".
```ruby
class Hashtag < ActiveRecord::Base
include Tagliani::Concerns::Search
endclass Tweet < ActiveRecord::Base
taggable tag_kls: "Hashtag"
end
```*tag_kls is optional. By default it set to `Tag` model*
To attach the tag simply execute:
```ruby
tweet = Tweet.create(body: "Follow @rrubyist on Twitter")
tweet.tags.add(name: '#followme')
```To list the attached tags you can run:
```ruby
tweet.tags
```It will return you an array of `Hashtag` objects attached to the `Tweet` model.
```ruby
[#]
```If you want to search for all tweets attached to the `Hashtag` model with a name `#followme` you can use public `search` method defined in class.
*You don't have to specify `tag_kls`, unless you have multiple models that act as Tag model*
```ruby
Hashtag.search(where: { tag_name: ['#followme'], tag_kls: ['Hashtag'] }
```Tag name represents the `name` field of the `Hashtag` model.
```ruby
[#, #,
#, #]
```### More search
In fact, you can do so much more with it. You are in power of using all the abilities of ElasticSearch. For example, you can search using a `*`. You can write `pro*` and match all tags that contain this part of the word at the beginning of the name tag.
```ruby
producer.tags.search(where: { tag_name: ["pro*"] })
=> [#, #]
```## Asyncronous bulk index
For a non-blocking processes you can enable option to index jobs in background queue.
```ruby
class Artist < ActiveRecord::Base
has_many :albums
tagliani async: true
end
```To index in bulks, simply execute:
```ruby
Tagliani::Search::Index.bulk!
```## Inherit tags from models
You can specify the models you want to inherit tags from by adding an option `:inherit` with a list of models in the `taggable` method.
```ruby
class Album < ActiveRecord::Base
has_many :songs
belongs_to :artist
belongs_to :producertaggable inherit: %i[artist producer]
end
```## Contributing
Bug reports and pull requests are welcome on GitHub at https://github.com/rudkovskyi/tagliani. This project is intended to be a safe, welcoming space for collaboration, and contributors are expected to adhere to the [Contributor Covenant](http://contributor-covenant.org) code of conduct.
## License
The gem is available as open source under the terms of the [MIT License](https://opensource.org/licenses/MIT).
## Code of Conduct
Everyone interacting in the Tagliani project’s codebases, issue trackers, chat rooms and mailing lists is expected to follow the [code of conduct](https://github.com/rudkovskyi/tagliani/blob/master/CODE_OF_CONDUCT.md).