@ekrist1/vulse 0.1.6-alpha.3
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE +21 -0
- package/README.md +104 -0
- package/dist/admin/client/active-locale.d.ts +3 -0
- package/dist/admin/client/active-locale.d.ts.map +1 -0
- package/dist/admin/client/active-locale.js +14 -0
- package/dist/admin/client/api.d.ts +14 -0
- package/dist/admin/client/api.d.ts.map +1 -0
- package/dist/admin/client/api.js +26 -0
- package/dist/admin/client/form-from-zod.d.ts +2 -0
- package/dist/admin/client/form-from-zod.d.ts.map +1 -0
- package/dist/admin/client/form-from-zod.js +1 -0
- package/dist/admin/client/live-preview-enabled.d.ts +3 -0
- package/dist/admin/client/live-preview-enabled.d.ts.map +1 -0
- package/dist/admin/client/live-preview-enabled.js +6 -0
- package/dist/cli/collection-scaffold.d.ts +14 -0
- package/dist/cli/collection-scaffold.d.ts.map +1 -0
- package/dist/cli/collection-scaffold.js +44 -0
- package/dist/cli/index.d.ts +3 -0
- package/dist/cli/index.d.ts.map +1 -0
- package/dist/cli/index.js +74 -0
- package/dist/cli/migrate.d.ts +5 -0
- package/dist/cli/migrate.d.ts.map +1 -0
- package/dist/cli/migrate.js +10 -0
- package/dist/cli/platform.d.ts +12 -0
- package/dist/cli/platform.d.ts.map +1 -0
- package/dist/cli/platform.js +38 -0
- package/dist/cli/seed-admin.d.ts +19 -0
- package/dist/cli/seed-admin.d.ts.map +1 -0
- package/dist/cli/seed-admin.js +59 -0
- package/dist/cli/setup.d.ts +29 -0
- package/dist/cli/setup.d.ts.map +1 -0
- package/dist/cli/setup.js +254 -0
- package/dist/core/access.d.ts +5 -0
- package/dist/core/access.d.ts.map +1 -0
- package/dist/core/access.js +6 -0
- package/dist/core/blocks/schema.d.ts +81 -0
- package/dist/core/blocks/schema.d.ts.map +1 -0
- package/dist/core/blocks/schema.js +54 -0
- package/dist/core/blueprints/code-to-definition.d.ts +6 -0
- package/dist/core/blueprints/code-to-definition.d.ts.map +1 -0
- package/dist/core/blueprints/code-to-definition.js +147 -0
- package/dist/core/blueprints/compile.d.ts +10 -0
- package/dist/core/blueprints/compile.d.ts.map +1 -0
- package/dist/core/blueprints/compile.js +153 -0
- package/dist/core/blueprints/define.d.ts +6 -0
- package/dist/core/blueprints/define.d.ts.map +1 -0
- package/dist/core/blueprints/define.js +8 -0
- package/dist/core/blueprints/definition.d.ts +963 -0
- package/dist/core/blueprints/definition.d.ts.map +1 -0
- package/dist/core/blueprints/definition.js +151 -0
- package/dist/core/blueprints/load.d.ts +11 -0
- package/dist/core/blueprints/load.d.ts.map +1 -0
- package/dist/core/blueprints/load.js +137 -0
- package/dist/core/blueprints/mutations.d.ts +8 -0
- package/dist/core/blueprints/mutations.d.ts.map +1 -0
- package/dist/core/blueprints/mutations.js +191 -0
- package/dist/core/blueprints/preview-path.d.ts +15 -0
- package/dist/core/blueprints/preview-path.d.ts.map +1 -0
- package/dist/core/blueprints/preview-path.js +25 -0
- package/dist/core/blueprints/reflect-fields.d.ts +36 -0
- package/dist/core/blueprints/reflect-fields.d.ts.map +1 -0
- package/dist/core/blueprints/reflect-fields.js +229 -0
- package/dist/core/blueprints/registry.d.ts +9 -0
- package/dist/core/blueprints/registry.d.ts.map +1 -0
- package/dist/core/blueprints/registry.js +11 -0
- package/dist/core/blueprints/seed.d.ts +5 -0
- package/dist/core/blueprints/seed.d.ts.map +1 -0
- package/dist/core/blueprints/seed.js +17 -0
- package/dist/core/blueprints/select-helpers.d.ts +10 -0
- package/dist/core/blueprints/select-helpers.d.ts.map +1 -0
- package/dist/core/blueprints/select-helpers.js +26 -0
- package/dist/core/blueprints/seo.d.ts +41 -0
- package/dist/core/blueprints/seo.d.ts.map +1 -0
- package/dist/core/blueprints/seo.js +125 -0
- package/dist/core/blueprints/types.d.ts +60 -0
- package/dist/core/blueprints/types.d.ts.map +1 -0
- package/dist/core/blueprints/types.js +1 -0
- package/dist/core/blueprints/zod-helpers.d.ts +79 -0
- package/dist/core/blueprints/zod-helpers.d.ts.map +1 -0
- package/dist/core/blueprints/zod-helpers.js +72 -0
- package/dist/core/db.d.ts +7 -0
- package/dist/core/db.d.ts.map +1 -0
- package/dist/core/db.js +8 -0
- package/dist/core/errors.d.ts +21 -0
- package/dist/core/errors.d.ts.map +1 -0
- package/dist/core/errors.js +29 -0
- package/dist/core/forms/compile.d.ts +9 -0
- package/dist/core/forms/compile.d.ts.map +1 -0
- package/dist/core/forms/compile.js +80 -0
- package/dist/core/forms/definition.d.ts +226 -0
- package/dist/core/forms/definition.d.ts.map +1 -0
- package/dist/core/forms/definition.js +83 -0
- package/dist/core/forms/rate-limit.d.ts +10 -0
- package/dist/core/forms/rate-limit.d.ts.map +1 -0
- package/dist/core/forms/rate-limit.js +31 -0
- package/dist/core/forms/unique.d.ts +5 -0
- package/dist/core/forms/unique.d.ts.map +1 -0
- package/dist/core/forms/unique.js +30 -0
- package/dist/core/globals/compile.d.ts +13 -0
- package/dist/core/globals/compile.d.ts.map +1 -0
- package/dist/core/globals/compile.js +17 -0
- package/dist/core/globals/definition.d.ts +161 -0
- package/dist/core/globals/definition.d.ts.map +1 -0
- package/dist/core/globals/definition.js +23 -0
- package/dist/core/locales.d.ts +14 -0
- package/dist/core/locales.d.ts.map +1 -0
- package/dist/core/locales.js +35 -0
- package/dist/core/migrations.d.ts +3 -0
- package/dist/core/migrations.d.ts.map +1 -0
- package/dist/core/migrations.js +41 -0
- package/dist/core/parse-content.d.ts +14 -0
- package/dist/core/parse-content.d.ts.map +1 -0
- package/dist/core/parse-content.js +68 -0
- package/dist/core/plugins/definition.d.ts +99 -0
- package/dist/core/plugins/definition.d.ts.map +1 -0
- package/dist/core/plugins/definition.js +10 -0
- package/dist/core/preview-content.d.ts +16 -0
- package/dist/core/preview-content.d.ts.map +1 -0
- package/dist/core/preview-content.js +8 -0
- package/dist/core/repos/entries.d.ts +102 -0
- package/dist/core/repos/entries.d.ts.map +1 -0
- package/dist/core/repos/entries.js +393 -0
- package/dist/core/repos/forms.d.ts +82 -0
- package/dist/core/repos/forms.d.ts.map +1 -0
- package/dist/core/repos/forms.js +199 -0
- package/dist/core/repos/globals.d.ts +31 -0
- package/dist/core/repos/globals.d.ts.map +1 -0
- package/dist/core/repos/globals.js +150 -0
- package/dist/core/repos/media.d.ts +39 -0
- package/dist/core/repos/media.d.ts.map +1 -0
- package/dist/core/repos/media.js +81 -0
- package/dist/core/repos/preview-sessions.d.ts +35 -0
- package/dist/core/repos/preview-sessions.d.ts.map +1 -0
- package/dist/core/repos/preview-sessions.js +85 -0
- package/dist/core/repos/revisions.d.ts +24 -0
- package/dist/core/repos/revisions.d.ts.map +1 -0
- package/dist/core/repos/revisions.js +44 -0
- package/dist/core/repos/settings.d.ts +9 -0
- package/dist/core/repos/settings.d.ts.map +1 -0
- package/dist/core/repos/settings.js +21 -0
- package/dist/core/schema.d.ts +2717 -0
- package/dist/core/schema.d.ts.map +1 -0
- package/dist/core/schema.js +220 -0
- package/dist/core/sets/compile.d.ts +8 -0
- package/dist/core/sets/compile.d.ts.map +1 -0
- package/dist/core/sets/compile.js +4 -0
- package/dist/core/sets/definition.d.ts +53 -0
- package/dist/core/sets/definition.d.ts.map +1 -0
- package/dist/core/sets/definition.js +7 -0
- package/dist/core/sets/service.d.ts +13 -0
- package/dist/core/sets/service.d.ts.map +1 -0
- package/dist/core/sets/service.js +68 -0
- package/dist/core/sets/validate-tree.d.ts +4 -0
- package/dist/core/sets/validate-tree.d.ts.map +1 -0
- package/dist/core/sets/validate-tree.js +40 -0
- package/dist/core/slug.d.ts +5 -0
- package/dist/core/slug.d.ts.map +1 -0
- package/dist/core/slug.js +25 -0
- package/dist/index.d.ts +16 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +19 -0
- package/dist/integration/cron.d.ts +4 -0
- package/dist/integration/cron.d.ts.map +1 -0
- package/dist/integration/cron.js +2 -0
- package/dist/integration/index.d.ts +9 -0
- package/dist/integration/index.d.ts.map +1 -0
- package/dist/integration/index.js +63 -0
- package/dist/integration/inject-admin-routes.d.ts +12 -0
- package/dist/integration/inject-admin-routes.d.ts.map +1 -0
- package/dist/integration/inject-admin-routes.js +35 -0
- package/dist/integration/inject-routes.d.ts +11 -0
- package/dist/integration/inject-routes.d.ts.map +1 -0
- package/dist/integration/inject-routes.js +51 -0
- package/dist/integration/install-hook.d.ts +2 -0
- package/dist/integration/install-hook.d.ts.map +1 -0
- package/dist/integration/install-hook.js +74 -0
- package/dist/integration/live-preview-middleware-helpers.d.ts +29 -0
- package/dist/integration/live-preview-middleware-helpers.d.ts.map +1 -0
- package/dist/integration/live-preview-middleware-helpers.js +75 -0
- package/dist/integration/loader-binding.d.ts +6 -0
- package/dist/integration/loader-binding.d.ts.map +1 -0
- package/dist/integration/loader-binding.js +15 -0
- package/dist/integration/middleware.d.ts +2 -0
- package/dist/integration/middleware.d.ts.map +1 -0
- package/dist/integration/middleware.js +51 -0
- package/dist/integration/type-gen.d.ts +2 -0
- package/dist/integration/type-gen.d.ts.map +1 -0
- package/dist/integration/type-gen.js +26 -0
- package/dist/integration/vite-plugin-blueprints.d.ts +3 -0
- package/dist/integration/vite-plugin-blueprints.d.ts.map +1 -0
- package/dist/integration/vite-plugin-blueprints.js +33 -0
- package/dist/integration/wrangler-patch.d.ts +6 -0
- package/dist/integration/wrangler-patch.d.ts.map +1 -0
- package/dist/integration/wrangler-patch.js +18 -0
- package/dist/integration.d.ts +3 -0
- package/dist/integration.d.ts.map +1 -0
- package/dist/integration.js +1 -0
- package/dist/loader.d.ts +3 -0
- package/dist/loader.d.ts.map +1 -0
- package/dist/loader.js +1 -0
- package/dist/package-name.d.ts +3 -0
- package/dist/package-name.d.ts.map +1 -0
- package/dist/package-name.js +2 -0
- package/dist/scaffold/collection-write.d.ts +14 -0
- package/dist/scaffold/collection-write.d.ts.map +1 -0
- package/dist/scaffold/collection-write.js +59 -0
- package/dist/scaffold/collection.d.ts +36 -0
- package/dist/scaffold/collection.d.ts.map +1 -0
- package/dist/scaffold/collection.js +231 -0
- package/dist/server/assets/live-preview-bridge.content.d.ts +2 -0
- package/dist/server/assets/live-preview-bridge.content.d.ts.map +1 -0
- package/dist/server/assets/live-preview-bridge.content.js +2 -0
- package/dist/server/better-auth.d.ts +71 -0
- package/dist/server/better-auth.d.ts.map +1 -0
- package/dist/server/better-auth.js +68 -0
- package/dist/server/cf-images.d.ts +12 -0
- package/dist/server/cf-images.d.ts.map +1 -0
- package/dist/server/cf-images.js +27 -0
- package/dist/server/cron.d.ts +9 -0
- package/dist/server/cron.d.ts.map +1 -0
- package/dist/server/cron.js +26 -0
- package/dist/server/email.d.ts +10 -0
- package/dist/server/email.d.ts.map +1 -0
- package/dist/server/email.js +9 -0
- package/dist/server/endpoints/api-auth.d.ts +5 -0
- package/dist/server/endpoints/api-auth.d.ts.map +1 -0
- package/dist/server/endpoints/api-auth.js +7 -0
- package/dist/server/endpoints/api-vulse-blueprints.d.ts +6 -0
- package/dist/server/endpoints/api-vulse-blueprints.d.ts.map +1 -0
- package/dist/server/endpoints/api-vulse-blueprints.js +19 -0
- package/dist/server/endpoints/api-vulse-entries-locales.d.ts +4 -0
- package/dist/server/endpoints/api-vulse-entries-locales.d.ts.map +1 -0
- package/dist/server/endpoints/api-vulse-entries-locales.js +9 -0
- package/dist/server/endpoints/api-vulse-entries-move.d.ts +3 -0
- package/dist/server/endpoints/api-vulse-entries-move.d.ts.map +1 -0
- package/dist/server/endpoints/api-vulse-entries-move.js +5 -0
- package/dist/server/endpoints/api-vulse-entries-publish.d.ts +3 -0
- package/dist/server/endpoints/api-vulse-entries-publish.d.ts.map +1 -0
- package/dist/server/endpoints/api-vulse-entries-publish.js +5 -0
- package/dist/server/endpoints/api-vulse-entries-tree.d.ts +3 -0
- package/dist/server/endpoints/api-vulse-entries-tree.d.ts.map +1 -0
- package/dist/server/endpoints/api-vulse-entries-tree.js +5 -0
- package/dist/server/endpoints/api-vulse-entries.d.ts +6 -0
- package/dist/server/endpoints/api-vulse-entries.d.ts.map +1 -0
- package/dist/server/endpoints/api-vulse-entries.js +19 -0
- package/dist/server/endpoints/api-vulse-form-handle.d.ts +6 -0
- package/dist/server/endpoints/api-vulse-form-handle.d.ts.map +1 -0
- package/dist/server/endpoints/api-vulse-form-handle.js +27 -0
- package/dist/server/endpoints/api-vulse-form-public.d.ts +3 -0
- package/dist/server/endpoints/api-vulse-form-public.d.ts.map +1 -0
- package/dist/server/endpoints/api-vulse-form-public.js +5 -0
- package/dist/server/endpoints/api-vulse-form-submit.d.ts +3 -0
- package/dist/server/endpoints/api-vulse-form-submit.d.ts.map +1 -0
- package/dist/server/endpoints/api-vulse-form-submit.js +5 -0
- package/dist/server/endpoints/api-vulse-form-upload.d.ts +3 -0
- package/dist/server/endpoints/api-vulse-form-upload.d.ts.map +1 -0
- package/dist/server/endpoints/api-vulse-form-upload.js +5 -0
- package/dist/server/endpoints/api-vulse-forms.d.ts +4 -0
- package/dist/server/endpoints/api-vulse-forms.d.ts.map +1 -0
- package/dist/server/endpoints/api-vulse-forms.js +9 -0
- package/dist/server/endpoints/api-vulse-globals-handle.d.ts +5 -0
- package/dist/server/endpoints/api-vulse-globals-handle.d.ts.map +1 -0
- package/dist/server/endpoints/api-vulse-globals-handle.js +19 -0
- package/dist/server/endpoints/api-vulse-globals-public-handle.d.ts +3 -0
- package/dist/server/endpoints/api-vulse-globals-public-handle.d.ts.map +1 -0
- package/dist/server/endpoints/api-vulse-globals-public-handle.js +5 -0
- package/dist/server/endpoints/api-vulse-globals-public.d.ts +3 -0
- package/dist/server/endpoints/api-vulse-globals-public.d.ts.map +1 -0
- package/dist/server/endpoints/api-vulse-globals-public.js +5 -0
- package/dist/server/endpoints/api-vulse-globals-value.d.ts +3 -0
- package/dist/server/endpoints/api-vulse-globals-value.d.ts.map +1 -0
- package/dist/server/endpoints/api-vulse-globals-value.js +7 -0
- package/dist/server/endpoints/api-vulse-globals.d.ts +4 -0
- package/dist/server/endpoints/api-vulse-globals.d.ts.map +1 -0
- package/dist/server/endpoints/api-vulse-globals.js +9 -0
- package/dist/server/endpoints/api-vulse-media-file.d.ts +3 -0
- package/dist/server/endpoints/api-vulse-media-file.d.ts.map +1 -0
- package/dist/server/endpoints/api-vulse-media-file.js +5 -0
- package/dist/server/endpoints/api-vulse-media-id.d.ts +4 -0
- package/dist/server/endpoints/api-vulse-media-id.d.ts.map +1 -0
- package/dist/server/endpoints/api-vulse-media-id.js +9 -0
- package/dist/server/endpoints/api-vulse-media.d.ts +4 -0
- package/dist/server/endpoints/api-vulse-media.d.ts.map +1 -0
- package/dist/server/endpoints/api-vulse-media.js +9 -0
- package/dist/server/endpoints/api-vulse-preview-bridge.d.ts +3 -0
- package/dist/server/endpoints/api-vulse-preview-bridge.d.ts.map +1 -0
- package/dist/server/endpoints/api-vulse-preview-bridge.js +9 -0
- package/dist/server/endpoints/api-vulse-preview-sessions-id.d.ts +3 -0
- package/dist/server/endpoints/api-vulse-preview-sessions-id.d.ts.map +1 -0
- package/dist/server/endpoints/api-vulse-preview-sessions-id.js +10 -0
- package/dist/server/endpoints/api-vulse-preview-sessions.d.ts +3 -0
- package/dist/server/endpoints/api-vulse-preview-sessions.d.ts.map +1 -0
- package/dist/server/endpoints/api-vulse-preview-sessions.js +5 -0
- package/dist/server/endpoints/api-vulse-preview-start.d.ts +3 -0
- package/dist/server/endpoints/api-vulse-preview-start.d.ts.map +1 -0
- package/dist/server/endpoints/api-vulse-preview-start.js +5 -0
- package/dist/server/endpoints/api-vulse-preview-stop.d.ts +3 -0
- package/dist/server/endpoints/api-vulse-preview-stop.d.ts.map +1 -0
- package/dist/server/endpoints/api-vulse-preview-stop.js +5 -0
- package/dist/server/endpoints/api-vulse-revisions-restore.d.ts +3 -0
- package/dist/server/endpoints/api-vulse-revisions-restore.d.ts.map +1 -0
- package/dist/server/endpoints/api-vulse-revisions-restore.js +5 -0
- package/dist/server/endpoints/api-vulse-revisions.d.ts +3 -0
- package/dist/server/endpoints/api-vulse-revisions.d.ts.map +1 -0
- package/dist/server/endpoints/api-vulse-revisions.js +5 -0
- package/dist/server/endpoints/api-vulse-search.d.ts +3 -0
- package/dist/server/endpoints/api-vulse-search.d.ts.map +1 -0
- package/dist/server/endpoints/api-vulse-search.js +5 -0
- package/dist/server/endpoints/api-vulse-sets.d.ts +6 -0
- package/dist/server/endpoints/api-vulse-sets.d.ts.map +1 -0
- package/dist/server/endpoints/api-vulse-sets.js +19 -0
- package/dist/server/endpoints/api-vulse-settings.d.ts +4 -0
- package/dist/server/endpoints/api-vulse-settings.d.ts.map +1 -0
- package/dist/server/endpoints/api-vulse-settings.js +9 -0
- package/dist/server/endpoints/api-vulse-users-id.d.ts +4 -0
- package/dist/server/endpoints/api-vulse-users-id.d.ts.map +1 -0
- package/dist/server/endpoints/api-vulse-users-id.js +9 -0
- package/dist/server/endpoints/api-vulse-users-reset-password.d.ts +3 -0
- package/dist/server/endpoints/api-vulse-users-reset-password.d.ts.map +1 -0
- package/dist/server/endpoints/api-vulse-users-reset-password.js +5 -0
- package/dist/server/endpoints/api-vulse-users-role.d.ts +4 -0
- package/dist/server/endpoints/api-vulse-users-role.d.ts.map +1 -0
- package/dist/server/endpoints/api-vulse-users-role.js +6 -0
- package/dist/server/endpoints/api-vulse-users.d.ts +3 -0
- package/dist/server/endpoints/api-vulse-users.d.ts.map +1 -0
- package/dist/server/endpoints/api-vulse-users.js +5 -0
- package/dist/server/endpoints/with-runtime.d.ts +2 -0
- package/dist/server/endpoints/with-runtime.d.ts.map +1 -0
- package/dist/server/endpoints/with-runtime.js +10 -0
- package/dist/server/env.d.ts +16 -0
- package/dist/server/env.d.ts.map +1 -0
- package/dist/server/env.js +9 -0
- package/dist/server/envelope.d.ts +15 -0
- package/dist/server/envelope.d.ts.map +1 -0
- package/dist/server/envelope.js +16 -0
- package/dist/server/forms/email.d.ts +8 -0
- package/dist/server/forms/email.d.ts.map +1 -0
- package/dist/server/forms/email.js +6 -0
- package/dist/server/forms/process-submission.d.ts +8 -0
- package/dist/server/forms/process-submission.d.ts.map +1 -0
- package/dist/server/forms/process-submission.js +75 -0
- package/dist/server/forms/queue.d.ts +8 -0
- package/dist/server/forms/queue.d.ts.map +1 -0
- package/dist/server/forms/queue.js +17 -0
- package/dist/server/forms/templates.d.ts +9 -0
- package/dist/server/forms/templates.d.ts.map +1 -0
- package/dist/server/forms/templates.js +14 -0
- package/dist/server/forms/webhook.d.ts +2 -0
- package/dist/server/forms/webhook.d.ts.map +1 -0
- package/dist/server/forms/webhook.js +17 -0
- package/dist/server/handler.d.ts +17 -0
- package/dist/server/handler.d.ts.map +1 -0
- package/dist/server/handler.js +45 -0
- package/dist/server/image-probe.d.ts +6 -0
- package/dist/server/image-probe.d.ts.map +1 -0
- package/dist/server/image-probe.js +38 -0
- package/dist/server/loader.d.ts +10 -0
- package/dist/server/loader.d.ts.map +1 -0
- package/dist/server/loader.js +42 -0
- package/dist/server/plugins.d.ts +17 -0
- package/dist/server/plugins.d.ts.map +1 -0
- package/dist/server/plugins.js +134 -0
- package/dist/server/preview.d.ts +7 -0
- package/dist/server/preview.d.ts.map +1 -0
- package/dist/server/preview.js +22 -0
- package/dist/server/r2.d.ts +8 -0
- package/dist/server/r2.d.ts.map +1 -0
- package/dist/server/r2.js +9 -0
- package/dist/server/routes/blueprints.d.ts +10 -0
- package/dist/server/routes/blueprints.d.ts.map +1 -0
- package/dist/server/routes/blueprints.js +46 -0
- package/dist/server/routes/entries.d.ts +16 -0
- package/dist/server/routes/entries.d.ts.map +1 -0
- package/dist/server/routes/entries.js +262 -0
- package/dist/server/routes/form-submit.d.ts +10 -0
- package/dist/server/routes/form-submit.d.ts.map +1 -0
- package/dist/server/routes/form-submit.js +155 -0
- package/dist/server/routes/form-upload.d.ts +11 -0
- package/dist/server/routes/form-upload.d.ts.map +1 -0
- package/dist/server/routes/form-upload.js +87 -0
- package/dist/server/routes/forms.d.ts +14 -0
- package/dist/server/routes/forms.d.ts.map +1 -0
- package/dist/server/routes/forms.js +78 -0
- package/dist/server/routes/globals-public.d.ts +6 -0
- package/dist/server/routes/globals-public.d.ts.map +1 -0
- package/dist/server/routes/globals-public.js +30 -0
- package/dist/server/routes/globals.d.ts +11 -0
- package/dist/server/routes/globals.d.ts.map +1 -0
- package/dist/server/routes/globals.js +84 -0
- package/dist/server/routes/media.d.ts +23 -0
- package/dist/server/routes/media.d.ts.map +1 -0
- package/dist/server/routes/media.js +129 -0
- package/dist/server/routes/preview-sessions.d.ts +9 -0
- package/dist/server/routes/preview-sessions.d.ts.map +1 -0
- package/dist/server/routes/preview-sessions.js +74 -0
- package/dist/server/routes/preview.d.ts +6 -0
- package/dist/server/routes/preview.d.ts.map +1 -0
- package/dist/server/routes/preview.js +37 -0
- package/dist/server/routes/revisions.d.ts +7 -0
- package/dist/server/routes/revisions.d.ts.map +1 -0
- package/dist/server/routes/revisions.js +26 -0
- package/dist/server/routes/search.d.ts +6 -0
- package/dist/server/routes/search.d.ts.map +1 -0
- package/dist/server/routes/search.js +28 -0
- package/dist/server/routes/sets.d.ts +10 -0
- package/dist/server/routes/sets.d.ts.map +1 -0
- package/dist/server/routes/sets.js +33 -0
- package/dist/server/routes/settings.d.ts +7 -0
- package/dist/server/routes/settings.d.ts.map +1 -0
- package/dist/server/routes/settings.js +21 -0
- package/dist/server/routes/users.d.ts +10 -0
- package/dist/server/routes/users.d.ts.map +1 -0
- package/dist/server/routes/users.js +113 -0
- package/dist/server/runtime.d.ts +49 -0
- package/dist/server/runtime.d.ts.map +1 -0
- package/dist/server/runtime.js +69 -0
- package/dist/server/sdk/collections.d.ts +25 -0
- package/dist/server/sdk/collections.d.ts.map +1 -0
- package/dist/server/sdk/collections.js +76 -0
- package/dist/server/sdk/index.d.ts +45 -0
- package/dist/server/sdk/index.d.ts.map +1 -0
- package/dist/server/sdk/index.js +13 -0
- package/dist/server/sdk/media.d.ts +7 -0
- package/dist/server/sdk/media.d.ts.map +1 -0
- package/dist/server/sdk/media.js +9 -0
- package/dist/server/sdk/search.d.ts +19 -0
- package/dist/server/sdk/search.d.ts.map +1 -0
- package/dist/server/sdk/search.js +58 -0
- package/dist/server.d.ts +8 -0
- package/dist/server.d.ts.map +1 -0
- package/dist/server.js +6 -0
- package/dist/version.d.ts +2 -0
- package/dist/version.d.ts.map +1 -0
- package/dist/version.js +2 -0
- package/migrations/0000_init.sql +114 -0
- package/migrations/0001_collections_sets.sql +21 -0
- package/migrations/0003_fts.sql +22 -0
- package/migrations/0004_forms.sql +58 -0
- package/migrations/0005_globals.sql +16 -0
- package/migrations/0006_preview_sessions.sql +16 -0
- package/migrations/meta/0000_snapshot.json +672 -0
- package/migrations/meta/_journal.json +13 -0
- package/package.json +130 -0
- package/src/client/BlockRenderer.astro +40 -0
- package/src/client/BlockRenderer.vue +42 -0
- package/src/client/Node.vue +21 -0
- package/src/client/ProseMirrorRenderer.vue +31 -0
- package/src/client/auth.ts +28 -0
- package/src/client/blocks/Blockquote.vue +12 -0
- package/src/client/blocks/BulletList.vue +12 -0
- package/src/client/blocks/CodeBlock.vue +12 -0
- package/src/client/blocks/Emoji.vue +14 -0
- package/src/client/blocks/HardBreak.vue +1 -0
- package/src/client/blocks/Heading.vue +17 -0
- package/src/client/blocks/ListItem.vue +12 -0
- package/src/client/blocks/OrderedList.vue +12 -0
- package/src/client/blocks/Paragraph.vue +12 -0
- package/src/client/blocks/Text.vue +33 -0
- package/src/client/blocks/VulseAccordion.vue +16 -0
- package/src/client/blocks/VulseAccordionGroup.vue +12 -0
- package/src/client/blocks/VulseCallout.vue +14 -0
- package/src/client/blocks/VulseIframe.vue +65 -0
- package/src/client/blocks/VulseImage.vue +30 -0
- package/src/client/blocks/VulseSet.vue +26 -0
- package/src/client/blocks/VulseVideo.vue +18 -0
- package/src/client/components/ForgotPasswordForm.astro +71 -0
- package/src/client/components/FormRenderer.astro +40 -0
- package/src/client/components/ResetPasswordForm.astro +72 -0
- package/src/client/components/SessionGuard.astro +27 -0
- package/src/client/components/SignInForm.astro +57 -0
- package/src/client/components/SignOutButton.astro +22 -0
- package/src/client/components/SignUpForm.astro +61 -0
- package/src/client/components/VulseImage.vue +25 -0
- package/src/client/embed.ts +52 -0
- package/src/client/index.ts +2 -0
- package/src/client/inject.ts +4 -0
- package/src/client/live-preview-bridge.ts +20 -0
- package/src/client/pm-defaults.ts +38 -0
- package/src/client/pm-types.ts +21 -0
- package/src/client/render-pm-html.ts +154 -0
- package/src/client/url.ts +35 -0
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import type { Auth } from '../better-auth.js';
|
|
2
|
+
import type { VulseDb } from '../../core/db.js';
|
|
3
|
+
import type { BlueprintRegistry } from '../../core/blueprints/registry.js';
|
|
4
|
+
export declare function previewSessionsRoutes(db: VulseDb, auth: Auth, registry: BlueprintRegistry): {
|
|
5
|
+
create: (request: Request, rawParams?: Record<string, string>) => Promise<Response>;
|
|
6
|
+
update: (request: Request, rawParams?: Record<string, string>) => Promise<Response>;
|
|
7
|
+
remove: (request: Request, rawParams?: Record<string, string>) => Promise<Response>;
|
|
8
|
+
};
|
|
9
|
+
//# sourceMappingURL=preview-sessions.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"preview-sessions.d.ts","sourceRoot":"","sources":["../../../src/server/routes/preview-sessions.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,IAAI,EAAE,MAAM,mBAAmB,CAAA;AAC7C,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,kBAAkB,CAAA;AAC/C,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,mCAAmC,CAAA;AAa1E,wBAAgB,qBAAqB,CAAC,EAAE,EAAE,OAAO,EAAE,IAAI,EAAE,IAAI,EAAE,QAAQ,EAAE,iBAAiB;;;;EA2DzF"}
|
|
@@ -0,0 +1,74 @@
|
|
|
1
|
+
import { z } from 'astro/zod';
|
|
2
|
+
import { defineHandler } from '../handler.js';
|
|
3
|
+
import { resolvePreviewPath } from '../../core/blueprints/preview-path.js';
|
|
4
|
+
import { PreviewSessionsRepo } from '../../core/repos/preview-sessions.js';
|
|
5
|
+
import { AccessDeniedError, NotFoundError } from '../../core/errors.js';
|
|
6
|
+
function buildPreviewUrl(origin, pathTemplate, slug, token) {
|
|
7
|
+
const path = pathTemplate.replace('{slug}', encodeURIComponent(slug));
|
|
8
|
+
const url = new URL(path, origin);
|
|
9
|
+
url.searchParams.set('vulse_live_preview', token);
|
|
10
|
+
return url.toString();
|
|
11
|
+
}
|
|
12
|
+
export function previewSessionsRoutes(db, auth, registry) {
|
|
13
|
+
const repo = new PreviewSessionsRepo(db);
|
|
14
|
+
return {
|
|
15
|
+
create: defineHandler(auth, {
|
|
16
|
+
requireRole: ['admin', 'editor'],
|
|
17
|
+
body: z.object({
|
|
18
|
+
collection: z.string(),
|
|
19
|
+
entryId: z.string().nullable().optional(),
|
|
20
|
+
slug: z.string(),
|
|
21
|
+
content: z.record(z.string(), z.unknown()),
|
|
22
|
+
locale: z.string().optional(),
|
|
23
|
+
}),
|
|
24
|
+
}, async ({ auth: ctx, body, url }) => {
|
|
25
|
+
const bp = registry.get(body.collection);
|
|
26
|
+
if (!bp)
|
|
27
|
+
throw new NotFoundError(`Collection ${body.collection} not found`);
|
|
28
|
+
const row = await repo.create({
|
|
29
|
+
userId: ctx.user.id,
|
|
30
|
+
collection: body.collection,
|
|
31
|
+
slug: body.slug,
|
|
32
|
+
content: body.content,
|
|
33
|
+
entryId: body.entryId ?? null,
|
|
34
|
+
...(body.locale !== undefined ? { locale: body.locale } : {}),
|
|
35
|
+
});
|
|
36
|
+
const previewPath = resolvePreviewPath(bp);
|
|
37
|
+
return {
|
|
38
|
+
id: row.id,
|
|
39
|
+
previewUrl: buildPreviewUrl(url.origin, previewPath, row.slug, row.id),
|
|
40
|
+
expiresAt: row.expiresAt.toISOString(),
|
|
41
|
+
};
|
|
42
|
+
}),
|
|
43
|
+
update: defineHandler(auth, {
|
|
44
|
+
requireRole: ['admin', 'editor'],
|
|
45
|
+
params: z.object({ id: z.string() }),
|
|
46
|
+
body: z.object({
|
|
47
|
+
slug: z.string().optional(),
|
|
48
|
+
content: z.record(z.string(), z.unknown()).optional(),
|
|
49
|
+
locale: z.string().optional(),
|
|
50
|
+
}),
|
|
51
|
+
}, async ({ auth: ctx, params, body }) => {
|
|
52
|
+
const patch = {};
|
|
53
|
+
if (body.slug !== undefined)
|
|
54
|
+
patch.slug = body.slug;
|
|
55
|
+
if (body.content !== undefined)
|
|
56
|
+
patch.content = body.content;
|
|
57
|
+
if (body.locale !== undefined)
|
|
58
|
+
patch.locale = body.locale;
|
|
59
|
+
const updated = await repo.update(params.id, ctx.user.id, patch);
|
|
60
|
+
if (!updated)
|
|
61
|
+
throw new AccessDeniedError('Session not found or not owned by you');
|
|
62
|
+
return { expiresAt: updated.expiresAt.toISOString() };
|
|
63
|
+
}),
|
|
64
|
+
remove: defineHandler(auth, {
|
|
65
|
+
requireRole: ['admin', 'editor'],
|
|
66
|
+
params: z.object({ id: z.string() }),
|
|
67
|
+
}, async ({ auth: ctx, params }) => {
|
|
68
|
+
const ok = await repo.delete(params.id, ctx.user.id);
|
|
69
|
+
if (!ok)
|
|
70
|
+
throw new NotFoundError('Session not found');
|
|
71
|
+
return { ok: true };
|
|
72
|
+
}),
|
|
73
|
+
};
|
|
74
|
+
}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
import type { Auth } from '../better-auth.js';
|
|
2
|
+
export declare function previewRoutes(auth: Auth, secret: string): {
|
|
3
|
+
start: (request: Request, rawParams?: Record<string, string>) => Promise<Response>;
|
|
4
|
+
stop: (request: Request, rawParams?: Record<string, string>) => Promise<Response>;
|
|
5
|
+
};
|
|
6
|
+
//# sourceMappingURL=preview.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"preview.d.ts","sourceRoot":"","sources":["../../../src/server/routes/preview.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,IAAI,EAAE,MAAM,mBAAmB,CAAA;AAmB7C,wBAAgB,aAAa,CAAC,IAAI,EAAE,IAAI,EAAE,MAAM,EAAE,MAAM;;;EAgBvD"}
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
import { defineHandler } from '../handler.js';
|
|
2
|
+
import { mintPreviewToken } from '../preview.js';
|
|
3
|
+
function safePreviewTarget(raw, origin) {
|
|
4
|
+
const fallback = new URL('/', origin);
|
|
5
|
+
if (!raw)
|
|
6
|
+
return fallback;
|
|
7
|
+
// Reject anything that could escape origin: protocol-relative URLs (//evil.com)
|
|
8
|
+
// and any input that isn't a single leading "/" path.
|
|
9
|
+
if (!raw.startsWith('/') || raw.startsWith('//'))
|
|
10
|
+
return fallback;
|
|
11
|
+
try {
|
|
12
|
+
const candidate = new URL(raw, origin);
|
|
13
|
+
if (candidate.origin !== new URL(origin).origin)
|
|
14
|
+
return fallback;
|
|
15
|
+
return candidate;
|
|
16
|
+
}
|
|
17
|
+
catch {
|
|
18
|
+
return fallback;
|
|
19
|
+
}
|
|
20
|
+
}
|
|
21
|
+
export function previewRoutes(auth, secret) {
|
|
22
|
+
return {
|
|
23
|
+
start: defineHandler(auth, { requireRole: ['admin', 'editor'] }, async ({ auth: authCtx, url }) => {
|
|
24
|
+
const token = await mintPreviewToken(secret, authCtx.user.id);
|
|
25
|
+
const secure = url.protocol === 'https:';
|
|
26
|
+
const cookie = `vulse_preview=${token}; Path=/; HttpOnly; SameSite=Lax; Max-Age=3600${secure ? '; Secure' : ''}`;
|
|
27
|
+
const redirect = safePreviewTarget(url.searchParams.get('to'), url.origin);
|
|
28
|
+
return new Response(null, { status: 302, headers: { Location: redirect.toString(), 'Set-Cookie': cookie } });
|
|
29
|
+
}),
|
|
30
|
+
stop: defineHandler(auth, {}, async ({ url }) => {
|
|
31
|
+
return new Response(null, {
|
|
32
|
+
status: 302,
|
|
33
|
+
headers: { Location: new URL('/', url.origin).toString(), 'Set-Cookie': 'vulse_preview=; Path=/; Max-Age=0' },
|
|
34
|
+
});
|
|
35
|
+
}),
|
|
36
|
+
};
|
|
37
|
+
}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import type { VulseDb } from '../../core/db.js';
|
|
2
|
+
import type { Auth } from '../better-auth.js';
|
|
3
|
+
export declare function revisionsRoutes(db: VulseDb, auth: Auth): {
|
|
4
|
+
list: (request: Request, rawParams?: Record<string, string>) => Promise<Response>;
|
|
5
|
+
restore: (request: Request, rawParams?: Record<string, string>) => Promise<Response>;
|
|
6
|
+
};
|
|
7
|
+
//# sourceMappingURL=revisions.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"revisions.d.ts","sourceRoot":"","sources":["../../../src/server/routes/revisions.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,kBAAkB,CAAA;AAC/C,OAAO,KAAK,EAAE,IAAI,EAAE,MAAM,mBAAmB,CAAA;AAK7C,wBAAgB,eAAe,CAAC,EAAE,EAAE,OAAO,EAAE,IAAI,EAAE,IAAI;;;EAqBtD"}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
import { z } from 'astro/zod';
|
|
2
|
+
import { RevisionsRepo } from '../../core/repos/revisions.js';
|
|
3
|
+
import { resolveLocale } from '../../core/locales.js';
|
|
4
|
+
import { defineHandler } from '../handler.js';
|
|
5
|
+
export function revisionsRoutes(db, auth) {
|
|
6
|
+
const repo = new RevisionsRepo(db);
|
|
7
|
+
return {
|
|
8
|
+
list: defineHandler(auth, {
|
|
9
|
+
params: z.object({ collection: z.string(), id: z.string() }),
|
|
10
|
+
requireRole: ['admin', 'editor'],
|
|
11
|
+
}, async ({ params, url }) => {
|
|
12
|
+
const locale = await resolveLocale(db, url.searchParams.get('locale'));
|
|
13
|
+
return await repo.listByEntry(params.id, locale);
|
|
14
|
+
}),
|
|
15
|
+
restore: defineHandler(auth, {
|
|
16
|
+
params: z.object({ collection: z.string(), id: z.string(), version: z.string() }),
|
|
17
|
+
requireRole: ['admin', 'editor'],
|
|
18
|
+
}, async ({ params, url, auth: authCtx }) => {
|
|
19
|
+
if (!authCtx.user)
|
|
20
|
+
throw new Error('unreachable');
|
|
21
|
+
const locale = await resolveLocale(db, url.searchParams.get('locale'));
|
|
22
|
+
await repo.restore(params.id, Number(params.version), { userId: authCtx.user.id, locale });
|
|
23
|
+
return { restored: Number(params.version) };
|
|
24
|
+
}),
|
|
25
|
+
};
|
|
26
|
+
}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
import type { VulseDb } from '../../core/db.js';
|
|
2
|
+
import type { Auth } from '../better-auth.js';
|
|
3
|
+
export declare function searchRoutes(db: VulseDb, auth: Auth): {
|
|
4
|
+
query: (request: Request, rawParams?: Record<string, string>) => Promise<Response>;
|
|
5
|
+
};
|
|
6
|
+
//# sourceMappingURL=search.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"search.d.ts","sourceRoot":"","sources":["../../../src/server/routes/search.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,kBAAkB,CAAA;AAC/C,OAAO,KAAK,EAAE,IAAI,EAAE,MAAM,mBAAmB,CAAA;AAI7C,wBAAgB,YAAY,CAAC,EAAE,EAAE,OAAO,EAAE,IAAI,EAAE,IAAI;;EAwBnD"}
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
import { z } from 'astro/zod';
|
|
2
|
+
import { defineHandler } from '../handler.js';
|
|
3
|
+
import { searchSdk } from '../sdk/search.js';
|
|
4
|
+
export function searchRoutes(db, auth) {
|
|
5
|
+
const sdk = searchSdk(db);
|
|
6
|
+
return {
|
|
7
|
+
query: defineHandler(auth, {
|
|
8
|
+
params: z.object({}),
|
|
9
|
+
body: z.object({
|
|
10
|
+
q: z.string(),
|
|
11
|
+
collections: z.array(z.string()).optional(),
|
|
12
|
+
limit: z.number().optional(),
|
|
13
|
+
includeDrafts: z.boolean().optional(),
|
|
14
|
+
locale: z.string().optional(),
|
|
15
|
+
}),
|
|
16
|
+
}, async ({ body, auth: authCtx }) => {
|
|
17
|
+
const role = authCtx.user?.role;
|
|
18
|
+
const mayReadDrafts = role === 'admin' || role === 'editor';
|
|
19
|
+
const includeDrafts = body.includeDrafts === true && mayReadDrafts;
|
|
20
|
+
return sdk.query(body.q, {
|
|
21
|
+
...(body.collections !== undefined ? { collections: body.collections } : {}),
|
|
22
|
+
...(body.limit !== undefined ? { limit: body.limit } : {}),
|
|
23
|
+
...(body.locale !== undefined ? { locale: body.locale } : {}),
|
|
24
|
+
includeDrafts,
|
|
25
|
+
});
|
|
26
|
+
}),
|
|
27
|
+
};
|
|
28
|
+
}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import type { Auth } from '../better-auth.js';
|
|
2
|
+
import type { VulseDb } from '../../core/db.js';
|
|
3
|
+
export declare function setsRoutes(db: VulseDb, auth: Auth): {
|
|
4
|
+
list: (request: Request, rawParams?: Record<string, string>) => Promise<Response>;
|
|
5
|
+
get: (request: Request, rawParams?: Record<string, string>) => Promise<Response>;
|
|
6
|
+
create: (request: Request, rawParams?: Record<string, string>) => Promise<Response>;
|
|
7
|
+
update: (request: Request, rawParams?: Record<string, string>) => Promise<Response>;
|
|
8
|
+
delete: (request: Request, rawParams?: Record<string, string>) => Promise<Response>;
|
|
9
|
+
};
|
|
10
|
+
//# sourceMappingURL=sets.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"sets.d.ts","sourceRoot":"","sources":["../../../src/server/routes/sets.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,IAAI,EAAE,MAAM,mBAAmB,CAAA;AAC7C,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,kBAAkB,CAAA;AAQ/C,wBAAgB,UAAU,CAAC,EAAE,EAAE,OAAO,EAAE,IAAI,EAAE,IAAI;;;;;;EA6BjD"}
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
import { z } from 'astro/zod';
|
|
2
|
+
import { SetDefinitionSchema } from '../../core/sets/definition.js';
|
|
3
|
+
import { createSet, deleteSet, getSet, listSets, updateSet } from '../../core/sets/service.js';
|
|
4
|
+
import { NotFoundError } from '../../core/errors.js';
|
|
5
|
+
import { defineHandler } from '../handler.js';
|
|
6
|
+
const paramsHandle = z.object({ handle: z.string() });
|
|
7
|
+
export function setsRoutes(db, auth) {
|
|
8
|
+
return {
|
|
9
|
+
list: defineHandler(auth, {}, async () => listSets(db)),
|
|
10
|
+
get: defineHandler(auth, { params: paramsHandle }, async ({ params }) => {
|
|
11
|
+
const row = await getSet(db, params.handle);
|
|
12
|
+
if (!row)
|
|
13
|
+
throw new NotFoundError('set not found');
|
|
14
|
+
return row;
|
|
15
|
+
}),
|
|
16
|
+
create: defineHandler(auth, {
|
|
17
|
+
body: SetDefinitionSchema,
|
|
18
|
+
requireRole: ['admin'],
|
|
19
|
+
}, async ({ body }) => createSet(db, body)),
|
|
20
|
+
update: defineHandler(auth, {
|
|
21
|
+
params: paramsHandle,
|
|
22
|
+
body: SetDefinitionSchema,
|
|
23
|
+
requireRole: ['admin'],
|
|
24
|
+
}, async ({ params, body }) => updateSet(db, params.handle, body)),
|
|
25
|
+
delete: defineHandler(auth, {
|
|
26
|
+
params: paramsHandle,
|
|
27
|
+
requireRole: ['admin'],
|
|
28
|
+
}, async ({ params }) => {
|
|
29
|
+
await deleteSet(db, params.handle);
|
|
30
|
+
return null;
|
|
31
|
+
}),
|
|
32
|
+
};
|
|
33
|
+
}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import type { VulseDb } from '../../core/db.js';
|
|
2
|
+
import type { Auth } from '../better-auth.js';
|
|
3
|
+
export declare function settingsRoutes(db: VulseDb, auth: Auth): {
|
|
4
|
+
list: (request: Request, rawParams?: Record<string, string>) => Promise<Response>;
|
|
5
|
+
set: (request: Request, rawParams?: Record<string, string>) => Promise<Response>;
|
|
6
|
+
};
|
|
7
|
+
//# sourceMappingURL=settings.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"settings.d.ts","sourceRoot":"","sources":["../../../src/server/routes/settings.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,kBAAkB,CAAA;AAC/C,OAAO,KAAK,EAAE,IAAI,EAAE,MAAM,mBAAmB,CAAA;AAO7C,wBAAgB,cAAc,CAAC,EAAE,EAAE,OAAO,EAAE,IAAI,EAAE,IAAI;;;EAcrD"}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import { z } from 'astro/zod';
|
|
2
|
+
import { defineHandler } from '../handler.js';
|
|
3
|
+
import { SettingsRepo } from '../../core/repos/settings.js';
|
|
4
|
+
import { invalidateRuntime } from '../runtime.js';
|
|
5
|
+
const AUTH_SETTING_KEYS = new Set(['allowMemberSignUp', 'allowedSignUpDomains']);
|
|
6
|
+
export function settingsRoutes(db, auth) {
|
|
7
|
+
const repo = new SettingsRepo(db);
|
|
8
|
+
return {
|
|
9
|
+
list: defineHandler(auth, { requireRole: ['admin'] }, async () => await repo.all()),
|
|
10
|
+
set: defineHandler(auth, {
|
|
11
|
+
params: z.object({ key: z.string() }),
|
|
12
|
+
body: z.object({ value: z.unknown() }),
|
|
13
|
+
requireRole: ['admin'],
|
|
14
|
+
}, async ({ params, body }) => {
|
|
15
|
+
await repo.set(params.key, body.value);
|
|
16
|
+
if (AUTH_SETTING_KEYS.has(params.key))
|
|
17
|
+
invalidateRuntime();
|
|
18
|
+
return { key: params.key };
|
|
19
|
+
}),
|
|
20
|
+
};
|
|
21
|
+
}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import type { VulseDb } from '../../core/db.js';
|
|
2
|
+
import type { Auth } from '../better-auth.js';
|
|
3
|
+
export declare function usersRoutes(db: VulseDb, auth: Auth): {
|
|
4
|
+
list: (request: Request, rawParams?: Record<string, string>) => Promise<Response>;
|
|
5
|
+
get: (request: Request, rawParams?: Record<string, string>) => Promise<Response>;
|
|
6
|
+
update: (request: Request, rawParams?: Record<string, string>) => Promise<Response>;
|
|
7
|
+
setRole: (request: Request, rawParams?: Record<string, string>) => Promise<Response>;
|
|
8
|
+
resetPassword: (request: Request, rawParams?: Record<string, string>) => Promise<Response>;
|
|
9
|
+
};
|
|
10
|
+
//# sourceMappingURL=users.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"users.d.ts","sourceRoot":"","sources":["../../../src/server/routes/users.ts"],"names":[],"mappings":"AAIA,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,kBAAkB,CAAA;AAC/C,OAAO,KAAK,EAAE,IAAI,EAAE,MAAM,mBAAmB,CAAA;AAgB7C,wBAAgB,WAAW,CAAC,EAAE,EAAE,OAAO,EAAE,IAAI,EAAE,IAAI;;;;;;EAyGlD"}
|
|
@@ -0,0 +1,113 @@
|
|
|
1
|
+
import { z } from 'astro/zod';
|
|
2
|
+
import { and, eq, like, or } from 'drizzle-orm';
|
|
3
|
+
import { hashPassword } from 'better-auth/crypto';
|
|
4
|
+
import { nanoid } from 'nanoid';
|
|
5
|
+
import { account as accountTable, user as userTable } from '../../core/schema.js';
|
|
6
|
+
import { defineHandler } from '../handler.js';
|
|
7
|
+
import { NotFoundError } from '../../core/errors.js';
|
|
8
|
+
const userFields = {
|
|
9
|
+
id: userTable.id,
|
|
10
|
+
email: userTable.email,
|
|
11
|
+
name: userTable.name,
|
|
12
|
+
role: userTable.role,
|
|
13
|
+
displayName: userTable.displayName,
|
|
14
|
+
emailVerified: userTable.emailVerified,
|
|
15
|
+
createdAt: userTable.createdAt,
|
|
16
|
+
updatedAt: userTable.updatedAt,
|
|
17
|
+
};
|
|
18
|
+
export function usersRoutes(db, auth) {
|
|
19
|
+
return {
|
|
20
|
+
list: defineHandler(auth, { requireRole: ['admin'] }, async ({ url }) => {
|
|
21
|
+
const q = url.searchParams.get('q')?.trim();
|
|
22
|
+
if (q) {
|
|
23
|
+
const pattern = `%${q}%`;
|
|
24
|
+
return await db.select(userFields).from(userTable).where(or(like(userTable.email, pattern), like(userTable.name, pattern), like(userTable.displayName, pattern), eq(userTable.id, q)));
|
|
25
|
+
}
|
|
26
|
+
return await db.select(userFields).from(userTable);
|
|
27
|
+
}),
|
|
28
|
+
get: defineHandler(auth, {
|
|
29
|
+
params: z.object({ id: z.string() }),
|
|
30
|
+
requireRole: ['admin'],
|
|
31
|
+
}, async ({ params }) => {
|
|
32
|
+
const rows = await db.select(userFields).from(userTable).where(eq(userTable.id, params.id));
|
|
33
|
+
if (!rows.length)
|
|
34
|
+
throw new NotFoundError(`User ${params.id} not found`);
|
|
35
|
+
return rows[0];
|
|
36
|
+
}),
|
|
37
|
+
update: defineHandler(auth, {
|
|
38
|
+
params: z.object({ id: z.string() }),
|
|
39
|
+
body: z.object({
|
|
40
|
+
name: z.string().min(1).optional(),
|
|
41
|
+
displayName: z.string().nullable().optional(),
|
|
42
|
+
role: z.enum(['admin', 'editor', 'member']).optional(),
|
|
43
|
+
}),
|
|
44
|
+
requireRole: ['admin'],
|
|
45
|
+
}, async ({ params, body }) => {
|
|
46
|
+
const existing = await db.select({ id: userTable.id }).from(userTable).where(eq(userTable.id, params.id));
|
|
47
|
+
if (!existing.length)
|
|
48
|
+
throw new NotFoundError(`User ${params.id} not found`);
|
|
49
|
+
const patch = { updatedAt: new Date() };
|
|
50
|
+
if (body.name !== undefined)
|
|
51
|
+
patch.name = body.name;
|
|
52
|
+
if (body.displayName !== undefined)
|
|
53
|
+
patch.displayName = body.displayName;
|
|
54
|
+
if (body.role !== undefined)
|
|
55
|
+
patch.role = body.role;
|
|
56
|
+
await db.update(userTable).set(patch).where(eq(userTable.id, params.id));
|
|
57
|
+
const rows = await db.select(userFields).from(userTable).where(eq(userTable.id, params.id));
|
|
58
|
+
return rows[0];
|
|
59
|
+
}),
|
|
60
|
+
setRole: defineHandler(auth, {
|
|
61
|
+
params: z.object({ id: z.string() }),
|
|
62
|
+
body: z.object({ role: z.enum(['admin', 'editor', 'member']) }),
|
|
63
|
+
requireRole: ['admin'],
|
|
64
|
+
}, async ({ params, body }) => {
|
|
65
|
+
const existing = await db.select({ id: userTable.id }).from(userTable).where(eq(userTable.id, params.id));
|
|
66
|
+
if (!existing.length)
|
|
67
|
+
throw new NotFoundError(`User ${params.id} not found`);
|
|
68
|
+
await db.update(userTable).set({ role: body.role, updatedAt: new Date() }).where(eq(userTable.id, params.id));
|
|
69
|
+
return { id: params.id, role: body.role };
|
|
70
|
+
}),
|
|
71
|
+
resetPassword: defineHandler(auth, {
|
|
72
|
+
params: z.object({ id: z.string() }),
|
|
73
|
+
body: z.discriminatedUnion('action', [
|
|
74
|
+
z.object({ action: z.literal('email'), redirectTo: z.string().optional() }),
|
|
75
|
+
z.object({ action: z.literal('set'), password: z.string().min(8) }),
|
|
76
|
+
]),
|
|
77
|
+
requireRole: ['admin'],
|
|
78
|
+
}, async ({ params, body, request }) => {
|
|
79
|
+
const rows = await db.select({ id: userTable.id, email: userTable.email }).from(userTable).where(eq(userTable.id, params.id));
|
|
80
|
+
if (!rows.length)
|
|
81
|
+
throw new NotFoundError(`User ${params.id} not found`);
|
|
82
|
+
const target = rows[0];
|
|
83
|
+
if (body.action === 'email') {
|
|
84
|
+
await auth.api.requestPasswordReset({
|
|
85
|
+
body: {
|
|
86
|
+
email: target.email,
|
|
87
|
+
redirectTo: body.redirectTo ?? '/reset-password',
|
|
88
|
+
},
|
|
89
|
+
headers: request.headers,
|
|
90
|
+
});
|
|
91
|
+
return { action: 'email', sent: true };
|
|
92
|
+
}
|
|
93
|
+
const hashedPassword = await hashPassword(body.password);
|
|
94
|
+
const accounts = await db.select({ id: accountTable.id }).from(accountTable).where(and(eq(accountTable.userId, params.id), eq(accountTable.providerId, 'credential')));
|
|
95
|
+
const now = new Date();
|
|
96
|
+
if (accounts.length) {
|
|
97
|
+
await db.update(accountTable).set({ password: hashedPassword, updatedAt: now }).where(eq(accountTable.id, accounts[0].id));
|
|
98
|
+
}
|
|
99
|
+
else {
|
|
100
|
+
await db.insert(accountTable).values({
|
|
101
|
+
id: nanoid(),
|
|
102
|
+
userId: params.id,
|
|
103
|
+
accountId: params.id,
|
|
104
|
+
providerId: 'credential',
|
|
105
|
+
password: hashedPassword,
|
|
106
|
+
createdAt: now,
|
|
107
|
+
updatedAt: now,
|
|
108
|
+
});
|
|
109
|
+
}
|
|
110
|
+
return { action: 'set', updated: true };
|
|
111
|
+
}),
|
|
112
|
+
};
|
|
113
|
+
}
|
|
@@ -0,0 +1,49 @@
|
|
|
1
|
+
import { createDb } from '../core/db.js';
|
|
2
|
+
import { BlueprintRegistry } from '../core/blueprints/registry.js';
|
|
3
|
+
import { entriesRoutes } from './routes/entries.js';
|
|
4
|
+
import { revisionsRoutes } from './routes/revisions.js';
|
|
5
|
+
import { usersRoutes } from './routes/users.js';
|
|
6
|
+
import { settingsRoutes } from './routes/settings.js';
|
|
7
|
+
import { blueprintsRoutes } from './routes/blueprints.js';
|
|
8
|
+
import { setsRoutes } from './routes/sets.js';
|
|
9
|
+
import { mediaRoutes } from './routes/media.js';
|
|
10
|
+
import { searchRoutes } from './routes/search.js';
|
|
11
|
+
import { previewRoutes } from './routes/preview.js';
|
|
12
|
+
import { previewSessionsRoutes } from './routes/preview-sessions.js';
|
|
13
|
+
import { formsRoutes } from './routes/forms.js';
|
|
14
|
+
import { formSubmitRoutes } from './routes/form-submit.js';
|
|
15
|
+
import { formUploadRoutes } from './routes/form-upload.js';
|
|
16
|
+
import { globalsRoutes } from './routes/globals.js';
|
|
17
|
+
import { globalsPublicRoutes } from './routes/globals-public.js';
|
|
18
|
+
import { createSdk } from './sdk/index.js';
|
|
19
|
+
import type { Auth } from './better-auth.js';
|
|
20
|
+
import type { RuntimeEnv } from './env.js';
|
|
21
|
+
export interface VulseRuntime {
|
|
22
|
+
db: ReturnType<typeof createDb>;
|
|
23
|
+
auth: Auth;
|
|
24
|
+
registry: BlueprintRegistry;
|
|
25
|
+
sdk: ReturnType<typeof createSdk>;
|
|
26
|
+
routes: {
|
|
27
|
+
entries: ReturnType<typeof entriesRoutes>;
|
|
28
|
+
revisions: ReturnType<typeof revisionsRoutes>;
|
|
29
|
+
users: ReturnType<typeof usersRoutes>;
|
|
30
|
+
settings: ReturnType<typeof settingsRoutes>;
|
|
31
|
+
blueprints: ReturnType<typeof blueprintsRoutes>;
|
|
32
|
+
sets: ReturnType<typeof setsRoutes>;
|
|
33
|
+
media: ReturnType<typeof mediaRoutes>;
|
|
34
|
+
search: ReturnType<typeof searchRoutes>;
|
|
35
|
+
preview: ReturnType<typeof previewRoutes>;
|
|
36
|
+
previewSessions: ReturnType<typeof previewSessionsRoutes>;
|
|
37
|
+
forms: ReturnType<typeof formsRoutes>;
|
|
38
|
+
formSubmit: ReturnType<typeof formSubmitRoutes>;
|
|
39
|
+
formUpload: ReturnType<typeof formUploadRoutes>;
|
|
40
|
+
globals: ReturnType<typeof globalsRoutes>;
|
|
41
|
+
globalsPublic: ReturnType<typeof globalsPublicRoutes>;
|
|
42
|
+
};
|
|
43
|
+
}
|
|
44
|
+
export declare function getRuntime(env: RuntimeEnv, registry: BlueprintRegistry, baseURL: string): Promise<VulseRuntime>;
|
|
45
|
+
export declare function invalidateRuntime(): void;
|
|
46
|
+
/** @deprecated use invalidateRuntime */
|
|
47
|
+
export declare function _resetRuntime(): void;
|
|
48
|
+
export type { RuntimeEnv } from './env.js';
|
|
49
|
+
//# sourceMappingURL=runtime.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"runtime.d.ts","sourceRoot":"","sources":["../../src/server/runtime.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,eAAe,CAAA;AAExC,OAAO,EAAE,iBAAiB,EAAE,MAAM,gCAAgC,CAAA;AAClE,OAAO,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAA;AACnD,OAAO,EAAE,eAAe,EAAE,MAAM,uBAAuB,CAAA;AACvD,OAAO,EAAE,WAAW,EAAE,MAAM,mBAAmB,CAAA;AAC/C,OAAO,EAAE,cAAc,EAAE,MAAM,sBAAsB,CAAA;AACrD,OAAO,EAAE,gBAAgB,EAAE,MAAM,wBAAwB,CAAA;AACzD,OAAO,EAAE,UAAU,EAAE,MAAM,kBAAkB,CAAA;AAC7C,OAAO,EAAE,WAAW,EAAE,MAAM,mBAAmB,CAAA;AAC/C,OAAO,EAAE,YAAY,EAAE,MAAM,oBAAoB,CAAA;AACjD,OAAO,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAA;AACnD,OAAO,EAAE,qBAAqB,EAAE,MAAM,8BAA8B,CAAA;AACpE,OAAO,EAAE,WAAW,EAAE,MAAM,mBAAmB,CAAA;AAC/C,OAAO,EAAE,gBAAgB,EAAE,MAAM,yBAAyB,CAAA;AAC1D,OAAO,EAAE,gBAAgB,EAAE,MAAM,yBAAyB,CAAA;AAC1D,OAAO,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAA;AACnD,OAAO,EAAE,mBAAmB,EAAE,MAAM,4BAA4B,CAAA;AAChE,OAAO,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAA;AAE1C,OAAO,KAAK,EAAE,IAAI,EAAE,MAAM,kBAAkB,CAAA;AAC5C,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,UAAU,CAAA;AAE1C,MAAM,WAAW,YAAY;IAC3B,EAAE,EAAE,UAAU,CAAC,OAAO,QAAQ,CAAC,CAAA;IAC/B,IAAI,EAAE,IAAI,CAAA;IACV,QAAQ,EAAE,iBAAiB,CAAA;IAC3B,GAAG,EAAE,UAAU,CAAC,OAAO,SAAS,CAAC,CAAA;IACjC,MAAM,EAAE;QACN,OAAO,EAAE,UAAU,CAAC,OAAO,aAAa,CAAC,CAAA;QACzC,SAAS,EAAE,UAAU,CAAC,OAAO,eAAe,CAAC,CAAA;QAC7C,KAAK,EAAE,UAAU,CAAC,OAAO,WAAW,CAAC,CAAA;QACrC,QAAQ,EAAE,UAAU,CAAC,OAAO,cAAc,CAAC,CAAA;QAC3C,UAAU,EAAE,UAAU,CAAC,OAAO,gBAAgB,CAAC,CAAA;QAC/C,IAAI,EAAE,UAAU,CAAC,OAAO,UAAU,CAAC,CAAA;QACnC,KAAK,EAAE,UAAU,CAAC,OAAO,WAAW,CAAC,CAAA;QACrC,MAAM,EAAE,UAAU,CAAC,OAAO,YAAY,CAAC,CAAA;QACvC,OAAO,EAAE,UAAU,CAAC,OAAO,aAAa,CAAC,CAAA;QACzC,eAAe,EAAE,UAAU,CAAC,OAAO,qBAAqB,CAAC,CAAA;QACzD,KAAK,EAAE,UAAU,CAAC,OAAO,WAAW,CAAC,CAAA;QACrC,UAAU,EAAE,UAAU,CAAC,OAAO,gBAAgB,CAAC,CAAA;QAC/C,UAAU,EAAE,UAAU,CAAC,OAAO,gBAAgB,CAAC,CAAA;QAC/C,OAAO,EAAE,UAAU,CAAC,OAAO,aAAa,CAAC,CAAA;QACzC,aAAa,EAAE,UAAU,CAAC,OAAO,mBAAmB,CAAC,CAAA;KACtD,CAAA;CACF;AAID,wBAAsB,UAAU,CAAC,GAAG,EAAE,UAAU,EAAE,QAAQ,EAAE,iBAAiB,EAAE,OAAO,EAAE,MAAM,GAAG,OAAO,CAAC,YAAY,CAAC,CA0CrH;AAED,wBAAgB,iBAAiB,IAAI,IAAI,CAAkB;AAE3D,wCAAwC;AACxC,wBAAgB,aAAa,IAAI,IAAI,CAAwB;AAE7D,YAAY,EAAE,UAAU,EAAE,MAAM,UAAU,CAAA"}
|
|
@@ -0,0 +1,69 @@
|
|
|
1
|
+
import { createDb } from '../core/db.js';
|
|
2
|
+
import { createAuth } from './better-auth.js';
|
|
3
|
+
import { BlueprintRegistry } from '../core/blueprints/registry.js';
|
|
4
|
+
import { entriesRoutes } from './routes/entries.js';
|
|
5
|
+
import { revisionsRoutes } from './routes/revisions.js';
|
|
6
|
+
import { usersRoutes } from './routes/users.js';
|
|
7
|
+
import { settingsRoutes } from './routes/settings.js';
|
|
8
|
+
import { blueprintsRoutes } from './routes/blueprints.js';
|
|
9
|
+
import { setsRoutes } from './routes/sets.js';
|
|
10
|
+
import { mediaRoutes } from './routes/media.js';
|
|
11
|
+
import { searchRoutes } from './routes/search.js';
|
|
12
|
+
import { previewRoutes } from './routes/preview.js';
|
|
13
|
+
import { previewSessionsRoutes } from './routes/preview-sessions.js';
|
|
14
|
+
import { formsRoutes } from './routes/forms.js';
|
|
15
|
+
import { formSubmitRoutes } from './routes/form-submit.js';
|
|
16
|
+
import { formUploadRoutes } from './routes/form-upload.js';
|
|
17
|
+
import { globalsRoutes } from './routes/globals.js';
|
|
18
|
+
import { globalsPublicRoutes } from './routes/globals-public.js';
|
|
19
|
+
import { createSdk } from './sdk/index.js';
|
|
20
|
+
import { previewSecret } from './preview.js';
|
|
21
|
+
let cached = null;
|
|
22
|
+
export async function getRuntime(env, registry, baseURL) {
|
|
23
|
+
if (cached)
|
|
24
|
+
return cached;
|
|
25
|
+
const db = createDb(env.DB);
|
|
26
|
+
const auth = await createAuth(db, {
|
|
27
|
+
baseURL: env.BETTER_AUTH_URL ?? baseURL,
|
|
28
|
+
secret: env.BETTER_AUTH_SECRET,
|
|
29
|
+
...(env.VULSE_ALLOW_MEMBER_SIGNUP === 'true' ? { allowSignUp: true } : {}),
|
|
30
|
+
env: env,
|
|
31
|
+
});
|
|
32
|
+
if (!env.BUCKET)
|
|
33
|
+
throw new Error('Vulse: R2 binding "BUCKET" is missing. Add it to wrangler.toml.');
|
|
34
|
+
const cfImages = {
|
|
35
|
+
...(env.CF_IMAGES_ACCOUNT_HASH ? { accountHash: env.CF_IMAGES_ACCOUNT_HASH } : {}),
|
|
36
|
+
...(env.CF_IMAGES_TOKEN ? { token: env.CF_IMAGES_TOKEN } : {}),
|
|
37
|
+
};
|
|
38
|
+
cached = {
|
|
39
|
+
db, auth, registry,
|
|
40
|
+
sdk: createSdk(db, auth, registry, cfImages),
|
|
41
|
+
routes: {
|
|
42
|
+
entries: entriesRoutes(db, auth, registry),
|
|
43
|
+
revisions: revisionsRoutes(db, auth),
|
|
44
|
+
users: usersRoutes(db, auth),
|
|
45
|
+
settings: settingsRoutes(db, auth),
|
|
46
|
+
blueprints: blueprintsRoutes(db, auth),
|
|
47
|
+
sets: setsRoutes(db, auth),
|
|
48
|
+
media: mediaRoutes(db, auth, {
|
|
49
|
+
bucket: env.BUCKET,
|
|
50
|
+
cfImages,
|
|
51
|
+
}),
|
|
52
|
+
search: searchRoutes(db, auth),
|
|
53
|
+
preview: previewRoutes(auth, previewSecret(env)),
|
|
54
|
+
previewSessions: previewSessionsRoutes(db, auth, registry),
|
|
55
|
+
forms: formsRoutes(db, auth),
|
|
56
|
+
formSubmit: formSubmitRoutes(db, {
|
|
57
|
+
...(env.FORM_QUEUE ? { queue: env.FORM_QUEUE } : {}),
|
|
58
|
+
env: env,
|
|
59
|
+
}),
|
|
60
|
+
formUpload: formUploadRoutes(db, { bucket: env.BUCKET }),
|
|
61
|
+
globals: globalsRoutes(db, auth),
|
|
62
|
+
globalsPublic: globalsPublicRoutes(db),
|
|
63
|
+
},
|
|
64
|
+
};
|
|
65
|
+
return cached;
|
|
66
|
+
}
|
|
67
|
+
export function invalidateRuntime() { cached = null; }
|
|
68
|
+
/** @deprecated use invalidateRuntime */
|
|
69
|
+
export function _resetRuntime() { invalidateRuntime(); }
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
import type { VulseDb } from '../../core/db.js';
|
|
2
|
+
import { type EntryOrderBy, type EntryRow } from '../../core/repos/entries.js';
|
|
3
|
+
import type { BlueprintRegistry } from '../../core/blueprints/registry.js';
|
|
4
|
+
import type { AuthContext } from '../../core/blueprints/types.js';
|
|
5
|
+
export interface CollectionSdkOptions {
|
|
6
|
+
audience?: AuthContext['user'] | null;
|
|
7
|
+
includeDrafts?: boolean;
|
|
8
|
+
locale?: string;
|
|
9
|
+
}
|
|
10
|
+
export interface CollectionFindOptions extends CollectionSdkOptions {
|
|
11
|
+
limit?: number;
|
|
12
|
+
offset?: number;
|
|
13
|
+
createdBy?: string;
|
|
14
|
+
/** ISO date string or Date */
|
|
15
|
+
publishedAfter?: Date | string;
|
|
16
|
+
publishedBefore?: Date | string;
|
|
17
|
+
orderBy?: EntryOrderBy;
|
|
18
|
+
order?: 'asc' | 'desc';
|
|
19
|
+
}
|
|
20
|
+
export declare function collectionsSdk(db: VulseDb, reg: BlueprintRegistry): {
|
|
21
|
+
find: (collection: string, opts?: CollectionFindOptions) => Promise<EntryRow[]>;
|
|
22
|
+
findById: (collection: string, id: string, opts?: CollectionSdkOptions) => Promise<EntryRow | null>;
|
|
23
|
+
findBySlug: (collection: string, slug: string, opts?: CollectionSdkOptions) => Promise<EntryRow | null>;
|
|
24
|
+
};
|
|
25
|
+
//# sourceMappingURL=collections.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"collections.d.ts","sourceRoot":"","sources":["../../../src/server/sdk/collections.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,kBAAkB,CAAA;AAE/C,OAAO,EAAe,KAAK,YAAY,EAAE,KAAK,QAAQ,EAAE,MAAM,6BAA6B,CAAA;AAE3F,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,mCAAmC,CAAA;AAC1E,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,gCAAgC,CAAA;AAEjE,MAAM,WAAW,oBAAoB;IACnC,QAAQ,CAAC,EAAE,WAAW,CAAC,MAAM,CAAC,GAAG,IAAI,CAAA;IACrC,aAAa,CAAC,EAAE,OAAO,CAAA;IACvB,MAAM,CAAC,EAAE,MAAM,CAAA;CAChB;AAED,MAAM,WAAW,qBAAsB,SAAQ,oBAAoB;IACjE,KAAK,CAAC,EAAE,MAAM,CAAA;IACd,MAAM,CAAC,EAAE,MAAM,CAAA;IACf,SAAS,CAAC,EAAE,MAAM,CAAA;IAClB,8BAA8B;IAC9B,cAAc,CAAC,EAAE,IAAI,GAAG,MAAM,CAAA;IAC9B,eAAe,CAAC,EAAE,IAAI,GAAG,MAAM,CAAA;IAC/B,OAAO,CAAC,EAAE,YAAY,CAAA;IACtB,KAAK,CAAC,EAAE,KAAK,GAAG,MAAM,CAAA;CACvB;AAQD,wBAAgB,cAAc,CAAC,EAAE,EAAE,OAAO,EAAE,GAAG,EAAE,iBAAiB;uBA6BrC,MAAM,SAAQ,qBAAqB;2BAe/B,MAAM,MAAM,MAAM,SAAQ,oBAAoB;6BAW5C,MAAM,QAAQ,MAAM,SAAQ,oBAAoB;EAYlF"}
|