happner-elastic-proxy

8.0.0 • Public • Published

happner elastic proxy

prerequisites:

node v7+

npm

run the 3 services

OPTION 1: Install and run services

elasticsearch 5.4
kibana 5.4
redis server

OPTION 2: Start services up in dockers

docker-compose up

installation instructions:

#install deps
npm install happner-elastic-proxy
#test run
npm test

run the service locally:
git clone https://github.com/happner/happner-elastic-proxy.git && cd happner-elastic-proxy && npm install && node service/start proxy

running the proxy service:

assuming kibana and elasticsearch is on the same machine, and we have all the prerequisites installed:
  1. modify kibana.yml:

elasticsearch.url: "http://localhost:55555"
elasticsearch.customHeaders: { "kibana_server_secret" : "username=_ADMIN&password=happn" }
elasticsearch.requestHeadersWhitelist: [ authorization, cookie ]

  1. download and run proxy:
> git clone https://github.com/happner/happner-elastic-proxy.git && cd happner-elastic-proxy && npm install

> node service/start proxy

# to start the proxy with non-default settings:

> node service/start proxy=proxy.port=55555,proxy.target=http://localhost:9200,proxy.log_output=true,proxy.log_output_errors_only=true

# if log_output=true - requests are logged to the console
# the elasticURL is adjusted to point to the elastic service, elastic requests are proxied to
  1. navigate to http://localhost:4444/app/kibana and check proxy-ing is working.

running the proxy as a component:

npm i happner-elastic-proxy --save
//starts the proxy service, we test pushing requests through it to elasticsearch, default listen port 55555 and target http://localhost:9200

var Service = require('happner-elastic-feed');

var proxyConfig = {};

var proxyService = new Service();

var http = require('http');

proxyService

    .proxy(proxyConfig)

    .then(function () {

      http.get({
        host: 'localhost',
        port: 55555,
        path: '/_cat/indices?v'
      }, function(res) {

        var body = '';

        res.on('data', function(chunk) {
          body += chunk;
        });

        res.on('end', function() {

          console.log('successfully queried :::', body);

          proxyService.stop()
            .then(function(){
              done();
            })
            .catch(done)
        });

      }).on('error', function(e) {
        done(e);
      });
    })
    .catch(function(e){
      done(e);
    })

for detailed proxy usage have a look at the tests.

Happner setup instructions in more detail here.

running the system as a component:

npm i happner-elastic-proxy --save
var Service = require('happner-elastic-proxy');

var service = new Service();

var proxyConfig = {

};

service
.proxy(proxyConfig)
.then(function () {
 //do something else
})

TODOS:

  • finish performance analysis tagging proxy
  • create proxy with permissions check

/happner-elastic-proxy/

    Package Sidebar

    Install

    npm i happner-elastic-proxy

    Weekly Downloads

    6

    Version

    8.0.0

    License

    none

    Unpacked Size

    73.7 kB

    Total Files

    33

    Last publish

    Collaborators

    • leebow
    • bsahli77
    • justin.koevort
    • gear4s
    • gideon-daniels
    • keeganfrieslaar
    • vladimir1990
    • justin_creighton
    • henno.esterhuyse
    • simonbishopza
    • biancaferreira
    • erasmusjw
    • amirshap
    • rnieuwoudt
    • johanvdwest
    • csampsonza
    • mrstruwig
    • smc-admin
    • jeggers
    • cyrussalem
    • dbacon
    • cordell.calitz
    • smc-tenacious