Skip to content

Berkmann18/ServerBuilder

Folders and files

NameName
Last commit message
Last commit date

Latest commit

Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 

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. Fore more details, please check the contribution guideline.

Contributors


Maximilian Berkmann

πŸ› πŸ’» πŸ“– πŸ€” πŸ’¬ πŸ‘€ πŸ›‘οΈ ⚠️

Dependabot

πŸ”§

Semantic Release Bot

πŸ“– πŸ“¦

Snyk bot

πŸ›‘οΈ

License

MIT