You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
Eli Perelman ea5c0e72e5 Functional refactor 8 years ago
..
neutrino-middleware-banner Switching paths to relative 8 years ago
neutrino-middleware-chunk Switching paths to relative 8 years ago
neutrino-middleware-clean Updating for latest v5 changes 8 years ago
neutrino-middleware-compile-loader Updating for latest v5 changes 8 years ago
neutrino-middleware-copy Switching paths to relative 8 years ago
neutrino-middleware-env README updates for v5 8 years ago
neutrino-middleware-eslint Updating for latest v5 changes 8 years ago
neutrino-middleware-font-loader Switching paths to relative 8 years ago
neutrino-middleware-hot Switching paths to relative 8 years ago
neutrino-middleware-html-loader Switching paths to relative 8 years ago
neutrino-middleware-html-template README updates for v5 8 years ago
neutrino-middleware-image-loader Switching paths to relative 8 years ago
neutrino-middleware-loader-merge Updating for latest v5 changes 8 years ago
neutrino-middleware-minify README updates for v5 8 years ago
neutrino-middleware-named-modules Review nits 8 years ago
neutrino-middleware-start-server Updating for latest v5 changes 8 years ago
neutrino-middleware-style-loader Switching paths to relative 8 years ago
README.md Updating for latest v5 changes 8 years ago

README.md

Middleware

The basic unit of interacting with Neutrino is middleware. In Neutrino, middleware are functions that are provided a Neutrino instance for the intent of modifying configuration, listening for events, getting build metadata, or augmenting with custom functionality. At its simplest, a middleware function accepts a Neutrino instance argument and does nothing:

function middleware(neutrino) {}

A middleware function can also optionally accept an options argument which will be fed back into the middleware function when used.

function middleware(neutrino, options) {}

The signature of this function is what we call "Neutrino middleware". If you're familiar with middleware from the Express/connect world, this works similarly. When using Express middleware, you provide a function to Express which receives arguments to modify a request or response along its lifecycle. There can be a number of middleware functions that Express can load, each one potentially modifying a request or response in succession.

Neutrino will execute middleware similarly, where each middleware function successively interacts with Neutrino along the lifecycle. This is done by plugging in the middleware to Neutrino via the use() method.

const api = new Neutrino();

api.use(middleware);
api.use(middleware, options);

To use a concrete example, let's create middleware that adds an environment plugin:

const Neutrino = require('neutrino');
const { EnvironmentPlugin } = require('webpack');

const api = new Neutrino();

function env(neutrino, additionalVars = []) {
  neutrino.config
    .plugin('env')
    .use(EnvironmentPlugin, ['NODE_ENV', ...additionalVars]);
}

api.use(env); // or:
api.use(env, ['SECRET_KEY']);

Loading middleware

Additional middleware can also be loaded from a middleware function. This makes their composition simpler for consumers.

// neutrino-middleware-env
const { EnvironmentPlugin } = require('webpack');

module.exports = (neutrino, additionalVars = []) => neutrino.config
  .plugin('env')
  .use(EnvironmentPlugin, ['NODE_ENV', ...additionalVars]);
// react preset (which is also middleware)
const env = require('./neutrino-middleware-env');

module.exports = neutrino => {
  neutrino.use(env, ['SECRET_KEY']);
  neutrino.use(/* next middleware */);
  neutrino.use(/* next middleware */)
};

Configuring

If your middleware requires configuration outside of the options necessary for running the middleware, use a closure technique for simplifying this for your middleware consumers. In short, your module will provide a function to consumers which, when executed, will return a Neutrino middleware function. Describing this in code:

module.exports = function wrapper(...args) {
  return function middleware(neutrino, options) {
    // do something with neutrino, options, and args
  };
};

Let's create a contrived example using our env middleware. Let's use a closure to let the consumer provide an alternate plugin name when creating the middleware:

// neutrino-middleware-env
const { EnvironmentPlugin } = require('webpack');

module.exports = (pluginName = 'env') => (neutrino, additionalVars = []) => {
    neutrino.config
      .plugin(pluginName)
      .use(EnvironmentPlugin, ['NODE_ENV', ...additionalVars]);
};
// react preset (which is also middleware)
const env = require('./neutrino-middleware-env');

module.exports = neutrino => {
  neutrino.use(env('ENV-PLUGIN'), ['SECRET_KEY']);
};

Distributing

If you would like your middleware to be used by others, feel free to publish and distribute! By putting your middleware on npm, GitHub, or another location, you can share the hard work put into abstracting away Neutrino and Webpack interactions and save everyone in the community time and effort. As long as the Neutrino CLI, other middleware, or presets can require your middleware, it puts no restrictions on where you want to host it.

Core middleware

Neutrino maintains a number of core middleware packages which aid in creating the various preset packages we also distribute. Continue onward for documentation on these various middleware packages.