alepha 0.13.6 → 0.13.8
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +5 -2
- package/assets/swagger-ui/swagger-ui-bundle.js +1 -1
- package/assets/swagger-ui/swagger-ui-standalone-preset.js +1 -1
- package/assets/swagger-ui/swagger-ui.css +1 -1
- package/dist/api/audits/index.browser.js +116 -0
- package/dist/api/audits/index.browser.js.map +1 -0
- package/dist/api/audits/index.d.ts +1194 -0
- package/dist/api/audits/index.js +674 -0
- package/dist/api/audits/index.js.map +1 -0
- package/dist/{api-files → api/files}/index.browser.js +5 -5
- package/dist/api/files/index.browser.js.map +1 -0
- package/dist/{api-files → api/files}/index.d.ts +16 -9
- package/dist/{api-files → api/files}/index.js +10 -10
- package/dist/api/files/index.js.map +1 -0
- package/dist/{api-jobs → api/jobs}/index.browser.js +5 -5
- package/dist/api/jobs/index.browser.js.map +1 -0
- package/dist/{api-jobs → api/jobs}/index.d.ts +35 -35
- package/dist/{api-jobs → api/jobs}/index.js +9 -9
- package/dist/api/jobs/index.js.map +1 -0
- package/dist/{api-notifications → api/notifications}/index.browser.js +11 -11
- package/dist/api/notifications/index.browser.js.map +1 -0
- package/dist/api/notifications/index.d.ts +327 -0
- package/dist/{api-notifications → api/notifications}/index.js +11 -11
- package/dist/api/notifications/index.js.map +1 -0
- package/dist/api/parameters/index.browser.js +60 -0
- package/dist/api/parameters/index.browser.js.map +1 -0
- package/dist/api/parameters/index.d.ts +761 -0
- package/dist/api/parameters/index.js +877 -0
- package/dist/api/parameters/index.js.map +1 -0
- package/dist/{api-users → api/users}/index.browser.js +6 -6
- package/dist/api/users/index.browser.js.map +1 -0
- package/dist/{api-users → api/users}/index.d.ts +259 -247
- package/dist/{api-users → api/users}/index.js +125 -112
- package/dist/api/users/index.js.map +1 -0
- package/dist/{api-verifications → api/verifications}/index.browser.js +5 -5
- package/dist/api/verifications/index.browser.js.map +1 -0
- package/dist/api/verifications/index.d.ts +248 -0
- package/dist/{api-verifications → api/verifications}/index.js +13 -12
- package/dist/api/verifications/index.js.map +1 -0
- package/dist/bin/index.js +1 -0
- package/dist/bin/index.js.map +1 -1
- package/dist/cache/{index.d.ts → core/index.d.ts} +4 -4
- package/dist/cache/{index.js → core/index.js} +5 -5
- package/dist/cache/core/index.js.map +1 -0
- package/dist/{cache-redis → cache/redis}/index.d.ts +2 -2
- package/dist/{cache-redis → cache/redis}/index.js +2 -2
- package/dist/cache/redis/index.js.map +1 -0
- package/dist/cli/index.d.ts +71 -9
- package/dist/cli/index.js +280 -79
- package/dist/cli/index.js.map +1 -1
- package/dist/command/index.d.ts +63 -2
- package/dist/command/index.js +30 -3
- package/dist/command/index.js.map +1 -1
- package/dist/core/index.browser.js +241 -61
- package/dist/core/index.browser.js.map +1 -1
- package/dist/core/index.d.ts +170 -90
- package/dist/core/index.js +264 -67
- package/dist/core/index.js.map +1 -1
- package/dist/core/index.native.js +248 -65
- package/dist/core/index.native.js.map +1 -1
- package/dist/email/index.js +15 -10554
- package/dist/email/index.js.map +1 -1
- package/dist/lock/{index.d.ts → core/index.d.ts} +5 -5
- package/dist/lock/{index.js → core/index.js} +5 -5
- package/dist/lock/core/index.js.map +1 -0
- package/dist/{lock-redis → lock/redis}/index.d.ts +2 -2
- package/dist/{lock-redis → lock/redis}/index.js +2 -2
- package/dist/lock/redis/index.js.map +1 -0
- package/dist/logger/index.d.ts +4 -4
- package/dist/logger/index.js +77 -72
- package/dist/logger/index.js.map +1 -1
- package/dist/orm/index.d.ts +5 -1
- package/dist/orm/index.js +24 -7
- package/dist/orm/index.js.map +1 -1
- package/dist/queue/core/index.d.ts +548 -0
- package/dist/queue/core/index.js +391 -0
- package/dist/queue/core/index.js.map +1 -0
- package/dist/queue/redis/index.d.ts +28 -0
- package/dist/queue/redis/index.js +43 -0
- package/dist/queue/redis/index.js.map +1 -0
- package/dist/scheduler/index.d.ts +7 -7
- package/dist/scheduler/index.js +1 -393
- package/dist/scheduler/index.js.map +1 -1
- package/dist/security/index.d.ts +1 -1
- package/dist/security/index.js +2 -1413
- package/dist/security/index.js.map +1 -1
- package/dist/{server-auth → server/auth}/index.browser.js +6 -6
- package/dist/server/auth/index.browser.js.map +1 -0
- package/dist/{server-auth → server/auth}/index.d.ts +175 -164
- package/dist/server/auth/index.js +742 -0
- package/dist/server/auth/index.js.map +1 -0
- package/dist/{server-cache → server/cache}/index.d.ts +2 -2
- package/dist/{server-cache → server/cache}/index.js +2 -2
- package/dist/server/cache/index.js.map +1 -0
- package/dist/{server-compress → server/compress}/index.d.ts +2 -2
- package/dist/{server-compress → server/compress}/index.js +2 -2
- package/dist/server/compress/index.js.map +1 -0
- package/dist/{server-cookies → server/cookies}/index.browser.js +3 -3
- package/dist/server/cookies/index.browser.js.map +1 -0
- package/dist/{server-cookies → server/cookies}/index.d.ts +4 -4
- package/dist/{server-cookies → server/cookies}/index.js +9 -5
- package/dist/server/cookies/index.js.map +1 -0
- package/dist/server/{index.browser.js → core/index.browser.js} +14 -14
- package/dist/server/core/index.browser.js.map +1 -0
- package/dist/server/{index.d.ts → core/index.d.ts} +46 -37
- package/dist/server/{index.js → core/index.js} +47 -33
- package/dist/server/core/index.js.map +1 -0
- package/dist/{server-cors → server/cors}/index.d.ts +3 -3
- package/dist/{server-cors → server/cors}/index.js +3 -3
- package/dist/server/cors/index.js.map +1 -0
- package/dist/{server-health → server/health}/index.d.ts +3 -3
- package/dist/{server-health → server/health}/index.js +3 -3
- package/dist/server/health/index.js.map +1 -0
- package/dist/{server-helmet → server/helmet}/index.d.ts +2 -2
- package/dist/{server-helmet → server/helmet}/index.js +2 -2
- package/dist/server/helmet/index.js.map +1 -0
- package/dist/{server-links → server/links}/index.browser.js +5 -5
- package/dist/server/links/index.browser.js.map +1 -0
- package/dist/{server-links → server/links}/index.d.ts +40 -40
- package/dist/{server-links → server/links}/index.js +7 -7
- package/dist/server/links/index.js.map +1 -0
- package/dist/{server-metrics → server/metrics}/index.d.ts +2 -2
- package/dist/server/metrics/index.js +74 -0
- package/dist/server/metrics/index.js.map +1 -0
- package/dist/{server-multipart → server/multipart}/index.d.ts +2 -2
- package/dist/{server-multipart → server/multipart}/index.js +2 -2
- package/dist/server/multipart/index.js.map +1 -0
- package/dist/{server-proxy → server/proxy}/index.d.ts +3 -3
- package/dist/{server-proxy → server/proxy}/index.js +3 -3
- package/dist/server/proxy/index.js.map +1 -0
- package/dist/{server-rate-limit → server/rate-limit}/index.d.ts +4 -4
- package/dist/{server-rate-limit → server/rate-limit}/index.js +4 -4
- package/dist/server/rate-limit/index.js.map +1 -0
- package/dist/{server-security → server/security}/index.browser.js +1 -1
- package/dist/server/security/index.browser.js.map +1 -0
- package/dist/{server-security → server/security}/index.d.ts +4 -4
- package/dist/{server-security → server/security}/index.js +4 -4
- package/dist/server/security/index.js.map +1 -0
- package/dist/{server-static → server/static}/index.d.ts +3 -3
- package/dist/{server-static → server/static}/index.js +3 -3
- package/dist/server/static/index.js.map +1 -0
- package/dist/{server-swagger → server/swagger}/index.d.ts +3 -3
- package/dist/{server-swagger → server/swagger}/index.js +4 -4
- package/dist/server/swagger/index.js.map +1 -0
- package/dist/thread/index.js +2 -2
- package/dist/thread/index.js.map +1 -1
- package/dist/topic/{index.d.ts → core/index.d.ts} +6 -6
- package/dist/topic/{index.js → core/index.js} +6 -6
- package/dist/topic/core/index.js.map +1 -0
- package/dist/{topic-redis → topic/redis}/index.d.ts +2 -2
- package/dist/{topic-redis → topic/redis}/index.js +2 -2
- package/dist/topic/redis/index.js.map +1 -0
- package/dist/vite/index.d.ts +13 -2
- package/dist/vite/index.js +114 -50
- package/dist/vite/index.js.map +1 -1
- package/dist/websocket/index.browser.js +3 -3
- package/dist/websocket/index.browser.js.map +1 -1
- package/dist/websocket/index.js +4 -4
- package/dist/websocket/index.js.map +1 -1
- package/package.json +160 -156
- package/src/api/audits/controllers/AuditController.ts +186 -0
- package/src/api/audits/entities/audits.ts +132 -0
- package/src/api/audits/index.browser.ts +18 -0
- package/src/api/audits/index.ts +58 -0
- package/src/api/audits/primitives/$audit.ts +159 -0
- package/src/api/audits/schemas/auditQuerySchema.ts +23 -0
- package/src/api/audits/schemas/auditResourceSchema.ts +9 -0
- package/src/api/audits/schemas/createAuditSchema.ts +27 -0
- package/src/api/audits/services/AuditService.ts +412 -0
- package/src/{api-files → api/files}/index.ts +1 -0
- package/src/api/parameters/controllers/ConfigController.ts +324 -0
- package/src/api/parameters/entities/parameters.ts +113 -0
- package/src/api/parameters/index.ts +60 -0
- package/src/api/parameters/primitives/$config.ts +351 -0
- package/src/api/parameters/schedulers/ConfigActivationScheduler.ts +30 -0
- package/src/api/parameters/services/ConfigStore.ts +491 -0
- package/src/{api-users → api/users}/atoms/realmAuthSettingsAtom.ts +19 -0
- package/src/{api-users → api/users}/controllers/UserRealmController.ts +0 -2
- package/src/{api-users → api/users}/index.ts +2 -0
- package/src/{api-users → api/users}/primitives/$userRealm.ts +18 -3
- package/src/{api-users → api/users}/providers/UserRealmProvider.ts +12 -10
- package/src/{api-users → api/users}/services/RegistrationService.ts +2 -1
- package/src/{api-users → api/users}/services/SessionService.ts +4 -0
- package/src/{api-users → api/users}/services/UserService.ts +3 -0
- package/src/{api-verifications → api/verifications}/index.ts +9 -1
- package/src/bin/index.ts +1 -0
- package/src/cli/apps/AlephaPackageBuilderCli.ts +73 -48
- package/src/cli/assets/appRouterTs.ts +1 -1
- package/src/cli/assets/biomeJson.ts +2 -2
- package/src/cli/assets/dummySpecTs.ts +7 -0
- package/src/cli/assets/editorconfig.ts +13 -0
- package/src/cli/assets/indexHtml.ts +1 -1
- package/src/cli/assets/mainBrowserTs.ts +1 -1
- package/src/cli/assets/mainTs.ts +14 -0
- package/src/cli/assets/viteConfigTs.ts +1 -1
- package/src/cli/commands/BiomeCommands.ts +2 -0
- package/src/cli/commands/CoreCommands.ts +38 -15
- package/src/cli/commands/VerifyCommands.ts +6 -2
- package/src/cli/commands/ViteCommands.ts +28 -18
- package/src/cli/services/AlephaCliUtils.ts +243 -37
- package/src/command/helpers/Asker.ts +0 -1
- package/src/command/primitives/$command.ts +67 -0
- package/src/command/providers/CliProvider.ts +39 -8
- package/src/core/Alepha.ts +40 -30
- package/src/core/helpers/jsonSchemaToTypeBox.ts +307 -0
- package/src/core/index.shared.ts +1 -0
- package/src/core/index.ts +30 -3
- package/src/core/providers/EventManager.ts +1 -1
- package/src/core/providers/SchemaValidator.ts +1 -1
- package/src/core/providers/StateManager.ts +23 -12
- package/src/core/providers/TypeProvider.ts +26 -34
- package/src/logger/index.ts +8 -6
- package/src/logger/primitives/$logger.ts +1 -1
- package/src/logger/providers/{SimpleFormatterProvider.ts → PrettyFormatterProvider.ts} +10 -1
- package/src/orm/index.ts +6 -0
- package/src/orm/services/PgRelationManager.ts +2 -2
- package/src/orm/services/PostgresModelBuilder.ts +11 -7
- package/src/orm/services/Repository.ts +16 -7
- package/src/orm/services/SqliteModelBuilder.ts +10 -0
- package/src/queue/{index.ts → core/index.ts} +2 -3
- package/src/queue/{primitives → core/primitives}/$queue.ts +17 -162
- package/src/queue/core/providers/MemoryQueueProvider.ts +19 -0
- package/src/queue/core/providers/QueueProvider.ts +23 -0
- package/src/queue/core/providers/WorkerProvider.ts +244 -0
- package/src/queue/redis/providers/RedisQueueProvider.ts +31 -0
- package/src/{server-auth → server/auth}/primitives/$auth.ts +7 -0
- package/src/{server-auth → server/auth}/providers/ServerAuthProvider.ts +51 -8
- package/src/{server-cookies → server/cookies}/index.ts +2 -1
- package/src/server/{index.ts → core/index.ts} +7 -0
- package/src/server/{primitives → core/primitives}/$action.ts +10 -1
- package/src/server/{providers → core/providers}/ServerBodyParserProvider.ts +11 -5
- package/src/server/{providers → core/providers}/ServerRouterProvider.ts +13 -7
- package/src/{server-rate-limit → server/rate-limit}/index.ts +1 -1
- package/src/{server-swagger → server/swagger}/providers/ServerSwaggerProvider.ts +1 -0
- package/src/thread/primitives/$thread.ts +2 -2
- package/src/vite/index.ts +0 -2
- package/src/vite/tasks/buildServer.ts +3 -4
- package/src/vite/tasks/copyAssets.ts +32 -8
- package/src/vite/tasks/generateCloudflare.ts +35 -19
- package/src/vite/tasks/generateDocker.ts +18 -4
- package/src/vite/tasks/generateSitemap.ts +5 -7
- package/src/vite/tasks/generateVercel.ts +76 -41
- package/src/vite/tasks/runAlepha.ts +16 -1
- package/src/websocket/providers/NodeWebSocketServerProvider.ts +3 -11
- package/src/websocket/services/WebSocketClient.ts +3 -3
- package/dist/api-files/index.browser.js.map +0 -1
- package/dist/api-files/index.js.map +0 -1
- package/dist/api-jobs/index.browser.js.map +0 -1
- package/dist/api-jobs/index.js.map +0 -1
- package/dist/api-notifications/index.browser.js.map +0 -1
- package/dist/api-notifications/index.d.ts +0 -327
- package/dist/api-notifications/index.js.map +0 -1
- package/dist/api-parameters/index.browser.js +0 -29
- package/dist/api-parameters/index.browser.js.map +0 -1
- package/dist/api-parameters/index.d.ts +0 -83
- package/dist/api-parameters/index.js +0 -63
- package/dist/api-parameters/index.js.map +0 -1
- package/dist/api-users/index.browser.js.map +0 -1
- package/dist/api-users/index.js.map +0 -1
- package/dist/api-verifications/index.browser.js.map +0 -1
- package/dist/api-verifications/index.d.ts +0 -229
- package/dist/api-verifications/index.js.map +0 -1
- package/dist/cache/index.js.map +0 -1
- package/dist/cache-redis/index.js.map +0 -1
- package/dist/cli/dist-BlfFtOk2.js +0 -2770
- package/dist/cli/dist-BlfFtOk2.js.map +0 -1
- package/dist/lock/index.js.map +0 -1
- package/dist/lock-redis/index.js.map +0 -1
- package/dist/queue/index.d.ts +0 -1265
- package/dist/queue/index.js +0 -1037
- package/dist/queue/index.js.map +0 -1
- package/dist/queue-redis/index.d.ts +0 -82
- package/dist/queue-redis/index.js +0 -872
- package/dist/queue-redis/index.js.map +0 -1
- package/dist/server/index.browser.js.map +0 -1
- package/dist/server/index.js.map +0 -1
- package/dist/server-auth/index.browser.js.map +0 -1
- package/dist/server-auth/index.js +0 -1943
- package/dist/server-auth/index.js.map +0 -1
- package/dist/server-cache/index.js.map +0 -1
- package/dist/server-compress/index.js.map +0 -1
- package/dist/server-cookies/index.browser.js.map +0 -1
- package/dist/server-cookies/index.js.map +0 -1
- package/dist/server-cors/index.js.map +0 -1
- package/dist/server-health/index.js.map +0 -1
- package/dist/server-helmet/index.js.map +0 -1
- package/dist/server-links/index.browser.js.map +0 -1
- package/dist/server-links/index.js.map +0 -1
- package/dist/server-metrics/index.js +0 -4532
- package/dist/server-metrics/index.js.map +0 -1
- package/dist/server-multipart/index.js.map +0 -1
- package/dist/server-proxy/index.js.map +0 -1
- package/dist/server-rate-limit/index.js.map +0 -1
- package/dist/server-security/index.browser.js.map +0 -1
- package/dist/server-security/index.js.map +0 -1
- package/dist/server-static/index.js.map +0 -1
- package/dist/server-swagger/index.js.map +0 -1
- package/dist/topic/index.js.map +0 -1
- package/dist/topic-redis/index.js.map +0 -1
- package/src/api-parameters/controllers/ParameterController.ts +0 -45
- package/src/api-parameters/entities/parameters.ts +0 -30
- package/src/api-parameters/index.ts +0 -21
- package/src/api-parameters/primitives/$config.ts +0 -79
- package/src/api-parameters/services/ParameterStore.ts +0 -23
- package/src/queue/interfaces/QueueJob.ts +0 -459
- package/src/queue/providers/MemoryQueueProvider.ts +0 -850
- package/src/queue/providers/QueueProvider.ts +0 -319
- package/src/queue/providers/WorkerProvider.ts +0 -344
- package/src/queue-redis/providers/RedisQueueProvider.ts +0 -1209
- /package/src/{api-files → api/files}/controllers/FileController.ts +0 -0
- /package/src/{api-files → api/files}/controllers/StorageStatsController.ts +0 -0
- /package/src/{api-files → api/files}/entities/files.ts +0 -0
- /package/src/{api-files → api/files}/index.browser.ts +0 -0
- /package/src/{api-files → api/files}/jobs/FileJobs.ts +0 -0
- /package/src/{api-files → api/files}/schemas/fileQuerySchema.ts +0 -0
- /package/src/{api-files → api/files}/schemas/fileResourceSchema.ts +0 -0
- /package/src/{api-files → api/files}/schemas/storageStatsSchema.ts +0 -0
- /package/src/{api-files → api/files}/services/FileService.ts +0 -0
- /package/src/{api-jobs → api/jobs}/controllers/JobController.ts +0 -0
- /package/src/{api-jobs → api/jobs}/entities/jobExecutions.ts +0 -0
- /package/src/{api-jobs → api/jobs}/index.browser.ts +0 -0
- /package/src/{api-jobs → api/jobs}/index.ts +0 -0
- /package/src/{api-jobs → api/jobs}/primitives/$job.ts +0 -0
- /package/src/{api-jobs → api/jobs}/providers/JobProvider.ts +0 -0
- /package/src/{api-jobs → api/jobs}/schemas/jobExecutionQuerySchema.ts +0 -0
- /package/src/{api-jobs → api/jobs}/schemas/jobExecutionResourceSchema.ts +0 -0
- /package/src/{api-jobs → api/jobs}/schemas/triggerJobSchema.ts +0 -0
- /package/src/{api-jobs → api/jobs}/services/JobService.ts +0 -0
- /package/src/{api-notifications → api/notifications}/controllers/NotificationController.ts +0 -0
- /package/src/{api-notifications → api/notifications}/entities/notifications.ts +0 -0
- /package/src/{api-notifications → api/notifications}/index.browser.ts +0 -0
- /package/src/{api-notifications → api/notifications}/index.ts +0 -0
- /package/src/{api-notifications → api/notifications}/jobs/NotificationJobs.ts +0 -0
- /package/src/{api-notifications → api/notifications}/primitives/$notification.ts +0 -0
- /package/src/{api-notifications → api/notifications}/queues/NotificationQueues.ts +0 -0
- /package/src/{api-notifications → api/notifications}/schemas/notificationContactPreferencesSchema.ts +0 -0
- /package/src/{api-notifications → api/notifications}/schemas/notificationContactSchema.ts +0 -0
- /package/src/{api-notifications → api/notifications}/schemas/notificationCreateSchema.ts +0 -0
- /package/src/{api-notifications → api/notifications}/schemas/notificationQuerySchema.ts +0 -0
- /package/src/{api-notifications → api/notifications}/services/NotificationSenderService.ts +0 -0
- /package/src/{api-notifications → api/notifications}/services/NotificationService.ts +0 -0
- /package/src/{api-parameters → api/parameters}/index.browser.ts +0 -0
- /package/src/{api-users → api/users}/controllers/IdentityController.ts +0 -0
- /package/src/{api-users → api/users}/controllers/SessionController.ts +0 -0
- /package/src/{api-users → api/users}/controllers/UserController.ts +0 -0
- /package/src/{api-users → api/users}/entities/identities.ts +0 -0
- /package/src/{api-users → api/users}/entities/sessions.ts +0 -0
- /package/src/{api-users → api/users}/entities/users.ts +0 -0
- /package/src/{api-users → api/users}/index.browser.ts +0 -0
- /package/src/{api-users → api/users}/notifications/UserNotifications.ts +0 -0
- /package/src/{api-users → api/users}/schemas/completePasswordResetRequestSchema.ts +0 -0
- /package/src/{api-users → api/users}/schemas/completeRegistrationRequestSchema.ts +0 -0
- /package/src/{api-users → api/users}/schemas/createUserSchema.ts +0 -0
- /package/src/{api-users → api/users}/schemas/identityQuerySchema.ts +0 -0
- /package/src/{api-users → api/users}/schemas/identityResourceSchema.ts +0 -0
- /package/src/{api-users → api/users}/schemas/loginSchema.ts +0 -0
- /package/src/{api-users → api/users}/schemas/passwordResetIntentResponseSchema.ts +0 -0
- /package/src/{api-users → api/users}/schemas/registerQuerySchema.ts +0 -0
- /package/src/{api-users → api/users}/schemas/registerRequestSchema.ts +0 -0
- /package/src/{api-users → api/users}/schemas/registerResponseSchema.ts +0 -0
- /package/src/{api-users → api/users}/schemas/registerSchema.ts +0 -0
- /package/src/{api-users → api/users}/schemas/registrationIntentResponseSchema.ts +0 -0
- /package/src/{api-users → api/users}/schemas/resetPasswordSchema.ts +0 -0
- /package/src/{api-users → api/users}/schemas/sessionQuerySchema.ts +0 -0
- /package/src/{api-users → api/users}/schemas/sessionResourceSchema.ts +0 -0
- /package/src/{api-users → api/users}/schemas/updateUserSchema.ts +0 -0
- /package/src/{api-users → api/users}/schemas/userQuerySchema.ts +0 -0
- /package/src/{api-users → api/users}/schemas/userRealmConfigSchema.ts +0 -0
- /package/src/{api-users → api/users}/schemas/userResourceSchema.ts +0 -0
- /package/src/{api-users → api/users}/services/CredentialService.ts +0 -0
- /package/src/{api-users → api/users}/services/IdentityService.ts +0 -0
- /package/src/{api-users → api/users}/services/SessionCrudService.ts +0 -0
- /package/src/{api-verifications → api/verifications}/controllers/VerificationController.ts +0 -0
- /package/src/{api-verifications → api/verifications}/entities/verifications.ts +0 -0
- /package/src/{api-verifications → api/verifications}/index.browser.ts +0 -0
- /package/src/{api-verifications → api/verifications}/jobs/VerificationJobs.ts +0 -0
- /package/src/{api-verifications → api/verifications}/parameters/VerificationParameters.ts +0 -0
- /package/src/{api-verifications → api/verifications}/schemas/requestVerificationCodeResponseSchema.ts +0 -0
- /package/src/{api-verifications → api/verifications}/schemas/validateVerificationCodeResponseSchema.ts +0 -0
- /package/src/{api-verifications → api/verifications}/schemas/verificationSettingsSchema.ts +0 -0
- /package/src/{api-verifications → api/verifications}/schemas/verificationTypeEnumSchema.ts +0 -0
- /package/src/{api-verifications → api/verifications}/services/VerificationService.ts +0 -0
- /package/src/cache/{errors → core/errors}/CacheError.ts +0 -0
- /package/src/cache/{index.ts → core/index.ts} +0 -0
- /package/src/cache/{primitives → core/primitives}/$cache.ts +0 -0
- /package/src/cache/{providers → core/providers}/CacheProvider.ts +0 -0
- /package/src/cache/{providers → core/providers}/MemoryCacheProvider.ts +0 -0
- /package/src/{cache-redis → cache/redis}/index.ts +0 -0
- /package/src/{cache-redis → cache/redis}/providers/RedisCacheProvider.ts +0 -0
- /package/src/lock/{index.ts → core/index.ts} +0 -0
- /package/src/lock/{primitives → core/primitives}/$lock.ts +0 -0
- /package/src/lock/{providers → core/providers}/LockProvider.ts +0 -0
- /package/src/lock/{providers → core/providers}/LockTopicProvider.ts +0 -0
- /package/src/lock/{providers → core/providers}/MemoryLockProvider.ts +0 -0
- /package/src/{lock-redis → lock/redis}/index.ts +0 -0
- /package/src/{lock-redis → lock/redis}/providers/RedisLockProvider.ts +0 -0
- /package/src/queue/{primitives → core/primitives}/$consumer.ts +0 -0
- /package/src/{queue-redis → queue/redis}/index.ts +0 -0
- /package/src/{server-auth → server/auth}/constants/routes.ts +0 -0
- /package/src/{server-auth → server/auth}/index.browser.ts +0 -0
- /package/src/{server-auth → server/auth}/index.shared.ts +0 -0
- /package/src/{server-auth → server/auth}/index.ts +0 -0
- /package/src/{server-auth → server/auth}/primitives/$authApple.ts +0 -0
- /package/src/{server-auth → server/auth}/primitives/$authCredentials.ts +0 -0
- /package/src/{server-auth → server/auth}/primitives/$authGithub.ts +0 -0
- /package/src/{server-auth → server/auth}/primitives/$authGoogle.ts +0 -0
- /package/src/{server-auth → server/auth}/schemas/authenticationProviderSchema.ts +0 -0
- /package/src/{server-auth → server/auth}/schemas/tokenResponseSchema.ts +0 -0
- /package/src/{server-auth → server/auth}/schemas/tokensSchema.ts +0 -0
- /package/src/{server-auth → server/auth}/schemas/userinfoResponseSchema.ts +0 -0
- /package/src/{server-cache → server/cache}/index.ts +0 -0
- /package/src/{server-cache → server/cache}/providers/ServerCacheProvider.ts +0 -0
- /package/src/{server-compress → server/compress}/index.ts +0 -0
- /package/src/{server-compress → server/compress}/providers/ServerCompressProvider.ts +0 -0
- /package/src/{server-cookies → server/cookies}/index.browser.ts +0 -0
- /package/src/{server-cookies → server/cookies}/primitives/$cookie.browser.ts +0 -0
- /package/src/{server-cookies → server/cookies}/primitives/$cookie.ts +0 -0
- /package/src/{server-cookies → server/cookies}/providers/ServerCookiesProvider.ts +0 -0
- /package/src/{server-cookies → server/cookies}/services/CookieParser.ts +0 -0
- /package/src/server/{constants → core/constants}/routeMethods.ts +0 -0
- /package/src/server/{errors → core/errors}/BadRequestError.ts +0 -0
- /package/src/server/{errors → core/errors}/ConflictError.ts +0 -0
- /package/src/server/{errors → core/errors}/ForbiddenError.ts +0 -0
- /package/src/server/{errors → core/errors}/HttpError.ts +0 -0
- /package/src/server/{errors → core/errors}/NotFoundError.ts +0 -0
- /package/src/server/{errors → core/errors}/UnauthorizedError.ts +0 -0
- /package/src/server/{errors → core/errors}/ValidationError.ts +0 -0
- /package/src/server/{helpers → core/helpers}/ServerReply.ts +0 -0
- /package/src/server/{helpers → core/helpers}/isMultipart.ts +0 -0
- /package/src/server/{index.browser.ts → core/index.browser.ts} +0 -0
- /package/src/server/{index.shared.ts → core/index.shared.ts} +0 -0
- /package/src/server/{interfaces → core/interfaces}/ServerRequest.ts +0 -0
- /package/src/server/{primitives → core/primitives}/$route.ts +0 -0
- /package/src/server/{providers → core/providers}/BunHttpServerProvider.ts +0 -0
- /package/src/server/{providers → core/providers}/NodeHttpServerProvider.ts +0 -0
- /package/src/server/{providers → core/providers}/ServerLoggerProvider.ts +0 -0
- /package/src/server/{providers → core/providers}/ServerNotReadyProvider.ts +0 -0
- /package/src/server/{providers → core/providers}/ServerProvider.ts +0 -0
- /package/src/server/{providers → core/providers}/ServerTimingProvider.ts +0 -0
- /package/src/server/{schemas → core/schemas}/errorSchema.ts +0 -0
- /package/src/server/{schemas → core/schemas}/okSchema.ts +0 -0
- /package/src/server/{services → core/services}/HttpClient.ts +0 -0
- /package/src/server/{services → core/services}/ServerRequestParser.ts +0 -0
- /package/src/server/{services → core/services}/UserAgentParser.ts +0 -0
- /package/src/{server-cors → server/cors}/index.ts +0 -0
- /package/src/{server-cors → server/cors}/primitives/$cors.ts +0 -0
- /package/src/{server-cors → server/cors}/providers/ServerCorsProvider.ts +0 -0
- /package/src/{server-health → server/health}/index.ts +0 -0
- /package/src/{server-health → server/health}/providers/ServerHealthProvider.ts +0 -0
- /package/src/{server-health → server/health}/schemas/healthSchema.ts +0 -0
- /package/src/{server-helmet → server/helmet}/index.ts +0 -0
- /package/src/{server-helmet → server/helmet}/providers/ServerHelmetProvider.ts +0 -0
- /package/src/{server-links → server/links}/index.browser.ts +0 -0
- /package/src/{server-links → server/links}/index.ts +0 -0
- /package/src/{server-links → server/links}/primitives/$client.ts +0 -0
- /package/src/{server-links → server/links}/primitives/$remote.ts +0 -0
- /package/src/{server-links → server/links}/providers/LinkProvider.ts +0 -0
- /package/src/{server-links → server/links}/providers/RemotePrimitiveProvider.ts +0 -0
- /package/src/{server-links → server/links}/providers/ServerLinksProvider.ts +0 -0
- /package/src/{server-links → server/links}/schemas/apiLinksResponseSchema.ts +0 -0
- /package/src/{server-metrics → server/metrics}/index.ts +0 -0
- /package/src/{server-metrics → server/metrics}/providers/ServerMetricsProvider.ts +0 -0
- /package/src/{server-multipart → server/multipart}/index.ts +0 -0
- /package/src/{server-multipart → server/multipart}/providers/ServerMultipartProvider.ts +0 -0
- /package/src/{server-proxy → server/proxy}/index.ts +0 -0
- /package/src/{server-proxy → server/proxy}/primitives/$proxy.ts +0 -0
- /package/src/{server-proxy → server/proxy}/providers/ServerProxyProvider.ts +0 -0
- /package/src/{server-rate-limit → server/rate-limit}/primitives/$rateLimit.ts +0 -0
- /package/src/{server-rate-limit → server/rate-limit}/providers/ServerRateLimitProvider.ts +0 -0
- /package/src/{server-security → server/security}/index.browser.ts +0 -0
- /package/src/{server-security → server/security}/index.ts +0 -0
- /package/src/{server-security → server/security}/primitives/$basicAuth.ts +0 -0
- /package/src/{server-security → server/security}/providers/ServerBasicAuthProvider.ts +0 -0
- /package/src/{server-security → server/security}/providers/ServerSecurityProvider.ts +0 -0
- /package/src/{server-static → server/static}/index.ts +0 -0
- /package/src/{server-static → server/static}/primitives/$serve.ts +0 -0
- /package/src/{server-static → server/static}/providers/ServerStaticProvider.ts +0 -0
- /package/src/{server-swagger → server/swagger}/index.ts +0 -0
- /package/src/{server-swagger → server/swagger}/primitives/$swagger.ts +0 -0
- /package/src/topic/{errors → core/errors}/TopicTimeoutError.ts +0 -0
- /package/src/topic/{index.ts → core/index.ts} +0 -0
- /package/src/topic/{primitives → core/primitives}/$subscriber.ts +0 -0
- /package/src/topic/{primitives → core/primitives}/$topic.ts +0 -0
- /package/src/topic/{providers → core/providers}/MemoryTopicProvider.ts +0 -0
- /package/src/topic/{providers → core/providers}/TopicProvider.ts +0 -0
- /package/src/{topic-redis → topic/redis}/index.ts +0 -0
- /package/src/{topic-redis → topic/redis}/providers/RedisTopicProvider.ts +0 -0
|
@@ -1,12 +1,15 @@
|
|
|
1
1
|
import { $module } from "alepha";
|
|
2
2
|
import { VerificationController } from "./controllers/VerificationController.ts";
|
|
3
3
|
import { VerificationJobs } from "./jobs/VerificationJobs.ts";
|
|
4
|
+
import { VerificationParameters } from "./parameters/VerificationParameters.ts";
|
|
4
5
|
import { VerificationService } from "./services/VerificationService.ts";
|
|
5
6
|
|
|
6
7
|
// ---------------------------------------------------------------------------------------------------------------------
|
|
7
8
|
|
|
8
9
|
export * from "./controllers/VerificationController.ts";
|
|
9
10
|
export * from "./entities/verifications.ts";
|
|
11
|
+
export * from "./jobs/VerificationJobs.ts";
|
|
12
|
+
export * from "./parameters/VerificationParameters.ts";
|
|
10
13
|
export * from "./schemas/requestVerificationCodeResponseSchema.ts";
|
|
11
14
|
export * from "./schemas/validateVerificationCodeResponseSchema.ts";
|
|
12
15
|
export * from "./schemas/verificationTypeEnumSchema.ts";
|
|
@@ -25,5 +28,10 @@ export * from "./services/VerificationService.ts";
|
|
|
25
28
|
*/
|
|
26
29
|
export const AlephaApiVerification = $module({
|
|
27
30
|
name: "alepha.api.verifications",
|
|
28
|
-
services: [
|
|
31
|
+
services: [
|
|
32
|
+
VerificationController,
|
|
33
|
+
VerificationJobs,
|
|
34
|
+
VerificationService,
|
|
35
|
+
VerificationParameters,
|
|
36
|
+
],
|
|
29
37
|
});
|
package/src/bin/index.ts
CHANGED
|
@@ -37,8 +37,10 @@ export class AlephaPackageBuilderCli {
|
|
|
37
37
|
pkgData.exports = {};
|
|
38
38
|
|
|
39
39
|
for (const item of modules) {
|
|
40
|
-
|
|
41
|
-
|
|
40
|
+
let m = `./${item.name.replace("core", "")}`;
|
|
41
|
+
if (m.endsWith("/")) m = m.slice(0, -1);
|
|
42
|
+
const path = m;
|
|
43
|
+
|
|
42
44
|
pkgData.exports[path] = {};
|
|
43
45
|
// order is important here for compatibility
|
|
44
46
|
pkgData.exports[path].types = `./src/${item.name}/index.ts`;
|
|
@@ -81,7 +83,8 @@ export class AlephaPackageBuilderCli {
|
|
|
81
83
|
"alepha",
|
|
82
84
|
packageName,
|
|
83
85
|
...modules.map(
|
|
84
|
-
(item) =>
|
|
86
|
+
(item) =>
|
|
87
|
+
`${packageName}/${item.name.replace("-", "/").replace("/core", "")}`,
|
|
85
88
|
),
|
|
86
89
|
];
|
|
87
90
|
|
|
@@ -124,13 +127,16 @@ export class AlephaPackageBuilderCli {
|
|
|
124
127
|
});
|
|
125
128
|
}
|
|
126
129
|
|
|
127
|
-
const config = join(
|
|
130
|
+
const config = join(
|
|
131
|
+
tmpDir,
|
|
132
|
+
`tsdown-${item.name.replace("/", "-")}.config.js`,
|
|
133
|
+
);
|
|
128
134
|
await this.fs.writeFile(
|
|
129
135
|
config,
|
|
130
136
|
`export default ${JSON.stringify(entries, null, 2)};`,
|
|
131
137
|
);
|
|
132
138
|
await run(`npx tsdown -c=${config}`);
|
|
133
|
-
await this.fs.rm(config);
|
|
139
|
+
//await this.fs.rm(config);
|
|
134
140
|
};
|
|
135
141
|
|
|
136
142
|
const concurrency = Math.ceil(os.cpus().length / 2);
|
|
@@ -257,57 +263,76 @@ export async function analyzeModules(
|
|
|
257
263
|
packageName: string,
|
|
258
264
|
): Promise<Module[]> {
|
|
259
265
|
const modules: Module[] = [];
|
|
260
|
-
|
|
261
|
-
|
|
262
|
-
|
|
263
|
-
|
|
264
|
-
|
|
265
|
-
|
|
266
|
-
|
|
267
|
-
|
|
268
|
-
|
|
269
|
-
|
|
270
|
-
|
|
271
|
-
|
|
272
|
-
|
|
273
|
-
|
|
274
|
-
|
|
275
|
-
|
|
276
|
-
|
|
277
|
-
|
|
278
|
-
|
|
279
|
-
|
|
280
|
-
|
|
281
|
-
|
|
282
|
-
|
|
283
|
-
|
|
284
|
-
|
|
285
|
-
|
|
286
|
-
|
|
287
|
-
|
|
288
|
-
|
|
289
|
-
|
|
290
|
-
|
|
291
|
-
|
|
266
|
+
|
|
267
|
+
async function scanDirectory(dir: string, prefix: string): Promise<void> {
|
|
268
|
+
const entries = await readdir(dir, { withFileTypes: true });
|
|
269
|
+
|
|
270
|
+
for (const entry of entries) {
|
|
271
|
+
if (entry.isDirectory()) {
|
|
272
|
+
const moduleName = prefix ? `${prefix}/${entry.name}` : entry.name;
|
|
273
|
+
const modulePath = join(dir, entry.name);
|
|
274
|
+
|
|
275
|
+
// Check if this directory has an index.ts (is a module)
|
|
276
|
+
const hasIndex = await fileExists(join(modulePath, "index.ts"));
|
|
277
|
+
|
|
278
|
+
if (hasIndex) {
|
|
279
|
+
// This is a module
|
|
280
|
+
const dependencies = new Set<string>();
|
|
281
|
+
|
|
282
|
+
// Check for browser/node entry points
|
|
283
|
+
const hasBrowser = await fileExists(
|
|
284
|
+
join(modulePath, "index.browser.ts"),
|
|
285
|
+
);
|
|
286
|
+
const hasNative = await fileExists(
|
|
287
|
+
join(modulePath, "index.native.ts"),
|
|
288
|
+
);
|
|
289
|
+
const hasNode = await fileExists(join(modulePath, "index.node.ts"));
|
|
290
|
+
|
|
291
|
+
// Get all .ts/.tsx files in this module
|
|
292
|
+
const files = await getAllFiles(modulePath);
|
|
293
|
+
|
|
294
|
+
for (const file of files) {
|
|
295
|
+
const content = await readFile(file, "utf-8");
|
|
296
|
+
const deps = extractAlephaDependencies(
|
|
297
|
+
content,
|
|
298
|
+
packageName,
|
|
299
|
+
moduleName,
|
|
292
300
|
);
|
|
301
|
+
for (const dep of deps) {
|
|
302
|
+
if (dep.endsWith(".ts")) {
|
|
303
|
+
throw new Error(
|
|
304
|
+
`Invalid dependency '${dep}' in module '${moduleName}'. Do not include file extensions in Alepha module imports.`,
|
|
305
|
+
);
|
|
306
|
+
}
|
|
307
|
+
if (dep.includes("-")) {
|
|
308
|
+
throw new Error(
|
|
309
|
+
`Invalid dependency '${dep}' in module '${moduleName}'. Use '/' instead of '-' in Alepha module imports.`,
|
|
310
|
+
);
|
|
311
|
+
}
|
|
312
|
+
dependencies.add(dep);
|
|
313
|
+
}
|
|
293
314
|
}
|
|
294
|
-
dependencies.add(dep);
|
|
295
|
-
}
|
|
296
|
-
}
|
|
297
315
|
|
|
298
|
-
|
|
299
|
-
|
|
300
|
-
|
|
301
|
-
|
|
316
|
+
const module: Module = {
|
|
317
|
+
name: moduleName,
|
|
318
|
+
dependencies: Array.from(dependencies),
|
|
319
|
+
};
|
|
302
320
|
|
|
303
|
-
|
|
304
|
-
|
|
305
|
-
|
|
321
|
+
if (hasNative) module.native = true;
|
|
322
|
+
if (hasBrowser) module.browser = true;
|
|
323
|
+
if (hasNode) module.node = true;
|
|
306
324
|
|
|
307
|
-
|
|
325
|
+
modules.push(module);
|
|
326
|
+
} else {
|
|
327
|
+
// No index.ts, check subdirectories for modules
|
|
328
|
+
await scanDirectory(modulePath, moduleName);
|
|
329
|
+
}
|
|
330
|
+
}
|
|
308
331
|
}
|
|
309
332
|
}
|
|
310
333
|
|
|
334
|
+
await scanDirectory(srcDir, "");
|
|
335
|
+
|
|
311
336
|
// Check for circular dependencies
|
|
312
337
|
detectCircularDependencies(modules);
|
|
313
338
|
|
|
@@ -11,7 +11,7 @@ export const biomeJson = `
|
|
|
11
11
|
},
|
|
12
12
|
"formatter": {
|
|
13
13
|
"enabled": true,
|
|
14
|
-
"
|
|
14
|
+
"useEditorconfig": true
|
|
15
15
|
},
|
|
16
16
|
"linter": {
|
|
17
17
|
"enabled": true,
|
|
@@ -30,4 +30,4 @@ export const biomeJson = `
|
|
|
30
30
|
}
|
|
31
31
|
}
|
|
32
32
|
}
|
|
33
|
-
`.trim()
|
|
33
|
+
`.trim();
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
export const mainTs = () => `
|
|
2
|
+
import { Alepha, run } from "alepha";
|
|
3
|
+
import { $logger } from "alepha/logger";
|
|
4
|
+
|
|
5
|
+
const alepha = Alepha.create();
|
|
6
|
+
|
|
7
|
+
alepha.with(() => {
|
|
8
|
+
const log = $logger();
|
|
9
|
+
|
|
10
|
+
log.info("Hello from Alepha!");
|
|
11
|
+
});
|
|
12
|
+
|
|
13
|
+
run(alepha);
|
|
14
|
+
`.trim();
|
|
@@ -12,6 +12,7 @@ export class BiomeCommands {
|
|
|
12
12
|
description: "Format the codebase using Biome",
|
|
13
13
|
handler: async ({ root }) => {
|
|
14
14
|
await this.utils.ensureConfig(root, { biomeJson: true });
|
|
15
|
+
await this.utils.ensureDependency(root, "@biomejs/biome");
|
|
15
16
|
await this.utils.exec(`biome format --fix`);
|
|
16
17
|
},
|
|
17
18
|
});
|
|
@@ -21,6 +22,7 @@ export class BiomeCommands {
|
|
|
21
22
|
description: "Run linter across the codebase using Biome",
|
|
22
23
|
handler: async ({ root }) => {
|
|
23
24
|
await this.utils.ensureConfig(root, { biomeJson: true });
|
|
25
|
+
await this.utils.ensureDependency(root, "@biomejs/biome");
|
|
24
26
|
await this.utils.exec(`biome check --formatter-enabled=false --fix`);
|
|
25
27
|
},
|
|
26
28
|
});
|
|
@@ -51,13 +51,11 @@ export class CoreCommands {
|
|
|
51
51
|
name: "init",
|
|
52
52
|
description: "Add missing Alepha configuration files to the project",
|
|
53
53
|
flags: t.object({
|
|
54
|
-
// TODO:
|
|
55
|
-
// force: t.boolean({
|
|
56
|
-
// description: "If true, all config files will be overwritten",
|
|
57
|
-
// }),
|
|
58
54
|
// choose package manager
|
|
59
55
|
yarn: t.optional(t.boolean({ description: "Use Yarn package manager" })),
|
|
60
56
|
pnpm: t.optional(t.boolean({ description: "Use pnpm package manager" })),
|
|
57
|
+
npm: t.optional(t.boolean({ description: "Use npm package manager" })),
|
|
58
|
+
bun: t.optional(t.boolean({ description: "Use Bun package manager" })),
|
|
61
59
|
// choose which dependencies to add
|
|
62
60
|
react: t.optional(
|
|
63
61
|
t.boolean({ description: "Include Alepha React dependencies" }),
|
|
@@ -65,38 +63,63 @@ export class CoreCommands {
|
|
|
65
63
|
ui: t.optional(
|
|
66
64
|
t.boolean({ description: "Include Alepha UI dependencies" }),
|
|
67
65
|
),
|
|
66
|
+
test: t.optional(
|
|
67
|
+
t.boolean({ description: "Include Vitest and create test directory" }),
|
|
68
|
+
),
|
|
68
69
|
}),
|
|
69
70
|
handler: async ({ run, flags, root }) => {
|
|
70
71
|
if (flags.ui) {
|
|
71
72
|
flags.react = true;
|
|
72
73
|
}
|
|
73
74
|
|
|
75
|
+
const isExpo = await this.utils.hasExpo(root);
|
|
76
|
+
|
|
74
77
|
await run({
|
|
75
|
-
name: "
|
|
78
|
+
name: "ensuring configuration files",
|
|
76
79
|
handler: async () => {
|
|
77
80
|
await this.utils.ensureConfig(root, {
|
|
78
81
|
tsconfigJson: true,
|
|
79
82
|
packageJson: flags,
|
|
80
83
|
biomeJson: true,
|
|
81
|
-
viteConfigTs:
|
|
82
|
-
|
|
84
|
+
viteConfigTs: !isExpo,
|
|
85
|
+
editorconfig: true,
|
|
86
|
+
indexHtml: !!flags.react && !isExpo,
|
|
83
87
|
});
|
|
88
|
+
|
|
89
|
+
// Create src/main.ts if src directory is empty or doesn't exist
|
|
90
|
+
if (!flags.react) {
|
|
91
|
+
await this.utils.ensureSrcMain(root);
|
|
92
|
+
}
|
|
84
93
|
},
|
|
85
94
|
});
|
|
86
95
|
|
|
87
96
|
// TODO: check if all alepha dependencies are same version
|
|
88
97
|
|
|
89
|
-
const
|
|
90
|
-
|
|
91
|
-
if (flags.yarn || guessedPm === "yarn") {
|
|
98
|
+
const pm = await this.utils.getPackageManager(root, flags);
|
|
99
|
+
if (pm === "yarn") {
|
|
92
100
|
await this.utils.ensureYarn(root);
|
|
93
101
|
await run("yarn set version stable");
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
});
|
|
102
|
+
} else if (pm === "pnpm") {
|
|
103
|
+
await this.utils.ensurePnpm(root);
|
|
97
104
|
} else {
|
|
98
|
-
await
|
|
99
|
-
|
|
105
|
+
await this.utils.ensureNpm(root);
|
|
106
|
+
}
|
|
107
|
+
|
|
108
|
+
await run(`${pm} install`, {
|
|
109
|
+
alias: `installing dependencies with ${pm}`,
|
|
110
|
+
});
|
|
111
|
+
|
|
112
|
+
if (!isExpo) {
|
|
113
|
+
await this.utils.ensureDependency(root, "vite", { run });
|
|
114
|
+
}
|
|
115
|
+
|
|
116
|
+
await this.utils.ensureDependency(root, "@biomejs/biome", { run });
|
|
117
|
+
|
|
118
|
+
// Install vitest and create test directory if --test flag is set
|
|
119
|
+
if (flags.test) {
|
|
120
|
+
await this.utils.ensureTestDir(root);
|
|
121
|
+
await run(`${pm} ${pm === "yarn" ? "add" : "install"} -D vitest`, {
|
|
122
|
+
alias: "setup testing with Vitest",
|
|
100
123
|
});
|
|
101
124
|
}
|
|
102
125
|
},
|
|
@@ -37,7 +37,10 @@ export class VerifyCommands {
|
|
|
37
37
|
await run("alepha db:check-migrations");
|
|
38
38
|
}
|
|
39
39
|
|
|
40
|
-
await
|
|
40
|
+
const isExpo = await this.utils.hasExpo(root);
|
|
41
|
+
if (!isExpo) {
|
|
42
|
+
await run("alepha build");
|
|
43
|
+
}
|
|
41
44
|
await run("alepha clean");
|
|
42
45
|
},
|
|
43
46
|
});
|
|
@@ -48,7 +51,8 @@ export class VerifyCommands {
|
|
|
48
51
|
public readonly typecheck = $command({
|
|
49
52
|
name: "typecheck",
|
|
50
53
|
description: "Check TypeScript types across the codebase",
|
|
51
|
-
handler: async () => {
|
|
54
|
+
handler: async ({ root }) => {
|
|
55
|
+
await this.utils.ensureDependency(root, "typescript");
|
|
52
56
|
await this.utils.exec("tsc --noEmit");
|
|
53
57
|
},
|
|
54
58
|
});
|
|
@@ -29,6 +29,7 @@ export class ViteCommands {
|
|
|
29
29
|
|
|
30
30
|
public readonly run = $command({
|
|
31
31
|
name: "run",
|
|
32
|
+
hide: true,
|
|
32
33
|
description: "Run a TypeScript file directly",
|
|
33
34
|
flags: t.object({
|
|
34
35
|
watch: t.optional(
|
|
@@ -54,11 +55,18 @@ export class ViteCommands {
|
|
|
54
55
|
description: "Run the project in development mode",
|
|
55
56
|
args: t.optional(t.text({ title: "path", description: "Filepath to run" })),
|
|
56
57
|
handler: async ({ args, root }) => {
|
|
58
|
+
const expo = await this.utils.hasExpo(root);
|
|
59
|
+
|
|
57
60
|
await this.utils.ensureConfig(root, {
|
|
58
|
-
viteConfigTs:
|
|
61
|
+
viteConfigTs: !expo,
|
|
59
62
|
tsconfigJson: true,
|
|
60
63
|
});
|
|
61
64
|
|
|
65
|
+
if (expo) {
|
|
66
|
+
await this.utils.exec(`expo start`);
|
|
67
|
+
return;
|
|
68
|
+
}
|
|
69
|
+
|
|
62
70
|
const entry = await boot.getServerEntry(root, args);
|
|
63
71
|
this.log.trace("Entry file found", { entry });
|
|
64
72
|
|
|
@@ -75,6 +83,8 @@ export class ViteCommands {
|
|
|
75
83
|
return;
|
|
76
84
|
}
|
|
77
85
|
|
|
86
|
+
// Ensure vite is installed before running
|
|
87
|
+
await this.utils.ensureDependency(root, "vite");
|
|
78
88
|
await this.utils.exec(`vite`);
|
|
79
89
|
},
|
|
80
90
|
});
|
|
@@ -121,6 +131,12 @@ export class ViteCommands {
|
|
|
121
131
|
// Tell viteAlephaBuild plugin to skip - CLI handles all tasks
|
|
122
132
|
process.env.ALEPHA_BUILD_MODE = "cli";
|
|
123
133
|
|
|
134
|
+
if (await this.utils.hasExpo(root)) {
|
|
135
|
+
// will coming soon
|
|
136
|
+
// 1. ensure "expo prebuild" is run
|
|
137
|
+
return;
|
|
138
|
+
}
|
|
139
|
+
|
|
124
140
|
await this.utils.ensureConfig(root, {
|
|
125
141
|
viteConfigTs: true,
|
|
126
142
|
tsconfigJson: true,
|
|
@@ -132,6 +148,10 @@ export class ViteCommands {
|
|
|
132
148
|
const distDir = "dist";
|
|
133
149
|
const clientDir = "public";
|
|
134
150
|
|
|
151
|
+
await this.utils.ensureDependency(root, "vite", {
|
|
152
|
+
run,
|
|
153
|
+
});
|
|
154
|
+
|
|
135
155
|
await run.rm("dist", {
|
|
136
156
|
alias: "clean dist",
|
|
137
157
|
});
|
|
@@ -195,14 +215,11 @@ export class ViteCommands {
|
|
|
195
215
|
});
|
|
196
216
|
|
|
197
217
|
// Copy assets
|
|
198
|
-
|
|
199
|
-
|
|
200
|
-
|
|
201
|
-
|
|
202
|
-
|
|
203
|
-
entry: `${distDir}/index.js`,
|
|
204
|
-
distDir,
|
|
205
|
-
}),
|
|
218
|
+
await copyAssets({
|
|
219
|
+
root,
|
|
220
|
+
entry: `${distDir}/index.js`,
|
|
221
|
+
distDir,
|
|
222
|
+
run,
|
|
206
223
|
});
|
|
207
224
|
|
|
208
225
|
if (hasClient) {
|
|
@@ -301,15 +318,8 @@ export class ViteCommands {
|
|
|
301
318
|
viteConfigTs: true,
|
|
302
319
|
});
|
|
303
320
|
|
|
304
|
-
//
|
|
305
|
-
|
|
306
|
-
await import("vitest");
|
|
307
|
-
} catch {
|
|
308
|
-
this.log.error(
|
|
309
|
-
"Vitest is not installed. Please install it with `npm install -D vitest` or `yarn add -D vitest`.",
|
|
310
|
-
);
|
|
311
|
-
process.exit(1);
|
|
312
|
-
}
|
|
321
|
+
// Ensure vitest is installed before running
|
|
322
|
+
await this.utils.ensureDependency(root, "vitest");
|
|
313
323
|
|
|
314
324
|
await this.utils.exec(`vitest run ${this.env.VITEST_ARGS}`);
|
|
315
325
|
},
|