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.
Files changed (195) hide show
  1. package/dist/api-jobs/index.d.ts +26 -26
  2. package/dist/api-users/index.d.ts +1 -1
  3. package/dist/cli/{dist-Sz2EXvQX.cjs → dist-Dl9Vl7Ur.js} +17 -13
  4. package/dist/cli/{dist-BBPjuQ56.js.map → dist-Dl9Vl7Ur.js.map} +1 -1
  5. package/dist/cli/index.d.ts +3 -11
  6. package/dist/cli/index.js +106 -74
  7. package/dist/cli/index.js.map +1 -1
  8. package/dist/email/index.js +71 -73
  9. package/dist/email/index.js.map +1 -1
  10. package/dist/orm/index.d.ts +1 -1
  11. package/dist/orm/index.js.map +1 -1
  12. package/dist/queue/index.d.ts +4 -4
  13. package/dist/retry/index.d.ts +1 -1
  14. package/dist/retry/index.js +2 -2
  15. package/dist/retry/index.js.map +1 -1
  16. package/dist/scheduler/index.d.ts +6 -6
  17. package/dist/security/index.d.ts +28 -28
  18. package/dist/server/index.js +1 -1
  19. package/dist/server/index.js.map +1 -1
  20. package/dist/server-health/index.d.ts +17 -17
  21. package/dist/server-metrics/index.js +170 -174
  22. package/dist/server-metrics/index.js.map +1 -1
  23. package/dist/server-security/index.d.ts +9 -9
  24. package/dist/vite/index.js +4 -5
  25. package/dist/vite/index.js.map +1 -1
  26. package/dist/websocket/index.d.ts +7 -7
  27. package/package.json +52 -103
  28. package/src/cli/apps/AlephaPackageBuilderCli.ts +7 -2
  29. package/src/cli/assets/appRouterTs.ts +9 -0
  30. package/src/cli/assets/indexHtml.ts +2 -1
  31. package/src/cli/assets/mainBrowserTs.ts +10 -0
  32. package/src/cli/commands/CoreCommands.ts +6 -5
  33. package/src/cli/commands/DrizzleCommands.ts +65 -57
  34. package/src/cli/commands/VerifyCommands.ts +1 -1
  35. package/src/cli/services/ProjectUtils.ts +44 -38
  36. package/src/orm/providers/DrizzleKitProvider.ts +1 -1
  37. package/src/retry/descriptors/$retry.ts +5 -3
  38. package/src/server/providers/NodeHttpServerProvider.ts +1 -1
  39. package/src/vite/helpers/boot.ts +3 -3
  40. package/dist/api-files/index.cjs +0 -1293
  41. package/dist/api-files/index.cjs.map +0 -1
  42. package/dist/api-files/index.d.cts +0 -829
  43. package/dist/api-jobs/index.cjs +0 -274
  44. package/dist/api-jobs/index.cjs.map +0 -1
  45. package/dist/api-jobs/index.d.cts +0 -654
  46. package/dist/api-notifications/index.cjs +0 -380
  47. package/dist/api-notifications/index.cjs.map +0 -1
  48. package/dist/api-notifications/index.d.cts +0 -289
  49. package/dist/api-parameters/index.cjs +0 -66
  50. package/dist/api-parameters/index.cjs.map +0 -1
  51. package/dist/api-parameters/index.d.cts +0 -84
  52. package/dist/api-users/index.cjs +0 -6009
  53. package/dist/api-users/index.cjs.map +0 -1
  54. package/dist/api-users/index.d.cts +0 -4740
  55. package/dist/api-verifications/index.cjs +0 -407
  56. package/dist/api-verifications/index.cjs.map +0 -1
  57. package/dist/api-verifications/index.d.cts +0 -207
  58. package/dist/batch/index.cjs +0 -408
  59. package/dist/batch/index.cjs.map +0 -1
  60. package/dist/batch/index.d.cts +0 -330
  61. package/dist/bin/index.cjs +0 -17
  62. package/dist/bin/index.cjs.map +0 -1
  63. package/dist/bin/index.d.cts +0 -1
  64. package/dist/bucket/index.cjs +0 -303
  65. package/dist/bucket/index.cjs.map +0 -1
  66. package/dist/bucket/index.d.cts +0 -355
  67. package/dist/cache/index.cjs +0 -241
  68. package/dist/cache/index.cjs.map +0 -1
  69. package/dist/cache/index.d.cts +0 -202
  70. package/dist/cache-redis/index.cjs +0 -84
  71. package/dist/cache-redis/index.cjs.map +0 -1
  72. package/dist/cache-redis/index.d.cts +0 -40
  73. package/dist/cli/chunk-DSlc6foC.cjs +0 -43
  74. package/dist/cli/dist-BBPjuQ56.js +0 -2778
  75. package/dist/cli/dist-Sz2EXvQX.cjs.map +0 -1
  76. package/dist/cli/index.cjs +0 -1241
  77. package/dist/cli/index.cjs.map +0 -1
  78. package/dist/cli/index.d.cts +0 -422
  79. package/dist/command/index.cjs +0 -693
  80. package/dist/command/index.cjs.map +0 -1
  81. package/dist/command/index.d.cts +0 -340
  82. package/dist/core/index.cjs +0 -2264
  83. package/dist/core/index.cjs.map +0 -1
  84. package/dist/core/index.d.cts +0 -1927
  85. package/dist/datetime/index.cjs +0 -318
  86. package/dist/datetime/index.cjs.map +0 -1
  87. package/dist/datetime/index.d.cts +0 -145
  88. package/dist/email/index.cjs +0 -10874
  89. package/dist/email/index.cjs.map +0 -1
  90. package/dist/email/index.d.cts +0 -186
  91. package/dist/fake/index.cjs +0 -34641
  92. package/dist/fake/index.cjs.map +0 -1
  93. package/dist/fake/index.d.cts +0 -74
  94. package/dist/file/index.cjs +0 -1212
  95. package/dist/file/index.cjs.map +0 -1
  96. package/dist/file/index.d.cts +0 -698
  97. package/dist/lock/index.cjs +0 -226
  98. package/dist/lock/index.cjs.map +0 -1
  99. package/dist/lock/index.d.cts +0 -361
  100. package/dist/lock-redis/index.cjs +0 -113
  101. package/dist/lock-redis/index.cjs.map +0 -1
  102. package/dist/lock-redis/index.d.cts +0 -24
  103. package/dist/logger/index.cjs +0 -521
  104. package/dist/logger/index.cjs.map +0 -1
  105. package/dist/logger/index.d.cts +0 -281
  106. package/dist/orm/index.cjs +0 -2986
  107. package/dist/orm/index.cjs.map +0 -1
  108. package/dist/orm/index.d.cts +0 -2213
  109. package/dist/queue/index.cjs +0 -1044
  110. package/dist/queue/index.cjs.map +0 -1
  111. package/dist/queue/index.d.cts +0 -1265
  112. package/dist/queue-redis/index.cjs +0 -873
  113. package/dist/queue-redis/index.cjs.map +0 -1
  114. package/dist/queue-redis/index.d.cts +0 -82
  115. package/dist/redis/index.cjs +0 -153
  116. package/dist/redis/index.cjs.map +0 -1
  117. package/dist/redis/index.d.cts +0 -82
  118. package/dist/retry/index.cjs +0 -146
  119. package/dist/retry/index.cjs.map +0 -1
  120. package/dist/retry/index.d.cts +0 -172
  121. package/dist/router/index.cjs +0 -111
  122. package/dist/router/index.cjs.map +0 -1
  123. package/dist/router/index.d.cts +0 -46
  124. package/dist/scheduler/index.cjs +0 -576
  125. package/dist/scheduler/index.cjs.map +0 -1
  126. package/dist/scheduler/index.d.cts +0 -145
  127. package/dist/security/index.cjs +0 -2402
  128. package/dist/security/index.cjs.map +0 -1
  129. package/dist/security/index.d.cts +0 -598
  130. package/dist/server/index.cjs +0 -1680
  131. package/dist/server/index.cjs.map +0 -1
  132. package/dist/server/index.d.cts +0 -810
  133. package/dist/server-auth/index.cjs +0 -3146
  134. package/dist/server-auth/index.cjs.map +0 -1
  135. package/dist/server-auth/index.d.cts +0 -1164
  136. package/dist/server-cache/index.cjs +0 -252
  137. package/dist/server-cache/index.cjs.map +0 -1
  138. package/dist/server-cache/index.d.cts +0 -164
  139. package/dist/server-compress/index.cjs +0 -141
  140. package/dist/server-compress/index.cjs.map +0 -1
  141. package/dist/server-compress/index.d.cts +0 -38
  142. package/dist/server-cookies/index.cjs +0 -234
  143. package/dist/server-cookies/index.cjs.map +0 -1
  144. package/dist/server-cookies/index.d.cts +0 -144
  145. package/dist/server-cors/index.cjs +0 -201
  146. package/dist/server-cors/index.cjs.map +0 -1
  147. package/dist/server-cors/index.d.cts +0 -140
  148. package/dist/server-health/index.cjs +0 -62
  149. package/dist/server-health/index.cjs.map +0 -1
  150. package/dist/server-health/index.d.cts +0 -58
  151. package/dist/server-helmet/index.cjs +0 -131
  152. package/dist/server-helmet/index.cjs.map +0 -1
  153. package/dist/server-helmet/index.d.cts +0 -97
  154. package/dist/server-links/index.cjs +0 -992
  155. package/dist/server-links/index.cjs.map +0 -1
  156. package/dist/server-links/index.d.cts +0 -513
  157. package/dist/server-metrics/index.cjs +0 -4535
  158. package/dist/server-metrics/index.cjs.map +0 -1
  159. package/dist/server-metrics/index.d.cts +0 -35
  160. package/dist/server-multipart/index.cjs +0 -237
  161. package/dist/server-multipart/index.cjs.map +0 -1
  162. package/dist/server-multipart/index.d.cts +0 -50
  163. package/dist/server-proxy/index.cjs +0 -186
  164. package/dist/server-proxy/index.cjs.map +0 -1
  165. package/dist/server-proxy/index.d.cts +0 -234
  166. package/dist/server-rate-limit/index.cjs +0 -241
  167. package/dist/server-rate-limit/index.cjs.map +0 -1
  168. package/dist/server-rate-limit/index.d.cts +0 -183
  169. package/dist/server-security/index.cjs +0 -316
  170. package/dist/server-security/index.cjs.map +0 -1
  171. package/dist/server-security/index.d.cts +0 -173
  172. package/dist/server-static/index.cjs +0 -170
  173. package/dist/server-static/index.cjs.map +0 -1
  174. package/dist/server-static/index.d.cts +0 -121
  175. package/dist/server-swagger/index.cjs +0 -1021
  176. package/dist/server-swagger/index.cjs.map +0 -1
  177. package/dist/server-swagger/index.d.cts +0 -382
  178. package/dist/sms/index.cjs +0 -221
  179. package/dist/sms/index.cjs.map +0 -1
  180. package/dist/sms/index.d.cts +0 -130
  181. package/dist/thread/index.cjs +0 -350
  182. package/dist/thread/index.cjs.map +0 -1
  183. package/dist/thread/index.d.cts +0 -260
  184. package/dist/topic/index.cjs +0 -282
  185. package/dist/topic/index.cjs.map +0 -1
  186. package/dist/topic/index.d.cts +0 -523
  187. package/dist/topic-redis/index.cjs +0 -71
  188. package/dist/topic-redis/index.cjs.map +0 -1
  189. package/dist/topic-redis/index.d.cts +0 -42
  190. package/dist/vite/index.cjs +0 -1077
  191. package/dist/vite/index.cjs.map +0 -1
  192. package/dist/vite/index.d.cts +0 -542
  193. package/dist/websocket/index.cjs +0 -1117
  194. package/dist/websocket/index.cjs.map +0 -1
  195. 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
@@ -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