New Research: Supply Chain Attack on Axios Pulls Malicious Dependency from npm.Details
Socket
Book a DemoSign in
Socket

abstractfactory

Package Overview
Dependencies
Maintainers
1
Versions
6
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

abstractfactory

Copyright (c) 2017 David Betz

latest
npmnpm
Version
1.0.5
Version published
Weekly downloads
8
14.29%
Maintainers
1
Weekly downloads
 
Created
Source

Abstract Factory for JavaScript

Copyright (c) 2017 David Betz

license Build Status npm version coverage Say Thanks!

See test/provider.js unit test for usage.

Basically an implementation of an abstract factory pattern.

In one system where I use this, I create factories for eachs type of thing in my system. So, SearchFactory, CloudStorageFactory, QueueFactory, AristotleFactory, etc... These would implement for ID interface like ICloudStorageProvider (in Node, it's just a class).

Each of these would have their own switch/case (or whatever) to create the factory for it. So, for example, I may have config in a YAML file specifying that I want to use Mongo for my Aristotle provider ("Aristotle" is what most people incorrectly call "NoSQL").

To begin, create the factory (do this one for the entirety of your system):

const abstractFactory = new AbstractFactory()

Then, add your factories:

    abstractFactory.set(SearchFactory)
    abstractFactory.set(CloudStorageFactory)
    abstractFactory.set(QueueFactory)
    abstractFactory.set(AristotleFactory)

When the time comes, just ask for your provider:

provider = abstractFactory.resolve(IAristotleProvider)

Your code SHOULD. NOT. CARE. ABOUT. MONGO. It should the your configuration or something handle that. Don't tightly couple your providers.

Also note that the resolver also accepts various arguments for extra flexibility:

provider = abstractFactory.resolve(IAristotleProvider, "alternateConnectionString", { "collection": "log" })

Despite what random bloggers say, service locators are awesome and provide excellent decoupling.

Look at the Mock examples provided with the tests; they're rather extensive.

FAQs

Package last updated on 10 Aug 2017

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts