alepha 0.13.1 → 0.13.3

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 (329) hide show
  1. package/README.md +1 -1
  2. package/dist/api-files/index.browser.js +80 -0
  3. package/dist/api-files/index.browser.js.map +1 -0
  4. package/dist/api-files/index.d.ts +28 -91
  5. package/dist/api-files/index.js +10 -755
  6. package/dist/api-files/index.js.map +1 -1
  7. package/dist/api-jobs/index.browser.js +56 -0
  8. package/dist/api-jobs/index.browser.js.map +1 -0
  9. package/dist/api-jobs/index.d.ts +46 -46
  10. package/dist/api-jobs/index.js +13 -13
  11. package/dist/api-jobs/index.js.map +1 -1
  12. package/dist/api-notifications/index.browser.js +382 -0
  13. package/dist/api-notifications/index.browser.js.map +1 -0
  14. package/dist/api-notifications/index.d.ts +231 -193
  15. package/dist/api-notifications/index.js +108 -78
  16. package/dist/api-notifications/index.js.map +1 -1
  17. package/dist/api-parameters/index.browser.js +29 -0
  18. package/dist/api-parameters/index.browser.js.map +1 -0
  19. package/dist/api-parameters/index.d.ts +21 -22
  20. package/dist/api-parameters/index.js +22 -22
  21. package/dist/api-parameters/index.js.map +1 -1
  22. package/dist/api-users/index.d.ts +237 -2001
  23. package/dist/api-users/index.js +969 -4795
  24. package/dist/api-users/index.js.map +1 -1
  25. package/dist/api-verifications/index.browser.js +52 -0
  26. package/dist/api-verifications/index.browser.js.map +1 -0
  27. package/dist/api-verifications/index.d.ts +119 -97
  28. package/dist/api-verifications/index.js +1 -1
  29. package/dist/api-verifications/index.js.map +1 -1
  30. package/dist/batch/index.d.ts +13 -13
  31. package/dist/batch/index.js +8 -13
  32. package/dist/batch/index.js.map +1 -1
  33. package/dist/bucket/index.d.ts +14 -14
  34. package/dist/bucket/index.js +19 -17
  35. package/dist/bucket/index.js.map +1 -1
  36. package/dist/cache/index.d.ts +11 -11
  37. package/dist/cache/index.js +9 -9
  38. package/dist/cache/index.js.map +1 -1
  39. package/dist/cli/{dist-Dl9Vl7Ur.js → dist-lGnqsKpu.js} +11 -15
  40. package/dist/cli/dist-lGnqsKpu.js.map +1 -0
  41. package/dist/cli/index.d.ts +32 -49
  42. package/dist/cli/index.js +90 -71
  43. package/dist/cli/index.js.map +1 -1
  44. package/dist/command/index.d.ts +20 -19
  45. package/dist/command/index.js +34 -25
  46. package/dist/command/index.js.map +1 -1
  47. package/dist/core/index.browser.js +218 -218
  48. package/dist/core/index.browser.js.map +1 -1
  49. package/dist/core/index.d.ts +232 -232
  50. package/dist/core/index.js +218 -218
  51. package/dist/core/index.js.map +1 -1
  52. package/dist/core/index.native.js +2113 -0
  53. package/dist/core/index.native.js.map +1 -0
  54. package/dist/datetime/index.d.ts +9 -9
  55. package/dist/datetime/index.js +7 -7
  56. package/dist/datetime/index.js.map +1 -1
  57. package/dist/email/index.d.ts +16 -16
  58. package/dist/email/index.js +14 -9
  59. package/dist/email/index.js.map +1 -1
  60. package/dist/file/index.js +1 -1
  61. package/dist/file/index.js.map +1 -1
  62. package/dist/lock/index.d.ts +9 -9
  63. package/dist/lock/index.js +8 -8
  64. package/dist/lock/index.js.map +1 -1
  65. package/dist/lock-redis/index.js +3 -66
  66. package/dist/lock-redis/index.js.map +1 -1
  67. package/dist/logger/index.d.ts +5 -5
  68. package/dist/logger/index.js +8 -8
  69. package/dist/logger/index.js.map +1 -1
  70. package/dist/orm/index.browser.js +114 -114
  71. package/dist/orm/index.browser.js.map +1 -1
  72. package/dist/orm/index.d.ts +218 -218
  73. package/dist/orm/index.js +49 -49
  74. package/dist/orm/index.js.map +1 -1
  75. package/dist/queue/index.d.ts +29 -29
  76. package/dist/queue/index.js +20 -20
  77. package/dist/queue/index.js.map +1 -1
  78. package/dist/queue-redis/index.d.ts +2 -2
  79. package/dist/redis/index.d.ts +4 -4
  80. package/dist/retry/index.d.ts +19 -19
  81. package/dist/retry/index.js +7 -7
  82. package/dist/retry/index.js.map +1 -1
  83. package/dist/scheduler/index.d.ts +16 -16
  84. package/dist/scheduler/index.js +9 -9
  85. package/dist/scheduler/index.js.map +1 -1
  86. package/dist/security/index.d.ts +53 -53
  87. package/dist/security/index.js +35 -35
  88. package/dist/security/index.js.map +1 -1
  89. package/dist/server/index.browser.js +1 -1
  90. package/dist/server/index.browser.js.map +1 -1
  91. package/dist/server/index.d.ts +92 -92
  92. package/dist/server/index.js +16 -16
  93. package/dist/server/index.js.map +1 -1
  94. package/dist/server-auth/index.browser.js +4 -982
  95. package/dist/server-auth/index.browser.js.map +1 -1
  96. package/dist/server-auth/index.d.ts +204 -785
  97. package/dist/server-auth/index.js +47 -1239
  98. package/dist/server-auth/index.js.map +1 -1
  99. package/dist/server-cache/index.d.ts +10 -10
  100. package/dist/server-cache/index.js +2 -2
  101. package/dist/server-cache/index.js.map +1 -1
  102. package/dist/server-compress/index.d.ts +4 -4
  103. package/dist/server-compress/index.js +1 -1
  104. package/dist/server-compress/index.js.map +1 -1
  105. package/dist/server-cookies/index.browser.js +8 -8
  106. package/dist/server-cookies/index.browser.js.map +1 -1
  107. package/dist/server-cookies/index.d.ts +17 -17
  108. package/dist/server-cookies/index.js +11 -11
  109. package/dist/server-cookies/index.js.map +1 -1
  110. package/dist/server-cors/index.d.ts +17 -17
  111. package/dist/server-cors/index.js +9 -9
  112. package/dist/server-cors/index.js.map +1 -1
  113. package/dist/server-health/index.d.ts +19 -19
  114. package/dist/server-helmet/index.d.ts +1 -1
  115. package/dist/server-links/index.browser.js +12 -12
  116. package/dist/server-links/index.browser.js.map +1 -1
  117. package/dist/server-links/index.d.ts +59 -251
  118. package/dist/server-links/index.js +23 -502
  119. package/dist/server-links/index.js.map +1 -1
  120. package/dist/server-metrics/index.d.ts +4 -4
  121. package/dist/server-multipart/index.d.ts +2 -2
  122. package/dist/server-proxy/index.d.ts +12 -12
  123. package/dist/server-proxy/index.js +10 -10
  124. package/dist/server-proxy/index.js.map +1 -1
  125. package/dist/server-rate-limit/index.d.ts +22 -22
  126. package/dist/server-rate-limit/index.js +12 -12
  127. package/dist/server-rate-limit/index.js.map +1 -1
  128. package/dist/server-security/index.d.ts +22 -22
  129. package/dist/server-security/index.js +15 -15
  130. package/dist/server-security/index.js.map +1 -1
  131. package/dist/server-static/index.d.ts +14 -14
  132. package/dist/server-static/index.js +26 -10
  133. package/dist/server-static/index.js.map +1 -1
  134. package/dist/server-swagger/index.d.ts +25 -184
  135. package/dist/server-swagger/index.js +21 -724
  136. package/dist/server-swagger/index.js.map +1 -1
  137. package/dist/sms/index.d.ts +14 -14
  138. package/dist/sms/index.js +9 -9
  139. package/dist/sms/index.js.map +1 -1
  140. package/dist/thread/index.d.ts +11 -11
  141. package/dist/thread/index.js +17 -17
  142. package/dist/thread/index.js.map +1 -1
  143. package/dist/topic/index.d.ts +26 -26
  144. package/dist/topic/index.js +16 -16
  145. package/dist/topic/index.js.map +1 -1
  146. package/dist/topic-redis/index.d.ts +1 -1
  147. package/dist/vite/index.d.ts +3 -3
  148. package/dist/vite/index.js +8 -8
  149. package/dist/vite/index.js.map +1 -1
  150. package/dist/websocket/index.browser.js +11 -11
  151. package/dist/websocket/index.browser.js.map +1 -1
  152. package/dist/websocket/index.d.ts +58 -58
  153. package/dist/websocket/index.js +13 -13
  154. package/dist/websocket/index.js.map +1 -1
  155. package/package.json +128 -57
  156. package/src/api-files/index.browser.ts +17 -0
  157. package/src/api-files/services/FileService.ts +5 -7
  158. package/src/api-jobs/index.browser.ts +15 -0
  159. package/src/api-jobs/index.ts +1 -1
  160. package/src/api-jobs/{descriptors → primitives}/$job.ts +8 -8
  161. package/src/api-jobs/providers/JobProvider.ts +9 -9
  162. package/src/api-jobs/services/JobService.ts +5 -5
  163. package/src/api-notifications/controllers/NotificationController.ts +26 -1
  164. package/src/api-notifications/index.browser.ts +17 -0
  165. package/src/api-notifications/index.ts +6 -15
  166. package/src/api-notifications/{descriptors → primitives}/$notification.ts +10 -10
  167. package/src/api-notifications/schemas/notificationQuerySchema.ts +13 -0
  168. package/src/api-notifications/services/NotificationSenderService.ts +3 -3
  169. package/src/api-notifications/services/NotificationService.ts +45 -2
  170. package/src/api-parameters/index.browser.ts +12 -0
  171. package/src/api-parameters/index.ts +1 -1
  172. package/src/api-parameters/{descriptors → primitives}/$config.ts +7 -12
  173. package/src/api-users/atoms/realmAuthSettingsAtom.ts +3 -1
  174. package/src/api-users/controllers/UserController.ts +21 -1
  175. package/src/api-users/index.ts +1 -1
  176. package/src/api-users/{descriptors → primitives}/$userRealm.ts +40 -17
  177. package/src/api-users/providers/UserRealmProvider.ts +2 -1
  178. package/src/api-users/services/SessionService.ts +2 -0
  179. package/src/api-users/services/UserService.ts +56 -16
  180. package/src/api-verifications/index.browser.ts +15 -0
  181. package/src/api-verifications/index.ts +1 -0
  182. package/src/batch/index.ts +3 -3
  183. package/src/batch/{descriptors → primitives}/$batch.ts +13 -16
  184. package/src/batch/providers/BatchProvider.ts +0 -7
  185. package/src/bucket/index.ts +15 -13
  186. package/src/bucket/{descriptors → primitives}/$bucket.ts +8 -8
  187. package/src/bucket/providers/LocalFileStorageProvider.ts +3 -3
  188. package/src/cache/index.ts +4 -4
  189. package/src/cache/{descriptors → primitives}/$cache.ts +15 -15
  190. package/src/cli/apps/AlephaCli.ts +27 -1
  191. package/src/cli/apps/AlephaPackageBuilderCli.ts +27 -2
  192. package/src/cli/commands/CoreCommands.ts +6 -2
  193. package/src/cli/commands/DrizzleCommands.ts +6 -6
  194. package/src/cli/commands/VerifyCommands.ts +1 -1
  195. package/src/cli/commands/ViteCommands.ts +8 -2
  196. package/src/cli/services/ProjectUtils.ts +74 -78
  197. package/src/command/helpers/Asker.ts +10 -0
  198. package/src/command/index.ts +5 -5
  199. package/src/command/{descriptors → primitives}/$command.ts +9 -12
  200. package/src/command/providers/CliProvider.ts +10 -10
  201. package/src/core/Alepha.ts +30 -33
  202. package/src/core/constants/KIND.ts +1 -1
  203. package/src/core/constants/OPTIONS.ts +1 -1
  204. package/src/core/helpers/{descriptor.ts → primitive.ts} +18 -18
  205. package/src/core/helpers/ref.ts +1 -1
  206. package/src/core/index.shared.ts +8 -8
  207. package/src/core/{descriptors → primitives}/$context.ts +5 -5
  208. package/src/core/{descriptors → primitives}/$hook.ts +4 -4
  209. package/src/core/{descriptors → primitives}/$inject.ts +2 -2
  210. package/src/core/{descriptors → primitives}/$module.ts +9 -9
  211. package/src/core/{descriptors → primitives}/$use.ts +2 -2
  212. package/src/core/providers/CodecManager.ts +1 -1
  213. package/src/core/providers/JsonSchemaCodec.ts +1 -1
  214. package/src/core/providers/StateManager.ts +2 -2
  215. package/src/datetime/index.ts +3 -3
  216. package/src/datetime/{descriptors → primitives}/$interval.ts +6 -6
  217. package/src/email/index.ts +17 -9
  218. package/src/email/{descriptors → primitives}/$email.ts +8 -8
  219. package/src/file/index.ts +1 -1
  220. package/src/lock/index.ts +3 -3
  221. package/src/lock/{descriptors → primitives}/$lock.ts +10 -10
  222. package/src/logger/index.ts +8 -8
  223. package/src/logger/{descriptors → primitives}/$logger.ts +2 -2
  224. package/src/logger/services/Logger.ts +1 -1
  225. package/src/orm/constants/PG_SYMBOLS.ts +2 -2
  226. package/src/orm/index.browser.ts +2 -2
  227. package/src/orm/index.ts +8 -8
  228. package/src/orm/{descriptors → primitives}/$entity.ts +11 -11
  229. package/src/orm/{descriptors → primitives}/$repository.ts +2 -2
  230. package/src/orm/{descriptors → primitives}/$sequence.ts +8 -8
  231. package/src/orm/{descriptors → primitives}/$transaction.ts +4 -4
  232. package/src/orm/providers/PostgresTypeProvider.ts +3 -3
  233. package/src/orm/providers/RepositoryProvider.ts +4 -4
  234. package/src/orm/providers/drivers/DatabaseProvider.ts +7 -7
  235. package/src/orm/providers/drivers/NodeSqliteProvider.ts +3 -3
  236. package/src/orm/services/ModelBuilder.ts +9 -9
  237. package/src/orm/services/PgRelationManager.ts +2 -2
  238. package/src/orm/services/PostgresModelBuilder.ts +5 -5
  239. package/src/orm/services/Repository.ts +7 -7
  240. package/src/orm/services/SqliteModelBuilder.ts +5 -5
  241. package/src/queue/index.ts +7 -7
  242. package/src/queue/{descriptors → primitives}/$consumer.ts +15 -15
  243. package/src/queue/{descriptors → primitives}/$queue.ts +12 -12
  244. package/src/queue/providers/WorkerProvider.ts +7 -7
  245. package/src/retry/index.ts +3 -3
  246. package/src/retry/{descriptors → primitives}/$retry.ts +14 -14
  247. package/src/scheduler/index.ts +3 -3
  248. package/src/scheduler/{descriptors → primitives}/$scheduler.ts +9 -9
  249. package/src/scheduler/providers/CronProvider.ts +1 -1
  250. package/src/security/index.ts +9 -9
  251. package/src/security/{descriptors → primitives}/$permission.ts +7 -7
  252. package/src/security/{descriptors → primitives}/$realm.ts +6 -12
  253. package/src/security/{descriptors → primitives}/$role.ts +12 -12
  254. package/src/security/{descriptors → primitives}/$serviceAccount.ts +8 -8
  255. package/src/server/index.browser.ts +1 -1
  256. package/src/server/index.ts +14 -14
  257. package/src/server/{descriptors → primitives}/$action.ts +13 -13
  258. package/src/server/{descriptors → primitives}/$route.ts +9 -9
  259. package/src/server/providers/NodeHttpServerProvider.ts +1 -1
  260. package/src/server/services/HttpClient.ts +1 -1
  261. package/src/server-auth/index.browser.ts +1 -1
  262. package/src/server-auth/index.ts +6 -6
  263. package/src/server-auth/{descriptors → primitives}/$auth.ts +10 -10
  264. package/src/server-auth/{descriptors → primitives}/$authCredentials.ts +4 -4
  265. package/src/server-auth/{descriptors → primitives}/$authGithub.ts +4 -4
  266. package/src/server-auth/{descriptors → primitives}/$authGoogle.ts +4 -4
  267. package/src/server-auth/providers/ServerAuthProvider.ts +4 -4
  268. package/src/server-cache/providers/ServerCacheProvider.ts +7 -7
  269. package/src/server-compress/providers/ServerCompressProvider.ts +3 -3
  270. package/src/server-cookies/index.browser.ts +2 -2
  271. package/src/server-cookies/index.ts +5 -5
  272. package/src/server-cookies/{descriptors → primitives}/$cookie.browser.ts +12 -12
  273. package/src/server-cookies/{descriptors → primitives}/$cookie.ts +13 -13
  274. package/src/server-cookies/providers/ServerCookiesProvider.ts +6 -5
  275. package/src/server-cookies/services/CookieParser.ts +1 -1
  276. package/src/server-cors/index.ts +3 -3
  277. package/src/server-cors/{descriptors → primitives}/$cors.ts +11 -13
  278. package/src/server-cors/providers/ServerCorsProvider.ts +5 -5
  279. package/src/server-links/index.browser.ts +5 -5
  280. package/src/server-links/index.ts +9 -9
  281. package/src/server-links/{descriptors → primitives}/$remote.ts +11 -11
  282. package/src/server-links/providers/LinkProvider.ts +7 -7
  283. package/src/server-links/providers/{RemoteDescriptorProvider.ts → RemotePrimitiveProvider.ts} +6 -6
  284. package/src/server-links/providers/ServerLinksProvider.ts +3 -3
  285. package/src/server-proxy/index.ts +3 -3
  286. package/src/server-proxy/{descriptors → primitives}/$proxy.ts +8 -8
  287. package/src/server-proxy/providers/ServerProxyProvider.ts +4 -4
  288. package/src/server-rate-limit/index.ts +6 -6
  289. package/src/server-rate-limit/{descriptors → primitives}/$rateLimit.ts +13 -13
  290. package/src/server-rate-limit/providers/ServerRateLimitProvider.ts +5 -5
  291. package/src/server-security/index.ts +3 -3
  292. package/src/server-security/{descriptors → primitives}/$basicAuth.ts +13 -13
  293. package/src/server-security/providers/ServerBasicAuthProvider.ts +5 -5
  294. package/src/server-security/providers/ServerSecurityProvider.ts +4 -4
  295. package/src/server-static/index.ts +3 -3
  296. package/src/server-static/{descriptors → primitives}/$serve.ts +8 -10
  297. package/src/server-static/providers/ServerStaticProvider.ts +24 -9
  298. package/src/server-swagger/index.ts +5 -5
  299. package/src/server-swagger/{descriptors → primitives}/$swagger.ts +9 -9
  300. package/src/server-swagger/providers/ServerSwaggerProvider.ts +11 -10
  301. package/src/sms/index.ts +4 -4
  302. package/src/sms/{descriptors → primitives}/$sms.ts +8 -8
  303. package/src/thread/index.ts +3 -3
  304. package/src/thread/{descriptors → primitives}/$thread.ts +13 -13
  305. package/src/thread/providers/ThreadProvider.ts +7 -9
  306. package/src/topic/index.ts +5 -5
  307. package/src/topic/{descriptors → primitives}/$subscriber.ts +14 -14
  308. package/src/topic/{descriptors → primitives}/$topic.ts +10 -10
  309. package/src/topic/providers/TopicProvider.ts +4 -4
  310. package/src/vite/tasks/copyAssets.ts +1 -1
  311. package/src/vite/tasks/generateSitemap.ts +3 -3
  312. package/src/vite/tasks/prerenderPages.ts +2 -2
  313. package/src/vite/tasks/runAlepha.ts +2 -2
  314. package/src/websocket/index.browser.ts +3 -3
  315. package/src/websocket/index.shared.ts +2 -2
  316. package/src/websocket/index.ts +4 -4
  317. package/src/websocket/interfaces/WebSocketInterfaces.ts +3 -3
  318. package/src/websocket/{descriptors → primitives}/$channel.ts +10 -10
  319. package/src/websocket/{descriptors → primitives}/$websocket.ts +8 -8
  320. package/src/websocket/providers/NodeWebSocketServerProvider.ts +7 -7
  321. package/src/websocket/providers/WebSocketServerProvider.ts +3 -3
  322. package/src/websocket/services/WebSocketClient.ts +5 -5
  323. package/dist/cli/dist-Dl9Vl7Ur.js.map +0 -1
  324. package/src/api-notifications/providers/MemorySmsProvider.ts +0 -20
  325. package/src/api-notifications/providers/SmsProvider.ts +0 -8
  326. /package/src/core/{descriptors → primitives}/$atom.ts +0 -0
  327. /package/src/core/{descriptors → primitives}/$env.ts +0 -0
  328. /package/src/server-auth/{descriptors → primitives}/$authApple.ts +0 -0
  329. /package/src/server-links/{descriptors → primitives}/$client.ts +0 -0
@@ -1,8 +1,8 @@
1
1
  import {
2
2
  $inject,
3
- createDescriptor,
4
- Descriptor,
3
+ createPrimitive,
5
4
  KIND,
5
+ Primitive,
6
6
  type Static,
7
7
  type TSchema,
8
8
  } from "alepha";
@@ -11,18 +11,18 @@ import { ServerCookiesProvider } from "../providers/ServerCookiesProvider.ts";
11
11
 
12
12
  /**
13
13
  * Declares a type-safe, configurable HTTP cookie.
14
- * This descriptor provides methods to get, set, and delete the cookie
14
+ * This primitive provides methods to get, set, and delete the cookie
15
15
  * within the server request/response cycle.
16
16
  */
17
17
  export const $cookie = <T extends TSchema>(
18
- options: CookieDescriptorOptions<T>,
19
- ): AbstractCookieDescriptor<T> => {
20
- return createDescriptor(CookieDescriptor<T>, options);
18
+ options: CookiePrimitiveOptions<T>,
19
+ ): AbstractCookiePrimitive<T> => {
20
+ return createPrimitive(CookiePrimitive<T>, options);
21
21
  };
22
22
 
23
23
  // ---------------------------------------------------------------------------------------------------------------------
24
24
 
25
- export interface CookieDescriptorOptions<T extends TSchema> {
25
+ export interface CookiePrimitiveOptions<T extends TSchema> {
26
26
  /** The schema for the cookie's value, used for validation and type safety. */
27
27
  schema: T;
28
28
 
@@ -57,9 +57,9 @@ export interface CookieDescriptorOptions<T extends TSchema> {
57
57
  sign?: boolean;
58
58
  }
59
59
 
60
- export interface AbstractCookieDescriptor<T extends TSchema> {
60
+ export interface AbstractCookiePrimitive<T extends TSchema> {
61
61
  readonly name: string;
62
- readonly options: CookieDescriptorOptions<T>;
62
+ readonly options: CookiePrimitiveOptions<T>;
63
63
  set(
64
64
  value: Static<T>,
65
65
  options?: { cookies?: Cookies; ttl?: DurationLike },
@@ -68,9 +68,9 @@ export interface AbstractCookieDescriptor<T extends TSchema> {
68
68
  del(options?: { cookies?: Cookies }): void;
69
69
  }
70
70
 
71
- export class CookieDescriptor<T extends TSchema>
72
- extends Descriptor<CookieDescriptorOptions<T>>
73
- implements AbstractCookieDescriptor<T>
71
+ export class CookiePrimitive<T extends TSchema>
72
+ extends Primitive<CookiePrimitiveOptions<T>>
73
+ implements AbstractCookiePrimitive<T>
74
74
  {
75
75
  protected readonly serverCookiesProvider = $inject(ServerCookiesProvider);
76
76
 
@@ -119,7 +119,7 @@ export class CookieDescriptor<T extends TSchema>
119
119
  }
120
120
  }
121
121
 
122
- $cookie[KIND] = CookieDescriptor;
122
+ $cookie[KIND] = CookiePrimitive;
123
123
 
124
124
  // ---------------------------------------------------------------------------------------------------------------------
125
125
 
@@ -11,6 +11,7 @@ import {
11
11
  $hook,
12
12
  $inject,
13
13
  Alepha,
14
+ AlephaError,
14
15
  type Static,
15
16
  type TSchema,
16
17
  t,
@@ -21,9 +22,9 @@ import { DEFAULT_APP_SECRET } from "alepha/security";
21
22
  import type { ServerRequest } from "alepha/server";
22
23
  import type {
23
24
  Cookie,
24
- CookieDescriptorOptions,
25
+ CookiePrimitiveOptions,
25
26
  Cookies,
26
- } from "../descriptors/$cookie.ts";
27
+ } from "../primitives/$cookie.ts";
27
28
  import { CookieParser } from "../services/CookieParser.ts";
28
29
 
29
30
  const envSchema = t.object({
@@ -89,14 +90,14 @@ export class ServerCookiesProvider {
89
90
  this.alepha.context.get<ServerRequest>("request")?.cookies;
90
91
  if (cookies) return cookies;
91
92
  if (contextCookies) return contextCookies;
92
- throw new Error(
93
+ throw new AlephaError(
93
94
  "Cookie context is not available. This method must be called within a server request cycle.",
94
95
  );
95
96
  }
96
97
 
97
98
  public getCookie<T extends TSchema>(
98
99
  name: string,
99
- options: CookieDescriptorOptions<T>,
100
+ options: CookiePrimitiveOptions<T>,
100
101
  contextCookies?: Cookies,
101
102
  ): Static<T> | undefined {
102
103
  const cookies = this.getCookiesFromContext(contextCookies);
@@ -145,7 +146,7 @@ export class ServerCookiesProvider {
145
146
 
146
147
  public setCookie<T extends TSchema>(
147
148
  name: string,
148
- options: CookieDescriptorOptions<T>,
149
+ options: CookiePrimitiveOptions<T>,
149
150
  data: Static<T>,
150
151
  contextCookies?: Cookies,
151
152
  ): void {
@@ -1,4 +1,4 @@
1
- import type { Cookie } from "../descriptors/$cookie.ts";
1
+ import type { Cookie } from "../primitives/$cookie.ts";
2
2
 
3
3
  export class CookieParser {
4
4
  public parseRequestCookies(header: string): Record<string, string> {
@@ -1,5 +1,5 @@
1
1
  import { $module } from "alepha";
2
- import { $cors } from "./descriptors/$cors.ts";
2
+ import { $cors } from "./primitives/$cors.ts";
3
3
  import {
4
4
  type CorsOptions,
5
5
  ServerCorsProvider,
@@ -7,7 +7,7 @@ import {
7
7
 
8
8
  // ---------------------------------------------------------------------------------------------------------------------
9
9
 
10
- export * from "./descriptors/$cors.ts";
10
+ export * from "./primitives/$cors.ts";
11
11
  export * from "./providers/ServerCorsProvider.ts";
12
12
 
13
13
  // ---------------------------------------------------------------------------------------------------------------------
@@ -52,6 +52,6 @@ declare module "alepha/server" {
52
52
  */
53
53
  export const AlephaServerCors = $module({
54
54
  name: "alepha.server.cors",
55
- descriptors: [$cors],
55
+ primitives: [$cors],
56
56
  services: [ServerCorsProvider],
57
57
  });
@@ -1,10 +1,10 @@
1
- import { $inject, createDescriptor, Descriptor, KIND } from "alepha";
1
+ import { $inject, createPrimitive, KIND, Primitive } from "alepha";
2
2
  import type { CorsOptions } from "../providers/ServerCorsProvider.ts";
3
3
  import { ServerCorsProvider } from "../providers/ServerCorsProvider.ts";
4
4
 
5
5
  /**
6
6
  * Declares CORS configuration for specific server routes.
7
- * This descriptor provides path-based CORS configuration.
7
+ * This primitive provides path-based CORS configuration.
8
8
  *
9
9
  * @example
10
10
  * ```ts
@@ -18,15 +18,13 @@ import { ServerCorsProvider } from "../providers/ServerCorsProvider.ts";
18
18
  * }
19
19
  * ```
20
20
  */
21
- export const $cors = (
22
- options: CorsDescriptorConfig,
23
- ): AbstractCorsDescriptor => {
24
- return createDescriptor(CorsDescriptor, options);
21
+ export const $cors = (options: CorsPrimitiveConfig): AbstractCorsPrimitive => {
22
+ return createPrimitive(CorsPrimitive, options);
25
23
  };
26
24
 
27
25
  // ---------------------------------------------------------------------------------------------------------------------
28
26
 
29
- export interface CorsDescriptorConfig extends Partial<CorsOptions> {
27
+ export interface CorsPrimitiveConfig extends Partial<CorsOptions> {
30
28
  /** Name identifier for this CORS config (default: property key) */
31
29
  name?: string;
32
30
  /** Path patterns to match (supports wildcards like /api/*) */
@@ -35,14 +33,14 @@ export interface CorsDescriptorConfig extends Partial<CorsOptions> {
35
33
 
36
34
  // ---------------------------------------------------------------------------------------------------------------------
37
35
 
38
- export interface AbstractCorsDescriptor {
36
+ export interface AbstractCorsPrimitive {
39
37
  readonly name: string;
40
- readonly options: CorsDescriptorConfig;
38
+ readonly options: CorsPrimitiveConfig;
41
39
  }
42
40
 
43
- export class CorsDescriptor
44
- extends Descriptor<CorsDescriptorConfig>
45
- implements AbstractCorsDescriptor
41
+ export class CorsPrimitive
42
+ extends Primitive<CorsPrimitiveConfig>
43
+ implements AbstractCorsPrimitive
46
44
  {
47
45
  protected readonly serverCorsProvider = $inject(ServerCorsProvider);
48
46
 
@@ -56,4 +54,4 @@ export class CorsDescriptor
56
54
  }
57
55
  }
58
56
 
59
- $cors[KIND] = CorsDescriptor;
57
+ $cors[KIND] = CorsPrimitive;
@@ -1,7 +1,7 @@
1
1
  import { $atom, $hook, $inject, $use, type Static, t } from "alepha";
2
2
  import { $logger } from "alepha/logger";
3
3
  import { ServerRouterProvider } from "alepha/server";
4
- import type { CorsDescriptorConfig } from "../descriptors/$cors.ts";
4
+ import type { CorsPrimitiveConfig } from "../primitives/$cors.ts";
5
5
 
6
6
  // ---------------------------------------------------------------------------------------------------------------------
7
7
 
@@ -64,12 +64,12 @@ export class ServerCorsProvider {
64
64
  /**
65
65
  * Registered CORS configurations with their path patterns
66
66
  */
67
- public readonly registeredConfigs: CorsDescriptorConfig[] = [];
67
+ public readonly registeredConfigs: CorsPrimitiveConfig[] = [];
68
68
 
69
69
  /**
70
- * Register a CORS configuration (called by descriptors)
70
+ * Register a CORS configuration (called by primitives)
71
71
  */
72
- public registerCors(config: CorsDescriptorConfig): void {
72
+ public registerCors(config: CorsPrimitiveConfig): void {
73
73
  this.registeredConfigs.push(config);
74
74
  }
75
75
 
@@ -132,7 +132,7 @@ export class ServerCorsProvider {
132
132
  /**
133
133
  * Build complete CORS options by merging with global defaults
134
134
  */
135
- protected buildCorsOptions(config: CorsDescriptorConfig): CorsOptions {
135
+ protected buildCorsOptions(config: CorsPrimitiveConfig): CorsOptions {
136
136
  return {
137
137
  origin: config.origin ?? this.globalOptions.origin,
138
138
  methods: config.methods ?? this.globalOptions.methods,
@@ -1,12 +1,12 @@
1
1
  import { $module } from "alepha";
2
- import { $client } from "./descriptors/$client.ts";
3
- import { $remote } from "./descriptors/$remote.ts";
2
+ import { $client } from "./primitives/$client.ts";
3
+ import { $remote } from "./primitives/$remote.ts";
4
4
  import { LinkProvider } from "./providers/LinkProvider.ts";
5
5
 
6
6
  // ---------------------------------------------------------------------------------------------------------------------
7
7
 
8
- export * from "./descriptors/$client.ts";
9
- export * from "./descriptors/$remote.ts";
8
+ export * from "./primitives/$client.ts";
9
+ export * from "./primitives/$remote.ts";
10
10
  export * from "./providers/LinkProvider.ts";
11
11
  export * from "./schemas/apiLinksResponseSchema.ts";
12
12
 
@@ -14,6 +14,6 @@ export * from "./schemas/apiLinksResponseSchema.ts";
14
14
 
15
15
  export const AlephaServerLinks = $module({
16
16
  name: "alepha.server.links",
17
- descriptors: [$remote, $client],
17
+ primitives: [$remote, $client],
18
18
  services: [LinkProvider],
19
19
  });
@@ -1,19 +1,19 @@
1
1
  import "alepha/server/security";
2
2
  import { $module } from "alepha";
3
3
  import { AlephaServer } from "alepha/server";
4
- import { $client } from "./descriptors/$client.ts";
5
- import { $remote } from "./descriptors/$remote.ts";
4
+ import { $client } from "./primitives/$client.ts";
5
+ import { $remote } from "./primitives/$remote.ts";
6
6
  import { LinkProvider } from "./providers/LinkProvider.ts";
7
- import { RemoteDescriptorProvider } from "./providers/RemoteDescriptorProvider.ts";
7
+ import { RemotePrimitiveProvider } from "./providers/RemotePrimitiveProvider.ts";
8
8
  import { ServerLinksProvider } from "./providers/ServerLinksProvider.ts";
9
9
  import type { ApiLinksResponse } from "./schemas/apiLinksResponseSchema.ts";
10
10
 
11
11
  // ---------------------------------------------------------------------------------------------------------------------
12
12
 
13
- export * from "./descriptors/$client.ts";
14
- export * from "./descriptors/$remote.ts";
13
+ export * from "./primitives/$client.ts";
14
+ export * from "./primitives/$remote.ts";
15
15
  export * from "./providers/LinkProvider.ts";
16
- export * from "./providers/RemoteDescriptorProvider.ts";
16
+ export * from "./providers/RemotePrimitiveProvider.ts";
17
17
  export * from "./providers/ServerLinksProvider.ts";
18
18
  export * from "./schemas/apiLinksResponseSchema.ts";
19
19
 
@@ -36,7 +36,7 @@ declare module "alepha" {
36
36
  /**
37
37
  * Provides server-side link management and remote capabilities for client-server interactions.
38
38
  *
39
- * The server-links module enables declarative link definitions using `$remote` and `$client` descriptors,
39
+ * The server-links module enables declarative link definitions using `$remote` and `$client` primitives,
40
40
  * facilitating seamless API endpoint management and client-server communication. It integrates with server
41
41
  * security features to ensure safe and controlled access to resources.
42
42
  *
@@ -46,11 +46,11 @@ declare module "alepha" {
46
46
  */
47
47
  export const AlephaServerLinks = $module({
48
48
  name: "alepha.server.links",
49
- descriptors: [$remote, $client],
49
+ primitives: [$remote, $client],
50
50
  services: [
51
51
  AlephaServer,
52
52
  ServerLinksProvider,
53
- RemoteDescriptorProvider,
53
+ RemotePrimitiveProvider,
54
54
  LinkProvider,
55
55
  ],
56
56
  });
@@ -1,9 +1,9 @@
1
- import { createDescriptor, Descriptor, KIND } from "alepha";
2
- import type { ServiceAccountDescriptor } from "alepha/security";
3
- import type { ProxyDescriptorOptions } from "alepha/server/proxy";
1
+ import { createPrimitive, KIND, Primitive } from "alepha";
2
+ import type { ServiceAccountPrimitive } from "alepha/security";
3
+ import type { ProxyPrimitiveOptions } from "alepha/server/proxy";
4
4
 
5
5
  /**
6
- * $remote is a descriptor that allows you to define remote service access.
6
+ * $remote is a primitive that allows you to define remote service access.
7
7
  *
8
8
  * Use it only when you have 2 or more services that need to communicate with each other.
9
9
  *
@@ -11,11 +11,11 @@ import type { ProxyDescriptorOptions } from "alepha/server/proxy";
11
11
  *
12
12
  * You can add a service account if you want to use a security layer.
13
13
  */
14
- export const $remote = (options: RemoteDescriptorOptions) => {
15
- return createDescriptor(RemoteDescriptor, options);
14
+ export const $remote = (options: RemotePrimitiveOptions) => {
15
+ return createPrimitive(RemotePrimitive, options);
16
16
  };
17
17
 
18
- export interface RemoteDescriptorOptions {
18
+ export interface RemotePrimitiveOptions {
19
19
  /**
20
20
  * The URL of the remote service.
21
21
  * You can use a function to generate the URL dynamically.
@@ -52,7 +52,7 @@ export interface RemoteDescriptorOptions {
52
52
  proxy?:
53
53
  | boolean
54
54
  | Partial<
55
- ProxyDescriptorOptions & {
55
+ ProxyPrimitiveOptions & {
56
56
  /**
57
57
  * If true, the remote service won't be available internally, only through the proxy.
58
58
  */
@@ -64,13 +64,13 @@ export interface RemoteDescriptorOptions {
64
64
  * For communication between the server and the remote service with a security layer.
65
65
  * This will be used for internal communication and will not be exposed to the client.
66
66
  */
67
- serviceAccount?: ServiceAccountDescriptor;
67
+ serviceAccount?: ServiceAccountPrimitive;
68
68
  }
69
69
 
70
- export class RemoteDescriptor extends Descriptor<RemoteDescriptorOptions> {
70
+ export class RemotePrimitive extends Primitive<RemotePrimitiveOptions> {
71
71
  public get name(): string {
72
72
  return this.options.name ?? this.config.propertyKey;
73
73
  }
74
74
  }
75
75
 
76
- $remote[KIND] = RemoteDescriptor;
76
+ $remote[KIND] = RemotePrimitive;
@@ -1,7 +1,7 @@
1
1
  import { $inject, Alepha, AlephaError, type Async, t } from "alepha";
2
2
  import { $logger } from "alepha/logger";
3
3
  import {
4
- type ActionDescriptor,
4
+ type ActionPrimitive,
5
5
  type ClientRequestEntry,
6
6
  type ClientRequestOptions,
7
7
  type ClientRequestResponse,
@@ -79,7 +79,7 @@ export class LinkProvider {
79
79
 
80
80
  public get links(): HttpClientLink[] {
81
81
  // TODO: not performant at all, use a map instead for ServerLinks
82
- const apiLinks = this.alepha.state.get(
82
+ const apiLinks = this.alepha.store.get(
83
83
  "alepha.server.request.apiLinks",
84
84
  )?.links;
85
85
  if (apiLinks) {
@@ -114,7 +114,7 @@ export class LinkProvider {
114
114
  },
115
115
  );
116
116
 
117
- this.alepha.state.set("alepha.server.request.apiLinks", data);
117
+ this.alepha.store.set("alepha.server.request.apiLinks", data);
118
118
 
119
119
  return data.links;
120
120
  }
@@ -277,7 +277,7 @@ export class LinkProvider {
277
277
  ): Promise<HttpClientLink> {
278
278
  if (
279
279
  this.alepha.isBrowser() &&
280
- !this.alepha.state.get("alepha.server.request.apiLinks")
280
+ !this.alepha.store.get("alepha.server.request.apiLinks")
281
281
  ) {
282
282
  await this.fetchLinks();
283
283
  }
@@ -334,15 +334,15 @@ export interface ClientScope {
334
334
  }
335
335
 
336
336
  export type HttpVirtualClient<T> = {
337
- [K in keyof T as T[K] extends ActionDescriptor<RequestConfigSchema>
337
+ [K in keyof T as T[K] extends ActionPrimitive<RequestConfigSchema>
338
338
  ? K
339
- : never]: T[K] extends ActionDescriptor<infer Schema>
339
+ : never]: T[K] extends ActionPrimitive<infer Schema>
340
340
  ? VirtualAction<Schema>
341
341
  : never;
342
342
  };
343
343
 
344
344
  export interface VirtualAction<T extends RequestConfigSchema>
345
- extends Pick<ActionDescriptor<T>, "name" | "run" | "fetch"> {
345
+ extends Pick<ActionPrimitive<T>, "name" | "run" | "fetch"> {
346
346
  (
347
347
  config?: ClientRequestEntry<T>,
348
348
  opts?: ClientRequestOptions,
@@ -1,9 +1,9 @@
1
1
  import { $env, $hook, $inject, Alepha, t } from "alepha";
2
2
  import { $logger } from "alepha/logger";
3
3
  import { $retry } from "alepha/retry";
4
- import type { ServiceAccountDescriptor } from "alepha/security";
4
+ import type { ServiceAccountPrimitive } from "alepha/security";
5
5
  import { ServerProxyProvider } from "alepha/server/proxy";
6
- import { $remote, type RemoteDescriptor } from "../descriptors/$remote.ts";
6
+ import { $remote, type RemotePrimitive } from "../primitives/$remote.ts";
7
7
  import {
8
8
  type ApiLinksResponse,
9
9
  apiLinksResponseSchema,
@@ -17,7 +17,7 @@ const envSchema = t.object({
17
17
  }),
18
18
  });
19
19
 
20
- export class RemoteDescriptorProvider {
20
+ export class RemotePrimitiveProvider {
21
21
  protected readonly env = $env(envSchema);
22
22
  protected readonly alepha = $inject(Alepha);
23
23
  protected readonly proxyProvider = $inject(ServerProxyProvider);
@@ -32,7 +32,7 @@ export class RemoteDescriptorProvider {
32
32
  public readonly configure = $hook({
33
33
  on: "configure",
34
34
  handler: async () => {
35
- const remotes = this.alepha.descriptors($remote);
35
+ const remotes = this.alepha.primitives($remote);
36
36
  for (const remote of remotes) {
37
37
  await this.registerRemote(remote);
38
38
  }
@@ -78,7 +78,7 @@ export class RemoteDescriptorProvider {
78
78
  },
79
79
  });
80
80
 
81
- public async registerRemote(value: RemoteDescriptor): Promise<void> {
81
+ public async registerRemote(value: RemotePrimitive): Promise<void> {
82
82
  const options = value.options;
83
83
  const url = typeof options.url === "string" ? options.url : options.url();
84
84
  const linkPath = LinkProvider.path.apiLinks;
@@ -225,7 +225,7 @@ export interface ServerRemote {
225
225
  /**
226
226
  * Force a default access token provider when not provided.
227
227
  */
228
- serviceAccount?: ServiceAccountDescriptor;
228
+ serviceAccount?: ServiceAccountPrimitive;
229
229
 
230
230
  /**
231
231
  * Prefix for the remote service links.
@@ -18,7 +18,7 @@ import {
18
18
  apiLinksResponseSchema,
19
19
  } from "../schemas/apiLinksResponseSchema.ts";
20
20
  import { LinkProvider } from "./LinkProvider.ts";
21
- import { RemoteDescriptorProvider } from "./RemoteDescriptorProvider.ts";
21
+ import { RemotePrimitiveProvider } from "./RemotePrimitiveProvider.ts";
22
22
 
23
23
  const envSchema = t.object({
24
24
  SERVER_API_PREFIX: t.text({
@@ -31,7 +31,7 @@ export class ServerLinksProvider {
31
31
  protected readonly env = $env(envSchema);
32
32
  protected readonly alepha = $inject(Alepha);
33
33
  protected readonly linkProvider = $inject(LinkProvider);
34
- protected readonly remoteProvider = $inject(RemoteDescriptorProvider);
34
+ protected readonly remoteProvider = $inject(RemotePrimitiveProvider);
35
35
  protected readonly serverTimingProvider = $inject(ServerTimingProvider);
36
36
 
37
37
  public get prefix() {
@@ -42,7 +42,7 @@ export class ServerLinksProvider {
42
42
  on: "configure",
43
43
  handler: () => {
44
44
  // convert all $action to local links
45
- for (const action of this.alepha.descriptors($action)) {
45
+ for (const action of this.alepha.primitives($action)) {
46
46
  this.linkProvider.registerLink({
47
47
  name: action.name,
48
48
  group: action.group,
@@ -1,11 +1,11 @@
1
1
  import { $module } from "alepha";
2
2
  import { AlephaServer } from "alepha/server";
3
- import { $proxy } from "./descriptors/$proxy.ts";
3
+ import { $proxy } from "./primitives/$proxy.ts";
4
4
  import { ServerProxyProvider } from "./providers/ServerProxyProvider.ts";
5
5
 
6
6
  // ---------------------------------------------------------------------------------------------------------------------
7
7
 
8
- export * from "./descriptors/$proxy.ts";
8
+ export * from "./primitives/$proxy.ts";
9
9
  export * from "./providers/ServerProxyProvider.ts";
10
10
 
11
11
  // ---------------------------------------------------------------------------------------------------------------------
@@ -18,6 +18,6 @@ export * from "./providers/ServerProxyProvider.ts";
18
18
  */
19
19
  export const AlephaServerProxy = $module({
20
20
  name: "alepha.server.proxy",
21
- descriptors: [$proxy],
21
+ primitives: [$proxy],
22
22
  services: [AlephaServer, ServerProxyProvider],
23
23
  });
@@ -1,10 +1,10 @@
1
- import { type Async, createDescriptor, Descriptor, KIND } from "alepha";
1
+ import { type Async, createPrimitive, KIND, Primitive } from "alepha";
2
2
  import type { ServerRequest } from "alepha/server";
3
3
 
4
4
  /**
5
- * Creates a proxy descriptor to forward requests to another server.
5
+ * Creates a proxy primitive to forward requests to another server.
6
6
  *
7
- * This descriptor enables you to create reverse proxy functionality, allowing your Alepha server
7
+ * This primitive enables you to create reverse proxy functionality, allowing your Alepha server
8
8
  * to forward requests to other services while maintaining a unified API surface. It's particularly
9
9
  * useful for microservice architectures, API gateways, or when you need to aggregate multiple
10
10
  * services behind a single endpoint.
@@ -84,11 +84,11 @@ import type { ServerRequest } from "alepha/server";
84
84
  * }
85
85
  * ```
86
86
  */
87
- export const $proxy = (options: ProxyDescriptorOptions): ProxyDescriptor => {
88
- return createDescriptor(ProxyDescriptor, options);
87
+ export const $proxy = (options: ProxyPrimitiveOptions): ProxyPrimitive => {
88
+ return createPrimitive(ProxyPrimitive, options);
89
89
  };
90
90
 
91
- export type ProxyDescriptorOptions = {
91
+ export type ProxyPrimitiveOptions = {
92
92
  /**
93
93
  * Path pattern to match for proxying requests.
94
94
  *
@@ -219,6 +219,6 @@ export type ProxyDescriptorOptions = {
219
219
  // retry?: RetryOptions;
220
220
  };
221
221
 
222
- export class ProxyDescriptor extends Descriptor<ProxyDescriptorOptions> {}
222
+ export class ProxyPrimitive extends Primitive<ProxyPrimitiveOptions> {}
223
223
 
224
- $proxy[KIND] = ProxyDescriptor;
224
+ $proxy[KIND] = ProxyPrimitive;
@@ -7,7 +7,7 @@ import {
7
7
  type ServerRequest,
8
8
  ServerRouterProvider,
9
9
  } from "alepha/server";
10
- import { $proxy, type ProxyDescriptorOptions } from "../descriptors/$proxy.ts";
10
+ import { $proxy, type ProxyPrimitiveOptions } from "../primitives/$proxy.ts";
11
11
 
12
12
  export class ServerProxyProvider {
13
13
  protected readonly log = $logger();
@@ -17,13 +17,13 @@ export class ServerProxyProvider {
17
17
  protected readonly configure = $hook({
18
18
  on: "configure",
19
19
  handler: () => {
20
- for (const proxy of this.alepha.descriptors($proxy)) {
20
+ for (const proxy of this.alepha.primitives($proxy)) {
21
21
  this.createProxy(proxy.options);
22
22
  }
23
23
  },
24
24
  });
25
25
 
26
- public createProxy(options: ProxyDescriptorOptions): void {
26
+ public createProxy(options: ProxyPrimitiveOptions): void {
27
27
  if (options.disabled) {
28
28
  return;
29
29
  }
@@ -52,7 +52,7 @@ export class ServerProxyProvider {
52
52
 
53
53
  public createProxyHandler(
54
54
  target: string,
55
- options: Omit<ProxyDescriptorOptions, "path">,
55
+ options: Omit<ProxyPrimitiveOptions, "path">,
56
56
  ): ServerHandler {
57
57
  return async (request) => {
58
58
  const url = new URL(target + request.url.pathname);
@@ -1,17 +1,17 @@
1
1
  import { $module } from "alepha";
2
2
  import { AlephaServer } from "alepha/server";
3
- import { $rateLimit } from "./descriptors/$rateLimit.ts";
3
+ import { $rateLimit } from "./primitives/$rateLimit.ts";
4
4
  import { ServerRateLimitProvider } from "./providers/ServerRateLimitProvider.ts";
5
5
 
6
6
  // ---------------------------------------------------------------------------------------------------------------------
7
7
 
8
- export * from "./descriptors/$rateLimit.ts";
8
+ export * from "./primitives/$rateLimit.ts";
9
9
  export * from "./providers/ServerRateLimitProvider.ts";
10
10
 
11
11
  // ---------------------------------------------------------------------------------------------------------------------
12
12
 
13
13
  declare module "alepha/server" {
14
- interface ActionDescriptorOptions<TConfig> {
14
+ interface ActionPrimitiveOptions<TConfig> {
15
15
  /**
16
16
  * Rate limiting configuration for this action.
17
17
  * When specified, the action will be rate limited according to these settings.
@@ -47,8 +47,8 @@ export interface RateLimitOptions {
47
47
  * Provides rate limiting capabilities for server routes and actions with configurable limits and windows.
48
48
  *
49
49
  * The server-rate-limit module enables per-route and per-action rate limiting using either:
50
- * - The `$rateLimit` descriptor with `paths` option for path-based rate limiting
51
- * - The `rateLimit` option in action descriptors for action-specific limiting
50
+ * - The `$rateLimit` primitive with `paths` option for path-based rate limiting
51
+ * - The `rateLimit` option in action primitives for action-specific limiting
52
52
  *
53
53
  * It offers sliding window rate limiting, custom key generation, and seamless integration with server routes.
54
54
  *
@@ -71,6 +71,6 @@ export interface RateLimitOptions {
71
71
  */
72
72
  export const AlephaServerRateLimit = $module({
73
73
  name: "alepha.server.rate-limit",
74
- descriptors: [$rateLimit],
74
+ primitives: [$rateLimit],
75
75
  services: [AlephaServer, ServerRateLimitProvider],
76
76
  });