Skip to content

A plugin to connect to Elasticsearch and persist elements via hooks

License

Notifications You must be signed in to change notification settings

fork/craft-elastica

Repository files navigation

Table of contents


Features

  • Index entries and other elements in Elasticsearch
  • Customize Index data structures via hooks
  • Define Index Templates to configure the Index and its fields and mapping in Elasticsearch
  • Re-Index contents via utility or console command

Requirements

  • Craft CMS >= 3.5.x

Setup

1. Install

Install the package

cd /path/to/project
composer require fork/craft-elastica

2. Configuration

Go to the plugin settings page and enter a index prefix name which is prepended to the indexes beeing created in Elasticsearch. The name of the index is generated from this prefix. Also provide the hostname of the elasticsearch instance.

Usage

To generate the data to index register event handlers in your own module or plugin class like this:

// initialize elasticsearch indexer
Event::on(
   Indexer::class,
   Indexer::EVENT_INDEXER_INIT,
   function (IndexerInitEvent $event) {
       $event->addSectionHandles([
           'articles',
       ]);
       $event->addCategoryGroupHandles([
           'topics',
       ]);
   }
);
// build elasticsearch index data
Event::on(
   Indexer::class,
   Indexer::EVENT_BEFORE_INDEX_DATA,
   function (IndexEvent $event) {
       // build your custom data structure to index
       $indexData = MyCustomPlugin::$plugin->mySearchService->getIndexData($event->sender);
       $event->indexData = $indexData;
   }
);

Roadmap

  • Logo
  • Index categories
  • Maybe include search proxy
  • Exclude sites via settings
  • Show index info / test index in utility
  • More documentation

Fork Logo

Brought to you by Fork Unstable Media GmbH