ts-ioc-container 25.0.11 → 25.2.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +44 -0
- package/cjm/container/AutoMockedContainer.d.ts +1 -0
- package/cjm/container/AutoMockedContainer.js +3 -0
- package/cjm/container/AutoMockedContainer.js.map +1 -1
- package/cjm/container/Container.d.ts +1 -0
- package/cjm/container/Container.js +9 -0
- package/cjm/container/Container.js.map +1 -1
- package/cjm/container/EmptyContainer.d.ts +1 -0
- package/cjm/container/EmptyContainer.js +3 -0
- package/cjm/container/EmptyContainer.js.map +1 -1
- package/cjm/container/IContainer.d.ts +1 -0
- package/cjm/index.d.ts +2 -1
- package/cjm/index.js +9 -1
- package/cjm/index.js.map +1 -1
- package/cjm/provider/IProvider.d.ts +7 -1
- package/cjm/provider/IProvider.js +11 -0
- package/cjm/provider/IProvider.js.map +1 -1
- package/cjm/provider/Provider.d.ts +4 -1
- package/cjm/provider/Provider.js +10 -0
- package/cjm/provider/Provider.js.map +1 -1
- package/cjm/provider/ProviderDecorator.d.ts +3 -1
- package/cjm/provider/ProviderDecorator.js +7 -0
- package/cjm/provider/ProviderDecorator.js.map +1 -1
- package/esm/container/AutoMockedContainer.d.ts +1 -0
- package/esm/container/AutoMockedContainer.js +3 -0
- package/esm/container/AutoMockedContainer.js.map +1 -1
- package/esm/container/Container.d.ts +1 -0
- package/esm/container/Container.js +9 -0
- package/esm/container/Container.js.map +1 -1
- package/esm/container/EmptyContainer.d.ts +1 -0
- package/esm/container/EmptyContainer.js +3 -0
- package/esm/container/EmptyContainer.js.map +1 -1
- package/esm/container/IContainer.d.ts +1 -0
- package/esm/index.d.ts +2 -1
- package/esm/index.js +9 -1
- package/esm/index.js.map +1 -1
- package/esm/provider/IProvider.d.ts +7 -1
- package/esm/provider/IProvider.js +11 -0
- package/esm/provider/IProvider.js.map +1 -1
- package/esm/provider/Provider.d.ts +4 -1
- package/esm/provider/Provider.js +10 -0
- package/esm/provider/Provider.js.map +1 -1
- package/esm/provider/ProviderDecorator.d.ts +3 -1
- package/esm/provider/ProviderDecorator.js +7 -0
- package/esm/provider/ProviderDecorator.js.map +1 -1
- package/package.json +2 -2
package/README.md
CHANGED
|
@@ -34,6 +34,7 @@
|
|
|
34
34
|
- [Singleton provider](#singleton-provider)
|
|
35
35
|
- [Tagged provider](#tagged-provider)
|
|
36
36
|
- [Args provider](#args-provider)
|
|
37
|
+
- [Aliases](#aliases) `alias`
|
|
37
38
|
- [Container modules](#container-modules)
|
|
38
39
|
- [Basic usage](#basic-usage-1)
|
|
39
40
|
- [Registration module (Provider + DependencyKey)](#registration-module-provider--dependencykey) `@key`
|
|
@@ -482,6 +483,49 @@ describe('ArgsProvider', function () {
|
|
|
482
483
|
|
|
483
484
|
```
|
|
484
485
|
|
|
486
|
+
### Aliases
|
|
487
|
+
Sometimes you want to register the same provider with different keys. This is what `Aliases` is for.
|
|
488
|
+
- `@provider(alias('logger'))` helper assigns `logger` alias to provider.
|
|
489
|
+
- `bySomeAlias('logger', 'a')` method resolves the same provider with different keys. (logger OR a)
|
|
490
|
+
- `byAllAlias('logger', 'a')` method resolves to resolve the same provider with different keys. (logger AND a)
|
|
491
|
+
|
|
492
|
+
```typescript
|
|
493
|
+
import 'reflect-metadata';
|
|
494
|
+
import { alias, bySomeAlias, Container, inject, Provider, provider, ReflectionInjector } from 'ts-ioc-container';
|
|
495
|
+
|
|
496
|
+
describe('alias', () => {
|
|
497
|
+
it('should create an alias', () => {
|
|
498
|
+
interface ILogger {
|
|
499
|
+
name: string;
|
|
500
|
+
}
|
|
501
|
+
|
|
502
|
+
@provider(alias('ILogger'))
|
|
503
|
+
class FileLogger implements ILogger {
|
|
504
|
+
name = 'FileLogger';
|
|
505
|
+
}
|
|
506
|
+
|
|
507
|
+
@provider(alias('ILogger'))
|
|
508
|
+
class DbLogger implements ILogger {
|
|
509
|
+
name = 'DbLogger';
|
|
510
|
+
}
|
|
511
|
+
|
|
512
|
+
class App {
|
|
513
|
+
constructor(@inject(bySomeAlias('ILogger')) public loggers: ILogger[]) {}
|
|
514
|
+
}
|
|
515
|
+
|
|
516
|
+
const container = new Container(new ReflectionInjector())
|
|
517
|
+
.register('IFileLogger', Provider.fromClass(FileLogger))
|
|
518
|
+
.register('IDbLogger', Provider.fromClass(DbLogger));
|
|
519
|
+
|
|
520
|
+
const app = container.resolve(App);
|
|
521
|
+
|
|
522
|
+
expect(app.loggers[0]).toBeInstanceOf(FileLogger);
|
|
523
|
+
expect(app.loggers[1]).toBeInstanceOf(DbLogger);
|
|
524
|
+
});
|
|
525
|
+
});
|
|
526
|
+
|
|
527
|
+
```
|
|
528
|
+
|
|
485
529
|
## Container modules
|
|
486
530
|
Sometimes you want to encapsulate registration logic in separate module. This is what `IContainerModule` is for.
|
|
487
531
|
|
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
import { IContainer, InjectionToken, IProvider, DependencyKey, Tag, IContainerModule } from '../index';
|
|
2
2
|
export declare abstract class AutoMockedContainer implements IContainer {
|
|
3
|
+
getTokensByProvider(predicate: (provider: IProvider<unknown>) => boolean): DependencyKey[];
|
|
3
4
|
createScope(...tags: Tag[]): IContainer;
|
|
4
5
|
abstract resolve<T>(key: InjectionToken<T>): T;
|
|
5
6
|
dispose(): void;
|
|
@@ -3,6 +3,9 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
3
3
|
exports.AutoMockedContainer = void 0;
|
|
4
4
|
const index_1 = require("../index");
|
|
5
5
|
class AutoMockedContainer {
|
|
6
|
+
getTokensByProvider(predicate) {
|
|
7
|
+
return [];
|
|
8
|
+
}
|
|
6
9
|
createScope(...tags) {
|
|
7
10
|
throw new index_1.MethodNotImplementedError();
|
|
8
11
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"AutoMockedContainer.js","sourceRoot":"","sources":["../../lib/container/AutoMockedContainer.ts"],"names":[],"mappings":";;;AAAA,oCAQkB;AAElB,MAAsB,mBAAmB;IACvC,WAAW,CAAC,GAAG,IAAW;QACxB,MAAM,IAAI,iCAAyB,EAAE,CAAC;IACxC,CAAC;IAID,OAAO,KAAU,CAAC;IAElB,2BAA2B;QACzB,OAAO,IAAI,GAAG,EAAE,CAAC;IACnB,CAAC;IAED,QAAQ,CAAC,GAAkB,EAAE,KAAgB;QAC3C,MAAM,IAAI,iCAAyB,EAAE,CAAC;IACxC,CAAC;IAED,YAAY;QACV,OAAO,EAAE,CAAC;IACZ,CAAC;IAED,WAAW,KAAU,CAAC;IAEtB,GAAG,CAAC,MAAwB;QAC1B,MAAM,IAAI,iCAAyB,EAAE,CAAC;IACxC,CAAC;IAED,eAAe;QACb,OAAO,IAAI,GAAG,EAAE,CAAC;IACnB,CAAC;IAED,MAAM,CAAC,GAAQ;QACb,OAAO,KAAK,CAAC;IACf,CAAC;CACF;
|
|
1
|
+
{"version":3,"file":"AutoMockedContainer.js","sourceRoot":"","sources":["../../lib/container/AutoMockedContainer.ts"],"names":[],"mappings":";;;AAAA,oCAQkB;AAElB,MAAsB,mBAAmB;IACvC,mBAAmB,CAAC,SAAoD;QACtE,OAAO,EAAE,CAAC;IACZ,CAAC;IAED,WAAW,CAAC,GAAG,IAAW;QACxB,MAAM,IAAI,iCAAyB,EAAE,CAAC;IACxC,CAAC;IAID,OAAO,KAAU,CAAC;IAElB,2BAA2B;QACzB,OAAO,IAAI,GAAG,EAAE,CAAC;IACnB,CAAC;IAED,QAAQ,CAAC,GAAkB,EAAE,KAAgB;QAC3C,MAAM,IAAI,iCAAyB,EAAE,CAAC;IACxC,CAAC;IAED,YAAY;QACV,OAAO,EAAE,CAAC;IACZ,CAAC;IAED,WAAW,KAAU,CAAC;IAEtB,GAAG,CAAC,MAAwB;QAC1B,MAAM,IAAI,iCAAyB,EAAE,CAAC;IACxC,CAAC;IAED,eAAe;QACb,OAAO,IAAI,GAAG,EAAE,CAAC;IACnB,CAAC;IAED,MAAM,CAAC,GAAQ;QACb,OAAO,KAAK,CAAC;IACf,CAAC;CACF;AAtCD,kDAsCC"}
|
|
@@ -15,6 +15,7 @@ export declare class Container implements IContainer, Tagged {
|
|
|
15
15
|
});
|
|
16
16
|
register(key: DependencyKey, provider: IProvider): this;
|
|
17
17
|
resolve<T>(token: InjectionToken<T>, ...args: unknown[]): T;
|
|
18
|
+
getTokensByProvider(predicate: (provider: IProvider) => boolean): DependencyKey[];
|
|
18
19
|
createScope(...tags: Tag[]): Container;
|
|
19
20
|
dispose(): void;
|
|
20
21
|
getInstances(): unknown[];
|
|
@@ -30,6 +30,15 @@ class Container {
|
|
|
30
30
|
const provider = this.providers.get(token);
|
|
31
31
|
return (provider === null || provider === void 0 ? void 0 : provider.isValid(this)) ? provider.resolve(this, ...args) : this.parent.resolve(token, ...args);
|
|
32
32
|
}
|
|
33
|
+
getTokensByProvider(predicate) {
|
|
34
|
+
const keys = new Set(this.parent.getTokensByProvider(predicate));
|
|
35
|
+
for (const [key, provider] of this.providers) {
|
|
36
|
+
if (predicate(provider)) {
|
|
37
|
+
keys.add(key);
|
|
38
|
+
}
|
|
39
|
+
}
|
|
40
|
+
return Array.from(keys);
|
|
41
|
+
}
|
|
33
42
|
createScope(...tags) {
|
|
34
43
|
this.validateContainer();
|
|
35
44
|
const scope = new Container(this.injector, { parent: this, tags });
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Container.js","sourceRoot":"","sources":["../../lib/container/Container.ts"],"names":[],"mappings":";;;AAAA,6CAAuH;AAGvH,qDAAkD;AAClD,qEAAkE;AAElE,MAAa,SAAS;IAQpB,YAA6B,QAAmB,EAAE,UAAiD,EAAE;;QAAxE,aAAQ,GAAR,QAAQ,CAAW;QAPvC,cAAS,GAAG,IAAI,GAAG,EAA4B,CAAC;QAEjD,eAAU,GAAG,KAAK,CAAC;QAEnB,WAAM,GAAoB,IAAI,GAAG,EAAE,CAAC;QACpC,cAAS,GAAiB,IAAI,GAAG,EAAE,CAAC;QAG1C,IAAI,CAAC,MAAM,GAAG,MAAA,OAAO,CAAC,MAAM,mCAAI,IAAI,+BAAc,EAAE,CAAC;QACrD,IAAI,CAAC,IAAI,GAAG,MAAA,OAAO,CAAC,IAAI,mCAAI,EAAE,CAAC;IACjC,CAAC;IAED,QAAQ,CAAC,GAAkB,EAAE,QAAmB;QAC9C,IAAI,CAAC,iBAAiB,EAAE,CAAC;QACzB,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,GAAG,EAAE,QAAQ,CAAC,CAAC;QAClC,OAAO,IAAI,CAAC;IACd,CAAC;IAED,OAAO,CAAI,KAAwB,EAAE,GAAG,IAAe;QACrD,IAAI,CAAC,iBAAiB,EAAE,CAAC;QAEzB,IAAI,IAAA,0BAAa,EAAC,KAAK,CAAC,EAAE;YACxB,MAAM,QAAQ,GAAG,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC,IAAI,EAAE,KAAK,EAAE,GAAG,IAAI,CAAC,CAAC;YAC7D,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;YAC7B,OAAO,QAAQ,CAAC;SACjB;QAED,MAAM,QAAQ,GAAG,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,KAAK,CAA6B,CAAC;QACvE,OAAO,CAAA,QAAQ,aAAR,QAAQ,uBAAR,QAAQ,CAAE,OAAO,CAAC,IAAI,CAAC,EAAC,CAAC,CAAC,QAAQ,CAAC,OAAO,CAAC,IAAI,EAAE,GAAG,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,OAAO,CAAI,KAAK,EAAE,GAAG,IAAI,CAAC,CAAC;IAC5G,CAAC;IAED,WAAW,CAAC,GAAG,IAAW;QACxB,IAAI,CAAC,iBAAiB,EAAE,CAAC;QAEzB,MAAM,KAAK,GAAG,IAAI,SAAS,CAAC,IAAI,CAAC,QAAQ,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE,IAAI,EAAE,CAAC,CAAC;QACnE,KAAK,CAAC,uBAAuB,CAAC,IAAI,CAAC,CAAC;QACpC,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;QAEvB,OAAO,KAAK,CAAC;IACf,CAAC;IAED,OAAO;QACL,IAAI,CAAC,iBAAiB,EAAE,CAAC;QACzB,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC;QACvB,IAAI,CAAC,MAAM,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC;QAC9B,IAAI,CAAC,MAAM,GAAG,IAAI,+BAAc,EAAE,CAAC;QACnC,KAAK,MAAM,KAAK,IAAI,IAAI,CAAC,MAAM,EAAE;YAC/B,KAAK,CAAC,OAAO,EAAE,CAAC;SACjB;QACD,IAAI,CAAC,SAAS,CAAC,KAAK,EAAE,CAAC;QACvB,IAAI,CAAC,SAAS,CAAC,KAAK,EAAE,CAAC;IACzB,CAAC;IAED,YAAY;QACV,MAAM,SAAS,GAAc,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;QACxD,KAAK,MAAM,KAAK,IAAI,IAAI,CAAC,MAAM,EAAE;YAC/B,SAAS,CAAC,IAAI,CAAC,GAAG,KAAK,CAAC,YAAY,EAAE,CAAC,CAAC;SACzC;QACD,OAAO,SAAS,CAAC;IACnB,CAAC;IAED,MAAM,CAAC,GAAQ;QACb,OAAO,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC;IACjC,CAAC;IAED,GAAG,CAAC,MAAwB;QAC1B,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;QACrB,OAAO,IAAI,CAAC;IACd,CAAC;IAED;;OAEG;IACH,uBAAuB,CAAC,MAAkB;QACxC,KAAK,MAAM,CAAC,GAAG,EAAE,QAAQ,CAAC,IAAI,MAAM,CAAC,eAAe,EAAE,EAAE;YACtD,IAAI,QAAQ,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE;gBAC1B,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,GAAG,EAAE,QAAQ,CAAC,KAAK,EAAE,CAAC,CAAC;aAC3C;SACF;IACH,CAAC;IAED;;OAEG;IACH,eAAe;QACb,OAAO,IAAI,GAAG,CAAC,CAAC,GAAG,IAAI,CAAC,MAAM,CAAC,eAAe,EAAE,EAAE,GAAG,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC;IACxE,CAAC;IAED;;OAEG;IACH,WAAW,CAAC,KAAiB;QAC3B,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;IAC5B,CAAC;IAEO,iBAAiB;QACvB,+CAAsB,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,UAAU,EAAE,+BAA+B,CAAC,CAAC;IACnF,CAAC;CACF;
|
|
1
|
+
{"version":3,"file":"Container.js","sourceRoot":"","sources":["../../lib/container/Container.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
import { DependencyKey, IContainer, IContainerModule, InjectionToken, Tag } from './IContainer';
|
|
2
2
|
import { IProvider } from '../provider/IProvider';
|
|
3
3
|
export declare class EmptyContainer implements IContainer {
|
|
4
|
+
getTokensByProvider(predicate: (provider: IProvider<unknown>) => boolean): DependencyKey[];
|
|
4
5
|
hasTag(tag: Tag): boolean;
|
|
5
6
|
createScope(...tags: Tag[]): IContainer;
|
|
6
7
|
dispose(): void;
|
|
@@ -4,6 +4,9 @@ exports.EmptyContainer = void 0;
|
|
|
4
4
|
const MethodNotImplementedError_1 = require("./MethodNotImplementedError");
|
|
5
5
|
const DependencyNotFoundError_1 = require("./DependencyNotFoundError");
|
|
6
6
|
class EmptyContainer {
|
|
7
|
+
getTokensByProvider(predicate) {
|
|
8
|
+
return [];
|
|
9
|
+
}
|
|
7
10
|
hasTag(tag) {
|
|
8
11
|
throw new MethodNotImplementedError_1.MethodNotImplementedError();
|
|
9
12
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"EmptyContainer.js","sourceRoot":"","sources":["../../lib/container/EmptyContainer.ts"],"names":[],"mappings":";;;AACA,2EAAwE;AACxE,uEAAoE;AAGpE,MAAa,cAAc;IACzB,MAAM,CAAC,GAAQ;QACb,MAAM,IAAI,qDAAyB,EAAE,CAAC;IACxC,CAAC;IAED,WAAW,CAAC,GAAG,IAAW;QACxB,MAAM,IAAI,qDAAyB,EAAE,CAAC;IACxC,CAAC;IAED,OAAO;QACL,MAAM,IAAI,qDAAyB,EAAE,CAAC;IACxC,CAAC;IAED,QAAQ,CAAC,GAAkB,EAAE,KAAgB;QAC3C,MAAM,IAAI,qDAAyB,EAAE,CAAC;IACxC,CAAC;IAED,OAAO,CAAI,GAAsB;QAC/B,MAAM,IAAI,iDAAuB,CAAC,eAAe,GAAG,CAAC,QAAQ,EAAE,EAAE,CAAC,CAAC;IACrE,CAAC;IAED,eAAe;QACb,OAAO,IAAI,GAAG,EAAE,CAAC;IACnB,CAAC;IAED,2BAA2B;QACzB,MAAM,IAAI,qDAAyB,EAAE,CAAC;IACxC,CAAC;IAED,YAAY;QACV,OAAO,EAAE,CAAC;IACZ,CAAC;IAED,WAAW,KAAU,CAAC;IAEtB,GAAG,CAAC,MAAwB;QAC1B,MAAM,IAAI,qDAAyB,EAAE,CAAC;IACxC,CAAC;CACF;
|
|
1
|
+
{"version":3,"file":"EmptyContainer.js","sourceRoot":"","sources":["../../lib/container/EmptyContainer.ts"],"names":[],"mappings":";;;AACA,2EAAwE;AACxE,uEAAoE;AAGpE,MAAa,cAAc;IACzB,mBAAmB,CAAC,SAAoD;QACtE,OAAO,EAAE,CAAC;IACZ,CAAC;IAED,MAAM,CAAC,GAAQ;QACb,MAAM,IAAI,qDAAyB,EAAE,CAAC;IACxC,CAAC;IAED,WAAW,CAAC,GAAG,IAAW;QACxB,MAAM,IAAI,qDAAyB,EAAE,CAAC;IACxC,CAAC;IAED,OAAO;QACL,MAAM,IAAI,qDAAyB,EAAE,CAAC;IACxC,CAAC;IAED,QAAQ,CAAC,GAAkB,EAAE,KAAgB;QAC3C,MAAM,IAAI,qDAAyB,EAAE,CAAC;IACxC,CAAC;IAED,OAAO,CAAI,GAAsB;QAC/B,MAAM,IAAI,iDAAuB,CAAC,eAAe,GAAG,CAAC,QAAQ,EAAE,EAAE,CAAC,CAAC;IACrE,CAAC;IAED,eAAe;QACb,OAAO,IAAI,GAAG,EAAE,CAAC;IACnB,CAAC;IAED,2BAA2B;QACzB,MAAM,IAAI,qDAAyB,EAAE,CAAC;IACxC,CAAC;IAED,YAAY;QACV,OAAO,EAAE,CAAC;IACZ,CAAC;IAED,WAAW,KAAU,CAAC;IAEtB,GAAG,CAAC,MAAwB;QAC1B,MAAM,IAAI,qDAAyB,EAAE,CAAC;IACxC,CAAC;CACF;AA1CD,wCA0CC"}
|
package/cjm/index.d.ts
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
export { IContainer, Resolvable, IContainerModule, isDependencyKey, DependencyKey, InjectionToken, Tag, } from './container/IContainer';
|
|
2
2
|
export { constructor } from './utils';
|
|
3
3
|
export { Container } from './container/Container';
|
|
4
|
-
export { ResolveDependency, IProvider } from './provider/IProvider';
|
|
4
|
+
export { ResolveDependency, IProvider, bySomeAlias, byAllAliases, alias, byKeys } from './provider/IProvider';
|
|
5
5
|
export { IInjector } from './injector/IInjector';
|
|
6
6
|
export { DependencyNotFoundError } from './container/DependencyNotFoundError';
|
|
7
7
|
export { MethodNotImplementedError } from './container/MethodNotImplementedError';
|
|
@@ -17,3 +17,4 @@ export { ReflectionInjector, inject, by } from './injector/ReflectionInjector';
|
|
|
17
17
|
export { SimpleInjector } from './injector/SimpleInjector';
|
|
18
18
|
export { ProxyInjector } from './injector/ProxyInjector';
|
|
19
19
|
export { getHooks, hook } from './hook';
|
|
20
|
+
export { setMetadata, getMetadata } from './metadata';
|
package/cjm/index.js
CHANGED
|
@@ -1,10 +1,15 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.hook = exports.getHooks = exports.ProxyInjector = exports.SimpleInjector = exports.by = exports.inject = exports.ReflectionInjector = exports.DependencyMissingKeyError = exports.Registration = exports.key = exports.AutoMockedContainer = exports.TaggedProvider = exports.tags = exports.SingletonProvider = exports.singleton = exports.ArgsProvider = exports.args = exports.argsFn = exports.provider = exports.Provider = exports.ContainerDisposedError = exports.MethodNotImplementedError = exports.DependencyNotFoundError = exports.Container = exports.isDependencyKey = void 0;
|
|
3
|
+
exports.getMetadata = exports.setMetadata = exports.hook = exports.getHooks = exports.ProxyInjector = exports.SimpleInjector = exports.by = exports.inject = exports.ReflectionInjector = exports.DependencyMissingKeyError = exports.Registration = exports.key = exports.AutoMockedContainer = exports.TaggedProvider = exports.tags = exports.SingletonProvider = exports.singleton = exports.ArgsProvider = exports.args = exports.argsFn = exports.provider = exports.Provider = exports.ContainerDisposedError = exports.MethodNotImplementedError = exports.DependencyNotFoundError = exports.byKeys = exports.alias = exports.byAllAliases = exports.bySomeAlias = exports.Container = exports.isDependencyKey = void 0;
|
|
4
4
|
var IContainer_1 = require("./container/IContainer");
|
|
5
5
|
Object.defineProperty(exports, "isDependencyKey", { enumerable: true, get: function () { return IContainer_1.isDependencyKey; } });
|
|
6
6
|
var Container_1 = require("./container/Container");
|
|
7
7
|
Object.defineProperty(exports, "Container", { enumerable: true, get: function () { return Container_1.Container; } });
|
|
8
|
+
var IProvider_1 = require("./provider/IProvider");
|
|
9
|
+
Object.defineProperty(exports, "bySomeAlias", { enumerable: true, get: function () { return IProvider_1.bySomeAlias; } });
|
|
10
|
+
Object.defineProperty(exports, "byAllAliases", { enumerable: true, get: function () { return IProvider_1.byAllAliases; } });
|
|
11
|
+
Object.defineProperty(exports, "alias", { enumerable: true, get: function () { return IProvider_1.alias; } });
|
|
12
|
+
Object.defineProperty(exports, "byKeys", { enumerable: true, get: function () { return IProvider_1.byKeys; } });
|
|
8
13
|
var DependencyNotFoundError_1 = require("./container/DependencyNotFoundError");
|
|
9
14
|
Object.defineProperty(exports, "DependencyNotFoundError", { enumerable: true, get: function () { return DependencyNotFoundError_1.DependencyNotFoundError; } });
|
|
10
15
|
var MethodNotImplementedError_1 = require("./container/MethodNotImplementedError");
|
|
@@ -42,4 +47,7 @@ Object.defineProperty(exports, "ProxyInjector", { enumerable: true, get: functio
|
|
|
42
47
|
var hook_1 = require("./hook");
|
|
43
48
|
Object.defineProperty(exports, "getHooks", { enumerable: true, get: function () { return hook_1.getHooks; } });
|
|
44
49
|
Object.defineProperty(exports, "hook", { enumerable: true, get: function () { return hook_1.hook; } });
|
|
50
|
+
var metadata_1 = require("./metadata");
|
|
51
|
+
Object.defineProperty(exports, "setMetadata", { enumerable: true, get: function () { return metadata_1.setMetadata; } });
|
|
52
|
+
Object.defineProperty(exports, "getMetadata", { enumerable: true, get: function () { return metadata_1.getMetadata; } });
|
|
45
53
|
//# sourceMappingURL=index.js.map
|
package/cjm/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../lib/index.ts"],"names":[],"mappings":";;;AAAA,qDAQgC;AAJ9B,6GAAA,eAAe,OAAA;AAMjB,mDAAkD;AAAzC,sGAAA,SAAS,OAAA;
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../lib/index.ts"],"names":[],"mappings":";;;AAAA,qDAQgC;AAJ9B,6GAAA,eAAe,OAAA;AAMjB,mDAAkD;AAAzC,sGAAA,SAAS,OAAA;AAClB,kDAA8G;AAAvE,wGAAA,WAAW,OAAA;AAAE,yGAAA,YAAY,OAAA;AAAE,kGAAA,KAAK,OAAA;AAAE,mGAAA,MAAM,OAAA;AAE/E,+EAA8E;AAArE,kIAAA,uBAAuB,OAAA;AAChC,mFAAkF;AAAzE,sIAAA,yBAAyB,OAAA;AAClC,6EAA4E;AAAnE,gIAAA,sBAAsB,OAAA;AAC/B,gDAAyD;AAAhD,oGAAA,QAAQ,OAAA;AAAE,oGAAA,QAAQ,OAAA;AAC3B,wDAA6E;AAA5D,sGAAA,MAAM,OAAA;AAAE,oGAAA,IAAI,OAAA;AAAE,4GAAA,YAAY,OAAA;AAC3C,kEAA4E;AAAnE,8GAAA,SAAS,OAAA;AAAE,sHAAA,iBAAiB,OAAA;AACrC,4DAAiE;AAAxD,sGAAA,IAAI,OAAA;AAAE,gHAAA,cAAc,OAAA;AAC7B,uEAAsE;AAA7D,0HAAA,mBAAmB,OAAA;AAC5B,4DAAgE;AAAvD,mGAAA,GAAG,OAAA;AAAE,4GAAA,YAAY,OAAA;AAC1B,sFAAqF;AAA5E,sIAAA,yBAAyB,OAAA;AAClC,oEAA+E;AAAtE,wHAAA,kBAAkB,OAAA;AAAE,4GAAA,MAAM,OAAA;AAAE,wGAAA,EAAE,OAAA;AACvC,4DAA2D;AAAlD,gHAAA,cAAc,OAAA;AACvB,0DAAyD;AAAhD,8GAAA,aAAa,OAAA;AACtB,+BAAwC;AAA/B,gGAAA,QAAQ,OAAA;AAAE,4FAAA,IAAI,OAAA;AACvB,uCAAsD;AAA7C,uGAAA,WAAW,OAAA;AAAE,uGAAA,WAAW,OAAA"}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { Resolvable, Tagged } from '../container/IContainer';
|
|
1
|
+
import { DependencyKey, IContainer, Resolvable, Tagged } from '../container/IContainer';
|
|
2
2
|
import { MapFn } from '../utils';
|
|
3
3
|
export declare type ResolveDependency<T = unknown> = (container: Resolvable, ...args: unknown[]) => T;
|
|
4
4
|
export interface IProvider<T = unknown> {
|
|
@@ -6,4 +6,10 @@ export interface IProvider<T = unknown> {
|
|
|
6
6
|
resolve(container: Resolvable, ...args: unknown[]): T;
|
|
7
7
|
isValid(filters: Tagged): boolean;
|
|
8
8
|
pipe(...mappers: MapFn<IProvider<T>>[]): IProvider<T>;
|
|
9
|
+
hasAlias(alias: DependencyKey): boolean;
|
|
10
|
+
addAliases(...aliases: DependencyKey[]): this;
|
|
9
11
|
}
|
|
12
|
+
export declare function alias<T = unknown>(...tokens: DependencyKey[]): MapFn<IProvider<T>>;
|
|
13
|
+
export declare const bySomeAlias: (...aliases: DependencyKey[]) => (с: IContainer, ...args: unknown[]) => unknown[];
|
|
14
|
+
export declare const byAllAliases: (...aliases: DependencyKey[]) => (с: IContainer, ...args: unknown[]) => unknown[];
|
|
15
|
+
export declare const byKeys: (keys: DependencyKey[]) => (с: IContainer, ...args: unknown[]) => unknown[];
|
|
@@ -1,3 +1,14 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.byKeys = exports.byAllAliases = exports.bySomeAlias = exports.alias = void 0;
|
|
4
|
+
function alias(...tokens) {
|
|
5
|
+
return (provider) => provider.addAliases(...tokens);
|
|
6
|
+
}
|
|
7
|
+
exports.alias = alias;
|
|
8
|
+
const bySomeAlias = (...aliases) => (с, ...args) => с.getTokensByProvider((p) => aliases.some((alias) => p.hasAlias(alias))).map((t) => с.resolve(t, ...args));
|
|
9
|
+
exports.bySomeAlias = bySomeAlias;
|
|
10
|
+
const byAllAliases = (...aliases) => (с, ...args) => с.getTokensByProvider((p) => aliases.some((alias) => p.hasAlias(alias))).map((t) => с.resolve(t, ...args));
|
|
11
|
+
exports.byAllAliases = byAllAliases;
|
|
12
|
+
const byKeys = (keys) => (с, ...args) => keys.map((t) => с.resolve(t, ...args));
|
|
13
|
+
exports.byKeys = byKeys;
|
|
3
14
|
//# sourceMappingURL=IProvider.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"IProvider.js","sourceRoot":"","sources":["../../lib/provider/IProvider.ts"],"names":[],"mappings":""}
|
|
1
|
+
{"version":3,"file":"IProvider.js","sourceRoot":"","sources":["../../lib/provider/IProvider.ts"],"names":[],"mappings":";;;AAmBA,SAAgB,KAAK,CAAc,GAAG,MAAuB;IAC3D,OAAO,CAAC,QAAQ,EAAE,EAAE,CAAC,QAAQ,CAAC,UAAU,CAAC,GAAG,MAAM,CAAC,CAAC;AACtD,CAAC;AAFD,sBAEC;AAEM,MAAM,WAAW,GACtB,CAAC,GAAG,OAAwB,EAAE,EAAE,CAChC,CAAC,CAAa,EAAE,GAAG,IAAe,EAAE,EAAE,CACpC,CAAC,CAAC,mBAAmB,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,EAAE,GAAG,IAAI,CAAC,CAAC,CAAC;AAHlG,QAAA,WAAW,eAGuF;AAExG,MAAM,YAAY,GACvB,CAAC,GAAG,OAAwB,EAAE,EAAE,CAChC,CAAC,CAAa,EAAE,GAAG,IAAe,EAAE,EAAE,CACpC,CAAC,CAAC,mBAAmB,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,EAAE,GAAG,IAAI,CAAC,CAAC,CAAC;AAHlG,QAAA,YAAY,gBAGsF;AAExG,MAAM,MAAM,GACjB,CAAC,IAAqB,EAAE,EAAE,CAC1B,CAAC,CAAa,EAAE,GAAG,IAAe,EAAE,EAAE,CACpC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,EAAE,GAAG,IAAI,CAAC,CAAC,CAAC;AAH9B,QAAA,MAAM,UAGwB"}
|
|
@@ -1,13 +1,16 @@
|
|
|
1
1
|
import { IProvider, ResolveDependency } from './IProvider';
|
|
2
|
-
import { Resolvable } from '../container/IContainer';
|
|
2
|
+
import { DependencyKey, Resolvable } from '../container/IContainer';
|
|
3
3
|
import { constructor, MapFn } from '../utils';
|
|
4
4
|
export declare const provider: (...mappers: MapFn<IProvider>[]) => ClassDecorator;
|
|
5
5
|
export declare class Provider<T> implements IProvider<T> {
|
|
6
6
|
private readonly resolveDependency;
|
|
7
7
|
static fromClass<T>(Target: constructor<T>): IProvider<T>;
|
|
8
8
|
static fromValue<T>(value: T): Provider<T>;
|
|
9
|
+
private aliases;
|
|
9
10
|
constructor(resolveDependency: ResolveDependency<T>);
|
|
10
11
|
pipe(...mappers: MapFn<IProvider<T>>[]): IProvider<T>;
|
|
12
|
+
addAliases(...aliases: DependencyKey[]): this;
|
|
13
|
+
hasAlias(alias: DependencyKey): boolean;
|
|
11
14
|
clone(): Provider<T>;
|
|
12
15
|
resolve(container: Resolvable, ...args: unknown[]): T;
|
|
13
16
|
isValid(): boolean;
|
package/cjm/provider/Provider.js
CHANGED
|
@@ -9,6 +9,7 @@ exports.provider = provider;
|
|
|
9
9
|
class Provider {
|
|
10
10
|
constructor(resolveDependency) {
|
|
11
11
|
this.resolveDependency = resolveDependency;
|
|
12
|
+
this.aliases = new Set();
|
|
12
13
|
}
|
|
13
14
|
static fromClass(Target) {
|
|
14
15
|
var _a;
|
|
@@ -21,6 +22,15 @@ class Provider {
|
|
|
21
22
|
pipe(...mappers) {
|
|
22
23
|
return (0, utils_1.pipe)(...mappers)(this);
|
|
23
24
|
}
|
|
25
|
+
addAliases(...aliases) {
|
|
26
|
+
for (const alias of aliases) {
|
|
27
|
+
this.aliases.add(alias);
|
|
28
|
+
}
|
|
29
|
+
return this;
|
|
30
|
+
}
|
|
31
|
+
hasAlias(alias) {
|
|
32
|
+
return this.aliases.has(alias);
|
|
33
|
+
}
|
|
24
34
|
clone() {
|
|
25
35
|
return new Provider(this.resolveDependency);
|
|
26
36
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Provider.js","sourceRoot":"","sources":["../../lib/provider/Provider.ts"],"names":[],"mappings":";;;AAEA,oCAAoD;AACpD,0CAAuD;AAEvD,MAAM,YAAY,GAAG,UAAU,CAAC;AAEzB,MAAM,QAAQ,GAAG,CAAC,GAAG,OAA2B,EAAkB,EAAE,CAAC,IAAA,sBAAW,EAAC,YAAY,EAAE,OAAO,CAAC,CAAC;AAAlG,QAAA,QAAQ,YAA0F;AAE/G,MAAa,QAAQ;
|
|
1
|
+
{"version":3,"file":"Provider.js","sourceRoot":"","sources":["../../lib/provider/Provider.ts"],"names":[],"mappings":";;;AAEA,oCAAoD;AACpD,0CAAuD;AAEvD,MAAM,YAAY,GAAG,UAAU,CAAC;AAEzB,MAAM,QAAQ,GAAG,CAAC,GAAG,OAA2B,EAAkB,EAAE,CAAC,IAAA,sBAAW,EAAC,YAAY,EAAE,OAAO,CAAC,CAAC;AAAlG,QAAA,QAAQ,YAA0F;AAE/G,MAAa,QAAQ;IAYnB,YAA6B,iBAAuC;QAAvC,sBAAiB,GAAjB,iBAAiB,CAAsB;QAF5D,YAAO,GAAuB,IAAI,GAAG,EAAE,CAAC;IAEuB,CAAC;IAXxE,MAAM,CAAC,SAAS,CAAI,MAAsB;;QACxC,MAAM,OAAO,GAAG,MAAA,IAAA,sBAAW,EAAwB,MAAM,EAAE,YAAY,CAAC,mCAAI,EAAE,CAAC;QAC/E,OAAO,IAAI,QAAQ,CAAC,CAAC,SAAS,EAAE,GAAG,IAAI,EAAE,EAAE,CAAC,SAAS,CAAC,OAAO,CAAC,MAAM,EAAE,GAAG,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,OAAO,CAAC,CAAC;IACnG,CAAC;IAED,MAAM,CAAC,SAAS,CAAI,KAAQ;QAC1B,OAAO,IAAI,QAAQ,CAAC,GAAG,EAAE,CAAC,KAAK,CAAC,CAAC;IACnC,CAAC;IAMD,IAAI,CAAC,GAAG,OAA8B;QACpC,OAAO,IAAA,YAAI,EAAC,GAAG,OAAO,CAAC,CAAC,IAAI,CAAC,CAAC;IAChC,CAAC;IAED,UAAU,CAAC,GAAG,OAAwB;QACpC,KAAK,MAAM,KAAK,IAAI,OAAO,EAAE;YAC3B,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;SACzB;QACD,OAAO,IAAI,CAAC;IACd,CAAC;IAED,QAAQ,CAAC,KAAoB;QAC3B,OAAO,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;IACjC,CAAC;IAED,KAAK;QACH,OAAO,IAAI,QAAQ,CAAC,IAAI,CAAC,iBAAiB,CAAC,CAAC;IAC9C,CAAC;IAED,OAAO,CAAC,SAAqB,EAAE,GAAG,IAAe;QAC/C,OAAO,IAAI,CAAC,iBAAiB,CAAC,SAAS,EAAE,GAAG,IAAI,CAAC,CAAC;IACpD,CAAC;IAED,OAAO;QACL,OAAO,IAAI,CAAC;IACd,CAAC;CACF;AAxCD,4BAwCC"}
|
|
@@ -1,9 +1,11 @@
|
|
|
1
|
-
import { Resolvable, Tagged } from '../container/IContainer';
|
|
1
|
+
import { DependencyKey, Resolvable, Tagged } from '../container/IContainer';
|
|
2
2
|
import { IProvider } from './IProvider';
|
|
3
3
|
import { MapFn } from '../utils';
|
|
4
4
|
export declare abstract class ProviderDecorator<T> implements IProvider<T> {
|
|
5
5
|
private decorated;
|
|
6
6
|
protected constructor(decorated: IProvider<T>);
|
|
7
|
+
addAliases(...aliases: DependencyKey[]): this;
|
|
8
|
+
hasAlias(alias: DependencyKey): boolean;
|
|
7
9
|
abstract clone(): IProvider<T>;
|
|
8
10
|
isValid(filters: Tagged): boolean;
|
|
9
11
|
resolve(container: Resolvable, ...args: any[]): T;
|
|
@@ -6,6 +6,13 @@ class ProviderDecorator {
|
|
|
6
6
|
constructor(decorated) {
|
|
7
7
|
this.decorated = decorated;
|
|
8
8
|
}
|
|
9
|
+
addAliases(...aliases) {
|
|
10
|
+
this.decorated.addAliases(...aliases);
|
|
11
|
+
return this;
|
|
12
|
+
}
|
|
13
|
+
hasAlias(alias) {
|
|
14
|
+
return this.decorated.hasAlias(alias);
|
|
15
|
+
}
|
|
9
16
|
isValid(filters) {
|
|
10
17
|
return this.decorated.isValid(filters);
|
|
11
18
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ProviderDecorator.js","sourceRoot":"","sources":["../../lib/provider/ProviderDecorator.ts"],"names":[],"mappings":";;;AAEA,oCAAuC;AAEvC,MAAsB,iBAAiB;IACrC,YAA8B,SAAuB;QAAvB,cAAS,GAAT,SAAS,CAAc;IAAG,CAAC;
|
|
1
|
+
{"version":3,"file":"ProviderDecorator.js","sourceRoot":"","sources":["../../lib/provider/ProviderDecorator.ts"],"names":[],"mappings":";;;AAEA,oCAAuC;AAEvC,MAAsB,iBAAiB;IACrC,YAA8B,SAAuB;QAAvB,cAAS,GAAT,SAAS,CAAc;IAAG,CAAC;IAEzD,UAAU,CAAC,GAAG,OAAwB;QACpC,IAAI,CAAC,SAAS,CAAC,UAAU,CAAC,GAAG,OAAO,CAAC,CAAC;QACtC,OAAO,IAAI,CAAC;IACd,CAAC;IAED,QAAQ,CAAC,KAAoB;QAC3B,OAAO,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;IACxC,CAAC;IAID,OAAO,CAAC,OAAe;QACrB,OAAO,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC;IACzC,CAAC;IAED,OAAO,CAAC,SAAqB,EAAE,GAAG,IAAW;QAC3C,OAAO,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,SAAS,EAAE,GAAG,IAAI,CAAC,CAAC;IACpD,CAAC;IAED,IAAI,CAAC,GAAG,OAA8B;QACpC,OAAO,IAAA,YAAI,EAAC,GAAG,OAAO,CAAC,CAAC,IAAI,CAAC,CAAC;IAChC,CAAC;CACF;AAzBD,8CAyBC"}
|
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
import { IContainer, InjectionToken, IProvider, DependencyKey, Tag, IContainerModule } from '../index';
|
|
2
2
|
export declare abstract class AutoMockedContainer implements IContainer {
|
|
3
|
+
getTokensByProvider(predicate: (provider: IProvider<unknown>) => boolean): DependencyKey[];
|
|
3
4
|
createScope(...tags: Tag[]): IContainer;
|
|
4
5
|
abstract resolve<T>(key: InjectionToken<T>): T;
|
|
5
6
|
dispose(): void;
|
|
@@ -3,6 +3,9 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
3
3
|
exports.AutoMockedContainer = void 0;
|
|
4
4
|
const index_1 = require("../index");
|
|
5
5
|
class AutoMockedContainer {
|
|
6
|
+
getTokensByProvider(predicate) {
|
|
7
|
+
return [];
|
|
8
|
+
}
|
|
6
9
|
createScope(...tags) {
|
|
7
10
|
throw new index_1.MethodNotImplementedError();
|
|
8
11
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"AutoMockedContainer.js","sourceRoot":"","sources":["../../lib/container/AutoMockedContainer.ts"],"names":[],"mappings":";;;AAAA,oCAQkB;AAElB,MAAsB,mBAAmB;IACvC,WAAW,CAAC,GAAG,IAAW;QACxB,MAAM,IAAI,iCAAyB,EAAE,CAAC;IACxC,CAAC;IAID,OAAO,KAAU,CAAC;IAElB,2BAA2B;QACzB,OAAO,IAAI,GAAG,EAAE,CAAC;IACnB,CAAC;IAED,QAAQ,CAAC,GAAkB,EAAE,KAAgB;QAC3C,MAAM,IAAI,iCAAyB,EAAE,CAAC;IACxC,CAAC;IAED,YAAY;QACV,OAAO,EAAE,CAAC;IACZ,CAAC;IAED,WAAW,KAAU,CAAC;IAEtB,GAAG,CAAC,MAAwB;QAC1B,MAAM,IAAI,iCAAyB,EAAE,CAAC;IACxC,CAAC;IAED,eAAe;QACb,OAAO,IAAI,GAAG,EAAE,CAAC;IACnB,CAAC;IAED,MAAM,CAAC,GAAQ;QACb,OAAO,KAAK,CAAC;IACf,CAAC;CACF;
|
|
1
|
+
{"version":3,"file":"AutoMockedContainer.js","sourceRoot":"","sources":["../../lib/container/AutoMockedContainer.ts"],"names":[],"mappings":";;;AAAA,oCAQkB;AAElB,MAAsB,mBAAmB;IACvC,mBAAmB,CAAC,SAAoD;QACtE,OAAO,EAAE,CAAC;IACZ,CAAC;IAED,WAAW,CAAC,GAAG,IAAW;QACxB,MAAM,IAAI,iCAAyB,EAAE,CAAC;IACxC,CAAC;IAID,OAAO,KAAU,CAAC;IAElB,2BAA2B;QACzB,OAAO,IAAI,GAAG,EAAE,CAAC;IACnB,CAAC;IAED,QAAQ,CAAC,GAAkB,EAAE,KAAgB;QAC3C,MAAM,IAAI,iCAAyB,EAAE,CAAC;IACxC,CAAC;IAED,YAAY;QACV,OAAO,EAAE,CAAC;IACZ,CAAC;IAED,WAAW,KAAU,CAAC;IAEtB,GAAG,CAAC,MAAwB;QAC1B,MAAM,IAAI,iCAAyB,EAAE,CAAC;IACxC,CAAC;IAED,eAAe;QACb,OAAO,IAAI,GAAG,EAAE,CAAC;IACnB,CAAC;IAED,MAAM,CAAC,GAAQ;QACb,OAAO,KAAK,CAAC;IACf,CAAC;CACF;AAtCD,kDAsCC"}
|
|
@@ -15,6 +15,7 @@ export declare class Container implements IContainer, Tagged {
|
|
|
15
15
|
});
|
|
16
16
|
register(key: DependencyKey, provider: IProvider): this;
|
|
17
17
|
resolve<T>(token: InjectionToken<T>, ...args: unknown[]): T;
|
|
18
|
+
getTokensByProvider(predicate: (provider: IProvider) => boolean): DependencyKey[];
|
|
18
19
|
createScope(...tags: Tag[]): Container;
|
|
19
20
|
dispose(): void;
|
|
20
21
|
getInstances(): unknown[];
|
|
@@ -30,6 +30,15 @@ class Container {
|
|
|
30
30
|
const provider = this.providers.get(token);
|
|
31
31
|
return (provider === null || provider === void 0 ? void 0 : provider.isValid(this)) ? provider.resolve(this, ...args) : this.parent.resolve(token, ...args);
|
|
32
32
|
}
|
|
33
|
+
getTokensByProvider(predicate) {
|
|
34
|
+
const keys = new Set(this.parent.getTokensByProvider(predicate));
|
|
35
|
+
for (const [key, provider] of this.providers) {
|
|
36
|
+
if (predicate(provider)) {
|
|
37
|
+
keys.add(key);
|
|
38
|
+
}
|
|
39
|
+
}
|
|
40
|
+
return Array.from(keys);
|
|
41
|
+
}
|
|
33
42
|
createScope(...tags) {
|
|
34
43
|
this.validateContainer();
|
|
35
44
|
const scope = new Container(this.injector, { parent: this, tags });
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Container.js","sourceRoot":"","sources":["../../lib/container/Container.ts"],"names":[],"mappings":"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
|
|
1
|
+
{"version":3,"file":"Container.js","sourceRoot":"","sources":["../../lib/container/Container.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
import { DependencyKey, IContainer, IContainerModule, InjectionToken, Tag } from './IContainer';
|
|
2
2
|
import { IProvider } from '../provider/IProvider';
|
|
3
3
|
export declare class EmptyContainer implements IContainer {
|
|
4
|
+
getTokensByProvider(predicate: (provider: IProvider<unknown>) => boolean): DependencyKey[];
|
|
4
5
|
hasTag(tag: Tag): boolean;
|
|
5
6
|
createScope(...tags: Tag[]): IContainer;
|
|
6
7
|
dispose(): void;
|
|
@@ -4,6 +4,9 @@ exports.EmptyContainer = void 0;
|
|
|
4
4
|
const MethodNotImplementedError_1 = require("./MethodNotImplementedError");
|
|
5
5
|
const DependencyNotFoundError_1 = require("./DependencyNotFoundError");
|
|
6
6
|
class EmptyContainer {
|
|
7
|
+
getTokensByProvider(predicate) {
|
|
8
|
+
return [];
|
|
9
|
+
}
|
|
7
10
|
hasTag(tag) {
|
|
8
11
|
throw new MethodNotImplementedError_1.MethodNotImplementedError();
|
|
9
12
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"EmptyContainer.js","sourceRoot":"","sources":["../../lib/container/EmptyContainer.ts"],"names":[],"mappings":";;;AACA,2EAAwE;AACxE,uEAAoE;AAGpE,MAAa,cAAc;IACzB,MAAM,CAAC,GAAQ;QACb,MAAM,IAAI,qDAAyB,EAAE,CAAC;IACxC,CAAC;IAED,WAAW,CAAC,GAAG,IAAW;QACxB,MAAM,IAAI,qDAAyB,EAAE,CAAC;IACxC,CAAC;IAED,OAAO;QACL,MAAM,IAAI,qDAAyB,EAAE,CAAC;IACxC,CAAC;IAED,QAAQ,CAAC,GAAkB,EAAE,KAAgB;QAC3C,MAAM,IAAI,qDAAyB,EAAE,CAAC;IACxC,CAAC;IAED,OAAO,CAAI,GAAsB;QAC/B,MAAM,IAAI,iDAAuB,CAAC,eAAe,GAAG,CAAC,QAAQ,EAAE,EAAE,CAAC,CAAC;IACrE,CAAC;IAED,eAAe;QACb,OAAO,IAAI,GAAG,EAAE,CAAC;IACnB,CAAC;IAED,2BAA2B;QACzB,MAAM,IAAI,qDAAyB,EAAE,CAAC;IACxC,CAAC;IAED,YAAY;QACV,OAAO,EAAE,CAAC;IACZ,CAAC;IAED,WAAW,KAAU,CAAC;IAEtB,GAAG,CAAC,MAAwB;QAC1B,MAAM,IAAI,qDAAyB,EAAE,CAAC;IACxC,CAAC;CACF;
|
|
1
|
+
{"version":3,"file":"EmptyContainer.js","sourceRoot":"","sources":["../../lib/container/EmptyContainer.ts"],"names":[],"mappings":";;;AACA,2EAAwE;AACxE,uEAAoE;AAGpE,MAAa,cAAc;IACzB,mBAAmB,CAAC,SAAoD;QACtE,OAAO,EAAE,CAAC;IACZ,CAAC;IAED,MAAM,CAAC,GAAQ;QACb,MAAM,IAAI,qDAAyB,EAAE,CAAC;IACxC,CAAC;IAED,WAAW,CAAC,GAAG,IAAW;QACxB,MAAM,IAAI,qDAAyB,EAAE,CAAC;IACxC,CAAC;IAED,OAAO;QACL,MAAM,IAAI,qDAAyB,EAAE,CAAC;IACxC,CAAC;IAED,QAAQ,CAAC,GAAkB,EAAE,KAAgB;QAC3C,MAAM,IAAI,qDAAyB,EAAE,CAAC;IACxC,CAAC;IAED,OAAO,CAAI,GAAsB;QAC/B,MAAM,IAAI,iDAAuB,CAAC,eAAe,GAAG,CAAC,QAAQ,EAAE,EAAE,CAAC,CAAC;IACrE,CAAC;IAED,eAAe;QACb,OAAO,IAAI,GAAG,EAAE,CAAC;IACnB,CAAC;IAED,2BAA2B;QACzB,MAAM,IAAI,qDAAyB,EAAE,CAAC;IACxC,CAAC;IAED,YAAY;QACV,OAAO,EAAE,CAAC;IACZ,CAAC;IAED,WAAW,KAAU,CAAC;IAEtB,GAAG,CAAC,MAAwB;QAC1B,MAAM,IAAI,qDAAyB,EAAE,CAAC;IACxC,CAAC;CACF;AA1CD,wCA0CC"}
|
package/esm/index.d.ts
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
export { IContainer, Resolvable, IContainerModule, isDependencyKey, DependencyKey, InjectionToken, Tag, } from './container/IContainer';
|
|
2
2
|
export { constructor } from './utils';
|
|
3
3
|
export { Container } from './container/Container';
|
|
4
|
-
export { ResolveDependency, IProvider } from './provider/IProvider';
|
|
4
|
+
export { ResolveDependency, IProvider, bySomeAlias, byAllAliases, alias, byKeys } from './provider/IProvider';
|
|
5
5
|
export { IInjector } from './injector/IInjector';
|
|
6
6
|
export { DependencyNotFoundError } from './container/DependencyNotFoundError';
|
|
7
7
|
export { MethodNotImplementedError } from './container/MethodNotImplementedError';
|
|
@@ -17,3 +17,4 @@ export { ReflectionInjector, inject, by } from './injector/ReflectionInjector';
|
|
|
17
17
|
export { SimpleInjector } from './injector/SimpleInjector';
|
|
18
18
|
export { ProxyInjector } from './injector/ProxyInjector';
|
|
19
19
|
export { getHooks, hook } from './hook';
|
|
20
|
+
export { setMetadata, getMetadata } from './metadata';
|
package/esm/index.js
CHANGED
|
@@ -1,10 +1,15 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.hook = exports.getHooks = exports.ProxyInjector = exports.SimpleInjector = exports.by = exports.inject = exports.ReflectionInjector = exports.DependencyMissingKeyError = exports.Registration = exports.key = exports.AutoMockedContainer = exports.TaggedProvider = exports.tags = exports.SingletonProvider = exports.singleton = exports.ArgsProvider = exports.args = exports.argsFn = exports.provider = exports.Provider = exports.ContainerDisposedError = exports.MethodNotImplementedError = exports.DependencyNotFoundError = exports.Container = exports.isDependencyKey = void 0;
|
|
3
|
+
exports.getMetadata = exports.setMetadata = exports.hook = exports.getHooks = exports.ProxyInjector = exports.SimpleInjector = exports.by = exports.inject = exports.ReflectionInjector = exports.DependencyMissingKeyError = exports.Registration = exports.key = exports.AutoMockedContainer = exports.TaggedProvider = exports.tags = exports.SingletonProvider = exports.singleton = exports.ArgsProvider = exports.args = exports.argsFn = exports.provider = exports.Provider = exports.ContainerDisposedError = exports.MethodNotImplementedError = exports.DependencyNotFoundError = exports.byKeys = exports.alias = exports.byAllAliases = exports.bySomeAlias = exports.Container = exports.isDependencyKey = void 0;
|
|
4
4
|
var IContainer_1 = require("./container/IContainer");
|
|
5
5
|
Object.defineProperty(exports, "isDependencyKey", { enumerable: true, get: function () { return IContainer_1.isDependencyKey; } });
|
|
6
6
|
var Container_1 = require("./container/Container");
|
|
7
7
|
Object.defineProperty(exports, "Container", { enumerable: true, get: function () { return Container_1.Container; } });
|
|
8
|
+
var IProvider_1 = require("./provider/IProvider");
|
|
9
|
+
Object.defineProperty(exports, "bySomeAlias", { enumerable: true, get: function () { return IProvider_1.bySomeAlias; } });
|
|
10
|
+
Object.defineProperty(exports, "byAllAliases", { enumerable: true, get: function () { return IProvider_1.byAllAliases; } });
|
|
11
|
+
Object.defineProperty(exports, "alias", { enumerable: true, get: function () { return IProvider_1.alias; } });
|
|
12
|
+
Object.defineProperty(exports, "byKeys", { enumerable: true, get: function () { return IProvider_1.byKeys; } });
|
|
8
13
|
var DependencyNotFoundError_1 = require("./container/DependencyNotFoundError");
|
|
9
14
|
Object.defineProperty(exports, "DependencyNotFoundError", { enumerable: true, get: function () { return DependencyNotFoundError_1.DependencyNotFoundError; } });
|
|
10
15
|
var MethodNotImplementedError_1 = require("./container/MethodNotImplementedError");
|
|
@@ -42,4 +47,7 @@ Object.defineProperty(exports, "ProxyInjector", { enumerable: true, get: functio
|
|
|
42
47
|
var hook_1 = require("./hook");
|
|
43
48
|
Object.defineProperty(exports, "getHooks", { enumerable: true, get: function () { return hook_1.getHooks; } });
|
|
44
49
|
Object.defineProperty(exports, "hook", { enumerable: true, get: function () { return hook_1.hook; } });
|
|
50
|
+
var metadata_1 = require("./metadata");
|
|
51
|
+
Object.defineProperty(exports, "setMetadata", { enumerable: true, get: function () { return metadata_1.setMetadata; } });
|
|
52
|
+
Object.defineProperty(exports, "getMetadata", { enumerable: true, get: function () { return metadata_1.getMetadata; } });
|
|
45
53
|
//# sourceMappingURL=index.js.map
|
package/esm/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../lib/index.ts"],"names":[],"mappings":";;;AAAA,qDAQgC;AAJ9B,6GAAA,eAAe,OAAA;AAMjB,mDAAkD;AAAzC,sGAAA,SAAS,OAAA;
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../lib/index.ts"],"names":[],"mappings":";;;AAAA,qDAQgC;AAJ9B,6GAAA,eAAe,OAAA;AAMjB,mDAAkD;AAAzC,sGAAA,SAAS,OAAA;AAClB,kDAA8G;AAAvE,wGAAA,WAAW,OAAA;AAAE,yGAAA,YAAY,OAAA;AAAE,kGAAA,KAAK,OAAA;AAAE,mGAAA,MAAM,OAAA;AAE/E,+EAA8E;AAArE,kIAAA,uBAAuB,OAAA;AAChC,mFAAkF;AAAzE,sIAAA,yBAAyB,OAAA;AAClC,6EAA4E;AAAnE,gIAAA,sBAAsB,OAAA;AAC/B,gDAAyD;AAAhD,oGAAA,QAAQ,OAAA;AAAE,oGAAA,QAAQ,OAAA;AAC3B,wDAA6E;AAA5D,sGAAA,MAAM,OAAA;AAAE,oGAAA,IAAI,OAAA;AAAE,4GAAA,YAAY,OAAA;AAC3C,kEAA4E;AAAnE,8GAAA,SAAS,OAAA;AAAE,sHAAA,iBAAiB,OAAA;AACrC,4DAAiE;AAAxD,sGAAA,IAAI,OAAA;AAAE,gHAAA,cAAc,OAAA;AAC7B,uEAAsE;AAA7D,0HAAA,mBAAmB,OAAA;AAC5B,4DAAgE;AAAvD,mGAAA,GAAG,OAAA;AAAE,4GAAA,YAAY,OAAA;AAC1B,sFAAqF;AAA5E,sIAAA,yBAAyB,OAAA;AAClC,oEAA+E;AAAtE,wHAAA,kBAAkB,OAAA;AAAE,4GAAA,MAAM,OAAA;AAAE,wGAAA,EAAE,OAAA;AACvC,4DAA2D;AAAlD,gHAAA,cAAc,OAAA;AACvB,0DAAyD;AAAhD,8GAAA,aAAa,OAAA;AACtB,+BAAwC;AAA/B,gGAAA,QAAQ,OAAA;AAAE,4FAAA,IAAI,OAAA;AACvB,uCAAsD;AAA7C,uGAAA,WAAW,OAAA;AAAE,uGAAA,WAAW,OAAA"}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { Resolvable, Tagged } from '../container/IContainer';
|
|
1
|
+
import { DependencyKey, IContainer, Resolvable, Tagged } from '../container/IContainer';
|
|
2
2
|
import { MapFn } from '../utils';
|
|
3
3
|
export declare type ResolveDependency<T = unknown> = (container: Resolvable, ...args: unknown[]) => T;
|
|
4
4
|
export interface IProvider<T = unknown> {
|
|
@@ -6,4 +6,10 @@ export interface IProvider<T = unknown> {
|
|
|
6
6
|
resolve(container: Resolvable, ...args: unknown[]): T;
|
|
7
7
|
isValid(filters: Tagged): boolean;
|
|
8
8
|
pipe(...mappers: MapFn<IProvider<T>>[]): IProvider<T>;
|
|
9
|
+
hasAlias(alias: DependencyKey): boolean;
|
|
10
|
+
addAliases(...aliases: DependencyKey[]): this;
|
|
9
11
|
}
|
|
12
|
+
export declare function alias<T = unknown>(...tokens: DependencyKey[]): MapFn<IProvider<T>>;
|
|
13
|
+
export declare const bySomeAlias: (...aliases: DependencyKey[]) => (с: IContainer, ...args: unknown[]) => unknown[];
|
|
14
|
+
export declare const byAllAliases: (...aliases: DependencyKey[]) => (с: IContainer, ...args: unknown[]) => unknown[];
|
|
15
|
+
export declare const byKeys: (keys: DependencyKey[]) => (с: IContainer, ...args: unknown[]) => unknown[];
|
|
@@ -1,3 +1,14 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.byKeys = exports.byAllAliases = exports.bySomeAlias = exports.alias = void 0;
|
|
4
|
+
function alias(...tokens) {
|
|
5
|
+
return (provider) => provider.addAliases(...tokens);
|
|
6
|
+
}
|
|
7
|
+
exports.alias = alias;
|
|
8
|
+
const bySomeAlias = (...aliases) => (с, ...args) => с.getTokensByProvider((p) => aliases.some((alias) => p.hasAlias(alias))).map((t) => с.resolve(t, ...args));
|
|
9
|
+
exports.bySomeAlias = bySomeAlias;
|
|
10
|
+
const byAllAliases = (...aliases) => (с, ...args) => с.getTokensByProvider((p) => aliases.some((alias) => p.hasAlias(alias))).map((t) => с.resolve(t, ...args));
|
|
11
|
+
exports.byAllAliases = byAllAliases;
|
|
12
|
+
const byKeys = (keys) => (с, ...args) => keys.map((t) => с.resolve(t, ...args));
|
|
13
|
+
exports.byKeys = byKeys;
|
|
3
14
|
//# sourceMappingURL=IProvider.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"IProvider.js","sourceRoot":"","sources":["../../lib/provider/IProvider.ts"],"names":[],"mappings":""}
|
|
1
|
+
{"version":3,"file":"IProvider.js","sourceRoot":"","sources":["../../lib/provider/IProvider.ts"],"names":[],"mappings":";;;AAmBA,SAAgB,KAAK,CAAc,GAAG,MAAuB;IAC3D,OAAO,CAAC,QAAQ,EAAE,EAAE,CAAC,QAAQ,CAAC,UAAU,CAAC,GAAG,MAAM,CAAC,CAAC;AACtD,CAAC;AAFD,sBAEC;AAEM,MAAM,WAAW,GACtB,CAAC,GAAG,OAAwB,EAAE,EAAE,CAChC,CAAC,CAAa,EAAE,GAAG,IAAe,EAAE,EAAE,CACpC,CAAC,CAAC,mBAAmB,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,EAAE,GAAG,IAAI,CAAC,CAAC,CAAC;AAHlG,QAAA,WAAW,eAGuF;AAExG,MAAM,YAAY,GACvB,CAAC,GAAG,OAAwB,EAAE,EAAE,CAChC,CAAC,CAAa,EAAE,GAAG,IAAe,EAAE,EAAE,CACpC,CAAC,CAAC,mBAAmB,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,EAAE,GAAG,IAAI,CAAC,CAAC,CAAC;AAHlG,QAAA,YAAY,gBAGsF;AAExG,MAAM,MAAM,GACjB,CAAC,IAAqB,EAAE,EAAE,CAC1B,CAAC,CAAa,EAAE,GAAG,IAAe,EAAE,EAAE,CACpC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,EAAE,GAAG,IAAI,CAAC,CAAC,CAAC;AAH9B,QAAA,MAAM,UAGwB"}
|
|
@@ -1,13 +1,16 @@
|
|
|
1
1
|
import { IProvider, ResolveDependency } from './IProvider';
|
|
2
|
-
import { Resolvable } from '../container/IContainer';
|
|
2
|
+
import { DependencyKey, Resolvable } from '../container/IContainer';
|
|
3
3
|
import { constructor, MapFn } from '../utils';
|
|
4
4
|
export declare const provider: (...mappers: MapFn<IProvider>[]) => ClassDecorator;
|
|
5
5
|
export declare class Provider<T> implements IProvider<T> {
|
|
6
6
|
private readonly resolveDependency;
|
|
7
7
|
static fromClass<T>(Target: constructor<T>): IProvider<T>;
|
|
8
8
|
static fromValue<T>(value: T): Provider<T>;
|
|
9
|
+
private aliases;
|
|
9
10
|
constructor(resolveDependency: ResolveDependency<T>);
|
|
10
11
|
pipe(...mappers: MapFn<IProvider<T>>[]): IProvider<T>;
|
|
12
|
+
addAliases(...aliases: DependencyKey[]): this;
|
|
13
|
+
hasAlias(alias: DependencyKey): boolean;
|
|
11
14
|
clone(): Provider<T>;
|
|
12
15
|
resolve(container: Resolvable, ...args: unknown[]): T;
|
|
13
16
|
isValid(): boolean;
|
package/esm/provider/Provider.js
CHANGED
|
@@ -9,6 +9,7 @@ exports.provider = provider;
|
|
|
9
9
|
class Provider {
|
|
10
10
|
constructor(resolveDependency) {
|
|
11
11
|
this.resolveDependency = resolveDependency;
|
|
12
|
+
this.aliases = new Set();
|
|
12
13
|
}
|
|
13
14
|
static fromClass(Target) {
|
|
14
15
|
var _a;
|
|
@@ -21,6 +22,15 @@ class Provider {
|
|
|
21
22
|
pipe(...mappers) {
|
|
22
23
|
return (0, utils_1.pipe)(...mappers)(this);
|
|
23
24
|
}
|
|
25
|
+
addAliases(...aliases) {
|
|
26
|
+
for (const alias of aliases) {
|
|
27
|
+
this.aliases.add(alias);
|
|
28
|
+
}
|
|
29
|
+
return this;
|
|
30
|
+
}
|
|
31
|
+
hasAlias(alias) {
|
|
32
|
+
return this.aliases.has(alias);
|
|
33
|
+
}
|
|
24
34
|
clone() {
|
|
25
35
|
return new Provider(this.resolveDependency);
|
|
26
36
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Provider.js","sourceRoot":"","sources":["../../lib/provider/Provider.ts"],"names":[],"mappings":";;;AAEA,oCAAoD;AACpD,0CAAuD;AAEvD,MAAM,YAAY,GAAG,UAAU,CAAC;AAEzB,MAAM,QAAQ,GAAG,CAAC,GAAG,OAA2B,EAAkB,EAAE,CAAC,IAAA,sBAAW,EAAC,YAAY,EAAE,OAAO,CAAC,CAAC;AAAlG,QAAA,QAAQ,YAA0F;AAE/G,MAAa,QAAQ;
|
|
1
|
+
{"version":3,"file":"Provider.js","sourceRoot":"","sources":["../../lib/provider/Provider.ts"],"names":[],"mappings":";;;AAEA,oCAAoD;AACpD,0CAAuD;AAEvD,MAAM,YAAY,GAAG,UAAU,CAAC;AAEzB,MAAM,QAAQ,GAAG,CAAC,GAAG,OAA2B,EAAkB,EAAE,CAAC,IAAA,sBAAW,EAAC,YAAY,EAAE,OAAO,CAAC,CAAC;AAAlG,QAAA,QAAQ,YAA0F;AAE/G,MAAa,QAAQ;IAYnB,YAA6B,iBAAuC;QAAvC,sBAAiB,GAAjB,iBAAiB,CAAsB;QAF5D,YAAO,GAAuB,IAAI,GAAG,EAAE,CAAC;IAEuB,CAAC;IAXxE,MAAM,CAAC,SAAS,CAAI,MAAsB;;QACxC,MAAM,OAAO,GAAG,MAAA,IAAA,sBAAW,EAAwB,MAAM,EAAE,YAAY,CAAC,mCAAI,EAAE,CAAC;QAC/E,OAAO,IAAI,QAAQ,CAAC,CAAC,SAAS,EAAE,GAAG,IAAI,EAAE,EAAE,CAAC,SAAS,CAAC,OAAO,CAAC,MAAM,EAAE,GAAG,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,OAAO,CAAC,CAAC;IACnG,CAAC;IAED,MAAM,CAAC,SAAS,CAAI,KAAQ;QAC1B,OAAO,IAAI,QAAQ,CAAC,GAAG,EAAE,CAAC,KAAK,CAAC,CAAC;IACnC,CAAC;IAMD,IAAI,CAAC,GAAG,OAA8B;QACpC,OAAO,IAAA,YAAI,EAAC,GAAG,OAAO,CAAC,CAAC,IAAI,CAAC,CAAC;IAChC,CAAC;IAED,UAAU,CAAC,GAAG,OAAwB;QACpC,KAAK,MAAM,KAAK,IAAI,OAAO,EAAE;YAC3B,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;SACzB;QACD,OAAO,IAAI,CAAC;IACd,CAAC;IAED,QAAQ,CAAC,KAAoB;QAC3B,OAAO,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;IACjC,CAAC;IAED,KAAK;QACH,OAAO,IAAI,QAAQ,CAAC,IAAI,CAAC,iBAAiB,CAAC,CAAC;IAC9C,CAAC;IAED,OAAO,CAAC,SAAqB,EAAE,GAAG,IAAe;QAC/C,OAAO,IAAI,CAAC,iBAAiB,CAAC,SAAS,EAAE,GAAG,IAAI,CAAC,CAAC;IACpD,CAAC;IAED,OAAO;QACL,OAAO,IAAI,CAAC;IACd,CAAC;CACF;AAxCD,4BAwCC"}
|
|
@@ -1,9 +1,11 @@
|
|
|
1
|
-
import { Resolvable, Tagged } from '../container/IContainer';
|
|
1
|
+
import { DependencyKey, Resolvable, Tagged } from '../container/IContainer';
|
|
2
2
|
import { IProvider } from './IProvider';
|
|
3
3
|
import { MapFn } from '../utils';
|
|
4
4
|
export declare abstract class ProviderDecorator<T> implements IProvider<T> {
|
|
5
5
|
private decorated;
|
|
6
6
|
protected constructor(decorated: IProvider<T>);
|
|
7
|
+
addAliases(...aliases: DependencyKey[]): this;
|
|
8
|
+
hasAlias(alias: DependencyKey): boolean;
|
|
7
9
|
abstract clone(): IProvider<T>;
|
|
8
10
|
isValid(filters: Tagged): boolean;
|
|
9
11
|
resolve(container: Resolvable, ...args: any[]): T;
|
|
@@ -6,6 +6,13 @@ class ProviderDecorator {
|
|
|
6
6
|
constructor(decorated) {
|
|
7
7
|
this.decorated = decorated;
|
|
8
8
|
}
|
|
9
|
+
addAliases(...aliases) {
|
|
10
|
+
this.decorated.addAliases(...aliases);
|
|
11
|
+
return this;
|
|
12
|
+
}
|
|
13
|
+
hasAlias(alias) {
|
|
14
|
+
return this.decorated.hasAlias(alias);
|
|
15
|
+
}
|
|
9
16
|
isValid(filters) {
|
|
10
17
|
return this.decorated.isValid(filters);
|
|
11
18
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ProviderDecorator.js","sourceRoot":"","sources":["../../lib/provider/ProviderDecorator.ts"],"names":[],"mappings":";;;AAEA,oCAAuC;AAEvC,MAAsB,iBAAiB;IACrC,YAA8B,SAAuB;QAAvB,cAAS,GAAT,SAAS,CAAc;IAAG,CAAC;
|
|
1
|
+
{"version":3,"file":"ProviderDecorator.js","sourceRoot":"","sources":["../../lib/provider/ProviderDecorator.ts"],"names":[],"mappings":";;;AAEA,oCAAuC;AAEvC,MAAsB,iBAAiB;IACrC,YAA8B,SAAuB;QAAvB,cAAS,GAAT,SAAS,CAAc;IAAG,CAAC;IAEzD,UAAU,CAAC,GAAG,OAAwB;QACpC,IAAI,CAAC,SAAS,CAAC,UAAU,CAAC,GAAG,OAAO,CAAC,CAAC;QACtC,OAAO,IAAI,CAAC;IACd,CAAC;IAED,QAAQ,CAAC,KAAoB;QAC3B,OAAO,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;IACxC,CAAC;IAID,OAAO,CAAC,OAAe;QACrB,OAAO,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC;IACzC,CAAC;IAED,OAAO,CAAC,SAAqB,EAAE,GAAG,IAAW;QAC3C,OAAO,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,SAAS,EAAE,GAAG,IAAI,CAAC,CAAC;IACpD,CAAC;IAED,IAAI,CAAC,GAAG,OAA8B;QACpC,OAAO,IAAA,YAAI,EAAC,GAAG,OAAO,CAAC,CAAC,IAAI,CAAC,CAAC;IAChC,CAAC;CACF;AAzBD,8CAyBC"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "ts-ioc-container",
|
|
3
|
-
"version": "25.0
|
|
3
|
+
"version": "25.2.0",
|
|
4
4
|
"description": "Typescript IoC container",
|
|
5
5
|
"publishConfig": {
|
|
6
6
|
"access": "public",
|
|
@@ -58,5 +58,5 @@
|
|
|
58
58
|
"ts-node": "^10.9.1",
|
|
59
59
|
"typescript": "4.4.3"
|
|
60
60
|
},
|
|
61
|
-
"gitHead": "
|
|
61
|
+
"gitHead": "5ba79a412340f7d218533eaf2e5d4932103665f7"
|
|
62
62
|
}
|