alepha 0.20.5 → 0.20.7
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/AGENTS.md +0 -1
- package/CLAUDE.md +0 -1
- package/assets/agents-template.md +0 -1
- package/dist/api/audits/index.browser.js +1 -0
- package/dist/api/audits/index.browser.js.map +1 -1
- package/dist/api/audits/index.d.ts +701 -654
- package/dist/api/audits/index.d.ts.map +1 -1
- package/dist/api/audits/index.js +24 -1
- package/dist/api/audits/index.js.map +1 -1
- package/dist/api/files/index.browser.js +1 -0
- package/dist/api/files/index.browser.js.map +1 -1
- package/dist/api/files/index.d.ts +193 -166
- package/dist/api/files/index.d.ts.map +1 -1
- package/dist/api/files/index.js +52 -0
- package/dist/api/files/index.js.map +1 -1
- package/dist/api/jobs/index.browser.js +40 -14
- package/dist/api/jobs/index.browser.js.map +1 -1
- package/dist/api/jobs/index.d.ts +639 -333
- package/dist/api/jobs/index.d.ts.map +1 -1
- package/dist/api/jobs/index.js +495 -162
- package/dist/api/jobs/index.js.map +1 -1
- package/dist/api/keys/index.d.ts +222 -188
- package/dist/api/keys/index.d.ts.map +1 -1
- package/dist/api/keys/index.js +54 -0
- package/dist/api/keys/index.js.map +1 -1
- package/dist/api/notifications/index.d.ts +265 -236
- package/dist/api/notifications/index.d.ts.map +1 -1
- package/dist/api/notifications/index.js +55 -13
- package/dist/api/notifications/index.js.map +1 -1
- package/dist/api/organizations/index.d.ts +100 -97
- package/dist/api/organizations/index.d.ts.map +1 -1
- package/dist/api/organizations/index.js.map +1 -1
- package/dist/api/parameters/index.d.ts +332 -314
- package/dist/api/parameters/index.d.ts.map +1 -1
- package/dist/api/parameters/index.js +37 -0
- package/dist/api/parameters/index.js.map +1 -1
- package/dist/api/payments/index.d.ts +431 -376
- package/dist/api/payments/index.d.ts.map +1 -1
- package/dist/api/payments/index.js +202 -87
- package/dist/api/payments/index.js.map +1 -1
- package/dist/api/subscriptions/index.d.ts +1695 -0
- package/dist/api/subscriptions/index.d.ts.map +1 -0
- package/dist/api/subscriptions/index.js +1919 -0
- package/dist/api/subscriptions/index.js.map +1 -0
- package/dist/api/users/index.d.ts +1001 -844
- package/dist/api/users/index.d.ts.map +1 -1
- package/dist/api/users/index.js +237 -28
- package/dist/api/users/index.js.map +1 -1
- package/dist/api/verifications/index.d.ts +123 -122
- package/dist/api/verifications/index.d.ts.map +1 -1
- package/dist/api/verifications/index.js.map +1 -1
- package/dist/batch/index.js.map +1 -1
- package/dist/bucket/index.d.ts +21 -2
- package/dist/bucket/index.d.ts.map +1 -1
- package/dist/bucket/index.js +47 -0
- package/dist/bucket/index.js.map +1 -1
- package/dist/bucket/index.workerd.js +24 -0
- package/dist/bucket/index.workerd.js.map +1 -1
- package/dist/cache/core/index.d.ts +134 -7
- package/dist/cache/core/index.d.ts.map +1 -1
- package/dist/cache/core/index.js +181 -15
- package/dist/cache/core/index.js.map +1 -1
- package/dist/cache/core/index.workerd.js +181 -15
- package/dist/cache/core/index.workerd.js.map +1 -1
- package/dist/cache/database/index.d.ts +156 -0
- package/dist/cache/database/index.d.ts.map +1 -0
- package/dist/cache/database/index.js +266 -0
- package/dist/cache/database/index.js.map +1 -0
- package/dist/cache/redis/index.d.ts +3 -2
- package/dist/cache/redis/index.d.ts.map +1 -1
- package/dist/cache/redis/index.js.map +1 -1
- package/dist/captcha/index.js.map +1 -1
- package/dist/cli/config/index.js.map +1 -1
- package/dist/cli/core/index.d.ts +142 -128
- package/dist/cli/core/index.d.ts.map +1 -1
- package/dist/cli/core/index.js +160 -13
- package/dist/cli/core/index.js.map +1 -1
- package/dist/cli/devtools/index.d.ts +3 -2
- package/dist/cli/devtools/index.d.ts.map +1 -1
- package/dist/cli/devtools/index.js.map +1 -1
- package/dist/cli/platform/index.d.ts +346 -290
- package/dist/cli/platform/index.d.ts.map +1 -1
- package/dist/cli/platform/index.js +106 -7
- package/dist/cli/platform/index.js.map +1 -1
- package/dist/cli/vendor/index.d.ts +12 -11
- package/dist/cli/vendor/index.d.ts.map +1 -1
- package/dist/cli/vendor/index.js.map +1 -1
- package/dist/command/index.d.ts +6 -5
- package/dist/command/index.d.ts.map +1 -1
- package/dist/command/index.js.map +1 -1
- package/dist/core/index.browser.js +1 -1
- package/dist/core/index.browser.js.map +1 -1
- package/dist/core/index.d.ts +119 -118
- package/dist/core/index.d.ts.map +1 -1
- package/dist/core/index.js +1 -1
- package/dist/core/index.js.map +1 -1
- package/dist/core/index.native.js +1 -1
- package/dist/core/index.native.js.map +1 -1
- package/dist/core/index.workerd.js +1 -1
- package/dist/core/index.workerd.js.map +1 -1
- package/dist/crypto/index.browser.js.map +1 -1
- package/dist/crypto/index.d.ts +3 -2
- package/dist/crypto/index.d.ts.map +1 -1
- package/dist/crypto/index.js.map +1 -1
- package/dist/datetime/index.js.map +1 -1
- package/dist/email/brevo/index.js.map +1 -1
- package/dist/email/core/index.d.ts +3 -2
- package/dist/email/core/index.d.ts.map +1 -1
- package/dist/email/core/index.js.map +1 -1
- package/dist/email/core/index.workerd.js.map +1 -1
- package/dist/email/smtp/index.d.ts +7 -6
- package/dist/email/smtp/index.d.ts.map +1 -1
- package/dist/email/smtp/index.js.map +1 -1
- package/dist/fake/index.js.map +1 -1
- package/dist/lock/core/index.d.ts +5 -4
- package/dist/lock/core/index.d.ts.map +1 -1
- package/dist/lock/core/index.js.map +1 -1
- package/dist/lock/redis/index.js.map +1 -1
- package/dist/logger/index.d.ts +10 -9
- package/dist/logger/index.d.ts.map +1 -1
- package/dist/logger/index.js.map +1 -1
- package/dist/mcp/index.d.ts +9 -8
- package/dist/mcp/index.d.ts.map +1 -1
- package/dist/mcp/index.js +1 -1
- package/dist/mcp/index.js.map +1 -1
- package/dist/orm/core/index.browser.js +9 -3
- package/dist/orm/core/index.browser.js.map +1 -1
- package/dist/orm/core/index.bun.js +31 -10
- package/dist/orm/core/index.bun.js.map +1 -1
- package/dist/orm/core/index.d.ts +33 -14
- package/dist/orm/core/index.d.ts.map +1 -1
- package/dist/orm/core/index.js +31 -10
- package/dist/orm/core/index.js.map +1 -1
- package/dist/orm/postgres/index.bun.js.map +1 -1
- package/dist/orm/postgres/index.d.ts +6 -5
- package/dist/orm/postgres/index.d.ts.map +1 -1
- package/dist/orm/postgres/index.js.map +1 -1
- package/dist/queue/core/index.d.ts +5 -4
- package/dist/queue/core/index.d.ts.map +1 -1
- package/dist/queue/core/index.js.map +1 -1
- package/dist/queue/core/index.workerd.js.map +1 -1
- package/dist/queue/redis/index.d.ts +3 -2
- package/dist/queue/redis/index.d.ts.map +1 -1
- package/dist/queue/redis/index.js.map +1 -1
- package/dist/react/auth/index.browser.js.map +1 -1
- package/dist/react/auth/index.js.map +1 -1
- package/dist/react/core/index.js.map +1 -1
- package/dist/react/form/index.d.ts +5 -0
- package/dist/react/form/index.d.ts.map +1 -1
- package/dist/react/form/index.js +8 -4
- package/dist/react/form/index.js.map +1 -1
- package/dist/react/head/index.browser.js.map +1 -1
- package/dist/react/head/index.js.map +1 -1
- package/dist/react/i18n/index.d.ts +2 -1
- package/dist/react/i18n/index.d.ts.map +1 -1
- package/dist/react/i18n/index.js.map +1 -1
- package/dist/react/intro/index.js.map +1 -1
- package/dist/react/router/index.browser.js.map +1 -1
- package/dist/react/router/index.d.ts +206 -205
- package/dist/react/router/index.d.ts.map +1 -1
- package/dist/react/router/index.js.map +1 -1
- package/dist/react/testing/index.js.map +1 -1
- package/dist/react/ui/index.d.ts +11 -11
- package/dist/react/ui/index.d.ts.map +1 -1
- package/dist/react/ui/index.js.map +1 -1
- package/dist/redis/index.bun.js.map +1 -1
- package/dist/redis/index.js.map +1 -1
- package/dist/retry/index.js.map +1 -1
- package/dist/router/index.js.map +1 -1
- package/dist/scheduler/index.d.ts +25 -2
- package/dist/scheduler/index.d.ts.map +1 -1
- package/dist/scheduler/index.js +12 -0
- package/dist/scheduler/index.js.map +1 -1
- package/dist/scheduler/index.workerd.js +12 -0
- package/dist/scheduler/index.workerd.js.map +1 -1
- package/dist/security/index.browser.js +29 -1
- package/dist/security/index.browser.js.map +1 -1
- package/dist/security/index.d.ts +82 -35
- package/dist/security/index.d.ts.map +1 -1
- package/dist/security/index.js +56 -3
- package/dist/security/index.js.map +1 -1
- package/dist/server/auth/index.d.ts +163 -158
- package/dist/server/auth/index.d.ts.map +1 -1
- package/dist/server/auth/index.js +16 -4
- package/dist/server/auth/index.js.map +1 -1
- package/dist/server/cookies/index.browser.js.map +1 -1
- package/dist/server/cookies/index.js.map +1 -1
- package/dist/server/core/index.browser.js.map +1 -1
- package/dist/server/core/index.d.ts +35 -34
- package/dist/server/core/index.d.ts.map +1 -1
- package/dist/server/core/index.js.map +1 -1
- package/dist/server/cors/index.d.ts +7 -6
- package/dist/server/cors/index.d.ts.map +1 -1
- package/dist/server/cors/index.js.map +1 -1
- package/dist/server/etag/index.js.map +1 -1
- package/dist/server/health/index.d.ts +16 -15
- package/dist/server/health/index.d.ts.map +1 -1
- package/dist/server/health/index.js.map +1 -1
- package/dist/server/links/index.browser.js.map +1 -1
- package/dist/server/links/index.d.ts +51 -50
- package/dist/server/links/index.d.ts.map +1 -1
- package/dist/server/links/index.js.map +1 -1
- package/dist/server/metrics/index.js.map +1 -1
- package/dist/server/proxy/index.js.map +1 -1
- package/dist/server/rate-limit/index.d.ts +6 -5
- package/dist/server/rate-limit/index.d.ts.map +1 -1
- package/dist/server/rate-limit/index.js.map +1 -1
- package/dist/server/static/index.js.map +1 -1
- package/dist/server/swagger/index.d.ts +2 -1
- package/dist/server/swagger/index.d.ts.map +1 -1
- package/dist/server/swagger/index.js.map +1 -1
- package/dist/sms/index.js.map +1 -1
- package/dist/system/index.browser.js.map +1 -1
- package/dist/system/index.js.map +1 -1
- package/dist/system/index.workerd.js.map +1 -1
- package/dist/topic/core/index.js.map +1 -1
- package/dist/topic/redis/index.d.ts +3 -2
- package/dist/topic/redis/index.d.ts.map +1 -1
- package/dist/topic/redis/index.js.map +1 -1
- package/package.json +33 -39
- package/src/api/audits/controllers/AdminAuditController.ts +29 -0
- package/src/api/audits/entities/audits.ts +1 -0
- package/src/api/files/controllers/FileController.ts +24 -0
- package/src/api/files/entities/files.ts +1 -0
- package/src/api/files/services/FileService.ts +41 -0
- package/src/api/jobs/__tests__/$job.spec.ts +501 -24
- package/src/api/jobs/entities/jobExecutionEntity.ts +4 -3
- package/src/api/jobs/index.ts +47 -10
- package/src/api/jobs/primitives/$job.ts +22 -9
- package/src/api/jobs/providers/DirectJobDispatcher.ts +71 -0
- package/src/api/jobs/providers/JobDispatcher.ts +49 -0
- package/src/api/jobs/providers/JobProvider.ts +385 -147
- package/src/api/jobs/providers/JobQueueProvider.ts +43 -18
- package/src/api/jobs/schemas/jobConfigAtom.ts +9 -3
- package/src/api/jobs/schemas/jobExecutionResourceSchema.ts +11 -0
- package/src/api/jobs/schemas/jobRegistrationSchema.ts +4 -2
- package/src/api/jobs/services/JobService.ts +21 -11
- package/src/api/keys/controllers/AdminApiKeyController.ts +23 -0
- package/src/api/keys/entities/apiKeyEntity.ts +1 -0
- package/src/api/keys/services/ApiKeyService.ts +42 -0
- package/src/api/notifications/__tests__/AlephaApiNotifications.spec.ts +63 -0
- package/src/api/notifications/controllers/AdminNotificationController.ts +48 -1
- package/src/api/notifications/index.ts +13 -3
- package/src/api/notifications/jobs/NotificationJobs.ts +0 -6
- package/src/api/parameters/controllers/AdminParameterController.ts +26 -0
- package/src/api/parameters/services/ParameterProvider.ts +18 -0
- package/src/api/payments/controllers/MockCheckoutController.ts +146 -0
- package/src/api/payments/index.ts +3 -0
- package/src/api/payments/providers/MemoryPaymentProvider.ts +9 -4
- package/src/api/payments/providers/PaymentProvider.ts +25 -9
- package/src/api/payments/services/PaymentService.ts +3 -0
- package/src/api/subscriptions/__tests__/BillingService.spec.ts +218 -0
- package/src/api/subscriptions/__tests__/SubscriptionService.spec.ts +278 -0
- package/src/api/subscriptions/controllers/AdminSubscriptionController.ts +212 -0
- package/src/api/subscriptions/controllers/SubscriptionController.ts +189 -0
- package/src/api/subscriptions/entities/subscriptionEvents.ts +54 -0
- package/src/api/subscriptions/entities/subscriptions.ts +68 -0
- package/src/api/subscriptions/index.ts +133 -0
- package/src/api/subscriptions/jobs/SubscriptionJobs.ts +382 -0
- package/src/api/subscriptions/middleware/$requireLimit.ts +50 -0
- package/src/api/subscriptions/middleware/$requirePlan.ts +49 -0
- package/src/api/subscriptions/notifications/SubscriptionNotifications.ts +110 -0
- package/src/api/subscriptions/schemas/cancelSubscriptionSchema.ts +8 -0
- package/src/api/subscriptions/schemas/changePlanSchema.ts +9 -0
- package/src/api/subscriptions/schemas/createSubscriptionSchema.ts +11 -0
- package/src/api/subscriptions/schemas/entitlementsSchema.ts +21 -0
- package/src/api/subscriptions/schemas/mrrSchema.ts +13 -0
- package/src/api/subscriptions/schemas/planDefinitionSchema.ts +71 -0
- package/src/api/subscriptions/schemas/planResourceSchema.ts +25 -0
- package/src/api/subscriptions/schemas/subscriptionEventResourceSchema.ts +8 -0
- package/src/api/subscriptions/schemas/subscriptionQuerySchema.ts +19 -0
- package/src/api/subscriptions/schemas/subscriptionResourceSchema.ts +6 -0
- package/src/api/subscriptions/schemas/subscriptionSettingsSchema.ts +32 -0
- package/src/api/subscriptions/schemas/subscriptionStatsSchema.ts +23 -0
- package/src/api/subscriptions/services/BillingService.ts +437 -0
- package/src/api/subscriptions/services/SubscriptionConfig.ts +56 -0
- package/src/api/subscriptions/services/SubscriptionService.ts +867 -0
- package/src/api/subscriptions/services/UsageService.ts +118 -0
- package/src/api/users/__tests__/Registration-emailMode.spec.ts +203 -0
- package/src/api/users/__tests__/UsernameSlugger.spec.ts +138 -0
- package/src/api/users/atoms/realmAuthSettingsAtom.ts +41 -3
- package/src/api/users/controllers/AdminSessionController.ts +29 -0
- package/src/api/users/controllers/AdminUserController.ts +32 -0
- package/src/api/users/index.ts +3 -0
- package/src/api/users/services/CredentialService.ts +5 -0
- package/src/api/users/services/RegistrationService.ts +49 -1
- package/src/api/users/services/SessionCrudService.ts +16 -0
- package/src/api/users/services/SessionService.ts +17 -59
- package/src/api/users/services/UsernameSlugger.ts +195 -0
- package/src/bucket/primitives/$bucket.ts +21 -0
- package/src/bucket/providers/CloudflareR2Provider.ts +15 -0
- package/src/bucket/providers/FileStorageProvider.ts +9 -0
- package/src/bucket/providers/LocalFileStorageProvider.ts +14 -0
- package/src/bucket/providers/MemoryFileStorageProvider.ts +9 -0
- package/src/bucket/providers/NodeS3BucketProvider.ts +35 -0
- package/src/cache/core/__tests__/$cache.memory.spec.ts +450 -0
- package/src/cache/core/__tests__/$cache.swr.spec.ts +394 -0
- package/src/cache/core/index.ts +16 -0
- package/src/cache/core/primitives/$cache.ts +367 -24
- package/src/cache/database/__tests__/DatabaseCacheProvider.behavior.spec.ts +203 -0
- package/src/cache/database/__tests__/DatabaseCacheProvider.spec.ts +110 -0
- package/src/cache/database/entities/cacheEntries.ts +55 -0
- package/src/cache/database/index.ts +36 -0
- package/src/cache/database/providers/DatabaseCacheProvider.ts +348 -0
- package/src/cli/core/services/ProjectScaffolder.ts +0 -2
- package/src/cli/core/tasks/BuildCloudflareTask.ts +33 -3
- package/src/cli/core/tasks/BuildSitemapTask.ts +7 -0
- package/src/cli/core/tasks/BuildVercelTask.ts +82 -3
- package/src/cli/core/templates/agentMd.ts +39 -4
- package/src/cli/core/templates/biomeJson.ts +25 -1
- package/src/cli/core/templates/saasAdminLayoutTsx.ts +2 -2
- package/src/cli/platform/__tests__/CloudflareAdapter.spec.ts +117 -0
- package/src/cli/platform/__tests__/detectResources.spec.ts +96 -0
- package/src/cli/platform/adapters/CloudflareAdapter.ts +104 -7
- package/src/cli/platform/atoms/platformOptions.ts +13 -0
- package/src/cli/platform/commands/platform.ts +7 -1
- package/src/cli/platform/schemas/platform.ts +1 -0
- package/src/cli/platform/services/CloudflareApi.ts +61 -0
- package/src/cli/platform/services/PlatformOrchestrator.ts +9 -4
- package/src/core/__tests__/$module.spec.ts +2 -2
- package/src/core/primitives/$module.ts +4 -4
- package/src/mcp/providers/McpServerProvider.ts +1 -1
- package/src/orm/core/providers/DatabaseTypeProvider.ts +9 -3
- package/src/orm/core/providers/drivers/DatabaseProvider.ts +1 -1
- package/src/orm/core/schemas/insertSchema.ts +10 -2
- package/src/orm/core/services/Repository.ts +27 -7
- package/src/react/form/hooks/useFormState.ts +8 -1
- package/src/react/form/index.ts +10 -1
- package/src/react/form/services/FormModel.ts +9 -3
- package/src/scheduler/index.ts +14 -0
- package/src/scheduler/providers/CronProvider.ts +13 -0
- package/src/security/atoms/currentTenantAtom.ts +34 -0
- package/src/security/index.browser.ts +1 -0
- package/src/security/index.ts +12 -1
- package/src/security/primitives/$issuer.ts +17 -1
- package/src/security/providers/SecurityProvider.ts +37 -0
- package/src/server/auth/__tests__/validateRedirectUri.spec.ts +78 -0
- package/src/server/auth/providers/ServerAuthProvider.ts +21 -5
- package/tsconfig.base.json +2 -1
- package/dist/react/websocket/index.d.ts +0 -117
- package/dist/react/websocket/index.d.ts.map +0 -1
- package/dist/react/websocket/index.js +0 -108
- package/dist/react/websocket/index.js.map +0 -1
- package/dist/websocket/index.browser.js +0 -844
- package/dist/websocket/index.browser.js.map +0 -1
- package/dist/websocket/index.d.ts +0 -876
- package/dist/websocket/index.d.ts.map +0 -1
- package/dist/websocket/index.js +0 -1175
- package/dist/websocket/index.js.map +0 -1
- package/src/react/websocket/hooks/useRoom.tsx +0 -251
- package/src/react/websocket/index.ts +0 -7
- package/src/websocket/__tests__/$channel.spec.ts +0 -30
- package/src/websocket/__tests__/$websocket-new.spec.ts +0 -195
- package/src/websocket/__tests__/RoomManager.spec.ts +0 -146
- package/src/websocket/__tests__/websocket-integration.spec.ts +0 -951
- package/src/websocket/errors/WebSocketError.ts +0 -34
- package/src/websocket/index.browser.ts +0 -25
- package/src/websocket/index.shared.ts +0 -8
- package/src/websocket/index.ts +0 -85
- package/src/websocket/interfaces/WebSocketInterfaces.ts +0 -252
- package/src/websocket/primitives/$channel.ts +0 -131
- package/src/websocket/primitives/$websocket.ts +0 -107
- package/src/websocket/providers/NodeWebSocketServerProvider.ts +0 -617
- package/src/websocket/providers/WebSocketServerProvider.ts +0 -56
- package/src/websocket/services/RoomManager.ts +0 -160
- package/src/websocket/services/WebSocketClient.ts +0 -642
- package/src/websocket/services/WebSocketTopicService.ts +0 -108
|
@@ -9,40 +9,42 @@ import * as _$alepha_logger0 from "alepha/logger";
|
|
|
9
9
|
import * as _$alepha_orm0 from "alepha/orm";
|
|
10
10
|
import { Page } from "alepha/orm";
|
|
11
11
|
import * as _$alepha_scheduler0 from "alepha/scheduler";
|
|
12
|
+
import * as _$typebox from "typebox";
|
|
12
13
|
import { BuildExtraConfigColumns, SQL } from "drizzle-orm";
|
|
13
14
|
import { PgColumnBuilderBase, PgSequenceOptions, PgTableExtraConfigValue, UpdateDeleteAction } from "drizzle-orm/pg-core";
|
|
14
15
|
//#region ../../src/api/files/entities/files.d.ts
|
|
15
|
-
declare const files: _$alepha_orm0.EntityPrimitive<_$
|
|
16
|
-
id: _$alepha_orm0.PgAttr<_$alepha_orm0.PgAttr<_$
|
|
17
|
-
version: _$alepha_orm0.PgAttr<_$alepha_orm0.PgAttr<_$
|
|
18
|
-
createdAt: _$alepha_orm0.PgAttr<_$alepha_orm0.PgAttr<_$
|
|
19
|
-
updatedAt: _$alepha_orm0.PgAttr<_$alepha_orm0.PgAttr<_$
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
16
|
+
declare const files: _$alepha_orm0.EntityPrimitive<_$typebox.TObject<{
|
|
17
|
+
id: _$alepha_orm0.PgAttr<_$alepha_orm0.PgAttr<_$typebox.TString, typeof _$alepha_orm0.PG_PRIMARY_KEY>, typeof _$alepha_orm0.PG_DEFAULT>;
|
|
18
|
+
version: _$alepha_orm0.PgAttr<_$alepha_orm0.PgAttr<_$typebox.TInteger, typeof _$alepha_orm0.PG_VERSION>, typeof _$alepha_orm0.PG_DEFAULT>;
|
|
19
|
+
createdAt: _$alepha_orm0.PgAttr<_$alepha_orm0.PgAttr<_$typebox.TString, typeof _$alepha_orm0.PG_CREATED_AT>, typeof _$alepha_orm0.PG_DEFAULT>;
|
|
20
|
+
updatedAt: _$alepha_orm0.PgAttr<_$alepha_orm0.PgAttr<_$typebox.TString, typeof _$alepha_orm0.PG_UPDATED_AT>, typeof _$alepha_orm0.PG_DEFAULT>;
|
|
21
|
+
organizationId: _$alepha_orm0.PgAttr<_$typebox.TString, typeof _$alepha_orm0.PG_ORGANIZATION>;
|
|
22
|
+
blobId: _$typebox.TString;
|
|
23
|
+
creator: _$typebox.TOptional<_$typebox.TString>;
|
|
24
|
+
creatorRealm: _$typebox.TOptional<_$typebox.TString>;
|
|
25
|
+
creatorName: _$typebox.TOptional<_$typebox.TString>;
|
|
26
|
+
bucket: _$typebox.TString;
|
|
27
|
+
expirationDate: _$typebox.TOptional<_$typebox.TString>;
|
|
28
|
+
name: _$typebox.TString;
|
|
29
|
+
size: _$typebox.TNumber;
|
|
30
|
+
mimeType: _$typebox.TString;
|
|
31
|
+
tags: _$typebox.TOptional<_$typebox.TArray<_$typebox.TString>>;
|
|
32
|
+
checksum: _$typebox.TOptional<_$typebox.TString>;
|
|
31
33
|
}>>;
|
|
32
34
|
type FileEntity = Static<typeof files.schema>;
|
|
33
35
|
//#endregion
|
|
34
36
|
//#region ../../src/api/files/schemas/fileQuerySchema.d.ts
|
|
35
|
-
declare const fileQuerySchema: _$
|
|
36
|
-
page: _$
|
|
37
|
-
size: _$
|
|
38
|
-
sort: _$
|
|
39
|
-
bucket: _$
|
|
40
|
-
tags: _$
|
|
41
|
-
name: _$
|
|
42
|
-
mimeType: _$
|
|
43
|
-
creator: _$
|
|
44
|
-
createdAfter: _$
|
|
45
|
-
createdBefore: _$
|
|
37
|
+
declare const fileQuerySchema: _$typebox.TObject<{
|
|
38
|
+
page: _$typebox.TOptional<_$typebox.TInteger>;
|
|
39
|
+
size: _$typebox.TOptional<_$typebox.TInteger>;
|
|
40
|
+
sort: _$typebox.TOptional<_$typebox.TString>;
|
|
41
|
+
bucket: _$typebox.TOptional<_$typebox.TString>;
|
|
42
|
+
tags: _$typebox.TOptional<_$typebox.TArray<_$typebox.TString>>;
|
|
43
|
+
name: _$typebox.TOptional<_$typebox.TString>;
|
|
44
|
+
mimeType: _$typebox.TOptional<_$typebox.TString>;
|
|
45
|
+
creator: _$typebox.TOptional<_$typebox.TString>;
|
|
46
|
+
createdAfter: _$typebox.TOptional<_$typebox.TString>;
|
|
47
|
+
createdBefore: _$typebox.TOptional<_$typebox.TString>;
|
|
46
48
|
}>;
|
|
47
49
|
type FileQuery = Static<typeof fileQuerySchema>;
|
|
48
50
|
//#endregion
|
|
@@ -60,6 +62,8 @@ type TObjectInsert<T extends TObject> = TObject<{ [K in keyof T["properties"] as
|
|
|
60
62
|
[PG_GENERATED]: any;
|
|
61
63
|
} ? never : K]: T["properties"][K] extends {
|
|
62
64
|
[PG_DEFAULT]: any;
|
|
65
|
+
} | {
|
|
66
|
+
[PG_ORGANIZATION]: any;
|
|
63
67
|
} | {
|
|
64
68
|
"~optional": true;
|
|
65
69
|
} ? TOptional<T["properties"][K]> : T["properties"][K] }>;
|
|
@@ -335,8 +339,8 @@ type PgAttr<T extends TSchema, TAttr extends PgSymbolKeys> = T & { [K in TAttr]:
|
|
|
335
339
|
* - `d1://BINDING_NAME` — Cloudflare D1
|
|
336
340
|
* - `hyperdrive://BINDING_NAME` — Cloudflare Hyperdrive
|
|
337
341
|
*/
|
|
338
|
-
declare const databaseEnvSchema: _$
|
|
339
|
-
DATABASE_URL: _$
|
|
342
|
+
declare const databaseEnvSchema: _$typebox.TObject<{
|
|
343
|
+
DATABASE_URL: _$typebox.TOptional<_$typebox.TString>;
|
|
340
344
|
/**
|
|
341
345
|
* Enable or disable push-based schema synchronization (drizzle-kit push).
|
|
342
346
|
*
|
|
@@ -344,53 +348,54 @@ declare const databaseEnvSchema: _$alepha.TObject<{
|
|
|
344
348
|
* Set to `false` in development to skip automatic schema sync
|
|
345
349
|
* (e.g. when managing migrations manually).
|
|
346
350
|
*/
|
|
347
|
-
DATABASE_SYNC: _$
|
|
351
|
+
DATABASE_SYNC: _$typebox.TOptional<_$typebox.TBoolean>;
|
|
348
352
|
}>;
|
|
349
353
|
declare module "alepha" {
|
|
350
354
|
interface Env extends Partial<Static<typeof databaseEnvSchema>> {}
|
|
351
355
|
} //# sourceMappingURL=databaseEnvSchema.d.ts.map
|
|
352
356
|
//#endregion
|
|
353
357
|
//#region ../../src/api/files/schemas/fileResourceSchema.d.ts
|
|
354
|
-
declare const fileResourceSchema: _$
|
|
355
|
-
id: PgAttr<PgAttr<_$
|
|
356
|
-
version: PgAttr<PgAttr<_$
|
|
357
|
-
createdAt: PgAttr<PgAttr<_$
|
|
358
|
-
updatedAt: PgAttr<PgAttr<_$
|
|
359
|
-
|
|
360
|
-
|
|
361
|
-
|
|
362
|
-
|
|
363
|
-
|
|
364
|
-
|
|
365
|
-
|
|
366
|
-
|
|
367
|
-
|
|
368
|
-
|
|
369
|
-
|
|
358
|
+
declare const fileResourceSchema: _$typebox.TObject<{
|
|
359
|
+
id: PgAttr<PgAttr<_$typebox.TString, typeof PG_PRIMARY_KEY>, typeof PG_DEFAULT>;
|
|
360
|
+
version: PgAttr<PgAttr<_$typebox.TInteger, typeof PG_VERSION>, typeof PG_DEFAULT>;
|
|
361
|
+
createdAt: PgAttr<PgAttr<_$typebox.TString, typeof PG_CREATED_AT>, typeof PG_DEFAULT>;
|
|
362
|
+
updatedAt: PgAttr<PgAttr<_$typebox.TString, typeof PG_UPDATED_AT>, typeof PG_DEFAULT>;
|
|
363
|
+
organizationId: PgAttr<_$typebox.TString, typeof PG_ORGANIZATION>;
|
|
364
|
+
blobId: _$typebox.TString;
|
|
365
|
+
creator: _$typebox.TOptional<_$typebox.TString>;
|
|
366
|
+
creatorRealm: _$typebox.TOptional<_$typebox.TString>;
|
|
367
|
+
creatorName: _$typebox.TOptional<_$typebox.TString>;
|
|
368
|
+
bucket: _$typebox.TString;
|
|
369
|
+
expirationDate: _$typebox.TOptional<_$typebox.TString>;
|
|
370
|
+
name: _$typebox.TString;
|
|
371
|
+
size: _$typebox.TNumber;
|
|
372
|
+
mimeType: _$typebox.TString;
|
|
373
|
+
tags: _$typebox.TOptional<_$typebox.TArray<_$typebox.TString>>;
|
|
374
|
+
checksum: _$typebox.TOptional<_$typebox.TString>;
|
|
370
375
|
}>;
|
|
371
376
|
type FileResource = Static<typeof fileResourceSchema>;
|
|
372
377
|
//#endregion
|
|
373
378
|
//#region ../../src/api/files/schemas/storageStatsSchema.d.ts
|
|
374
|
-
declare const bucketStatsSchema: _$
|
|
375
|
-
bucket: _$
|
|
376
|
-
totalSize: _$
|
|
377
|
-
fileCount: _$
|
|
379
|
+
declare const bucketStatsSchema: _$typebox.TObject<{
|
|
380
|
+
bucket: _$typebox.TString;
|
|
381
|
+
totalSize: _$typebox.TNumber;
|
|
382
|
+
fileCount: _$typebox.TNumber;
|
|
378
383
|
}>;
|
|
379
|
-
declare const mimeTypeStatsSchema: _$
|
|
380
|
-
mimeType: _$
|
|
381
|
-
fileCount: _$
|
|
384
|
+
declare const mimeTypeStatsSchema: _$typebox.TObject<{
|
|
385
|
+
mimeType: _$typebox.TString;
|
|
386
|
+
fileCount: _$typebox.TNumber;
|
|
382
387
|
}>;
|
|
383
|
-
declare const storageStatsSchema: _$
|
|
384
|
-
totalSize: _$
|
|
385
|
-
totalFiles: _$
|
|
386
|
-
byBucket: _$
|
|
387
|
-
bucket: _$
|
|
388
|
-
totalSize: _$
|
|
389
|
-
fileCount: _$
|
|
388
|
+
declare const storageStatsSchema: _$typebox.TObject<{
|
|
389
|
+
totalSize: _$typebox.TNumber;
|
|
390
|
+
totalFiles: _$typebox.TNumber;
|
|
391
|
+
byBucket: _$typebox.TArray<_$typebox.TObject<{
|
|
392
|
+
bucket: _$typebox.TString;
|
|
393
|
+
totalSize: _$typebox.TNumber;
|
|
394
|
+
fileCount: _$typebox.TNumber;
|
|
390
395
|
}>>;
|
|
391
|
-
byMimeType: _$
|
|
392
|
-
mimeType: _$
|
|
393
|
-
fileCount: _$
|
|
396
|
+
byMimeType: _$typebox.TArray<_$typebox.TObject<{
|
|
397
|
+
mimeType: _$typebox.TString;
|
|
398
|
+
fileCount: _$typebox.TNumber;
|
|
394
399
|
}>>;
|
|
395
400
|
}>;
|
|
396
401
|
type BucketStats = Static<typeof bucketStatsSchema>;
|
|
@@ -403,22 +408,23 @@ declare class FileService {
|
|
|
403
408
|
protected readonly log: _$alepha_logger0.Logger;
|
|
404
409
|
protected readonly dateTimeProvider: DateTimeProvider;
|
|
405
410
|
protected readonly defaultBucket: BucketPrimitive;
|
|
406
|
-
readonly fileRepository: _$alepha_orm0.Repository<_$
|
|
407
|
-
id: _$alepha_orm0.PgAttr<_$alepha_orm0.PgAttr<_$
|
|
408
|
-
version: _$alepha_orm0.PgAttr<_$alepha_orm0.PgAttr<_$
|
|
409
|
-
createdAt: _$alepha_orm0.PgAttr<_$alepha_orm0.PgAttr<_$
|
|
410
|
-
updatedAt: _$alepha_orm0.PgAttr<_$alepha_orm0.PgAttr<_$
|
|
411
|
-
|
|
412
|
-
|
|
413
|
-
|
|
414
|
-
|
|
415
|
-
|
|
416
|
-
|
|
417
|
-
|
|
418
|
-
|
|
419
|
-
|
|
420
|
-
|
|
421
|
-
|
|
411
|
+
readonly fileRepository: _$alepha_orm0.Repository<_$typebox.TObject<{
|
|
412
|
+
id: _$alepha_orm0.PgAttr<_$alepha_orm0.PgAttr<_$typebox.TString, typeof _$alepha_orm0.PG_PRIMARY_KEY>, typeof _$alepha_orm0.PG_DEFAULT>;
|
|
413
|
+
version: _$alepha_orm0.PgAttr<_$alepha_orm0.PgAttr<_$typebox.TInteger, typeof _$alepha_orm0.PG_VERSION>, typeof _$alepha_orm0.PG_DEFAULT>;
|
|
414
|
+
createdAt: _$alepha_orm0.PgAttr<_$alepha_orm0.PgAttr<_$typebox.TString, typeof _$alepha_orm0.PG_CREATED_AT>, typeof _$alepha_orm0.PG_DEFAULT>;
|
|
415
|
+
updatedAt: _$alepha_orm0.PgAttr<_$alepha_orm0.PgAttr<_$typebox.TString, typeof _$alepha_orm0.PG_UPDATED_AT>, typeof _$alepha_orm0.PG_DEFAULT>;
|
|
416
|
+
organizationId: _$alepha_orm0.PgAttr<_$typebox.TString, typeof _$alepha_orm0.PG_ORGANIZATION>;
|
|
417
|
+
blobId: _$typebox.TString;
|
|
418
|
+
creator: _$typebox.TOptional<_$typebox.TString>;
|
|
419
|
+
creatorRealm: _$typebox.TOptional<_$typebox.TString>;
|
|
420
|
+
creatorName: _$typebox.TOptional<_$typebox.TString>;
|
|
421
|
+
bucket: _$typebox.TString;
|
|
422
|
+
expirationDate: _$typebox.TOptional<_$typebox.TString>;
|
|
423
|
+
name: _$typebox.TString;
|
|
424
|
+
size: _$typebox.TNumber;
|
|
425
|
+
mimeType: _$typebox.TString;
|
|
426
|
+
tags: _$typebox.TOptional<_$typebox.TArray<_$typebox.TString>>;
|
|
427
|
+
checksum: _$typebox.TOptional<_$typebox.TString>;
|
|
422
428
|
}>>;
|
|
423
429
|
protected onUploadFile: _$alepha.HookPrimitive<"bucket:file:uploaded">;
|
|
424
430
|
protected onDeleteBucketFile: _$alepha.HookPrimitive<"bucket:file:deleted">;
|
|
@@ -516,6 +522,12 @@ declare class FileService {
|
|
|
516
522
|
* @throws {NotFoundError} If the file doesn't exist in the database
|
|
517
523
|
*/
|
|
518
524
|
deleteFile(id: string): Promise<Ok>;
|
|
525
|
+
/**
|
|
526
|
+
* Delete many files in one round-trip per bucket. The database rows are
|
|
527
|
+
* removed in a single `deleteMany`, and each affected bucket gets a single
|
|
528
|
+
* `bucket.deleteMany` call (R2/S3 batch where supported).
|
|
529
|
+
*/
|
|
530
|
+
deleteFiles(ids: string[]): Promise<string[]>;
|
|
519
531
|
/**
|
|
520
532
|
* Retrieves a file entity by its ID.
|
|
521
533
|
* If already an entity object, returns it as-is (convenience method).
|
|
@@ -556,17 +568,17 @@ declare class AdminFileStatsController {
|
|
|
556
568
|
* and breakdowns by bucket and MIME type.
|
|
557
569
|
*/
|
|
558
570
|
readonly getFileStats: _$alepha_server0.ActionPrimitiveFn<{
|
|
559
|
-
response: _$
|
|
560
|
-
totalSize: _$
|
|
561
|
-
totalFiles: _$
|
|
562
|
-
byBucket: _$
|
|
563
|
-
bucket: _$
|
|
564
|
-
totalSize: _$
|
|
565
|
-
fileCount: _$
|
|
571
|
+
response: _$typebox.TObject<{
|
|
572
|
+
totalSize: _$typebox.TNumber;
|
|
573
|
+
totalFiles: _$typebox.TNumber;
|
|
574
|
+
byBucket: _$typebox.TArray<_$typebox.TObject<{
|
|
575
|
+
bucket: _$typebox.TString;
|
|
576
|
+
totalSize: _$typebox.TNumber;
|
|
577
|
+
fileCount: _$typebox.TNumber;
|
|
566
578
|
}>>;
|
|
567
|
-
byMimeType: _$
|
|
568
|
-
mimeType: _$
|
|
569
|
-
fileCount: _$
|
|
579
|
+
byMimeType: _$typebox.TArray<_$typebox.TObject<{
|
|
580
|
+
mimeType: _$typebox.TString;
|
|
581
|
+
fileCount: _$typebox.TNumber;
|
|
570
582
|
}>>;
|
|
571
583
|
}>;
|
|
572
584
|
}>;
|
|
@@ -586,34 +598,35 @@ declare class FileController {
|
|
|
586
598
|
* Supports filtering by bucket and tags.
|
|
587
599
|
*/
|
|
588
600
|
readonly findFiles: _$alepha_server0.ActionPrimitiveFn<{
|
|
589
|
-
query: _$
|
|
590
|
-
page: _$
|
|
591
|
-
size: _$
|
|
592
|
-
sort: _$
|
|
593
|
-
bucket: _$
|
|
594
|
-
tags: _$
|
|
595
|
-
name: _$
|
|
596
|
-
mimeType: _$
|
|
597
|
-
creator: _$
|
|
598
|
-
createdAfter: _$
|
|
599
|
-
createdBefore: _$
|
|
601
|
+
query: _$typebox.TObject<{
|
|
602
|
+
page: _$typebox.TOptional<_$typebox.TInteger>;
|
|
603
|
+
size: _$typebox.TOptional<_$typebox.TInteger>;
|
|
604
|
+
sort: _$typebox.TOptional<_$typebox.TString>;
|
|
605
|
+
bucket: _$typebox.TOptional<_$typebox.TString>;
|
|
606
|
+
tags: _$typebox.TOptional<_$typebox.TArray<_$typebox.TString>>;
|
|
607
|
+
name: _$typebox.TOptional<_$typebox.TString>;
|
|
608
|
+
mimeType: _$typebox.TOptional<_$typebox.TString>;
|
|
609
|
+
creator: _$typebox.TOptional<_$typebox.TString>;
|
|
610
|
+
createdAfter: _$typebox.TOptional<_$typebox.TString>;
|
|
611
|
+
createdBefore: _$typebox.TOptional<_$typebox.TString>;
|
|
600
612
|
}>;
|
|
601
|
-
response: _$alepha.TPage<_$
|
|
602
|
-
id: PgAttr<PgAttr<_$
|
|
603
|
-
version: PgAttr<PgAttr<_$
|
|
604
|
-
createdAt: PgAttr<PgAttr<_$
|
|
605
|
-
updatedAt: PgAttr<PgAttr<_$
|
|
606
|
-
|
|
607
|
-
|
|
608
|
-
|
|
609
|
-
|
|
610
|
-
|
|
611
|
-
|
|
612
|
-
|
|
613
|
-
|
|
614
|
-
|
|
615
|
-
|
|
616
|
-
|
|
613
|
+
response: _$alepha.TPage<_$typebox.TObject<{
|
|
614
|
+
id: PgAttr<PgAttr<_$typebox.TString, typeof PG_PRIMARY_KEY>, typeof PG_DEFAULT>;
|
|
615
|
+
version: PgAttr<PgAttr<_$typebox.TInteger, typeof PG_VERSION>, typeof PG_DEFAULT>;
|
|
616
|
+
createdAt: PgAttr<PgAttr<_$typebox.TString, typeof PG_CREATED_AT>, typeof PG_DEFAULT>;
|
|
617
|
+
updatedAt: PgAttr<PgAttr<_$typebox.TString, typeof PG_UPDATED_AT>, typeof PG_DEFAULT>;
|
|
618
|
+
organizationId: PgAttr<_$typebox.TString, typeof PG_ORGANIZATION>;
|
|
619
|
+
blobId: _$typebox.TString;
|
|
620
|
+
creator: _$typebox.TOptional<_$typebox.TString>;
|
|
621
|
+
creatorRealm: _$typebox.TOptional<_$typebox.TString>;
|
|
622
|
+
creatorName: _$typebox.TOptional<_$typebox.TString>;
|
|
623
|
+
bucket: _$typebox.TString;
|
|
624
|
+
expirationDate: _$typebox.TOptional<_$typebox.TString>;
|
|
625
|
+
name: _$typebox.TString;
|
|
626
|
+
size: _$typebox.TNumber;
|
|
627
|
+
mimeType: _$typebox.TString;
|
|
628
|
+
tags: _$typebox.TOptional<_$typebox.TArray<_$typebox.TString>>;
|
|
629
|
+
checksum: _$typebox.TOptional<_$typebox.TString>;
|
|
617
630
|
}>>;
|
|
618
631
|
}>;
|
|
619
632
|
/**
|
|
@@ -621,13 +634,25 @@ declare class FileController {
|
|
|
621
634
|
* Removes the file from the bucket and cleans up the database record.
|
|
622
635
|
*/
|
|
623
636
|
readonly deleteFile: _$alepha_server0.ActionPrimitiveFn<{
|
|
624
|
-
params: _$
|
|
625
|
-
id: _$
|
|
637
|
+
params: _$typebox.TObject<{
|
|
638
|
+
id: _$typebox.TString;
|
|
639
|
+
}>;
|
|
640
|
+
response: _$typebox.TObject<{
|
|
641
|
+
ok: _$typebox.TBoolean;
|
|
642
|
+
id: _$typebox.TOptional<_$typebox.TUnion<[_$typebox.TString, _$typebox.TInteger]>>;
|
|
643
|
+
count: _$typebox.TOptional<_$typebox.TNumber>;
|
|
644
|
+
}>;
|
|
645
|
+
}>;
|
|
646
|
+
/**
|
|
647
|
+
* POST /files/delete - Delete many files in one request, batching the
|
|
648
|
+
* underlying bucket calls per bucket (R2/S3 batch where supported).
|
|
649
|
+
*/
|
|
650
|
+
readonly deleteFiles: _$alepha_server0.ActionPrimitiveFn<{
|
|
651
|
+
body: _$typebox.TObject<{
|
|
652
|
+
ids: _$typebox.TArray<_$typebox.TString>;
|
|
626
653
|
}>;
|
|
627
|
-
response: _$
|
|
628
|
-
|
|
629
|
-
id: _$alepha.TOptional<_$alepha.TUnion<[_$alepha.TString, _$alepha.TInteger]>>;
|
|
630
|
-
count: _$alepha.TOptional<_$alepha.TNumber>;
|
|
654
|
+
response: _$typebox.TObject<{
|
|
655
|
+
deleted: _$typebox.TArray<_$typebox.TString>;
|
|
631
656
|
}>;
|
|
632
657
|
}>;
|
|
633
658
|
/**
|
|
@@ -636,29 +661,30 @@ declare class FileController {
|
|
|
636
661
|
* Optionally specify bucket and expiration date.
|
|
637
662
|
*/
|
|
638
663
|
readonly uploadFile: _$alepha_server0.ActionPrimitiveFn<{
|
|
639
|
-
body: _$
|
|
664
|
+
body: _$typebox.TObject<{
|
|
640
665
|
file: _$alepha.TFile;
|
|
641
666
|
}>;
|
|
642
|
-
query: _$
|
|
643
|
-
expirationDate: _$
|
|
644
|
-
bucket: _$
|
|
667
|
+
query: _$typebox.TObject<{
|
|
668
|
+
expirationDate: _$typebox.TOptional<_$typebox.TString>;
|
|
669
|
+
bucket: _$typebox.TOptional<_$typebox.TString>;
|
|
645
670
|
}>;
|
|
646
|
-
response: _$
|
|
647
|
-
id: PgAttr<PgAttr<_$
|
|
648
|
-
version: PgAttr<PgAttr<_$
|
|
649
|
-
createdAt: PgAttr<PgAttr<_$
|
|
650
|
-
updatedAt: PgAttr<PgAttr<_$
|
|
651
|
-
|
|
652
|
-
|
|
653
|
-
|
|
654
|
-
|
|
655
|
-
|
|
656
|
-
|
|
657
|
-
|
|
658
|
-
|
|
659
|
-
|
|
660
|
-
|
|
661
|
-
|
|
671
|
+
response: _$typebox.TObject<{
|
|
672
|
+
id: PgAttr<PgAttr<_$typebox.TString, typeof PG_PRIMARY_KEY>, typeof PG_DEFAULT>;
|
|
673
|
+
version: PgAttr<PgAttr<_$typebox.TInteger, typeof PG_VERSION>, typeof PG_DEFAULT>;
|
|
674
|
+
createdAt: PgAttr<PgAttr<_$typebox.TString, typeof PG_CREATED_AT>, typeof PG_DEFAULT>;
|
|
675
|
+
updatedAt: PgAttr<PgAttr<_$typebox.TString, typeof PG_UPDATED_AT>, typeof PG_DEFAULT>;
|
|
676
|
+
organizationId: PgAttr<_$typebox.TString, typeof PG_ORGANIZATION>;
|
|
677
|
+
blobId: _$typebox.TString;
|
|
678
|
+
creator: _$typebox.TOptional<_$typebox.TString>;
|
|
679
|
+
creatorRealm: _$typebox.TOptional<_$typebox.TString>;
|
|
680
|
+
creatorName: _$typebox.TOptional<_$typebox.TString>;
|
|
681
|
+
bucket: _$typebox.TString;
|
|
682
|
+
expirationDate: _$typebox.TOptional<_$typebox.TString>;
|
|
683
|
+
name: _$typebox.TString;
|
|
684
|
+
size: _$typebox.TNumber;
|
|
685
|
+
mimeType: _$typebox.TString;
|
|
686
|
+
tags: _$typebox.TOptional<_$typebox.TArray<_$typebox.TString>>;
|
|
687
|
+
checksum: _$typebox.TOptional<_$typebox.TString>;
|
|
662
688
|
}>;
|
|
663
689
|
}>;
|
|
664
690
|
/**
|
|
@@ -666,30 +692,31 @@ declare class FileController {
|
|
|
666
692
|
* Allows updating name, tags, and expiration date without modifying file content.
|
|
667
693
|
*/
|
|
668
694
|
readonly updateFile: _$alepha_server0.ActionPrimitiveFn<{
|
|
669
|
-
params: _$
|
|
670
|
-
id: _$
|
|
695
|
+
params: _$typebox.TObject<{
|
|
696
|
+
id: _$typebox.TString;
|
|
671
697
|
}>;
|
|
672
|
-
body: _$
|
|
673
|
-
name: _$
|
|
674
|
-
tags: _$
|
|
675
|
-
expirationDate: _$
|
|
698
|
+
body: _$typebox.TObject<{
|
|
699
|
+
name: _$typebox.TOptional<_$typebox.TString>;
|
|
700
|
+
tags: _$typebox.TOptional<_$typebox.TArray<_$typebox.TString>>;
|
|
701
|
+
expirationDate: _$typebox.TOptional<_$typebox.TString>;
|
|
676
702
|
}>;
|
|
677
|
-
response: _$
|
|
678
|
-
id: PgAttr<PgAttr<_$
|
|
679
|
-
version: PgAttr<PgAttr<_$
|
|
680
|
-
createdAt: PgAttr<PgAttr<_$
|
|
681
|
-
updatedAt: PgAttr<PgAttr<_$
|
|
682
|
-
|
|
683
|
-
|
|
684
|
-
|
|
685
|
-
|
|
686
|
-
|
|
687
|
-
|
|
688
|
-
|
|
689
|
-
|
|
690
|
-
|
|
691
|
-
|
|
692
|
-
|
|
703
|
+
response: _$typebox.TObject<{
|
|
704
|
+
id: PgAttr<PgAttr<_$typebox.TString, typeof PG_PRIMARY_KEY>, typeof PG_DEFAULT>;
|
|
705
|
+
version: PgAttr<PgAttr<_$typebox.TInteger, typeof PG_VERSION>, typeof PG_DEFAULT>;
|
|
706
|
+
createdAt: PgAttr<PgAttr<_$typebox.TString, typeof PG_CREATED_AT>, typeof PG_DEFAULT>;
|
|
707
|
+
updatedAt: PgAttr<PgAttr<_$typebox.TString, typeof PG_UPDATED_AT>, typeof PG_DEFAULT>;
|
|
708
|
+
organizationId: PgAttr<_$typebox.TString, typeof PG_ORGANIZATION>;
|
|
709
|
+
blobId: _$typebox.TString;
|
|
710
|
+
creator: _$typebox.TOptional<_$typebox.TString>;
|
|
711
|
+
creatorRealm: _$typebox.TOptional<_$typebox.TString>;
|
|
712
|
+
creatorName: _$typebox.TOptional<_$typebox.TString>;
|
|
713
|
+
bucket: _$typebox.TString;
|
|
714
|
+
expirationDate: _$typebox.TOptional<_$typebox.TString>;
|
|
715
|
+
name: _$typebox.TString;
|
|
716
|
+
size: _$typebox.TNumber;
|
|
717
|
+
mimeType: _$typebox.TString;
|
|
718
|
+
tags: _$typebox.TOptional<_$typebox.TArray<_$typebox.TString>>;
|
|
719
|
+
checksum: _$typebox.TOptional<_$typebox.TString>;
|
|
693
720
|
}>;
|
|
694
721
|
}>;
|
|
695
722
|
/**
|
|
@@ -698,8 +725,8 @@ declare class FileController {
|
|
|
698
725
|
* Cached with ETag support for 1 year (immutable).
|
|
699
726
|
*/
|
|
700
727
|
readonly streamFile: _$alepha_server0.ActionPrimitiveFn<{
|
|
701
|
-
params: _$
|
|
702
|
-
id: _$
|
|
728
|
+
params: _$typebox.TObject<{
|
|
729
|
+
id: _$typebox.TString;
|
|
703
730
|
}>;
|
|
704
731
|
response: _$alepha.TFile;
|
|
705
732
|
}>;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","names":[],"sources":["../../../src/api/files/entities/files.ts","../../../src/api/files/schemas/fileQuerySchema.ts","../../../src/orm/core/schemas/insertSchema.ts","../../../src/orm/core/schemas/updateSchema.ts","../../../src/orm/core/primitives/$entity.ts","../../../src/orm/core/constants/PG_SYMBOLS.ts","../../../src/orm/core/helpers/pgAttr.ts","../../../src/orm/core/schemas/databaseEnvSchema.ts","../../../src/api/files/schemas/fileResourceSchema.ts","../../../src/api/files/schemas/storageStatsSchema.ts","../../../src/api/files/services/FileService.ts","../../../src/api/files/controllers/AdminFileStatsController.ts","../../../src/api/files/controllers/FileController.ts","../../../src/api/files/jobs/FileJobs.ts","../../../src/api/files/index.ts"],"mappings":"
|
|
1
|
+
{"version":3,"file":"index.d.ts","names":[],"sources":["../../../src/api/files/entities/files.ts","../../../src/api/files/schemas/fileQuerySchema.ts","../../../src/orm/core/schemas/insertSchema.ts","../../../src/orm/core/schemas/updateSchema.ts","../../../src/orm/core/primitives/$entity.ts","../../../src/orm/core/constants/PG_SYMBOLS.ts","../../../src/orm/core/helpers/pgAttr.ts","../../../src/orm/core/schemas/databaseEnvSchema.ts","../../../src/api/files/schemas/fileResourceSchema.ts","../../../src/api/files/schemas/storageStatsSchema.ts","../../../src/api/files/services/FileService.ts","../../../src/api/files/controllers/AdminFileStatsController.ts","../../../src/api/files/controllers/FileController.ts","../../../src/api/files/jobs/FileJobs.ts","../../../src/api/files/index.ts"],"mappings":"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"}
|
package/dist/api/files/index.js
CHANGED
|
@@ -33,6 +33,7 @@ const files = $entity({
|
|
|
33
33
|
version: db.version(),
|
|
34
34
|
createdAt: db.createdAt(),
|
|
35
35
|
updatedAt: db.updatedAt(),
|
|
36
|
+
organizationId: db.organization(),
|
|
36
37
|
blobId: t.text(),
|
|
37
38
|
creator: t.optional(t.uuid()),
|
|
38
39
|
creatorRealm: t.optional(t.string()),
|
|
@@ -255,6 +256,36 @@ var FileService = class {
|
|
|
255
256
|
};
|
|
256
257
|
}
|
|
257
258
|
/**
|
|
259
|
+
* Delete many files in one round-trip per bucket. The database rows are
|
|
260
|
+
* removed in a single `deleteMany`, and each affected bucket gets a single
|
|
261
|
+
* `bucket.deleteMany` call (R2/S3 batch where supported).
|
|
262
|
+
*/
|
|
263
|
+
async deleteFiles(ids) {
|
|
264
|
+
if (ids.length === 0) return [];
|
|
265
|
+
const files = await this.fileRepository.findMany({
|
|
266
|
+
where: { id: { inArray: ids } },
|
|
267
|
+
columns: [
|
|
268
|
+
"id",
|
|
269
|
+
"bucket",
|
|
270
|
+
"blobId"
|
|
271
|
+
]
|
|
272
|
+
});
|
|
273
|
+
if (files.length === 0) return [];
|
|
274
|
+
const dbDeleted = await this.fileRepository.deleteMany({ id: { inArray: files.map((f) => f.id) } });
|
|
275
|
+
const blobsByBucket = /* @__PURE__ */ new Map();
|
|
276
|
+
for (const f of files) {
|
|
277
|
+
const list = blobsByBucket.get(f.bucket) ?? [];
|
|
278
|
+
list.push(f.blobId);
|
|
279
|
+
blobsByBucket.set(f.bucket, list);
|
|
280
|
+
}
|
|
281
|
+
for (const [bucketName, blobIds] of blobsByBucket) try {
|
|
282
|
+
await this.bucket(bucketName).deleteMany(blobIds, true);
|
|
283
|
+
} catch (e) {
|
|
284
|
+
this.log.warn(`Failed to bulk-delete ${blobIds.length} files from bucket ${bucketName}`, e);
|
|
285
|
+
}
|
|
286
|
+
return dbDeleted.map(String);
|
|
287
|
+
}
|
|
288
|
+
/**
|
|
258
289
|
* Retrieves a file entity by its ID.
|
|
259
290
|
* If already an entity object, returns it as-is (convenience method).
|
|
260
291
|
*
|
|
@@ -398,6 +429,27 @@ var FileController = class {
|
|
|
398
429
|
handler: ({ params }) => this.fileService.deleteFile(params.id)
|
|
399
430
|
});
|
|
400
431
|
/**
|
|
432
|
+
* POST /files/delete - Delete many files in one request, batching the
|
|
433
|
+
* underlying bucket calls per bucket (R2/S3 batch where supported).
|
|
434
|
+
*/
|
|
435
|
+
deleteFiles = $action({
|
|
436
|
+
method: "POST",
|
|
437
|
+
path: `${this.url}/delete`,
|
|
438
|
+
group: `admin:${this.group}`,
|
|
439
|
+
use: [$secure({ permissions: ["admin:file:delete"] })],
|
|
440
|
+
description: "Delete many files",
|
|
441
|
+
schema: {
|
|
442
|
+
body: t.object({ ids: t.array(t.uuid(), {
|
|
443
|
+
minItems: 1,
|
|
444
|
+
maxItems: 1e3
|
|
445
|
+
}) }),
|
|
446
|
+
response: t.object({ deleted: t.array(t.string()) })
|
|
447
|
+
},
|
|
448
|
+
handler: async ({ body }) => {
|
|
449
|
+
return { deleted: await this.fileService.deleteFiles(body.ids) };
|
|
450
|
+
}
|
|
451
|
+
});
|
|
452
|
+
/**
|
|
401
453
|
* POST /files - Uploads a new file to storage.
|
|
402
454
|
* Creates a database record with metadata and calculates checksum.
|
|
403
455
|
* Optionally specify bucket and expiration date.
|