alepha 0.19.0 → 0.19.2
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/LICENSE +1 -1
- package/README.md +6 -9
- package/dist/api/audits/index.d.ts +378 -346
- package/dist/api/audits/index.d.ts.map +1 -1
- package/dist/api/files/index.d.ts +216 -184
- package/dist/api/files/index.d.ts.map +1 -1
- package/dist/api/files/index.js +5 -1
- package/dist/api/files/index.js.map +1 -1
- package/dist/api/jobs/index.d.ts +528 -496
- package/dist/api/jobs/index.d.ts.map +1 -1
- package/dist/api/jobs/index.js +3 -3
- package/dist/api/jobs/index.js.map +1 -1
- package/dist/api/keys/index.d.ts +202 -202
- package/dist/api/keys/index.d.ts.map +1 -1
- package/dist/api/notifications/index.d.ts +152 -152
- package/dist/api/notifications/index.d.ts.map +1 -1
- package/dist/api/organizations/index.browser.js +48 -0
- package/dist/api/organizations/index.browser.js.map +1 -0
- package/dist/api/organizations/index.d.ts +516 -0
- package/dist/api/organizations/index.d.ts.map +1 -0
- package/dist/api/organizations/index.js +202 -0
- package/dist/api/organizations/index.js.map +1 -0
- package/dist/api/parameters/index.d.ts +391 -358
- package/dist/api/parameters/index.d.ts.map +1 -1
- package/dist/api/parameters/index.js +5 -1
- package/dist/api/parameters/index.js.map +1 -1
- package/dist/api/users/index.browser.js +7 -5
- package/dist/api/users/index.browser.js.map +1 -1
- package/dist/api/users/index.d.ts +989 -931
- package/dist/api/users/index.d.ts.map +1 -1
- package/dist/api/users/index.js +292 -146
- package/dist/api/users/index.js.map +1 -1
- package/dist/api/verifications/index.d.ts +132 -132
- package/dist/api/verifications/index.d.ts.map +1 -1
- package/dist/api/verifications/index.js +2 -2
- package/dist/api/verifications/index.js.map +1 -1
- package/dist/batch/index.d.ts +6 -6
- package/dist/batch/index.d.ts.map +1 -1
- package/dist/billing/index.d.ts +1048 -0
- package/dist/billing/index.d.ts.map +1 -0
- package/dist/billing/index.js +713 -0
- package/dist/billing/index.js.map +1 -0
- package/dist/bin/index.js +0 -2
- package/dist/bin/index.js.map +1 -1
- package/dist/bucket/index.d.ts +10 -10
- package/dist/bucket/index.d.ts.map +1 -1
- package/dist/bucket/index.js +2 -2
- package/dist/bucket/index.js.map +1 -1
- package/dist/cache/core/index.d.ts +9 -9
- package/dist/cache/core/index.d.ts.map +1 -1
- package/dist/cache/core/index.js +2 -2
- package/dist/cache/core/index.js.map +1 -1
- package/dist/cache/core/index.workerd.js +2 -2
- package/dist/cache/core/index.workerd.js.map +1 -1
- package/dist/cache/redis/index.d.ts +6 -6
- package/dist/cache/redis/index.d.ts.map +1 -1
- package/dist/cache/redis/index.js +2 -2
- package/dist/cache/redis/index.js.map +1 -1
- package/dist/cli/config/index.d.ts +12 -2
- package/dist/cli/config/index.d.ts.map +1 -1
- package/dist/cli/config/index.js +4 -0
- package/dist/cli/config/index.js.map +1 -1
- package/dist/cli/core/index.d.ts +183 -139
- package/dist/cli/core/index.d.ts.map +1 -1
- package/dist/cli/core/index.js +283 -86
- package/dist/cli/core/index.js.map +1 -1
- package/dist/cli/devtools/index.d.ts +45 -0
- package/dist/cli/devtools/index.d.ts.map +1 -0
- package/dist/cli/devtools/index.js +170 -0
- package/dist/cli/devtools/index.js.map +1 -0
- package/dist/cli/platform/index.d.ts +383 -492
- package/dist/cli/platform/index.d.ts.map +1 -1
- package/dist/cli/platform/index.js +42 -511
- package/dist/cli/platform/index.js.map +1 -1
- package/dist/cli/vendor/index.d.ts +196 -0
- package/dist/cli/vendor/index.d.ts.map +1 -0
- package/dist/cli/vendor/index.js +384 -0
- package/dist/cli/vendor/index.js.map +1 -0
- package/dist/command/index.d.ts +18 -18
- package/dist/command/index.d.ts.map +1 -1
- package/dist/command/index.js +2 -2
- package/dist/command/index.js.map +1 -1
- package/dist/core/index.browser.js +4 -4
- package/dist/core/index.browser.js.map +1 -1
- package/dist/core/index.d.ts +10 -10
- package/dist/core/index.d.ts.map +1 -1
- package/dist/core/index.js +4 -4
- package/dist/core/index.js.map +1 -1
- package/dist/core/index.native.js +4 -4
- package/dist/core/index.native.js.map +1 -1
- package/dist/core/index.workerd.js +4 -4
- package/dist/core/index.workerd.js.map +1 -1
- package/dist/crypto/index.d.ts +7 -7
- package/dist/crypto/index.d.ts.map +1 -1
- package/dist/datetime/index.d.ts +4 -4
- package/dist/datetime/index.d.ts.map +1 -1
- package/dist/email/brevo/index.d.ts +4 -4
- package/dist/email/brevo/index.d.ts.map +1 -1
- package/dist/email/core/index.d.ts +15 -11
- package/dist/email/core/index.d.ts.map +1 -1
- package/dist/email/core/index.js +12 -35
- package/dist/email/core/index.js.map +1 -1
- package/dist/email/smtp/index.d.ts +12 -12
- package/dist/email/smtp/index.d.ts.map +1 -1
- package/dist/email/smtp/index.js +7 -4
- package/dist/email/smtp/index.js.map +1 -1
- package/dist/fake/index.d.ts +4 -8
- package/dist/fake/index.d.ts.map +1 -1
- package/dist/fake/index.js +55 -889
- package/dist/fake/index.js.map +1 -1
- package/dist/lock/core/index.d.ts +13 -13
- package/dist/lock/core/index.d.ts.map +1 -1
- package/dist/lock/core/index.js +2 -2
- package/dist/lock/core/index.js.map +1 -1
- package/dist/lock/redis/index.d.ts +4 -4
- package/dist/lock/redis/index.d.ts.map +1 -1
- package/dist/logger/index.d.ts +16 -15
- package/dist/logger/index.d.ts.map +1 -1
- package/dist/logger/index.js +5 -2
- package/dist/logger/index.js.map +1 -1
- package/dist/mcp/index.d.ts +11 -11
- package/dist/mcp/index.d.ts.map +1 -1
- package/dist/mcp/index.js +2 -2
- package/dist/mcp/index.js.map +1 -1
- package/dist/orm/core/index.browser.js +11 -1
- package/dist/orm/core/index.browser.js.map +1 -1
- package/dist/orm/core/index.bun.js +53 -16
- package/dist/orm/core/index.bun.js.map +1 -1
- package/dist/orm/core/index.d.ts +95 -51
- package/dist/orm/core/index.d.ts.map +1 -1
- package/dist/orm/core/index.js +55 -14
- package/dist/orm/core/index.js.map +1 -1
- package/dist/orm/postgres/index.bun.js +17 -11
- package/dist/orm/postgres/index.bun.js.map +1 -1
- package/dist/orm/postgres/index.d.ts +21 -15
- package/dist/orm/postgres/index.d.ts.map +1 -1
- package/dist/orm/postgres/index.js +19 -13
- package/dist/orm/postgres/index.js.map +1 -1
- package/dist/queue/core/index.d.ts +14 -14
- package/dist/queue/core/index.d.ts.map +1 -1
- package/dist/queue/core/index.js +2 -2
- package/dist/queue/core/index.js.map +1 -1
- package/dist/queue/core/index.workerd.js +2 -2
- package/dist/queue/core/index.workerd.js.map +1 -1
- package/dist/queue/redis/index.d.ts +4 -4
- package/dist/queue/redis/index.d.ts.map +1 -1
- package/dist/queue/redis/index.js +2 -2
- package/dist/queue/redis/index.js.map +1 -1
- package/dist/react/auth/index.d.ts +9 -9
- package/dist/react/auth/index.d.ts.map +1 -1
- package/dist/react/core/index.d.ts +6 -6
- package/dist/react/core/index.d.ts.map +1 -1
- package/dist/react/core/index.js +5 -4
- package/dist/react/core/index.js.map +1 -1
- package/dist/react/form/index.d.ts +4 -4
- package/dist/react/form/index.d.ts.map +1 -1
- package/dist/react/head/index.d.ts +4 -4
- package/dist/react/head/index.d.ts.map +1 -1
- package/dist/react/i18n/index.d.ts +9 -9
- package/dist/react/i18n/index.d.ts.map +1 -1
- package/dist/react/intro/index.d.ts +2 -2
- package/dist/react/intro/index.d.ts.map +1 -1
- package/dist/react/intro/index.js +3 -4
- package/dist/react/intro/index.js.map +1 -1
- package/dist/react/router/index.browser.js +4 -5
- package/dist/react/router/index.browser.js.map +1 -1
- package/dist/react/router/index.d.ts +215 -215
- package/dist/react/router/index.d.ts.map +1 -1
- package/dist/react/router/index.js +6 -7
- package/dist/react/router/index.js.map +1 -1
- package/dist/react/testing/index.d.ts +2 -2
- package/dist/react/testing/index.d.ts.map +1 -1
- package/dist/react/testing/index.js +2 -4
- package/dist/react/testing/index.js.map +1 -1
- package/dist/redis/index.d.ts +19 -19
- package/dist/redis/index.d.ts.map +1 -1
- package/dist/retry/index.d.ts +4 -4
- package/dist/retry/index.d.ts.map +1 -1
- package/dist/scheduler/index.d.ts +13 -13
- package/dist/scheduler/index.d.ts.map +1 -1
- package/dist/scheduler/index.js +2 -2
- package/dist/scheduler/index.js.map +1 -1
- package/dist/scheduler/index.workerd.js +2 -2
- package/dist/scheduler/index.workerd.js.map +1 -1
- package/dist/security/index.browser.js +1 -1
- package/dist/security/index.browser.js.map +1 -1
- package/dist/security/index.d.ts +47 -47
- package/dist/security/index.d.ts.map +1 -1
- package/dist/security/index.js +9 -12
- package/dist/security/index.js.map +1 -1
- package/dist/server/auth/index.d.ts +170 -169
- package/dist/server/auth/index.d.ts.map +1 -1
- package/dist/server/auth/index.js +16 -2
- package/dist/server/auth/index.js.map +1 -1
- package/dist/server/cookies/index.d.ts +7 -7
- package/dist/server/cookies/index.d.ts.map +1 -1
- package/dist/server/core/index.d.ts +76 -76
- package/dist/server/core/index.d.ts.map +1 -1
- package/dist/server/core/index.js +23 -17
- package/dist/server/core/index.js.map +1 -1
- package/dist/server/cors/index.d.ts +13 -13
- package/dist/server/cors/index.d.ts.map +1 -1
- package/dist/server/cors/index.js +2 -2
- package/dist/server/cors/index.js.map +1 -1
- package/dist/server/etag/index.d.ts +9 -9
- package/dist/server/etag/index.d.ts.map +1 -1
- package/dist/server/health/index.d.ts +20 -20
- package/dist/server/health/index.d.ts.map +1 -1
- package/dist/server/links/index.browser.js +2 -2
- package/dist/server/links/index.browser.js.map +1 -1
- package/dist/server/links/index.d.ts +66 -66
- package/dist/server/links/index.d.ts.map +1 -1
- package/dist/server/links/index.js +4 -4
- package/dist/server/links/index.js.map +1 -1
- package/dist/server/metrics/index.d.ts +7 -7
- package/dist/server/metrics/index.d.ts.map +1 -1
- package/dist/server/proxy/index.d.ts +5 -5
- package/dist/server/proxy/index.d.ts.map +1 -1
- package/dist/server/rate-limit/index.d.ts +12 -12
- package/dist/server/rate-limit/index.d.ts.map +1 -1
- package/dist/server/rate-limit/index.js +2 -2
- package/dist/server/rate-limit/index.js.map +1 -1
- package/dist/server/static/index.d.ts +5 -5
- package/dist/server/static/index.d.ts.map +1 -1
- package/dist/server/swagger/index.d.ts +7 -7
- package/dist/server/swagger/index.d.ts.map +1 -1
- package/dist/server/swagger/index.js +2 -2
- package/dist/server/swagger/index.js.map +1 -1
- package/dist/sms/index.d.ts +11 -7
- package/dist/sms/index.d.ts.map +1 -1
- package/dist/sms/index.js +9 -15
- package/dist/sms/index.js.map +1 -1
- package/dist/system/index.d.ts +4 -4
- package/dist/system/index.d.ts.map +1 -1
- package/dist/topic/core/index.d.ts +6 -6
- package/dist/topic/core/index.d.ts.map +1 -1
- package/dist/topic/redis/index.d.ts +7 -7
- package/dist/topic/redis/index.d.ts.map +1 -1
- package/dist/topic/redis/index.js +2 -2
- package/dist/topic/redis/index.js.map +1 -1
- package/dist/websocket/index.d.ts +36 -36
- package/dist/websocket/index.d.ts.map +1 -1
- package/dist/websocket/index.js +2 -2
- package/dist/websocket/index.js.map +1 -1
- package/package.json +37 -32
- package/src/api/files/{controllers → __tests__}/FileController.spec.ts +189 -143
- package/src/api/files/{services → __tests__}/FileService.spec.ts +50 -30
- package/src/api/files/controllers/FileController.ts +6 -0
- package/src/api/jobs/{services → __tests__}/JobService.spec.ts +1 -1
- package/src/api/jobs/providers/JobProvider.ts +3 -3
- package/src/api/keys/{services → __tests__}/ApiKeyService.spec.ts +1 -1
- package/src/api/organizations/__tests__/OrganizationService.spec.ts +193 -0
- package/src/api/organizations/controllers/AdminOrganizationController.ts +103 -0
- package/src/api/organizations/entities/organizations.ts +20 -0
- package/src/api/organizations/index.browser.ts +10 -0
- package/src/api/organizations/index.ts +31 -0
- package/src/api/organizations/schemas/createOrganizationSchema.ts +10 -0
- package/src/api/organizations/schemas/organizationQuerySchema.ts +10 -0
- package/src/api/organizations/schemas/organizationResourceSchema.ts +6 -0
- package/src/api/organizations/schemas/updateOrganizationSchema.ts +7 -0
- package/src/api/organizations/services/OrganizationService.ts +75 -0
- package/src/api/parameters/services/ParameterProvider.ts +6 -1
- package/src/api/users/__tests__/$realm.spec.ts +191 -0
- package/src/api/users/__tests__/RealmProvider.spec.ts +53 -0
- package/src/api/users/__tests__/SessionService.spec.ts +778 -0
- package/src/api/users/{jobs → __tests__}/UserJobs.spec.ts +1 -1
- package/src/api/users/atoms/realmAuthSettingsAtom.ts +24 -0
- package/src/api/users/controllers/RealmController.ts +5 -11
- package/src/api/users/entities/users.ts +9 -3
- package/src/api/users/index.ts +23 -3
- package/src/api/users/primitives/$realm.ts +23 -11
- package/src/api/users/providers/RealmProvider.ts +23 -3
- package/src/api/users/services/RegistrationService.ts +3 -2
- package/src/api/users/services/SessionService.ts +249 -8
- package/src/api/users/services/UserService.ts +1 -1
- package/src/api/verifications/{jobs → __tests__}/VerificationJobs.spec.ts +4 -2
- package/src/api/verifications/parameters/VerificationParameters.ts +2 -2
- package/src/billing/__tests__/BillingService.spec.ts +136 -0
- package/src/billing/__tests__/PaymentMethodService.spec.ts +78 -0
- package/src/billing/controllers/AdminBillingController.ts +149 -0
- package/src/billing/controllers/BillingController.ts +108 -0
- package/src/billing/entities/paymentIntents.ts +34 -0
- package/src/billing/entities/paymentMethods.ts +24 -0
- package/src/billing/entities/refunds.ts +22 -0
- package/src/billing/errors/BillingError.ts +5 -0
- package/src/billing/index.ts +76 -0
- package/src/billing/providers/BillingProvider.ts +79 -0
- package/src/billing/providers/MemoryBillingProvider.ts +139 -0
- package/src/billing/schemas/intentSchemas.ts +60 -0
- package/src/billing/schemas/paymentMethodSchemas.ts +13 -0
- package/src/billing/schemas/refundSchemas.ts +6 -0
- package/src/billing/services/BillingService.ts +325 -0
- package/src/billing/services/PaymentMethodService.ts +82 -0
- package/src/bin/index.ts +0 -2
- package/src/bucket/providers/LocalFileStorageProvider.ts +2 -2
- package/src/cache/core/{primitives → __tests__}/$cache.middleware.spec.ts +1 -1
- package/src/cache/core/{providers → __tests__}/MemoryCacheProvider.spec.ts +1 -1
- package/src/cache/core/primitives/$cache.ts +2 -2
- package/src/cache/redis/providers/RedisCacheProvider.ts +2 -2
- package/src/cli/config/defineConfig.ts +20 -0
- package/src/cli/core/{services → __tests__}/ProjectScaffolder.spec.ts +1 -1
- package/src/cli/core/{commands/gen → __tests__}/changelog.spec.ts +1 -1
- package/src/cli/core/{commands → __tests__}/init.spec.ts +4 -12
- package/src/cli/core/assets.ts +0 -1
- package/src/cli/core/atoms/devOptions.ts +0 -5
- package/src/cli/core/commands/build.ts +2 -2
- package/src/cli/core/commands/dev.ts +165 -30
- package/src/cli/core/commands/gen/changelog.ts +2 -2
- package/src/cli/core/commands/init.ts +2 -7
- package/src/cli/core/commands/verify.ts +0 -1
- package/src/cli/core/providers/AppEntryProvider.ts +2 -2
- package/src/cli/core/providers/ViteDevServerProvider.ts +53 -46
- package/src/cli/core/services/PackageManagerUtils.ts +8 -3
- package/src/cli/core/services/ProjectScaffolder.ts +20 -20
- package/src/cli/core/tasks/BuildClientTask.ts +8 -0
- package/src/cli/core/tasks/BuildServerTask.ts +17 -4
- package/src/cli/core/templates/alephaConfigTs.ts +0 -6
- package/src/cli/core/templates/webAdminDashboardTsx.ts +17 -0
- package/src/cli/core/templates/webAppRouterTs.ts +85 -2
- package/src/cli/devtools/atoms/devtoolsOptions.ts +26 -0
- package/src/cli/devtools/index.ts +194 -0
- package/src/cli/platform/{adapters → __tests__}/CloudflareAdapter.spec.ts +2 -2
- package/src/cli/platform/{providers → __tests__}/GitHubSecretStore.spec.ts +1 -1
- package/src/cli/platform/{services → __tests__}/NamingService.spec.ts +1 -1
- package/src/cli/platform/{providers → __tests__}/PlatformCacheProvider.spec.ts +1 -1
- package/src/cli/platform/{services → __tests__}/PlatformInspector.spec.ts +1 -1
- package/src/cli/platform/{services → __tests__}/PlatformOrchestrator.spec.ts +3 -3
- package/src/cli/platform/{services → __tests__}/SecretFilterService.spec.ts +1 -1
- package/src/cli/platform/{commands → __tests__}/SecretsCommand.spec.ts +1 -1
- package/src/cli/platform/{adapters → __tests__}/VercelAdapter.spec.ts +2 -2
- package/src/cli/platform/atoms/platformOptions.ts +2 -10
- package/src/cli/platform/commands/SecretsCommand.ts +2 -2
- package/src/cli/platform/commands/platform.ts +2 -11
- package/src/cli/platform/index.ts +34 -11
- package/src/cli/platform/services/PlatformInspector.ts +2 -2
- package/src/cli/platform/services/PlatformOrchestrator.ts +0 -9
- package/src/cli/vendor/__tests__/VendorService.spec.ts +407 -0
- package/src/cli/vendor/atoms/vendorOptions.ts +41 -0
- package/src/cli/vendor/commands/VendorCommand.ts +204 -0
- package/src/cli/vendor/index.ts +43 -0
- package/src/cli/vendor/services/VendorService.ts +338 -0
- package/src/command/{providers → __tests__}/CliProvider.spec.ts +1 -1
- package/src/command/{helpers → __tests__}/EnvUtils.spec.ts +1 -1
- package/src/command/providers/CliProvider.ts +2 -2
- package/src/core/{primitives → __tests__}/$atom.spec.ts +2 -2
- package/src/core/{primitives → __tests__}/$memoize.spec.ts +1 -1
- package/src/core/{primitives → __tests__}/$mode.spec.ts +1 -1
- package/src/core/{primitives → __tests__}/$pipeline.spec.ts +1 -1
- package/src/core/{primitives → __tests__}/$scope.spec.ts +2 -2
- package/src/core/{providers → __tests__}/KeylessJsonSchemaCodec.spec.ts +1 -1
- package/src/core/{providers → __tests__}/SchemaValidator.spec.ts +1 -1
- package/src/core/{helpers → __tests__}/jsonSchemaToTypeBox.spec.ts +1 -1
- package/src/core/index.shared.ts +1 -1
- package/src/core/primitives/{$use.ts → $state.ts} +4 -4
- package/src/crypto/{providers → __tests__}/BrowserCryptoProvider.browser.spec.ts +1 -1
- package/src/crypto/{providers → __tests__}/CryptoProvider.spec.ts +1 -1
- package/src/datetime/{primitives → __tests__}/$debounce.spec.ts +1 -1
- package/src/datetime/{primitives → __tests__}/$throttle.spec.ts +1 -1
- package/src/datetime/{primitives → __tests__}/$timeout.spec.ts +1 -1
- package/src/email/brevo/{providers → __tests__}/BrevoEmailProvider.spec.ts +1 -1
- package/src/email/core/{providers → __tests__}/LocalEmailProvider.spec.ts +39 -150
- package/src/email/core/providers/LocalEmailProvider.ts +13 -51
- package/src/email/smtp/providers/NodemailerEmailProvider.ts +2 -2
- package/src/lock/core/{primitives → __tests__}/$lock.middleware.spec.ts +1 -1
- package/src/lock/core/primitives/$lock.ts +2 -2
- package/src/logger/index.ts +10 -4
- package/src/mcp/transports/SseMcpTransport.ts +2 -2
- package/src/orm/__tests__/ModelBuilder-tests.ts +53 -0
- package/src/orm/__tests__/ModelBuilder.spec.ts +80 -0
- package/src/orm/__tests__/organization-tests.ts +200 -0
- package/src/orm/__tests__/organization.spec.ts +103 -0
- package/src/orm/core/{providers/drivers → __tests__}/BunSqliteProvider.bun.spec.ts +5 -2
- package/src/orm/core/constants/PG_SYMBOLS.ts +2 -0
- package/src/orm/core/index.shared.ts +1 -0
- package/src/orm/core/primitives/$entity.ts +31 -0
- package/src/orm/core/providers/DatabaseTypeProvider.ts +11 -0
- package/src/orm/core/providers/DrizzleKitProvider.ts +1 -1
- package/src/orm/core/providers/drivers/BunSqliteProvider.ts +2 -2
- package/src/orm/core/providers/drivers/NodeSqliteProvider.ts +3 -3
- package/src/orm/core/services/ModelBuilder.ts +11 -0
- package/src/orm/core/services/QueryManager.ts +16 -2
- package/src/orm/core/services/Repository.ts +70 -10
- package/src/orm/postgres/{providers → __tests__}/BunPostgresProvider.bun.spec.ts +1 -1
- package/src/orm/postgres/services/PostgresModelBuilder.ts +9 -1
- package/src/queue/core/providers/WorkerProvider.ts +2 -2
- package/src/queue/redis/providers/RedisQueueProvider.ts +2 -2
- package/src/react/core/{hooks → __tests__}/useAction.browser.spec.tsx +1 -1
- package/src/react/core/hooks/useAction.ts +7 -6
- package/src/react/head/{providers → __tests__}/BrowserHeadProvider.browser.spec.ts +1 -1
- package/src/react/head/{helpers → __tests__}/SeoExpander.spec.ts +1 -1
- package/src/react/i18n/{providers → __tests__}/I18nProvider.spec.ts +1 -1
- package/src/react/i18n/{hooks → __tests__}/useI18n.browser.spec.tsx +1 -1
- package/src/react/intro/components/GettingStartedDevtoolsSlide.tsx +3 -6
- package/src/react/router/{providers → __tests__}/ReactBrowserProvider.browser.spec.ts +1 -1
- package/src/react/router/providers/ReactBrowserProvider.ts +2 -2
- package/src/react/router/providers/ReactPageProvider.ts +2 -2
- package/src/react/router/providers/ReactServerProvider.ts +3 -3
- package/src/redis/{providers → __tests__}/BunRedisProvider.bun.spec.ts +4 -4
- package/src/retry/{primitives → __tests__}/$retry.middleware.spec.ts +1 -1
- package/src/router/{TemplatedPathParser.spec.ts → __tests__/TemplatedPathParser.spec.ts} +1 -1
- package/src/scheduler/primitives/$scheduler.ts +2 -2
- package/src/security/{primitives → __tests__}/$secure-browser.spec.ts +1 -1
- package/src/security/{primitives → __tests__}/$secure.spec.ts +1 -1
- package/src/security/primitives/$issuer.ts +1 -1
- package/src/security/providers/JwtProvider.ts +6 -10
- package/src/security/providers/SecurityProvider.ts +6 -11
- package/src/security/schemas/userAccountInfoSchema.ts +3 -3
- package/src/server/auth/providers/ServerAuthProvider.ts +24 -2
- package/src/server/cookies/{services → __tests__}/CookieParser.spec.ts +1 -1
- package/src/server/core/{primitives → __tests__}/$circuit.spec.ts +1 -1
- package/src/server/core/{providers → __tests__}/NodeHttpServerProvider.spec.ts +1 -1
- package/src/server/core/{providers → __tests__}/ServerBodyParserProvider.spec.ts +31 -1
- package/src/server/core/{providers → __tests__}/ServerCompressProvider.spec.ts +1 -1
- package/src/server/core/{providers → __tests__}/ServerHelmetProvider.spec.ts +4 -1
- package/src/server/core/{providers → __tests__}/ServerMultipartProvider.spec.ts +1 -1
- package/src/server/core/{services → __tests__}/ServerRequestParser.spec.ts +1 -1
- package/src/server/core/primitives/$action.ts +2 -2
- package/src/server/core/primitives/$sse.ts +2 -2
- package/src/server/core/providers/ServerBodyParserProvider.ts +21 -12
- package/src/server/core/providers/ServerCompressProvider.ts +2 -2
- package/src/server/core/providers/ServerHelmetProvider.ts +2 -2
- package/src/server/core/providers/ServerMultipartProvider.ts +2 -2
- package/src/server/core/providers/ServerRouterProvider.ts +1 -5
- package/src/server/cors/{primitives → __tests__}/$cors.spec.ts +1 -1
- package/src/server/cors/providers/ServerCorsProvider.ts +2 -2
- package/src/server/links/{services → __tests__}/BatchCollector.spec.ts +1 -1
- package/src/server/links/providers/LinkProvider.ts +2 -2
- package/src/server/links/providers/RemotePrimitiveProvider.ts +2 -2
- package/src/server/links/providers/ServerLinksProvider.ts +2 -2
- package/src/server/rate-limit/{primitives → __tests__}/$rateLimit.spec.ts +1 -1
- package/src/server/rate-limit/providers/ServerRateLimitProvider.ts +2 -2
- package/src/server/swagger/providers/ServerSwaggerProvider.ts +2 -2
- package/src/sms/{providers → __tests__}/LocalSmsProvider.spec.ts +35 -29
- package/src/sms/providers/LocalSmsProvider.ts +13 -24
- package/src/system/{providers → __tests__}/MemoryFileSystemProvider.spec.ts +1 -1
- package/src/system/{providers → __tests__}/MemoryShellProvider.spec.ts +1 -1
- package/src/topic/redis/providers/RedisTopicProvider.ts +2 -2
- package/src/websocket/{services → __tests__}/RoomManager.spec.ts +1 -1
- package/src/websocket/providers/NodeWebSocketServerProvider.ts +2 -2
- package/tsconfig.base.json +1 -0
- package/assets/devtools-ui/200.html +0 -10
- package/assets/devtools-ui/200.html.br +0 -0
- package/assets/devtools-ui/404.html +0 -10
- package/assets/devtools-ui/404.html.br +0 -0
- package/assets/devtools-ui/CNAME +0 -1
- package/assets/devtools-ui/asset.CHpVij2M.css +0 -1
- package/assets/devtools-ui/asset.CHpVij2M.css.br +0 -0
- package/assets/devtools-ui/asset.DJ-i0UDz.css +0 -1
- package/assets/devtools-ui/asset.DJ-i0UDz.css.br +0 -0
- package/assets/devtools-ui/chunk.1jwpJORo.js +0 -1
- package/assets/devtools-ui/chunk.1jwpJORo.js.br +0 -0
- package/assets/devtools-ui/chunk.B0r2wfUL.js +0 -1
- package/assets/devtools-ui/chunk.B0r2wfUL.js.br +0 -0
- package/assets/devtools-ui/chunk.BScN4dVR.js +0 -84
- package/assets/devtools-ui/chunk.BScN4dVR.js.br +0 -0
- package/assets/devtools-ui/chunk.BispuoY4.js +0 -1
- package/assets/devtools-ui/chunk.BispuoY4.js.br +0 -0
- package/assets/devtools-ui/chunk.BtrPUUd7.js +0 -2
- package/assets/devtools-ui/chunk.BtrPUUd7.js.br +0 -0
- package/assets/devtools-ui/chunk.C-KMHgqf.js +0 -1
- package/assets/devtools-ui/chunk.C-KMHgqf.js.br +0 -0
- package/assets/devtools-ui/chunk.C2zQ3CF6.js +0 -7
- package/assets/devtools-ui/chunk.C2zQ3CF6.js.br +0 -0
- package/assets/devtools-ui/chunk.C619McpO.js +0 -1
- package/assets/devtools-ui/chunk.C619McpO.js.br +0 -0
- package/assets/devtools-ui/chunk.C9OsYsVl.js +0 -1
- package/assets/devtools-ui/chunk.C9OsYsVl.js.br +0 -3
- package/assets/devtools-ui/chunk.CAC_-151.js +0 -1
- package/assets/devtools-ui/chunk.CAC_-151.js.br +0 -0
- package/assets/devtools-ui/chunk.CCmesWfx.js +0 -1
- package/assets/devtools-ui/chunk.CCmesWfx.js.br +0 -0
- package/assets/devtools-ui/chunk.CFQDmrcV.js +0 -1
- package/assets/devtools-ui/chunk.CFQDmrcV.js.br +0 -0
- package/assets/devtools-ui/chunk.CgM71Zau.js +0 -1
- package/assets/devtools-ui/chunk.CgM71Zau.js.br +0 -0
- package/assets/devtools-ui/chunk.CmHq336a.js +0 -1
- package/assets/devtools-ui/chunk.CmHq336a.js.br +0 -0
- package/assets/devtools-ui/chunk.CthNMCar.js +0 -1
- package/assets/devtools-ui/chunk.CthNMCar.js.br +0 -0
- package/assets/devtools-ui/chunk.D2brVJP1.js +0 -1
- package/assets/devtools-ui/chunk.D2brVJP1.js.br +0 -0
- package/assets/devtools-ui/chunk.DgBKGkiw.js +0 -1
- package/assets/devtools-ui/chunk.DgBKGkiw.js.br +0 -0
- package/assets/devtools-ui/chunk.NNHHCQsa.js +0 -1
- package/assets/devtools-ui/chunk.NNHHCQsa.js.br +0 -0
- package/assets/devtools-ui/chunk._CDKKWMo.js +0 -1
- package/assets/devtools-ui/chunk._CDKKWMo.js.br +0 -0
- package/assets/devtools-ui/entry.B_nOjAod.js +0 -2
- package/assets/devtools-ui/entry.B_nOjAod.js.br +0 -0
- package/assets/devtools-ui/index.html +0 -10
- package/assets/devtools-ui/index.html.br +0 -0
- package/dist/devtools/index.browser.js +0 -224
- package/dist/devtools/index.browser.js.map +0 -1
- package/dist/devtools/index.d.ts +0 -499
- package/dist/devtools/index.d.ts.map +0 -1
- package/dist/devtools/index.js +0 -782
- package/dist/devtools/index.js.map +0 -1
- package/dist/mqtt/index.d.ts +0 -164
- package/dist/mqtt/index.d.ts.map +0 -1
- package/dist/mqtt/index.js +0 -214
- package/dist/mqtt/index.js.map +0 -1
- package/dist/topic/mqtt/index.d.ts +0 -87
- package/dist/topic/mqtt/index.d.ts.map +0 -1
- package/dist/topic/mqtt/index.js +0 -88
- package/dist/topic/mqtt/index.js.map +0 -1
- package/src/api/users/parameters/UserParameters.ts +0 -23
- package/src/api/users/services/SessionService.spec.ts +0 -303
- package/src/cli/platform/adapters/DockerAdapter.spec.ts +0 -378
- package/src/cli/platform/adapters/DockerAdapter.ts +0 -417
- package/src/cli/platform/services/DockerComposeGenerator.spec.ts +0 -490
- package/src/cli/platform/services/DockerComposeGenerator.ts +0 -353
- package/src/cli/platform/services/DockerSshService.spec.ts +0 -47
- package/src/cli/platform/services/DockerSshService.ts +0 -61
- package/src/devtools/__tests__/DevCollectorProvider.spec.ts +0 -7
- package/src/devtools/assets.ts +0 -6
- package/src/devtools/entities/logs.ts +0 -21
- package/src/devtools/index.browser.ts +0 -11
- package/src/devtools/index.shared.ts +0 -15
- package/src/devtools/index.ts +0 -39
- package/src/devtools/providers/DevToolsMetadataProvider.ts +0 -459
- package/src/devtools/providers/DevToolsProvider.ts +0 -280
- package/src/devtools/schemas/DevActionMetadata.ts +0 -30
- package/src/devtools/schemas/DevAtomMetadata.ts +0 -26
- package/src/devtools/schemas/DevBucketMetadata.ts +0 -11
- package/src/devtools/schemas/DevCacheMetadata.ts +0 -10
- package/src/devtools/schemas/DevEntityMetadata.ts +0 -60
- package/src/devtools/schemas/DevEnvMetadata.ts +0 -22
- package/src/devtools/schemas/DevMetadata.ts +0 -47
- package/src/devtools/schemas/DevModuleMetadata.ts +0 -8
- package/src/devtools/schemas/DevPageMetadata.ts +0 -24
- package/src/devtools/schemas/DevProviderMetadata.ts +0 -10
- package/src/devtools/schemas/DevQueueMetadata.ts +0 -10
- package/src/devtools/schemas/DevRealmMetadata.ts +0 -19
- package/src/devtools/schemas/DevRouteMetadata.ts +0 -8
- package/src/devtools/schemas/DevSchedulerMetadata.ts +0 -11
- package/src/devtools/schemas/DevTopicMetadata.ts +0 -11
- package/src/mqtt/index.ts +0 -32
- package/src/mqtt/providers/MqttClientProvider.ts +0 -63
- package/src/mqtt/providers/MqttJsClientProvider.spec.ts +0 -165
- package/src/mqtt/providers/MqttJsClientProvider.ts +0 -309
- package/src/topic/mqtt/index.ts +0 -30
- package/src/topic/mqtt/providers/MqttTopicProvider.spec.ts +0 -160
- package/src/topic/mqtt/providers/MqttTopicProvider.ts +0 -146
- /package/src/api/audits/{primitives → __tests__}/$audit.spec.ts +0 -0
- /package/src/api/audits/{services → __tests__}/AuditService.spec.ts +0 -0
- /package/src/api/files/{controllers → __tests__}/AdminFileStatsController.spec.ts +0 -0
- /package/src/api/files/{jobs → __tests__}/FileJobs.spec.ts +0 -0
- /package/src/api/jobs/{primitives → __tests__}/$job-middleware.spec.ts +0 -0
- /package/src/api/parameters/{primitives → __tests__}/$parameter.spec.ts +0 -0
- /package/src/api/users/{controllers → __tests__}/AdminIdentityController.spec.ts +0 -0
- /package/src/api/users/{controllers → __tests__}/AdminSessionController.spec.ts +0 -0
- /package/src/api/users/{controllers → __tests__}/AdminUserController.spec.ts +0 -0
- /package/src/api/users/{services → __tests__}/CredentialService.spec.ts +0 -0
- /package/src/api/users/{services → __tests__}/RegistrationService.spec.ts +0 -0
- /package/src/batch/{primitives → __tests__}/$batch.spec.ts +0 -0
- /package/src/batch/{providers → __tests__}/BatchProvider.spec.ts +0 -0
- /package/src/bucket/{primitives → __tests__}/$bucket.spec.ts +0 -0
- /package/src/bucket/{providers → __tests__}/FileStorageProvider.spec.ts +0 -0
- /package/src/bucket/{providers → __tests__}/LocalFileStorageProvider.spec.ts +0 -0
- /package/src/bucket/{providers → __tests__}/MemoryFileStorageProvider.spec.ts +0 -0
- /package/src/cache/core/{primitives → __tests__}/$cache.spec.ts +0 -0
- /package/src/cache/redis/{providers → __tests__}/RedisCacheProvider.spec.ts +0 -0
- /package/src/command/{primitives → __tests__}/$command.spec.ts +0 -0
- /package/src/command/{helpers → __tests__}/Asker.spec.ts +0 -0
- /package/src/command/{helpers → __tests__}/Runner.spec.ts +0 -0
- /package/src/core/{primitives → __tests__}/$context.spec.ts +0 -0
- /package/src/core/{primitives → __tests__}/$env.spec.ts +0 -0
- /package/src/core/{primitives → __tests__}/$hook.spec.ts +0 -0
- /package/src/core/{primitives → __tests__}/$inject.spec.ts +0 -0
- /package/src/core/{primitives → __tests__}/$module.spec.ts +0 -0
- /package/src/core/{providers → __tests__}/CodecManager.spec.ts +0 -0
- /package/src/core/{providers → __tests__}/EventManager.spec.ts +0 -0
- /package/src/core/{providers → __tests__}/StateManager.spec.ts +0 -0
- /package/src/core/{providers → __tests__}/TypeProvider.spec.ts +0 -0
- /package/src/datetime/{primitives → __tests__}/$interval.spec.ts +0 -0
- /package/src/datetime/{providers → __tests__}/DateTimeProvider.spec.ts +0 -0
- /package/src/email/core/{primitives → __tests__}/$email.spec.ts +0 -0
- /package/src/fake/{providers → __tests__}/FakeProvider.spec.ts +0 -0
- /package/src/lock/core/{providers → __tests__}/MemoryLockProvider.spec.ts +0 -0
- /package/src/lock/redis/{providers → __tests__}/RedisLockProvider.spec.ts +0 -0
- /package/src/logger/{primitives → __tests__}/$logger.spec.ts +0 -0
- /package/src/logger/{services → __tests__}/Logger.spec.ts +0 -0
- /package/src/mcp/{primitives → __tests__}/$prompt.spec.ts +0 -0
- /package/src/mcp/{primitives → __tests__}/$resource.spec.ts +0 -0
- /package/src/mcp/{primitives → __tests__}/$tool.spec.ts +0 -0
- /package/src/mcp/{providers → __tests__}/McpServerProvider.spec.ts +0 -0
- /package/src/mcp/{helpers → __tests__}/jsonrpc.spec.ts +0 -0
- /package/src/orm/core/{helpers → __tests__}/parseQueryString.spec.ts +0 -0
- /package/src/queue/core/{primitives → __tests__}/$consumer.spec.ts +0 -0
- /package/src/queue/core/{providers → __tests__}/MemoryQueueProvider.spec.ts +0 -0
- /package/src/queue/core/{providers → __tests__}/WorkerProvider.spec.ts +0 -0
- /package/src/queue/redis/{providers → __tests__}/RedisQueueProvider.spec.ts +0 -0
- /package/src/react/form/{hooks → __tests__}/useForm.browser.spec.tsx +0 -0
- /package/src/react/head/{hooks → __tests__}/useHead.spec.tsx +0 -0
- /package/src/react/i18n/{components → __tests__}/Localize.spec.tsx +0 -0
- /package/src/react/router/{primitives → __tests__}/$page.browser.spec.tsx +0 -0
- /package/src/react/router/{primitives → __tests__}/$page.middleware.spec.tsx +0 -0
- /package/src/react/router/{primitives → __tests__}/$page.spec.tsx +0 -0
- /package/src/react/router/{providers → __tests__}/ReactPreloadProvider.spec.ts +0 -0
- /package/src/react/router/{providers → __tests__}/ReactServerProvider.spec.tsx +0 -0
- /package/src/react/router/{providers → __tests__}/ReactServerTemplateProvider.spec.ts +0 -0
- /package/src/retry/{primitives → __tests__}/$retry.spec.ts +0 -0
- /package/src/retry/{providers → __tests__}/RetryProvider.spec.ts +0 -0
- /package/src/router/{providers → __tests__}/RouterProvider.spec.ts +0 -0
- /package/src/security/{primitives → __tests__}/$issuer.spec.ts +0 -0
- /package/src/security/{primitives → __tests__}/$permission.spec.ts +0 -0
- /package/src/security/{primitives → __tests__}/$role.spec.ts +0 -0
- /package/src/security/{primitives → __tests__}/$serviceAccount.spec.ts +0 -0
- /package/src/security/{providers → __tests__}/SecurityProvider.spec.ts +0 -0
- /package/src/server/cookies/{providers → __tests__}/ServerCookiesProvider.spec.ts +0 -0
- /package/src/server/core/{primitives → __tests__}/$action.spec.ts +0 -0
- /package/src/server/core/{primitives → __tests__}/$middleware.spec.ts +0 -0
- /package/src/server/core/{primitives → __tests__}/$route.spec.ts +0 -0
- /package/src/server/core/{primitives → __tests__}/$sse.spec.ts +0 -0
- /package/src/server/core/{providers → __tests__}/BunHttpServerProvider.bun.spec.ts +0 -0
- /package/src/server/core/{services → __tests__}/HttpClient.spec.ts +0 -0
- /package/src/server/core/{providers → __tests__}/ServerLoggerProvider.spec.ts +0 -0
- /package/src/server/core/{services → __tests__}/UserAgentParser.spec.ts +0 -0
- /package/src/server/cors/{providers → __tests__}/ServerCorsProvider.spec.ts +0 -0
- /package/src/server/etag/{providers → __tests__}/ServerEtagProvider.spec.ts +0 -0
- /package/src/server/health/{providers → __tests__}/ServerHealthProvider.spec.ts +0 -0
- /package/src/server/links/{primitives → __tests__}/$remote.spec.ts +0 -0
- /package/src/server/links/{services → __tests__}/BatchEndpoint.spec.ts +0 -0
- /package/src/server/links/{providers → __tests__}/LinkProvider.spec.ts +0 -0
- /package/src/server/links/{providers → __tests__}/ServerLinksProvider.spec.ts +0 -0
- /package/src/server/metrics/{providers → __tests__}/ServerMetricsProvider.spec.ts +0 -0
- /package/src/server/proxy/{primitives → __tests__}/$proxy.spec.ts +0 -0
- /package/src/server/rate-limit/{providers → __tests__}/ServerRateLimitProvider.spec.ts +0 -0
- /package/src/server/static/{primitives → __tests__}/$serve.spec.ts +0 -0
- /package/src/server/swagger/{primitives → __tests__}/$swagger.spec.ts +0 -0
- /package/src/sms/{primitives → __tests__}/$sms.spec.ts +0 -0
- /package/src/sms/{providers → __tests__}/MemorySmsProvider.spec.ts +0 -0
- /package/src/system/{services → __tests__}/FileDetector.spec.ts +0 -0
- /package/src/system/{providers → __tests__}/NodeFileSystemProvider.spec.ts +0 -0
- /package/src/topic/core/{primitives → __tests__}/$subscriber.spec.ts +0 -0
- /package/src/topic/core/{providers → __tests__}/MemoryTopicProvider.spec.ts +0 -0
- /package/src/topic/redis/{providers → __tests__}/RedisTopicProvider.spec.ts +0 -0
- /package/src/websocket/{primitives → __tests__}/$channel.spec.ts +0 -0
package/dist/devtools/index.js
DELETED
|
@@ -1,782 +0,0 @@
|
|
|
1
|
-
import { $hook, $inject, $module, Alepha, t } from "alepha";
|
|
2
|
-
import { $action, $route, AlephaServer, ServerProvider } from "alepha/server";
|
|
3
|
-
import { $serve, AlephaServerStatic } from "alepha/server/static";
|
|
4
|
-
import { $bucket } from "alepha/bucket";
|
|
5
|
-
import { $cache } from "alepha/cache";
|
|
6
|
-
import { DateTimeProvider } from "alepha/datetime";
|
|
7
|
-
import { $logger, MemoryDestinationProvider } from "alepha/logger";
|
|
8
|
-
import { PG_CREATED_AT, PG_DEFAULT, PG_DELETED_AT, PG_IDENTITY, PG_PRIMARY_KEY, PG_REF, PG_SERIAL, PG_UPDATED_AT, PG_VERSION, RepositoryProvider } from "alepha/orm";
|
|
9
|
-
import { $queue } from "alepha/queue";
|
|
10
|
-
import { $page } from "alepha/react/router";
|
|
11
|
-
import { $scheduler } from "alepha/scheduler";
|
|
12
|
-
import { $issuer } from "alepha/security";
|
|
13
|
-
import { $topic } from "alepha/topic";
|
|
14
|
-
import { join } from "node:path";
|
|
15
|
-
import { fileURLToPath } from "node:url";
|
|
16
|
-
//#region ../../src/devtools/providers/DevToolsMetadataProvider.ts
|
|
17
|
-
var DevToolsMetadataProvider = class {
|
|
18
|
-
alepha = $inject(Alepha);
|
|
19
|
-
dateTime = $inject(DateTimeProvider);
|
|
20
|
-
log = $logger();
|
|
21
|
-
serverProvider = $inject(ServerProvider);
|
|
22
|
-
startedAt = this.dateTime.nowMillis();
|
|
23
|
-
getActions() {
|
|
24
|
-
return this.alepha.primitives($action).map((action) => {
|
|
25
|
-
const schema = action.schema;
|
|
26
|
-
const options = action.options;
|
|
27
|
-
return {
|
|
28
|
-
name: action.name,
|
|
29
|
-
group: action.group,
|
|
30
|
-
method: action.method,
|
|
31
|
-
path: action.path,
|
|
32
|
-
prefix: action.prefix,
|
|
33
|
-
fullPath: action.route.path,
|
|
34
|
-
description: action.options.description,
|
|
35
|
-
summary: options.summary,
|
|
36
|
-
disabled: action.options.disabled,
|
|
37
|
-
secure: action.middlewares.some((m) => m?.name === "$secure") || void 0,
|
|
38
|
-
hide: options.hide,
|
|
39
|
-
body: schema?.body,
|
|
40
|
-
params: schema?.params,
|
|
41
|
-
query: schema?.query,
|
|
42
|
-
response: schema?.response,
|
|
43
|
-
bodyContentType: action.getBodyContentType(),
|
|
44
|
-
middlewares: action.middlewares.filter(Boolean).length ? action.middlewares.filter(Boolean) : void 0
|
|
45
|
-
};
|
|
46
|
-
});
|
|
47
|
-
}
|
|
48
|
-
getQueues() {
|
|
49
|
-
return this.alepha.primitives($queue).map((queue) => ({
|
|
50
|
-
name: queue.name,
|
|
51
|
-
description: queue.options.description,
|
|
52
|
-
schema: queue.options.schema,
|
|
53
|
-
provider: this.getProviderName(queue.options.provider)
|
|
54
|
-
}));
|
|
55
|
-
}
|
|
56
|
-
getSchedulers() {
|
|
57
|
-
return this.alepha.primitives($scheduler).map((scheduler) => ({
|
|
58
|
-
name: scheduler.name,
|
|
59
|
-
description: scheduler.options.description,
|
|
60
|
-
cron: scheduler.options.cron,
|
|
61
|
-
interval: scheduler.options.interval,
|
|
62
|
-
lock: scheduler.options.lock
|
|
63
|
-
}));
|
|
64
|
-
}
|
|
65
|
-
getTopics() {
|
|
66
|
-
const topicPrimitives = this.alepha.primitives($topic);
|
|
67
|
-
const topicMap = /* @__PURE__ */ new Map();
|
|
68
|
-
for (const topic of topicPrimitives) {
|
|
69
|
-
const existing = topicMap.get(topic.name);
|
|
70
|
-
if (existing) existing.subscribers++;
|
|
71
|
-
else topicMap.set(topic.name, {
|
|
72
|
-
name: topic.name,
|
|
73
|
-
description: topic.options.description,
|
|
74
|
-
schema: topic.options.schema,
|
|
75
|
-
provider: this.getProviderName(topic.options.provider),
|
|
76
|
-
subscribers: 1
|
|
77
|
-
});
|
|
78
|
-
}
|
|
79
|
-
return Array.from(topicMap.values());
|
|
80
|
-
}
|
|
81
|
-
getBuckets() {
|
|
82
|
-
return this.alepha.primitives($bucket).map((bucket) => ({
|
|
83
|
-
name: bucket.name,
|
|
84
|
-
description: bucket.options.description,
|
|
85
|
-
mimeTypes: bucket.options.mimeTypes,
|
|
86
|
-
maxSize: bucket.options.maxSize,
|
|
87
|
-
provider: this.getProviderName(bucket.options.provider)
|
|
88
|
-
}));
|
|
89
|
-
}
|
|
90
|
-
getRealms() {
|
|
91
|
-
return this.alepha.primitives($issuer).map((realm) => ({
|
|
92
|
-
name: realm.name,
|
|
93
|
-
description: realm.options.description,
|
|
94
|
-
roles: realm.options.roles,
|
|
95
|
-
type: "secret" in realm.options ? "internal" : "external",
|
|
96
|
-
settings: {
|
|
97
|
-
accessTokenExpiration: realm.options.settings?.accessToken?.expiration,
|
|
98
|
-
refreshTokenExpiration: realm.options.settings?.refreshToken?.expiration,
|
|
99
|
-
hasOnCreateSession: !!realm.options.settings?.onCreateSession,
|
|
100
|
-
hasOnRefreshSession: !!realm.options.settings?.onRefreshSession,
|
|
101
|
-
hasOnDeleteSession: !!realm.options.settings?.onDeleteSession
|
|
102
|
-
}
|
|
103
|
-
}));
|
|
104
|
-
}
|
|
105
|
-
getCaches() {
|
|
106
|
-
return this.alepha.primitives($cache).map((cache) => ({
|
|
107
|
-
name: cache.container,
|
|
108
|
-
ttl: cache.options.ttl,
|
|
109
|
-
disabled: cache.options.disabled,
|
|
110
|
-
provider: this.getProviderName(cache.options.provider)
|
|
111
|
-
}));
|
|
112
|
-
}
|
|
113
|
-
getPages() {
|
|
114
|
-
return this.alepha.primitives($page).map((page) => {
|
|
115
|
-
const children = typeof page.options.children === "function" ? page.options.children() : page.options.children;
|
|
116
|
-
const childrenNames = Array.isArray(children) ? children.map((c) => c.name).filter(Boolean) : void 0;
|
|
117
|
-
return {
|
|
118
|
-
name: page.name,
|
|
119
|
-
label: page.options.label,
|
|
120
|
-
description: page.options.description,
|
|
121
|
-
path: page.options.path,
|
|
122
|
-
parentName: page.options.parent?.name,
|
|
123
|
-
params: page.options.schema?.params,
|
|
124
|
-
query: page.options.schema?.query,
|
|
125
|
-
hasComponent: !!page.options.component,
|
|
126
|
-
hasLazy: !!page.options.lazy,
|
|
127
|
-
hasResolve: !!page.options.resolve,
|
|
128
|
-
childrenNames: childrenNames?.length ? childrenNames : void 0,
|
|
129
|
-
hasChildren: !!page.options.children,
|
|
130
|
-
hasParent: !!page.options.parent,
|
|
131
|
-
hasErrorHandler: !!page.options.errorHandler,
|
|
132
|
-
static: typeof page.options.static === "boolean" ? page.options.static : !!page.options.static,
|
|
133
|
-
cache: page.options.cache,
|
|
134
|
-
client: page.options.client,
|
|
135
|
-
animation: page.options.animation
|
|
136
|
-
};
|
|
137
|
-
});
|
|
138
|
-
}
|
|
139
|
-
getProviders() {
|
|
140
|
-
const graph = this.alepha.graph();
|
|
141
|
-
return Object.entries(graph).map(([name, info]) => ({
|
|
142
|
-
name,
|
|
143
|
-
module: info.module ?? name,
|
|
144
|
-
dependencies: info.from,
|
|
145
|
-
aliases: info.as
|
|
146
|
-
}));
|
|
147
|
-
}
|
|
148
|
-
getModules() {
|
|
149
|
-
const graph = this.alepha.graph();
|
|
150
|
-
const moduleMap = /* @__PURE__ */ new Map();
|
|
151
|
-
for (const [providerName, info] of Object.entries(graph)) if (info.module) {
|
|
152
|
-
if (!moduleMap.has(info.module)) moduleMap.set(info.module, /* @__PURE__ */ new Set());
|
|
153
|
-
moduleMap.get(info.module).add(providerName);
|
|
154
|
-
}
|
|
155
|
-
return Array.from(moduleMap.entries()).map(([name, providers]) => ({
|
|
156
|
-
name,
|
|
157
|
-
providers: Array.from(providers)
|
|
158
|
-
}));
|
|
159
|
-
}
|
|
160
|
-
getEntities() {
|
|
161
|
-
try {
|
|
162
|
-
return this.alepha.inject(RepositoryProvider).getRepositories().map((repo) => {
|
|
163
|
-
const entity = repo.entity;
|
|
164
|
-
const schema = entity.schema;
|
|
165
|
-
const options = entity.options;
|
|
166
|
-
const columns = Object.entries(schema.properties).map(([name, field]) => {
|
|
167
|
-
const fieldSchema = field;
|
|
168
|
-
const refData = fieldSchema[PG_REF];
|
|
169
|
-
return {
|
|
170
|
-
name,
|
|
171
|
-
type: this.getColumnType(fieldSchema),
|
|
172
|
-
nullable: this.isNullable(fieldSchema),
|
|
173
|
-
primaryKey: PG_PRIMARY_KEY in fieldSchema,
|
|
174
|
-
identity: PG_IDENTITY in fieldSchema || PG_SERIAL in fieldSchema,
|
|
175
|
-
createdAt: PG_CREATED_AT in fieldSchema,
|
|
176
|
-
updatedAt: PG_UPDATED_AT in fieldSchema,
|
|
177
|
-
deletedAt: PG_DELETED_AT in fieldSchema,
|
|
178
|
-
version: PG_VERSION in fieldSchema,
|
|
179
|
-
hasDefault: PG_DEFAULT in fieldSchema,
|
|
180
|
-
ref: refData ? {
|
|
181
|
-
entity: refData.ref?.()?.entity?.name ?? "unknown",
|
|
182
|
-
column: refData.ref?.()?.name ?? "unknown",
|
|
183
|
-
onUpdate: refData.actions?.onUpdate,
|
|
184
|
-
onDelete: refData.actions?.onDelete
|
|
185
|
-
} : void 0
|
|
186
|
-
};
|
|
187
|
-
});
|
|
188
|
-
const indexes = (options.indexes ?? []).map((idx) => {
|
|
189
|
-
if (typeof idx === "string") return {
|
|
190
|
-
columns: [idx],
|
|
191
|
-
unique: false
|
|
192
|
-
};
|
|
193
|
-
return {
|
|
194
|
-
name: idx.name,
|
|
195
|
-
columns: idx.column ? [idx.column] : idx.columns ?? [],
|
|
196
|
-
unique: idx.unique ?? false
|
|
197
|
-
};
|
|
198
|
-
});
|
|
199
|
-
const foreignKeys = (options.foreignKeys ?? []).map((fk) => ({
|
|
200
|
-
name: fk.name,
|
|
201
|
-
columns: fk.columns.map(String),
|
|
202
|
-
foreignEntity: fk.foreignColumns?.[0]?.()?.entity?.name ?? "unknown",
|
|
203
|
-
foreignColumns: fk.foreignColumns?.map((fc) => fc?.()?.name ?? "unknown")
|
|
204
|
-
}));
|
|
205
|
-
const constraints = (options.constraints ?? []).map((c) => ({
|
|
206
|
-
name: c.name,
|
|
207
|
-
columns: c.columns.map(String),
|
|
208
|
-
unique: !!c.unique,
|
|
209
|
-
hasCheck: !!c.check
|
|
210
|
-
}));
|
|
211
|
-
return {
|
|
212
|
-
name: entity.name,
|
|
213
|
-
provider: repo.provider.constructor.name,
|
|
214
|
-
columns,
|
|
215
|
-
indexes,
|
|
216
|
-
foreignKeys,
|
|
217
|
-
constraints,
|
|
218
|
-
schema: entity.schema,
|
|
219
|
-
insertSchema: entity.insertSchema,
|
|
220
|
-
updateSchema: entity.updateSchema
|
|
221
|
-
};
|
|
222
|
-
});
|
|
223
|
-
} catch {
|
|
224
|
-
return [];
|
|
225
|
-
}
|
|
226
|
-
}
|
|
227
|
-
getColumnType(field) {
|
|
228
|
-
if (t.schema.isUnion(field) && field.anyOf) {
|
|
229
|
-
const nonNull = field.anyOf.find((type) => !t.schema.isNull(type));
|
|
230
|
-
if (nonNull) return this.getColumnType(nonNull);
|
|
231
|
-
}
|
|
232
|
-
const f = field;
|
|
233
|
-
if (t.schema.isUnsafe(field) && f.type === "string" && Array.isArray(f.enum)) return "enum";
|
|
234
|
-
if (t.schema.isString(field)) {
|
|
235
|
-
if (f.enum) return "enum";
|
|
236
|
-
if (f.format === "uuid") return "uuid";
|
|
237
|
-
if (f.format === "date-time") return "datetime";
|
|
238
|
-
if (f.format === "date") return "date";
|
|
239
|
-
if (f.format === "bigint") return "bigint";
|
|
240
|
-
return "text";
|
|
241
|
-
}
|
|
242
|
-
if (t.schema.isInteger(field)) return "integer";
|
|
243
|
-
if (t.schema.isNumber(field)) return "number";
|
|
244
|
-
if (t.schema.isBoolean(field)) return "boolean";
|
|
245
|
-
if (t.schema.isArray(field)) return "array";
|
|
246
|
-
if (t.schema.isObject(field)) return "json";
|
|
247
|
-
if (t.schema.isLiteral(field)) return "literal";
|
|
248
|
-
return "unknown";
|
|
249
|
-
}
|
|
250
|
-
isNullable(field) {
|
|
251
|
-
if (t.schema.isUnion(field) && field.anyOf) return field.anyOf.some((type) => t.schema.isNull(type));
|
|
252
|
-
return false;
|
|
253
|
-
}
|
|
254
|
-
getRoutes() {
|
|
255
|
-
return [];
|
|
256
|
-
}
|
|
257
|
-
getEnvs() {
|
|
258
|
-
return this.alepha.getEnvSchemas().map((item, index) => ({
|
|
259
|
-
propertyKey: `env_${index}`,
|
|
260
|
-
schema: item.schema,
|
|
261
|
-
values: item.values,
|
|
262
|
-
serviceName: void 0
|
|
263
|
-
}));
|
|
264
|
-
}
|
|
265
|
-
getAtoms() {
|
|
266
|
-
return this.alepha.store.getAtoms(false).map(({ atom, value }) => ({
|
|
267
|
-
name: atom.key,
|
|
268
|
-
description: atom.options.description,
|
|
269
|
-
schema: atom.schema,
|
|
270
|
-
defaultValue: atom.options.default,
|
|
271
|
-
currentValue: value
|
|
272
|
-
}));
|
|
273
|
-
}
|
|
274
|
-
getSystem() {
|
|
275
|
-
const isBun = typeof globalThis.Bun !== "undefined";
|
|
276
|
-
const port = Number(this.alepha.env.SERVER_PORT) || 3e3;
|
|
277
|
-
return {
|
|
278
|
-
alephaVersion: String(this.alepha.env.npm_package_version ?? "unknown"),
|
|
279
|
-
nodeVersion: isBun ? globalThis.Bun?.version ?? "unknown" : process.version,
|
|
280
|
-
runtime: isBun ? "bun" : "node",
|
|
281
|
-
mode: this.alepha.isProduction() ? "production" : "development",
|
|
282
|
-
port,
|
|
283
|
-
uptime: (this.dateTime.nowMillis() - this.startedAt) / 1e3,
|
|
284
|
-
memoryUsage: process.memoryUsage?.()?.rss ?? 0
|
|
285
|
-
};
|
|
286
|
-
}
|
|
287
|
-
getMetadata() {
|
|
288
|
-
return {
|
|
289
|
-
system: this.getSystem(),
|
|
290
|
-
actions: this.getActions(),
|
|
291
|
-
queues: this.getQueues(),
|
|
292
|
-
schedulers: this.getSchedulers(),
|
|
293
|
-
topics: this.getTopics(),
|
|
294
|
-
buckets: this.getBuckets(),
|
|
295
|
-
realms: this.getRealms(),
|
|
296
|
-
caches: this.getCaches(),
|
|
297
|
-
pages: this.getPages(),
|
|
298
|
-
providers: this.getProviders(),
|
|
299
|
-
modules: this.getModules(),
|
|
300
|
-
entities: this.getEntities(),
|
|
301
|
-
routes: this.getRoutes(),
|
|
302
|
-
envs: this.getEnvs(),
|
|
303
|
-
atoms: this.getAtoms()
|
|
304
|
-
};
|
|
305
|
-
}
|
|
306
|
-
getProviderName(provider) {
|
|
307
|
-
if (!provider) return "default";
|
|
308
|
-
if (provider === "memory") return "memory";
|
|
309
|
-
return provider.name || "custom";
|
|
310
|
-
}
|
|
311
|
-
};
|
|
312
|
-
//#endregion
|
|
313
|
-
//#region ../../src/devtools/assets.ts
|
|
314
|
-
const devtoolsAssets = { ui: join(fileURLToPath(import.meta.url), "../../../assets/devtools-ui") };
|
|
315
|
-
//#endregion
|
|
316
|
-
//#region ../../src/devtools/schemas/DevActionMetadata.ts
|
|
317
|
-
const devActionMetadataSchema = t.object({
|
|
318
|
-
name: t.text(),
|
|
319
|
-
group: t.text(),
|
|
320
|
-
method: t.text(),
|
|
321
|
-
path: t.text(),
|
|
322
|
-
prefix: t.text(),
|
|
323
|
-
fullPath: t.text(),
|
|
324
|
-
description: t.optional(t.text()),
|
|
325
|
-
summary: t.optional(t.text()),
|
|
326
|
-
disabled: t.optional(t.boolean()),
|
|
327
|
-
secure: t.optional(t.boolean()),
|
|
328
|
-
hide: t.optional(t.boolean()),
|
|
329
|
-
body: t.optional(t.any()),
|
|
330
|
-
params: t.optional(t.any()),
|
|
331
|
-
query: t.optional(t.any()),
|
|
332
|
-
response: t.optional(t.any()),
|
|
333
|
-
bodyContentType: t.optional(t.text()),
|
|
334
|
-
middlewares: t.optional(t.array(t.object({
|
|
335
|
-
name: t.text(),
|
|
336
|
-
options: t.optional(t.any())
|
|
337
|
-
})))
|
|
338
|
-
});
|
|
339
|
-
//#endregion
|
|
340
|
-
//#region ../../src/devtools/schemas/DevAtomMetadata.ts
|
|
341
|
-
const devAtomMetadataSchema = t.object({
|
|
342
|
-
name: t.text(),
|
|
343
|
-
description: t.optional(t.text()),
|
|
344
|
-
schema: t.any(),
|
|
345
|
-
defaultValue: t.optional(t.any()),
|
|
346
|
-
currentValue: t.optional(t.any())
|
|
347
|
-
});
|
|
348
|
-
//#endregion
|
|
349
|
-
//#region ../../src/devtools/schemas/DevBucketMetadata.ts
|
|
350
|
-
const devBucketMetadataSchema = t.object({
|
|
351
|
-
name: t.text(),
|
|
352
|
-
description: t.optional(t.text()),
|
|
353
|
-
mimeTypes: t.optional(t.array(t.text())),
|
|
354
|
-
maxSize: t.optional(t.number()),
|
|
355
|
-
provider: t.text()
|
|
356
|
-
});
|
|
357
|
-
//#endregion
|
|
358
|
-
//#region ../../src/devtools/schemas/DevCacheMetadata.ts
|
|
359
|
-
const devCacheMetadataSchema = t.object({
|
|
360
|
-
name: t.text(),
|
|
361
|
-
ttl: t.optional(t.any()),
|
|
362
|
-
disabled: t.optional(t.boolean()),
|
|
363
|
-
provider: t.text()
|
|
364
|
-
});
|
|
365
|
-
//#endregion
|
|
366
|
-
//#region ../../src/devtools/schemas/DevEntityMetadata.ts
|
|
367
|
-
const devEntityColumnSchema = t.object({
|
|
368
|
-
name: t.text(),
|
|
369
|
-
type: t.text(),
|
|
370
|
-
nullable: t.boolean(),
|
|
371
|
-
primaryKey: t.boolean(),
|
|
372
|
-
identity: t.boolean(),
|
|
373
|
-
createdAt: t.boolean(),
|
|
374
|
-
updatedAt: t.boolean(),
|
|
375
|
-
deletedAt: t.boolean(),
|
|
376
|
-
version: t.boolean(),
|
|
377
|
-
hasDefault: t.boolean(),
|
|
378
|
-
ref: t.optional(t.object({
|
|
379
|
-
entity: t.text(),
|
|
380
|
-
column: t.text(),
|
|
381
|
-
onUpdate: t.optional(t.text()),
|
|
382
|
-
onDelete: t.optional(t.text())
|
|
383
|
-
}))
|
|
384
|
-
});
|
|
385
|
-
const devEntityIndexSchema = t.object({
|
|
386
|
-
name: t.optional(t.text()),
|
|
387
|
-
columns: t.array(t.text()),
|
|
388
|
-
unique: t.boolean()
|
|
389
|
-
});
|
|
390
|
-
const devEntityForeignKeySchema = t.object({
|
|
391
|
-
name: t.optional(t.text()),
|
|
392
|
-
columns: t.array(t.text()),
|
|
393
|
-
foreignEntity: t.text(),
|
|
394
|
-
foreignColumns: t.array(t.text())
|
|
395
|
-
});
|
|
396
|
-
const devEntityConstraintSchema = t.object({
|
|
397
|
-
name: t.optional(t.text()),
|
|
398
|
-
columns: t.array(t.text()),
|
|
399
|
-
unique: t.boolean(),
|
|
400
|
-
hasCheck: t.boolean()
|
|
401
|
-
});
|
|
402
|
-
const devEntityMetadataSchema = t.object({
|
|
403
|
-
name: t.text(),
|
|
404
|
-
provider: t.text(),
|
|
405
|
-
columns: t.array(devEntityColumnSchema),
|
|
406
|
-
indexes: t.array(devEntityIndexSchema),
|
|
407
|
-
foreignKeys: t.array(devEntityForeignKeySchema),
|
|
408
|
-
constraints: t.array(devEntityConstraintSchema),
|
|
409
|
-
schema: t.optional(t.any()),
|
|
410
|
-
insertSchema: t.optional(t.any()),
|
|
411
|
-
updateSchema: t.optional(t.any())
|
|
412
|
-
});
|
|
413
|
-
//#endregion
|
|
414
|
-
//#region ../../src/devtools/schemas/DevEnvMetadata.ts
|
|
415
|
-
const devEnvMetadataSchema = t.object({
|
|
416
|
-
propertyKey: t.text(),
|
|
417
|
-
schema: t.any(),
|
|
418
|
-
values: t.record(t.text(), t.any()),
|
|
419
|
-
serviceName: t.optional(t.text())
|
|
420
|
-
});
|
|
421
|
-
//#endregion
|
|
422
|
-
//#region ../../src/devtools/schemas/DevModuleMetadata.ts
|
|
423
|
-
const devModuleMetadataSchema = t.object({
|
|
424
|
-
name: t.text(),
|
|
425
|
-
providers: t.array(t.text())
|
|
426
|
-
});
|
|
427
|
-
//#endregion
|
|
428
|
-
//#region ../../src/devtools/schemas/DevPageMetadata.ts
|
|
429
|
-
const devPageMetadataSchema = t.object({
|
|
430
|
-
name: t.text(),
|
|
431
|
-
label: t.optional(t.text()),
|
|
432
|
-
description: t.optional(t.text()),
|
|
433
|
-
path: t.optional(t.text()),
|
|
434
|
-
parentName: t.optional(t.text()),
|
|
435
|
-
params: t.optional(t.any()),
|
|
436
|
-
query: t.optional(t.any()),
|
|
437
|
-
hasComponent: t.boolean(),
|
|
438
|
-
hasLazy: t.boolean(),
|
|
439
|
-
hasResolve: t.boolean(),
|
|
440
|
-
childrenNames: t.optional(t.array(t.text())),
|
|
441
|
-
hasChildren: t.boolean(),
|
|
442
|
-
hasParent: t.boolean(),
|
|
443
|
-
hasErrorHandler: t.boolean(),
|
|
444
|
-
static: t.optional(t.boolean()),
|
|
445
|
-
cache: t.optional(t.any()),
|
|
446
|
-
client: t.optional(t.any()),
|
|
447
|
-
animation: t.optional(t.any())
|
|
448
|
-
});
|
|
449
|
-
//#endregion
|
|
450
|
-
//#region ../../src/devtools/schemas/DevProviderMetadata.ts
|
|
451
|
-
const devProviderMetadataSchema = t.object({
|
|
452
|
-
name: t.text(),
|
|
453
|
-
module: t.optional(t.text()),
|
|
454
|
-
dependencies: t.array(t.text()),
|
|
455
|
-
aliases: t.optional(t.array(t.text()))
|
|
456
|
-
});
|
|
457
|
-
//#endregion
|
|
458
|
-
//#region ../../src/devtools/schemas/DevQueueMetadata.ts
|
|
459
|
-
const devQueueMetadataSchema = t.object({
|
|
460
|
-
name: t.text(),
|
|
461
|
-
description: t.optional(t.text()),
|
|
462
|
-
schema: t.optional(t.any()),
|
|
463
|
-
provider: t.text()
|
|
464
|
-
});
|
|
465
|
-
//#endregion
|
|
466
|
-
//#region ../../src/devtools/schemas/DevRealmMetadata.ts
|
|
467
|
-
const devRealmMetadataSchema = t.object({
|
|
468
|
-
name: t.text(),
|
|
469
|
-
description: t.optional(t.text()),
|
|
470
|
-
roles: t.optional(t.array(t.any())),
|
|
471
|
-
type: t.enum(["internal", "external"]),
|
|
472
|
-
settings: t.optional(t.object({
|
|
473
|
-
accessTokenExpiration: t.optional(t.any()),
|
|
474
|
-
refreshTokenExpiration: t.optional(t.any()),
|
|
475
|
-
hasOnCreateSession: t.boolean(),
|
|
476
|
-
hasOnRefreshSession: t.boolean(),
|
|
477
|
-
hasOnDeleteSession: t.boolean()
|
|
478
|
-
}))
|
|
479
|
-
});
|
|
480
|
-
//#endregion
|
|
481
|
-
//#region ../../src/devtools/schemas/DevRouteMetadata.ts
|
|
482
|
-
const devRouteMetadataSchema = t.object({
|
|
483
|
-
method: t.text(),
|
|
484
|
-
path: t.text()
|
|
485
|
-
});
|
|
486
|
-
//#endregion
|
|
487
|
-
//#region ../../src/devtools/schemas/DevSchedulerMetadata.ts
|
|
488
|
-
const devSchedulerMetadataSchema = t.object({
|
|
489
|
-
name: t.text(),
|
|
490
|
-
description: t.optional(t.text()),
|
|
491
|
-
cron: t.optional(t.text()),
|
|
492
|
-
interval: t.optional(t.any()),
|
|
493
|
-
lock: t.optional(t.boolean())
|
|
494
|
-
});
|
|
495
|
-
//#endregion
|
|
496
|
-
//#region ../../src/devtools/schemas/DevTopicMetadata.ts
|
|
497
|
-
const devTopicMetadataSchema = t.object({
|
|
498
|
-
name: t.text(),
|
|
499
|
-
description: t.optional(t.text()),
|
|
500
|
-
schema: t.optional(t.any()),
|
|
501
|
-
provider: t.text(),
|
|
502
|
-
subscribers: t.integer()
|
|
503
|
-
});
|
|
504
|
-
//#endregion
|
|
505
|
-
//#region ../../src/devtools/schemas/DevMetadata.ts
|
|
506
|
-
const devSystemSchema = t.object({
|
|
507
|
-
alephaVersion: t.text(),
|
|
508
|
-
nodeVersion: t.text(),
|
|
509
|
-
runtime: t.enum(["node", "bun"]),
|
|
510
|
-
mode: t.enum(["development", "production"]),
|
|
511
|
-
port: t.integer(),
|
|
512
|
-
uptime: t.number(),
|
|
513
|
-
memoryUsage: t.number()
|
|
514
|
-
});
|
|
515
|
-
const devMetadataSchema = t.object({
|
|
516
|
-
system: devSystemSchema,
|
|
517
|
-
actions: t.array(devActionMetadataSchema),
|
|
518
|
-
queues: t.array(devQueueMetadataSchema),
|
|
519
|
-
schedulers: t.array(devSchedulerMetadataSchema),
|
|
520
|
-
topics: t.array(devTopicMetadataSchema),
|
|
521
|
-
buckets: t.array(devBucketMetadataSchema),
|
|
522
|
-
realms: t.array(devRealmMetadataSchema),
|
|
523
|
-
caches: t.array(devCacheMetadataSchema),
|
|
524
|
-
pages: t.array(devPageMetadataSchema),
|
|
525
|
-
providers: t.array(devProviderMetadataSchema),
|
|
526
|
-
modules: t.array(devModuleMetadataSchema),
|
|
527
|
-
entities: t.array(devEntityMetadataSchema),
|
|
528
|
-
routes: t.array(devRouteMetadataSchema),
|
|
529
|
-
envs: t.array(devEnvMetadataSchema),
|
|
530
|
-
atoms: t.array(devAtomMetadataSchema)
|
|
531
|
-
});
|
|
532
|
-
//#endregion
|
|
533
|
-
//#region ../../src/devtools/providers/DevToolsProvider.ts
|
|
534
|
-
var DevToolsProvider = class {
|
|
535
|
-
log = $logger();
|
|
536
|
-
alepha = $inject(Alepha);
|
|
537
|
-
serverProvider = $inject(ServerProvider);
|
|
538
|
-
devCollectorProvider = $inject(DevToolsMetadataProvider);
|
|
539
|
-
memoryDestination = $inject(MemoryDestinationProvider);
|
|
540
|
-
onStart = $hook({
|
|
541
|
-
on: "start",
|
|
542
|
-
handler: () => {
|
|
543
|
-
this.log.info("Devtools OK", { url: `${this.serverProvider.hostname}/__devtools/` });
|
|
544
|
-
}
|
|
545
|
-
});
|
|
546
|
-
/**
|
|
547
|
-
* Capture all logs into memory so the devtools UI can display them.
|
|
548
|
-
* In dev mode, LogDestinationProvider is bound to ConsoleDestinationProvider,
|
|
549
|
-
* so MemoryDestinationProvider would otherwise never receive writes.
|
|
550
|
-
*/
|
|
551
|
-
onLog = $hook({
|
|
552
|
-
on: "log",
|
|
553
|
-
handler: ({ entry }) => {
|
|
554
|
-
this.memoryDestination.write("", entry);
|
|
555
|
-
}
|
|
556
|
-
});
|
|
557
|
-
uiRoute = $serve({
|
|
558
|
-
path: "/__devtools",
|
|
559
|
-
root: devtoolsAssets.ui,
|
|
560
|
-
historyApiFallback: true,
|
|
561
|
-
silent: true
|
|
562
|
-
});
|
|
563
|
-
metadataRoute = $route({
|
|
564
|
-
method: "GET",
|
|
565
|
-
path: "/__devtools/api/metadata",
|
|
566
|
-
silent: true,
|
|
567
|
-
schema: { response: devMetadataSchema },
|
|
568
|
-
handler: () => {
|
|
569
|
-
return this.devCollectorProvider.getMetadata();
|
|
570
|
-
}
|
|
571
|
-
});
|
|
572
|
-
updateAtomRoute = $route({
|
|
573
|
-
method: "POST",
|
|
574
|
-
path: "/__devtools/api/atoms",
|
|
575
|
-
silent: true,
|
|
576
|
-
schema: {
|
|
577
|
-
body: t.object({
|
|
578
|
-
name: t.text(),
|
|
579
|
-
value: t.any()
|
|
580
|
-
}),
|
|
581
|
-
response: t.object({ success: t.boolean() })
|
|
582
|
-
},
|
|
583
|
-
handler: ({ body }) => {
|
|
584
|
-
const atomEntry = this.alepha.store.getAtoms(false).find((a) => a.atom.key === body.name);
|
|
585
|
-
if (atomEntry) {
|
|
586
|
-
this.alepha.store.set(atomEntry.atom, body.value);
|
|
587
|
-
return { success: true };
|
|
588
|
-
}
|
|
589
|
-
return { success: false };
|
|
590
|
-
}
|
|
591
|
-
});
|
|
592
|
-
logsRoute = $route({
|
|
593
|
-
method: "GET",
|
|
594
|
-
path: "/__devtools/api/logs",
|
|
595
|
-
silent: true,
|
|
596
|
-
schema: {
|
|
597
|
-
query: t.object({
|
|
598
|
-
level: t.optional(t.text()),
|
|
599
|
-
type: t.optional(t.text()),
|
|
600
|
-
module: t.optional(t.text()),
|
|
601
|
-
search: t.optional(t.text()),
|
|
602
|
-
since: t.optional(t.text()),
|
|
603
|
-
limit: t.optional(t.text()),
|
|
604
|
-
offset: t.optional(t.text())
|
|
605
|
-
}),
|
|
606
|
-
response: t.object({
|
|
607
|
-
logs: t.array(t.any()),
|
|
608
|
-
total: t.integer()
|
|
609
|
-
})
|
|
610
|
-
},
|
|
611
|
-
handler: ({ query }) => {
|
|
612
|
-
const levelOrder = [
|
|
613
|
-
"TRACE",
|
|
614
|
-
"DEBUG",
|
|
615
|
-
"INFO",
|
|
616
|
-
"WARN",
|
|
617
|
-
"ERROR"
|
|
618
|
-
];
|
|
619
|
-
let entries = this.memoryDestination.logs;
|
|
620
|
-
if (query.level) {
|
|
621
|
-
const minIndex = levelOrder.indexOf(query.level.toUpperCase());
|
|
622
|
-
if (minIndex >= 0) entries = entries.filter((e) => levelOrder.indexOf(e.level) >= minIndex);
|
|
623
|
-
}
|
|
624
|
-
if (query.type) {
|
|
625
|
-
const types = query.type.split(",").map((t) => t.trim());
|
|
626
|
-
entries = entries.filter((e) => {
|
|
627
|
-
if (!e.data || typeof e.data !== "object") return false;
|
|
628
|
-
const d = e.data;
|
|
629
|
-
for (const t of types) if (t === "http" || t === "http:request") {
|
|
630
|
-
if (d.status && d.method && d.path && d.duration) return true;
|
|
631
|
-
} else if (t === "db" || t === "db:query") {
|
|
632
|
-
if (d.type === "db:query") return true;
|
|
633
|
-
} else if (d.type === t) return true;
|
|
634
|
-
return false;
|
|
635
|
-
});
|
|
636
|
-
}
|
|
637
|
-
if (query.module) entries = entries.filter((e) => e.module === query.module);
|
|
638
|
-
if (query.search) {
|
|
639
|
-
const terms = query.search.toLowerCase().split(/\s+/);
|
|
640
|
-
entries = entries.filter((e) => {
|
|
641
|
-
const text = `${e.message} ${e.module} ${e.service}`.toLowerCase();
|
|
642
|
-
return terms.every((term) => text.includes(term));
|
|
643
|
-
});
|
|
644
|
-
}
|
|
645
|
-
if (query.since) {
|
|
646
|
-
const since = Number(query.since);
|
|
647
|
-
if (!Number.isNaN(since)) entries = entries.filter((e) => e.timestamp >= since);
|
|
648
|
-
}
|
|
649
|
-
const total = entries.length;
|
|
650
|
-
entries = entries.reverse();
|
|
651
|
-
const offset = query.offset ? Number(query.offset) : 0;
|
|
652
|
-
const limit = query.limit ? Number(query.limit) : 100;
|
|
653
|
-
entries = entries.slice(offset, offset + limit);
|
|
654
|
-
return {
|
|
655
|
-
logs: entries,
|
|
656
|
-
total
|
|
657
|
-
};
|
|
658
|
-
}
|
|
659
|
-
});
|
|
660
|
-
dbListRoute = $route({
|
|
661
|
-
method: "GET",
|
|
662
|
-
path: "/__devtools/api/db/:entity/records",
|
|
663
|
-
silent: true,
|
|
664
|
-
schema: {
|
|
665
|
-
params: t.object({ entity: t.text() }),
|
|
666
|
-
query: t.object({
|
|
667
|
-
page: t.optional(t.text()),
|
|
668
|
-
size: t.optional(t.text()),
|
|
669
|
-
sort: t.optional(t.text())
|
|
670
|
-
}),
|
|
671
|
-
response: t.record(t.text(), t.any())
|
|
672
|
-
},
|
|
673
|
-
handler: async ({ params, query }) => {
|
|
674
|
-
const repo = this.getRepository(params.entity);
|
|
675
|
-
if (!repo) return {
|
|
676
|
-
content: [],
|
|
677
|
-
page: { totalElements: 0 }
|
|
678
|
-
};
|
|
679
|
-
return repo.paginate({
|
|
680
|
-
page: query.page ? Number(query.page) : 0,
|
|
681
|
-
size: query.size ? Number(query.size) : 50,
|
|
682
|
-
sort: query.sort || void 0
|
|
683
|
-
}, {}, { count: true });
|
|
684
|
-
}
|
|
685
|
-
});
|
|
686
|
-
dbCreateRoute = $route({
|
|
687
|
-
method: "POST",
|
|
688
|
-
path: "/__devtools/api/db/:entity/records",
|
|
689
|
-
silent: true,
|
|
690
|
-
schema: {
|
|
691
|
-
params: t.object({ entity: t.text() }),
|
|
692
|
-
body: t.record(t.text(), t.any()),
|
|
693
|
-
response: t.record(t.text(), t.any())
|
|
694
|
-
},
|
|
695
|
-
handler: async ({ params, body }) => {
|
|
696
|
-
const repo = this.getRepository(params.entity);
|
|
697
|
-
if (!repo) return { error: "Entity not found" };
|
|
698
|
-
return repo.create(body);
|
|
699
|
-
}
|
|
700
|
-
});
|
|
701
|
-
dbUpdateRoute = $route({
|
|
702
|
-
method: "PUT",
|
|
703
|
-
path: "/__devtools/api/db/:entity/records/:id",
|
|
704
|
-
silent: true,
|
|
705
|
-
schema: {
|
|
706
|
-
params: t.object({
|
|
707
|
-
entity: t.text(),
|
|
708
|
-
id: t.text()
|
|
709
|
-
}),
|
|
710
|
-
body: t.record(t.text(), t.any()),
|
|
711
|
-
response: t.record(t.text(), t.any())
|
|
712
|
-
},
|
|
713
|
-
handler: async ({ params, body }) => {
|
|
714
|
-
const repo = this.getRepository(params.entity);
|
|
715
|
-
if (!repo) return { error: "Entity not found" };
|
|
716
|
-
const idValue = this.parseId(repo, params.id);
|
|
717
|
-
return repo.updateById(idValue, body);
|
|
718
|
-
}
|
|
719
|
-
});
|
|
720
|
-
dbDeleteRoute = $route({
|
|
721
|
-
method: "DELETE",
|
|
722
|
-
path: "/__devtools/api/db/:entity/records/:id",
|
|
723
|
-
silent: true,
|
|
724
|
-
schema: {
|
|
725
|
-
params: t.object({
|
|
726
|
-
entity: t.text(),
|
|
727
|
-
id: t.text()
|
|
728
|
-
}),
|
|
729
|
-
response: t.record(t.text(), t.any())
|
|
730
|
-
},
|
|
731
|
-
handler: async ({ params }) => {
|
|
732
|
-
const repo = this.getRepository(params.entity);
|
|
733
|
-
if (!repo) return { error: "Entity not found" };
|
|
734
|
-
const idValue = this.parseId(repo, params.id);
|
|
735
|
-
return repo.deleteById(idValue);
|
|
736
|
-
}
|
|
737
|
-
});
|
|
738
|
-
getRepository(entityName) {
|
|
739
|
-
try {
|
|
740
|
-
return this.alepha.inject(RepositoryProvider).getRepositories().find((r) => r.entity.name === entityName);
|
|
741
|
-
} catch {
|
|
742
|
-
return;
|
|
743
|
-
}
|
|
744
|
-
}
|
|
745
|
-
parseId(repo, rawId) {
|
|
746
|
-
const idType = repo.id.type;
|
|
747
|
-
if (idType?.type === "integer" || idType?.type === "number") return Number(rawId);
|
|
748
|
-
return rawId;
|
|
749
|
-
}
|
|
750
|
-
};
|
|
751
|
-
//#endregion
|
|
752
|
-
//#region ../../src/devtools/index.ts
|
|
753
|
-
/**
|
|
754
|
-
* Runtime inspection and debugging UI.
|
|
755
|
-
*
|
|
756
|
-
* **Features:**
|
|
757
|
-
* - DevTools UI at `GET /devtools`
|
|
758
|
-
* - Application metadata at `GET /devtools/metadata`
|
|
759
|
-
* - Last 10,000 logs at `GET /devtools/logs`
|
|
760
|
-
* - Runtime inspection of actions, queues, schedulers, topics, buckets
|
|
761
|
-
* - Log viewer with filtering
|
|
762
|
-
* - React Flow visualization
|
|
763
|
-
* - Provider and module browsing
|
|
764
|
-
*
|
|
765
|
-
* @module alepha.devtools
|
|
766
|
-
*/
|
|
767
|
-
const AlephaDevtools = $module({
|
|
768
|
-
name: "alepha.devtools",
|
|
769
|
-
primitives: [],
|
|
770
|
-
services: [DevToolsMetadataProvider, DevToolsProvider],
|
|
771
|
-
register: (alepha) => {
|
|
772
|
-
alepha.with(AlephaServer);
|
|
773
|
-
alepha.with(AlephaServerStatic);
|
|
774
|
-
alepha.with(DevToolsProvider);
|
|
775
|
-
alepha.with(DevToolsMetadataProvider);
|
|
776
|
-
alepha.store.push("alepha.build.assets", "alepha");
|
|
777
|
-
}
|
|
778
|
-
});
|
|
779
|
-
//#endregion
|
|
780
|
-
export { AlephaDevtools, DevToolsMetadataProvider, devActionMetadataSchema, devAtomMetadataSchema, devBucketMetadataSchema, devCacheMetadataSchema, devEntityColumnSchema, devEntityConstraintSchema, devEntityForeignKeySchema, devEntityIndexSchema, devEntityMetadataSchema, devEnvMetadataSchema, devMetadataSchema, devModuleMetadataSchema, devPageMetadataSchema, devProviderMetadataSchema, devQueueMetadataSchema, devRealmMetadataSchema, devRouteMetadataSchema, devSchedulerMetadataSchema, devSystemSchema, devTopicMetadataSchema };
|
|
781
|
-
|
|
782
|
-
//# sourceMappingURL=index.js.map
|