alpha-dic
Version:
Asynchronous dependency injection container
94 lines (75 loc) • 2.79 kB
Markdown
# Alpha DIC
[](https://travis-ci.org/wookieb/alpha-dic)
[](https://coveralls.io/github/wookieb/alpha-dic?branch=master)
Flexible Dependency Injection Container with support for asynchronous service creation, annotations and middlewares.
Features:
* Autowiring
* Supports middlewares
* Allows to define service as constructor, (async) factory or a value
* Detects cycle dependencies
* Prevents race condition for concurrent service requests
* Supports annotations (and ability to search services by annotations)
* Simple service definition via container methods or decorators
# Installation
```bash
npm install alpha-dic
```
# Example
```typescript
import {createStandard} from 'alpha-dic';
const container = createStandard();
// if you're defining services via decorators
// preloadServiceModules(container, './path/to/service/modules/*')
container.definitionWithFactory('my-service', async () => {
const connection = new DatabaseConnection();
await connection.connect();
return connection;
});
container.get('my-service').then((connection) => {
// connection has been established in factory
});
```
Example with dependencies and decorators
```typescript
import {createStandard, reference, AutowiredService, Service, OnActivation} from 'alpha-dic';
import * as assert from 'assert';
const container = createStandard();
class NotificationCenter {
constructor(renderer: EmailRenderer, sender: EmailSender) {
assert.ok(renderer instanceof EmailRenderer);
// connection to SMTP was established in factory
assert.ok(sender instanceof EmailSender);
}
async sendEmail(to, type, vars) {
// render email
// send it via sender
}
}
class EmailRenderer {
}
class EmailSender {
}
container.get('NotificationCenter')
.then((centre) => {
return centre.sendEmail('admin@example.com', 'limits-exceeded', {})
})
```
* [Simple usage rules](./docs/rules.md)
* [Defining services](./docs/defining-services.md)
* [Decorators](./docs/decorators.md)
* [Annotations](./docs/annotations.md)
* [Middlewares](./docs/middlewares.md)
* [Hierarchical container](./docs/hierarchical-di.md)
* [Injecting configuration values](./docs/configuration.md)
* [Hooks - , onActivation](./docs/on-activation.md)
* [Deprecating services](./docs/deprecating.md)
* [Autowiring](./docs/autowiring.md)
* [Big projects tips](./docs/big-project-tips.md)
* [Example](./example)