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

Readme

Keywords

none

Package Sidebar

Install

npm i happner-elastic-proxy

Weekly Downloads

4

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