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
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.browser.js","names":["pageSchema"],"sources":["../../../src/orm/core/errors/DbError.ts","../../../src/orm/core/errors/DbColumnNotFoundError.ts","../../../src/orm/core/errors/DbConnectionError.ts","../../../src/orm/core/errors/DbDeadlockError.ts","../../../src/orm/core/errors/DbEntityNotFoundError.ts","../../../src/orm/core/errors/DbForeignKeyError.ts","../../../src/orm/core/errors/DbNotNullError.ts","../../../src/orm/core/errors/DbTableNotFoundError.ts","../../../src/orm/core/helpers/parseQueryString.ts","../../../src/orm/core/helpers/pgAttr.ts","../../../src/orm/core/constants/PG_SYMBOLS.ts","../../../src/orm/core/schemas/insertSchema.ts","../../../src/orm/core/schemas/updateSchema.ts","../../../src/orm/core/primitives/$entity.ts","../../../src/orm/core/primitives/$view.ts","../../../src/orm/core/providers/DatabaseTypeProvider.ts","../../../src/orm/core/schemas/legacyIdSchema.ts","../../../src/orm/core/index.browser.ts"],"sourcesContent":["import { AlephaError } from \"alepha\";\n\nexport class DbError extends AlephaError {\n name = \"DbError\";\n\n constructor(message: string, cause?: unknown) {\n super(message, { cause });\n }\n}\n","import { DbError } from \"./DbError.ts\";\n\n/**\n * Error thrown when a column does not exist.\n *\n * This typically happens when:\n * - Column name is misspelled\n * - Migrations haven't been run\n * - Using wrong schema version\n */\nexport class DbColumnNotFoundError extends DbError {\n readonly name = \"DbColumnNotFoundError\";\n readonly status = 500;\n\n /**\n * The column that was not found.\n */\n readonly column?: string;\n\n /**\n * The table where the column was expected.\n */\n readonly table?: string;\n\n constructor(\n message: string,\n cause?: unknown,\n options?: { column?: string; table?: string },\n ) {\n super(message, cause);\n this.column = options?.column;\n this.table = options?.table;\n }\n\n /**\n * Parse a database column not found error and create a DbColumnNotFoundError.\n * Supports both PostgreSQL and SQLite error formats.\n */\n static fromDatabaseError(error: Error): DbColumnNotFoundError {\n const message = error.message;\n\n // PostgreSQL format:\n // 'column \"foo\" does not exist'\n // 'column \"foo\" of relation \"users\" does not exist'\n const pgMatch = message.match(\n /column \"([^\"]+)\"(?: of relation \"([^\"]+)\")? does not exist/,\n );\n\n if (pgMatch) {\n const column = pgMatch[1];\n const table = pgMatch[2];\n const msg = table\n ? `Column '${column}' does not exist in table '${table}'`\n : `Column '${column}' does not exist`;\n return new DbColumnNotFoundError(msg, error, { column, table });\n }\n\n // SQLite format:\n // 'no such column: foo'\n // 'no such column: users.foo'\n const sqliteMatch = message.match(/no such column: (?:(\\S+)\\.)?(\\S+)/);\n\n if (sqliteMatch) {\n const table = sqliteMatch[1];\n const column = sqliteMatch[2];\n const msg = table\n ? `Column '${column}' does not exist in table '${table}'`\n : `Column '${column}' does not exist`;\n return new DbColumnNotFoundError(msg, error, { column, table });\n }\n\n return new DbColumnNotFoundError(\"Column does not exist\", error);\n }\n}\n","import { DbError } from \"./DbError.ts\";\n\n/**\n * Error thrown when a database connection fails.\n *\n * This can happen due to:\n * - Connection refused (server not running)\n * - Connection timeout\n * - Authentication failure\n * - Network issues\n * - Database file not found (SQLite)\n */\nexport class DbConnectionError extends DbError {\n readonly name = \"DbConnectionError\";\n readonly status = 503;\n\n /**\n * The type of connection error.\n */\n readonly errorType?:\n | \"refused\"\n | \"timeout\"\n | \"auth\"\n | \"not_found\"\n | \"locked\"\n | \"unknown\";\n\n /**\n * Whether this error is retryable.\n * Connection errors are often transient and can be retried.\n */\n readonly retryable: boolean;\n\n constructor(\n message: string,\n cause?: unknown,\n options?: {\n errorType?: DbConnectionError[\"errorType\"];\n retryable?: boolean;\n },\n ) {\n super(message, cause);\n this.errorType = options?.errorType;\n this.retryable = options?.retryable ?? true;\n }\n\n /**\n * Parse a database connection error message and create a DbConnectionError.\n * Supports both PostgreSQL and SQLite error formats.\n */\n static fromDatabaseError(error: Error): DbConnectionError {\n const message = error.message.toLowerCase();\n\n // Connection refused\n if (\n message.includes(\"connection refused\") ||\n message.includes(\"econnrefused\") ||\n message.includes(\"could not connect\")\n ) {\n return new DbConnectionError(\n \"Database connection refused. Is the server running?\",\n error,\n { errorType: \"refused\", retryable: true },\n );\n }\n\n // Timeout\n if (\n message.includes(\"timeout\") ||\n message.includes(\"timed out\") ||\n message.includes(\"etimedout\")\n ) {\n return new DbConnectionError(\"Database connection timed out\", error, {\n errorType: \"timeout\",\n retryable: true,\n });\n }\n\n // Authentication\n if (\n message.includes(\"password authentication failed\") ||\n message.includes(\"authentication failed\") ||\n message.includes(\"access denied\")\n ) {\n return new DbConnectionError(\n \"Database authentication failed. Check credentials.\",\n error,\n { errorType: \"auth\", retryable: false },\n );\n }\n\n // SQLite file not found\n if (\n message.includes(\"unable to open database\") ||\n message.includes(\"no such file\") ||\n message.includes(\"enoent\")\n ) {\n return new DbConnectionError(\"Database file not found\", error, {\n errorType: \"not_found\",\n retryable: false,\n });\n }\n\n // SQLite database locked\n if (message.includes(\"database is locked\")) {\n return new DbConnectionError(\n \"Database is locked by another process\",\n error,\n { errorType: \"locked\", retryable: true },\n );\n }\n\n return new DbConnectionError(\"Failed to connect to database\", error, {\n errorType: \"unknown\",\n retryable: true,\n });\n }\n}\n","import { DbError } from \"./DbError.ts\";\n\n/**\n * Error thrown when a deadlock is detected.\n *\n * This happens when two or more transactions are waiting for each other\n * to release locks. The database automatically aborts one transaction\n * to resolve the deadlock.\n *\n * This error is useful for implementing retry logic.\n */\nexport class DbDeadlockError extends DbError {\n readonly name = \"DbDeadlockError\";\n readonly status = 409;\n\n /**\n * Whether this error is retryable.\n * Deadlocks are typically safe to retry.\n */\n readonly retryable = true;\n\n /**\n * Parse a database deadlock error message and create a DbDeadlockError.\n * Supports PostgreSQL. SQLite doesn't have true deadlocks (uses SQLITE_BUSY instead).\n */\n static fromDatabaseError(error: Error): DbDeadlockError {\n return new DbDeadlockError(\n \"Transaction deadlock detected. Please retry the operation.\",\n error,\n );\n }\n}\n","import { DbError } from \"./DbError.ts\";\n\nexport class DbEntityNotFoundError extends DbError {\n readonly name = \"DbEntityNotFoundError\";\n readonly status = 404;\n\n constructor(entityName: string) {\n super(`Entity from '${entityName}' was not found`);\n }\n}\n","import { DbError } from \"./DbError.ts\";\n\n/**\n * Error thrown when a foreign key constraint is violated.\n *\n * This typically happens when trying to delete an entity that is\n * referenced by another entity.\n */\nexport class DbForeignKeyError extends DbError {\n readonly name = \"DbForeignKeyError\";\n readonly status = 409;\n\n /**\n * The table that references the entity being deleted.\n */\n readonly referencingTable?: string;\n\n /**\n * The constraint name that was violated.\n */\n readonly constraintName?: string;\n\n constructor(\n message: string,\n cause?: unknown,\n options?: { referencingTable?: string; constraintName?: string },\n ) {\n super(message, cause);\n this.referencingTable = options?.referencingTable;\n this.constraintName = options?.constraintName;\n }\n\n /**\n * Parse a database foreign key error message and create a DbForeignKeyError.\n * Supports both PostgreSQL and SQLite error formats.\n */\n static fromDatabaseError(error: Error, tableName: string): DbForeignKeyError {\n const message = error.message;\n\n // PostgreSQL format:\n // 'violates foreign key constraint \"reporting_alert_query_id_fk\" on table \"reporting_alert\"'\n const pgMatch = message.match(\n /violates foreign key constraint \"([^\"]+)\" on table \"([^\"]+)\"/,\n );\n\n if (pgMatch) {\n const constraintName = pgMatch[1];\n const referencingTable = pgMatch[2];\n\n return new DbForeignKeyError(\n `Cannot delete ${tableName}: it is referenced by ${referencingTable}`,\n error,\n { referencingTable, constraintName },\n );\n }\n\n // SQLite format:\n // 'FOREIGN KEY constraint failed' (no table name available)\n return new DbForeignKeyError(\n `Cannot delete ${tableName}: it is referenced by another entity`,\n error,\n );\n }\n}\n","import { DbError } from \"./DbError.ts\";\n\n/**\n * Error thrown when a NOT NULL constraint is violated.\n *\n * This happens when inserting or updating a NULL value into a column\n * that has a NOT NULL constraint.\n */\nexport class DbNotNullError extends DbError {\n readonly name = \"DbNotNullError\";\n readonly status = 400;\n\n /**\n * The column that violated the NOT NULL constraint.\n */\n readonly column?: string;\n\n /**\n * The table containing the column.\n */\n readonly table?: string;\n\n constructor(\n message: string,\n cause?: unknown,\n options?: { column?: string; table?: string },\n ) {\n super(message, cause);\n this.column = options?.column;\n this.table = options?.table;\n }\n\n /**\n * Parse a database NOT NULL error message and create a DbNotNullError.\n * Supports both PostgreSQL and SQLite error formats.\n */\n static fromDatabaseError(error: Error, tableName: string): DbNotNullError {\n const message = error.message;\n\n // PostgreSQL format:\n // 'null value in column \"email\" of relation \"users\" violates not-null constraint'\n const pgMatch = message.match(\n /null value in column \"([^\"]+)\" of relation \"([^\"]+)\" violates not-null constraint/,\n );\n\n if (pgMatch) {\n const column = pgMatch[1];\n const table = pgMatch[2];\n return new DbNotNullError(\n `Column '${column}' in '${table}' cannot be null`,\n error,\n { column, table },\n );\n }\n\n // SQLite format:\n // 'NOT NULL constraint failed: users.email'\n const sqliteMatch = message.match(\n /NOT NULL constraint failed: ([^.]+)\\.(\\S+)/,\n );\n\n if (sqliteMatch) {\n const table = sqliteMatch[1];\n const column = sqliteMatch[2];\n return new DbNotNullError(\n `Column '${column}' in '${table}' cannot be null`,\n error,\n { column, table },\n );\n }\n\n return new DbNotNullError(\n `A required field in '${tableName}' cannot be null`,\n error,\n );\n }\n}\n","import { DbError } from \"./DbError.ts\";\n\n/**\n * Error thrown when a table does not exist.\n *\n * This typically happens when:\n * - Migrations haven't been run\n * - Table name is misspelled\n * - Wrong database/schema is being used\n */\nexport class DbTableNotFoundError extends DbError {\n readonly name = \"DbTableNotFoundError\";\n readonly status = 500;\n\n /**\n * The table that was not found.\n */\n readonly table?: string;\n\n constructor(message: string, cause?: unknown, options?: { table?: string }) {\n super(message, cause);\n this.table = options?.table;\n }\n\n /**\n * Parse a database table not found error and create a DbTableNotFoundError.\n * Supports both PostgreSQL and SQLite error formats.\n */\n static fromDatabaseError(error: Error): DbTableNotFoundError {\n const message = error.message;\n\n // PostgreSQL format:\n // 'relation \"users\" does not exist'\n const pgMatch = message.match(/relation \"([^\"]+)\" does not exist/);\n\n if (pgMatch) {\n const table = pgMatch[1];\n return new DbTableNotFoundError(\n `Table '${table}' does not exist. Have you run migrations?`,\n error,\n { table },\n );\n }\n\n // SQLite format:\n // 'no such table: users'\n const sqliteMatch = message.match(/no such table: (\\S+)/);\n\n if (sqliteMatch) {\n const table = sqliteMatch[1];\n return new DbTableNotFoundError(\n `Table '${table}' does not exist. Have you run migrations?`,\n error,\n { table },\n );\n }\n\n return new DbTableNotFoundError(\n \"Table does not exist. Have you run migrations?\",\n error,\n );\n }\n}\n","import { AlephaError, type TObject } from \"alepha\";\nimport type { PgQueryWhere } from \"../interfaces/PgQueryWhere.ts\";\n\n/**\n * Parse a string query into a PgQueryWhere object.\n *\n * Supported syntax:\n * - Simple equality: \"name=John\"\n * - Wildcard patterns: \"name=John*\" (startsWith), \"name=*John\" (endsWith), \"name=*John*\" (contains)\n * - Operators: \"age>18\", \"age>=18\", \"age<65\", \"age<=65\", \"status!=active\"\n * - NULL checks: \"deletedAt=null\", \"email!=null\"\n * - IN arrays: \"status=[pending,active]\"\n * - AND conditions: \"name=John&age>18\"\n * - OR conditions: \"name=John|email=john@example.com\"\n * - Nested AND/OR: \"(name=John|name=Jane)&age>18\"\n * - JSONB nested: \"profile.city=Paris\"\n *\n * @example\n * ```ts\n * // Simple equality\n * parseQueryString(\"name=John\")\n * // => { name: { eq: \"John\" } }\n *\n * // Wildcard patterns\n * parseQueryString(\"name=John*\") // startsWith\n * // => { name: { startsWith: \"John\" } }\n * parseQueryString(\"name=*Smith\") // endsWith\n * // => { name: { endsWith: \"Smith\" } }\n * parseQueryString(\"name=*oh*\") // contains\n * // => { name: { contains: \"oh\" } }\n *\n * // Multiple conditions\n * parseQueryString(\"name=John&age>18\")\n * // => { and: [{ name: { eq: \"John\" } }, { age: { gt: 18 } }] }\n *\n * // OR conditions\n * parseQueryString(\"status=active|status=pending\")\n * // => { or: [{ status: { eq: \"active\" } }, { status: { eq: \"pending\" } }] }\n *\n * // Complex nested\n * parseQueryString(\"(name=John|name=Jane)&age>18&status!=archived\")\n * // => { and: [\n * // { or: [{ name: { eq: \"John\" } }, { name: { eq: \"Jane\" } }] },\n * // { age: { gt: 18 } },\n * // { status: { ne: \"archived\" } }\n * // ] }\n *\n * // JSONB nested query\n * parseQueryString(\"profile.city=Paris&profile.age>25\")\n * // => { profile: { city: { eq: \"Paris\" }, age: { gt: 25 } } }\n * ```\n */\nexport function parseQueryString<T extends TObject>(\n query: string,\n): PgQueryWhere<T> {\n if (!query || query.trim() === \"\") {\n return {};\n }\n\n const parser = new QueryStringParser(query);\n return parser.parse() as PgQueryWhere<T>;\n}\n\n// ---------------------------------------------------------------------------------------------------------------------\n\nclass QueryStringParser {\n protected pos = 0;\n protected readonly query: string;\n\n constructor(query: string) {\n this.query = query.trim();\n }\n\n parse(): PgQueryWhere<any> {\n return this.parseExpression();\n }\n\n protected parseExpression(): PgQueryWhere<any> {\n return this.parseOr();\n }\n\n protected parseOr(): any {\n const left = this.parseAnd();\n\n // Check for OR operator (|)\n if (this.peek() === \"|\") {\n const conditions = [left];\n\n while (this.peek() === \"|\") {\n this.consume(\"|\");\n conditions.push(this.parseAnd());\n }\n\n return { or: conditions };\n }\n\n return left;\n }\n\n protected parseAnd(): any {\n const left = this.parsePrimary();\n\n // Check for AND operator (&)\n if (this.peek() === \"&\") {\n const conditions = [left];\n\n while (this.peek() === \"&\") {\n this.consume(\"&\");\n conditions.push(this.parsePrimary());\n }\n\n return { and: conditions };\n }\n\n return left;\n }\n\n protected parsePrimary(): any {\n this.skipWhitespace();\n\n // Handle parentheses\n if (this.peek() === \"(\") {\n this.consume(\"(\");\n const expr = this.parseExpression();\n this.consume(\")\");\n return expr;\n }\n\n // Parse field condition\n return this.parseCondition();\n }\n\n protected parseCondition(): any {\n const field = this.parseFieldPath();\n this.skipWhitespace();\n\n // Get operator\n const operator = this.parseOperator();\n this.skipWhitespace();\n\n // Get value\n const value = this.parseValue();\n\n if (value === \"\") {\n throw new AlephaError(`Expected value for field '${field.join(\".\")}'`);\n }\n\n // Build the condition object\n return this.buildCondition(field, operator, value);\n }\n\n protected parseFieldPath(): string[] {\n const path: string[] = [];\n let current = \"\";\n\n while (this.pos < this.query.length) {\n const ch = this.query[this.pos];\n\n if (ch === \".\" && current) {\n path.push(current);\n current = \"\";\n this.pos++;\n continue;\n }\n\n if (ch === \"=\" || ch === \"!\" || ch === \">\" || ch === \"<\" || ch === \" \") {\n break;\n }\n\n current += ch;\n this.pos++;\n }\n\n if (current) {\n path.push(current);\n }\n\n return path;\n }\n\n protected parseOperator(): string {\n this.skipWhitespace();\n\n const remaining = this.query.slice(this.pos);\n\n // Two-character operators\n if (remaining.startsWith(\">=\")) {\n this.pos += 2;\n return \">=\";\n }\n if (remaining.startsWith(\"<=\")) {\n this.pos += 2;\n return \"<=\";\n }\n if (remaining.startsWith(\"!=\")) {\n this.pos += 2;\n return \"!=\";\n }\n\n // Single-character operators\n const ch = this.query[this.pos];\n if (ch === \"=\" || ch === \">\" || ch === \"<\") {\n this.pos++;\n return ch;\n }\n\n throw new AlephaError(`Expected operator at position ${this.pos}`);\n }\n\n protected parseValue(): any {\n this.skipWhitespace();\n\n // Handle null\n if (this.query.slice(this.pos, this.pos + 4).toLowerCase() === \"null\") {\n this.pos += 4;\n return null;\n }\n\n // Handle arrays [value1,value2,...]\n if (this.query[this.pos] === \"[\") {\n return this.parseArray();\n }\n\n // Handle quoted strings\n if (this.query[this.pos] === '\"' || this.query[this.pos] === \"'\") {\n return this.parseQuotedString();\n }\n\n // Parse unquoted value (until &, |, or ))\n let value = \"\";\n while (this.pos < this.query.length) {\n const ch = this.query[this.pos];\n if (ch === \"&\" || ch === \"|\" || ch === \")\") {\n break;\n }\n value += ch;\n this.pos++;\n }\n\n return this.coerceValue(value.trim());\n }\n\n protected parseArray(): any[] {\n this.consume(\"[\");\n const values: any[] = [];\n\n while (this.pos < this.query.length && this.query[this.pos] !== \"]\") {\n this.skipWhitespace();\n\n // Handle quoted values\n if (this.query[this.pos] === '\"' || this.query[this.pos] === \"'\") {\n values.push(this.parseQuotedString());\n } else {\n // Parse until comma or ]\n let value = \"\";\n while (\n this.pos < this.query.length &&\n this.query[this.pos] !== \",\" &&\n this.query[this.pos] !== \"]\"\n ) {\n value += this.query[this.pos];\n this.pos++;\n }\n values.push(this.coerceValue(value.trim()));\n }\n\n this.skipWhitespace();\n if (this.query[this.pos] === \",\") {\n this.pos++;\n }\n }\n\n this.consume(\"]\");\n return values;\n }\n\n protected parseQuotedString(): string {\n const quote = this.query[this.pos];\n this.pos++; // Skip opening quote\n\n let value = \"\";\n let escaped = false;\n\n while (this.pos < this.query.length) {\n const ch = this.query[this.pos];\n\n if (escaped) {\n value += ch;\n escaped = false;\n this.pos++;\n continue;\n }\n\n if (ch === \"\\\\\") {\n escaped = true;\n this.pos++;\n continue;\n }\n\n if (ch === quote) {\n this.pos++; // Skip closing quote\n break;\n }\n\n value += ch;\n this.pos++;\n }\n\n return value;\n }\n\n protected coerceValue(value: string): any {\n // Try to parse as number\n if (/^-?\\d+$/.test(value)) {\n return parseInt(value, 10);\n }\n\n if (/^-?\\d+\\.\\d+$/.test(value)) {\n return parseFloat(value);\n }\n\n // Try to parse as boolean\n if (value.toLowerCase() === \"true\") {\n return true;\n }\n if (value.toLowerCase() === \"false\") {\n return false;\n }\n\n return value;\n }\n\n protected buildCondition(path: string[], operator: string, value: any): any {\n // Map operator to filter operator\n let filterOp: any;\n\n if (operator === \"=\") {\n if (value === null) {\n filterOp = { isNull: true };\n } else if (Array.isArray(value)) {\n // Arrays should be treated as inArray regardless of content\n filterOp = { inArray: value };\n } else if (typeof value === \"string\" && value.includes(\"*\")) {\n // Handle wildcard patterns\n const startsWithAsterisk = value.startsWith(\"*\");\n const endsWithAsterisk = value.endsWith(\"*\");\n const cleanValue = value.replace(/^\\*|\\*$/g, \"\"); // Remove leading/trailing asterisks\n\n if (startsWithAsterisk && endsWithAsterisk) {\n // *text* -> contains\n filterOp = { contains: cleanValue };\n } else if (startsWithAsterisk) {\n // *text -> endsWith\n filterOp = { endsWith: cleanValue };\n } else if (endsWithAsterisk) {\n // text* -> startsWith\n filterOp = { startsWith: cleanValue };\n } else {\n // Has asterisk in the middle, treat as literal\n filterOp = { eq: value };\n }\n } else {\n filterOp = { eq: value };\n }\n } else if (operator === \"!=\") {\n if (value === null) {\n filterOp = { isNotNull: true };\n } else {\n filterOp = { ne: value };\n }\n } else if (operator === \">\") {\n filterOp = { gt: value };\n } else if (operator === \">=\") {\n filterOp = { gte: value };\n } else if (operator === \"<\") {\n filterOp = { lt: value };\n } else if (operator === \"<=\") {\n filterOp = { lte: value };\n } else {\n throw new AlephaError(`Unsupported operator: ${operator}`);\n }\n\n // Build nested object for path\n if (path.length === 1) {\n return { [path[0]]: filterOp };\n }\n\n // Handle nested paths (JSONB)\n let result: any = filterOp;\n for (let i = path.length - 1; i >= 0; i--) {\n result = { [path[i]]: result };\n }\n\n return result;\n }\n\n protected peek(): string {\n this.skipWhitespace();\n return this.query[this.pos] || \"\";\n }\n\n protected consume(expected: string): void {\n this.skipWhitespace();\n if (this.query[this.pos] !== expected) {\n throw new AlephaError(\n `Expected '${expected}' at position ${this.pos}, got '${this.query[this.pos]}'`,\n );\n }\n this.pos++;\n }\n\n protected skipWhitespace(): void {\n while (this.pos < this.query.length && /\\s/.test(this.query[this.pos])) {\n this.pos++;\n }\n }\n}\n\n// ---------------------------------------------------------------------------------------------------------------------\n\n/**\n * Helper function to build query strings programmatically\n *\n * @example\n * ```ts\n * buildQueryString({\n * and: [\n * { name: \"eq:John\" },\n * { age: \"gt:18\" }\n * ]\n * })\n * // => \"name=John&age>18\"\n * ```\n */\nexport function buildQueryString(where: any): string {\n if (!where || typeof where !== \"object\") {\n return \"\";\n }\n\n // Handle logical operators\n if (\"and\" in where && Array.isArray(where.and)) {\n return where.and.map((w: any) => buildQueryString(w)).join(\"&\");\n }\n\n if (\"or\" in where && Array.isArray(where.or)) {\n const parts = where.or.map((w: any) => buildQueryString(w));\n return parts.length > 1 ? `(${parts.join(\"|\")})` : parts[0];\n }\n\n if (\"not\" in where) {\n // Not operator is harder to represent in string form\n // For now, we'll skip it or you could add a syntax like \"!field=value\"\n return \"\";\n }\n\n // Handle field conditions\n const parts: string[] = [];\n\n for (const [field, condition] of Object.entries(where)) {\n if (typeof condition !== \"object\" || condition === null) {\n parts.push(`${field}=${condition}`);\n continue;\n }\n\n if (\"eq\" in condition) {\n parts.push(`${field}=${condition.eq}`);\n } else if (\"ne\" in condition) {\n parts.push(`${field}!=${condition.ne}`);\n } else if (\"gt\" in condition) {\n parts.push(`${field}>${condition.gt}`);\n } else if (\"gte\" in condition) {\n parts.push(`${field}>=${condition.gte}`);\n } else if (\"lt\" in condition) {\n parts.push(`${field}<${condition.lt}`);\n } else if (\"lte\" in condition) {\n parts.push(`${field}<=${condition.lte}`);\n } else if (\"contains\" in condition) {\n parts.push(`${field}=*${condition.contains}*`);\n } else if (\"startsWith\" in condition) {\n parts.push(`${field}=${condition.startsWith}*`);\n } else if (\"endsWith\" in condition) {\n parts.push(`${field}=*${condition.endsWith}`);\n } else if (\"isNull\" in condition && condition.isNull) {\n parts.push(`${field}=null`);\n } else if (\"isNotNull\" in condition && condition.isNotNull) {\n parts.push(`${field}!=null`);\n } else if (\"inArray\" in condition && Array.isArray(condition.inArray)) {\n const values = condition.inArray.map((v: any) =>\n typeof v === \"string\" ? `\"${v}\"` : v,\n );\n parts.push(`${field}=[${values.join(\",\")}]`);\n } else {\n // Nested object (JSONB)\n const nested = buildQueryString(condition);\n if (nested) {\n parts.push(`${field}.${nested}`);\n }\n }\n }\n\n return parts.join(\"&\");\n}\n","import type { TObject, TSchema } from \"alepha\";\nimport type { PgSymbolKeys, PgSymbols } from \"../constants/PG_SYMBOLS.ts\";\n\n/**\n * Decorates a typebox schema with a Postgres attribute.\n *\n * > It's just a fancy way to add Symbols to a field.\n *\n * @example\n * ```ts\n * import { t } from \"alepha\";\n * import { PG_UPDATED_AT } from \"../constants/PG_SYMBOLS\";\n *\n * export const updatedAtSchema = pgAttr(\n * t.datetime(), PG_UPDATED_AT,\n * );\n * ```\n */\nexport const pgAttr = <T extends TSchema, Attr extends PgSymbolKeys>(\n type: T,\n attr: Attr,\n value?: PgSymbols[Attr],\n): PgAttr<T, Attr> => {\n Object.assign(type, { [attr]: value ?? {} });\n return type as PgAttr<T, Attr>;\n};\n\n/**\n * Retrieves the fields of a schema that have a specific attribute.\n */\nexport const getAttrFields = (\n schema: TObject,\n name: PgSymbolKeys,\n): PgAttrField[] => {\n const fields: Array<PgAttrField> = [];\n\n for (const key of Object.keys(schema.properties)) {\n const value = schema.properties[key];\n if (name in value) {\n fields.push({\n type: value as TSchema,\n key: key,\n data: (value as any)[name],\n });\n }\n }\n\n return fields;\n};\n\n/**\n * Type representation.\n */\nexport type PgAttr<T extends TSchema, TAttr extends PgSymbolKeys> = T & {\n [K in TAttr]: PgSymbols[K];\n};\n\nexport interface PgAttrField {\n key: string;\n type: TSchema;\n data: any;\n nested?: any[];\n one?: boolean;\n}\n","import type { SQL } from \"drizzle-orm\";\nimport type {\n PgSequenceOptions,\n UpdateDeleteAction,\n} from \"drizzle-orm/pg-core\";\nimport type { EntityPrimitive } from \"../primitives/$entity.ts\";\n\nexport const PG_DEFAULT = Symbol.for(\"Alepha.Postgres.Default\");\nexport const PG_PRIMARY_KEY = Symbol.for(\"Alepha.Postgres.PrimaryKey\");\nexport const PG_CREATED_AT = Symbol.for(\"Alepha.Postgres.CreatedAt\");\nexport const PG_UPDATED_AT = Symbol.for(\"Alepha.Postgres.UpdatedAt\");\nexport const PG_DELETED_AT = Symbol.for(\"Alepha.Postgres.DeletedAt\");\nexport const PG_VERSION = Symbol.for(\"Alepha.Postgres.Version\");\nexport const PG_IDENTITY = Symbol.for(\"Alepha.Postgres.Identity\");\nexport const PG_ENUM = Symbol.for(\"Alepha.Postgres.Enum\");\nexport const PG_REF = Symbol.for(\"Alepha.Postgres.Ref\");\nexport const PG_GENERATED = Symbol.for(\"Alepha.Postgres.Generated\");\n\n/**\n * @deprecated Use `PG_IDENTITY` instead.\n */\nexport const PG_SERIAL = Symbol.for(\"Alepha.Postgres.Serial\");\n\nexport type PgDefault = typeof PG_DEFAULT;\nexport type PgRef = typeof PG_REF;\nexport type PgPrimaryKey = typeof PG_PRIMARY_KEY;\n\nexport type PgSymbols = {\n [PG_DEFAULT]: {};\n [PG_PRIMARY_KEY]: {};\n [PG_CREATED_AT]: {};\n [PG_UPDATED_AT]: {};\n [PG_DELETED_AT]: {};\n [PG_VERSION]: {};\n [PG_IDENTITY]: PgIdentityOptions;\n [PG_REF]: PgRefOptions;\n [PG_ENUM]: PgEnumOptions;\n [PG_GENERATED]: PgGeneratedOptions;\n\n /**\n * @deprecated Use `PG_IDENTITY` instead.\n */\n [PG_SERIAL]: {};\n};\n\nexport type PgSymbolKeys = keyof PgSymbols;\n\nexport type PgIdentityOptions = {\n mode: \"always\" | \"byDefault\";\n} & PgSequenceOptions & {\n name?: string;\n };\n\nexport interface PgEnumOptions {\n name?: string;\n description?: string;\n}\n\nexport interface PgGeneratedOptions {\n /**\n * SQL expression for the generated column.\n */\n expression: SQL;\n\n /**\n * Storage mode for the generated column.\n * - `\"stored\"` — value is computed on write and stored on disk (default for PostgreSQL).\n * - `\"virtual\"` — value is computed on read (default for SQLite).\n */\n mode?: \"stored\" | \"virtual\";\n}\n\nexport interface PgRefOptions {\n ref: () => {\n name: string;\n entity: EntityPrimitive;\n };\n actions?: {\n onUpdate?: UpdateDeleteAction;\n onDelete?: UpdateDeleteAction;\n };\n}\n","import type { TObject, TOptional } from \"alepha\";\nimport { t } from \"alepha\";\nimport { PG_DEFAULT, PG_GENERATED } from \"../constants/PG_SYMBOLS.ts\";\n\n/**\n * Transforms a TObject schema for insert operations.\n * All default properties at the root level are made optional.\n * Generated columns are excluded entirely.\n *\n * @example\n * Before: { name: string; age: number(default=0); fullName: generated }\n * After: { name: string; age?: number; }\n */\nexport type TObjectInsert<T extends TObject> = TObject<{\n [K in keyof T[\"properties\"] as T[\"properties\"][K] extends {\n [PG_GENERATED]: any;\n }\n ? never\n : K]: T[\"properties\"][K] extends\n | { [PG_DEFAULT]: any }\n | { \"~optional\": true }\n ? TOptional<T[\"properties\"][K]>\n : T[\"properties\"][K];\n}>;\n\nexport const insertSchema = <T extends TObject>(obj: T): TObjectInsert<T> => {\n const newProperties: Record<string, any> = {};\n\n for (const key in obj.properties) {\n const prop = obj.properties[key];\n\n // Skip generated columns — they are computed by the database\n if (PG_GENERATED in prop) {\n continue;\n }\n\n if (PG_DEFAULT in prop) {\n newProperties[key] = t.optional(prop);\n } else {\n newProperties[key] = prop;\n }\n }\n\n return t.object(\n newProperties,\n \"options\" in obj && typeof obj.options === \"object\"\n ? { ...obj.options }\n : {},\n ) as TObjectInsert<T>;\n};\n","import {\n type TNull,\n type TObject,\n type TOptional,\n type TUnion,\n t,\n} from \"alepha\";\nimport { PG_GENERATED } from \"../constants/PG_SYMBOLS.ts\";\n\n/**\n * Transforms a TObject schema for update operations.\n * All optional properties at the root level are made nullable (i.e., `T | null`).\n * Generated columns are excluded entirely.\n *\n * @example\n * Before: { name?: string; age: number; fullName: generated }\n * After: { name?: string | null; age: number; }\n */\nexport type TObjectUpdate<T extends TObject> = TObject<{\n [K in keyof T[\"properties\"] as T[\"properties\"][K] extends {\n [PG_GENERATED]: any;\n }\n ? never\n : K]: T[\"properties\"][K] extends TOptional<infer U>\n ? TOptional<TUnion<[U, TNull]>>\n : T[\"properties\"][K];\n}>;\n\nexport const updateSchema = <T extends TObject>(\n schema: T,\n): TObjectUpdate<T> => {\n const newProperties: Record<string, any> = {};\n\n for (const key in schema.properties) {\n const prop = schema.properties[key];\n\n // Skip generated columns — they are computed by the database\n if (PG_GENERATED in prop) {\n continue;\n }\n\n if (t.schema.isOptional(prop)) {\n newProperties[key] = t.optional(t.union([prop, t.raw.Null()]));\n } else {\n newProperties[key] = prop;\n }\n }\n\n return t.object(\n newProperties,\n \"options\" in schema && typeof schema.options === \"object\"\n ? { ...schema.options }\n : {},\n ) as TObjectUpdate<T>;\n};\n","import { KIND, type Static, type TObject } from \"alepha\";\nimport type { BuildExtraConfigColumns, SQL } from \"drizzle-orm\";\nimport type {\n PgColumn,\n PgColumnBuilderBase,\n PgTableExtraConfigValue,\n} from \"drizzle-orm/pg-core\";\nimport { insertSchema, type TObjectInsert } from \"../schemas/insertSchema.ts\";\nimport { type TObjectUpdate, updateSchema } from \"../schemas/updateSchema.ts\";\n\n/**\n * Creates a database entity primitive that defines table structure using TypeBox schemas.\n *\n * @example\n * ```ts\n * import { t } from \"alepha\";\n * import { $entity } from \"alepha/orm\";\n *\n * const userEntity = $entity({\n * name: \"users\",\n * schema: t.object({\n * id: pg.primaryKey(),\n * name: t.text(),\n * email: t.email(),\n * }),\n * });\n * ```\n */\nexport const $entity = <TSchema extends TObject>(\n options: EntityPrimitiveOptions<TSchema>,\n): EntityPrimitive<TSchema> => {\n return new EntityPrimitive<TSchema>(options);\n};\n\n// ---------------------------------------------------------------------------------------------------------------------\n\nexport interface EntityPrimitiveOptions<\n T extends TObject,\n Keys = keyof Static<T>,\n> {\n /**\n * The database table name that will be created for this entity.\n * If not provided, name will be inferred from the $repository variable name.\n */\n name: string;\n\n /**\n * TypeBox schema defining the table structure and column types.\n */\n schema: T;\n\n /**\n * Database indexes to create for query optimization.\n */\n indexes?: (\n | Keys\n | {\n /**\n * Single column to index.\n */\n column: Keys;\n /**\n * Whether this should be a unique index (enforces uniqueness constraint).\n */\n unique?: boolean;\n /**\n * Custom name for the index. If not provided, generates name automatically.\n */\n name?: string;\n /**\n * Partial index condition. Only rows matching this SQL expression are indexed.\n */\n where?: SQL;\n }\n | {\n /**\n * Multiple columns for composite index (order matters for query optimization).\n */\n columns: Keys[];\n /**\n * Whether this should be a unique index (enforces uniqueness constraint).\n */\n unique?: boolean;\n /**\n * Custom name for the index. If not provided, generates name automatically.\n */\n name?: string;\n /**\n * Partial index condition. Only rows matching this SQL expression are indexed.\n */\n where?: SQL;\n }\n )[];\n\n /**\n * Foreign key constraints to maintain referential integrity.\n */\n foreignKeys?: Array<{\n /**\n * Optional name for the foreign key constraint.\n */\n name?: string;\n /**\n * Local columns that reference the foreign table.\n */\n columns: Array<keyof Static<T>>;\n /**\n * Referenced columns in the foreign table.\n * Must be EntityColumn references from other entities.\n */\n foreignColumns: Array<() => EntityColumn<any>>;\n }>;\n\n /**\n * Additional table constraints for data validation.\n *\n * Constraints enforce business rules at the database level, providing\n * an additional layer of data integrity beyond application validation.\n *\n * **Constraint Types**:\n * - **Unique constraints**: Prevent duplicate values across columns\n * - **Check constraints**: Enforce custom validation rules with SQL expressions\n *\n * @example\n * ```ts\n * constraints: [\n * {\n * name: \"unique_user_email\",\n * columns: [\"email\"],\n * unique: true\n * },\n * {\n * name: \"valid_age_range\",\n * columns: [\"age\"],\n * check: sql`age >= 0 AND age <= 150`\n * },\n * {\n * name: \"unique_user_username_per_tenant\",\n * columns: [\"tenantId\", \"username\"],\n * unique: true\n * }\n * ]\n * ```\n */\n constraints?: Array<{\n /**\n * Columns involved in this constraint.\n */\n columns: Array<keyof Static<T>>;\n /**\n * Optional name for the constraint.\n */\n name?: string;\n /**\n * Whether this is a unique constraint.\n */\n unique?: boolean | {} /* options */;\n /**\n * SQL expression for check constraint validation.\n */\n check?: SQL;\n }>;\n\n /**\n * Advanced Drizzle ORM configuration for complex table setups.\n */\n config?: (\n self: BuildExtraConfigColumns<string, FromSchema<T>, \"pg\">,\n ) => PgTableExtraConfigValue[];\n}\n\n// ---------------------------------------------------------------------------------------------------------------------\n\nexport class EntityPrimitive<T extends TObject = TObject> {\n public readonly options: EntityPrimitiveOptions<T>;\n\n constructor(options: EntityPrimitiveOptions<T>) {\n this.options = options;\n }\n\n alias(alias: string): this {\n const aliased = new EntityPrimitive<T>(this.options);\n return new Proxy(aliased, {\n get(target, prop, receiver) {\n if (prop === \"$alias\") {\n return alias;\n }\n return Reflect.get(target, prop, receiver);\n },\n }) as this;\n }\n\n get cols(): EntityColumns<T> {\n const cols: Partial<EntityColumns<T>> = {};\n for (const key of Object.keys(this.schema.properties) as Array<\n keyof T[\"properties\"]\n >) {\n cols[key] = {\n name: key as string,\n entity: this,\n };\n }\n\n return cols as EntityColumns<T>;\n }\n\n get name(): string {\n return this.options.name;\n }\n\n get schema(): T {\n return this.options.schema;\n }\n\n get insertSchema(): TObjectInsert<T> {\n return insertSchema(this.options.schema);\n }\n\n get updateSchema(): TObjectUpdate<T> {\n return updateSchema(this.options.schema);\n }\n}\n\n$entity[KIND] = EntityPrimitive;\n\n// ---------------------------------------------------------------------------------------------------------------------\n\n/**\n * Convert a schema to columns.\n */\nexport type FromSchema<T extends TObject> = {\n [key in keyof T[\"properties\"]]: PgColumnBuilderBase;\n};\n\nexport type SchemaToTableConfig<T extends TObject> = {\n name: string;\n schema: string | undefined;\n columns: {\n [key in keyof T[\"properties\"]]: PgColumn;\n };\n dialect: string;\n};\n\nexport type EntityColumn<T extends TObject> = {\n name: string;\n entity: EntityPrimitive<T>;\n};\n\nexport type EntityColumns<T extends TObject> = {\n [key in keyof T[\"properties\"]]: EntityColumn<T>;\n};\n","import { KIND, type TObject } from \"alepha\";\nimport type { SQL } from \"drizzle-orm\";\n\n/**\n * Creates a database view primitive from a TypeBox schema and SQL query.\n *\n * Views are read-only: Repository blocks all write operations.\n *\n * @example\n * ```ts\n * import { t } from \"alepha\";\n * import { $view } from \"alepha/orm\";\n * import { sql } from \"drizzle-orm\";\n *\n * const userSummary = $view({\n * name: \"user_summary\",\n * schema: t.object({\n * id: t.uuid(),\n * fullName: t.text(),\n * orderCount: t.integer(),\n * }),\n * query: sql`SELECT u.id, u.first_name || ' ' || u.last_name AS full_name, COUNT(o.id) AS order_count FROM users u LEFT JOIN orders o ON o.user_id = u.id GROUP BY u.id`,\n * });\n *\n * // Materialized view (PostgreSQL only)\n * const monthlyStats = $view({\n * name: \"monthly_stats\",\n * schema: t.object({ ... }),\n * query: sql`...`,\n * materialized: true,\n * });\n * ```\n */\nexport const $view = <TSchema extends TObject>(\n options: ViewPrimitiveOptions<TSchema>,\n): ViewPrimitive<TSchema> => {\n return new ViewPrimitive<TSchema>(options);\n};\n\n// ---------------------------------------------------------------------------------------------------------------------\n\nexport interface ViewPrimitiveOptions<T extends TObject> {\n /**\n * The database view name.\n */\n name: string;\n\n /**\n * TypeBox schema defining the view's columns.\n */\n schema: T;\n\n /**\n * SQL query that defines the view.\n */\n query: SQL;\n\n /**\n * Whether this is a materialized view (PostgreSQL only).\n * Materialized views store results on disk and can be refreshed.\n */\n materialized?: boolean;\n}\n\n// ---------------------------------------------------------------------------------------------------------------------\n\nexport class ViewPrimitive<T extends TObject = TObject> {\n public readonly options: ViewPrimitiveOptions<T>;\n public readonly isView = true;\n\n constructor(options: ViewPrimitiveOptions<T>) {\n this.options = options;\n }\n\n get name(): string {\n return this.options.name;\n }\n\n get schema(): T {\n return this.options.schema;\n }\n\n get materialized(): boolean {\n return this.options.materialized ?? false;\n }\n}\n\n$view[KIND] = ViewPrimitive;\n","import {\n AlephaError,\n pageSchema,\n type Static,\n type TBigInt,\n type TInteger,\n type TNumber,\n type TNumberOptions,\n type TObject,\n type TObjectOptions,\n type TPage,\n type TSchema,\n type TString,\n type TStringOptions,\n type TUnsafe,\n t,\n} from \"alepha\";\nimport type { UpdateDeleteAction } from \"drizzle-orm/pg-core/foreign-keys\";\nimport {\n PG_CREATED_AT,\n PG_DEFAULT,\n PG_DELETED_AT,\n PG_ENUM,\n PG_IDENTITY,\n PG_PRIMARY_KEY,\n PG_REF,\n PG_UPDATED_AT,\n PG_VERSION,\n type PgDefault,\n type PgEnumOptions,\n type PgIdentityOptions,\n type PgPrimaryKey,\n type PgRef,\n} from \"../constants/PG_SYMBOLS.ts\";\nimport type { PgAttr } from \"../helpers/pgAttr.ts\";\nimport { pgAttr } from \"../helpers/pgAttr.ts\";\n\nexport class DatabaseTypeProvider {\n public readonly attr = pgAttr;\n\n /**\n * Creates a primary key with an identity column.\n */\n public readonly identityPrimaryKey = (\n identity?: PgIdentityOptions,\n options?: TNumberOptions,\n ) =>\n pgAttr(\n pgAttr(pgAttr(t.integer(options), PG_PRIMARY_KEY), PG_IDENTITY, identity),\n PG_DEFAULT,\n );\n\n /**\n * Creates a primary key with a big identity column. (default)\n */\n public readonly bigIdentityPrimaryKey = (\n identity?: PgIdentityOptions,\n options?: TNumberOptions,\n ) =>\n pgAttr(\n pgAttr(pgAttr(t.int64(options), PG_PRIMARY_KEY), PG_IDENTITY, identity),\n PG_DEFAULT,\n );\n\n /**\n * Creates a primary key with a UUID column.\n */\n public readonly uuidPrimaryKey = () =>\n pgAttr(pgAttr(t.uuid(), PG_PRIMARY_KEY), PG_DEFAULT);\n\n /**\n * Creates a primary key for a given type. Supports:\n * - `t.integer()` -> PG INT (default)\n * - `t.bigint()` -> PG BIGINT\n * - `t.uuid()` -> PG UUID\n */\n public primaryKey(): PgAttr<PgAttr<TInteger, PgPrimaryKey>, PgDefault>;\n public primaryKey(\n type: TString,\n options?: TStringOptions,\n ): PgAttr<PgAttr<TString, PgPrimaryKey>, PgDefault>;\n public primaryKey(\n type: TInteger,\n options?: TNumberOptions,\n identity?: PgIdentityOptions,\n ): PgAttr<PgAttr<TInteger, PgPrimaryKey>, PgDefault>;\n public primaryKey(\n type: TNumber,\n options?: TNumberOptions,\n identity?: PgIdentityOptions,\n ): PgAttr<PgAttr<TNumber, PgPrimaryKey>, PgDefault>;\n public primaryKey(\n type: TBigInt,\n options?: TNumberOptions,\n identity?: PgIdentityOptions,\n ): PgAttr<PgAttr<TBigInt, PgPrimaryKey>, PgDefault>;\n public primaryKey(\n type?: TSchema,\n options?: TNumberOptions | TStringOptions,\n identity?: PgIdentityOptions,\n ): PgAttr<PgAttr<TSchema, PgPrimaryKey>, PgDefault> {\n if (!type || t.schema.isInteger(type)) {\n return pgAttr(\n pgAttr(\n pgAttr(t.integer(options), PG_PRIMARY_KEY),\n PG_IDENTITY,\n identity,\n ),\n PG_DEFAULT,\n );\n }\n\n if (t.schema.isString(type) && type.format === \"uuid\") {\n return pgAttr(pgAttr(t.uuid(), PG_PRIMARY_KEY), PG_DEFAULT);\n }\n\n if (t.schema.isNumber(type) && type.format === \"int64\") {\n return pgAttr(\n pgAttr(\n pgAttr(t.number(options), PG_PRIMARY_KEY),\n PG_IDENTITY,\n identity,\n ),\n PG_DEFAULT,\n );\n }\n\n if (t.schema.isBigInt(type)) {\n return pgAttr(\n pgAttr(\n pgAttr(t.bigint(options), PG_PRIMARY_KEY),\n PG_IDENTITY,\n identity,\n ),\n PG_DEFAULT,\n );\n }\n\n throw new AlephaError(`Unsupported type for primary key: ${type}`);\n }\n\n /**\n * Wrap a schema with \"default\" attribute.\n * This is used to set a default value for a column in the database.\n */\n public readonly default = <T extends TSchema>(\n type: T,\n value?: Static<T>,\n ): PgAttr<T, PgDefault> => {\n if (value != null) {\n Object.assign(type, { default: value });\n }\n\n return this.attr(type, PG_DEFAULT);\n };\n\n /**\n * Creates a column 'version'.\n *\n * This is used to track the version of a row in the database.\n *\n * You can use it for optimistic concurrency control (OCC) with {@link RepositoryPrimitive#save}.\n *\n * @see {@link RepositoryPrimitive#save}\n * @see {@link PgVersionMismatchError}\n */\n public readonly version = (options: TNumberOptions = {}) =>\n this.default(pgAttr(t.integer(options), PG_VERSION), 0);\n\n /**\n * Creates a column Created At. So just a datetime column with a default value of the current timestamp.\n */\n public readonly createdAt = (options?: TStringOptions) =>\n pgAttr(pgAttr(t.datetime(options), PG_CREATED_AT), PG_DEFAULT);\n\n /**\n * Creates a column Updated At. Like createdAt, but it is updated on every update of the row.\n */\n public readonly updatedAt = (options?: TStringOptions) =>\n pgAttr(pgAttr(t.datetime(options), PG_UPDATED_AT), PG_DEFAULT);\n\n /**\n * Creates a column Deleted At for soft delete functionality.\n * This is used to mark rows as deleted without actually removing them from the database.\n * The column is nullable - NULL means not deleted, timestamp means deleted.\n */\n public readonly deletedAt = (options?: TStringOptions) =>\n pgAttr(t.optional(t.datetime(options)), PG_DELETED_AT);\n\n /**\n * Creates a Postgres ENUM type.\n *\n * > By default, `t.enum()` is mapped to a TEXT column in Postgres.\n * > Using this method, you can create a real ENUM type in the database.\n *\n * @example\n * ```ts\n * const statusEnum = pg.enum([\"pending\", \"active\", \"archived\"], { name: \"status_enum\" });\n * ```\n */\n public readonly enum = <T extends string[]>(\n values: [...T],\n pgEnumOptions?: PgEnumOptions,\n typeOptions?: TStringOptions,\n ): PgAttr<TUnsafe<T[number]>, typeof PG_ENUM> => {\n return pgAttr(\n t.enum(values, {\n description: pgEnumOptions?.description,\n ...typeOptions,\n }),\n PG_ENUM,\n pgEnumOptions,\n );\n };\n\n /**\n * Creates a reference to another table or schema. Basically a foreign key.\n */\n public readonly ref = <T extends TSchema>(\n type: T,\n ref: () => any,\n actions?: {\n onUpdate?: UpdateDeleteAction;\n onDelete?: UpdateDeleteAction;\n },\n ): PgAttr<T, PgRef> => {\n // If actions are not provided, set default onDelete based on type\n const finalActions = actions ?? {\n onDelete: t.schema.isOptional(type) ? \"set null\" : \"cascade\",\n };\n\n return this.attr(type, PG_REF, {\n ref,\n actions: finalActions,\n });\n };\n\n // -------------------------------------------------------------------------------------------------------------------\n\n /**\n * Creates a page schema for a given object schema.\n * It's used by {@link Repository#paginate} method.\n */\n public readonly page = <T extends TObject>(\n resource: T,\n options?: TObjectOptions,\n ): TPage<T> => {\n return pageSchema(resource, options);\n };\n}\n\n/**\n * Wrapper of TypeProvider (`t`) for database types.\n *\n * Use `db` for improve TypeBox schema definitions with database-specific attributes.\n *\n * @example\n * ```ts\n * import { t } from \"alepha\";\n * import { db } from \"alepha/orm\";\n *\n * const userSchema = t.object({\n * id: db.primaryKey(t.uuid()),\n * email: t.email(),\n * createdAt: db.createdAt(),\n * });\n * ```\n */\nexport const db = new DatabaseTypeProvider();\n","import { t } from \"alepha\";\nimport {\n PG_DEFAULT,\n PG_PRIMARY_KEY,\n PG_SERIAL,\n} from \"../constants/PG_SYMBOLS.ts\";\nimport { pgAttr } from \"../helpers/pgAttr.ts\";\n\n/**\n * @deprecated Use `pg.primaryKey()` instead.\n */\nexport const legacyIdSchema = pgAttr(\n pgAttr(pgAttr(t.integer(), PG_PRIMARY_KEY), PG_SERIAL),\n PG_DEFAULT,\n);\n","import { $module } from \"alepha\";\nimport { AlephaDateTime } from \"alepha/datetime\";\n\nexport * from \"./index.shared.ts\";\n\nexport const AlephaOrm = $module({\n name: \"alepha.orm\",\n primitives: [],\n services: [AlephaDateTime],\n});\n"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"index.browser.js","names":["pageSchema"],"sources":["../../../src/orm/core/errors/DbError.ts","../../../src/orm/core/errors/DbColumnNotFoundError.ts","../../../src/orm/core/errors/DbConnectionError.ts","../../../src/orm/core/errors/DbDeadlockError.ts","../../../src/orm/core/errors/DbEntityNotFoundError.ts","../../../src/orm/core/errors/DbForeignKeyError.ts","../../../src/orm/core/errors/DbNotNullError.ts","../../../src/orm/core/errors/DbTableNotFoundError.ts","../../../src/orm/core/helpers/parseQueryString.ts","../../../src/orm/core/helpers/pgAttr.ts","../../../src/orm/core/constants/PG_SYMBOLS.ts","../../../src/orm/core/schemas/insertSchema.ts","../../../src/orm/core/schemas/updateSchema.ts","../../../src/orm/core/primitives/$entity.ts","../../../src/orm/core/primitives/$view.ts","../../../src/orm/core/providers/DatabaseTypeProvider.ts","../../../src/orm/core/schemas/legacyIdSchema.ts","../../../src/orm/core/index.browser.ts"],"sourcesContent":["import { AlephaError } from \"alepha\";\n\nexport class DbError extends AlephaError {\n name = \"DbError\";\n\n constructor(message: string, cause?: unknown) {\n super(message, { cause });\n }\n}\n","import { DbError } from \"./DbError.ts\";\n\n/**\n * Error thrown when a column does not exist.\n *\n * This typically happens when:\n * - Column name is misspelled\n * - Migrations haven't been run\n * - Using wrong schema version\n */\nexport class DbColumnNotFoundError extends DbError {\n readonly name = \"DbColumnNotFoundError\";\n readonly status = 500;\n\n /**\n * The column that was not found.\n */\n readonly column?: string;\n\n /**\n * The table where the column was expected.\n */\n readonly table?: string;\n\n constructor(\n message: string,\n cause?: unknown,\n options?: { column?: string; table?: string },\n ) {\n super(message, cause);\n this.column = options?.column;\n this.table = options?.table;\n }\n\n /**\n * Parse a database column not found error and create a DbColumnNotFoundError.\n * Supports both PostgreSQL and SQLite error formats.\n */\n static fromDatabaseError(error: Error): DbColumnNotFoundError {\n const message = error.message;\n\n // PostgreSQL format:\n // 'column \"foo\" does not exist'\n // 'column \"foo\" of relation \"users\" does not exist'\n const pgMatch = message.match(\n /column \"([^\"]+)\"(?: of relation \"([^\"]+)\")? does not exist/,\n );\n\n if (pgMatch) {\n const column = pgMatch[1];\n const table = pgMatch[2];\n const msg = table\n ? `Column '${column}' does not exist in table '${table}'`\n : `Column '${column}' does not exist`;\n return new DbColumnNotFoundError(msg, error, { column, table });\n }\n\n // SQLite format:\n // 'no such column: foo'\n // 'no such column: users.foo'\n const sqliteMatch = message.match(/no such column: (?:(\\S+)\\.)?(\\S+)/);\n\n if (sqliteMatch) {\n const table = sqliteMatch[1];\n const column = sqliteMatch[2];\n const msg = table\n ? `Column '${column}' does not exist in table '${table}'`\n : `Column '${column}' does not exist`;\n return new DbColumnNotFoundError(msg, error, { column, table });\n }\n\n return new DbColumnNotFoundError(\"Column does not exist\", error);\n }\n}\n","import { DbError } from \"./DbError.ts\";\n\n/**\n * Error thrown when a database connection fails.\n *\n * This can happen due to:\n * - Connection refused (server not running)\n * - Connection timeout\n * - Authentication failure\n * - Network issues\n * - Database file not found (SQLite)\n */\nexport class DbConnectionError extends DbError {\n readonly name = \"DbConnectionError\";\n readonly status = 503;\n\n /**\n * The type of connection error.\n */\n readonly errorType?:\n | \"refused\"\n | \"timeout\"\n | \"auth\"\n | \"not_found\"\n | \"locked\"\n | \"unknown\";\n\n /**\n * Whether this error is retryable.\n * Connection errors are often transient and can be retried.\n */\n readonly retryable: boolean;\n\n constructor(\n message: string,\n cause?: unknown,\n options?: {\n errorType?: DbConnectionError[\"errorType\"];\n retryable?: boolean;\n },\n ) {\n super(message, cause);\n this.errorType = options?.errorType;\n this.retryable = options?.retryable ?? true;\n }\n\n /**\n * Parse a database connection error message and create a DbConnectionError.\n * Supports both PostgreSQL and SQLite error formats.\n */\n static fromDatabaseError(error: Error): DbConnectionError {\n const message = error.message.toLowerCase();\n\n // Connection refused\n if (\n message.includes(\"connection refused\") ||\n message.includes(\"econnrefused\") ||\n message.includes(\"could not connect\")\n ) {\n return new DbConnectionError(\n \"Database connection refused. Is the server running?\",\n error,\n { errorType: \"refused\", retryable: true },\n );\n }\n\n // Timeout\n if (\n message.includes(\"timeout\") ||\n message.includes(\"timed out\") ||\n message.includes(\"etimedout\")\n ) {\n return new DbConnectionError(\"Database connection timed out\", error, {\n errorType: \"timeout\",\n retryable: true,\n });\n }\n\n // Authentication\n if (\n message.includes(\"password authentication failed\") ||\n message.includes(\"authentication failed\") ||\n message.includes(\"access denied\")\n ) {\n return new DbConnectionError(\n \"Database authentication failed. Check credentials.\",\n error,\n { errorType: \"auth\", retryable: false },\n );\n }\n\n // SQLite file not found\n if (\n message.includes(\"unable to open database\") ||\n message.includes(\"no such file\") ||\n message.includes(\"enoent\")\n ) {\n return new DbConnectionError(\"Database file not found\", error, {\n errorType: \"not_found\",\n retryable: false,\n });\n }\n\n // SQLite database locked\n if (message.includes(\"database is locked\")) {\n return new DbConnectionError(\n \"Database is locked by another process\",\n error,\n { errorType: \"locked\", retryable: true },\n );\n }\n\n return new DbConnectionError(\"Failed to connect to database\", error, {\n errorType: \"unknown\",\n retryable: true,\n });\n }\n}\n","import { DbError } from \"./DbError.ts\";\n\n/**\n * Error thrown when a deadlock is detected.\n *\n * This happens when two or more transactions are waiting for each other\n * to release locks. The database automatically aborts one transaction\n * to resolve the deadlock.\n *\n * This error is useful for implementing retry logic.\n */\nexport class DbDeadlockError extends DbError {\n readonly name = \"DbDeadlockError\";\n readonly status = 409;\n\n /**\n * Whether this error is retryable.\n * Deadlocks are typically safe to retry.\n */\n readonly retryable = true;\n\n /**\n * Parse a database deadlock error message and create a DbDeadlockError.\n * Supports PostgreSQL. SQLite doesn't have true deadlocks (uses SQLITE_BUSY instead).\n */\n static fromDatabaseError(error: Error): DbDeadlockError {\n return new DbDeadlockError(\n \"Transaction deadlock detected. Please retry the operation.\",\n error,\n );\n }\n}\n","import { DbError } from \"./DbError.ts\";\n\nexport class DbEntityNotFoundError extends DbError {\n readonly name = \"DbEntityNotFoundError\";\n readonly status = 404;\n\n constructor(entityName: string) {\n super(`Entity from '${entityName}' was not found`);\n }\n}\n","import { DbError } from \"./DbError.ts\";\n\n/**\n * Error thrown when a foreign key constraint is violated.\n *\n * This typically happens when trying to delete an entity that is\n * referenced by another entity.\n */\nexport class DbForeignKeyError extends DbError {\n readonly name = \"DbForeignKeyError\";\n readonly status = 409;\n\n /**\n * The table that references the entity being deleted.\n */\n readonly referencingTable?: string;\n\n /**\n * The constraint name that was violated.\n */\n readonly constraintName?: string;\n\n constructor(\n message: string,\n cause?: unknown,\n options?: { referencingTable?: string; constraintName?: string },\n ) {\n super(message, cause);\n this.referencingTable = options?.referencingTable;\n this.constraintName = options?.constraintName;\n }\n\n /**\n * Parse a database foreign key error message and create a DbForeignKeyError.\n * Supports both PostgreSQL and SQLite error formats.\n */\n static fromDatabaseError(error: Error, tableName: string): DbForeignKeyError {\n const message = error.message;\n\n // PostgreSQL format:\n // 'violates foreign key constraint \"reporting_alert_query_id_fk\" on table \"reporting_alert\"'\n const pgMatch = message.match(\n /violates foreign key constraint \"([^\"]+)\" on table \"([^\"]+)\"/,\n );\n\n if (pgMatch) {\n const constraintName = pgMatch[1];\n const referencingTable = pgMatch[2];\n\n return new DbForeignKeyError(\n `Cannot delete ${tableName}: it is referenced by ${referencingTable}`,\n error,\n { referencingTable, constraintName },\n );\n }\n\n // SQLite format:\n // 'FOREIGN KEY constraint failed' (no table name available)\n return new DbForeignKeyError(\n `Cannot delete ${tableName}: it is referenced by another entity`,\n error,\n );\n }\n}\n","import { DbError } from \"./DbError.ts\";\n\n/**\n * Error thrown when a NOT NULL constraint is violated.\n *\n * This happens when inserting or updating a NULL value into a column\n * that has a NOT NULL constraint.\n */\nexport class DbNotNullError extends DbError {\n readonly name = \"DbNotNullError\";\n readonly status = 400;\n\n /**\n * The column that violated the NOT NULL constraint.\n */\n readonly column?: string;\n\n /**\n * The table containing the column.\n */\n readonly table?: string;\n\n constructor(\n message: string,\n cause?: unknown,\n options?: { column?: string; table?: string },\n ) {\n super(message, cause);\n this.column = options?.column;\n this.table = options?.table;\n }\n\n /**\n * Parse a database NOT NULL error message and create a DbNotNullError.\n * Supports both PostgreSQL and SQLite error formats.\n */\n static fromDatabaseError(error: Error, tableName: string): DbNotNullError {\n const message = error.message;\n\n // PostgreSQL format:\n // 'null value in column \"email\" of relation \"users\" violates not-null constraint'\n const pgMatch = message.match(\n /null value in column \"([^\"]+)\" of relation \"([^\"]+)\" violates not-null constraint/,\n );\n\n if (pgMatch) {\n const column = pgMatch[1];\n const table = pgMatch[2];\n return new DbNotNullError(\n `Column '${column}' in '${table}' cannot be null`,\n error,\n { column, table },\n );\n }\n\n // SQLite format:\n // 'NOT NULL constraint failed: users.email'\n const sqliteMatch = message.match(\n /NOT NULL constraint failed: ([^.]+)\\.(\\S+)/,\n );\n\n if (sqliteMatch) {\n const table = sqliteMatch[1];\n const column = sqliteMatch[2];\n return new DbNotNullError(\n `Column '${column}' in '${table}' cannot be null`,\n error,\n { column, table },\n );\n }\n\n return new DbNotNullError(\n `A required field in '${tableName}' cannot be null`,\n error,\n );\n }\n}\n","import { DbError } from \"./DbError.ts\";\n\n/**\n * Error thrown when a table does not exist.\n *\n * This typically happens when:\n * - Migrations haven't been run\n * - Table name is misspelled\n * - Wrong database/schema is being used\n */\nexport class DbTableNotFoundError extends DbError {\n readonly name = \"DbTableNotFoundError\";\n readonly status = 500;\n\n /**\n * The table that was not found.\n */\n readonly table?: string;\n\n constructor(message: string, cause?: unknown, options?: { table?: string }) {\n super(message, cause);\n this.table = options?.table;\n }\n\n /**\n * Parse a database table not found error and create a DbTableNotFoundError.\n * Supports both PostgreSQL and SQLite error formats.\n */\n static fromDatabaseError(error: Error): DbTableNotFoundError {\n const message = error.message;\n\n // PostgreSQL format:\n // 'relation \"users\" does not exist'\n const pgMatch = message.match(/relation \"([^\"]+)\" does not exist/);\n\n if (pgMatch) {\n const table = pgMatch[1];\n return new DbTableNotFoundError(\n `Table '${table}' does not exist. Have you run migrations?`,\n error,\n { table },\n );\n }\n\n // SQLite format:\n // 'no such table: users'\n const sqliteMatch = message.match(/no such table: (\\S+)/);\n\n if (sqliteMatch) {\n const table = sqliteMatch[1];\n return new DbTableNotFoundError(\n `Table '${table}' does not exist. Have you run migrations?`,\n error,\n { table },\n );\n }\n\n return new DbTableNotFoundError(\n \"Table does not exist. Have you run migrations?\",\n error,\n );\n }\n}\n","import { AlephaError, type TObject } from \"alepha\";\nimport type { PgQueryWhere } from \"../interfaces/PgQueryWhere.ts\";\n\n/**\n * Parse a string query into a PgQueryWhere object.\n *\n * Supported syntax:\n * - Simple equality: \"name=John\"\n * - Wildcard patterns: \"name=John*\" (startsWith), \"name=*John\" (endsWith), \"name=*John*\" (contains)\n * - Operators: \"age>18\", \"age>=18\", \"age<65\", \"age<=65\", \"status!=active\"\n * - NULL checks: \"deletedAt=null\", \"email!=null\"\n * - IN arrays: \"status=[pending,active]\"\n * - AND conditions: \"name=John&age>18\"\n * - OR conditions: \"name=John|email=john@example.com\"\n * - Nested AND/OR: \"(name=John|name=Jane)&age>18\"\n * - JSONB nested: \"profile.city=Paris\"\n *\n * @example\n * ```ts\n * // Simple equality\n * parseQueryString(\"name=John\")\n * // => { name: { eq: \"John\" } }\n *\n * // Wildcard patterns\n * parseQueryString(\"name=John*\") // startsWith\n * // => { name: { startsWith: \"John\" } }\n * parseQueryString(\"name=*Smith\") // endsWith\n * // => { name: { endsWith: \"Smith\" } }\n * parseQueryString(\"name=*oh*\") // contains\n * // => { name: { contains: \"oh\" } }\n *\n * // Multiple conditions\n * parseQueryString(\"name=John&age>18\")\n * // => { and: [{ name: { eq: \"John\" } }, { age: { gt: 18 } }] }\n *\n * // OR conditions\n * parseQueryString(\"status=active|status=pending\")\n * // => { or: [{ status: { eq: \"active\" } }, { status: { eq: \"pending\" } }] }\n *\n * // Complex nested\n * parseQueryString(\"(name=John|name=Jane)&age>18&status!=archived\")\n * // => { and: [\n * // { or: [{ name: { eq: \"John\" } }, { name: { eq: \"Jane\" } }] },\n * // { age: { gt: 18 } },\n * // { status: { ne: \"archived\" } }\n * // ] }\n *\n * // JSONB nested query\n * parseQueryString(\"profile.city=Paris&profile.age>25\")\n * // => { profile: { city: { eq: \"Paris\" }, age: { gt: 25 } } }\n * ```\n */\nexport function parseQueryString<T extends TObject>(\n query: string,\n): PgQueryWhere<T> {\n if (!query || query.trim() === \"\") {\n return {};\n }\n\n const parser = new QueryStringParser(query);\n return parser.parse() as PgQueryWhere<T>;\n}\n\n// ---------------------------------------------------------------------------------------------------------------------\n\nclass QueryStringParser {\n protected pos = 0;\n protected readonly query: string;\n\n constructor(query: string) {\n this.query = query.trim();\n }\n\n parse(): PgQueryWhere<any> {\n return this.parseExpression();\n }\n\n protected parseExpression(): PgQueryWhere<any> {\n return this.parseOr();\n }\n\n protected parseOr(): any {\n const left = this.parseAnd();\n\n // Check for OR operator (|)\n if (this.peek() === \"|\") {\n const conditions = [left];\n\n while (this.peek() === \"|\") {\n this.consume(\"|\");\n conditions.push(this.parseAnd());\n }\n\n return { or: conditions };\n }\n\n return left;\n }\n\n protected parseAnd(): any {\n const left = this.parsePrimary();\n\n // Check for AND operator (&)\n if (this.peek() === \"&\") {\n const conditions = [left];\n\n while (this.peek() === \"&\") {\n this.consume(\"&\");\n conditions.push(this.parsePrimary());\n }\n\n return { and: conditions };\n }\n\n return left;\n }\n\n protected parsePrimary(): any {\n this.skipWhitespace();\n\n // Handle parentheses\n if (this.peek() === \"(\") {\n this.consume(\"(\");\n const expr = this.parseExpression();\n this.consume(\")\");\n return expr;\n }\n\n // Parse field condition\n return this.parseCondition();\n }\n\n protected parseCondition(): any {\n const field = this.parseFieldPath();\n this.skipWhitespace();\n\n // Get operator\n const operator = this.parseOperator();\n this.skipWhitespace();\n\n // Get value\n const value = this.parseValue();\n\n if (value === \"\") {\n throw new AlephaError(`Expected value for field '${field.join(\".\")}'`);\n }\n\n // Build the condition object\n return this.buildCondition(field, operator, value);\n }\n\n protected parseFieldPath(): string[] {\n const path: string[] = [];\n let current = \"\";\n\n while (this.pos < this.query.length) {\n const ch = this.query[this.pos];\n\n if (ch === \".\" && current) {\n path.push(current);\n current = \"\";\n this.pos++;\n continue;\n }\n\n if (ch === \"=\" || ch === \"!\" || ch === \">\" || ch === \"<\" || ch === \" \") {\n break;\n }\n\n current += ch;\n this.pos++;\n }\n\n if (current) {\n path.push(current);\n }\n\n return path;\n }\n\n protected parseOperator(): string {\n this.skipWhitespace();\n\n const remaining = this.query.slice(this.pos);\n\n // Two-character operators\n if (remaining.startsWith(\">=\")) {\n this.pos += 2;\n return \">=\";\n }\n if (remaining.startsWith(\"<=\")) {\n this.pos += 2;\n return \"<=\";\n }\n if (remaining.startsWith(\"!=\")) {\n this.pos += 2;\n return \"!=\";\n }\n\n // Single-character operators\n const ch = this.query[this.pos];\n if (ch === \"=\" || ch === \">\" || ch === \"<\") {\n this.pos++;\n return ch;\n }\n\n throw new AlephaError(`Expected operator at position ${this.pos}`);\n }\n\n protected parseValue(): any {\n this.skipWhitespace();\n\n // Handle null\n if (this.query.slice(this.pos, this.pos + 4).toLowerCase() === \"null\") {\n this.pos += 4;\n return null;\n }\n\n // Handle arrays [value1,value2,...]\n if (this.query[this.pos] === \"[\") {\n return this.parseArray();\n }\n\n // Handle quoted strings\n if (this.query[this.pos] === '\"' || this.query[this.pos] === \"'\") {\n return this.parseQuotedString();\n }\n\n // Parse unquoted value (until &, |, or ))\n let value = \"\";\n while (this.pos < this.query.length) {\n const ch = this.query[this.pos];\n if (ch === \"&\" || ch === \"|\" || ch === \")\") {\n break;\n }\n value += ch;\n this.pos++;\n }\n\n return this.coerceValue(value.trim());\n }\n\n protected parseArray(): any[] {\n this.consume(\"[\");\n const values: any[] = [];\n\n while (this.pos < this.query.length && this.query[this.pos] !== \"]\") {\n this.skipWhitespace();\n\n // Handle quoted values\n if (this.query[this.pos] === '\"' || this.query[this.pos] === \"'\") {\n values.push(this.parseQuotedString());\n } else {\n // Parse until comma or ]\n let value = \"\";\n while (\n this.pos < this.query.length &&\n this.query[this.pos] !== \",\" &&\n this.query[this.pos] !== \"]\"\n ) {\n value += this.query[this.pos];\n this.pos++;\n }\n values.push(this.coerceValue(value.trim()));\n }\n\n this.skipWhitespace();\n if (this.query[this.pos] === \",\") {\n this.pos++;\n }\n }\n\n this.consume(\"]\");\n return values;\n }\n\n protected parseQuotedString(): string {\n const quote = this.query[this.pos];\n this.pos++; // Skip opening quote\n\n let value = \"\";\n let escaped = false;\n\n while (this.pos < this.query.length) {\n const ch = this.query[this.pos];\n\n if (escaped) {\n value += ch;\n escaped = false;\n this.pos++;\n continue;\n }\n\n if (ch === \"\\\\\") {\n escaped = true;\n this.pos++;\n continue;\n }\n\n if (ch === quote) {\n this.pos++; // Skip closing quote\n break;\n }\n\n value += ch;\n this.pos++;\n }\n\n return value;\n }\n\n protected coerceValue(value: string): any {\n // Try to parse as number\n if (/^-?\\d+$/.test(value)) {\n return parseInt(value, 10);\n }\n\n if (/^-?\\d+\\.\\d+$/.test(value)) {\n return parseFloat(value);\n }\n\n // Try to parse as boolean\n if (value.toLowerCase() === \"true\") {\n return true;\n }\n if (value.toLowerCase() === \"false\") {\n return false;\n }\n\n return value;\n }\n\n protected buildCondition(path: string[], operator: string, value: any): any {\n // Map operator to filter operator\n let filterOp: any;\n\n if (operator === \"=\") {\n if (value === null) {\n filterOp = { isNull: true };\n } else if (Array.isArray(value)) {\n // Arrays should be treated as inArray regardless of content\n filterOp = { inArray: value };\n } else if (typeof value === \"string\" && value.includes(\"*\")) {\n // Handle wildcard patterns\n const startsWithAsterisk = value.startsWith(\"*\");\n const endsWithAsterisk = value.endsWith(\"*\");\n const cleanValue = value.replace(/^\\*|\\*$/g, \"\"); // Remove leading/trailing asterisks\n\n if (startsWithAsterisk && endsWithAsterisk) {\n // *text* -> contains\n filterOp = { contains: cleanValue };\n } else if (startsWithAsterisk) {\n // *text -> endsWith\n filterOp = { endsWith: cleanValue };\n } else if (endsWithAsterisk) {\n // text* -> startsWith\n filterOp = { startsWith: cleanValue };\n } else {\n // Has asterisk in the middle, treat as literal\n filterOp = { eq: value };\n }\n } else {\n filterOp = { eq: value };\n }\n } else if (operator === \"!=\") {\n if (value === null) {\n filterOp = { isNotNull: true };\n } else {\n filterOp = { ne: value };\n }\n } else if (operator === \">\") {\n filterOp = { gt: value };\n } else if (operator === \">=\") {\n filterOp = { gte: value };\n } else if (operator === \"<\") {\n filterOp = { lt: value };\n } else if (operator === \"<=\") {\n filterOp = { lte: value };\n } else {\n throw new AlephaError(`Unsupported operator: ${operator}`);\n }\n\n // Build nested object for path\n if (path.length === 1) {\n return { [path[0]]: filterOp };\n }\n\n // Handle nested paths (JSONB)\n let result: any = filterOp;\n for (let i = path.length - 1; i >= 0; i--) {\n result = { [path[i]]: result };\n }\n\n return result;\n }\n\n protected peek(): string {\n this.skipWhitespace();\n return this.query[this.pos] || \"\";\n }\n\n protected consume(expected: string): void {\n this.skipWhitespace();\n if (this.query[this.pos] !== expected) {\n throw new AlephaError(\n `Expected '${expected}' at position ${this.pos}, got '${this.query[this.pos]}'`,\n );\n }\n this.pos++;\n }\n\n protected skipWhitespace(): void {\n while (this.pos < this.query.length && /\\s/.test(this.query[this.pos])) {\n this.pos++;\n }\n }\n}\n\n// ---------------------------------------------------------------------------------------------------------------------\n\n/**\n * Helper function to build query strings programmatically\n *\n * @example\n * ```ts\n * buildQueryString({\n * and: [\n * { name: \"eq:John\" },\n * { age: \"gt:18\" }\n * ]\n * })\n * // => \"name=John&age>18\"\n * ```\n */\nexport function buildQueryString(where: any): string {\n if (!where || typeof where !== \"object\") {\n return \"\";\n }\n\n // Handle logical operators\n if (\"and\" in where && Array.isArray(where.and)) {\n return where.and.map((w: any) => buildQueryString(w)).join(\"&\");\n }\n\n if (\"or\" in where && Array.isArray(where.or)) {\n const parts = where.or.map((w: any) => buildQueryString(w));\n return parts.length > 1 ? `(${parts.join(\"|\")})` : parts[0];\n }\n\n if (\"not\" in where) {\n // Not operator is harder to represent in string form\n // For now, we'll skip it or you could add a syntax like \"!field=value\"\n return \"\";\n }\n\n // Handle field conditions\n const parts: string[] = [];\n\n for (const [field, condition] of Object.entries(where)) {\n if (typeof condition !== \"object\" || condition === null) {\n parts.push(`${field}=${condition}`);\n continue;\n }\n\n if (\"eq\" in condition) {\n parts.push(`${field}=${condition.eq}`);\n } else if (\"ne\" in condition) {\n parts.push(`${field}!=${condition.ne}`);\n } else if (\"gt\" in condition) {\n parts.push(`${field}>${condition.gt}`);\n } else if (\"gte\" in condition) {\n parts.push(`${field}>=${condition.gte}`);\n } else if (\"lt\" in condition) {\n parts.push(`${field}<${condition.lt}`);\n } else if (\"lte\" in condition) {\n parts.push(`${field}<=${condition.lte}`);\n } else if (\"contains\" in condition) {\n parts.push(`${field}=*${condition.contains}*`);\n } else if (\"startsWith\" in condition) {\n parts.push(`${field}=${condition.startsWith}*`);\n } else if (\"endsWith\" in condition) {\n parts.push(`${field}=*${condition.endsWith}`);\n } else if (\"isNull\" in condition && condition.isNull) {\n parts.push(`${field}=null`);\n } else if (\"isNotNull\" in condition && condition.isNotNull) {\n parts.push(`${field}!=null`);\n } else if (\"inArray\" in condition && Array.isArray(condition.inArray)) {\n const values = condition.inArray.map((v: any) =>\n typeof v === \"string\" ? `\"${v}\"` : v,\n );\n parts.push(`${field}=[${values.join(\",\")}]`);\n } else {\n // Nested object (JSONB)\n const nested = buildQueryString(condition);\n if (nested) {\n parts.push(`${field}.${nested}`);\n }\n }\n }\n\n return parts.join(\"&\");\n}\n","import type { TObject, TSchema } from \"alepha\";\nimport type { PgSymbolKeys, PgSymbols } from \"../constants/PG_SYMBOLS.ts\";\n\n/**\n * Decorates a typebox schema with a Postgres attribute.\n *\n * > It's just a fancy way to add Symbols to a field.\n *\n * @example\n * ```ts\n * import { t } from \"alepha\";\n * import { PG_UPDATED_AT } from \"../constants/PG_SYMBOLS\";\n *\n * export const updatedAtSchema = pgAttr(\n * t.datetime(), PG_UPDATED_AT,\n * );\n * ```\n */\nexport const pgAttr = <T extends TSchema, Attr extends PgSymbolKeys>(\n type: T,\n attr: Attr,\n value?: PgSymbols[Attr],\n): PgAttr<T, Attr> => {\n Object.assign(type, { [attr]: value ?? {} });\n return type as PgAttr<T, Attr>;\n};\n\n/**\n * Retrieves the fields of a schema that have a specific attribute.\n */\nexport const getAttrFields = (\n schema: TObject,\n name: PgSymbolKeys,\n): PgAttrField[] => {\n const fields: Array<PgAttrField> = [];\n\n for (const key of Object.keys(schema.properties)) {\n const value = schema.properties[key];\n if (name in value) {\n fields.push({\n type: value as TSchema,\n key: key,\n data: (value as any)[name],\n });\n }\n }\n\n return fields;\n};\n\n/**\n * Type representation.\n */\nexport type PgAttr<T extends TSchema, TAttr extends PgSymbolKeys> = T & {\n [K in TAttr]: PgSymbols[K];\n};\n\nexport interface PgAttrField {\n key: string;\n type: TSchema;\n data: any;\n nested?: any[];\n one?: boolean;\n}\n","import type { SQL } from \"drizzle-orm\";\nimport type {\n PgSequenceOptions,\n UpdateDeleteAction,\n} from \"drizzle-orm/pg-core\";\nimport type { EntityPrimitive } from \"../primitives/$entity.ts\";\n\nexport const PG_DEFAULT = Symbol.for(\"Alepha.Postgres.Default\");\nexport const PG_PRIMARY_KEY = Symbol.for(\"Alepha.Postgres.PrimaryKey\");\nexport const PG_CREATED_AT = Symbol.for(\"Alepha.Postgres.CreatedAt\");\nexport const PG_UPDATED_AT = Symbol.for(\"Alepha.Postgres.UpdatedAt\");\nexport const PG_DELETED_AT = Symbol.for(\"Alepha.Postgres.DeletedAt\");\nexport const PG_VERSION = Symbol.for(\"Alepha.Postgres.Version\");\nexport const PG_IDENTITY = Symbol.for(\"Alepha.Postgres.Identity\");\nexport const PG_ENUM = Symbol.for(\"Alepha.Postgres.Enum\");\nexport const PG_REF = Symbol.for(\"Alepha.Postgres.Ref\");\nexport const PG_GENERATED = Symbol.for(\"Alepha.Postgres.Generated\");\nexport const PG_ORGANIZATION = Symbol.for(\"Alepha.Postgres.Organization\");\n\n/**\n * @deprecated Use `PG_IDENTITY` instead.\n */\nexport const PG_SERIAL = Symbol.for(\"Alepha.Postgres.Serial\");\n\nexport type PgDefault = typeof PG_DEFAULT;\nexport type PgRef = typeof PG_REF;\nexport type PgPrimaryKey = typeof PG_PRIMARY_KEY;\n\nexport type PgSymbols = {\n [PG_DEFAULT]: {};\n [PG_PRIMARY_KEY]: {};\n [PG_CREATED_AT]: {};\n [PG_UPDATED_AT]: {};\n [PG_DELETED_AT]: {};\n [PG_VERSION]: {};\n [PG_IDENTITY]: PgIdentityOptions;\n [PG_REF]: PgRefOptions;\n [PG_ENUM]: PgEnumOptions;\n [PG_GENERATED]: PgGeneratedOptions;\n [PG_ORGANIZATION]: {};\n\n /**\n * @deprecated Use `PG_IDENTITY` instead.\n */\n [PG_SERIAL]: {};\n};\n\nexport type PgSymbolKeys = keyof PgSymbols;\n\nexport type PgIdentityOptions = {\n mode: \"always\" | \"byDefault\";\n} & PgSequenceOptions & {\n name?: string;\n };\n\nexport interface PgEnumOptions {\n name?: string;\n description?: string;\n}\n\nexport interface PgGeneratedOptions {\n /**\n * SQL expression for the generated column.\n */\n expression: SQL;\n\n /**\n * Storage mode for the generated column.\n * - `\"stored\"` — value is computed on write and stored on disk (default for PostgreSQL).\n * - `\"virtual\"` — value is computed on read (default for SQLite).\n */\n mode?: \"stored\" | \"virtual\";\n}\n\nexport interface PgRefOptions {\n ref: () => {\n name: string;\n entity: EntityPrimitive;\n };\n actions?: {\n onUpdate?: UpdateDeleteAction;\n onDelete?: UpdateDeleteAction;\n };\n}\n","import type { TObject, TOptional } from \"alepha\";\nimport { t } from \"alepha\";\nimport { PG_DEFAULT, PG_GENERATED } from \"../constants/PG_SYMBOLS.ts\";\n\n/**\n * Transforms a TObject schema for insert operations.\n * All default properties at the root level are made optional.\n * Generated columns are excluded entirely.\n *\n * @example\n * Before: { name: string; age: number(default=0); fullName: generated }\n * After: { name: string; age?: number; }\n */\nexport type TObjectInsert<T extends TObject> = TObject<{\n [K in keyof T[\"properties\"] as T[\"properties\"][K] extends {\n [PG_GENERATED]: any;\n }\n ? never\n : K]: T[\"properties\"][K] extends\n | { [PG_DEFAULT]: any }\n | { \"~optional\": true }\n ? TOptional<T[\"properties\"][K]>\n : T[\"properties\"][K];\n}>;\n\nexport const insertSchema = <T extends TObject>(obj: T): TObjectInsert<T> => {\n const newProperties: Record<string, any> = {};\n\n for (const key in obj.properties) {\n const prop = obj.properties[key];\n\n // Skip generated columns — they are computed by the database\n if (PG_GENERATED in prop) {\n continue;\n }\n\n if (PG_DEFAULT in prop) {\n newProperties[key] = t.optional(prop);\n } else {\n newProperties[key] = prop;\n }\n }\n\n return t.object(\n newProperties,\n \"options\" in obj && typeof obj.options === \"object\"\n ? { ...obj.options }\n : {},\n ) as TObjectInsert<T>;\n};\n","import {\n type TNull,\n type TObject,\n type TOptional,\n type TUnion,\n t,\n} from \"alepha\";\nimport { PG_GENERATED } from \"../constants/PG_SYMBOLS.ts\";\n\n/**\n * Transforms a TObject schema for update operations.\n * All optional properties at the root level are made nullable (i.e., `T | null`).\n * Generated columns are excluded entirely.\n *\n * @example\n * Before: { name?: string; age: number; fullName: generated }\n * After: { name?: string | null; age: number; }\n */\nexport type TObjectUpdate<T extends TObject> = TObject<{\n [K in keyof T[\"properties\"] as T[\"properties\"][K] extends {\n [PG_GENERATED]: any;\n }\n ? never\n : K]: T[\"properties\"][K] extends TOptional<infer U>\n ? TOptional<TUnion<[U, TNull]>>\n : T[\"properties\"][K];\n}>;\n\nexport const updateSchema = <T extends TObject>(\n schema: T,\n): TObjectUpdate<T> => {\n const newProperties: Record<string, any> = {};\n\n for (const key in schema.properties) {\n const prop = schema.properties[key];\n\n // Skip generated columns — they are computed by the database\n if (PG_GENERATED in prop) {\n continue;\n }\n\n if (t.schema.isOptional(prop)) {\n newProperties[key] = t.optional(t.union([prop, t.raw.Null()]));\n } else {\n newProperties[key] = prop;\n }\n }\n\n return t.object(\n newProperties,\n \"options\" in schema && typeof schema.options === \"object\"\n ? { ...schema.options }\n : {},\n ) as TObjectUpdate<T>;\n};\n","import { KIND, type Static, type TObject } from \"alepha\";\nimport type { BuildExtraConfigColumns, SQL } from \"drizzle-orm\";\nimport type {\n PgColumn,\n PgColumnBuilderBase,\n PgTableExtraConfigValue,\n} from \"drizzle-orm/pg-core\";\nimport { insertSchema, type TObjectInsert } from \"../schemas/insertSchema.ts\";\nimport { type TObjectUpdate, updateSchema } from \"../schemas/updateSchema.ts\";\n\n/**\n * Creates a database entity primitive that defines table structure using TypeBox schemas.\n *\n * @example\n * ```ts\n * import { t } from \"alepha\";\n * import { $entity } from \"alepha/orm\";\n *\n * const userEntity = $entity({\n * name: \"users\",\n * schema: t.object({\n * id: pg.primaryKey(),\n * name: t.text(),\n * email: t.email(),\n * }),\n * });\n * ```\n */\nexport const $entity = <TSchema extends TObject>(\n options: EntityPrimitiveOptions<TSchema>,\n): EntityPrimitive<TSchema> => {\n return new EntityPrimitive<TSchema>(options);\n};\n\n// ---------------------------------------------------------------------------------------------------------------------\n\nexport interface EntityPrimitiveOptions<\n T extends TObject,\n Keys = keyof Static<T>,\n> {\n /**\n * The database table name that will be created for this entity.\n * If not provided, name will be inferred from the $repository variable name.\n */\n name: string;\n\n /**\n * TypeBox schema defining the table structure and column types.\n */\n schema: T;\n\n /**\n * Database indexes to create for query optimization.\n */\n indexes?: (\n | Keys\n | {\n /**\n * Single column to index.\n */\n column: Keys;\n /**\n * Whether this should be a unique index (enforces uniqueness constraint).\n */\n unique?: boolean;\n /**\n * Custom name for the index. If not provided, generates name automatically.\n */\n name?: string;\n /**\n * Partial index condition. Only rows matching this SQL expression are indexed.\n */\n where?: SQL;\n }\n | {\n /**\n * Multiple columns for composite index (order matters for query optimization).\n */\n columns: Keys[];\n /**\n * Whether this should be a unique index (enforces uniqueness constraint).\n */\n unique?: boolean;\n /**\n * Custom name for the index. If not provided, generates name automatically.\n */\n name?: string;\n /**\n * Partial index condition. Only rows matching this SQL expression are indexed.\n */\n where?: SQL;\n }\n | {\n /**\n * SQL expressions for expression-based indexes.\n *\n * Can include column references and SQL functions like `LOWER()`, `UPPER()`, etc.\n * Columns and expressions can be mixed together.\n *\n * @example\n * ```ts\n * // Case-insensitive unique username per realm\n * indexes: [{\n * expressions: (self) => [self.realm, sql`LOWER(${self.username})`],\n * unique: true,\n * name: \"users_realm_username_lower_idx\",\n * }]\n * ```\n */\n expressions: (self: Record<Keys & string, any>) => (SQL | any)[];\n /**\n * Whether this should be a unique index (enforces uniqueness constraint).\n */\n unique?: boolean;\n /**\n * Custom name for the index. If not provided, generates name automatically.\n */\n name: string;\n /**\n * Partial index condition. Only rows matching this SQL expression are indexed.\n */\n where?: SQL;\n }\n )[];\n\n /**\n * Foreign key constraints to maintain referential integrity.\n */\n foreignKeys?: Array<{\n /**\n * Optional name for the foreign key constraint.\n */\n name?: string;\n /**\n * Local columns that reference the foreign table.\n */\n columns: Array<keyof Static<T>>;\n /**\n * Referenced columns in the foreign table.\n * Must be EntityColumn references from other entities.\n */\n foreignColumns: Array<() => EntityColumn<any>>;\n }>;\n\n /**\n * Additional table constraints for data validation.\n *\n * Constraints enforce business rules at the database level, providing\n * an additional layer of data integrity beyond application validation.\n *\n * **Constraint Types**:\n * - **Unique constraints**: Prevent duplicate values across columns\n * - **Check constraints**: Enforce custom validation rules with SQL expressions\n *\n * @example\n * ```ts\n * constraints: [\n * {\n * name: \"unique_user_email\",\n * columns: [\"email\"],\n * unique: true\n * },\n * {\n * name: \"valid_age_range\",\n * columns: [\"age\"],\n * check: sql`age >= 0 AND age <= 150`\n * },\n * {\n * name: \"unique_user_username_per_tenant\",\n * columns: [\"tenantId\", \"username\"],\n * unique: true\n * }\n * ]\n * ```\n */\n constraints?: Array<{\n /**\n * Columns involved in this constraint.\n */\n columns: Array<keyof Static<T>>;\n /**\n * Optional name for the constraint.\n */\n name?: string;\n /**\n * Whether this is a unique constraint.\n */\n unique?: boolean | {} /* options */;\n /**\n * SQL expression for check constraint validation.\n */\n check?: SQL;\n }>;\n\n /**\n * Advanced Drizzle ORM configuration for complex table setups.\n */\n config?: (\n self: BuildExtraConfigColumns<string, FromSchema<T>, \"pg\">,\n ) => PgTableExtraConfigValue[];\n}\n\n// ---------------------------------------------------------------------------------------------------------------------\n\nexport class EntityPrimitive<T extends TObject = TObject> {\n public readonly options: EntityPrimitiveOptions<T>;\n\n constructor(options: EntityPrimitiveOptions<T>) {\n this.options = options;\n }\n\n alias(alias: string): this {\n const aliased = new EntityPrimitive<T>(this.options);\n return new Proxy(aliased, {\n get(target, prop, receiver) {\n if (prop === \"$alias\") {\n return alias;\n }\n return Reflect.get(target, prop, receiver);\n },\n }) as this;\n }\n\n get cols(): EntityColumns<T> {\n const cols: Partial<EntityColumns<T>> = {};\n for (const key of Object.keys(this.schema.properties) as Array<\n keyof T[\"properties\"]\n >) {\n cols[key] = {\n name: key as string,\n entity: this,\n };\n }\n\n return cols as EntityColumns<T>;\n }\n\n get name(): string {\n return this.options.name;\n }\n\n get schema(): T {\n return this.options.schema;\n }\n\n get insertSchema(): TObjectInsert<T> {\n return insertSchema(this.options.schema);\n }\n\n get updateSchema(): TObjectUpdate<T> {\n return updateSchema(this.options.schema);\n }\n}\n\n$entity[KIND] = EntityPrimitive;\n\n// ---------------------------------------------------------------------------------------------------------------------\n\n/**\n * Convert a schema to columns.\n */\nexport type FromSchema<T extends TObject> = {\n [key in keyof T[\"properties\"]]: PgColumnBuilderBase;\n};\n\nexport type SchemaToTableConfig<T extends TObject> = {\n name: string;\n schema: string | undefined;\n columns: {\n [key in keyof T[\"properties\"]]: PgColumn;\n };\n dialect: string;\n};\n\nexport type EntityColumn<T extends TObject> = {\n name: string;\n entity: EntityPrimitive<T>;\n};\n\nexport type EntityColumns<T extends TObject> = {\n [key in keyof T[\"properties\"]]: EntityColumn<T>;\n};\n","import { KIND, type TObject } from \"alepha\";\nimport type { SQL } from \"drizzle-orm\";\n\n/**\n * Creates a database view primitive from a TypeBox schema and SQL query.\n *\n * Views are read-only: Repository blocks all write operations.\n *\n * @example\n * ```ts\n * import { t } from \"alepha\";\n * import { $view } from \"alepha/orm\";\n * import { sql } from \"drizzle-orm\";\n *\n * const userSummary = $view({\n * name: \"user_summary\",\n * schema: t.object({\n * id: t.uuid(),\n * fullName: t.text(),\n * orderCount: t.integer(),\n * }),\n * query: sql`SELECT u.id, u.first_name || ' ' || u.last_name AS full_name, COUNT(o.id) AS order_count FROM users u LEFT JOIN orders o ON o.user_id = u.id GROUP BY u.id`,\n * });\n *\n * // Materialized view (PostgreSQL only)\n * const monthlyStats = $view({\n * name: \"monthly_stats\",\n * schema: t.object({ ... }),\n * query: sql`...`,\n * materialized: true,\n * });\n * ```\n */\nexport const $view = <TSchema extends TObject>(\n options: ViewPrimitiveOptions<TSchema>,\n): ViewPrimitive<TSchema> => {\n return new ViewPrimitive<TSchema>(options);\n};\n\n// ---------------------------------------------------------------------------------------------------------------------\n\nexport interface ViewPrimitiveOptions<T extends TObject> {\n /**\n * The database view name.\n */\n name: string;\n\n /**\n * TypeBox schema defining the view's columns.\n */\n schema: T;\n\n /**\n * SQL query that defines the view.\n */\n query: SQL;\n\n /**\n * Whether this is a materialized view (PostgreSQL only).\n * Materialized views store results on disk and can be refreshed.\n */\n materialized?: boolean;\n}\n\n// ---------------------------------------------------------------------------------------------------------------------\n\nexport class ViewPrimitive<T extends TObject = TObject> {\n public readonly options: ViewPrimitiveOptions<T>;\n public readonly isView = true;\n\n constructor(options: ViewPrimitiveOptions<T>) {\n this.options = options;\n }\n\n get name(): string {\n return this.options.name;\n }\n\n get schema(): T {\n return this.options.schema;\n }\n\n get materialized(): boolean {\n return this.options.materialized ?? false;\n }\n}\n\n$view[KIND] = ViewPrimitive;\n","import {\n AlephaError,\n pageSchema,\n type Static,\n type TBigInt,\n type TInteger,\n type TNumber,\n type TNumberOptions,\n type TObject,\n type TObjectOptions,\n type TPage,\n type TSchema,\n type TString,\n type TStringOptions,\n type TUnsafe,\n t,\n} from \"alepha\";\nimport type { UpdateDeleteAction } from \"drizzle-orm/pg-core/foreign-keys\";\nimport {\n PG_CREATED_AT,\n PG_DEFAULT,\n PG_DELETED_AT,\n PG_ENUM,\n PG_IDENTITY,\n PG_ORGANIZATION,\n PG_PRIMARY_KEY,\n PG_REF,\n PG_UPDATED_AT,\n PG_VERSION,\n type PgDefault,\n type PgEnumOptions,\n type PgIdentityOptions,\n type PgPrimaryKey,\n type PgRef,\n} from \"../constants/PG_SYMBOLS.ts\";\nimport type { PgAttr } from \"../helpers/pgAttr.ts\";\nimport { pgAttr } from \"../helpers/pgAttr.ts\";\n\nexport class DatabaseTypeProvider {\n public readonly attr = pgAttr;\n\n /**\n * Creates a primary key with an identity column.\n */\n public readonly identityPrimaryKey = (\n identity?: PgIdentityOptions,\n options?: TNumberOptions,\n ) =>\n pgAttr(\n pgAttr(pgAttr(t.integer(options), PG_PRIMARY_KEY), PG_IDENTITY, identity),\n PG_DEFAULT,\n );\n\n /**\n * Creates a primary key with a big identity column. (default)\n */\n public readonly bigIdentityPrimaryKey = (\n identity?: PgIdentityOptions,\n options?: TNumberOptions,\n ) =>\n pgAttr(\n pgAttr(pgAttr(t.int64(options), PG_PRIMARY_KEY), PG_IDENTITY, identity),\n PG_DEFAULT,\n );\n\n /**\n * Creates a primary key with a UUID column.\n */\n public readonly uuidPrimaryKey = () =>\n pgAttr(pgAttr(t.uuid(), PG_PRIMARY_KEY), PG_DEFAULT);\n\n /**\n * Creates a primary key for a given type. Supports:\n * - `t.integer()` -> PG INT (default)\n * - `t.bigint()` -> PG BIGINT\n * - `t.uuid()` -> PG UUID\n */\n public primaryKey(): PgAttr<PgAttr<TInteger, PgPrimaryKey>, PgDefault>;\n public primaryKey(\n type: TString,\n options?: TStringOptions,\n ): PgAttr<PgAttr<TString, PgPrimaryKey>, PgDefault>;\n public primaryKey(\n type: TInteger,\n options?: TNumberOptions,\n identity?: PgIdentityOptions,\n ): PgAttr<PgAttr<TInteger, PgPrimaryKey>, PgDefault>;\n public primaryKey(\n type: TNumber,\n options?: TNumberOptions,\n identity?: PgIdentityOptions,\n ): PgAttr<PgAttr<TNumber, PgPrimaryKey>, PgDefault>;\n public primaryKey(\n type: TBigInt,\n options?: TNumberOptions,\n identity?: PgIdentityOptions,\n ): PgAttr<PgAttr<TBigInt, PgPrimaryKey>, PgDefault>;\n public primaryKey(\n type?: TSchema,\n options?: TNumberOptions | TStringOptions,\n identity?: PgIdentityOptions,\n ): PgAttr<PgAttr<TSchema, PgPrimaryKey>, PgDefault> {\n if (!type || t.schema.isInteger(type)) {\n return pgAttr(\n pgAttr(\n pgAttr(t.integer(options), PG_PRIMARY_KEY),\n PG_IDENTITY,\n identity,\n ),\n PG_DEFAULT,\n );\n }\n\n if (t.schema.isString(type) && type.format === \"uuid\") {\n return pgAttr(pgAttr(t.uuid(), PG_PRIMARY_KEY), PG_DEFAULT);\n }\n\n if (t.schema.isNumber(type) && type.format === \"int64\") {\n return pgAttr(\n pgAttr(\n pgAttr(t.number(options), PG_PRIMARY_KEY),\n PG_IDENTITY,\n identity,\n ),\n PG_DEFAULT,\n );\n }\n\n if (t.schema.isBigInt(type)) {\n return pgAttr(\n pgAttr(\n pgAttr(t.bigint(options), PG_PRIMARY_KEY),\n PG_IDENTITY,\n identity,\n ),\n PG_DEFAULT,\n );\n }\n\n throw new AlephaError(`Unsupported type for primary key: ${type}`);\n }\n\n /**\n * Wrap a schema with \"default\" attribute.\n * This is used to set a default value for a column in the database.\n */\n public readonly default = <T extends TSchema>(\n type: T,\n value?: Static<T>,\n ): PgAttr<T, PgDefault> => {\n if (value != null) {\n Object.assign(type, { default: value });\n }\n\n return this.attr(type, PG_DEFAULT);\n };\n\n /**\n * Creates a column 'version'.\n *\n * This is used to track the version of a row in the database.\n *\n * You can use it for optimistic concurrency control (OCC) with {@link RepositoryPrimitive#save}.\n *\n * @see {@link RepositoryPrimitive#save}\n * @see {@link PgVersionMismatchError}\n */\n public readonly version = (options: TNumberOptions = {}) =>\n this.default(pgAttr(t.integer(options), PG_VERSION), 0);\n\n /**\n * Creates a column Created At. So just a datetime column with a default value of the current timestamp.\n */\n public readonly createdAt = (options?: TStringOptions) =>\n pgAttr(pgAttr(t.datetime(options), PG_CREATED_AT), PG_DEFAULT);\n\n /**\n * Creates a column Updated At. Like createdAt, but it is updated on every update of the row.\n */\n public readonly updatedAt = (options?: TStringOptions) =>\n pgAttr(pgAttr(t.datetime(options), PG_UPDATED_AT), PG_DEFAULT);\n\n /**\n * Creates a column Deleted At for soft delete functionality.\n * This is used to mark rows as deleted without actually removing them from the database.\n * The column is nullable - NULL means not deleted, timestamp means deleted.\n */\n public readonly deletedAt = (options?: TStringOptions) =>\n pgAttr(t.optional(t.datetime(options)), PG_DELETED_AT);\n\n /**\n * Creates an organization column for multi-tenant row scoping.\n *\n * When present, queries are automatically filtered by the current user's organization.\n * Rows with `null` organization are considered global and visible to everyone.\n * On create, the column is auto-stamped with the current user's organization.\n */\n public readonly organization = () =>\n pgAttr(t.optional(t.uuid()), PG_ORGANIZATION);\n\n /**\n * Creates a Postgres ENUM type.\n *\n * > By default, `t.enum()` is mapped to a TEXT column in Postgres.\n * > Using this method, you can create a real ENUM type in the database.\n *\n * @example\n * ```ts\n * const statusEnum = pg.enum([\"pending\", \"active\", \"archived\"], { name: \"status_enum\" });\n * ```\n */\n public readonly enum = <T extends string[]>(\n values: [...T],\n pgEnumOptions?: PgEnumOptions,\n typeOptions?: TStringOptions,\n ): PgAttr<TUnsafe<T[number]>, typeof PG_ENUM> => {\n return pgAttr(\n t.enum(values, {\n description: pgEnumOptions?.description,\n ...typeOptions,\n }),\n PG_ENUM,\n pgEnumOptions,\n );\n };\n\n /**\n * Creates a reference to another table or schema. Basically a foreign key.\n */\n public readonly ref = <T extends TSchema>(\n type: T,\n ref: () => any,\n actions?: {\n onUpdate?: UpdateDeleteAction;\n onDelete?: UpdateDeleteAction;\n },\n ): PgAttr<T, PgRef> => {\n // If actions are not provided, set default onDelete based on type\n const finalActions = actions ?? {\n onDelete: t.schema.isOptional(type) ? \"set null\" : \"cascade\",\n };\n\n return this.attr(type, PG_REF, {\n ref,\n actions: finalActions,\n });\n };\n\n // -------------------------------------------------------------------------------------------------------------------\n\n /**\n * Creates a page schema for a given object schema.\n * It's used by {@link Repository#paginate} method.\n */\n public readonly page = <T extends TObject>(\n resource: T,\n options?: TObjectOptions,\n ): TPage<T> => {\n return pageSchema(resource, options);\n };\n}\n\n/**\n * Wrapper of TypeProvider (`t`) for database types.\n *\n * Use `db` for improve TypeBox schema definitions with database-specific attributes.\n *\n * @example\n * ```ts\n * import { t } from \"alepha\";\n * import { db } from \"alepha/orm\";\n *\n * const userSchema = t.object({\n * id: db.primaryKey(t.uuid()),\n * email: t.email(),\n * createdAt: db.createdAt(),\n * });\n * ```\n */\nexport const db = new DatabaseTypeProvider();\n","import { t } from \"alepha\";\nimport {\n PG_DEFAULT,\n PG_PRIMARY_KEY,\n PG_SERIAL,\n} from \"../constants/PG_SYMBOLS.ts\";\nimport { pgAttr } from \"../helpers/pgAttr.ts\";\n\n/**\n * @deprecated Use `pg.primaryKey()` instead.\n */\nexport const legacyIdSchema = pgAttr(\n pgAttr(pgAttr(t.integer(), PG_PRIMARY_KEY), PG_SERIAL),\n PG_DEFAULT,\n);\n","import { $module } from \"alepha\";\nimport { AlephaDateTime } from \"alepha/datetime\";\n\nexport * from \"./index.shared.ts\";\n\nexport const AlephaOrm = $module({\n name: \"alepha.orm\",\n primitives: [],\n services: [AlephaDateTime],\n});\n"],"mappings":"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"}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { createRequire } from "node:module";
|
|
2
|
-
import { $atom, $context, $env, $hook, $inject, $mode, $module, $
|
|
2
|
+
import { $atom, $context, $env, $hook, $inject, $mode, $module, $state, Alepha, AlephaError, KIND, Primitive, Value, createMiddleware, createPagination, createPrimitive, pageQuerySchema, pageSchema, pageSchema as pageSchema$1, t } from "alepha";
|
|
3
3
|
import { AlephaDateTime, DateTimeProvider } from "alepha/datetime";
|
|
4
4
|
import * as drizzle from "drizzle-orm";
|
|
5
5
|
import { and, arrayContained, arrayContains, arrayOverlaps, asc, avg, between, count, desc, eq, exists, getTableName, gt, gte, ilike, inArray, isNotNull, isNull, isSQLWrapper, like, lt, lte, max, min, ne, not, notBetween, notExists, notIlike, notInArray, notLike, or, sql, sql as sql$1, sum } from "drizzle-orm";
|
|
@@ -10,12 +10,9 @@ import { dirname } from "node:path";
|
|
|
10
10
|
import { randomUUID } from "node:crypto";
|
|
11
11
|
import * as pg from "drizzle-orm/sqlite-core";
|
|
12
12
|
import { check, foreignKey, index, sqliteTable, sqliteView, unique, uniqueIndex } from "drizzle-orm/sqlite-core";
|
|
13
|
+
import { currentUserAtom } from "alepha/security";
|
|
13
14
|
import { isSQLWrapper as isSQLWrapper$1 } from "drizzle-orm/sql/sql";
|
|
14
15
|
export * from "drizzle-orm/pg-core";
|
|
15
|
-
Object.defineProperty;
|
|
16
|
-
Object.getOwnPropertyDescriptor;
|
|
17
|
-
Object.getOwnPropertyNames;
|
|
18
|
-
Object.prototype.hasOwnProperty;
|
|
19
16
|
//#endregion
|
|
20
17
|
//#region ../../src/orm/core/constants/PG_SYMBOLS.ts
|
|
21
18
|
const PG_DEFAULT = Symbol.for("Alepha.Postgres.Default");
|
|
@@ -28,6 +25,7 @@ const PG_IDENTITY = Symbol.for("Alepha.Postgres.Identity");
|
|
|
28
25
|
const PG_ENUM = Symbol.for("Alepha.Postgres.Enum");
|
|
29
26
|
const PG_REF = Symbol.for("Alepha.Postgres.Ref");
|
|
30
27
|
const PG_GENERATED = Symbol.for("Alepha.Postgres.Generated");
|
|
28
|
+
const PG_ORGANIZATION = Symbol.for("Alepha.Postgres.Organization");
|
|
31
29
|
/**
|
|
32
30
|
* @deprecated Use `PG_IDENTITY` instead.
|
|
33
31
|
*/
|
|
@@ -182,7 +180,7 @@ var DrizzleKitProvider = class {
|
|
|
182
180
|
const { statements } = await this.generateMigration(provider);
|
|
183
181
|
await this.executeFallbackStatements(statements, provider);
|
|
184
182
|
}
|
|
185
|
-
this.log.info(`
|
|
183
|
+
this.log.info(`Synchronization of '${provider.name}' OK [${this.dateTime.nowMillis() - now}ms]`);
|
|
186
184
|
}
|
|
187
185
|
/**
|
|
188
186
|
* Generate SQL migration statements by diffing two schema states.
|
|
@@ -658,6 +656,13 @@ var ModelBuilder = class {
|
|
|
658
656
|
if ("where" in indexDef && indexDef.where) idx = idx.where(indexDef.where);
|
|
659
657
|
configs.push(idx);
|
|
660
658
|
}
|
|
659
|
+
} else if ("expressions" in indexDef) {
|
|
660
|
+
const parts = indexDef.expressions(self);
|
|
661
|
+
if (parts.length > 0) {
|
|
662
|
+
let idx = indexDef.unique ? builders.uniqueIndex(indexDef.name).on(...parts) : builders.index(indexDef.name).on(...parts);
|
|
663
|
+
if ("where" in indexDef && indexDef.where) idx = idx.where(indexDef.where);
|
|
664
|
+
configs.push(idx);
|
|
665
|
+
}
|
|
661
666
|
} else if ("columns" in indexDef) {
|
|
662
667
|
const columnNames = indexDef.columns.map((col) => this.toColumnName(col));
|
|
663
668
|
const indexName = indexDef.name || `${entity.name}_${columnNames.join("_")}_idx`;
|
|
@@ -891,7 +896,7 @@ const bunSqliteOptions = $atom({
|
|
|
891
896
|
var BunSqliteProvider = class extends DatabaseProvider {
|
|
892
897
|
env = $env(envSchema);
|
|
893
898
|
builder = $inject(SqliteModelBuilder);
|
|
894
|
-
options = $
|
|
899
|
+
options = $state(bunSqliteOptions);
|
|
895
900
|
sqlite;
|
|
896
901
|
bunDb;
|
|
897
902
|
get name() {
|
|
@@ -1572,8 +1577,10 @@ var QueryManager = class {
|
|
|
1572
1577
|
if (operator?.isNotNull != null) conditions.push(isNotNull(column));
|
|
1573
1578
|
if (operator?.like != null) conditions.push(like(column, encodeValue(operator.like)));
|
|
1574
1579
|
if (operator?.notLike != null) conditions.push(notLike(column, encodeValue(operator.notLike)));
|
|
1575
|
-
if (operator?.ilike != null) conditions.push(
|
|
1576
|
-
|
|
1580
|
+
if (operator?.ilike != null) if (dialect === "sqlite") conditions.push(sql$1`LOWER(${column}) LIKE LOWER(${encodeValue(operator.ilike)})`);
|
|
1581
|
+
else conditions.push(ilike(column, encodeValue(operator.ilike)));
|
|
1582
|
+
if (operator?.notIlike != null) if (dialect === "sqlite") conditions.push(sql$1`LOWER(${column}) NOT LIKE LOWER(${encodeValue(operator.notIlike)})`);
|
|
1583
|
+
else conditions.push(notIlike(column, encodeValue(operator.notIlike)));
|
|
1577
1584
|
if (operator?.contains != null) {
|
|
1578
1585
|
const escapedValue = String(operator.contains).replace(/\\/g, "\\\\").replace(/%/g, "\\%").replace(/_/g, "\\_");
|
|
1579
1586
|
if (dialect === "sqlite") conditions.push(sql$1`LOWER(${column}) LIKE LOWER(${encodeValue(`%${escapedValue}%`)}) ESCAPE '\\'`);
|
|
@@ -1850,7 +1857,7 @@ var Repository = class Repository {
|
|
|
1850
1857
|
const builder = query.distinct ? this.rawSelectDistinct(opts, query.distinct) : this.rawSelect(opts);
|
|
1851
1858
|
const joins = [];
|
|
1852
1859
|
if (query.with) this.relationManager.buildJoins(this.provider, builder, joins, query.with, this.table);
|
|
1853
|
-
const where = this.withDeletedAt(query.where ?? {}, opts);
|
|
1860
|
+
const where = this.withOrganization(this.withDeletedAt(query.where ?? {}, opts));
|
|
1854
1861
|
builder.where(() => this.toSQL(where, joins));
|
|
1855
1862
|
if (query.offset) {
|
|
1856
1863
|
builder.offset(query.offset);
|
|
@@ -1946,7 +1953,7 @@ var Repository = class Repository {
|
|
|
1946
1953
|
return it;
|
|
1947
1954
|
}));
|
|
1948
1955
|
if (opts.count) {
|
|
1949
|
-
const countWhere = this.withDeletedAt(query.where ?? {}, opts);
|
|
1956
|
+
const countWhere = this.withOrganization(this.withDeletedAt(query.where ?? {}, opts));
|
|
1950
1957
|
tasks.push(this.db.$count(this.table, this.toSQL(countWhere)).then((it) => {
|
|
1951
1958
|
timers.count = this.dateTimeProvider.nowMillis() - timers.count;
|
|
1952
1959
|
return it;
|
|
@@ -1995,6 +2002,7 @@ var Repository = class Repository {
|
|
|
1995
2002
|
*/
|
|
1996
2003
|
async create(data, opts = {}) {
|
|
1997
2004
|
this.assertWritable();
|
|
2005
|
+
this.stampOrganization(data);
|
|
1998
2006
|
await this.alepha.events.emit("repository:create:before", {
|
|
1999
2007
|
tableName: this.tableName,
|
|
2000
2008
|
data
|
|
@@ -2024,6 +2032,7 @@ var Repository = class Repository {
|
|
|
2024
2032
|
async createMany(values, opts = {}) {
|
|
2025
2033
|
this.assertWritable();
|
|
2026
2034
|
if (values.length === 0) return [];
|
|
2035
|
+
for (const value of values) this.stampOrganization(value);
|
|
2027
2036
|
await this.alepha.events.emit("repository:create:before", {
|
|
2028
2037
|
tableName: this.tableName,
|
|
2029
2038
|
data: values
|
|
@@ -2078,6 +2087,7 @@ var Repository = class Repository {
|
|
|
2078
2087
|
*/
|
|
2079
2088
|
async upsert(data, opts = {}) {
|
|
2080
2089
|
this.assertWritable();
|
|
2090
|
+
this.stampOrganization(data);
|
|
2081
2091
|
await this.alepha.events.emit("repository:create:before", {
|
|
2082
2092
|
tableName: this.tableName,
|
|
2083
2093
|
data
|
|
@@ -2122,7 +2132,7 @@ var Repository = class Repository {
|
|
|
2122
2132
|
let row = data;
|
|
2123
2133
|
const updatedAtField = getAttrFields(this.entity.schema, PG_UPDATED_AT)?.[0];
|
|
2124
2134
|
if (updatedAtField) row[updatedAtField.key] = opts.now ?? this.dateTimeProvider.nowISOString();
|
|
2125
|
-
where = this.withDeletedAt(where, opts);
|
|
2135
|
+
where = this.withOrganization(this.withDeletedAt(where, opts));
|
|
2126
2136
|
row = this.cast(row, false);
|
|
2127
2137
|
delete row[this.id.key];
|
|
2128
2138
|
const response = await this.rawUpdate(opts).set(row).where(this.toSQL(where)).returning(this.table).catch((error) => {
|
|
@@ -2210,7 +2220,7 @@ var Repository = class Repository {
|
|
|
2210
2220
|
});
|
|
2211
2221
|
const updatedAtField = getAttrFields(this.entity.schema, PG_UPDATED_AT)?.[0];
|
|
2212
2222
|
if (updatedAtField) data[updatedAtField.key] = opts.now ?? this.dateTimeProvider.nowISOString();
|
|
2213
|
-
where = this.withDeletedAt(where, opts);
|
|
2223
|
+
where = this.withOrganization(this.withDeletedAt(where, opts));
|
|
2214
2224
|
data = this.cast(data, false);
|
|
2215
2225
|
try {
|
|
2216
2226
|
const entities = await this.rawUpdate(opts).set(data).where(this.toSQL(where)).returning();
|
|
@@ -2234,6 +2244,7 @@ var Repository = class Repository {
|
|
|
2234
2244
|
this.assertWritable();
|
|
2235
2245
|
const deletedAt = this.deletedAt();
|
|
2236
2246
|
if (deletedAt && !opts.force) return await this.updateMany(where, { [deletedAt.key]: opts.now ?? this.dateTimeProvider.nowISOString() }, opts);
|
|
2247
|
+
where = this.withOrganization(where);
|
|
2237
2248
|
await this.alepha.events.emit("repository:delete:before", {
|
|
2238
2249
|
tableName: this.tableName,
|
|
2239
2250
|
where
|
|
@@ -2297,7 +2308,7 @@ var Repository = class Repository {
|
|
|
2297
2308
|
* Count entities.
|
|
2298
2309
|
*/
|
|
2299
2310
|
async count(where = {}, opts = {}) {
|
|
2300
|
-
where = this.withDeletedAt(where, opts);
|
|
2311
|
+
where = this.withOrganization(this.withDeletedAt(where, opts));
|
|
2301
2312
|
return (opts.tx === null ? this.provider.db : opts.tx ?? this.db).$count(this.table, this.toSQL(where));
|
|
2302
2313
|
}
|
|
2303
2314
|
/**
|
|
@@ -2332,7 +2343,7 @@ var Repository = class Repository {
|
|
|
2332
2343
|
}
|
|
2333
2344
|
let builder = (opts.tx === null ? this.provider.db : opts.tx ?? this.db).select(flatFields).from(this.table);
|
|
2334
2345
|
if (query.where) {
|
|
2335
|
-
const where = this.withDeletedAt(query.where, opts);
|
|
2346
|
+
const where = this.withOrganization(this.withDeletedAt(query.where, opts));
|
|
2336
2347
|
builder = builder.where(this.toSQL(where));
|
|
2337
2348
|
}
|
|
2338
2349
|
if (query.groupBy) builder = builder.groupBy(...query.groupBy.map((key) => this.col(key)));
|
|
@@ -2422,6 +2433,24 @@ var Repository = class Repository {
|
|
|
2422
2433
|
const deletedAtFields = getAttrFields(this.entity.schema, PG_DELETED_AT);
|
|
2423
2434
|
if (deletedAtFields.length > 0) return deletedAtFields[0];
|
|
2424
2435
|
}
|
|
2436
|
+
withOrganization(where) {
|
|
2437
|
+
const orgField = this.organizationField();
|
|
2438
|
+
if (!orgField) return where;
|
|
2439
|
+
const user = this.alepha.store.get(currentUserAtom);
|
|
2440
|
+
if (!user?.organization) return where;
|
|
2441
|
+
return { and: [where, { or: [{ [orgField.key]: { eq: user.organization } }, { [orgField.key]: { isNull: true } }] }] };
|
|
2442
|
+
}
|
|
2443
|
+
stampOrganization(data) {
|
|
2444
|
+
const orgField = this.organizationField();
|
|
2445
|
+
if (!orgField) return;
|
|
2446
|
+
if (data[orgField.key] != null) return;
|
|
2447
|
+
const user = this.alepha.store.get(currentUserAtom);
|
|
2448
|
+
if (user?.organization) data[orgField.key] = user.organization;
|
|
2449
|
+
}
|
|
2450
|
+
organizationField() {
|
|
2451
|
+
const fields = getAttrFields(this.entity.schema, PG_ORGANIZATION);
|
|
2452
|
+
if (fields.length > 0) return fields[0];
|
|
2453
|
+
}
|
|
2425
2454
|
/**
|
|
2426
2455
|
* Convert something to valid Pg Insert Value.
|
|
2427
2456
|
*/
|
|
@@ -3035,6 +3064,14 @@ var DatabaseTypeProvider = class {
|
|
|
3035
3064
|
*/
|
|
3036
3065
|
deletedAt = (options) => pgAttr(t.optional(t.datetime(options)), PG_DELETED_AT);
|
|
3037
3066
|
/**
|
|
3067
|
+
* Creates an organization column for multi-tenant row scoping.
|
|
3068
|
+
*
|
|
3069
|
+
* When present, queries are automatically filtered by the current user's organization.
|
|
3070
|
+
* Rows with `null` organization are considered global and visible to everyone.
|
|
3071
|
+
* On create, the column is auto-stamped with the current user's organization.
|
|
3072
|
+
*/
|
|
3073
|
+
organization = () => pgAttr(t.optional(t.uuid()), PG_ORGANIZATION);
|
|
3074
|
+
/**
|
|
3038
3075
|
* Creates a Postgres ENUM type.
|
|
3039
3076
|
*
|
|
3040
3077
|
* > By default, `t.enum()` is mapped to a TEXT column in Postgres.
|
|
@@ -3233,6 +3270,6 @@ const AlephaOrm = $module({
|
|
|
3233
3270
|
}
|
|
3234
3271
|
});
|
|
3235
3272
|
//#endregion
|
|
3236
|
-
export { $entity, $repository, $seed, $sequence, $transactional, $view, AlephaOrm, BunSqliteProvider, CloudflareD1Provider, DatabaseProvider, DatabaseTypeProvider, DbCacheProvider, DbColumnNotFoundError, DbConflictError, DbConnectionError, DbDeadlockError, DbEntityNotFoundError, DbError, DbForeignKeyError, DbMigrationError, DbNotNullError, DbTableNotFoundError, DbVersionMismatchError, DrizzleKitProvider, EntityPrimitive, ModelBuilder, PG_CREATED_AT, PG_DEFAULT, PG_DELETED_AT, PG_ENUM, PG_GENERATED, PG_IDENTITY, PG_PRIMARY_KEY, PG_REF, PG_SERIAL, PG_UPDATED_AT, PG_VERSION, Repository, RepositoryProvider, SequencePrimitive, SqliteProvider, ViewPrimitive, buildQueryString, bunSqliteOptions, databaseEnvSchema, db, drizzle, getAttrFields, insertSchema, legacyIdSchema, pageQuerySchema, pageSchema, parseQueryString, pgAttr, schema, sql, updateSchema };
|
|
3273
|
+
export { $entity, $repository, $seed, $sequence, $transactional, $view, AlephaOrm, BunSqliteProvider, CloudflareD1Provider, DatabaseProvider, DatabaseTypeProvider, DbCacheProvider, DbColumnNotFoundError, DbConflictError, DbConnectionError, DbDeadlockError, DbEntityNotFoundError, DbError, DbForeignKeyError, DbMigrationError, DbNotNullError, DbTableNotFoundError, DbVersionMismatchError, DrizzleKitProvider, EntityPrimitive, ModelBuilder, PG_CREATED_AT, PG_DEFAULT, PG_DELETED_AT, PG_ENUM, PG_GENERATED, PG_IDENTITY, PG_ORGANIZATION, PG_PRIMARY_KEY, PG_REF, PG_SERIAL, PG_UPDATED_AT, PG_VERSION, Repository, RepositoryProvider, SequencePrimitive, SqliteProvider, ViewPrimitive, buildQueryString, bunSqliteOptions, databaseEnvSchema, db, drizzle, getAttrFields, insertSchema, legacyIdSchema, pageQuerySchema, pageSchema, parseQueryString, pgAttr, schema, sql, updateSchema };
|
|
3237
3274
|
|
|
3238
3275
|
//# sourceMappingURL=index.bun.js.map
|