Skip to content

jonschlinkert/plasma-cache

Repository files navigation

plasma-cache NPM version

Object cache for Plasma.

Install

Install with npm

$ npm i plasma-cache --save

Install with bower

$ bower install plasma-cache --save

Usage

var PlasmaCache = require('plasma-cache');
var cache = new PlasmaCache();

API

Initialize a new PlasmaCache.

Extend the data object with the value returned by plasma.

See the plasma documentation for all available options.

Params

  • data {Object|String|Array}: File path(s), glob pattern, or object of data.
  • options {Object}: Options to pass to plasma.

Example

cache
  .plasma({foo: 'bar'}, {baz: 'quux'});
  .plasma({fez: 'bang'});

Register a dataLoader that will read and load data from files with the given ext.

Params

  • ext {String}: The extension of files to read.
  • fn {String}: The loader function

Example

var fs = require('fs');
var yaml = require('js-yaml');

plasma.dataLoader('yml', function (fp) {
  var str = fs.readFileSync(fp, 'utf8');
  return yaml.safeLoad(str);
});

Use expander to recursively expand template strings into their resolved values.

Params

  • lookup {*}: Any value to process, usually strings with a cache template, like <%= foo %> or ${foo}.
  • opts {*}: Options to pass to Lo-Dash _.template.

Example

cache.process({a: '<%= b %>', b: 'c'});
//=> {a: 'c', b: 'c'}

If a data property is on the given data object (e.g. data.data, like when files named data.json or data.yml are used), data.data is flattened to just data

Params

  • data {Object}
  • returns {Object}: Flattened object.

Extend the cache.data object with the given data. This method is chainable.

  • returns {Object} PlasmaCache: to enable chaining

Example

cache
  .extendData({foo: 'bar'}, {baz: 'quux'});
  .extendData({fez: 'bang'});

Extend the cache.data object with data from a JSON or YAML file, or by passing an object directly - glob patterns or file paths may be used.

Params

  • values {Object|Array|String}: Values to pass to plasma.
  • process {Boolean}: If true is passed as the last argumemnt data will
  • returns {Object} PlasmaCache: to enable chaining

Example

cache
  .data({a: 'b'})
  .data({c: 'd'});

console.log(cache);
//=> {data: {a: 'b', c: 'd'}}

cache.data('*.{json,yml}');
// or
cache.data('package.json');
//=> {name: 'plasma-cache', ...}

// process config templates
cache.data({a: '<%= b %>', b: 'z'})
//=> {data: {a: 'z', b: 'z'}}

Related projects

  • config-cache: General purpose JavaScript object storage methods.
  • data-store: Easily get, set and persist config data.
  • option-cache: Simple API for managing options in JavaScript applications.
  • plasma: Load data from globs or files or directly from objects.

Running tests

Install dev dependencies:

$ npm i -d && npm test

Contributing

Pull requests and stars are always welcome. For bugs and feature requests, please create an issue

Author

Jon Schlinkert

License

Copyright © 2015 Jon Schlinkert Released under the MIT license.


This file was generated by verb-cli on June 01, 2015.

About

Object cache for Plasma.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Sponsor this project

 

Packages

No packages published