node package manager

Introducing npm Enterprise add-ons. Integrate third-party dev tools into npm…


A collection of tools for Workers


A collection of tools for Workers

Shed provides some simple helpers for use in creating your own service workers. If you're not sure what service workers are or what they are for, start with the explainer doc.

From your registering page, register your service worker in the normal way. For example:

navigator.serviceWorker.register('my-servic-worker.js', {scope: '/'});

For even lower friction, if you don't intend to doing anything more fancy than just registering with a default scope, you can instead include the Shed companion script in your HTML:

<script src="/path/to/shed/companion.js" data-service-worker="my-service-worker.js"></script>

As currently implemented in Chrome 40, a service worker must exist at the root of the scope that you intend it to control, or higher. So if you want all of the pages under /myapp/ to be controlled by the worker, the worker script itself must be served from either / or /myapp/. The default scope is the containing path of the service worker script.

In your service worker you just need to use importScripts to load Shed

importScripts('../shed/dist/shed.js'); // Update path to match your own setup 
// shed.router has get, put, post, delete, head and any methods, matching HTTP 
// verbs. It uses ExpressJS style route syntax 
shed.router.get('/myapp/index.html', function(request, keys) {
  return new Response('Handled a request for /myapp/index.html');
// The built-in handlers are networkFirst, networkOnly, cacheFirst, cacheOnly 
// and fastest. The networkFirst, cacheFirst and fastest handlers will update 
// the cached version if a response is fetched from the network. 
shed.router.get('/myapp/index.html', shed.networkFirst); // Try the network, fallback to cache 
shed.router.get('/myapp/index.html', shed.networkOnly); // Try the network, fail if not available 
shed.router.get('/myapp/index.html', shed.cacheFirst); // Try the cache, fallback to network if not in the cache 
shed.router.get('/myapp/index.html', shed.cacheOnly); // Try the cache, fail if not cached 
shed.router.get('/myapp/index.html', shed.fastest); // Request from the cache and the network, return which ever comes back first 
// You can use relative URLs, which are relative to the scope of the worker 
shed.router.get(':foo/:bar', shed.networkOnly);
// For requests to other origins, pass the origin in the parameters to the route'/(.*)', shed.networkFirst, {origin: ''});
// Origins can be specified as a RegExp'/(.*)', shed.networkFirst, {origin: /https:\/\/.*\.example\.com/});
// At the moment, if the fetch is for a URL that doesn't match a route, you get 
// some default behaviour. The 'default default' is networkOnly, but you can 
// change it like so: 
shed.router.default = shed.cacheFirst;
// If you want some resources to be cached during the install event, specify 
// them with the precache method 
shed.precache(['/index.html', '/site.css', '/images/logo.png']);
// You can manually add or remove things from the cache 
// You can pass options to most methods 
// The `debug` option turns on verbose console logging 
shed.router.get('/example/route/', shed.cacheFirst, {debug: true});
// The `cache` option tells shed to use an alternative cache. Provide the string name of the cache, not a Cache object. 
shed.cache('/images/foo.png', {cache: 'my other cache'});
// These can also be set globally 
shed.options.debug = true;
shed.options.cache = 'main cache';