@nmtjs/core 0.14.5 → 0.15.0-beta.10
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/LICENSE.md +1 -1
- package/README.md +1 -1
- package/dist/constants.d.ts +2 -8
- package/dist/constants.js +2 -4
- package/dist/constants.js.map +1 -0
- package/dist/container.d.ts +13 -12
- package/dist/container.js +111 -91
- package/dist/container.js.map +1 -0
- package/dist/enums.d.ts +0 -12
- package/dist/enums.js +1 -13
- package/dist/enums.js.map +1 -0
- package/dist/hooks.d.ts +12 -18
- package/dist/hooks.js +10 -41
- package/dist/hooks.js.map +1 -0
- package/dist/index.d.ts +0 -1
- package/dist/index.js +1 -1
- package/dist/index.js.map +1 -0
- package/dist/injectables.d.ts +18 -49
- package/dist/injectables.js +18 -97
- package/dist/injectables.js.map +1 -0
- package/dist/logger.d.ts +7 -6
- package/dist/logger.js +10 -5
- package/dist/logger.js.map +1 -0
- package/dist/metadata.js +1 -0
- package/dist/metadata.js.map +1 -0
- package/dist/plugin.d.ts +3 -6
- package/dist/plugin.js +2 -1
- package/dist/plugin.js.map +1 -0
- package/dist/types.d.ts +2 -11
- package/dist/types.js +1 -0
- package/dist/types.js.map +1 -0
- package/dist/utils/functions.d.ts +6 -5
- package/dist/utils/functions.js +11 -28
- package/dist/utils/functions.js.map +1 -0
- package/dist/utils/index.js +1 -0
- package/dist/utils/index.js.map +1 -0
- package/dist/utils/pool.js +1 -0
- package/dist/utils/pool.js.map +1 -0
- package/dist/utils/semaphore.js +1 -0
- package/dist/utils/semaphore.js.map +1 -0
- package/package.json +16 -17
- 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
- package/dist/registry.d.ts +0 -21
- package/dist/registry.js +0 -24
package/dist/injectables.d.ts
CHANGED
|
@@ -1,11 +1,7 @@
|
|
|
1
|
-
import type { Async
|
|
2
|
-
import type { Hook } from './enums.ts';
|
|
3
|
-
import type { HookType } from './hooks.ts';
|
|
1
|
+
import type { Async } from '@nmtjs/common';
|
|
4
2
|
import type { Logger } from './logger.ts';
|
|
5
|
-
import
|
|
6
|
-
import { kClassInjectable, kClassInjectableCreate, kClassInjectableDispose, kFactoryInjectable, kInjectable, kLazyInjectable, kOptionalDependency, kValueInjectable } from './constants.ts';
|
|
3
|
+
import { kFactoryInjectable, kInjectable, kLazyInjectable, kOptionalDependency, kValueInjectable } from './constants.ts';
|
|
7
4
|
import { Scope } from './enums.ts';
|
|
8
|
-
import { Hooks } from './hooks.ts';
|
|
9
5
|
export type DependencyOptional<T extends AnyInjectable = AnyInjectable> = {
|
|
10
6
|
[kOptionalDependency]: any;
|
|
11
7
|
injectable: T;
|
|
@@ -29,6 +25,8 @@ export type InjectablePickType<Input, Output> = (injectable: Input) => Output;
|
|
|
29
25
|
export type InjectableDisposeType<InjectableType, InjectableDeps extends Dependencies> = (instance: InjectableType, context: DependencyContext<InjectableDeps>) => any;
|
|
30
26
|
export interface LazyInjectable<T, S extends Scope = Scope.Global> extends Dependant<{}> {
|
|
31
27
|
scope: S;
|
|
28
|
+
$withType<O extends T>(): LazyInjectable<O, S>;
|
|
29
|
+
optional(): DependencyOptional<LazyInjectable<T, S>>;
|
|
32
30
|
[kInjectable]: any;
|
|
33
31
|
[kLazyInjectable]: T;
|
|
34
32
|
}
|
|
@@ -43,30 +41,14 @@ export interface FactoryInjectable<T, D extends Dependencies = {}, S extends Sco
|
|
|
43
41
|
factory: InjectableFactoryType<P, D>;
|
|
44
42
|
pick: InjectablePickType<P, T>;
|
|
45
43
|
dispose?: InjectableDisposeType<P, D>;
|
|
44
|
+
optional(): DependencyOptional<FactoryInjectable<T, D, S, P>>;
|
|
46
45
|
[kInjectable]: any;
|
|
47
46
|
[kFactoryInjectable]: any;
|
|
48
47
|
}
|
|
49
|
-
export
|
|
50
|
-
new (...args: any[]): T;
|
|
51
|
-
scope: S;
|
|
52
|
-
[kInjectable]: any;
|
|
53
|
-
[kClassInjectable]: any;
|
|
54
|
-
}
|
|
55
|
-
export interface ClassInjectable<T, D extends Dependencies = {}, S extends Scope = Scope.Global, A extends any[] = []> extends Dependant<D> {
|
|
56
|
-
new ($context: DependencyContext<D>, ...args: A): T & {
|
|
57
|
-
$context: DependencyContext<D>;
|
|
58
|
-
[kClassInjectableCreate]?: () => Promise<void>;
|
|
59
|
-
[kClassInjectableDispose]?: () => Promise<void>;
|
|
60
|
-
};
|
|
61
|
-
scope: S;
|
|
62
|
-
[kInjectable]: any;
|
|
63
|
-
[kClassInjectable]: any;
|
|
64
|
-
}
|
|
65
|
-
export type Injectable<V = any, D extends Dependencies = {}, S extends Scope = Scope> = LazyInjectable<V, S> | ValueInjectable<V> | FactoryInjectable<V, D, S, any> | BaseClassInjectable<V, D, S>;
|
|
48
|
+
export type Injectable<V = any, D extends Dependencies = {}, S extends Scope = Scope> = LazyInjectable<V, S> | ValueInjectable<V> | FactoryInjectable<V, D, S, any>;
|
|
66
49
|
export type AnyInjectable<T = any, S extends Scope = Scope> = Injectable<T, any, S>;
|
|
67
50
|
export declare const isLazyInjectable: (injectable: any) => injectable is LazyInjectable<any>;
|
|
68
51
|
export declare const isFactoryInjectable: (injectable: any) => injectable is FactoryInjectable<any>;
|
|
69
|
-
export declare const isClassInjectable: (injectable: any) => injectable is ClassInjectable<any>;
|
|
70
52
|
export declare const isValueInjectable: (injectable: any) => injectable is ValueInjectable<any>;
|
|
71
53
|
export declare const isInjectable: (injectable: any) => injectable is AnyInjectable<any>;
|
|
72
54
|
export declare const isOptionalInjectable: (injectable: any) => injectable is DependencyOptional<any>;
|
|
@@ -82,38 +64,25 @@ export declare function createFactoryInjectable<T, D extends Dependencies = {},
|
|
|
82
64
|
factory: InjectableFactoryType<P, D>;
|
|
83
65
|
dispose?: InjectableDisposeType<P, D>;
|
|
84
66
|
} | InjectableFactoryType<P, D>, label?: string, stackTraceDepth?: number): FactoryInjectable<null extends T ? P : T, D, S, P>;
|
|
85
|
-
export declare const createClassInjectable: <D extends Dependencies = {}, S extends Scope = Scope.Global>(dependencies?: D, scope?: S, stackTraceDepth?: number) => ClassInjectable<ClassInstance<{
|
|
86
|
-
new ($context: DependencyContext<D>): {
|
|
87
|
-
$context: DependencyContext<D>;
|
|
88
|
-
[kClassInjectableCreate](): Promise<void>;
|
|
89
|
-
[kClassInjectableDispose](): Promise<void>;
|
|
90
|
-
};
|
|
91
|
-
dependencies: D;
|
|
92
|
-
scope: S;
|
|
93
|
-
stack: string | undefined;
|
|
94
|
-
get label(): string;
|
|
95
|
-
[kInjectable]: boolean;
|
|
96
|
-
[kClassInjectable]: boolean;
|
|
97
|
-
}>, D, S>;
|
|
98
|
-
export declare function createExtendableClassInjectable<B extends ClassConstructor<any>, D extends Dependencies = {}, S extends Scope = Scope.Global>(baseClass: B, dependencies?: D, scope?: S, stackTraceDepth?: number): B extends ClassInjectable<any> ? ClassInjectable<ClassInstance<B>, D, S> : ClassInjectable<ClassInstance<B>, D, S, ClassConstructorArgs<B, []>>;
|
|
99
67
|
export type DependenciesSubstitution<T extends Dependencies> = {
|
|
100
68
|
[K in keyof T]?: T[K] extends AnyInjectable<infer Type> ? AnyInjectable<Type> | DependenciesSubstitution<T[K]['dependencies']> : never;
|
|
101
69
|
};
|
|
102
|
-
export declare function substitute<T extends FactoryInjectable<any, any, Scope
|
|
70
|
+
export declare function substitute<T extends FactoryInjectable<any, any, Scope>>(injectable: T, substitution: DependenciesSubstitution<T['dependencies']>, stackTraceDepth?: number): T;
|
|
103
71
|
export declare function compareScope(left: Scope, operator: '>' | '<' | '>=' | '<=' | '=' | '!=', right: Scope): boolean;
|
|
104
72
|
export declare const CoreInjectables: {
|
|
105
|
-
logger:
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
73
|
+
logger: ((label: string) => FactoryInjectable<Logger, {
|
|
74
|
+
logger: LazyInjectable<Logger>;
|
|
75
|
+
}>) & LazyInjectable<Logger, Scope.Global>;
|
|
76
|
+
inject: LazyInjectable<(<T extends AnyInjectable>(injectable: T, context: { [K in keyof T["dependencies"]]?: ResolveInjectableType<T["dependencies"][K]> | AnyInjectable<ResolveInjectableType<T["dependencies"][K]>> | undefined; }, scope?: Exclude<Scope, Scope.Transient>) => Promise<ResolveInjectableType<T>>) & {
|
|
77
|
+
explicit: <T extends AnyInjectable>(injectable: T, context: { [K in keyof T["dependencies"]]?: ResolveInjectableType<T["dependencies"][K]> | AnyInjectable<ResolveInjectableType<T["dependencies"][K]>> | undefined; }, scope?: Exclude<Scope, Scope.Transient>) => Promise<{
|
|
78
|
+
instance: Awaited<ResolveInjectableType<T>>;
|
|
109
79
|
[Symbol.asyncDispose]: () => Promise<void>;
|
|
110
80
|
}>;
|
|
111
81
|
}, Scope.Global>;
|
|
112
82
|
dispose: LazyInjectable<(<T extends AnyInjectable>(injectable: T, instance?: any) => Promise<void>), Scope.Global>;
|
|
113
|
-
hook: FactoryInjectable<(<T extends Hook>(name: T, callback: HookType[T]) => () => void), {
|
|
114
|
-
registry: LazyInjectable<Registry, Scope.Global>;
|
|
115
|
-
}, Scope.Transient, {
|
|
116
|
-
hooks: Hooks;
|
|
117
|
-
on: <T extends Hook>(name: T, callback: HookType[T]) => () => void;
|
|
118
|
-
}>;
|
|
119
83
|
};
|
|
84
|
+
export type Injection<T extends AnyInjectable<any, any> = AnyInjectable<any, any>> = {
|
|
85
|
+
token: T;
|
|
86
|
+
value: T extends AnyInjectable<infer R, Scope> ? R | AnyInjectable<R> : never;
|
|
87
|
+
};
|
|
88
|
+
export declare const provide: <T extends AnyInjectable<any, any>, V extends T extends AnyInjectable<infer R, Scope> ? R | AnyInjectable<R> : never>(token: T, value: V) => Injection<T>;
|
package/dist/injectables.js
CHANGED
|
@@ -1,7 +1,6 @@
|
|
|
1
1
|
import { tryCaptureStackTrace } from '@nmtjs/common';
|
|
2
|
-
import {
|
|
2
|
+
import { kFactoryInjectable, kInjectable, kLazyInjectable, kOptionalDependency, kValueInjectable, } from "./constants.js";
|
|
3
3
|
import { Scope } from "./enums.js";
|
|
4
|
-
import { Hooks } from "./hooks.js";
|
|
5
4
|
const ScopeStrictness = {
|
|
6
5
|
[Scope.Transient]: Number.NaN, // this should make it always fail to compare with other scopes
|
|
7
6
|
[Scope.Global]: 1,
|
|
@@ -10,7 +9,6 @@ const ScopeStrictness = {
|
|
|
10
9
|
};
|
|
11
10
|
export const isLazyInjectable = (injectable) => injectable[kLazyInjectable];
|
|
12
11
|
export const isFactoryInjectable = (injectable) => injectable[kFactoryInjectable];
|
|
13
|
-
export const isClassInjectable = (injectable) => injectable[kClassInjectable];
|
|
14
12
|
export const isValueInjectable = (injectable) => injectable[kValueInjectable];
|
|
15
13
|
export const isInjectable = (injectable) => injectable[kInjectable];
|
|
16
14
|
export const isOptionalInjectable = (injectable) => injectable[kOptionalDependency];
|
|
@@ -42,14 +40,17 @@ export function createOptionalInjectable(injectable) {
|
|
|
42
40
|
});
|
|
43
41
|
}
|
|
44
42
|
export function createLazyInjectable(scope = Scope.Global, label, stackTraceDepth = 0) {
|
|
45
|
-
|
|
43
|
+
const injectable = Object.freeze({
|
|
46
44
|
scope,
|
|
47
45
|
dependencies: {},
|
|
48
46
|
label,
|
|
49
47
|
stack: tryCaptureStackTrace(stackTraceDepth),
|
|
48
|
+
optional: () => createOptionalInjectable(injectable),
|
|
49
|
+
$withType: () => injectable,
|
|
50
50
|
[kInjectable]: true,
|
|
51
51
|
[kLazyInjectable]: true,
|
|
52
52
|
});
|
|
53
|
+
return injectable;
|
|
53
54
|
}
|
|
54
55
|
export function createValueInjectable(value, label, stackTraceDepth = 0) {
|
|
55
56
|
return Object.freeze({
|
|
@@ -73,75 +74,13 @@ export function createFactoryInjectable(paramsOrFactory, label, stackTraceDepth
|
|
|
73
74
|
pick: params.pick ?? ((instance) => instance),
|
|
74
75
|
label,
|
|
75
76
|
stack: tryCaptureStackTrace(stackTraceDepth),
|
|
77
|
+
optional: () => createOptionalInjectable(injectable),
|
|
76
78
|
[kInjectable]: true,
|
|
77
79
|
[kFactoryInjectable]: true,
|
|
78
80
|
};
|
|
79
81
|
injectable.scope = resolveInjectableScope(typeof params.scope === 'undefined', injectable);
|
|
80
82
|
return Object.freeze(injectable);
|
|
81
83
|
}
|
|
82
|
-
export const createClassInjectable = (dependencies = {}, scope, stackTraceDepth = 0) => {
|
|
83
|
-
const InjectableClass = class {
|
|
84
|
-
$context;
|
|
85
|
-
static dependencies = dependencies;
|
|
86
|
-
static scope = (scope ?? Scope.Global);
|
|
87
|
-
static stack = tryCaptureStackTrace(stackTraceDepth + 2);
|
|
88
|
-
static [kInjectable] = true;
|
|
89
|
-
static [kClassInjectable] = true;
|
|
90
|
-
static get label() {
|
|
91
|
-
// biome-ignore lint/complexity/noThisInStatic: ok
|
|
92
|
-
return this.name;
|
|
93
|
-
}
|
|
94
|
-
constructor($context) {
|
|
95
|
-
this.$context = $context;
|
|
96
|
-
}
|
|
97
|
-
async [kClassInjectableCreate]() { }
|
|
98
|
-
async [kClassInjectableDispose]() { }
|
|
99
|
-
};
|
|
100
|
-
InjectableClass.scope = resolveInjectableScope(typeof scope === 'undefined', InjectableClass);
|
|
101
|
-
return InjectableClass;
|
|
102
|
-
};
|
|
103
|
-
export function createExtendableClassInjectable(baseClass, dependencies = {}, scope, stackTraceDepth = 0) {
|
|
104
|
-
if (isClassInjectable(baseClass)) {
|
|
105
|
-
if (scope && compareScope(baseClass.scope, '>', scope)) {
|
|
106
|
-
throw new Error(`Invalid scope ${scope} for an extendable class injectable: base class have stricter scope - ${baseClass.scope}`);
|
|
107
|
-
}
|
|
108
|
-
else {
|
|
109
|
-
scope = scope ?? baseClass.scope;
|
|
110
|
-
}
|
|
111
|
-
dependencies = Object.assign({}, baseClass.dependencies, dependencies);
|
|
112
|
-
}
|
|
113
|
-
const InjectableClass = class extends baseClass {
|
|
114
|
-
static dependencies = dependencies;
|
|
115
|
-
static scope = (scope ?? Scope.Global);
|
|
116
|
-
static stack = tryCaptureStackTrace(stackTraceDepth);
|
|
117
|
-
static [kInjectable] = true;
|
|
118
|
-
static [kClassInjectable] = true;
|
|
119
|
-
static get label() {
|
|
120
|
-
// biome-ignore lint/complexity/noThisInStatic: ok
|
|
121
|
-
return this.name;
|
|
122
|
-
}
|
|
123
|
-
$context;
|
|
124
|
-
constructor(...args) {
|
|
125
|
-
const [$context, ...baseClassArgs] = args;
|
|
126
|
-
if (isClassInjectable(baseClass)) {
|
|
127
|
-
super($context);
|
|
128
|
-
}
|
|
129
|
-
else {
|
|
130
|
-
super(...baseClassArgs);
|
|
131
|
-
}
|
|
132
|
-
this.$context = $context;
|
|
133
|
-
}
|
|
134
|
-
async $onCreate() {
|
|
135
|
-
await super.$onCreate?.();
|
|
136
|
-
}
|
|
137
|
-
async $onDispose() {
|
|
138
|
-
await super.$onDispose?.();
|
|
139
|
-
}
|
|
140
|
-
};
|
|
141
|
-
InjectableClass.scope = resolveInjectableScope(typeof scope === 'undefined', InjectableClass);
|
|
142
|
-
// @ts-expect-error
|
|
143
|
-
return InjectableClass;
|
|
144
|
-
}
|
|
145
84
|
export function substitute(injectable, substitution, stackTraceDepth = 0) {
|
|
146
85
|
const dependencies = { ...injectable.dependencies };
|
|
147
86
|
const depth = stackTraceDepth + 1;
|
|
@@ -152,16 +91,12 @@ export function substitute(injectable, substitution, stackTraceDepth = 0) {
|
|
|
152
91
|
if (isInjectable(value)) {
|
|
153
92
|
dependencies[key] = value;
|
|
154
93
|
}
|
|
155
|
-
else if (
|
|
94
|
+
else if (isFactoryInjectable(original)) {
|
|
156
95
|
dependencies[key] = substitute(original, value, depth);
|
|
157
96
|
}
|
|
158
97
|
}
|
|
159
98
|
}
|
|
160
|
-
if (
|
|
161
|
-
// @ts-expect-error
|
|
162
|
-
return createExtendableClassInjectable(injectable, dependencies, injectable.scope, depth);
|
|
163
|
-
}
|
|
164
|
-
else if (isFactoryInjectable(injectable)) {
|
|
99
|
+
if (isFactoryInjectable(injectable)) {
|
|
165
100
|
// @ts-expect-error
|
|
166
101
|
return createFactoryInjectable({ ...injectable, dependencies }, injectable.label, depth);
|
|
167
102
|
}
|
|
@@ -187,35 +122,21 @@ export function compareScope(left, operator, right) {
|
|
|
187
122
|
throw new Error('Invalid operator');
|
|
188
123
|
}
|
|
189
124
|
}
|
|
190
|
-
const logger =
|
|
191
|
-
|
|
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'));
|
|
192
130
|
const inject = createLazyInjectable(Scope.Global, 'Inject function');
|
|
193
131
|
const dispose = createLazyInjectable(Scope.Global, 'Dispose function');
|
|
194
|
-
const hook = createFactoryInjectable({
|
|
195
|
-
scope: Scope.Transient,
|
|
196
|
-
dependencies: { registry },
|
|
197
|
-
factory: ({ registry }) => {
|
|
198
|
-
const hooks = new Hooks();
|
|
199
|
-
const on = (name, callback) => {
|
|
200
|
-
hooks.add(name, callback);
|
|
201
|
-
return registry.hooks.add(name, callback);
|
|
202
|
-
};
|
|
203
|
-
return { hooks, on };
|
|
204
|
-
},
|
|
205
|
-
pick: ({ on }) => on,
|
|
206
|
-
dispose: ({ hooks }, { registry }) => {
|
|
207
|
-
for (const [hook, callbacks] of hooks[kHookCollection].entries()) {
|
|
208
|
-
for (const callback of callbacks) {
|
|
209
|
-
registry.hooks.remove(hook, callback);
|
|
210
|
-
}
|
|
211
|
-
}
|
|
212
|
-
hooks.clear();
|
|
213
|
-
},
|
|
214
|
-
});
|
|
215
132
|
function resolveInjectableScope(isDefaultScope, injectable) {
|
|
216
133
|
const actualScope = getInjectableScope(injectable);
|
|
217
134
|
if (!isDefaultScope && compareScope(actualScope, '>', injectable.scope))
|
|
218
135
|
throw new Error(`Invalid scope ${injectable.scope} for an injectable: dependencies have stricter scope - ${actualScope}`);
|
|
219
136
|
return actualScope;
|
|
220
137
|
}
|
|
221
|
-
export const CoreInjectables = { logger,
|
|
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
CHANGED
|
@@ -1,10 +1,11 @@
|
|
|
1
|
-
import type
|
|
2
|
-
import { pino } from 'pino';
|
|
1
|
+
import type * as pinoType from 'pino';
|
|
3
2
|
export type { StreamEntry } from 'pino';
|
|
4
|
-
export type Logger =
|
|
3
|
+
export type Logger = pinoType.Logger;
|
|
4
|
+
export type LoggerOptions = pinoType.LoggerOptions;
|
|
5
|
+
export type LoggerChildOptions = pinoType.ChildLoggerOptions;
|
|
5
6
|
export type LoggingOptions = {
|
|
6
|
-
destinations?: Array<DestinationStream | StreamEntry<Level>>;
|
|
7
|
+
destinations?: Array<pinoType.DestinationStream | pinoType.StreamEntry<pinoType.Level>>;
|
|
7
8
|
pinoOptions?: LoggerOptions;
|
|
8
9
|
};
|
|
9
|
-
export declare const createLogger: (options: LoggingOptions | undefined, $
|
|
10
|
-
export declare const createConsolePrettyDestination: (level: Level, sync?: boolean) => StreamEntry;
|
|
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
CHANGED
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
import { threadId } from 'node:worker_threads';
|
|
2
2
|
import { pino, stdTimeFunctions } from 'pino';
|
|
3
3
|
import { build as pretty } from 'pino-pretty';
|
|
4
|
+
import { errWithCause } from 'pino-std-serializers';
|
|
4
5
|
// TODO: use node:util inspect
|
|
5
6
|
const bg = (value, color) => `\x1b[${color}m${value}\x1b[0m`;
|
|
6
7
|
const fg = (value, color) => `\x1b[38;5;${color}m${value}\x1b[0m`;
|
|
@@ -31,25 +32,28 @@ const levelLabels = {
|
|
|
31
32
|
60: ' FATAL ',
|
|
32
33
|
[Number.POSITIVE_INFINITY]: 'SILENT',
|
|
33
34
|
};
|
|
34
|
-
export const createLogger = (options = {}, $
|
|
35
|
+
export const createLogger = (options = {}, $lable) => {
|
|
35
36
|
let { destinations, pinoOptions } = options;
|
|
36
37
|
if (!destinations || !destinations?.length) {
|
|
37
|
-
destinations = [
|
|
38
|
+
destinations = [
|
|
39
|
+
createConsolePrettyDestination((options.pinoOptions?.level || 'info')),
|
|
40
|
+
];
|
|
38
41
|
}
|
|
39
42
|
const lowestLevelValue = destinations.reduce((acc, destination) => Math.min(acc, 'stream' in destination
|
|
40
43
|
? pino.levels.values[destination.level]
|
|
41
44
|
: Number.POSITIVE_INFINITY), Number.POSITIVE_INFINITY);
|
|
42
45
|
const level = pino.levels.labels[lowestLevelValue];
|
|
43
|
-
|
|
46
|
+
const serializers = { ...pinoOptions?.serializers, err: errWithCause };
|
|
47
|
+
return pino({ timestamp: stdTimeFunctions.isoTime, ...pinoOptions, level, serializers }, pino.multistream(destinations)).child({ $lable, $threadId: threadId });
|
|
44
48
|
};
|
|
45
49
|
export const createConsolePrettyDestination = (level, sync = true) => ({
|
|
46
50
|
level,
|
|
47
51
|
stream: pretty({
|
|
48
52
|
colorize: true,
|
|
49
|
-
ignore: 'hostname,$
|
|
53
|
+
ignore: 'hostname,$lable,$threadId',
|
|
50
54
|
errorLikeObjectKeys: ['err', 'error', 'cause'],
|
|
51
55
|
messageFormat: (log, messageKey) => {
|
|
52
|
-
const group = fg(`[${log.$
|
|
56
|
+
const group = fg(`[${log.$lable}]`, 11);
|
|
53
57
|
const msg = fg(log[messageKey], messageColors[log.level]);
|
|
54
58
|
const thread = fg(`(Thread-${log.$threadId})`, 89);
|
|
55
59
|
return `\x1b[0m${thread} ${group} ${msg}`;
|
|
@@ -60,3 +64,4 @@ export const createConsolePrettyDestination = (level, sync = true) => ({
|
|
|
60
64
|
sync,
|
|
61
65
|
}),
|
|
62
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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"}
|
package/dist/metadata.js
CHANGED
|
@@ -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
CHANGED
|
@@ -1,12 +1,9 @@
|
|
|
1
1
|
import type { Async } from '@nmtjs/common';
|
|
2
|
-
import type { PluginContext } from './types.ts';
|
|
3
2
|
import { kPlugin } from './constants.ts';
|
|
4
|
-
export interface
|
|
3
|
+
export interface Plugin<Type = void, Context = unknown> {
|
|
5
4
|
name: string;
|
|
6
|
-
|
|
7
|
-
}
|
|
8
|
-
export interface Plugin<Type = void, Options = unknown, Context extends PluginContext = PluginContext> extends BasePlugin<Type, Options, Context> {
|
|
5
|
+
factory: (context: Context) => Async<Type>;
|
|
9
6
|
[kPlugin]: any;
|
|
10
7
|
}
|
|
11
|
-
export declare const createPlugin: <
|
|
8
|
+
export declare const createPlugin: <Type = void, Context = unknown>(name: string, factory: Plugin<Type, Context>["factory"]) => Plugin<Type, Context>;
|
|
12
9
|
export declare const isPlugin: (value: any) => value is Plugin;
|
package/dist/plugin.js
CHANGED
|
@@ -1,3 +1,4 @@
|
|
|
1
1
|
import { kPlugin } from "./constants.js";
|
|
2
|
-
export const createPlugin = (name,
|
|
2
|
+
export const createPlugin = (name, factory) => ({ name, factory, [kPlugin]: true });
|
|
3
3
|
export const isPlugin = (value) => kPlugin in value;
|
|
4
|
+
//# sourceMappingURL=plugin.js.map
|
|
@@ -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
CHANGED
|
@@ -1,11 +1,2 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
import type { Logger } from './logger.ts';
|
|
4
|
-
import type { Registry } from './registry.ts';
|
|
5
|
-
export interface PluginContext {
|
|
6
|
-
logger: Logger;
|
|
7
|
-
registry: Registry;
|
|
8
|
-
hooks: Hooks;
|
|
9
|
-
container: Container;
|
|
10
|
-
}
|
|
11
|
-
export type Pattern = RegExp | string | ((value: string) => boolean);
|
|
1
|
+
export type { Pattern } from '@nmtjs/common';
|
|
2
|
+
export type HookTypes = Record<string | symbol, any>;
|
package/dist/types.js
CHANGED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.js","sourceRoot":"","sources":["../src/types.ts"],"names":[],"mappings":""}
|
|
@@ -1,6 +1,7 @@
|
|
|
1
|
-
|
|
2
|
-
/**
|
|
3
|
-
* Very simple pattern matching function.
|
|
4
|
-
*/
|
|
5
|
-
export declare function match(value: string, pattern: Pattern): boolean;
|
|
1
|
+
export { match } from '@nmtjs/common';
|
|
6
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
|
+
}>;
|
package/dist/utils/functions.js
CHANGED
|
@@ -1,31 +1,4 @@
|
|
|
1
|
-
|
|
2
|
-
* Very simple pattern matching function.
|
|
3
|
-
*/
|
|
4
|
-
export function match(value, pattern) {
|
|
5
|
-
if (typeof pattern === 'function') {
|
|
6
|
-
return pattern(value);
|
|
7
|
-
}
|
|
8
|
-
else if (typeof pattern === 'string') {
|
|
9
|
-
if (pattern === '*' || pattern === '**') {
|
|
10
|
-
return true;
|
|
11
|
-
}
|
|
12
|
-
else if (pattern.at(0) === '*' && pattern.at(-1) === '*') {
|
|
13
|
-
return value.includes(pattern.slice(1, -1));
|
|
14
|
-
}
|
|
15
|
-
else if (pattern.at(-1) === '*') {
|
|
16
|
-
return value.startsWith(pattern.slice(0, -1));
|
|
17
|
-
}
|
|
18
|
-
else if (pattern.at(0) === '*') {
|
|
19
|
-
return value.endsWith(pattern.slice(1));
|
|
20
|
-
}
|
|
21
|
-
else {
|
|
22
|
-
return value === pattern;
|
|
23
|
-
}
|
|
24
|
-
}
|
|
25
|
-
else {
|
|
26
|
-
return pattern.test(value);
|
|
27
|
-
}
|
|
28
|
-
}
|
|
1
|
+
export { match } from '@nmtjs/common';
|
|
29
2
|
export function isJsFile(name) {
|
|
30
3
|
if (name.endsWith('.d.ts'))
|
|
31
4
|
return false;
|
|
@@ -33,3 +6,13 @@ export function isJsFile(name) {
|
|
|
33
6
|
const ext = leading.join('.');
|
|
34
7
|
return ['js', 'mjs', 'cjs', 'ts', 'mts', 'cts'].includes(ext);
|
|
35
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"}
|
package/dist/utils/index.js
CHANGED
|
@@ -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"}
|
package/dist/utils/pool.js
CHANGED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"pool.js","sourceRoot":"","sources":["../../src/utils/pool.ts"],"names":[],"mappings":"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"}
|
package/dist/utils/semaphore.js
CHANGED
|
@@ -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
|
@@ -2,38 +2,37 @@
|
|
|
2
2
|
"name": "@nmtjs/core",
|
|
3
3
|
"type": "module",
|
|
4
4
|
"exports": {
|
|
5
|
-
".":
|
|
6
|
-
|
|
7
|
-
"import": "./dist/index.js",
|
|
8
|
-
"module-sync": "./dist/index.js"
|
|
9
|
-
},
|
|
10
|
-
"./constants": {
|
|
11
|
-
"types": "./dist/constants.d.ts",
|
|
12
|
-
"import": "./dist/constants.js",
|
|
13
|
-
"module-sync": "./dist/constants.js"
|
|
14
|
-
}
|
|
5
|
+
".": "./dist/index.js",
|
|
6
|
+
"./constants": "./dist/constants.js"
|
|
15
7
|
},
|
|
16
8
|
"peerDependencies": {
|
|
17
9
|
"pino": "^9.6.0",
|
|
18
10
|
"pino-pretty": "^13.0.0",
|
|
19
|
-
"@nmtjs/common": "0.
|
|
20
|
-
"@nmtjs/type": "0.
|
|
11
|
+
"@nmtjs/common": "0.15.0-beta.10",
|
|
12
|
+
"@nmtjs/type": "0.15.0-beta.10"
|
|
21
13
|
},
|
|
22
14
|
"devDependencies": {
|
|
23
|
-
"@types/node": "^
|
|
15
|
+
"@types/node": "^24",
|
|
24
16
|
"pino": "^9.6.0",
|
|
25
17
|
"pino-pretty": "^13.0.0",
|
|
26
|
-
"@nmtjs/
|
|
27
|
-
"@nmtjs/
|
|
18
|
+
"@nmtjs/type": "0.15.0-beta.10",
|
|
19
|
+
"@nmtjs/common": "0.15.0-beta.10"
|
|
28
20
|
},
|
|
29
21
|
"files": [
|
|
30
22
|
"dist",
|
|
23
|
+
"src",
|
|
31
24
|
"LICENSE.md",
|
|
32
25
|
"README.md"
|
|
33
26
|
],
|
|
34
|
-
"
|
|
27
|
+
"dependencies": {
|
|
28
|
+
"hookable": "6.0.0-rc.1",
|
|
29
|
+
"pino-std-serializers": "^7.0.0"
|
|
30
|
+
},
|
|
31
|
+
"version": "0.15.0-beta.10",
|
|
35
32
|
"scripts": {
|
|
36
|
-
"build": "
|
|
33
|
+
"clean-build": "rm -rf ./dist",
|
|
34
|
+
"build": "tsc --declaration --sourcemap",
|
|
35
|
+
"dev": "tsc --watch",
|
|
37
36
|
"type-check": "tsc --noEmit"
|
|
38
37
|
}
|
|
39
38
|
}
|
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
|