@nmtjs/core 0.15.0-beta.1 → 0.15.0-beta.11
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/dist/constants.d.ts +18 -0
- package/dist/constants.js +10 -0
- package/dist/constants.js.map +1 -0
- package/dist/container.d.ts +47 -0
- package/dist/container.js +329 -0
- package/dist/container.js.map +1 -0
- package/dist/enums.d.ts +6 -0
- package/dist/enums.js +8 -0
- package/dist/enums.js.map +1 -0
- package/dist/hooks.d.ts +13 -0
- package/dist/hooks.js +12 -0
- package/dist/hooks.js.map +1 -0
- package/dist/index.d.ts +10 -0
- package/dist/index.js +14 -0
- package/dist/index.js.map +1 -0
- package/dist/injectables.d.ts +88 -0
- package/dist/injectables.js +142 -0
- package/dist/injectables.js.map +1 -0
- package/dist/logger.d.ts +11 -0
- package/dist/logger.js +67 -0
- package/dist/logger.js.map +1 -0
- package/dist/metadata.d.ts +13 -0
- package/dist/metadata.js +16 -0
- package/dist/metadata.js.map +1 -0
- package/dist/plugin.d.ts +9 -0
- package/dist/plugin.js +4 -0
- package/dist/plugin.js.map +1 -0
- package/dist/types.d.ts +2 -0
- package/dist/types.js +2 -0
- package/dist/types.js.map +1 -0
- package/dist/utils/functions.d.ts +7 -0
- package/dist/utils/functions.js +18 -0
- package/dist/utils/functions.js.map +1 -0
- package/dist/utils/index.d.ts +3 -0
- package/dist/utils/index.js +4 -0
- package/dist/utils/index.js.map +1 -0
- package/dist/utils/pool.d.ts +18 -0
- package/dist/utils/pool.js +106 -0
- package/dist/utils/pool.js.map +1 -0
- package/dist/utils/semaphore.d.ts +13 -0
- package/dist/utils/semaphore.js +56 -0
- package/dist/utils/semaphore.js.map +1 -0
- package/package.json +7 -6
- package/src/constants.ts +34 -0
- package/src/container.ts +509 -0
- package/src/enums.ts +6 -0
- package/src/hooks.ts +24 -0
- package/src/index.ts +14 -0
- package/src/injectables.ts +359 -0
- package/src/logger.ts +103 -0
- package/src/metadata.ts +24 -0
- package/src/plugin.ts +16 -0
- package/src/types.ts +3 -0
- package/src/utils/functions.ts +31 -0
- package/src/utils/index.ts +3 -0
- package/src/utils/pool.ts +111 -0
- package/src/utils/semaphore.ts +63 -0
|
@@ -0,0 +1,142 @@
|
|
|
1
|
+
import { tryCaptureStackTrace } from '@nmtjs/common';
|
|
2
|
+
import { kFactoryInjectable, kInjectable, kLazyInjectable, kOptionalDependency, kValueInjectable, } from "./constants.js";
|
|
3
|
+
import { Scope } from "./enums.js";
|
|
4
|
+
const ScopeStrictness = {
|
|
5
|
+
[Scope.Transient]: Number.NaN, // this should make it always fail to compare with other scopes
|
|
6
|
+
[Scope.Global]: 1,
|
|
7
|
+
[Scope.Connection]: 2,
|
|
8
|
+
[Scope.Call]: 3,
|
|
9
|
+
};
|
|
10
|
+
export const isLazyInjectable = (injectable) => injectable[kLazyInjectable];
|
|
11
|
+
export const isFactoryInjectable = (injectable) => injectable[kFactoryInjectable];
|
|
12
|
+
export const isValueInjectable = (injectable) => injectable[kValueInjectable];
|
|
13
|
+
export const isInjectable = (injectable) => injectable[kInjectable];
|
|
14
|
+
export const isOptionalInjectable = (injectable) => injectable[kOptionalDependency];
|
|
15
|
+
export function getInjectableScope(injectable) {
|
|
16
|
+
let scope = injectable.scope;
|
|
17
|
+
const deps = injectable.dependencies;
|
|
18
|
+
for (const key in deps) {
|
|
19
|
+
const dependency = deps[key];
|
|
20
|
+
const injectable = getDepedencencyInjectable(dependency);
|
|
21
|
+
const dependencyScope = getInjectableScope(injectable);
|
|
22
|
+
if (dependencyScope !== Scope.Transient &&
|
|
23
|
+
scope !== Scope.Transient &&
|
|
24
|
+
compareScope(dependencyScope, '>', scope)) {
|
|
25
|
+
scope = dependencyScope;
|
|
26
|
+
}
|
|
27
|
+
}
|
|
28
|
+
return scope;
|
|
29
|
+
}
|
|
30
|
+
export function getDepedencencyInjectable(dependency) {
|
|
31
|
+
if (kOptionalDependency in dependency) {
|
|
32
|
+
return dependency.injectable;
|
|
33
|
+
}
|
|
34
|
+
return dependency;
|
|
35
|
+
}
|
|
36
|
+
export function createOptionalInjectable(injectable) {
|
|
37
|
+
return Object.freeze({
|
|
38
|
+
[kOptionalDependency]: true,
|
|
39
|
+
injectable,
|
|
40
|
+
});
|
|
41
|
+
}
|
|
42
|
+
export function createLazyInjectable(scope = Scope.Global, label, stackTraceDepth = 0) {
|
|
43
|
+
const injectable = Object.freeze({
|
|
44
|
+
scope,
|
|
45
|
+
dependencies: {},
|
|
46
|
+
label,
|
|
47
|
+
stack: tryCaptureStackTrace(stackTraceDepth),
|
|
48
|
+
optional: () => createOptionalInjectable(injectable),
|
|
49
|
+
$withType: () => injectable,
|
|
50
|
+
[kInjectable]: true,
|
|
51
|
+
[kLazyInjectable]: true,
|
|
52
|
+
});
|
|
53
|
+
return injectable;
|
|
54
|
+
}
|
|
55
|
+
export function createValueInjectable(value, label, stackTraceDepth = 0) {
|
|
56
|
+
return Object.freeze({
|
|
57
|
+
value,
|
|
58
|
+
scope: Scope.Global,
|
|
59
|
+
dependencies: {},
|
|
60
|
+
label,
|
|
61
|
+
stack: tryCaptureStackTrace(stackTraceDepth),
|
|
62
|
+
[kInjectable]: true,
|
|
63
|
+
[kValueInjectable]: true,
|
|
64
|
+
});
|
|
65
|
+
}
|
|
66
|
+
export function createFactoryInjectable(paramsOrFactory, label, stackTraceDepth = 0) {
|
|
67
|
+
const isFactory = typeof paramsOrFactory === 'function';
|
|
68
|
+
const params = isFactory ? { factory: paramsOrFactory } : paramsOrFactory;
|
|
69
|
+
const injectable = {
|
|
70
|
+
dependencies: (params.dependencies ?? {}),
|
|
71
|
+
scope: (params.scope ?? Scope.Global),
|
|
72
|
+
factory: params.factory,
|
|
73
|
+
dispose: params.dispose,
|
|
74
|
+
pick: params.pick ?? ((instance) => instance),
|
|
75
|
+
label,
|
|
76
|
+
stack: tryCaptureStackTrace(stackTraceDepth),
|
|
77
|
+
optional: () => createOptionalInjectable(injectable),
|
|
78
|
+
[kInjectable]: true,
|
|
79
|
+
[kFactoryInjectable]: true,
|
|
80
|
+
};
|
|
81
|
+
injectable.scope = resolveInjectableScope(typeof params.scope === 'undefined', injectable);
|
|
82
|
+
return Object.freeze(injectable);
|
|
83
|
+
}
|
|
84
|
+
export function substitute(injectable, substitution, stackTraceDepth = 0) {
|
|
85
|
+
const dependencies = { ...injectable.dependencies };
|
|
86
|
+
const depth = stackTraceDepth + 1;
|
|
87
|
+
for (const key in substitution) {
|
|
88
|
+
const value = substitution[key];
|
|
89
|
+
if (key in dependencies) {
|
|
90
|
+
const original = dependencies[key];
|
|
91
|
+
if (isInjectable(value)) {
|
|
92
|
+
dependencies[key] = value;
|
|
93
|
+
}
|
|
94
|
+
else if (isFactoryInjectable(original)) {
|
|
95
|
+
dependencies[key] = substitute(original, value, depth);
|
|
96
|
+
}
|
|
97
|
+
}
|
|
98
|
+
}
|
|
99
|
+
if (isFactoryInjectable(injectable)) {
|
|
100
|
+
// @ts-expect-error
|
|
101
|
+
return createFactoryInjectable({ ...injectable, dependencies }, injectable.label, depth);
|
|
102
|
+
}
|
|
103
|
+
throw new Error('Invalid injectable type');
|
|
104
|
+
}
|
|
105
|
+
export function compareScope(left, operator, right) {
|
|
106
|
+
const leftScope = ScopeStrictness[left];
|
|
107
|
+
const rightScope = ScopeStrictness[right];
|
|
108
|
+
switch (operator) {
|
|
109
|
+
case '=':
|
|
110
|
+
return leftScope === rightScope;
|
|
111
|
+
case '!=':
|
|
112
|
+
return leftScope !== rightScope;
|
|
113
|
+
case '>':
|
|
114
|
+
return leftScope > rightScope;
|
|
115
|
+
case '<':
|
|
116
|
+
return leftScope < rightScope;
|
|
117
|
+
case '>=':
|
|
118
|
+
return leftScope >= rightScope;
|
|
119
|
+
case '<=':
|
|
120
|
+
return leftScope <= rightScope;
|
|
121
|
+
default:
|
|
122
|
+
throw new Error('Invalid operator');
|
|
123
|
+
}
|
|
124
|
+
}
|
|
125
|
+
const logger = Object.assign((label) => createFactoryInjectable({
|
|
126
|
+
dependencies: { logger },
|
|
127
|
+
scope: Scope.Global,
|
|
128
|
+
factory: ({ logger }) => logger.child({ $label: label }),
|
|
129
|
+
}), createLazyInjectable(Scope.Global, 'Logger'));
|
|
130
|
+
const inject = createLazyInjectable(Scope.Global, 'Inject function');
|
|
131
|
+
const dispose = createLazyInjectable(Scope.Global, 'Dispose function');
|
|
132
|
+
function resolveInjectableScope(isDefaultScope, injectable) {
|
|
133
|
+
const actualScope = getInjectableScope(injectable);
|
|
134
|
+
if (!isDefaultScope && compareScope(actualScope, '>', injectable.scope))
|
|
135
|
+
throw new Error(`Invalid scope ${injectable.scope} for an injectable: dependencies have stricter scope - ${actualScope}`);
|
|
136
|
+
return actualScope;
|
|
137
|
+
}
|
|
138
|
+
export const CoreInjectables = { logger, inject, dispose };
|
|
139
|
+
export const provide = (token, value) => {
|
|
140
|
+
return { token, value };
|
|
141
|
+
};
|
|
142
|
+
//# sourceMappingURL=injectables.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"injectables.js","sourceRoot":"","sources":["../src/injectables.ts"],"names":[],"mappings":"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"}
|
package/dist/logger.d.ts
ADDED
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import type * as pinoType from 'pino';
|
|
2
|
+
export type { StreamEntry } from 'pino';
|
|
3
|
+
export type Logger = pinoType.Logger;
|
|
4
|
+
export type LoggerOptions = pinoType.LoggerOptions;
|
|
5
|
+
export type LoggerChildOptions = pinoType.ChildLoggerOptions;
|
|
6
|
+
export type LoggingOptions = {
|
|
7
|
+
destinations?: Array<pinoType.DestinationStream | pinoType.StreamEntry<pinoType.Level>>;
|
|
8
|
+
pinoOptions?: LoggerOptions;
|
|
9
|
+
};
|
|
10
|
+
export declare const createLogger: (options: LoggingOptions | undefined, $lable: string) => pinoType.P.Logger<never, boolean>;
|
|
11
|
+
export declare const createConsolePrettyDestination: (level: pinoType.Level, sync?: boolean) => pinoType.StreamEntry;
|
package/dist/logger.js
ADDED
|
@@ -0,0 +1,67 @@
|
|
|
1
|
+
import { threadId } from 'node:worker_threads';
|
|
2
|
+
import { pino, stdTimeFunctions } from 'pino';
|
|
3
|
+
import { build as pretty } from 'pino-pretty';
|
|
4
|
+
import { errWithCause } from 'pino-std-serializers';
|
|
5
|
+
// TODO: use node:util inspect
|
|
6
|
+
const bg = (value, color) => `\x1b[${color}m${value}\x1b[0m`;
|
|
7
|
+
const fg = (value, color) => `\x1b[38;5;${color}m${value}\x1b[0m`;
|
|
8
|
+
const levelColors = {
|
|
9
|
+
10: 100,
|
|
10
|
+
20: 102,
|
|
11
|
+
30: 106,
|
|
12
|
+
40: 104,
|
|
13
|
+
50: 101,
|
|
14
|
+
60: 105,
|
|
15
|
+
[Number.POSITIVE_INFINITY]: 0,
|
|
16
|
+
};
|
|
17
|
+
const messageColors = {
|
|
18
|
+
10: 0,
|
|
19
|
+
20: 2,
|
|
20
|
+
30: 6,
|
|
21
|
+
40: 4,
|
|
22
|
+
50: 1,
|
|
23
|
+
60: 5,
|
|
24
|
+
[Number.POSITIVE_INFINITY]: 0,
|
|
25
|
+
};
|
|
26
|
+
const levelLabels = {
|
|
27
|
+
10: ' TRACE ',
|
|
28
|
+
20: ' DEBUG ',
|
|
29
|
+
30: ' INFO ',
|
|
30
|
+
40: ' WARN ',
|
|
31
|
+
50: ' ERROR ',
|
|
32
|
+
60: ' FATAL ',
|
|
33
|
+
[Number.POSITIVE_INFINITY]: 'SILENT',
|
|
34
|
+
};
|
|
35
|
+
export const createLogger = (options = {}, $lable) => {
|
|
36
|
+
let { destinations, pinoOptions } = options;
|
|
37
|
+
if (!destinations || !destinations?.length) {
|
|
38
|
+
destinations = [
|
|
39
|
+
createConsolePrettyDestination((options.pinoOptions?.level || 'info')),
|
|
40
|
+
];
|
|
41
|
+
}
|
|
42
|
+
const lowestLevelValue = destinations.reduce((acc, destination) => Math.min(acc, 'stream' in destination
|
|
43
|
+
? pino.levels.values[destination.level]
|
|
44
|
+
: Number.POSITIVE_INFINITY), Number.POSITIVE_INFINITY);
|
|
45
|
+
const level = pino.levels.labels[lowestLevelValue];
|
|
46
|
+
const serializers = { ...pinoOptions?.serializers, err: errWithCause };
|
|
47
|
+
return pino({ timestamp: stdTimeFunctions.isoTime, ...pinoOptions, level, serializers }, pino.multistream(destinations)).child({ $lable, $threadId: threadId });
|
|
48
|
+
};
|
|
49
|
+
export const createConsolePrettyDestination = (level, sync = true) => ({
|
|
50
|
+
level,
|
|
51
|
+
stream: pretty({
|
|
52
|
+
colorize: true,
|
|
53
|
+
ignore: 'hostname,$lable,$threadId',
|
|
54
|
+
errorLikeObjectKeys: ['err', 'error', 'cause'],
|
|
55
|
+
messageFormat: (log, messageKey) => {
|
|
56
|
+
const group = fg(`[${log.$lable}]`, 11);
|
|
57
|
+
const msg = fg(log[messageKey], messageColors[log.level]);
|
|
58
|
+
const thread = fg(`(Thread-${log.$threadId})`, 89);
|
|
59
|
+
return `\x1b[0m${thread} ${group} ${msg}`;
|
|
60
|
+
},
|
|
61
|
+
customPrettifiers: {
|
|
62
|
+
level: (level) => bg(levelLabels[level], levelColors[level]),
|
|
63
|
+
},
|
|
64
|
+
sync,
|
|
65
|
+
}),
|
|
66
|
+
});
|
|
67
|
+
//# sourceMappingURL=logger.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"logger.js","sourceRoot":"","sources":["../src/logger.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { kMetadata } from './constants.ts';
|
|
2
|
+
export type Metadata<T = any> = {
|
|
3
|
+
key: MetadataKey<T>;
|
|
4
|
+
value: T;
|
|
5
|
+
};
|
|
6
|
+
export type MetadataKey<T = any> = {
|
|
7
|
+
[kMetadata]: string;
|
|
8
|
+
as(value: T): Metadata<T>;
|
|
9
|
+
};
|
|
10
|
+
export declare const createMetadataKey: <T>(key: string) => MetadataKey<T>;
|
|
11
|
+
export declare class MetadataStore extends Map<MetadataKey, Metadata> {
|
|
12
|
+
get<T>(key: MetadataKey<T>): T | undefined;
|
|
13
|
+
}
|
package/dist/metadata.js
ADDED
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { kMetadata } from "./constants.js";
|
|
2
|
+
export const createMetadataKey = (key) => {
|
|
3
|
+
const metadataKey = {
|
|
4
|
+
[kMetadata]: key,
|
|
5
|
+
as(value) {
|
|
6
|
+
return { key: metadataKey, value };
|
|
7
|
+
},
|
|
8
|
+
};
|
|
9
|
+
return metadataKey;
|
|
10
|
+
};
|
|
11
|
+
export class MetadataStore extends Map {
|
|
12
|
+
get(key) {
|
|
13
|
+
return super.get(key);
|
|
14
|
+
}
|
|
15
|
+
}
|
|
16
|
+
//# sourceMappingURL=metadata.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"metadata.js","sourceRoot":"","sources":["../src/metadata.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAA;AAS1C,MAAM,CAAC,MAAM,iBAAiB,GAAG,CAAI,GAAW,EAAkB,EAAE;IAClE,MAAM,WAAW,GAAG;QAClB,CAAC,SAAS,CAAC,EAAE,GAAG;QAChB,EAAE,CAAC,KAAQ;YACT,OAAO,EAAE,GAAG,EAAE,WAAW,EAAE,KAAK,EAAE,CAAA;QACpC,CAAC;KACF,CAAA;IACD,OAAO,WAAW,CAAA;AACpB,CAAC,CAAA;AAED,MAAM,OAAO,aAAc,SAAQ,GAA0B;IAC3D,GAAG,CAAI,GAAmB;QACxB,OAAO,KAAK,CAAC,GAAG,CAAC,GAAG,CAAkB,CAAA;IACxC,CAAC;CACF"}
|
package/dist/plugin.d.ts
ADDED
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import type { Async } from '@nmtjs/common';
|
|
2
|
+
import { kPlugin } from './constants.ts';
|
|
3
|
+
export interface Plugin<Type = void, Context = unknown> {
|
|
4
|
+
name: string;
|
|
5
|
+
factory: (context: Context) => Async<Type>;
|
|
6
|
+
[kPlugin]: any;
|
|
7
|
+
}
|
|
8
|
+
export declare const createPlugin: <Type = void, Context = unknown>(name: string, factory: Plugin<Type, Context>["factory"]) => Plugin<Type, Context>;
|
|
9
|
+
export declare const isPlugin: (value: any) => value is Plugin;
|
package/dist/plugin.js
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"plugin.js","sourceRoot":"","sources":["../src/plugin.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,OAAO,EAAE,MAAM,gBAAgB,CAAA;AAQxC,MAAM,CAAC,MAAM,YAAY,GAAG,CAC1B,IAAY,EACZ,OAAyC,EAClB,EAAE,CAAC,CAAC,EAAE,IAAI,EAAE,OAAO,EAAE,CAAC,OAAO,CAAC,EAAE,IAAI,EAAE,CAAC,CAAA;AAEhE,MAAM,CAAC,MAAM,QAAQ,GAAG,CAAC,KAAU,EAAmB,EAAE,CAAC,OAAO,IAAI,KAAK,CAAA"}
|
package/dist/types.d.ts
ADDED
package/dist/types.js
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.js","sourceRoot":"","sources":["../src/types.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
export { match } from '@nmtjs/common';
|
|
2
|
+
export declare function isJsFile(name: string): boolean;
|
|
3
|
+
export declare function pick<T extends object, K extends {
|
|
4
|
+
[KK in keyof T as T[KK] extends (...args: any[]) => any ? never : KK]?: true;
|
|
5
|
+
}>(obj: T, keys: K): Pick<T, keyof {
|
|
6
|
+
[KK in keyof K as K[KK] extends true ? KK : never]: K[KK];
|
|
7
|
+
}>;
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
export { match } from '@nmtjs/common';
|
|
2
|
+
export function isJsFile(name) {
|
|
3
|
+
if (name.endsWith('.d.ts'))
|
|
4
|
+
return false;
|
|
5
|
+
const leading = name.split('.').slice(1);
|
|
6
|
+
const ext = leading.join('.');
|
|
7
|
+
return ['js', 'mjs', 'cjs', 'ts', 'mts', 'cts'].includes(ext);
|
|
8
|
+
}
|
|
9
|
+
export function pick(obj, keys) {
|
|
10
|
+
const result = {};
|
|
11
|
+
for (const key in keys) {
|
|
12
|
+
if (key in obj) {
|
|
13
|
+
result[key] = obj[key];
|
|
14
|
+
}
|
|
15
|
+
}
|
|
16
|
+
return result;
|
|
17
|
+
}
|
|
18
|
+
//# sourceMappingURL=functions.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"functions.js","sourceRoot":"","sources":["../../src/utils/functions.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,EAAE,MAAM,eAAe,CAAA;AAErC,MAAM,UAAU,QAAQ,CAAC,IAAY;IACnC,IAAI,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC;QAAE,OAAO,KAAK,CAAA;IACxC,MAAM,OAAO,GAAG,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAA;IACxC,MAAM,GAAG,GAAG,OAAO,CAAC,IAAI,CAAC,GAAG,CAAC,CAAA;IAC7B,OAAO,CAAC,IAAI,EAAE,KAAK,EAAE,KAAK,EAAE,IAAI,EAAE,KAAK,EAAE,KAAK,CAAC,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAA;AAC/D,CAAC;AAED,MAAM,UAAU,IAAI,CAMlB,GAAM,EACN,IAAO;IAOP,MAAM,MAAM,GAAG,EAAS,CAAA;IACxB,KAAK,MAAM,GAAG,IAAI,IAAI,EAAE,CAAC;QACvB,IAAI,GAAG,IAAI,GAAG,EAAE,CAAC;YACf,MAAM,CAAC,GAAG,CAAC,GAAG,GAAG,CAAC,GAAkC,CAAC,CAAA;QACvD,CAAC;IACH,CAAC;IACD,OAAO,MAAM,CAAA;AACf,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/utils/index.ts"],"names":[],"mappings":"AAAA,cAAc,gBAAgB,CAAA;AAC9B,cAAc,WAAW,CAAA;AACzB,cAAc,gBAAgB,CAAA"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
interface PoolOptions {
|
|
2
|
+
timeout?: number;
|
|
3
|
+
}
|
|
4
|
+
export declare class PoolError extends Error {
|
|
5
|
+
}
|
|
6
|
+
export declare class Pool<T = unknown> {
|
|
7
|
+
#private;
|
|
8
|
+
private readonly options;
|
|
9
|
+
constructor(options?: PoolOptions);
|
|
10
|
+
add(item: T): void;
|
|
11
|
+
remove(item: T): void;
|
|
12
|
+
capture(timeout?: number | undefined): Promise<T>;
|
|
13
|
+
next(exclusive?: boolean, timeout?: number | undefined): Promise<T>;
|
|
14
|
+
release(item: T): void;
|
|
15
|
+
isFree(item: T): boolean;
|
|
16
|
+
get items(): T[];
|
|
17
|
+
}
|
|
18
|
+
export {};
|
|
@@ -0,0 +1,106 @@
|
|
|
1
|
+
export class PoolError extends Error {
|
|
2
|
+
}
|
|
3
|
+
// Fixed pool from https://github.com/metarhia/metautil
|
|
4
|
+
export class Pool {
|
|
5
|
+
options;
|
|
6
|
+
#items = [];
|
|
7
|
+
#free = [];
|
|
8
|
+
#queue = [];
|
|
9
|
+
#current = 0;
|
|
10
|
+
#size = 0;
|
|
11
|
+
#available = 0;
|
|
12
|
+
constructor(options = {}) {
|
|
13
|
+
this.options = options;
|
|
14
|
+
}
|
|
15
|
+
add(item) {
|
|
16
|
+
if (this.#items.includes(item))
|
|
17
|
+
throw new PoolError('Item already exists');
|
|
18
|
+
this.#size++;
|
|
19
|
+
this.#available++;
|
|
20
|
+
this.#items.push(item);
|
|
21
|
+
this.#free.push(true);
|
|
22
|
+
}
|
|
23
|
+
remove(item) {
|
|
24
|
+
if (this.#size === 0)
|
|
25
|
+
throw new PoolError('Pool is empty');
|
|
26
|
+
const index = this.#items.indexOf(item);
|
|
27
|
+
if (index < 0)
|
|
28
|
+
throw new PoolError('Item is not in the pool');
|
|
29
|
+
const isCaptured = this.isFree(item);
|
|
30
|
+
if (isCaptured)
|
|
31
|
+
this.#available--;
|
|
32
|
+
this.#size--;
|
|
33
|
+
this.#current--;
|
|
34
|
+
this.#items.splice(index, 1);
|
|
35
|
+
this.#free.splice(index, 1);
|
|
36
|
+
}
|
|
37
|
+
capture(timeout = this.options.timeout) {
|
|
38
|
+
return this.next(true, timeout);
|
|
39
|
+
}
|
|
40
|
+
async next(exclusive = false, timeout = this.options.timeout) {
|
|
41
|
+
if (this.#size === 0)
|
|
42
|
+
throw new PoolError('Pool is empty');
|
|
43
|
+
if (this.#available === 0) {
|
|
44
|
+
return new Promise((resolve, reject) => {
|
|
45
|
+
const waiting = {
|
|
46
|
+
resolve: (item) => {
|
|
47
|
+
if (exclusive)
|
|
48
|
+
this.#capture(item);
|
|
49
|
+
resolve(item);
|
|
50
|
+
},
|
|
51
|
+
timer: undefined,
|
|
52
|
+
};
|
|
53
|
+
if (timeout) {
|
|
54
|
+
waiting.timer = setTimeout(() => {
|
|
55
|
+
waiting.resolve = undefined;
|
|
56
|
+
this.#queue.shift();
|
|
57
|
+
reject(new PoolError('Next item timeout'));
|
|
58
|
+
}, timeout);
|
|
59
|
+
}
|
|
60
|
+
this.#queue.push(waiting);
|
|
61
|
+
});
|
|
62
|
+
}
|
|
63
|
+
let item;
|
|
64
|
+
let free = false;
|
|
65
|
+
do {
|
|
66
|
+
item = this.#items[this.#current];
|
|
67
|
+
free = this.#free[this.#current];
|
|
68
|
+
this.#current++;
|
|
69
|
+
if (this.#current >= this.#size)
|
|
70
|
+
this.#current = 0;
|
|
71
|
+
} while (typeof item === 'undefined' || !free);
|
|
72
|
+
if (exclusive)
|
|
73
|
+
this.#capture(item);
|
|
74
|
+
return item;
|
|
75
|
+
}
|
|
76
|
+
release(item) {
|
|
77
|
+
const index = this.#items.indexOf(item);
|
|
78
|
+
if (index < 0)
|
|
79
|
+
throw new PoolError('Unexpected item');
|
|
80
|
+
if (this.#free[index])
|
|
81
|
+
throw new PoolError('Unable to release not captured item');
|
|
82
|
+
this.#free[index] = true;
|
|
83
|
+
this.#available++;
|
|
84
|
+
if (this.#queue.length > 0) {
|
|
85
|
+
const { resolve, timer } = this.#queue.shift();
|
|
86
|
+
clearTimeout(timer);
|
|
87
|
+
if (resolve)
|
|
88
|
+
setTimeout(resolve, 0, item);
|
|
89
|
+
}
|
|
90
|
+
}
|
|
91
|
+
isFree(item) {
|
|
92
|
+
const index = this.#items.indexOf(item);
|
|
93
|
+
if (index < 0)
|
|
94
|
+
return false;
|
|
95
|
+
return this.#free[index];
|
|
96
|
+
}
|
|
97
|
+
get items() {
|
|
98
|
+
return [...this.#items];
|
|
99
|
+
}
|
|
100
|
+
#capture(item) {
|
|
101
|
+
const index = this.#items.indexOf(item);
|
|
102
|
+
this.#free[index] = false;
|
|
103
|
+
this.#available--;
|
|
104
|
+
}
|
|
105
|
+
}
|
|
106
|
+
//# sourceMappingURL=pool.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"pool.js","sourceRoot":"","sources":["../../src/utils/pool.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
export declare class SemaphoreError extends Error {
|
|
2
|
+
}
|
|
3
|
+
export declare class Semaphore {
|
|
4
|
+
private readonly size;
|
|
5
|
+
private readonly timeout;
|
|
6
|
+
private counter;
|
|
7
|
+
private readonly queue;
|
|
8
|
+
constructor(concurrency: number, size?: number, timeout?: number);
|
|
9
|
+
enter(): Promise<void>;
|
|
10
|
+
leave(): void;
|
|
11
|
+
get isEmpty(): boolean;
|
|
12
|
+
get queueLength(): number;
|
|
13
|
+
}
|
|
@@ -0,0 +1,56 @@
|
|
|
1
|
+
export class SemaphoreError extends Error {
|
|
2
|
+
}
|
|
3
|
+
// Semaphore from https://github.com/metarhia/metautil
|
|
4
|
+
export class Semaphore {
|
|
5
|
+
size;
|
|
6
|
+
timeout;
|
|
7
|
+
counter;
|
|
8
|
+
queue = [];
|
|
9
|
+
constructor(concurrency, size = 0, timeout = 0) {
|
|
10
|
+
this.size = size;
|
|
11
|
+
this.timeout = timeout;
|
|
12
|
+
this.counter = concurrency;
|
|
13
|
+
}
|
|
14
|
+
enter() {
|
|
15
|
+
if (this.counter > 0) {
|
|
16
|
+
this.counter--;
|
|
17
|
+
return Promise.resolve();
|
|
18
|
+
}
|
|
19
|
+
else if (this.queue.length >= this.size) {
|
|
20
|
+
return Promise.reject(new SemaphoreError('Queue is full'));
|
|
21
|
+
}
|
|
22
|
+
else {
|
|
23
|
+
return new Promise((resolve, reject) => {
|
|
24
|
+
const waiting = { resolve };
|
|
25
|
+
waiting.timer = setTimeout(() => {
|
|
26
|
+
waiting.resolve = undefined;
|
|
27
|
+
this.queue.shift();
|
|
28
|
+
reject(new SemaphoreError('Timeout'));
|
|
29
|
+
}, this.timeout);
|
|
30
|
+
this.queue.push(waiting);
|
|
31
|
+
});
|
|
32
|
+
}
|
|
33
|
+
}
|
|
34
|
+
leave() {
|
|
35
|
+
if (this.queue.length === 0) {
|
|
36
|
+
this.counter++;
|
|
37
|
+
}
|
|
38
|
+
else {
|
|
39
|
+
const item = this.queue.shift();
|
|
40
|
+
if (item) {
|
|
41
|
+
const { resolve, timer } = item;
|
|
42
|
+
if (timer)
|
|
43
|
+
clearTimeout(timer);
|
|
44
|
+
if (resolve)
|
|
45
|
+
setTimeout(resolve, 0);
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
}
|
|
49
|
+
get isEmpty() {
|
|
50
|
+
return this.queue.length === 0;
|
|
51
|
+
}
|
|
52
|
+
get queueLength() {
|
|
53
|
+
return this.queue.length;
|
|
54
|
+
}
|
|
55
|
+
}
|
|
56
|
+
//# sourceMappingURL=semaphore.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"semaphore.js","sourceRoot":"","sources":["../../src/utils/semaphore.ts"],"names":[],"mappings":"AAOA,MAAM,OAAO,cAAe,SAAQ,KAAK;CAAG;AAE5C,sDAAsD;AACtD,MAAM,OAAO,SAAS;IAOD;IACA;IAPX,OAAO,CAAQ;IAEN,KAAK,GAAyB,EAAE,CAAA;IAEjD,YACE,WAAmB,EACF,OAAe,CAAC,EAChB,UAAkB,CAAC;QADnB,SAAI,GAAJ,IAAI,CAAY;QAChB,YAAO,GAAP,OAAO,CAAY;QAEpC,IAAI,CAAC,OAAO,GAAG,WAAW,CAAA;IAC5B,CAAC;IAED,KAAK;QACH,IAAI,IAAI,CAAC,OAAO,GAAG,CAAC,EAAE,CAAC;YACrB,IAAI,CAAC,OAAO,EAAE,CAAA;YACd,OAAO,OAAO,CAAC,OAAO,EAAE,CAAA;QAC1B,CAAC;aAAM,IAAI,IAAI,CAAC,KAAK,CAAC,MAAM,IAAI,IAAI,CAAC,IAAI,EAAE,CAAC;YAC1C,OAAO,OAAO,CAAC,MAAM,CAAC,IAAI,cAAc,CAAC,eAAe,CAAC,CAAC,CAAA;QAC5D,CAAC;aAAM,CAAC;YACN,OAAO,IAAI,OAAO,CAAC,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE;gBACrC,MAAM,OAAO,GAAuB,EAAE,OAAO,EAAE,CAAA;gBAC/C,OAAO,CAAC,KAAK,GAAG,UAAU,CAAC,GAAG,EAAE;oBAC9B,OAAO,CAAC,OAAO,GAAG,SAAS,CAAA;oBAC3B,IAAI,CAAC,KAAK,CAAC,KAAK,EAAE,CAAA;oBAClB,MAAM,CAAC,IAAI,cAAc,CAAC,SAAS,CAAC,CAAC,CAAA;gBACvC,CAAC,EAAE,IAAI,CAAC,OAAO,CAAC,CAAA;gBAChB,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,OAAO,CAAC,CAAA;YAC1B,CAAC,CAAC,CAAA;QACJ,CAAC;IACH,CAAC;IAED,KAAK;QACH,IAAI,IAAI,CAAC,KAAK,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;YAC5B,IAAI,CAAC,OAAO,EAAE,CAAA;QAChB,CAAC;aAAM,CAAC;YACN,MAAM,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,KAAK,EAAE,CAAA;YAC/B,IAAI,IAAI,EAAE,CAAC;gBACT,MAAM,EAAE,OAAO,EAAE,KAAK,EAAE,GAAG,IAAI,CAAA;gBAC/B,IAAI,KAAK;oBAAE,YAAY,CAAC,KAAK,CAAC,CAAA;gBAC9B,IAAI,OAAO;oBAAE,UAAU,CAAC,OAAO,EAAE,CAAC,CAAC,CAAA;YACrC,CAAC;QACH,CAAC;IACH,CAAC;IAED,IAAI,OAAO;QACT,OAAO,IAAI,CAAC,KAAK,CAAC,MAAM,KAAK,CAAC,CAAA;IAChC,CAAC;IAED,IAAI,WAAW;QACb,OAAO,IAAI,CAAC,KAAK,CAAC,MAAM,CAAA;IAC1B,CAAC;CACF"}
|
package/package.json
CHANGED
|
@@ -8,18 +8,19 @@
|
|
|
8
8
|
"peerDependencies": {
|
|
9
9
|
"pino": "^9.6.0",
|
|
10
10
|
"pino-pretty": "^13.0.0",
|
|
11
|
-
"@nmtjs/common": "0.15.0-beta.
|
|
12
|
-
"@nmtjs/type": "0.15.0-beta.
|
|
11
|
+
"@nmtjs/common": "0.15.0-beta.11",
|
|
12
|
+
"@nmtjs/type": "0.15.0-beta.11"
|
|
13
13
|
},
|
|
14
14
|
"devDependencies": {
|
|
15
15
|
"@types/node": "^24",
|
|
16
16
|
"pino": "^9.6.0",
|
|
17
17
|
"pino-pretty": "^13.0.0",
|
|
18
|
-
"@nmtjs/common": "0.15.0-beta.
|
|
19
|
-
"@nmtjs/type": "0.15.0-beta.
|
|
18
|
+
"@nmtjs/common": "0.15.0-beta.11",
|
|
19
|
+
"@nmtjs/type": "0.15.0-beta.11"
|
|
20
20
|
},
|
|
21
21
|
"files": [
|
|
22
22
|
"dist",
|
|
23
|
+
"src",
|
|
23
24
|
"LICENSE.md",
|
|
24
25
|
"README.md"
|
|
25
26
|
],
|
|
@@ -27,10 +28,10 @@
|
|
|
27
28
|
"hookable": "6.0.0-rc.1",
|
|
28
29
|
"pino-std-serializers": "^7.0.0"
|
|
29
30
|
},
|
|
30
|
-
"version": "0.15.0-beta.
|
|
31
|
+
"version": "0.15.0-beta.11",
|
|
31
32
|
"scripts": {
|
|
32
33
|
"clean-build": "rm -rf ./dist",
|
|
33
|
-
"build": "tsc",
|
|
34
|
+
"build": "tsc --declaration --sourcemap",
|
|
34
35
|
"dev": "tsc --watch",
|
|
35
36
|
"type-check": "tsc --noEmit"
|
|
36
37
|
}
|
package/src/constants.ts
ADDED
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
export const kOptionalDependency: unique symbol = Symbol.for(
|
|
2
|
+
'neemata:OptionalDependencyKey',
|
|
3
|
+
)
|
|
4
|
+
export type kOptionalDependency = typeof kOptionalDependency
|
|
5
|
+
|
|
6
|
+
export const kInjectable: unique symbol = Symbol.for('neemata:InjectableKey')
|
|
7
|
+
export type kInjectable = typeof kInjectable
|
|
8
|
+
|
|
9
|
+
export const kLazyInjectable: unique symbol = Symbol.for(
|
|
10
|
+
'neemata:LazyInjectableKey',
|
|
11
|
+
)
|
|
12
|
+
export type kLazyInjectable = typeof kLazyInjectable
|
|
13
|
+
|
|
14
|
+
export const kValueInjectable: unique symbol = Symbol.for(
|
|
15
|
+
'neemata:ValueInjectableKey',
|
|
16
|
+
)
|
|
17
|
+
export type kValueInjectable = typeof kValueInjectable
|
|
18
|
+
|
|
19
|
+
export const kFactoryInjectable: unique symbol = Symbol.for(
|
|
20
|
+
'neemata:FactoryInjectableKey',
|
|
21
|
+
)
|
|
22
|
+
export type kFactoryInjectable = typeof kFactoryInjectable
|
|
23
|
+
|
|
24
|
+
export const kProvider: unique symbol = Symbol.for('neemata:ProviderKey')
|
|
25
|
+
export type kProvider = typeof kProvider
|
|
26
|
+
|
|
27
|
+
export const kPlugin: unique symbol = Symbol.for('neemata:PluginKey')
|
|
28
|
+
export type kPlugin = typeof kPlugin
|
|
29
|
+
|
|
30
|
+
export const kMetadata: unique symbol = Symbol.for('neemata:MetadataKey')
|
|
31
|
+
export type kMetadata = typeof kMetadata
|
|
32
|
+
|
|
33
|
+
export const kHook: unique symbol = Symbol.for('neemata:HookKey')
|
|
34
|
+
export type kHook = typeof kHook
|