Project

esse

0.0
The project is in a healthy, maintained state
With all elegance of Ruby and ElasticSearch flexibility this gem brings to you the best of both worlds. Provides a solid architecture allowing to easily Extract, Transform, Enrich and Load data from any data source into ElasticSearch/OpenSearch and also to search it. It is framework-agnostic, which means you can use it with any Ruby framework or even without any framework at all.
2005
2006
2007
2008
2009
2010
2011
2012
2013
2014
2015
2016
2017
2018
2019
2020
2021
2022
2023
2024
2025
 Dependencies

Development

>= 0
>= 0
~> 12.3
~> 3.12
~> 0.9.20
~> 1.20
~> 1.11, >= 1.11.5
~> 1.3
~> 3.14

Runtime

>= 0.19
 Project Readme

esse-red

esse - ElasticSearch and OpenSearch Ruby Client

build

This gem is a Ruby simple and extremely flexible client for ElasticSearch and OpenSearch based on official clients such as elasticsearch-ruby and opensearch-ruby. It's a pure Ruby implementation, framework agnostic, and due to its modular design, it's easy to extend and adapt to your needs. Esse extensions are available as separate gems. A few examples:

Components

The main idea of the gem is to be compatible with any type of datasource. It means that you can use it with ActiveRecord, Sequel, HTTP APIs, or any other data source. The gem is divided into three main components:

  • Index: The index is the main component. It's responsible for defining the index settings, mappings, and other index-level configurations. It also provides a DSL to define the next two components.
  • Repository: The repository is responsible for loading the data. One index may have more than one repo. Each repo must implement a collection. Collection is an Enumerable that iterate over the data in chunks. It may receive a given context for filtering the data that can be used in the next component.
  • Document: Each repo's collection must have a respective Document. The document is responsible for defining the document itself. It's a simple Ruby object that can be used to define the document id, routing, doc attributes.

This architecture provides a powerful ETL (Extract, Transform, Load) solution for your elasticsearch/opensearch indices.

image1

And to help you to build and interact with the index, the gem provides a CLI tool called esse. You can use it to generate index boilerplate, and to interact with index operations and elasticsearch/opensearch cluster

Bellow is an image that shows the main components and how they interact with each other.

Installation

Add this line to your application's Gemfile:

gem 'elasticsearch' # or gem 'opensearch' with specific version according to your needs
gem 'esse'

And then execute:

❯ bundle install

Or install it yourself as:

❯ gem install esse

Usage

Configuration

To get started, you need to create the configuration file with the elasticsearch/opensearch cluster connection information. You can use the CLI tool to generate the configuration file:

❯ esse install

The CLI generates the configuration file in the config/esse.rb directory. Make sure you require application dependencies in the configuration file if you need to access them in your index classes.

require_relative "../environment" unless defined?(Rails)

Esse.configure do |config|
  conf.cluster(:default) do |cluster|
    cluster.client = Elasticsearch::Client.new
  end
end

For more information about the configuration options, check out the Configuration page.

Index

Now you need to create an index class. You can use the CLI tool to generate the boilerplate:

❯ esse generate index PostsIndex

For more information about the index class, check out the Index page.

After editing the index class, you can create the index in the elasticsearch/opensearch cluster and start indexing the data. There are several ways to do that. But the easiest way is to use the index reset command from the CLI tool:

❯ esse index reset PostsIndex

Reset will create the index with the defined settings and mappings, and then it will start indexing data using the bulk API, and finally, it will point the alias to the created index name. I recommend checking out the CLI page for more information about the CLI tool.

More information

In the wiki you can find more information about the gem and how to use it. If you have any questions, feel free to open an issue or contact me on twitter.

Contributing

Bug reports and pull requests are welcome on GitHub at https://github.com/marcosgz/esse.

License

The gem is available as open source under the terms of the MIT License.