ts-ioc-container 18.0.2 → 18.0.4
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 +17 -15
- package/cjm/core/provider/ProviderRepo.d.ts +1 -1
- package/cjm/core/provider/ProviderRepo.js +1 -0
- package/cjm/core/provider/ProviderRepo.js.map +1 -1
- package/cjm/hooks/AsyncMethodReflector.d.ts +8 -0
- package/cjm/hooks/AsyncMethodReflector.js +143 -0
- package/cjm/hooks/AsyncMethodReflector.js.map +1 -0
- package/cjm/index.d.ts +1 -2
- package/cjm/index.js +3 -5
- package/cjm/index.js.map +1 -1
- package/esm/core/provider/ProviderRepo.d.ts +1 -1
- package/esm/core/provider/ProviderRepo.js +1 -0
- package/esm/core/provider/ProviderRepo.js.map +1 -1
- package/esm/hooks/AsyncMethodReflector.d.ts +8 -0
- package/esm/hooks/AsyncMethodReflector.js +32 -0
- package/esm/hooks/AsyncMethodReflector.js.map +1 -0
- package/esm/index.d.ts +1 -2
- package/esm/index.js +1 -2
- package/esm/index.js.map +1 -1
- package/package.json +2 -2
- package/cjm/injectors/ProxyInjector.d.ts +0 -10
- package/cjm/injectors/ProxyInjector.js +0 -43
- package/cjm/injectors/ProxyInjector.js.map +0 -1
- package/cjm/injectors/SimpleInjector.d.ts +0 -9
- package/cjm/injectors/SimpleInjector.js +0 -49
- package/cjm/injectors/SimpleInjector.js.map +0 -1
- package/esm/injectors/ProxyInjector.d.ts +0 -10
- package/esm/injectors/ProxyInjector.js +0 -21
- package/esm/injectors/ProxyInjector.js.map +0 -1
- package/esm/injectors/SimpleInjector.d.ts +0 -9
- package/esm/injectors/SimpleInjector.js +0 -13
- package/esm/injectors/SimpleInjector.js.map +0 -1
package/README.md
CHANGED
|
@@ -19,10 +19,10 @@
|
|
|
19
19
|
|
|
20
20
|
## Install
|
|
21
21
|
```shell script
|
|
22
|
-
npm install ts-ioc-container reflect-metadata
|
|
22
|
+
npm install ts-ioc-container ts-constructor-injector reflect-metadata
|
|
23
23
|
```
|
|
24
24
|
```shell script
|
|
25
|
-
yarn add ts-ioc-container reflect-metadata
|
|
25
|
+
yarn add ts-ioc-container ts-constructor-injector reflect-metadata
|
|
26
26
|
```
|
|
27
27
|
|
|
28
28
|
## tsconfig.json
|
|
@@ -60,7 +60,6 @@ import { fromClass, ProviderBuilder } from "ts-ioc-container";
|
|
|
60
60
|
|
|
61
61
|
container.register('ILogger', new ProviderBuilder((container, ...args) => new Logger(...args)).build());
|
|
62
62
|
container.register('ILogger1', ProviderBuilder.fromClass(Logger).forKey('ILogger').asSingleton().forLevel(0).build()); // global singleton
|
|
63
|
-
container.register('ILogger2', ProviderBuilder.fromClass(Logger).asSingleton().forLevel(1).build()); // first scope singleton
|
|
64
63
|
container.register('ILogger3', ProviderBuilder.fromClass(Logger).asSingleton().forTags(['tag1', 'tag2']).build()); // singleton for scope with tag1 or tag2
|
|
65
64
|
container.register('ILogger4', ProviderBuilder.fromClass(Logger).withArgs('dev').asSingleton().build()); // singleton in every scope
|
|
66
65
|
```
|
|
@@ -89,7 +88,7 @@ import {
|
|
|
89
88
|
Container,
|
|
90
89
|
IInjector,
|
|
91
90
|
ContainerHook,
|
|
92
|
-
ProviderBuilder,
|
|
91
|
+
ProviderBuilder, Injector
|
|
93
92
|
} from "ts-ioc-container";
|
|
94
93
|
|
|
95
94
|
export const onConstructReflector = new MethodReflector('OnConstructHook');
|
|
@@ -104,21 +103,24 @@ class Logger {
|
|
|
104
103
|
}
|
|
105
104
|
|
|
106
105
|
@onDispose
|
|
107
|
-
dispose() {
|
|
106
|
+
dispose() {
|
|
107
|
+
}
|
|
108
108
|
}
|
|
109
109
|
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
}
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
}));
|
|
110
|
+
class IocInjector extends Injector {
|
|
111
|
+
resolve<T>(locator: Resolveable, value: constructor<T>, ...deps: unknown[]): T {
|
|
112
|
+
const instance = super.resolve(locator, value, ...deps);
|
|
113
|
+
onConstructReflector.invokeHooksOf(instance)
|
|
114
|
+
return instance;
|
|
115
|
+
}
|
|
116
|
+
}
|
|
117
|
+
|
|
118
|
+
const container = new Container(new IocInjector());
|
|
120
119
|
container.register('ILogger', ProviderBuilder.fromClass(Logger).build());
|
|
121
120
|
const logger = container.resolve<ILogger>('ILogger');
|
|
121
|
+
for (const instance of container.getInstances()) {
|
|
122
|
+
onDisposeReflector.invokeHooksOf(instance);
|
|
123
|
+
}
|
|
122
124
|
```
|
|
123
125
|
|
|
124
126
|
## Scoped locators
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import { IProvider, ProviderKey } from './IProvider';
|
|
2
2
|
export declare class ProviderRepo {
|
|
3
3
|
private readonly providers;
|
|
4
|
-
add(provider: IProvider<unknown>):
|
|
4
|
+
add(provider: IProvider<unknown>): this;
|
|
5
5
|
get<T>(key: ProviderKey): IProvider<T> | undefined;
|
|
6
6
|
merge(providers: IProvider<unknown>[]): IProvider<unknown>[];
|
|
7
7
|
dispose(): void;
|
|
@@ -18,6 +18,7 @@ var ProviderRepo = /** @class */ (function () {
|
|
|
18
18
|
}
|
|
19
19
|
ProviderRepo.prototype.add = function (provider) {
|
|
20
20
|
this.providers.set(provider.getKeyOrFail(), provider);
|
|
21
|
+
return this;
|
|
21
22
|
};
|
|
22
23
|
ProviderRepo.prototype.get = function (key) {
|
|
23
24
|
return this.providers.get(key);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ProviderRepo.js","sourceRoot":"","sources":["../../../lib/core/provider/ProviderRepo.ts"],"names":[],"mappings":";;;;;;;;;;;;;;AAEA;IAAA;QACqB,cAAS,GAAG,IAAI,GAAG,EAAmC,CAAC;
|
|
1
|
+
{"version":3,"file":"ProviderRepo.js","sourceRoot":"","sources":["../../../lib/core/provider/ProviderRepo.ts"],"names":[],"mappings":";;;;;;;;;;;;;;AAEA;IAAA;QACqB,cAAS,GAAG,IAAI,GAAG,EAAmC,CAAC;IAyB5E,CAAC;IAvBG,0BAAG,GAAH,UAAI,QAA4B;QAC5B,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,QAAQ,CAAC,YAAY,EAAE,EAAE,QAAQ,CAAC,CAAC;QACtD,OAAO,IAAI,CAAC;IAChB,CAAC;IAED,0BAAG,GAAH,UAAO,GAAgB;QACnB,OAAO,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,GAAG,CAAiB,CAAC;IACnD,CAAC;IAED,4BAAK,GAAL,UAAM,SAA+B;;QACjC,IAAM,GAAG,GAAG,IAAI,GAAG,EAAmC,CAAC;;YACvD,KAAgB,IAAA,KAAA,SAAA,SAAS,CAAC,MAAM,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,MAAM,EAAE,CAAC,CAAC,CAAA,gBAAA,4BAAE;gBAAlE,IAAM,CAAC,WAAA;gBACR,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC,YAAY,EAAE,EAAE,CAAC,CAAC,CAAC;aAChC;;;;;;;;;QACD,OAAO,KAAK,CAAC,IAAI,CAAC,GAAG,CAAC,MAAM,EAAE,CAAC,CAAC;IACpC,CAAC;IAED,8BAAO,GAAP;;;YACI,KAAgB,IAAA,KAAA,SAAA,IAAI,CAAC,SAAS,CAAC,MAAM,EAAE,CAAA,gBAAA,4BAAE;gBAApC,IAAM,CAAC,WAAA;gBACR,CAAC,CAAC,OAAO,EAAE,CAAC;aACf;;;;;;;;;QACD,IAAI,CAAC,SAAS,CAAC,KAAK,EAAE,CAAC;IAC3B,CAAC;IACL,mBAAC;AAAD,CAAC,AA1BD,IA0BC;AA1BY,oCAAY"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
export declare class AsyncMethodReflector {
|
|
2
|
+
readonly hookKey: string | symbol;
|
|
3
|
+
constructor(hookKey: string | symbol);
|
|
4
|
+
private addHook;
|
|
5
|
+
invokeHooksOf<GInstance extends Object>(target: GInstance): Promise<void>;
|
|
6
|
+
private static getTargetId;
|
|
7
|
+
createMethodHookDecorator(): MethodDecorator;
|
|
8
|
+
}
|
|
@@ -0,0 +1,143 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
3
|
+
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
4
|
+
return new (P || (P = Promise))(function (resolve, reject) {
|
|
5
|
+
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
6
|
+
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
7
|
+
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
8
|
+
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
9
|
+
});
|
|
10
|
+
};
|
|
11
|
+
var __generator = (this && this.__generator) || function (thisArg, body) {
|
|
12
|
+
var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;
|
|
13
|
+
return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g;
|
|
14
|
+
function verb(n) { return function (v) { return step([n, v]); }; }
|
|
15
|
+
function step(op) {
|
|
16
|
+
if (f) throw new TypeError("Generator is already executing.");
|
|
17
|
+
while (_) try {
|
|
18
|
+
if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;
|
|
19
|
+
if (y = 0, t) op = [op[0] & 2, t.value];
|
|
20
|
+
switch (op[0]) {
|
|
21
|
+
case 0: case 1: t = op; break;
|
|
22
|
+
case 4: _.label++; return { value: op[1], done: false };
|
|
23
|
+
case 5: _.label++; y = op[1]; op = [0]; continue;
|
|
24
|
+
case 7: op = _.ops.pop(); _.trys.pop(); continue;
|
|
25
|
+
default:
|
|
26
|
+
if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }
|
|
27
|
+
if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }
|
|
28
|
+
if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }
|
|
29
|
+
if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }
|
|
30
|
+
if (t[2]) _.ops.pop();
|
|
31
|
+
_.trys.pop(); continue;
|
|
32
|
+
}
|
|
33
|
+
op = body.call(thisArg, _);
|
|
34
|
+
} catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }
|
|
35
|
+
if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };
|
|
36
|
+
}
|
|
37
|
+
};
|
|
38
|
+
var __read = (this && this.__read) || function (o, n) {
|
|
39
|
+
var m = typeof Symbol === "function" && o[Symbol.iterator];
|
|
40
|
+
if (!m) return o;
|
|
41
|
+
var i = m.call(o), r, ar = [], e;
|
|
42
|
+
try {
|
|
43
|
+
while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);
|
|
44
|
+
}
|
|
45
|
+
catch (error) { e = { error: error }; }
|
|
46
|
+
finally {
|
|
47
|
+
try {
|
|
48
|
+
if (r && !r.done && (m = i["return"])) m.call(i);
|
|
49
|
+
}
|
|
50
|
+
finally { if (e) throw e.error; }
|
|
51
|
+
}
|
|
52
|
+
return ar;
|
|
53
|
+
};
|
|
54
|
+
var __spreadArray = (this && this.__spreadArray) || function (to, from, pack) {
|
|
55
|
+
if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) {
|
|
56
|
+
if (ar || !(i in from)) {
|
|
57
|
+
if (!ar) ar = Array.prototype.slice.call(from, 0, i);
|
|
58
|
+
ar[i] = from[i];
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
return to.concat(ar || Array.prototype.slice.call(from));
|
|
62
|
+
};
|
|
63
|
+
var __values = (this && this.__values) || function(o) {
|
|
64
|
+
var s = typeof Symbol === "function" && Symbol.iterator, m = s && o[s], i = 0;
|
|
65
|
+
if (m) return m.call(o);
|
|
66
|
+
if (o && typeof o.length === "number") return {
|
|
67
|
+
next: function () {
|
|
68
|
+
if (o && i >= o.length) o = void 0;
|
|
69
|
+
return { value: o && o[i++], done: !o };
|
|
70
|
+
}
|
|
71
|
+
};
|
|
72
|
+
throw new TypeError(s ? "Object is not iterable." : "Symbol.iterator is not defined.");
|
|
73
|
+
};
|
|
74
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
75
|
+
exports.AsyncMethodReflector = void 0;
|
|
76
|
+
var AsyncMethodReflector = /** @class */ (function () {
|
|
77
|
+
function AsyncMethodReflector(hookKey) {
|
|
78
|
+
this.hookKey = hookKey;
|
|
79
|
+
}
|
|
80
|
+
// eslint-disable-next-line @typescript-eslint/ban-types
|
|
81
|
+
AsyncMethodReflector.prototype.addHook = function (target, propertyKey) {
|
|
82
|
+
var targetId = AsyncMethodReflector.getTargetId(target);
|
|
83
|
+
var hooks = Reflect.getMetadata(this.hookKey, targetId) || [];
|
|
84
|
+
Reflect.defineMetadata(this.hookKey, __spreadArray(__spreadArray([], __read(hooks), false), [propertyKey], false), targetId);
|
|
85
|
+
};
|
|
86
|
+
// eslint-disable-next-line @typescript-eslint/ban-types
|
|
87
|
+
AsyncMethodReflector.prototype.invokeHooksOf = function (target) {
|
|
88
|
+
return __awaiter(this, void 0, void 0, function () {
|
|
89
|
+
var targetId, hooks, hooks_1, hooks_1_1, hookMethod, e_1_1;
|
|
90
|
+
var e_1, _a;
|
|
91
|
+
return __generator(this, function (_b) {
|
|
92
|
+
switch (_b.label) {
|
|
93
|
+
case 0:
|
|
94
|
+
targetId = AsyncMethodReflector.getTargetId(target);
|
|
95
|
+
hooks = Reflect.hasMetadata(this.hookKey, targetId)
|
|
96
|
+
? Reflect.getMetadata(this.hookKey, targetId)
|
|
97
|
+
: [];
|
|
98
|
+
_b.label = 1;
|
|
99
|
+
case 1:
|
|
100
|
+
_b.trys.push([1, 6, 7, 8]);
|
|
101
|
+
hooks_1 = __values(hooks), hooks_1_1 = hooks_1.next();
|
|
102
|
+
_b.label = 2;
|
|
103
|
+
case 2:
|
|
104
|
+
if (!!hooks_1_1.done) return [3 /*break*/, 5];
|
|
105
|
+
hookMethod = hooks_1_1.value;
|
|
106
|
+
return [4 /*yield*/, target[hookMethod]()];
|
|
107
|
+
case 3:
|
|
108
|
+
_b.sent();
|
|
109
|
+
_b.label = 4;
|
|
110
|
+
case 4:
|
|
111
|
+
hooks_1_1 = hooks_1.next();
|
|
112
|
+
return [3 /*break*/, 2];
|
|
113
|
+
case 5: return [3 /*break*/, 8];
|
|
114
|
+
case 6:
|
|
115
|
+
e_1_1 = _b.sent();
|
|
116
|
+
e_1 = { error: e_1_1 };
|
|
117
|
+
return [3 /*break*/, 8];
|
|
118
|
+
case 7:
|
|
119
|
+
try {
|
|
120
|
+
if (hooks_1_1 && !hooks_1_1.done && (_a = hooks_1.return)) _a.call(hooks_1);
|
|
121
|
+
}
|
|
122
|
+
finally { if (e_1) throw e_1.error; }
|
|
123
|
+
return [7 /*endfinally*/];
|
|
124
|
+
case 8: return [2 /*return*/];
|
|
125
|
+
}
|
|
126
|
+
});
|
|
127
|
+
});
|
|
128
|
+
};
|
|
129
|
+
// eslint-disable-next-line @typescript-eslint/ban-types
|
|
130
|
+
AsyncMethodReflector.getTargetId = function (target) {
|
|
131
|
+
return target.constructor;
|
|
132
|
+
};
|
|
133
|
+
AsyncMethodReflector.prototype.createMethodHookDecorator = function () {
|
|
134
|
+
var _this = this;
|
|
135
|
+
return function (target, propertyKey) {
|
|
136
|
+
// eslint-disable-next-line @typescript-eslint/ban-types
|
|
137
|
+
_this.addHook(target, propertyKey);
|
|
138
|
+
};
|
|
139
|
+
};
|
|
140
|
+
return AsyncMethodReflector;
|
|
141
|
+
}());
|
|
142
|
+
exports.AsyncMethodReflector = AsyncMethodReflector;
|
|
143
|
+
//# sourceMappingURL=AsyncMethodReflector.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"AsyncMethodReflector.js","sourceRoot":"","sources":["../../lib/hooks/AsyncMethodReflector.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;IACI,8BAAqB,OAAwB;QAAxB,YAAO,GAAP,OAAO,CAAiB;IAAG,CAAC;IAEjD,wDAAwD;IAChD,sCAAO,GAAf,UAA0C,MAAiB,EAAE,WAA4B;QACrF,IAAM,QAAQ,GAAG,oBAAoB,CAAC,WAAW,CAAC,MAAM,CAAC,CAAC;QAC1D,IAAM,KAAK,GAAG,OAAO,CAAC,WAAW,CAAC,IAAI,CAAC,OAAO,EAAE,QAAQ,CAAC,IAAI,EAAE,CAAC;QAChE,OAAO,CAAC,cAAc,CAAC,IAAI,CAAC,OAAO,yCAAM,KAAK,YAAE,WAAW,WAAG,QAAQ,CAAC,CAAC;IAC5E,CAAC;IAED,wDAAwD;IAClD,4CAAa,GAAnB,UAA8C,MAAiB;;;;;;;wBACrD,QAAQ,GAAG,oBAAoB,CAAC,WAAW,CAAC,MAAM,CAAC,CAAC;wBACpD,KAAK,GAAa,OAAO,CAAC,WAAW,CAAC,IAAI,CAAC,OAAO,EAAE,QAAQ,CAAC;4BAC/D,CAAC,CAAC,OAAO,CAAC,WAAW,CAAC,IAAI,CAAC,OAAO,EAAE,QAAQ,CAAC;4BAC7C,CAAC,CAAC,EAAE,CAAC;;;;wBAEgB,UAAA,SAAA,KAAK,CAAA;;;;wBAAnB,UAAU;wBACjB,qBAAO,MAAc,CAAC,UAAU,CAAC,EAAE,EAAA;;wBAAnC,SAAmC,CAAC;;;;;;;;;;;;;;;;;;;;KAE3C;IAED,wDAAwD;IACzC,gCAAW,GAA1B,UAA2D,MAAiB;QACxE,OAAO,MAAM,CAAC,WAAW,CAAC;IAC9B,CAAC;IAED,wDAAyB,GAAzB;QAAA,iBAKC;QAJG,OAAO,UAAC,MAAM,EAAE,WAAW;YACvB,wDAAwD;YACxD,KAAI,CAAC,OAAO,CAAC,MAAM,EAAE,WAAW,CAAC,CAAC;QACtC,CAAC,CAAC;IACN,CAAC;IACL,2BAAC;AAAD,CAAC,AAjCD,IAiCC;AAjCY,oDAAoB"}
|
package/cjm/index.d.ts
CHANGED
|
@@ -5,9 +5,9 @@ export { constructor } from './core/utils/types';
|
|
|
5
5
|
export { Container } from './core/container/Container';
|
|
6
6
|
export { Tagged, ResolveDependency, Tag, IProvider } from './core/provider/IProvider';
|
|
7
7
|
export { IInjector } from './core/IInjector';
|
|
8
|
-
export { SimpleInjector } from './injectors/SimpleInjector';
|
|
9
8
|
export { IMethodReflector } from './hooks/IMethodReflector';
|
|
10
9
|
export { MethodReflector } from './hooks/MethodReflector';
|
|
10
|
+
export { AsyncMethodReflector } from './hooks/AsyncMethodReflector';
|
|
11
11
|
export { InjectionToken } from './core/container/IContainer';
|
|
12
12
|
export { ProviderNotFoundError } from './core/provider/ProviderNotFoundError';
|
|
13
13
|
export { MethodNotImplementedError } from './core/utils/MethodNotImplementedError';
|
|
@@ -15,7 +15,6 @@ export { ContainerDisposedError } from './core/container/ContainerDisposedError'
|
|
|
15
15
|
export { Provider } from './core/provider/Provider';
|
|
16
16
|
export { ArgsProvider, ArgsFn, createArgsFnDecorator } from './providers/ArgsProvider';
|
|
17
17
|
export { TaggedProvider } from './providers/TaggedProvider';
|
|
18
|
-
export { ProxyInjector } from './injectors/ProxyInjector';
|
|
19
18
|
export { IMockRepository } from './automock/IMockRepository';
|
|
20
19
|
export { AutoMockedContainer } from './automock/AutoMockedContainer';
|
|
21
20
|
export { SingletonProvider } from './providers/SingletonProvider';
|
package/cjm/index.js
CHANGED
|
@@ -25,13 +25,13 @@ var __spreadArray = (this && this.__spreadArray) || function (to, from, pack) {
|
|
|
25
25
|
return to.concat(ar || Array.prototype.slice.call(from));
|
|
26
26
|
};
|
|
27
27
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
28
|
-
exports.by = exports.Injector = exports.forKey = exports.asSingleton = exports.perTags = exports.isProviderKey = exports.ProviderReflector = exports.ProviderBuilder = exports.SingletonProvider = exports.AutoMockedContainer = exports.
|
|
28
|
+
exports.by = exports.Injector = exports.forKey = exports.asSingleton = exports.perTags = exports.isProviderKey = exports.ProviderReflector = exports.ProviderBuilder = exports.SingletonProvider = exports.AutoMockedContainer = exports.TaggedProvider = exports.createArgsFnDecorator = exports.ArgsProvider = exports.Provider = exports.ContainerDisposedError = exports.MethodNotImplementedError = exports.ProviderNotFoundError = exports.AsyncMethodReflector = exports.MethodReflector = exports.Container = void 0;
|
|
29
29
|
var Container_1 = require("./core/container/Container");
|
|
30
30
|
Object.defineProperty(exports, "Container", { enumerable: true, get: function () { return Container_1.Container; } });
|
|
31
|
-
var SimpleInjector_1 = require("./injectors/SimpleInjector");
|
|
32
|
-
Object.defineProperty(exports, "SimpleInjector", { enumerable: true, get: function () { return SimpleInjector_1.SimpleInjector; } });
|
|
33
31
|
var MethodReflector_1 = require("./hooks/MethodReflector");
|
|
34
32
|
Object.defineProperty(exports, "MethodReflector", { enumerable: true, get: function () { return MethodReflector_1.MethodReflector; } });
|
|
33
|
+
var AsyncMethodReflector_1 = require("./hooks/AsyncMethodReflector");
|
|
34
|
+
Object.defineProperty(exports, "AsyncMethodReflector", { enumerable: true, get: function () { return AsyncMethodReflector_1.AsyncMethodReflector; } });
|
|
35
35
|
var ProviderNotFoundError_1 = require("./core/provider/ProviderNotFoundError");
|
|
36
36
|
Object.defineProperty(exports, "ProviderNotFoundError", { enumerable: true, get: function () { return ProviderNotFoundError_1.ProviderNotFoundError; } });
|
|
37
37
|
var MethodNotImplementedError_1 = require("./core/utils/MethodNotImplementedError");
|
|
@@ -45,8 +45,6 @@ Object.defineProperty(exports, "ArgsProvider", { enumerable: true, get: function
|
|
|
45
45
|
Object.defineProperty(exports, "createArgsFnDecorator", { enumerable: true, get: function () { return ArgsProvider_1.createArgsFnDecorator; } });
|
|
46
46
|
var TaggedProvider_1 = require("./providers/TaggedProvider");
|
|
47
47
|
Object.defineProperty(exports, "TaggedProvider", { enumerable: true, get: function () { return TaggedProvider_1.TaggedProvider; } });
|
|
48
|
-
var ProxyInjector_1 = require("./injectors/ProxyInjector");
|
|
49
|
-
Object.defineProperty(exports, "ProxyInjector", { enumerable: true, get: function () { return ProxyInjector_1.ProxyInjector; } });
|
|
50
48
|
var AutoMockedContainer_1 = require("./automock/AutoMockedContainer");
|
|
51
49
|
Object.defineProperty(exports, "AutoMockedContainer", { enumerable: true, get: function () { return AutoMockedContainer_1.AutoMockedContainer; } });
|
|
52
50
|
var SingletonProvider_1 = require("./providers/SingletonProvider");
|
package/cjm/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../lib/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;AAKA,wDAAuD;AAA9C,sGAAA,SAAS,OAAA;
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../lib/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;AAKA,wDAAuD;AAA9C,sGAAA,SAAS,OAAA;AAIlB,2DAA0D;AAAjD,kHAAA,eAAe,OAAA;AACxB,qEAAoE;AAA3D,4HAAA,oBAAoB,OAAA;AAE7B,+EAA8E;AAArE,8HAAA,qBAAqB,OAAA;AAC9B,oFAAmF;AAA1E,sIAAA,yBAAyB,OAAA;AAClC,kFAAiF;AAAxE,gIAAA,sBAAsB,OAAA;AAC/B,qDAAoD;AAA3C,oGAAA,QAAQ,OAAA;AACjB,yDAAuF;AAA9E,4GAAA,YAAY,OAAA;AAAU,qHAAA,qBAAqB,OAAA;AACpD,6DAA4D;AAAnD,gHAAA,cAAc,OAAA;AAEvB,sEAAqE;AAA5D,0HAAA,mBAAmB,OAAA;AAC5B,mEAAkE;AAAzD,sHAAA,iBAAiB,OAAA;AAC1B,+DAA8D;AAArD,kHAAA,eAAe,OAAA;AAExB,uEAAsE;AAA7D,sHAAA,iBAAiB,OAAA;AAG1B,uDAA0D;AAAjD,0GAAA,aAAa,OAAA;AACtB,6DAAqD;AAA5C,yGAAA,OAAO,OAAA;AAChB,mEAA4D;AAAnD,gHAAA,WAAW,OAAA;AACpB,qDAAkD;AAAzC,kGAAA,MAAM,OAAA;AACf,8CAA2D;AAAnC,qGAAA,QAAQ,OAAA;AAEzB,IAAM,EAAE,GACX,UAAI,GAAsB;IAAE,cAAkB;SAAlB,UAAkB,EAAlB,qBAAkB,EAAlB,IAAkB;QAAlB,6BAAkB;;IAC9C,OAAA,UAAC,CAAa;QACV,OAAA,CAAC,CAAC,OAAO,OAAT,CAAC,iBAAY,GAAG,UAAK,IAAI;IAAzB,CAA0B;AAD9B,CAC8B,CAAC;AAHtB,QAAA,EAAE,MAGoB"}
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import { IProvider, ProviderKey } from './IProvider';
|
|
2
2
|
export declare class ProviderRepo {
|
|
3
3
|
private readonly providers;
|
|
4
|
-
add(provider: IProvider<unknown>):
|
|
4
|
+
add(provider: IProvider<unknown>): this;
|
|
5
5
|
get<T>(key: ProviderKey): IProvider<T> | undefined;
|
|
6
6
|
merge(providers: IProvider<unknown>[]): IProvider<unknown>[];
|
|
7
7
|
dispose(): void;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ProviderRepo.js","sourceRoot":"","sources":["../../../lib/core/provider/ProviderRepo.ts"],"names":[],"mappings":"AAEA,MAAM,OAAO,YAAY;IAAzB;QACqB,cAAS,GAAG,IAAI,GAAG,EAAmC,CAAC;
|
|
1
|
+
{"version":3,"file":"ProviderRepo.js","sourceRoot":"","sources":["../../../lib/core/provider/ProviderRepo.ts"],"names":[],"mappings":"AAEA,MAAM,OAAO,YAAY;IAAzB;QACqB,cAAS,GAAG,IAAI,GAAG,EAAmC,CAAC;IAyB5E,CAAC;IAvBG,GAAG,CAAC,QAA4B;QAC5B,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,QAAQ,CAAC,YAAY,EAAE,EAAE,QAAQ,CAAC,CAAC;QACtD,OAAO,IAAI,CAAC;IAChB,CAAC;IAED,GAAG,CAAI,GAAgB;QACnB,OAAO,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,GAAG,CAAiB,CAAC;IACnD,CAAC;IAED,KAAK,CAAC,SAA+B;QACjC,MAAM,GAAG,GAAG,IAAI,GAAG,EAAmC,CAAC;QACvD,KAAK,MAAM,CAAC,IAAI,SAAS,CAAC,MAAM,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,MAAM,EAAE,CAAC,CAAC,EAAE;YACnE,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC,YAAY,EAAE,EAAE,CAAC,CAAC,CAAC;SAChC;QACD,OAAO,KAAK,CAAC,IAAI,CAAC,GAAG,CAAC,MAAM,EAAE,CAAC,CAAC;IACpC,CAAC;IAED,OAAO;QACH,KAAK,MAAM,CAAC,IAAI,IAAI,CAAC,SAAS,CAAC,MAAM,EAAE,EAAE;YACrC,CAAC,CAAC,OAAO,EAAE,CAAC;SACf;QACD,IAAI,CAAC,SAAS,CAAC,KAAK,EAAE,CAAC;IAC3B,CAAC;CACJ"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
export declare class AsyncMethodReflector {
|
|
2
|
+
readonly hookKey: string | symbol;
|
|
3
|
+
constructor(hookKey: string | symbol);
|
|
4
|
+
private addHook;
|
|
5
|
+
invokeHooksOf<GInstance extends Object>(target: GInstance): Promise<void>;
|
|
6
|
+
private static getTargetId;
|
|
7
|
+
createMethodHookDecorator(): MethodDecorator;
|
|
8
|
+
}
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
export class AsyncMethodReflector {
|
|
2
|
+
constructor(hookKey) {
|
|
3
|
+
this.hookKey = hookKey;
|
|
4
|
+
}
|
|
5
|
+
// eslint-disable-next-line @typescript-eslint/ban-types
|
|
6
|
+
addHook(target, propertyKey) {
|
|
7
|
+
const targetId = AsyncMethodReflector.getTargetId(target);
|
|
8
|
+
const hooks = Reflect.getMetadata(this.hookKey, targetId) || [];
|
|
9
|
+
Reflect.defineMetadata(this.hookKey, [...hooks, propertyKey], targetId);
|
|
10
|
+
}
|
|
11
|
+
// eslint-disable-next-line @typescript-eslint/ban-types
|
|
12
|
+
async invokeHooksOf(target) {
|
|
13
|
+
const targetId = AsyncMethodReflector.getTargetId(target);
|
|
14
|
+
const hooks = Reflect.hasMetadata(this.hookKey, targetId)
|
|
15
|
+
? Reflect.getMetadata(this.hookKey, targetId)
|
|
16
|
+
: [];
|
|
17
|
+
for (const hookMethod of hooks) {
|
|
18
|
+
await target[hookMethod]();
|
|
19
|
+
}
|
|
20
|
+
}
|
|
21
|
+
// eslint-disable-next-line @typescript-eslint/ban-types
|
|
22
|
+
static getTargetId(target) {
|
|
23
|
+
return target.constructor;
|
|
24
|
+
}
|
|
25
|
+
createMethodHookDecorator() {
|
|
26
|
+
return (target, propertyKey) => {
|
|
27
|
+
// eslint-disable-next-line @typescript-eslint/ban-types
|
|
28
|
+
this.addHook(target, propertyKey);
|
|
29
|
+
};
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
//# sourceMappingURL=AsyncMethodReflector.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"AsyncMethodReflector.js","sourceRoot":"","sources":["../../lib/hooks/AsyncMethodReflector.ts"],"names":[],"mappings":"AAAA,MAAM,OAAO,oBAAoB;IAC7B,YAAqB,OAAwB;QAAxB,YAAO,GAAP,OAAO,CAAiB;IAAG,CAAC;IAEjD,wDAAwD;IAChD,OAAO,CAA2B,MAAiB,EAAE,WAA4B;QACrF,MAAM,QAAQ,GAAG,oBAAoB,CAAC,WAAW,CAAC,MAAM,CAAC,CAAC;QAC1D,MAAM,KAAK,GAAG,OAAO,CAAC,WAAW,CAAC,IAAI,CAAC,OAAO,EAAE,QAAQ,CAAC,IAAI,EAAE,CAAC;QAChE,OAAO,CAAC,cAAc,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC,GAAG,KAAK,EAAE,WAAW,CAAC,EAAE,QAAQ,CAAC,CAAC;IAC5E,CAAC;IAED,wDAAwD;IACxD,KAAK,CAAC,aAAa,CAA2B,MAAiB;QAC3D,MAAM,QAAQ,GAAG,oBAAoB,CAAC,WAAW,CAAC,MAAM,CAAC,CAAC;QAC1D,MAAM,KAAK,GAAa,OAAO,CAAC,WAAW,CAAC,IAAI,CAAC,OAAO,EAAE,QAAQ,CAAC;YAC/D,CAAC,CAAC,OAAO,CAAC,WAAW,CAAC,IAAI,CAAC,OAAO,EAAE,QAAQ,CAAC;YAC7C,CAAC,CAAC,EAAE,CAAC;QAET,KAAK,MAAM,UAAU,IAAI,KAAK,EAAE;YAC5B,MAAO,MAAc,CAAC,UAAU,CAAC,EAAE,CAAC;SACvC;IACL,CAAC;IAED,wDAAwD;IAChD,MAAM,CAAC,WAAW,CAAiC,MAAiB;QACxE,OAAO,MAAM,CAAC,WAAW,CAAC;IAC9B,CAAC;IAED,yBAAyB;QACrB,OAAO,CAAC,MAAM,EAAE,WAAW,EAAE,EAAE;YAC3B,wDAAwD;YACxD,IAAI,CAAC,OAAO,CAAC,MAAM,EAAE,WAAW,CAAC,CAAC;QACtC,CAAC,CAAC;IACN,CAAC;CACJ"}
|
package/esm/index.d.ts
CHANGED
|
@@ -5,9 +5,9 @@ export { constructor } from './core/utils/types';
|
|
|
5
5
|
export { Container } from './core/container/Container';
|
|
6
6
|
export { Tagged, ResolveDependency, Tag, IProvider } from './core/provider/IProvider';
|
|
7
7
|
export { IInjector } from './core/IInjector';
|
|
8
|
-
export { SimpleInjector } from './injectors/SimpleInjector';
|
|
9
8
|
export { IMethodReflector } from './hooks/IMethodReflector';
|
|
10
9
|
export { MethodReflector } from './hooks/MethodReflector';
|
|
10
|
+
export { AsyncMethodReflector } from './hooks/AsyncMethodReflector';
|
|
11
11
|
export { InjectionToken } from './core/container/IContainer';
|
|
12
12
|
export { ProviderNotFoundError } from './core/provider/ProviderNotFoundError';
|
|
13
13
|
export { MethodNotImplementedError } from './core/utils/MethodNotImplementedError';
|
|
@@ -15,7 +15,6 @@ export { ContainerDisposedError } from './core/container/ContainerDisposedError'
|
|
|
15
15
|
export { Provider } from './core/provider/Provider';
|
|
16
16
|
export { ArgsProvider, ArgsFn, createArgsFnDecorator } from './providers/ArgsProvider';
|
|
17
17
|
export { TaggedProvider } from './providers/TaggedProvider';
|
|
18
|
-
export { ProxyInjector } from './injectors/ProxyInjector';
|
|
19
18
|
export { IMockRepository } from './automock/IMockRepository';
|
|
20
19
|
export { AutoMockedContainer } from './automock/AutoMockedContainer';
|
|
21
20
|
export { SingletonProvider } from './providers/SingletonProvider';
|
package/esm/index.js
CHANGED
|
@@ -1,13 +1,12 @@
|
|
|
1
1
|
export { Container } from './core/container/Container';
|
|
2
|
-
export { SimpleInjector } from './injectors/SimpleInjector';
|
|
3
2
|
export { MethodReflector } from './hooks/MethodReflector';
|
|
3
|
+
export { AsyncMethodReflector } from './hooks/AsyncMethodReflector';
|
|
4
4
|
export { ProviderNotFoundError } from './core/provider/ProviderNotFoundError';
|
|
5
5
|
export { MethodNotImplementedError } from './core/utils/MethodNotImplementedError';
|
|
6
6
|
export { ContainerDisposedError } from './core/container/ContainerDisposedError';
|
|
7
7
|
export { Provider } from './core/provider/Provider';
|
|
8
8
|
export { ArgsProvider, createArgsFnDecorator } from './providers/ArgsProvider';
|
|
9
9
|
export { TaggedProvider } from './providers/TaggedProvider';
|
|
10
|
-
export { ProxyInjector } from './injectors/ProxyInjector';
|
|
11
10
|
export { AutoMockedContainer } from './automock/AutoMockedContainer';
|
|
12
11
|
export { SingletonProvider } from './providers/SingletonProvider';
|
|
13
12
|
export { ProviderBuilder } from './providers/ProviderBuilder';
|
package/esm/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../lib/index.ts"],"names":[],"mappings":"AAKA,OAAO,EAAE,SAAS,EAAE,MAAM,4BAA4B,CAAC;
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../lib/index.ts"],"names":[],"mappings":"AAKA,OAAO,EAAE,SAAS,EAAE,MAAM,4BAA4B,CAAC;AAIvD,OAAO,EAAE,eAAe,EAAE,MAAM,yBAAyB,CAAC;AAC1D,OAAO,EAAE,oBAAoB,EAAE,MAAM,8BAA8B,CAAC;AAEpE,OAAO,EAAE,qBAAqB,EAAE,MAAM,uCAAuC,CAAC;AAC9E,OAAO,EAAE,yBAAyB,EAAE,MAAM,wCAAwC,CAAC;AACnF,OAAO,EAAE,sBAAsB,EAAE,MAAM,yCAAyC,CAAC;AACjF,OAAO,EAAE,QAAQ,EAAE,MAAM,0BAA0B,CAAC;AACpD,OAAO,EAAE,YAAY,EAAU,qBAAqB,EAAE,MAAM,0BAA0B,CAAC;AACvF,OAAO,EAAE,cAAc,EAAE,MAAM,4BAA4B,CAAC;AAE5D,OAAO,EAAE,mBAAmB,EAAE,MAAM,gCAAgC,CAAC;AACrE,OAAO,EAAE,iBAAiB,EAAE,MAAM,+BAA+B,CAAC;AAClE,OAAO,EAAE,eAAe,EAAE,MAAM,6BAA6B,CAAC;AAE9D,OAAO,EAAE,iBAAiB,EAAE,MAAM,mCAAmC,CAAC;AAGtE,OAAO,EAAE,aAAa,EAAE,MAAM,2BAA2B,CAAC;AAC1D,OAAO,EAAE,OAAO,EAAE,MAAM,4BAA4B,CAAC;AACrD,OAAO,EAAE,WAAW,EAAE,MAAM,+BAA+B,CAAC;AAC5D,OAAO,EAAE,MAAM,EAAE,MAAM,0BAA0B,CAAC;AAClD,OAAO,EAAiB,QAAQ,EAAE,MAAM,kBAAkB,CAAC;AAE3D,MAAM,CAAC,MAAM,EAAE,GACX,CAAI,GAAsB,EAAE,GAAG,IAAe,EAAE,EAAE,CAClD,CAAC,CAAa,EAAE,EAAE,CACd,CAAC,CAAC,OAAO,CAAI,GAAG,EAAE,GAAG,IAAI,CAAC,CAAC"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "ts-ioc-container",
|
|
3
|
-
"version": "18.0.
|
|
3
|
+
"version": "18.0.4",
|
|
4
4
|
"description": "Typescript IoC container",
|
|
5
5
|
"author": "ibabkin <igba14@gmail.com>",
|
|
6
6
|
"homepage": "https://github.com/IgorBabkin/ts-ioc-container/tree/master/packages/ts-ioc-container",
|
|
@@ -46,5 +46,5 @@
|
|
|
46
46
|
"ts-jest": "27.0.5",
|
|
47
47
|
"typescript": "4.4.3"
|
|
48
48
|
},
|
|
49
|
-
"gitHead": "
|
|
49
|
+
"gitHead": "897666753d6e03f2fec691bf09e2ac9046689294"
|
|
50
50
|
}
|
|
@@ -1,10 +0,0 @@
|
|
|
1
|
-
import { IInjector } from '../core/IInjector';
|
|
2
|
-
import { IContainer } from '../core/container/IContainer';
|
|
3
|
-
import { constructor } from '../core/utils/types';
|
|
4
|
-
import { ProviderKey } from '../core/provider/IProvider';
|
|
5
|
-
export declare class ProxyInjector implements IInjector {
|
|
6
|
-
resolve<T>(container: IContainer, value: constructor<T>, ...deps: Record<ProviderKey, unknown>[]): T;
|
|
7
|
-
clone(): IInjector;
|
|
8
|
-
dispose(): void;
|
|
9
|
-
getInstances(): unknown[];
|
|
10
|
-
}
|
|
@@ -1,43 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __assign = (this && this.__assign) || function () {
|
|
3
|
-
__assign = Object.assign || function(t) {
|
|
4
|
-
for (var s, i = 1, n = arguments.length; i < n; i++) {
|
|
5
|
-
s = arguments[i];
|
|
6
|
-
for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
|
|
7
|
-
t[p] = s[p];
|
|
8
|
-
}
|
|
9
|
-
return t;
|
|
10
|
-
};
|
|
11
|
-
return __assign.apply(this, arguments);
|
|
12
|
-
};
|
|
13
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
14
|
-
exports.ProxyInjector = void 0;
|
|
15
|
-
var ProxyInjector = /** @class */ (function () {
|
|
16
|
-
function ProxyInjector() {
|
|
17
|
-
}
|
|
18
|
-
// eslint-disable-next-line @typescript-eslint/ban-types
|
|
19
|
-
ProxyInjector.prototype.resolve = function (container, value) {
|
|
20
|
-
var deps = [];
|
|
21
|
-
for (var _i = 2; _i < arguments.length; _i++) {
|
|
22
|
-
deps[_i - 2] = arguments[_i];
|
|
23
|
-
}
|
|
24
|
-
var args = deps.reduce(function (acc, it) { return (__assign(__assign({}, acc), it)); }, {});
|
|
25
|
-
return new value(new Proxy(container, {
|
|
26
|
-
// eslint-disable-next-line @typescript-eslint/ban-types
|
|
27
|
-
get: function (target, prop) {
|
|
28
|
-
// eslint-disable-next-line no-prototype-builtins
|
|
29
|
-
return args.hasOwnProperty(prop) ? args[prop] : target.resolve(prop);
|
|
30
|
-
},
|
|
31
|
-
}));
|
|
32
|
-
};
|
|
33
|
-
ProxyInjector.prototype.clone = function () {
|
|
34
|
-
return new ProxyInjector();
|
|
35
|
-
};
|
|
36
|
-
ProxyInjector.prototype.dispose = function () { };
|
|
37
|
-
ProxyInjector.prototype.getInstances = function () {
|
|
38
|
-
return [];
|
|
39
|
-
};
|
|
40
|
-
return ProxyInjector;
|
|
41
|
-
}());
|
|
42
|
-
exports.ProxyInjector = ProxyInjector;
|
|
43
|
-
//# sourceMappingURL=ProxyInjector.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"ProxyInjector.js","sourceRoot":"","sources":["../../lib/injectors/ProxyInjector.ts"],"names":[],"mappings":";;;;;;;;;;;;;;AAKA;IAAA;IAwBA,CAAC;IAvBG,wDAAwD;IACxD,+BAAO,GAAP,UAAW,SAAqB,EAAE,KAAqB;QAAE,cAAuC;aAAvC,UAAuC,EAAvC,qBAAuC,EAAvC,IAAuC;YAAvC,6BAAuC;;QAC5F,IAAM,IAAI,GAAG,IAAI,CAAC,MAAM,CAAC,UAAC,GAAG,EAAE,EAAE,IAAK,OAAA,uBAAM,GAAG,GAAK,EAAE,EAAG,EAAnB,CAAmB,EAAE,EAAE,CAAC,CAAC;QAC/D,OAAO,IAAI,KAAK,CACZ,IAAI,KAAK,CAAC,SAAS,EAAE;YACjB,wDAAwD;YACxD,GAAG,EAAH,UAAI,MAAkB,EAAE,IAAiB;gBACrC,iDAAiD;gBACjD,OAAO,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;YACzE,CAAC;SACJ,CAAC,CACL,CAAC;IACN,CAAC;IAED,6BAAK,GAAL;QACI,OAAO,IAAI,aAAa,EAAE,CAAC;IAC/B,CAAC;IAED,+BAAO,GAAP,cAAiB,CAAC;IAElB,oCAAY,GAAZ;QACI,OAAO,EAAE,CAAC;IACd,CAAC;IACL,oBAAC;AAAD,CAAC,AAxBD,IAwBC;AAxBY,sCAAa"}
|
|
@@ -1,9 +0,0 @@
|
|
|
1
|
-
import { constructor } from '../core/utils/types';
|
|
2
|
-
import { IContainer } from '../core/container/IContainer';
|
|
3
|
-
import { IInjector } from '../core/IInjector';
|
|
4
|
-
export declare class SimpleInjector implements IInjector {
|
|
5
|
-
resolve<T>(container: IContainer, value: constructor<T>, ...deps: any[]): T;
|
|
6
|
-
clone(): IInjector;
|
|
7
|
-
dispose(): void;
|
|
8
|
-
getInstances(): unknown[];
|
|
9
|
-
}
|
|
@@ -1,49 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __read = (this && this.__read) || function (o, n) {
|
|
3
|
-
var m = typeof Symbol === "function" && o[Symbol.iterator];
|
|
4
|
-
if (!m) return o;
|
|
5
|
-
var i = m.call(o), r, ar = [], e;
|
|
6
|
-
try {
|
|
7
|
-
while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);
|
|
8
|
-
}
|
|
9
|
-
catch (error) { e = { error: error }; }
|
|
10
|
-
finally {
|
|
11
|
-
try {
|
|
12
|
-
if (r && !r.done && (m = i["return"])) m.call(i);
|
|
13
|
-
}
|
|
14
|
-
finally { if (e) throw e.error; }
|
|
15
|
-
}
|
|
16
|
-
return ar;
|
|
17
|
-
};
|
|
18
|
-
var __spreadArray = (this && this.__spreadArray) || function (to, from, pack) {
|
|
19
|
-
if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) {
|
|
20
|
-
if (ar || !(i in from)) {
|
|
21
|
-
if (!ar) ar = Array.prototype.slice.call(from, 0, i);
|
|
22
|
-
ar[i] = from[i];
|
|
23
|
-
}
|
|
24
|
-
}
|
|
25
|
-
return to.concat(ar || Array.prototype.slice.call(from));
|
|
26
|
-
};
|
|
27
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
28
|
-
exports.SimpleInjector = void 0;
|
|
29
|
-
var SimpleInjector = /** @class */ (function () {
|
|
30
|
-
function SimpleInjector() {
|
|
31
|
-
}
|
|
32
|
-
SimpleInjector.prototype.resolve = function (container, value) {
|
|
33
|
-
var deps = [];
|
|
34
|
-
for (var _i = 2; _i < arguments.length; _i++) {
|
|
35
|
-
deps[_i - 2] = arguments[_i];
|
|
36
|
-
}
|
|
37
|
-
return new (value.bind.apply(value, __spreadArray([void 0, container], __read(deps), false)))();
|
|
38
|
-
};
|
|
39
|
-
SimpleInjector.prototype.clone = function () {
|
|
40
|
-
return new SimpleInjector();
|
|
41
|
-
};
|
|
42
|
-
SimpleInjector.prototype.dispose = function () { };
|
|
43
|
-
SimpleInjector.prototype.getInstances = function () {
|
|
44
|
-
return [];
|
|
45
|
-
};
|
|
46
|
-
return SimpleInjector;
|
|
47
|
-
}());
|
|
48
|
-
exports.SimpleInjector = SimpleInjector;
|
|
49
|
-
//# sourceMappingURL=SimpleInjector.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"SimpleInjector.js","sourceRoot":"","sources":["../../lib/injectors/SimpleInjector.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;AAIA;IAAA;IAcA,CAAC;IAbG,gCAAO,GAAP,UAAW,SAAqB,EAAE,KAAqB;QAAE,cAAc;aAAd,UAAc,EAAd,qBAAc,EAAd,IAAc;YAAd,6BAAc;;QACnE,YAAW,KAAK,YAAL,KAAK,yBAAC,SAAS,UAAK,IAAI,cAAE;IACzC,CAAC;IAED,8BAAK,GAAL;QACI,OAAO,IAAI,cAAc,EAAE,CAAC;IAChC,CAAC;IAED,gCAAO,GAAP,cAAiB,CAAC;IAElB,qCAAY,GAAZ;QACI,OAAO,EAAE,CAAC;IACd,CAAC;IACL,qBAAC;AAAD,CAAC,AAdD,IAcC;AAdY,wCAAc"}
|
|
@@ -1,10 +0,0 @@
|
|
|
1
|
-
import { IInjector } from '../core/IInjector';
|
|
2
|
-
import { IContainer } from '../core/container/IContainer';
|
|
3
|
-
import { constructor } from '../core/utils/types';
|
|
4
|
-
import { ProviderKey } from '../core/provider/IProvider';
|
|
5
|
-
export declare class ProxyInjector implements IInjector {
|
|
6
|
-
resolve<T>(container: IContainer, value: constructor<T>, ...deps: Record<ProviderKey, unknown>[]): T;
|
|
7
|
-
clone(): IInjector;
|
|
8
|
-
dispose(): void;
|
|
9
|
-
getInstances(): unknown[];
|
|
10
|
-
}
|
|
@@ -1,21 +0,0 @@
|
|
|
1
|
-
export class ProxyInjector {
|
|
2
|
-
// eslint-disable-next-line @typescript-eslint/ban-types
|
|
3
|
-
resolve(container, value, ...deps) {
|
|
4
|
-
const args = deps.reduce((acc, it) => (Object.assign(Object.assign({}, acc), it)), {});
|
|
5
|
-
return new value(new Proxy(container, {
|
|
6
|
-
// eslint-disable-next-line @typescript-eslint/ban-types
|
|
7
|
-
get(target, prop) {
|
|
8
|
-
// eslint-disable-next-line no-prototype-builtins
|
|
9
|
-
return args.hasOwnProperty(prop) ? args[prop] : target.resolve(prop);
|
|
10
|
-
},
|
|
11
|
-
}));
|
|
12
|
-
}
|
|
13
|
-
clone() {
|
|
14
|
-
return new ProxyInjector();
|
|
15
|
-
}
|
|
16
|
-
dispose() { }
|
|
17
|
-
getInstances() {
|
|
18
|
-
return [];
|
|
19
|
-
}
|
|
20
|
-
}
|
|
21
|
-
//# sourceMappingURL=ProxyInjector.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"ProxyInjector.js","sourceRoot":"","sources":["../../lib/injectors/ProxyInjector.ts"],"names":[],"mappings":"AAKA,MAAM,OAAO,aAAa;IACtB,wDAAwD;IACxD,OAAO,CAAI,SAAqB,EAAE,KAAqB,EAAE,GAAG,IAAoC;QAC5F,MAAM,IAAI,GAAG,IAAI,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,EAAE,EAAE,EAAE,CAAC,iCAAM,GAAG,GAAK,EAAE,EAAG,EAAE,EAAE,CAAC,CAAC;QAC/D,OAAO,IAAI,KAAK,CACZ,IAAI,KAAK,CAAC,SAAS,EAAE;YACjB,wDAAwD;YACxD,GAAG,CAAC,MAAkB,EAAE,IAAiB;gBACrC,iDAAiD;gBACjD,OAAO,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;YACzE,CAAC;SACJ,CAAC,CACL,CAAC;IACN,CAAC;IAED,KAAK;QACD,OAAO,IAAI,aAAa,EAAE,CAAC;IAC/B,CAAC;IAED,OAAO,KAAU,CAAC;IAElB,YAAY;QACR,OAAO,EAAE,CAAC;IACd,CAAC;CACJ"}
|
|
@@ -1,9 +0,0 @@
|
|
|
1
|
-
import { constructor } from '../core/utils/types';
|
|
2
|
-
import { IContainer } from '../core/container/IContainer';
|
|
3
|
-
import { IInjector } from '../core/IInjector';
|
|
4
|
-
export declare class SimpleInjector implements IInjector {
|
|
5
|
-
resolve<T>(container: IContainer, value: constructor<T>, ...deps: any[]): T;
|
|
6
|
-
clone(): IInjector;
|
|
7
|
-
dispose(): void;
|
|
8
|
-
getInstances(): unknown[];
|
|
9
|
-
}
|
|
@@ -1,13 +0,0 @@
|
|
|
1
|
-
export class SimpleInjector {
|
|
2
|
-
resolve(container, value, ...deps) {
|
|
3
|
-
return new value(container, ...deps);
|
|
4
|
-
}
|
|
5
|
-
clone() {
|
|
6
|
-
return new SimpleInjector();
|
|
7
|
-
}
|
|
8
|
-
dispose() { }
|
|
9
|
-
getInstances() {
|
|
10
|
-
return [];
|
|
11
|
-
}
|
|
12
|
-
}
|
|
13
|
-
//# sourceMappingURL=SimpleInjector.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"SimpleInjector.js","sourceRoot":"","sources":["../../lib/injectors/SimpleInjector.ts"],"names":[],"mappings":"AAIA,MAAM,OAAO,cAAc;IACvB,OAAO,CAAI,SAAqB,EAAE,KAAqB,EAAE,GAAG,IAAW;QACnE,OAAO,IAAI,KAAK,CAAC,SAAS,EAAE,GAAG,IAAI,CAAC,CAAC;IACzC,CAAC;IAED,KAAK;QACD,OAAO,IAAI,cAAc,EAAE,CAAC;IAChC,CAAC;IAED,OAAO,KAAU,CAAC;IAElB,YAAY;QACR,OAAO,EAAE,CAAC;IACd,CAAC;CACJ"}
|