itvisionsy / laravel-elastic-session by mhh1422

A laravel 5.1 session driver on elasticsearch
239
4
2
Package Data
Maintainer Username: mhh1422
Maintainer Contact: muhannad.shelleh@itvision-sy.com (Muhannad Shelleh)
Package Create Date: 2015-11-07
Package Last Update: 2017-03-23
Language: PHP
License: MIT
Last Refreshed: 2024-05-04 15:11:06
Package Statistics
Total Downloads: 239
Monthly Downloads: 0
Daily Downloads: 0
Total Stars: 4
Total Watchers: 2
Total Forks: 3
Total Open Issues: 0

Laravel Elastic Session Driver

An elastic-search based session driver for Laravel 5.1

How to use

  1. Require it via composer

    composer require itvisionsy/laravel-elastic-sessions
    
  2. Add it to the providers list in config/app.php:

    'providers' => [
    //...
    ItvisionSy\LaravelElasticSessionDriver\ElasticSessionServiceProvider::class,
    //...
    ]
    
  3. Set the correct settings in config/session.php

    "driver" => "elastic",
    "elastic" => [
        "url" => "http://localhost:9200/",
        "index" => "laravel-es-sessions",
        "type" => "session"
    ],
    "lifetime" => 30
    

    Values shown above for elastic parameter are the default values in case you did not configure.

Index/Type mapping

Elastic will detect the mapping by default, however, it is recommended to set the mapping explicitly.

You can do so manually by applying this mapping to the index and type:

{
    "index":"set_the_index",
    "type":"set_the_type",
    "body":{
        "properties":{
            "created":{"type":"date"},
            "updated":{"type":"date"},
            "data":{"type":"string","index":"no"}
        },
        "_ttl":{
            "enabled":true,
            "default":"30m"
        }
    }
}

Or simpler, the package can do it for you. You will need to tinker ./artisan tinker and then set the mapping:

\ItvisionSy\LaravelElasticSessionDriver\ElasticSessionStore::putMapping();

Please note that the putMapping() method will automatically read the values from your sessions config file including the session.lifetime value (in minutes) which will be used as the default TTL value.

Author

Muhannad Shelleh muhannad.shelleh@live.com

License

This code is published under MIT license.