Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

@mands/mns-fe-server

Package Overview
Dependencies
Maintainers
1
Versions
26
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@mands/mns-fe-server

A server, wrapping Express for use within M&S front-end projects.

  • 2.2.2
  • unpublished
  • Source
  • npm
  • Socket score

Version published
Weekly downloads
0
Maintainers
1
Weekly downloads
 
Created
Source

mns-fe-server

This module is a wrapper around the node Express.js server. It takes a single configuration object with the following properties:

NameTypeDescription
assetsDirstringDir to serve static files such as images, CSS files, and JavaScript files
jsonLoggingfunctionFunction used for logging events, can be used with @mands/mns-fe-foundation/src/components/logger
loggerbooleanEnable or Disable logging
routesDirfunctionA function that returns the path to the routes directory
handlebarsobjectHandlebars view engine object
pageNotFoundHandlerfunctionA mapping to a handler for 404 status events
errorPageHandlerfunctionA mapping to a handler for 500 status events
ExposeRoutesfunctionFunction which returns a dir with the exposed routes

Install the server:

npm install --save @mands/mns-fe-server

Include the module and start:

const config = require('./configuration/server')
let server = require('@mands/mns-fe-server')(config)
server.start()

Here's an example configuration object to get you started.

Automatic publishing with Semantic Release

The pipeline is configured to use the semantic release tool with the eslint default rules.

Commits Must be in a specific format: <Keyword>: <Your commit message>.Note keyword is case sensitive.

You must use this format for your commit message to be in change-log and at least one commit should use this format for release.

The following keywords are allowed:

 ESLint Rules:
 
 Breaking = Major Release
 Fix      = Patch Release
 Update   = Minor Release
 New      = Minor Release
  • When a PR is merged to master the commit messages are analysed and the npm version number is automatically incremented
  • This allows better control over the release process
  • Commits can be made without necessarily publishing a package to npm
  • When we do publish to npm, the version of the published package now accurately reflects the changes made
  • When a merge contains multiple commits the highest rule will be used

Manual semantic release

There may be times when you would like to publish a version manually as shown below:

     export GH_TOKEN=<String>
     export NPM_TOKEN=<String>
   
     npm run semantic-release 

These tokens can be retrieved from the vault:

      gh-token  = mns-fe-server.git_token (GitHub auth token)
      npm-token = mns-fe-server.npm_token (NPM token)

If you would like to test the commit analyser without actually releasing a new version use the --dry-run flag

    npm run semantic-release -- --dry-run

For application specific middlewares

  • Write a method name middlewares in config/server.js just like method routes. For example:
const middleware = require('<path to middleware>');

const middlewares = server => {
    server.use(middleware);
}

module.exports = {
    middlewares,
    analyticsEnv,
    env,
    routes,
    assetsDir,
    jsonLogging,
    ...
    ...
}

FAQs

Package last updated on 17 Jul 2018

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc