Skip to content

Berkmann18/ServerBuilder

Repository files navigation

ServerBuilder

NPM Inline docs

devDependencies Status dependencies Status

GH Downloads GitHub commit activity the past year GitHub contributors Github search hit counter

Build Status codecov.io Code Coverage mocha Known Vulnerabilities

GitHub contributions welcome Commitizen friendly Dependabot Status

GitHub top language GitHub language count GitHub code size in bytes

BCH compliance Codacy Badge

It's a simple NodeJS/Express server builder allowing you to get a working server up in just a few lines.

Install

To install it you need to run the following:

npm i serverbuilder

Note: Don't forget to use -g, --save, --save-dev if appropriate.

Usage

  • Using HTTP/1:
const app = require('express')(),
      Server = require('serverbuilder');
let options = {
  name: 'My Server',
  callback(server) {
    app.set('port', server.port);
  },
  publicIP: true
};

new Server(app, process.env.PORT || 3e3, options);
  • Or with HTTPS/1:
const fs = require('fs'),
      app = require('express')(),
      Server = require('serverbuilder');

let options = {
  name: 'My Server',
  useHttps: true,
  securityOptions: {
    key: fs.readFileSync('server-key.pem'),
    cert: fs.readFileSync('server-cert.pem')
  }
  callback(server) {
    app.set('port', server.port);
  },
  publicIP: true
};

new Server(app, process.env.PORT || 3e3, options);
  • Or with HTTP/2:
const fs = require('fs'),
      app = require('express')(),
      Server = require('serverbuilder');

let options = {
  name: 'My Server',
  useHttp2: true,
  securityOptions: {
    key: fs.readFileSync('server-key.pem'),
    cert: fs.readFileSync('server-cert.pem')
  }
  callback(server) {
    app.set('port', server.port);
  },
  publicIP: true
};

new Server(app, process.env.PORT || 3e3, options);

Contribution

If you discover bugs, errors or/and have suggestions/feedback please create an issue or/and submit a PR.

If you want to contribute, make sure you stick with the coding style that ESLint is enforcing (cf. configuration file). To check if a file stick to the standards:

eslint -c ./config/.eslintrc.js yourFile.js
#Or `npm lint` if appropriate

To fix formatting errors and such, run: Same as above but with --fix at the end.

License

MIT