Skip to content
This repository has been archived by the owner on Mar 7, 2019. It is now read-only.

Latest commit

 

History

History
95 lines (65 loc) · 2.8 KB

README.md

File metadata and controls

95 lines (65 loc) · 2.8 KB

This repository has been deprecated

Express Combo

Combo handler for express applications.

Build Status

Goals

  • register and serve static assets from a specific folder
  • register and serve static assets based on an explicit mapping to protect other files that should not be exposed
  • serve combo urls based on the static assets that were registered

Installation

Install using npm:

$ npm install express-combo

Usage

var express = require('express'),
    app = express(),
    statichandler = require('express-combo');

app.get('/static', statichandler.folder('public', 'full/path/to/folder/'));

app.get('/static', statichandler.map('protected', {
    'something/foo.js": "full/path/to/something/foo.js',
    'bar.js": "full/path/to/something/bar.js'
}));

app.get('/static', statichandler.combine({
    comboBase: '/combo~',
    comboSep: '~'
}));

The example above will allow you to access any file within the folder full/path/to/folder/ by following the route:

In this case, serving files without any protection, which means all files could be accessed. Under the hood this is equivalent to use express.static middleware. It also expose two files, but this time adding some explicit mapping for them, exposing:

It protects any other file within the those folders. It also provides a nice abstraction where filenames and paths in the filesystem are not longer relevant when it comes to serve them, and the mapping has to be explicit.

And last, but not least, it turns on the combo capabilities for all the previous registered assets, and doing so by defining the separator token. As a result, a urls like these will be valid:

Note: the /static prefix is optional, and you can remove it all together, and even use app.use() directly for those middleware.

TODO

  • support custom filters (regex) to include and/or exclude assets thru folder and map.
  • css relative path correction when serving thru combo

License

This software is free to use under the Yahoo! Inc. BSD license. See the LICENSE file for license text and copyright information.

Contribute

See the CONTRIBUTE file for info.