TupperwareJS
TupperwareJS is a dependency injection system for NodeJS that can be used in either functional or object-oriented contexts.
Getting Started
Install via npm
using the following command in Terminal:
npm install --save tupperware
Object Usage
var tupperware = var container = tupperware
set( name [, options], value )
Adds a new value to your container's registry.
container container
Storing Functions as Values
By default, TupperwareJS stores functions as resolvable factories. If you want to store a function that will simply be returned (without be called), you can use the isValue
option to store it as a value.
container
Explicitly Define Argument Names
If you're planning on doing anything that obscures the argument names for a function (namely, minification), then you'll want to provide the names manually. You can do this using the inject
option which should be an array of argument names.
container
get( name [, options] )
Resolves a set function's dependencies (and their dependencies) and then returns the value. It should be noted that stored functions (that are not values) will cache their result and that result will be used for all subsequent requests.
container// => `foobar`
Factories
One added bonus of TupperwareJS is that any stored value can be returned as a factory object. Simply suffix the name of the argument with Factory
and use the make()
function when creating new instances of the value you are resolving.
container container
Optional Arguments
Sometimes, you might want to make certain arguments optional. Using the optional
option allows you to specify an array of argument names that will insert null
if a specified argument can't be resolved.
var result = container// => 'no foo set yet'
Overriding Resolved Values
Coming soon.
inject( [options, ] fn )
Automatically determines the dependencies of the given function and resolves them without the need of registering the function with the container.
container// => `foobarbaz`
provide( name, [options] )
Packages a container value into a function that can be called / resolve without the container
object.
var bar = container // => `foobar`
Functional Usage
Coming soon.
register( registry, name, [options, ] value )
Identical to set()
above, except that a registry object is needed as the
first argument.
var register = tupperwareregistervar registry = {} registry// => 'foo'
resolve( registry, name [, options] )
Indentical to get()
above, except that a registry object is needed as the first argument.
var resolve = tupperwareresolvevar registry = foo: 'bar' var foo = // => 'bar'
inject( registry, fn [, options] )
Identical to inject()
above, except that a registry object is needed as the first argument.
var inject = tupperwareinjectvar registry = name: 'world' var result = // => 'hello world'
provide( registry, name [, options] )
Identical to provide()
above, except that a registry object is needed as the first argument.
var provide = tupperwareprovidevar registry = foo: 'bar' var result = // => 'bar'
annotate( fn )
Returns an array containing all of the argument names for the given function.
var annotate = tupperwareannotate var args = // => ['foo', 'bar']