npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

@hygorchristian/ioc

v0.0.4

Published

A lightweight and flexible dependency injection container for Node.js projects.

Downloads

5

Readme

IOC - Inversion of Control

A lightweight and flexible dependency injection container for Node.js, designed to simplify the management of service dependencies in your applications. The ioc package provides a straightforward approach to implementing inversion of control, supporting singleton and transient service lifetimes, and facilitating testing with mock implementations.

Table of Contents

Features :sparkles:

  • Simple API: Intuitive methods for registering, resolving, and mocking dependencies.
  • Support for Mocks: Easily replace real implementations with mocks for testing.
  • Singletons and Transient Services: Choose between single instance (singleton) or multiple instances (transient) for your services.
  • TypeScript Support: Fully typed for excellent IntelliSense and type checking.

Installation :package:

npm install @hygorchristian/ioc
# or
yarn add @hygorchristian/ioc

Quick Start :rocket:

Creating an IoC Container

Import InversionOfControl from the package and instantiate it:

import InversionOfControl from '@hygorchristian/ioc';

// Define your container contract
interface Dependencies {
  'Core/Env': Env;
  'Service/Database': Database;
}

const ioc = new InversionOfControl<Dependencies>();

Note: The Dependencies interface is used to define the contract of your container. It should contain the keys of your services and their respective types. This is optional, but recommended for better type checking and IntelliSense.

Registering Services

Register your services with the container:

// Register a transient service
ioc.register('Core/Env', () => new Env());

// Register a service that depends on another service
ioc.register('Service/Database', dependencies => {
  const env = dependencies.use('Core/Env');
  return new Config(env);
});

// Register a singleton service that depends on another service
ioc.registerSingleton('Service/Database', dependencies => {
  const config = dependencies.use('Service/Config');
  return new Database(config);
});

Note: It's recommended to register your services in the entry point of your application, such as index.ts or app.ts if you want your dependencies to be globally available.

Resolving Services

Resolve an instance of your service:

const database = ioc.use('Service/Database');

Using Mocks for Testing

Replace implementations with mocks for testing purposes:

ioc.mock('Service/Database', () => new MockDatabase());
ioc.enableMocks();
const mockDatabase = ioc.use('Service/Database');

Documentation :books:

For detailed documentation, including advanced features and examples, visit GitHub repository documentation.

Contributing :handshake:

Contributions are welcome! Please refer to the contribution guidelines for more information.

Issues and Feature Requests :mag:

Encountered a bug or have an idea? Please open an issue on the GitHub Issue Tracker.

License :balance_scale:

ioc is licensed under the MIT License. See the LICENSE file for more details.