alepha 0.13.0 → 0.13.1
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/api-jobs/index.d.ts +26 -26
- package/dist/api-users/index.d.ts +1 -1
- package/dist/cli/{dist-Sz2EXvQX.cjs → dist-Dl9Vl7Ur.js} +17 -13
- package/dist/cli/{dist-BBPjuQ56.js.map → dist-Dl9Vl7Ur.js.map} +1 -1
- package/dist/cli/index.d.ts +3 -11
- package/dist/cli/index.js +106 -74
- package/dist/cli/index.js.map +1 -1
- package/dist/email/index.js +71 -73
- package/dist/email/index.js.map +1 -1
- package/dist/orm/index.d.ts +1 -1
- package/dist/orm/index.js.map +1 -1
- package/dist/queue/index.d.ts +4 -4
- package/dist/retry/index.d.ts +1 -1
- package/dist/retry/index.js +2 -2
- package/dist/retry/index.js.map +1 -1
- package/dist/scheduler/index.d.ts +6 -6
- package/dist/security/index.d.ts +28 -28
- package/dist/server/index.js +1 -1
- package/dist/server/index.js.map +1 -1
- package/dist/server-health/index.d.ts +17 -17
- package/dist/server-metrics/index.js +170 -174
- package/dist/server-metrics/index.js.map +1 -1
- package/dist/server-security/index.d.ts +9 -9
- package/dist/vite/index.js +4 -5
- package/dist/vite/index.js.map +1 -1
- package/dist/websocket/index.d.ts +7 -7
- package/package.json +52 -103
- package/src/cli/apps/AlephaPackageBuilderCli.ts +7 -2
- package/src/cli/assets/appRouterTs.ts +9 -0
- package/src/cli/assets/indexHtml.ts +2 -1
- package/src/cli/assets/mainBrowserTs.ts +10 -0
- package/src/cli/commands/CoreCommands.ts +6 -5
- package/src/cli/commands/DrizzleCommands.ts +65 -57
- package/src/cli/commands/VerifyCommands.ts +1 -1
- package/src/cli/services/ProjectUtils.ts +44 -38
- package/src/orm/providers/DrizzleKitProvider.ts +1 -1
- package/src/retry/descriptors/$retry.ts +5 -3
- package/src/server/providers/NodeHttpServerProvider.ts +1 -1
- package/src/vite/helpers/boot.ts +3 -3
- package/dist/api-files/index.cjs +0 -1293
- package/dist/api-files/index.cjs.map +0 -1
- package/dist/api-files/index.d.cts +0 -829
- package/dist/api-jobs/index.cjs +0 -274
- package/dist/api-jobs/index.cjs.map +0 -1
- package/dist/api-jobs/index.d.cts +0 -654
- package/dist/api-notifications/index.cjs +0 -380
- package/dist/api-notifications/index.cjs.map +0 -1
- package/dist/api-notifications/index.d.cts +0 -289
- package/dist/api-parameters/index.cjs +0 -66
- package/dist/api-parameters/index.cjs.map +0 -1
- package/dist/api-parameters/index.d.cts +0 -84
- package/dist/api-users/index.cjs +0 -6009
- package/dist/api-users/index.cjs.map +0 -1
- package/dist/api-users/index.d.cts +0 -4740
- package/dist/api-verifications/index.cjs +0 -407
- package/dist/api-verifications/index.cjs.map +0 -1
- package/dist/api-verifications/index.d.cts +0 -207
- package/dist/batch/index.cjs +0 -408
- package/dist/batch/index.cjs.map +0 -1
- package/dist/batch/index.d.cts +0 -330
- package/dist/bin/index.cjs +0 -17
- package/dist/bin/index.cjs.map +0 -1
- package/dist/bin/index.d.cts +0 -1
- package/dist/bucket/index.cjs +0 -303
- package/dist/bucket/index.cjs.map +0 -1
- package/dist/bucket/index.d.cts +0 -355
- package/dist/cache/index.cjs +0 -241
- package/dist/cache/index.cjs.map +0 -1
- package/dist/cache/index.d.cts +0 -202
- package/dist/cache-redis/index.cjs +0 -84
- package/dist/cache-redis/index.cjs.map +0 -1
- package/dist/cache-redis/index.d.cts +0 -40
- package/dist/cli/chunk-DSlc6foC.cjs +0 -43
- package/dist/cli/dist-BBPjuQ56.js +0 -2778
- package/dist/cli/dist-Sz2EXvQX.cjs.map +0 -1
- package/dist/cli/index.cjs +0 -1241
- package/dist/cli/index.cjs.map +0 -1
- package/dist/cli/index.d.cts +0 -422
- package/dist/command/index.cjs +0 -693
- package/dist/command/index.cjs.map +0 -1
- package/dist/command/index.d.cts +0 -340
- package/dist/core/index.cjs +0 -2264
- package/dist/core/index.cjs.map +0 -1
- package/dist/core/index.d.cts +0 -1927
- package/dist/datetime/index.cjs +0 -318
- package/dist/datetime/index.cjs.map +0 -1
- package/dist/datetime/index.d.cts +0 -145
- package/dist/email/index.cjs +0 -10874
- package/dist/email/index.cjs.map +0 -1
- package/dist/email/index.d.cts +0 -186
- package/dist/fake/index.cjs +0 -34641
- package/dist/fake/index.cjs.map +0 -1
- package/dist/fake/index.d.cts +0 -74
- package/dist/file/index.cjs +0 -1212
- package/dist/file/index.cjs.map +0 -1
- package/dist/file/index.d.cts +0 -698
- package/dist/lock/index.cjs +0 -226
- package/dist/lock/index.cjs.map +0 -1
- package/dist/lock/index.d.cts +0 -361
- package/dist/lock-redis/index.cjs +0 -113
- package/dist/lock-redis/index.cjs.map +0 -1
- package/dist/lock-redis/index.d.cts +0 -24
- package/dist/logger/index.cjs +0 -521
- package/dist/logger/index.cjs.map +0 -1
- package/dist/logger/index.d.cts +0 -281
- package/dist/orm/index.cjs +0 -2986
- package/dist/orm/index.cjs.map +0 -1
- package/dist/orm/index.d.cts +0 -2213
- package/dist/queue/index.cjs +0 -1044
- package/dist/queue/index.cjs.map +0 -1
- package/dist/queue/index.d.cts +0 -1265
- package/dist/queue-redis/index.cjs +0 -873
- package/dist/queue-redis/index.cjs.map +0 -1
- package/dist/queue-redis/index.d.cts +0 -82
- package/dist/redis/index.cjs +0 -153
- package/dist/redis/index.cjs.map +0 -1
- package/dist/redis/index.d.cts +0 -82
- package/dist/retry/index.cjs +0 -146
- package/dist/retry/index.cjs.map +0 -1
- package/dist/retry/index.d.cts +0 -172
- package/dist/router/index.cjs +0 -111
- package/dist/router/index.cjs.map +0 -1
- package/dist/router/index.d.cts +0 -46
- package/dist/scheduler/index.cjs +0 -576
- package/dist/scheduler/index.cjs.map +0 -1
- package/dist/scheduler/index.d.cts +0 -145
- package/dist/security/index.cjs +0 -2402
- package/dist/security/index.cjs.map +0 -1
- package/dist/security/index.d.cts +0 -598
- package/dist/server/index.cjs +0 -1680
- package/dist/server/index.cjs.map +0 -1
- package/dist/server/index.d.cts +0 -810
- package/dist/server-auth/index.cjs +0 -3146
- package/dist/server-auth/index.cjs.map +0 -1
- package/dist/server-auth/index.d.cts +0 -1164
- package/dist/server-cache/index.cjs +0 -252
- package/dist/server-cache/index.cjs.map +0 -1
- package/dist/server-cache/index.d.cts +0 -164
- package/dist/server-compress/index.cjs +0 -141
- package/dist/server-compress/index.cjs.map +0 -1
- package/dist/server-compress/index.d.cts +0 -38
- package/dist/server-cookies/index.cjs +0 -234
- package/dist/server-cookies/index.cjs.map +0 -1
- package/dist/server-cookies/index.d.cts +0 -144
- package/dist/server-cors/index.cjs +0 -201
- package/dist/server-cors/index.cjs.map +0 -1
- package/dist/server-cors/index.d.cts +0 -140
- package/dist/server-health/index.cjs +0 -62
- package/dist/server-health/index.cjs.map +0 -1
- package/dist/server-health/index.d.cts +0 -58
- package/dist/server-helmet/index.cjs +0 -131
- package/dist/server-helmet/index.cjs.map +0 -1
- package/dist/server-helmet/index.d.cts +0 -97
- package/dist/server-links/index.cjs +0 -992
- package/dist/server-links/index.cjs.map +0 -1
- package/dist/server-links/index.d.cts +0 -513
- package/dist/server-metrics/index.cjs +0 -4535
- package/dist/server-metrics/index.cjs.map +0 -1
- package/dist/server-metrics/index.d.cts +0 -35
- package/dist/server-multipart/index.cjs +0 -237
- package/dist/server-multipart/index.cjs.map +0 -1
- package/dist/server-multipart/index.d.cts +0 -50
- package/dist/server-proxy/index.cjs +0 -186
- package/dist/server-proxy/index.cjs.map +0 -1
- package/dist/server-proxy/index.d.cts +0 -234
- package/dist/server-rate-limit/index.cjs +0 -241
- package/dist/server-rate-limit/index.cjs.map +0 -1
- package/dist/server-rate-limit/index.d.cts +0 -183
- package/dist/server-security/index.cjs +0 -316
- package/dist/server-security/index.cjs.map +0 -1
- package/dist/server-security/index.d.cts +0 -173
- package/dist/server-static/index.cjs +0 -170
- package/dist/server-static/index.cjs.map +0 -1
- package/dist/server-static/index.d.cts +0 -121
- package/dist/server-swagger/index.cjs +0 -1021
- package/dist/server-swagger/index.cjs.map +0 -1
- package/dist/server-swagger/index.d.cts +0 -382
- package/dist/sms/index.cjs +0 -221
- package/dist/sms/index.cjs.map +0 -1
- package/dist/sms/index.d.cts +0 -130
- package/dist/thread/index.cjs +0 -350
- package/dist/thread/index.cjs.map +0 -1
- package/dist/thread/index.d.cts +0 -260
- package/dist/topic/index.cjs +0 -282
- package/dist/topic/index.cjs.map +0 -1
- package/dist/topic/index.d.cts +0 -523
- package/dist/topic-redis/index.cjs +0 -71
- package/dist/topic-redis/index.cjs.map +0 -1
- package/dist/topic-redis/index.d.cts +0 -42
- package/dist/vite/index.cjs +0 -1077
- package/dist/vite/index.cjs.map +0 -1
- package/dist/vite/index.d.cts +0 -542
- package/dist/websocket/index.cjs +0 -1117
- package/dist/websocket/index.cjs.map +0 -1
- package/dist/websocket/index.d.cts +0 -861
|
@@ -1,113 +0,0 @@
|
|
|
1
|
-
let alepha = require("alepha");
|
|
2
|
-
let alepha_lock = require("alepha/lock");
|
|
3
|
-
let alepha_topic = require("alepha/topic");
|
|
4
|
-
let alepha_logger = require("alepha/logger");
|
|
5
|
-
let alepha_redis = require("alepha/redis");
|
|
6
|
-
|
|
7
|
-
//#region src/topic-redis/providers/RedisTopicProvider.ts
|
|
8
|
-
const envSchema = alepha.t.object({ REDIS_TOPIC_PREFIX: alepha.t.text({ default: "topic" }) });
|
|
9
|
-
var RedisTopicProvider = class extends alepha_topic.TopicProvider {
|
|
10
|
-
env = (0, alepha.$env)(envSchema);
|
|
11
|
-
alepha = (0, alepha.$inject)(alepha.Alepha);
|
|
12
|
-
redisProvider = (0, alepha.$inject)(alepha_redis.RedisProvider);
|
|
13
|
-
redisSubscriberProvider = (0, alepha.$inject)(alepha_redis.RedisSubscriberProvider);
|
|
14
|
-
log = (0, alepha_logger.$logger)();
|
|
15
|
-
start = (0, alepha.$hook)({
|
|
16
|
-
on: "start",
|
|
17
|
-
handler: async () => {
|
|
18
|
-
const subscribers = this.subscribers();
|
|
19
|
-
if (subscribers.length) {
|
|
20
|
-
await Promise.all(subscribers.map((fn) => fn()));
|
|
21
|
-
for (const subscriber of subscribers) this.log.debug(`Subscribed to topic '${subscriber.name}'`);
|
|
22
|
-
}
|
|
23
|
-
}
|
|
24
|
-
});
|
|
25
|
-
prefix(queue) {
|
|
26
|
-
return `${this.env.REDIS_TOPIC_PREFIX}:${queue}`;
|
|
27
|
-
}
|
|
28
|
-
/**
|
|
29
|
-
* Publish a message to a topic.
|
|
30
|
-
*/
|
|
31
|
-
async publish(topic, message) {
|
|
32
|
-
await this.redisProvider.publisher.publish(this.prefix(topic), message);
|
|
33
|
-
}
|
|
34
|
-
/**
|
|
35
|
-
* Subscribe to a topic.
|
|
36
|
-
*/
|
|
37
|
-
async subscribe(name, callback) {
|
|
38
|
-
const topic = this.prefix(name);
|
|
39
|
-
await this.redisSubscriberProvider.subscriber.subscribe(topic, callback);
|
|
40
|
-
return () => this.unsubscribe(name, callback);
|
|
41
|
-
}
|
|
42
|
-
/**
|
|
43
|
-
* Unsubscribe from a topic.
|
|
44
|
-
*/
|
|
45
|
-
async unsubscribe(name, callback) {
|
|
46
|
-
const topic = this.prefix(name);
|
|
47
|
-
await this.redisSubscriberProvider.subscriber.unsubscribe(topic, callback);
|
|
48
|
-
}
|
|
49
|
-
};
|
|
50
|
-
|
|
51
|
-
//#endregion
|
|
52
|
-
//#region src/topic-redis/index.ts
|
|
53
|
-
/**
|
|
54
|
-
* Plugin for Alepha Topic that provides Redis pub/sub capabilities.
|
|
55
|
-
*
|
|
56
|
-
* @see {@link RedisTopicProvider}
|
|
57
|
-
* @module alepha.topic.redis
|
|
58
|
-
*/
|
|
59
|
-
const AlephaTopicRedis = (0, alepha.$module)({
|
|
60
|
-
name: "alepha.topic.redis",
|
|
61
|
-
services: [RedisTopicProvider],
|
|
62
|
-
register: (alepha$1) => alepha$1.with({
|
|
63
|
-
optional: true,
|
|
64
|
-
provide: alepha_topic.TopicProvider,
|
|
65
|
-
use: RedisTopicProvider
|
|
66
|
-
}).with(alepha_topic.AlephaTopic)
|
|
67
|
-
});
|
|
68
|
-
|
|
69
|
-
//#endregion
|
|
70
|
-
//#region src/lock-redis/providers/RedisLockProvider.ts
|
|
71
|
-
var RedisLockProvider = class {
|
|
72
|
-
log = (0, alepha_logger.$logger)();
|
|
73
|
-
redisProvider = (0, alepha.$inject)(alepha_redis.RedisProvider);
|
|
74
|
-
async set(key, value, nx, px) {
|
|
75
|
-
const options = { GET: true };
|
|
76
|
-
if (px) options.expiration = {
|
|
77
|
-
type: "PX",
|
|
78
|
-
value: px
|
|
79
|
-
};
|
|
80
|
-
if (nx) options.condition = "NX";
|
|
81
|
-
return (await this.redisProvider.set(key, value, options)).toString("utf-8");
|
|
82
|
-
}
|
|
83
|
-
async del(...keys) {
|
|
84
|
-
await this.redisProvider.del(keys);
|
|
85
|
-
}
|
|
86
|
-
};
|
|
87
|
-
|
|
88
|
-
//#endregion
|
|
89
|
-
//#region src/lock-redis/index.ts
|
|
90
|
-
/**
|
|
91
|
-
* Plugin for Alepha that provides a locking mechanism.
|
|
92
|
-
*
|
|
93
|
-
* @see {@link RedisLockProvider}
|
|
94
|
-
* @module alepha.lock.redis
|
|
95
|
-
*/
|
|
96
|
-
const AlephaLockRedis = (0, alepha.$module)({
|
|
97
|
-
name: "alepha.lock.redis",
|
|
98
|
-
services: [RedisLockProvider, RedisTopicProvider],
|
|
99
|
-
register: (alepha$1) => alepha$1.with({
|
|
100
|
-
optional: true,
|
|
101
|
-
provide: alepha_lock.LockTopicProvider,
|
|
102
|
-
use: RedisTopicProvider
|
|
103
|
-
}).with({
|
|
104
|
-
optional: true,
|
|
105
|
-
provide: alepha_lock.LockProvider,
|
|
106
|
-
use: RedisLockProvider
|
|
107
|
-
}).with(alepha_lock.AlephaLock)
|
|
108
|
-
});
|
|
109
|
-
|
|
110
|
-
//#endregion
|
|
111
|
-
exports.AlephaLockRedis = AlephaLockRedis;
|
|
112
|
-
exports.RedisLockProvider = RedisLockProvider;
|
|
113
|
-
//# sourceMappingURL=index.cjs.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index.cjs","names":["t","TopicProvider","Alepha","RedisProvider","RedisSubscriberProvider","alepha","TopicProvider","AlephaTopic","RedisProvider","options: RedisSetOptions","alepha","LockTopicProvider","LockProvider","AlephaLock"],"sources":["../../src/topic-redis/providers/RedisTopicProvider.ts","../../src/topic-redis/index.ts","../../src/lock-redis/providers/RedisLockProvider.ts","../../src/lock-redis/index.ts"],"sourcesContent":["import { $env, $hook, $inject, Alepha, t } from \"alepha\";\nimport { $logger } from \"alepha/logger\";\nimport { RedisProvider, RedisSubscriberProvider } from \"alepha/redis\";\nimport {\n type SubscribeCallback,\n TopicProvider,\n type UnSubscribeFn,\n} from \"alepha/topic\";\n\nconst envSchema = t.object({\n REDIS_TOPIC_PREFIX: t.text({\n default: \"topic\",\n }),\n});\n\nexport class RedisTopicProvider extends TopicProvider {\n protected readonly env = $env(envSchema);\n protected readonly alepha = $inject(Alepha);\n protected readonly redisProvider = $inject(RedisProvider);\n protected readonly redisSubscriberProvider = $inject(RedisSubscriberProvider);\n\n protected readonly log = $logger();\n\n protected readonly start = $hook({\n on: \"start\",\n handler: async () => {\n const subscribers = this.subscribers();\n if (subscribers.length) {\n await Promise.all(subscribers.map((fn) => fn()));\n for (const subscriber of subscribers) {\n this.log.debug(`Subscribed to topic '${subscriber.name}'`);\n }\n }\n },\n });\n\n public prefix(queue: string): string {\n return `${this.env.REDIS_TOPIC_PREFIX}:${queue}`;\n }\n\n /**\n * Publish a message to a topic.\n */\n public async publish(topic: string, message: string): Promise<void> {\n await this.redisProvider.publisher.publish(this.prefix(topic), message);\n }\n\n /**\n * Subscribe to a topic.\n */\n public async subscribe(\n name: string,\n callback: SubscribeCallback,\n ): Promise<UnSubscribeFn> {\n const topic = this.prefix(name);\n await this.redisSubscriberProvider.subscriber.subscribe(topic, callback);\n\n return () => this.unsubscribe(name, callback);\n }\n\n /**\n * Unsubscribe from a topic.\n */\n public async unsubscribe(\n name: string,\n callback?: SubscribeCallback,\n ): Promise<void> {\n const topic = this.prefix(name);\n\n await this.redisSubscriberProvider.subscriber.unsubscribe(topic, callback);\n }\n}\n","import { $module, type Alepha } from \"alepha\";\nimport { AlephaTopic, TopicProvider } from \"alepha/topic\";\nimport { RedisTopicProvider } from \"./providers/RedisTopicProvider.ts\";\n\n// ---------------------------------------------------------------------------------------------------------------------\n\nexport * from \"./providers/RedisTopicProvider.ts\";\n\n// ---------------------------------------------------------------------------------------------------------------------\n\n/**\n * Plugin for Alepha Topic that provides Redis pub/sub capabilities.\n *\n * @see {@link RedisTopicProvider}\n * @module alepha.topic.redis\n */\nexport const AlephaTopicRedis = $module({\n name: \"alepha.topic.redis\",\n services: [RedisTopicProvider],\n register: (alepha: Alepha): Alepha =>\n alepha\n .with({\n optional: true,\n provide: TopicProvider,\n use: RedisTopicProvider,\n })\n .with(AlephaTopic),\n});\n","import { $inject } from \"alepha\";\nimport type { LockProvider } from \"alepha/lock\";\nimport { $logger } from \"alepha/logger\";\nimport { RedisProvider, type RedisSetOptions } from \"alepha/redis\";\n\nexport class RedisLockProvider implements LockProvider {\n protected readonly log = $logger();\n protected readonly redisProvider = $inject(RedisProvider);\n\n public async set(\n key: string,\n value: string,\n nx?: boolean,\n px?: number,\n ): Promise<string> {\n const options: RedisSetOptions = {\n GET: true, // all the secrets of $lock is based on this\n };\n\n if (px) {\n options.expiration = {\n type: \"PX\",\n value: px,\n };\n }\n\n if (nx) {\n options.condition = \"NX\";\n }\n\n const resp = await this.redisProvider.set(key, value, options);\n\n return resp.toString(\"utf-8\");\n }\n\n public async del(...keys: string[]): Promise<void> {\n await this.redisProvider.del(keys);\n }\n}\n","import { $module, type Alepha } from \"alepha\";\nimport { AlephaLock, LockProvider, LockTopicProvider } from \"alepha/lock\";\nimport { RedisTopicProvider } from \"alepha/topic/redis\";\nimport { RedisLockProvider } from \"./providers/RedisLockProvider.ts\";\n\n// ---------------------------------------------------------------------------------------------------------------------\n\nexport * from \"./providers/RedisLockProvider.ts\";\n\n// ---------------------------------------------------------------------------------------------------------------------\n\n/**\n * Plugin for Alepha that provides a locking mechanism.\n *\n * @see {@link RedisLockProvider}\n * @module alepha.lock.redis\n */\nexport const AlephaLockRedis = $module({\n name: \"alepha.lock.redis\",\n services: [RedisLockProvider, RedisTopicProvider],\n register: (alepha: Alepha) =>\n alepha\n .with({\n optional: true,\n provide: LockTopicProvider,\n use: RedisTopicProvider,\n })\n .with({\n optional: true,\n provide: LockProvider,\n use: RedisLockProvider,\n })\n .with(AlephaLock),\n});\n"],"mappings":";;;;;;;AASA,MAAM,YAAYA,SAAE,OAAO,EACzB,oBAAoBA,SAAE,KAAK,EACzB,SAAS,SACV,CAAC,EACH,CAAC;AAEF,IAAa,qBAAb,cAAwCC,2BAAc;CACpD,AAAmB,uBAAW,UAAU;CACxC,AAAmB,6BAAiBC,cAAO;CAC3C,AAAmB,oCAAwBC,2BAAc;CACzD,AAAmB,8CAAkCC,qCAAwB;CAE7E,AAAmB,kCAAe;CAElC,AAAmB,0BAAc;EAC/B,IAAI;EACJ,SAAS,YAAY;GACnB,MAAM,cAAc,KAAK,aAAa;AACtC,OAAI,YAAY,QAAQ;AACtB,UAAM,QAAQ,IAAI,YAAY,KAAK,OAAO,IAAI,CAAC,CAAC;AAChD,SAAK,MAAM,cAAc,YACvB,MAAK,IAAI,MAAM,wBAAwB,WAAW,KAAK,GAAG;;;EAIjE,CAAC;CAEF,AAAO,OAAO,OAAuB;AACnC,SAAO,GAAG,KAAK,IAAI,mBAAmB,GAAG;;;;;CAM3C,MAAa,QAAQ,OAAe,SAAgC;AAClE,QAAM,KAAK,cAAc,UAAU,QAAQ,KAAK,OAAO,MAAM,EAAE,QAAQ;;;;;CAMzE,MAAa,UACX,MACA,UACwB;EACxB,MAAM,QAAQ,KAAK,OAAO,KAAK;AAC/B,QAAM,KAAK,wBAAwB,WAAW,UAAU,OAAO,SAAS;AAExE,eAAa,KAAK,YAAY,MAAM,SAAS;;;;;CAM/C,MAAa,YACX,MACA,UACe;EACf,MAAM,QAAQ,KAAK,OAAO,KAAK;AAE/B,QAAM,KAAK,wBAAwB,WAAW,YAAY,OAAO,SAAS;;;;;;;;;;;;ACrD9E,MAAa,uCAA2B;CACtC,MAAM;CACN,UAAU,CAAC,mBAAmB;CAC9B,WAAW,aACTC,SACG,KAAK;EACJ,UAAU;EACV,SAASC;EACT,KAAK;EACN,CAAC,CACD,KAAKC,yBAAY;CACvB,CAAC;;;;ACtBF,IAAa,oBAAb,MAAuD;CACrD,AAAmB,kCAAe;CAClC,AAAmB,oCAAwBC,2BAAc;CAEzD,MAAa,IACX,KACA,OACA,IACA,IACiB;EACjB,MAAMC,UAA2B,EAC/B,KAAK,MACN;AAED,MAAI,GACF,SAAQ,aAAa;GACnB,MAAM;GACN,OAAO;GACR;AAGH,MAAI,GACF,SAAQ,YAAY;AAKtB,UAFa,MAAM,KAAK,cAAc,IAAI,KAAK,OAAO,QAAQ,EAElD,SAAS,QAAQ;;CAG/B,MAAa,IAAI,GAAG,MAA+B;AACjD,QAAM,KAAK,cAAc,IAAI,KAAK;;;;;;;;;;;;ACnBtC,MAAa,sCAA0B;CACrC,MAAM;CACN,UAAU,CAAC,mBAAmB,mBAAmB;CACjD,WAAW,aACTC,SACG,KAAK;EACJ,UAAU;EACV,SAASC;EACT,KAAK;EACN,CAAC,CACD,KAAK;EACJ,UAAU;EACV,SAASC;EACT,KAAK;EACN,CAAC,CACD,KAAKC,uBAAW;CACtB,CAAC"}
|
|
@@ -1,24 +0,0 @@
|
|
|
1
|
-
import * as alepha0 from "alepha";
|
|
2
|
-
import * as alepha_logger0 from "alepha/logger";
|
|
3
|
-
import { LockProvider } from "alepha/lock";
|
|
4
|
-
import { RedisProvider } from "alepha/redis";
|
|
5
|
-
|
|
6
|
-
//#region src/lock-redis/providers/RedisLockProvider.d.ts
|
|
7
|
-
declare class RedisLockProvider implements LockProvider {
|
|
8
|
-
protected readonly log: alepha_logger0.Logger;
|
|
9
|
-
protected readonly redisProvider: RedisProvider;
|
|
10
|
-
set(key: string, value: string, nx?: boolean, px?: number): Promise<string>;
|
|
11
|
-
del(...keys: string[]): Promise<void>;
|
|
12
|
-
}
|
|
13
|
-
//#endregion
|
|
14
|
-
//#region src/lock-redis/index.d.ts
|
|
15
|
-
/**
|
|
16
|
-
* Plugin for Alepha that provides a locking mechanism.
|
|
17
|
-
*
|
|
18
|
-
* @see {@link RedisLockProvider}
|
|
19
|
-
* @module alepha.lock.redis
|
|
20
|
-
*/
|
|
21
|
-
declare const AlephaLockRedis: alepha0.Service<alepha0.Module>;
|
|
22
|
-
//#endregion
|
|
23
|
-
export { AlephaLockRedis, RedisLockProvider };
|
|
24
|
-
//# sourceMappingURL=index.d.cts.map
|
package/dist/logger/index.cjs
DELETED
|
@@ -1,521 +0,0 @@
|
|
|
1
|
-
let alepha = require("alepha");
|
|
2
|
-
let alepha_datetime = require("alepha/datetime");
|
|
3
|
-
|
|
4
|
-
//#region src/logger/providers/LogDestinationProvider.ts
|
|
5
|
-
var LogDestinationProvider = class {};
|
|
6
|
-
|
|
7
|
-
//#endregion
|
|
8
|
-
//#region src/logger/providers/LogFormatterProvider.ts
|
|
9
|
-
var LogFormatterProvider = class {};
|
|
10
|
-
|
|
11
|
-
//#endregion
|
|
12
|
-
//#region src/logger/services/Logger.ts
|
|
13
|
-
var Logger = class {
|
|
14
|
-
alepha = (0, alepha.$inject)(alepha.Alepha);
|
|
15
|
-
formatter = (0, alepha.$inject)(LogFormatterProvider);
|
|
16
|
-
destination = (0, alepha.$inject)(LogDestinationProvider);
|
|
17
|
-
dateTimeProvider = (0, alepha.$inject)(alepha_datetime.DateTimeProvider);
|
|
18
|
-
levels = {
|
|
19
|
-
SILENT: -1,
|
|
20
|
-
ERROR: 0,
|
|
21
|
-
WARN: 1,
|
|
22
|
-
INFO: 2,
|
|
23
|
-
DEBUG: 3,
|
|
24
|
-
TRACE: 4
|
|
25
|
-
};
|
|
26
|
-
service;
|
|
27
|
-
module;
|
|
28
|
-
app;
|
|
29
|
-
appLogLevel = "INFO";
|
|
30
|
-
logLevel = "INFO";
|
|
31
|
-
constructor(service, module$1) {
|
|
32
|
-
this.service = service;
|
|
33
|
-
this.module = module$1;
|
|
34
|
-
this.app = this.alepha.env.APP_NAME;
|
|
35
|
-
}
|
|
36
|
-
get context() {
|
|
37
|
-
return this.alepha.context.get("context");
|
|
38
|
-
}
|
|
39
|
-
get level() {
|
|
40
|
-
const stateLogLevel = this.alepha.state.get("alepha.logger.level");
|
|
41
|
-
if (stateLogLevel && stateLogLevel !== this.appLogLevel) {
|
|
42
|
-
this.appLogLevel = stateLogLevel;
|
|
43
|
-
this.logLevel = this.parseLevel(this.appLogLevel, this.module);
|
|
44
|
-
}
|
|
45
|
-
return this.logLevel;
|
|
46
|
-
}
|
|
47
|
-
parseLevel(level, app) {
|
|
48
|
-
const parts = level.toLowerCase().split(/[,;]/);
|
|
49
|
-
for (const part of parts) {
|
|
50
|
-
const trimmedPart = part.trim();
|
|
51
|
-
if (!trimmedPart) continue;
|
|
52
|
-
if (trimmedPart.includes(":") || trimmedPart.includes("=")) {
|
|
53
|
-
const [modulePattern, levelValue] = trimmedPart.split(/[:=]/);
|
|
54
|
-
const trimmedModule = modulePattern.trim();
|
|
55
|
-
const trimmedLevel = levelValue?.trim();
|
|
56
|
-
if (!trimmedLevel) continue;
|
|
57
|
-
if (this.matchesPattern(app, trimmedModule)) try {
|
|
58
|
-
return this.asLogLevel(trimmedLevel);
|
|
59
|
-
} catch (error) {
|
|
60
|
-
throw new alepha.AlephaError(`Invalid log level '${levelValue?.trim()}' for module pattern '${trimmedModule}'`);
|
|
61
|
-
}
|
|
62
|
-
}
|
|
63
|
-
}
|
|
64
|
-
for (const part of parts) {
|
|
65
|
-
const trimmedPart = part.trim();
|
|
66
|
-
if (!trimmedPart) continue;
|
|
67
|
-
if (!trimmedPart.includes(":") && !trimmedPart.includes("=")) try {
|
|
68
|
-
return this.asLogLevel(trimmedPart);
|
|
69
|
-
} catch (error) {
|
|
70
|
-
throw new Error(`Invalid global log level "${trimmedPart}"`);
|
|
71
|
-
}
|
|
72
|
-
}
|
|
73
|
-
return "INFO";
|
|
74
|
-
}
|
|
75
|
-
matchesPattern(moduleName, pattern) {
|
|
76
|
-
if (pattern.includes("*")) {
|
|
77
|
-
const regexPattern = pattern.replace(/\./g, "\\.").replace(/\*/g, ".*");
|
|
78
|
-
return (/* @__PURE__ */ new RegExp(`^${regexPattern}`)).test(moduleName);
|
|
79
|
-
}
|
|
80
|
-
return moduleName.startsWith(pattern);
|
|
81
|
-
}
|
|
82
|
-
asLogLevel(something) {
|
|
83
|
-
const level = something.trim().toUpperCase();
|
|
84
|
-
if (this.levels[level] !== void 0) return level;
|
|
85
|
-
throw new alepha.AlephaError(`Invalid log level: ${something}`);
|
|
86
|
-
}
|
|
87
|
-
error(message, data) {
|
|
88
|
-
this.log("ERROR", message, data);
|
|
89
|
-
}
|
|
90
|
-
warn(message, data) {
|
|
91
|
-
this.log("WARN", message, data);
|
|
92
|
-
}
|
|
93
|
-
info(message, data) {
|
|
94
|
-
this.log("INFO", message, data);
|
|
95
|
-
}
|
|
96
|
-
debug(message, data) {
|
|
97
|
-
this.log("DEBUG", message, data);
|
|
98
|
-
}
|
|
99
|
-
trace(message, data) {
|
|
100
|
-
this.log("TRACE", message, data);
|
|
101
|
-
}
|
|
102
|
-
log(level, message, data) {
|
|
103
|
-
let _message = "";
|
|
104
|
-
if (typeof message === "string") _message = message;
|
|
105
|
-
else if (typeof data === "string") _message = data;
|
|
106
|
-
let _data;
|
|
107
|
-
if (typeof data === "object" && !!data) _data = data;
|
|
108
|
-
else if (typeof message === "object" && message) _data = message;
|
|
109
|
-
const logEntry = {
|
|
110
|
-
level,
|
|
111
|
-
message: _message,
|
|
112
|
-
data: _data,
|
|
113
|
-
context: this.context,
|
|
114
|
-
service: this.service,
|
|
115
|
-
module: this.module,
|
|
116
|
-
app: this.app,
|
|
117
|
-
timestamp: this.dateTimeProvider.nowMillis()
|
|
118
|
-
};
|
|
119
|
-
if (this.levels[level] > this.levels[this.level]) {
|
|
120
|
-
this.emit(logEntry);
|
|
121
|
-
return;
|
|
122
|
-
}
|
|
123
|
-
const formatted = this.formatter.format(logEntry);
|
|
124
|
-
this.emit(logEntry, formatted);
|
|
125
|
-
this.destination.write(formatted, logEntry);
|
|
126
|
-
}
|
|
127
|
-
emit(entry, message) {
|
|
128
|
-
this.alepha.events.emit("log", {
|
|
129
|
-
message,
|
|
130
|
-
entry
|
|
131
|
-
}, { catch: true }).catch(() => null);
|
|
132
|
-
}
|
|
133
|
-
};
|
|
134
|
-
|
|
135
|
-
//#endregion
|
|
136
|
-
//#region src/logger/descriptors/$logger.ts
|
|
137
|
-
/**
|
|
138
|
-
* Create a logger.
|
|
139
|
-
*
|
|
140
|
-
* `name` is optional, by default it will use the name of the service.
|
|
141
|
-
*
|
|
142
|
-
* @example
|
|
143
|
-
* ```ts
|
|
144
|
-
* import { $logger } from "alepha";
|
|
145
|
-
*
|
|
146
|
-
* class MyService {
|
|
147
|
-
* log = $logger();
|
|
148
|
-
*
|
|
149
|
-
* constructor() {
|
|
150
|
-
* this.log.info("Service initialized");
|
|
151
|
-
* // print something like '[23:45:53.326] INFO <app.MyService>: Service initialized'
|
|
152
|
-
* }
|
|
153
|
-
* }
|
|
154
|
-
* ```
|
|
155
|
-
*/
|
|
156
|
-
const $logger = (options = {}) => {
|
|
157
|
-
const { alepha: alepha$1, service, module: module$1 } = (0, alepha.$context)();
|
|
158
|
-
return (0, alepha.$inject)(Logger, {
|
|
159
|
-
lifetime: "transient",
|
|
160
|
-
args: [options.name ?? service?.name, module$1?.name ?? alepha$1.env.MODULE_NAME ?? "app"]
|
|
161
|
-
});
|
|
162
|
-
};
|
|
163
|
-
$logger[alepha.KIND] = Logger;
|
|
164
|
-
|
|
165
|
-
//#endregion
|
|
166
|
-
//#region src/logger/providers/ConsoleDestinationProvider.ts
|
|
167
|
-
var ConsoleDestinationProvider = class extends LogDestinationProvider {
|
|
168
|
-
write(message) {
|
|
169
|
-
console.log(message);
|
|
170
|
-
}
|
|
171
|
-
};
|
|
172
|
-
|
|
173
|
-
//#endregion
|
|
174
|
-
//#region src/logger/providers/JsonFormatterProvider.ts
|
|
175
|
-
var JsonFormatterProvider = class extends LogFormatterProvider {
|
|
176
|
-
format(entry) {
|
|
177
|
-
const json = {
|
|
178
|
-
level: entry.level,
|
|
179
|
-
message: entry.message,
|
|
180
|
-
context: entry.context,
|
|
181
|
-
service: entry.service,
|
|
182
|
-
module: entry.module,
|
|
183
|
-
app: entry.app,
|
|
184
|
-
time: entry.timestamp
|
|
185
|
-
};
|
|
186
|
-
if (entry.data instanceof Error) json.error = this.formatJsonError(entry.data);
|
|
187
|
-
else json.data = entry.data;
|
|
188
|
-
return JSON.stringify(json);
|
|
189
|
-
}
|
|
190
|
-
formatJsonError(error) {
|
|
191
|
-
return {
|
|
192
|
-
name: error.name,
|
|
193
|
-
message: error.message,
|
|
194
|
-
stack: error.stack,
|
|
195
|
-
cause: error.cause instanceof Error ? this.formatJsonError(error.cause) : void 0
|
|
196
|
-
};
|
|
197
|
-
}
|
|
198
|
-
};
|
|
199
|
-
|
|
200
|
-
//#endregion
|
|
201
|
-
//#region src/logger/providers/MemoryDestinationProvider.ts
|
|
202
|
-
var MemoryDestinationProvider = class extends LogDestinationProvider {
|
|
203
|
-
entries = [];
|
|
204
|
-
options = { maxEntries: 1e3 };
|
|
205
|
-
write(formatted, entry) {
|
|
206
|
-
this.entries.push({
|
|
207
|
-
...entry,
|
|
208
|
-
formatted
|
|
209
|
-
});
|
|
210
|
-
if (this.entries.length > this.options.maxEntries) this.entries = this.entries.slice(-Math.floor(this.options.maxEntries * .8));
|
|
211
|
-
}
|
|
212
|
-
get logs() {
|
|
213
|
-
return [...this.entries];
|
|
214
|
-
}
|
|
215
|
-
clear() {
|
|
216
|
-
this.entries = [];
|
|
217
|
-
}
|
|
218
|
-
};
|
|
219
|
-
|
|
220
|
-
//#endregion
|
|
221
|
-
//#region src/logger/providers/RawFormatterProvider.ts
|
|
222
|
-
var RawFormatterProvider = class extends LogFormatterProvider {
|
|
223
|
-
format(entry) {
|
|
224
|
-
let output = "";
|
|
225
|
-
output += `${entry.message}`;
|
|
226
|
-
if (entry.data instanceof Error) {
|
|
227
|
-
output += `\n${entry.data.message}`;
|
|
228
|
-
let cause = entry.data.cause;
|
|
229
|
-
while (cause instanceof Error) {
|
|
230
|
-
output += `\nCaused by: ${cause.message}`;
|
|
231
|
-
cause = cause.cause;
|
|
232
|
-
}
|
|
233
|
-
}
|
|
234
|
-
return output;
|
|
235
|
-
}
|
|
236
|
-
};
|
|
237
|
-
|
|
238
|
-
//#endregion
|
|
239
|
-
//#region src/logger/providers/ConsoleColorProvider.ts
|
|
240
|
-
const envSchema$1 = alepha.t.object({
|
|
241
|
-
NO_COLOR: alepha.t.optional(alepha.t.text()),
|
|
242
|
-
FORCE_COLOR: alepha.t.optional(alepha.t.text())
|
|
243
|
-
});
|
|
244
|
-
var ConsoleColorProvider = class ConsoleColorProvider {
|
|
245
|
-
static COLORS = {
|
|
246
|
-
RESET: "\x1B[0m",
|
|
247
|
-
BLACK: "\x1B[30m",
|
|
248
|
-
RED: "\x1B[31m",
|
|
249
|
-
GREEN: "\x1B[32m",
|
|
250
|
-
ORANGE: "\x1B[33m",
|
|
251
|
-
BLUE: "\x1B[34m",
|
|
252
|
-
PURPLE: "\x1B[35m",
|
|
253
|
-
CYAN: "\x1B[36m",
|
|
254
|
-
GREY_LIGHT: "\x1B[37m",
|
|
255
|
-
GREY_LIGHT_BOLD: "\x1B[1;37m",
|
|
256
|
-
GREY_DARK: "\x1B[90m",
|
|
257
|
-
GREY_DARK_BOLD: "\x1B[1;90m",
|
|
258
|
-
WHITE: "\x1B[97m",
|
|
259
|
-
WHITE_BOLD: "\x1B[1;97m",
|
|
260
|
-
SILENT: "",
|
|
261
|
-
ERROR: "\x1B[31m",
|
|
262
|
-
WARN: "\x1B[33m",
|
|
263
|
-
INFO: "\x1B[32m",
|
|
264
|
-
DEBUG: "\x1B[34m",
|
|
265
|
-
TRACE: "\x1B[90m"
|
|
266
|
-
};
|
|
267
|
-
env = (0, alepha.$env)(envSchema$1);
|
|
268
|
-
alepha = (0, alepha.$inject)(alepha.Alepha);
|
|
269
|
-
enabled = true;
|
|
270
|
-
constructor() {
|
|
271
|
-
this.enabled = this.isEnabled();
|
|
272
|
-
}
|
|
273
|
-
isEnabled() {
|
|
274
|
-
if (this.env.NO_COLOR) return false;
|
|
275
|
-
if (this.env.FORCE_COLOR) return true;
|
|
276
|
-
return !this.alepha.isProduction();
|
|
277
|
-
}
|
|
278
|
-
set(color, text, reset = ConsoleColorProvider.COLORS.RESET) {
|
|
279
|
-
if (!this.enabled) return text;
|
|
280
|
-
return `${ConsoleColorProvider.COLORS[color]}${text}${reset}`;
|
|
281
|
-
}
|
|
282
|
-
};
|
|
283
|
-
|
|
284
|
-
//#endregion
|
|
285
|
-
//#region src/logger/providers/SimpleFormatterProvider.ts
|
|
286
|
-
var SimpleFormatterProvider = class extends LogFormatterProvider {
|
|
287
|
-
color = (0, alepha.$inject)(ConsoleColorProvider);
|
|
288
|
-
alepha = (0, alepha.$inject)(alepha.Alepha);
|
|
289
|
-
format(entry) {
|
|
290
|
-
const { data, timestamp } = entry;
|
|
291
|
-
let output = "";
|
|
292
|
-
let details = "";
|
|
293
|
-
const isError = data instanceof Error;
|
|
294
|
-
if (isError) details = this.formatError(data);
|
|
295
|
-
else if (data) try {
|
|
296
|
-
details = JSON.stringify(data);
|
|
297
|
-
} catch {
|
|
298
|
-
details = "[Unserializable Object]";
|
|
299
|
-
}
|
|
300
|
-
output += this.color.set("GREY_DARK", `[${this.formatTimestamp(timestamp)}]`);
|
|
301
|
-
output += " ";
|
|
302
|
-
output += this.color.set(entry.level, entry.level.toUpperCase());
|
|
303
|
-
output += " ";
|
|
304
|
-
if (entry.app) {
|
|
305
|
-
output += this.color.set("GREY_DARK", `${entry.app}`);
|
|
306
|
-
output += " ";
|
|
307
|
-
}
|
|
308
|
-
if (entry.context) {
|
|
309
|
-
output += this.color.set("GREY_DARK", `(${this.formatContext(entry.context)})`);
|
|
310
|
-
output += " ";
|
|
311
|
-
}
|
|
312
|
-
const module$1 = this.color.set("GREY_LIGHT", `${entry.module}.`);
|
|
313
|
-
const service = this.color.set(this.alepha.isBrowser() ? "RESET" : "WHITE", entry.service);
|
|
314
|
-
output += `<${module$1}${service}>`;
|
|
315
|
-
if (entry.message) output += `: ${this.color.set("CYAN", entry.message)}`;
|
|
316
|
-
else output += ":";
|
|
317
|
-
if (details) if (isError) output += ` \n${details}`;
|
|
318
|
-
else output += ` ${this.color.set("GREY_DARK", details)}`;
|
|
319
|
-
return output;
|
|
320
|
-
}
|
|
321
|
-
formatTimestamp(timestamp) {
|
|
322
|
-
const d = new Date(timestamp);
|
|
323
|
-
const h = d.getHours();
|
|
324
|
-
const m = d.getMinutes();
|
|
325
|
-
const s = d.getSeconds();
|
|
326
|
-
const ms = d.getMilliseconds();
|
|
327
|
-
return `${this.pad2(h)}:${this.pad2(m)}:${this.pad2(s)}.${this.pad3(ms)}`;
|
|
328
|
-
}
|
|
329
|
-
pad2 = (n) => (n < 10 ? "0" : "") + n;
|
|
330
|
-
pad3 = (n) => n < 10 ? `00${n}` : n < 100 ? `0${n}` : `${n}`;
|
|
331
|
-
/**
|
|
332
|
-
* Avoid to display the whole UUID in development mode
|
|
333
|
-
*/
|
|
334
|
-
formatContext(context) {
|
|
335
|
-
if (this.alepha.isProduction()) return context;
|
|
336
|
-
return context.slice(0, 8);
|
|
337
|
-
}
|
|
338
|
-
formatError(error) {
|
|
339
|
-
if (this.alepha.isBrowser()) {
|
|
340
|
-
setTimeout(() => {
|
|
341
|
-
console.error(error);
|
|
342
|
-
});
|
|
343
|
-
return "";
|
|
344
|
-
}
|
|
345
|
-
let str = error.stack ?? error.message;
|
|
346
|
-
const anyError = error;
|
|
347
|
-
while (anyError.cause && anyError.cause instanceof Error) {
|
|
348
|
-
str += `\nCaused by: ${anyError.cause.stack ?? anyError.cause.message}`;
|
|
349
|
-
anyError.cause = anyError.cause.cause;
|
|
350
|
-
}
|
|
351
|
-
return str;
|
|
352
|
-
}
|
|
353
|
-
};
|
|
354
|
-
|
|
355
|
-
//#endregion
|
|
356
|
-
//#region src/logger/schemas/logEntrySchema.ts
|
|
357
|
-
const logEntrySchema = alepha.t.object({
|
|
358
|
-
level: alepha.t.enum([
|
|
359
|
-
"SILENT",
|
|
360
|
-
"TRACE",
|
|
361
|
-
"DEBUG",
|
|
362
|
-
"INFO",
|
|
363
|
-
"WARN",
|
|
364
|
-
"ERROR"
|
|
365
|
-
]),
|
|
366
|
-
message: alepha.t.text({ size: "rich" }),
|
|
367
|
-
service: alepha.t.text(),
|
|
368
|
-
module: alepha.t.text(),
|
|
369
|
-
context: alepha.t.optional(alepha.t.text()),
|
|
370
|
-
app: alepha.t.optional(alepha.t.text()),
|
|
371
|
-
data: alepha.t.optional(alepha.t.any()),
|
|
372
|
-
timestamp: alepha.t.number()
|
|
373
|
-
});
|
|
374
|
-
|
|
375
|
-
//#endregion
|
|
376
|
-
//#region src/logger/index.ts
|
|
377
|
-
/**
|
|
378
|
-
* Minimalist logger module for Alepha.
|
|
379
|
-
*
|
|
380
|
-
* It offers a global logger interface (info, warn, ...) via the `$logger` descriptor.
|
|
381
|
-
*
|
|
382
|
-
* ```ts
|
|
383
|
-
* import { $logger } from "alepha/logger";
|
|
384
|
-
*
|
|
385
|
-
* class App {
|
|
386
|
-
* log = $logger();
|
|
387
|
-
* }
|
|
388
|
-
* ```
|
|
389
|
-
*
|
|
390
|
-
* ### Formatting and Destinations
|
|
391
|
-
*
|
|
392
|
-
* `AlephaLogger` is **extensible**, destinations and formatters can be added or replaced.
|
|
393
|
-
*
|
|
394
|
-
* Default log destinations are:
|
|
395
|
-
* - ConsoleDestinationProvider: logs to the console.
|
|
396
|
-
* - MemoryDestinationProvider: stores logs in memory for later retrieval.
|
|
397
|
-
*
|
|
398
|
-
* Default log formatters are:
|
|
399
|
-
* - JsonFormatterProvider: formats logs as JSON.
|
|
400
|
-
* - SimpleFormatterProvider: formats logs as simple text (with colors when possible).
|
|
401
|
-
* - RawFormatterProvider: formats logs as raw text without any formatting.
|
|
402
|
-
*
|
|
403
|
-
* ### Event Emission
|
|
404
|
-
*
|
|
405
|
-
* The logger emits 'log' events that can be listened to by external code, allowing for custom log processing and destinations.
|
|
406
|
-
*
|
|
407
|
-
* ```ts
|
|
408
|
-
* class CustomDestination {
|
|
409
|
-
* onLog = $hook({
|
|
410
|
-
* on: "log",
|
|
411
|
-
* handler: (ev) => {
|
|
412
|
-
* // ev.message (formatted message)
|
|
413
|
-
* // ev.entry (level, raw message, ...)
|
|
414
|
-
* }
|
|
415
|
-
* });
|
|
416
|
-
* }
|
|
417
|
-
* ```
|
|
418
|
-
*
|
|
419
|
-
* ### Log Level
|
|
420
|
-
*
|
|
421
|
-
* You can configure the log level and format via environment variables:
|
|
422
|
-
*
|
|
423
|
-
* - `LOG_LEVEL`: Sets the default log level for the application.
|
|
424
|
-
* - `LOG_FORMAT`: Sets the default log format for the application.
|
|
425
|
-
*
|
|
426
|
-
* ```bash
|
|
427
|
-
* LOG_LEVEL=debug LOG_FORMAT=json node src/index.ts
|
|
428
|
-
* ```
|
|
429
|
-
*
|
|
430
|
-
* Log level is also available in the state as `logLevel`, which can be used to dynamically change the log level at runtime.
|
|
431
|
-
* ```ts
|
|
432
|
-
* alepha.state.set("alepha.logger.level", "debug");
|
|
433
|
-
* ```
|
|
434
|
-
*
|
|
435
|
-
* Log level is $module aware, meaning you can set different log levels for different modules.
|
|
436
|
-
*
|
|
437
|
-
* **Module-specific configuration:**
|
|
438
|
-
* - `LOG_LEVEL=my.module.name:debug,info` - debug for `my.module.name` (and submodules), info for others
|
|
439
|
-
* - `LOG_LEVEL=alepha:trace,my.app:error,info` - trace for alepha modules, error for my.app modules, info for others
|
|
440
|
-
*
|
|
441
|
-
* **Wildcard patterns (NEW):**
|
|
442
|
-
* - `LOG_LEVEL=alepha.*:debug,info` - debug for all alepha submodules
|
|
443
|
-
* - `LOG_LEVEL=*.test:silent,*.core:trace,info` - silent for test modules, trace for core modules
|
|
444
|
-
*/
|
|
445
|
-
const AlephaLogger = (0, alepha.$module)({
|
|
446
|
-
name: "alepha.logger",
|
|
447
|
-
descriptors: [$logger],
|
|
448
|
-
services: [
|
|
449
|
-
Logger,
|
|
450
|
-
ConsoleDestinationProvider,
|
|
451
|
-
MemoryDestinationProvider,
|
|
452
|
-
JsonFormatterProvider,
|
|
453
|
-
SimpleFormatterProvider,
|
|
454
|
-
RawFormatterProvider
|
|
455
|
-
],
|
|
456
|
-
register: (alepha$1) => {
|
|
457
|
-
const env = alepha$1.parseEnv(envSchema);
|
|
458
|
-
const getLogDestinationProvider = () => {
|
|
459
|
-
if (alepha$1.isTest() && !env.LOG_LEVEL) {
|
|
460
|
-
const printOnError = (ev) => {
|
|
461
|
-
if (ev.task?.result?.state === "fail") {
|
|
462
|
-
const output = alepha$1.inject(MemoryDestinationProvider);
|
|
463
|
-
for (const log of output.logs) console.log(log.formatted);
|
|
464
|
-
}
|
|
465
|
-
};
|
|
466
|
-
try {
|
|
467
|
-
alepha$1.state.get("alepha.test.afterEach")?.(printOnError);
|
|
468
|
-
alepha$1.state.get("alepha.test.onTestFinished")?.(printOnError);
|
|
469
|
-
} catch {}
|
|
470
|
-
return MemoryDestinationProvider;
|
|
471
|
-
}
|
|
472
|
-
return ConsoleDestinationProvider;
|
|
473
|
-
};
|
|
474
|
-
const getLogFormatterProvider = () => {
|
|
475
|
-
if (env.LOG_FORMAT) {
|
|
476
|
-
if (env.LOG_FORMAT === "json") return JsonFormatterProvider;
|
|
477
|
-
if (env.LOG_FORMAT === "raw") return RawFormatterProvider;
|
|
478
|
-
return SimpleFormatterProvider;
|
|
479
|
-
}
|
|
480
|
-
if (alepha$1.isProduction() && !alepha$1.isBrowser()) return JsonFormatterProvider;
|
|
481
|
-
return SimpleFormatterProvider;
|
|
482
|
-
};
|
|
483
|
-
alepha$1.with({
|
|
484
|
-
optional: true,
|
|
485
|
-
provide: LogDestinationProvider,
|
|
486
|
-
use: getLogDestinationProvider()
|
|
487
|
-
});
|
|
488
|
-
alepha$1.with({
|
|
489
|
-
optional: true,
|
|
490
|
-
provide: LogFormatterProvider,
|
|
491
|
-
use: getLogFormatterProvider()
|
|
492
|
-
});
|
|
493
|
-
alepha$1.state.set("alepha.logger", alepha$1.inject(Logger, {
|
|
494
|
-
lifetime: "transient",
|
|
495
|
-
args: ["Alepha", "alepha.core"]
|
|
496
|
-
}));
|
|
497
|
-
alepha$1.state.set("alepha.logger.level", env.LOG_LEVEL ?? (alepha$1.isTest() ? "trace" : "info"));
|
|
498
|
-
}
|
|
499
|
-
});
|
|
500
|
-
const envSchema = alepha.t.object({
|
|
501
|
-
LOG_LEVEL: alepha.t.optional(alepha.t.text({ lowercase: true })),
|
|
502
|
-
LOG_FORMAT: alepha.t.optional(alepha.t.enum([
|
|
503
|
-
"json",
|
|
504
|
-
"pretty",
|
|
505
|
-
"raw"
|
|
506
|
-
], { lowercase: true }))
|
|
507
|
-
});
|
|
508
|
-
|
|
509
|
-
//#endregion
|
|
510
|
-
exports.$logger = $logger;
|
|
511
|
-
exports.AlephaLogger = AlephaLogger;
|
|
512
|
-
exports.ConsoleColorProvider = ConsoleColorProvider;
|
|
513
|
-
exports.ConsoleDestinationProvider = ConsoleDestinationProvider;
|
|
514
|
-
exports.JsonFormatterProvider = JsonFormatterProvider;
|
|
515
|
-
exports.LogDestinationProvider = LogDestinationProvider;
|
|
516
|
-
exports.LogFormatterProvider = LogFormatterProvider;
|
|
517
|
-
exports.Logger = Logger;
|
|
518
|
-
exports.MemoryDestinationProvider = MemoryDestinationProvider;
|
|
519
|
-
exports.SimpleFormatterProvider = SimpleFormatterProvider;
|
|
520
|
-
exports.logEntrySchema = logEntrySchema;
|
|
521
|
-
//# sourceMappingURL=index.cjs.map
|