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