emdash 0.11.1 → 0.13.0
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/dist/{adapters-BktHA7EO.d.mts → adapters-9DybjTO6.d.mts} +1 -1
- package/dist/{adapters-BktHA7EO.d.mts.map → adapters-9DybjTO6.d.mts.map} +1 -1
- package/dist/allowed-origins-CDdG-4Gd.mjs +116 -0
- package/dist/allowed-origins-CDdG-4Gd.mjs.map +1 -0
- package/dist/api/route-utils.d.mts +68 -0
- package/dist/api/route-utils.d.mts.map +1 -0
- package/dist/api/route-utils.mjs +44 -0
- package/dist/api/route-utils.mjs.map +1 -0
- package/dist/api/schemas/index.d.mts +2 -0
- package/dist/api/schemas/index.mjs +4 -0
- package/dist/api-ayIQ7rIe.mjs +3941 -0
- package/dist/api-ayIQ7rIe.mjs.map +1 -0
- package/dist/api-tokens-D3C9v02m.mjs +3 -0
- package/dist/api-tokens-eYymBhIT.mjs +153 -0
- package/dist/api-tokens-eYymBhIT.mjs.map +1 -0
- package/dist/{apply-Ded_1vng.mjs → apply-v4DBgjPw.mjs} +19 -566
- package/dist/apply-v4DBgjPw.mjs.map +1 -0
- package/dist/astro/index.d.mts +10 -6
- package/dist/astro/index.d.mts.map +1 -1
- package/dist/astro/index.mjs +42 -83
- package/dist/astro/index.mjs.map +1 -1
- package/dist/astro/middleware/auth.d.mts +9 -5
- package/dist/astro/middleware/auth.d.mts.map +1 -1
- package/dist/astro/middleware/auth.mjs +25 -65
- package/dist/astro/middleware/auth.mjs.map +1 -1
- package/dist/astro/middleware/redirect.mjs +5 -5
- package/dist/astro/middleware/request-context.mjs +4 -4
- package/dist/astro/middleware/setup.mjs +1 -1
- package/dist/astro/middleware.d.mts.map +1 -1
- package/dist/astro/middleware.mjs +146 -71
- package/dist/astro/middleware.mjs.map +1 -1
- package/dist/astro/routes/PluginRegistry.d.mts +15 -0
- package/dist/astro/routes/PluginRegistry.d.mts.map +1 -0
- package/dist/astro/routes/PluginRegistry.mjs +25 -0
- package/dist/astro/routes/PluginRegistry.mjs.map +1 -0
- package/dist/astro/routes/api/admin/allowed-domains/_domain_.d.mts +15 -0
- package/dist/astro/routes/api/admin/allowed-domains/_domain_.d.mts.map +1 -0
- package/dist/astro/routes/api/admin/allowed-domains/_domain_.mjs +67 -0
- package/dist/astro/routes/api/admin/allowed-domains/_domain_.mjs.map +1 -0
- package/dist/astro/routes/api/admin/allowed-domains/index.d.mts +15 -0
- package/dist/astro/routes/api/admin/allowed-domains/index.d.mts.map +1 -0
- package/dist/astro/routes/api/admin/allowed-domains/index.mjs +67 -0
- package/dist/astro/routes/api/admin/allowed-domains/index.mjs.map +1 -0
- package/dist/astro/routes/api/admin/api-tokens/_id_.d.mts +11 -0
- package/dist/astro/routes/api/admin/api-tokens/_id_.d.mts.map +1 -0
- package/dist/astro/routes/api/admin/api-tokens/_id_.mjs +33 -0
- package/dist/astro/routes/api/admin/api-tokens/_id_.mjs.map +1 -0
- package/dist/astro/routes/api/admin/api-tokens/index.d.mts +17 -0
- package/dist/astro/routes/api/admin/api-tokens/index.d.mts.map +1 -0
- package/dist/astro/routes/api/admin/api-tokens/index.mjs +52 -0
- package/dist/astro/routes/api/admin/api-tokens/index.mjs.map +1 -0
- package/dist/astro/routes/api/admin/bylines/_id_/index.d.mts +10 -0
- package/dist/astro/routes/api/admin/bylines/_id_/index.d.mts.map +1 -0
- package/dist/astro/routes/api/admin/bylines/_id_/index.mjs +74 -0
- package/dist/astro/routes/api/admin/bylines/_id_/index.mjs.map +1 -0
- package/dist/astro/routes/api/admin/bylines/index.d.mts +9 -0
- package/dist/astro/routes/api/admin/bylines/index.d.mts.map +1 -0
- package/dist/astro/routes/api/admin/bylines/index.mjs +61 -0
- package/dist/astro/routes/api/admin/bylines/index.mjs.map +1 -0
- package/dist/astro/routes/api/admin/comments/_id_/status.d.mts +8 -0
- package/dist/astro/routes/api/admin/comments/_id_/status.d.mts.map +1 -0
- package/dist/astro/routes/api/admin/comments/_id_/status.mjs +80 -0
- package/dist/astro/routes/api/admin/comments/_id_/status.mjs.map +1 -0
- package/dist/astro/routes/api/admin/comments/_id_.d.mts +15 -0
- package/dist/astro/routes/api/admin/comments/_id_.d.mts.map +1 -0
- package/dist/astro/routes/api/admin/comments/_id_.mjs +47 -0
- package/dist/astro/routes/api/admin/comments/_id_.mjs.map +1 -0
- package/dist/astro/routes/api/admin/comments/bulk.d.mts +8 -0
- package/dist/astro/routes/api/admin/comments/bulk.d.mts.map +1 -0
- package/dist/astro/routes/api/admin/comments/bulk.mjs +36 -0
- package/dist/astro/routes/api/admin/comments/bulk.mjs.map +1 -0
- package/dist/astro/routes/api/admin/comments/counts.d.mts +8 -0
- package/dist/astro/routes/api/admin/comments/counts.d.mts.map +1 -0
- package/dist/astro/routes/api/admin/comments/counts.mjs +25 -0
- package/dist/astro/routes/api/admin/comments/counts.mjs.map +1 -0
- package/dist/astro/routes/api/admin/comments/index.d.mts +11 -0
- package/dist/astro/routes/api/admin/comments/index.d.mts.map +1 -0
- package/dist/astro/routes/api/admin/comments/index.mjs +40 -0
- package/dist/astro/routes/api/admin/comments/index.mjs.map +1 -0
- package/dist/astro/routes/api/admin/hooks/exclusive/_hookName_.d.mts +8 -0
- package/dist/astro/routes/api/admin/hooks/exclusive/_hookName_.d.mts.map +1 -0
- package/dist/astro/routes/api/admin/hooks/exclusive/_hookName_.mjs +48 -0
- package/dist/astro/routes/api/admin/hooks/exclusive/_hookName_.mjs.map +1 -0
- package/dist/astro/routes/api/admin/hooks/exclusive/index.d.mts +8 -0
- package/dist/astro/routes/api/admin/hooks/exclusive/index.d.mts.map +1 -0
- package/dist/astro/routes/api/admin/hooks/exclusive/index.mjs +36 -0
- package/dist/astro/routes/api/admin/hooks/exclusive/index.mjs.map +1 -0
- package/dist/astro/routes/api/admin/oauth-clients/_id_.d.mts +19 -0
- package/dist/astro/routes/api/admin/oauth-clients/_id_.d.mts.map +1 -0
- package/dist/astro/routes/api/admin/oauth-clients/_id_.mjs +69 -0
- package/dist/astro/routes/api/admin/oauth-clients/_id_.mjs.map +1 -0
- package/dist/astro/routes/api/admin/oauth-clients/index.d.mts +15 -0
- package/dist/astro/routes/api/admin/oauth-clients/index.d.mts.map +1 -0
- package/dist/astro/routes/api/admin/oauth-clients/index.mjs +50 -0
- package/dist/astro/routes/api/admin/oauth-clients/index.mjs.map +1 -0
- package/dist/astro/routes/api/admin/plugins/_id_/disable.d.mts +8 -0
- package/dist/astro/routes/api/admin/plugins/_id_/disable.d.mts.map +1 -0
- package/dist/astro/routes/api/admin/plugins/_id_/disable.mjs +56 -0
- package/dist/astro/routes/api/admin/plugins/_id_/disable.mjs.map +1 -0
- package/dist/astro/routes/api/admin/plugins/_id_/enable.d.mts +8 -0
- package/dist/astro/routes/api/admin/plugins/_id_/enable.d.mts.map +1 -0
- package/dist/astro/routes/api/admin/plugins/_id_/enable.mjs +59 -0
- package/dist/astro/routes/api/admin/plugins/_id_/enable.mjs.map +1 -0
- package/dist/astro/routes/api/admin/plugins/_id_/index.d.mts +8 -0
- package/dist/astro/routes/api/admin/plugins/_id_/index.d.mts.map +1 -0
- package/dist/astro/routes/api/admin/plugins/_id_/index.mjs +51 -0
- package/dist/astro/routes/api/admin/plugins/_id_/index.mjs.map +1 -0
- package/dist/astro/routes/api/admin/plugins/_id_/uninstall.d.mts +8 -0
- package/dist/astro/routes/api/admin/plugins/_id_/uninstall.d.mts.map +1 -0
- package/dist/astro/routes/api/admin/plugins/_id_/uninstall.mjs +58 -0
- package/dist/astro/routes/api/admin/plugins/_id_/uninstall.mjs.map +1 -0
- package/dist/astro/routes/api/admin/plugins/_id_/update.d.mts +8 -0
- package/dist/astro/routes/api/admin/plugins/_id_/update.d.mts.map +1 -0
- package/dist/astro/routes/api/admin/plugins/_id_/update.mjs +66 -0
- package/dist/astro/routes/api/admin/plugins/_id_/update.mjs.map +1 -0
- package/dist/astro/routes/api/admin/plugins/index.d.mts +8 -0
- package/dist/astro/routes/api/admin/plugins/index.d.mts.map +1 -0
- package/dist/astro/routes/api/admin/plugins/index.mjs +49 -0
- package/dist/astro/routes/api/admin/plugins/index.mjs.map +1 -0
- package/dist/astro/routes/api/admin/plugins/marketplace/_id_/icon.d.mts +8 -0
- package/dist/astro/routes/api/admin/plugins/marketplace/_id_/icon.d.mts.map +1 -0
- package/dist/astro/routes/api/admin/plugins/marketplace/_id_/icon.mjs +39 -0
- package/dist/astro/routes/api/admin/plugins/marketplace/_id_/icon.mjs.map +1 -0
- package/dist/astro/routes/api/admin/plugins/marketplace/_id_/index.d.mts +8 -0
- package/dist/astro/routes/api/admin/plugins/marketplace/_id_/index.d.mts.map +1 -0
- package/dist/astro/routes/api/admin/plugins/marketplace/_id_/index.mjs +51 -0
- package/dist/astro/routes/api/admin/plugins/marketplace/_id_/index.mjs.map +1 -0
- package/dist/astro/routes/api/admin/plugins/marketplace/_id_/install.d.mts +8 -0
- package/dist/astro/routes/api/admin/plugins/marketplace/_id_/install.d.mts.map +1 -0
- package/dist/astro/routes/api/admin/plugins/marketplace/_id_/install.mjs +69 -0
- package/dist/astro/routes/api/admin/plugins/marketplace/_id_/install.mjs.map +1 -0
- package/dist/astro/routes/api/admin/plugins/marketplace/index.d.mts +8 -0
- package/dist/astro/routes/api/admin/plugins/marketplace/index.d.mts.map +1 -0
- package/dist/astro/routes/api/admin/plugins/marketplace/index.mjs +58 -0
- package/dist/astro/routes/api/admin/plugins/marketplace/index.mjs.map +1 -0
- package/dist/astro/routes/api/admin/plugins/registry/install.d.mts +8 -0
- package/dist/astro/routes/api/admin/plugins/registry/install.d.mts.map +1 -0
- package/dist/astro/routes/api/admin/plugins/registry/install.mjs +72 -0
- package/dist/astro/routes/api/admin/plugins/registry/install.mjs.map +1 -0
- package/dist/astro/routes/api/admin/plugins/updates.d.mts +8 -0
- package/dist/astro/routes/api/admin/plugins/updates.d.mts.map +1 -0
- package/dist/astro/routes/api/admin/plugins/updates.mjs +49 -0
- package/dist/astro/routes/api/admin/plugins/updates.mjs.map +1 -0
- package/dist/astro/routes/api/admin/themes/marketplace/_id_/index.d.mts +8 -0
- package/dist/astro/routes/api/admin/themes/marketplace/_id_/index.d.mts.map +1 -0
- package/dist/astro/routes/api/admin/themes/marketplace/_id_/index.mjs +51 -0
- package/dist/astro/routes/api/admin/themes/marketplace/_id_/index.mjs.map +1 -0
- package/dist/astro/routes/api/admin/themes/marketplace/_id_/thumbnail.d.mts +8 -0
- package/dist/astro/routes/api/admin/themes/marketplace/_id_/thumbnail.d.mts.map +1 -0
- package/dist/astro/routes/api/admin/themes/marketplace/_id_/thumbnail.mjs +39 -0
- package/dist/astro/routes/api/admin/themes/marketplace/_id_/thumbnail.mjs.map +1 -0
- package/dist/astro/routes/api/admin/themes/marketplace/index.d.mts +8 -0
- package/dist/astro/routes/api/admin/themes/marketplace/index.d.mts.map +1 -0
- package/dist/astro/routes/api/admin/themes/marketplace/index.mjs +67 -0
- package/dist/astro/routes/api/admin/themes/marketplace/index.mjs.map +1 -0
- package/dist/astro/routes/api/admin/users/_id_/disable.d.mts +8 -0
- package/dist/astro/routes/api/admin/users/_id_/disable.d.mts.map +1 -0
- package/dist/astro/routes/api/admin/users/_id_/disable.mjs +43 -0
- package/dist/astro/routes/api/admin/users/_id_/disable.mjs.map +1 -0
- package/dist/astro/routes/api/admin/users/_id_/enable.d.mts +8 -0
- package/dist/astro/routes/api/admin/users/_id_/enable.d.mts.map +1 -0
- package/dist/astro/routes/api/admin/users/_id_/enable.mjs +32 -0
- package/dist/astro/routes/api/admin/users/_id_/enable.mjs.map +1 -0
- package/dist/astro/routes/api/admin/users/_id_/index.d.mts +9 -0
- package/dist/astro/routes/api/admin/users/_id_/index.d.mts.map +1 -0
- package/dist/astro/routes/api/admin/users/_id_/index.mjs +106 -0
- package/dist/astro/routes/api/admin/users/_id_/index.mjs.map +1 -0
- package/dist/astro/routes/api/admin/users/_id_/send-recovery.d.mts +8 -0
- package/dist/astro/routes/api/admin/users/_id_/send-recovery.d.mts.map +1 -0
- package/dist/astro/routes/api/admin/users/_id_/send-recovery.mjs +46 -0
- package/dist/astro/routes/api/admin/users/_id_/send-recovery.mjs.map +1 -0
- package/dist/astro/routes/api/admin/users/index.d.mts +8 -0
- package/dist/astro/routes/api/admin/users/index.d.mts.map +1 -0
- package/dist/astro/routes/api/admin/users/index.mjs +56 -0
- package/dist/astro/routes/api/admin/users/index.mjs.map +1 -0
- package/dist/astro/routes/api/auth/dev-bypass.d.mts +9 -0
- package/dist/astro/routes/api/auth/dev-bypass.d.mts.map +1 -0
- package/dist/astro/routes/api/auth/dev-bypass.mjs +84 -0
- package/dist/astro/routes/api/auth/dev-bypass.mjs.map +1 -0
- package/dist/astro/routes/api/auth/invite/accept.d.mts +8 -0
- package/dist/astro/routes/api/auth/invite/accept.d.mts.map +1 -0
- package/dist/astro/routes/api/auth/invite/accept.mjs +34 -0
- package/dist/astro/routes/api/auth/invite/accept.mjs.map +1 -0
- package/dist/astro/routes/api/auth/invite/complete.d.mts +8 -0
- package/dist/astro/routes/api/auth/invite/complete.d.mts.map +1 -0
- package/dist/astro/routes/api/auth/invite/complete.mjs +56 -0
- package/dist/astro/routes/api/auth/invite/complete.mjs.map +1 -0
- package/dist/astro/routes/api/auth/invite/index.d.mts +8 -0
- package/dist/astro/routes/api/auth/invite/index.d.mts.map +1 -0
- package/dist/astro/routes/api/auth/invite/index.mjs +53 -0
- package/dist/astro/routes/api/auth/invite/index.mjs.map +1 -0
- package/dist/astro/routes/api/auth/invite/register-options.d.mts +8 -0
- package/dist/astro/routes/api/auth/invite/register-options.d.mts.map +1 -0
- package/dist/astro/routes/api/auth/invite/register-options.mjs +46 -0
- package/dist/astro/routes/api/auth/invite/register-options.mjs.map +1 -0
- package/dist/astro/routes/api/auth/logout.d.mts +8 -0
- package/dist/astro/routes/api/auth/logout.d.mts.map +1 -0
- package/dist/astro/routes/api/auth/logout.mjs +27 -0
- package/dist/astro/routes/api/auth/logout.mjs.map +1 -0
- package/dist/astro/routes/api/auth/magic-link/send.d.mts +8 -0
- package/dist/astro/routes/api/auth/magic-link/send.d.mts.map +1 -0
- package/dist/astro/routes/api/auth/magic-link/send.mjs +50 -0
- package/dist/astro/routes/api/auth/magic-link/send.mjs.map +1 -0
- package/dist/astro/routes/api/auth/magic-link/verify.d.mts +8 -0
- package/dist/astro/routes/api/auth/magic-link/verify.d.mts.map +1 -0
- package/dist/astro/routes/api/auth/magic-link/verify.mjs +35 -0
- package/dist/astro/routes/api/auth/magic-link/verify.mjs.map +1 -0
- package/dist/astro/routes/api/auth/me.d.mts +14 -0
- package/dist/astro/routes/api/auth/me.d.mts.map +1 -0
- package/dist/astro/routes/api/auth/me.mjs +43 -0
- package/dist/astro/routes/api/auth/me.mjs.map +1 -0
- package/dist/astro/routes/api/auth/mode.d.mts +8 -0
- package/dist/astro/routes/api/auth/mode.d.mts.map +1 -0
- package/dist/astro/routes/api/auth/mode.mjs +29 -0
- package/dist/astro/routes/api/auth/mode.mjs.map +1 -0
- package/dist/astro/routes/api/auth/oauth/_provider_/callback.d.mts +8 -0
- package/dist/astro/routes/api/auth/oauth/_provider_/callback.d.mts.map +1 -0
- package/dist/astro/routes/api/auth/oauth/_provider_/callback.mjs +130 -0
- package/dist/astro/routes/api/auth/oauth/_provider_/callback.mjs.map +1 -0
- package/dist/astro/routes/api/auth/oauth/_provider_.d.mts +8 -0
- package/dist/astro/routes/api/auth/oauth/_provider_.d.mts.map +1 -0
- package/dist/astro/routes/api/auth/oauth/_provider_.mjs +60 -0
- package/dist/astro/routes/api/auth/oauth/_provider_.mjs.map +1 -0
- package/dist/astro/routes/api/auth/passkey/_id_.d.mts +15 -0
- package/dist/astro/routes/api/auth/passkey/_id_.d.mts.map +1 -0
- package/dist/astro/routes/api/auth/passkey/_id_.mjs +64 -0
- package/dist/astro/routes/api/auth/passkey/_id_.mjs.map +1 -0
- package/dist/astro/routes/api/auth/passkey/index.d.mts +8 -0
- package/dist/astro/routes/api/auth/passkey/index.d.mts.map +1 -0
- package/dist/astro/routes/api/auth/passkey/index.mjs +28 -0
- package/dist/astro/routes/api/auth/passkey/index.mjs.map +1 -0
- package/dist/astro/routes/api/auth/passkey/options.d.mts +8 -0
- package/dist/astro/routes/api/auth/passkey/options.d.mts.map +1 -0
- package/dist/astro/routes/api/auth/passkey/options.mjs +48 -0
- package/dist/astro/routes/api/auth/passkey/options.mjs.map +1 -0
- package/dist/astro/routes/api/auth/passkey/register/options.d.mts +8 -0
- package/dist/astro/routes/api/auth/passkey/register/options.d.mts.map +1 -0
- package/dist/astro/routes/api/auth/passkey/register/options.mjs +46 -0
- package/dist/astro/routes/api/auth/passkey/register/options.mjs.map +1 -0
- package/dist/astro/routes/api/auth/passkey/register/verify.d.mts +8 -0
- package/dist/astro/routes/api/auth/passkey/register/verify.d.mts.map +1 -0
- package/dist/astro/routes/api/auth/passkey/register/verify.mjs +61 -0
- package/dist/astro/routes/api/auth/passkey/register/verify.mjs.map +1 -0
- package/dist/astro/routes/api/auth/passkey/verify.d.mts +8 -0
- package/dist/astro/routes/api/auth/passkey/verify.d.mts.map +1 -0
- package/dist/astro/routes/api/auth/passkey/verify.mjs +49 -0
- package/dist/astro/routes/api/auth/passkey/verify.mjs.map +1 -0
- package/dist/astro/routes/api/auth/signup/complete.d.mts +8 -0
- package/dist/astro/routes/api/auth/signup/complete.d.mts.map +1 -0
- package/dist/astro/routes/api/auth/signup/complete.mjs +57 -0
- package/dist/astro/routes/api/auth/signup/complete.mjs.map +1 -0
- package/dist/astro/routes/api/auth/signup/request.d.mts +8 -0
- package/dist/astro/routes/api/auth/signup/request.d.mts.map +1 -0
- package/dist/astro/routes/api/auth/signup/request.mjs +46 -0
- package/dist/astro/routes/api/auth/signup/request.mjs.map +1 -0
- package/dist/astro/routes/api/auth/signup/verify.d.mts +8 -0
- package/dist/astro/routes/api/auth/signup/verify.d.mts.map +1 -0
- package/dist/astro/routes/api/auth/signup/verify.mjs +35 -0
- package/dist/astro/routes/api/auth/signup/verify.mjs.map +1 -0
- package/dist/astro/routes/api/comments/_collection_/_contentId_/index.d.mts +15 -0
- package/dist/astro/routes/api/comments/_collection_/_contentId_/index.d.mts.map +1 -0
- package/dist/astro/routes/api/comments/_collection_/_contentId_/index.mjs +193 -0
- package/dist/astro/routes/api/comments/_collection_/_contentId_/index.mjs.map +1 -0
- package/dist/astro/routes/api/content/_collection_/_id_/compare.d.mts +8 -0
- package/dist/astro/routes/api/content/_collection_/_id_/compare.d.mts.map +1 -0
- package/dist/astro/routes/api/content/_collection_/_id_/compare.mjs +20 -0
- package/dist/astro/routes/api/content/_collection_/_id_/compare.mjs.map +1 -0
- package/dist/astro/routes/api/content/_collection_/_id_/discard-draft.d.mts +8 -0
- package/dist/astro/routes/api/content/_collection_/_id_/discard-draft.d.mts.map +1 -0
- package/dist/astro/routes/api/content/_collection_/_id_/discard-draft.mjs +28 -0
- package/dist/astro/routes/api/content/_collection_/_id_/discard-draft.mjs.map +1 -0
- package/dist/astro/routes/api/content/_collection_/_id_/duplicate.d.mts +8 -0
- package/dist/astro/routes/api/content/_collection_/_id_/duplicate.d.mts.map +1 -0
- package/dist/astro/routes/api/content/_collection_/_id_/duplicate.mjs +30 -0
- package/dist/astro/routes/api/content/_collection_/_id_/duplicate.mjs.map +1 -0
- package/dist/astro/routes/api/content/_collection_/_id_/permanent.d.mts +8 -0
- package/dist/astro/routes/api/content/_collection_/_id_/permanent.d.mts.map +1 -0
- package/dist/astro/routes/api/content/_collection_/_id_/permanent.mjs +23 -0
- package/dist/astro/routes/api/content/_collection_/_id_/permanent.mjs.map +1 -0
- package/dist/astro/routes/api/content/_collection_/_id_/preview-url.d.mts +8 -0
- package/dist/astro/routes/api/content/_collection_/_id_/preview-url.d.mts.map +1 -0
- package/dist/astro/routes/api/content/_collection_/_id_/preview-url.mjs +78 -0
- package/dist/astro/routes/api/content/_collection_/_id_/preview-url.mjs.map +1 -0
- package/dist/astro/routes/api/content/_collection_/_id_/publish.d.mts +8 -0
- package/dist/astro/routes/api/content/_collection_/_id_/publish.d.mts.map +1 -0
- package/dist/astro/routes/api/content/_collection_/_id_/publish.mjs +48 -0
- package/dist/astro/routes/api/content/_collection_/_id_/publish.mjs.map +1 -0
- package/dist/astro/routes/api/content/_collection_/_id_/restore.d.mts +8 -0
- package/dist/astro/routes/api/content/_collection_/_id_/restore.d.mts.map +1 -0
- package/dist/astro/routes/api/content/_collection_/_id_/restore.mjs +28 -0
- package/dist/astro/routes/api/content/_collection_/_id_/restore.mjs.map +1 -0
- package/dist/astro/routes/api/content/_collection_/_id_/revisions.d.mts +8 -0
- package/dist/astro/routes/api/content/_collection_/_id_/revisions.d.mts.map +1 -0
- package/dist/astro/routes/api/content/_collection_/_id_/revisions.mjs +22 -0
- package/dist/astro/routes/api/content/_collection_/_id_/revisions.mjs.map +1 -0
- package/dist/astro/routes/api/content/_collection_/_id_/schedule.d.mts +9 -0
- package/dist/astro/routes/api/content/_collection_/_id_/schedule.d.mts.map +1 -0
- package/dist/astro/routes/api/content/_collection_/_id_/schedule.mjs +58 -0
- package/dist/astro/routes/api/content/_collection_/_id_/schedule.mjs.map +1 -0
- package/dist/astro/routes/api/content/_collection_/_id_/terms/_taxonomy_.d.mts +15 -0
- package/dist/astro/routes/api/content/_collection_/_id_/terms/_taxonomy_.d.mts.map +1 -0
- package/dist/astro/routes/api/content/_collection_/_id_/terms/_taxonomy_.mjs +85 -0
- package/dist/astro/routes/api/content/_collection_/_id_/terms/_taxonomy_.mjs.map +1 -0
- package/dist/astro/routes/api/content/_collection_/_id_/translations.d.mts +8 -0
- package/dist/astro/routes/api/content/_collection_/_id_/translations.d.mts.map +1 -0
- package/dist/astro/routes/api/content/_collection_/_id_/translations.mjs +43 -0
- package/dist/astro/routes/api/content/_collection_/_id_/translations.mjs.map +1 -0
- package/dist/astro/routes/api/content/_collection_/_id_/unpublish.d.mts +8 -0
- package/dist/astro/routes/api/content/_collection_/_id_/unpublish.d.mts.map +1 -0
- package/dist/astro/routes/api/content/_collection_/_id_/unpublish.mjs +28 -0
- package/dist/astro/routes/api/content/_collection_/_id_/unpublish.mjs.map +1 -0
- package/dist/astro/routes/api/content/_collection_/_id_.d.mts +10 -0
- package/dist/astro/routes/api/content/_collection_/_id_.d.mts.map +1 -0
- package/dist/astro/routes/api/content/_collection_/_id_.mjs +88 -0
- package/dist/astro/routes/api/content/_collection_/_id_.mjs.map +1 -0
- package/dist/astro/routes/api/content/_collection_/index.d.mts +9 -0
- package/dist/astro/routes/api/content/_collection_/index.d.mts.map +1 -0
- package/dist/astro/routes/api/content/_collection_/index.mjs +61 -0
- package/dist/astro/routes/api/content/_collection_/index.mjs.map +1 -0
- package/dist/astro/routes/api/content/_collection_/trash.d.mts +8 -0
- package/dist/astro/routes/api/content/_collection_/trash.d.mts.map +1 -0
- package/dist/astro/routes/api/content/_collection_/trash.mjs +25 -0
- package/dist/astro/routes/api/content/_collection_/trash.mjs.map +1 -0
- package/dist/astro/routes/api/dashboard.d.mts +8 -0
- package/dist/astro/routes/api/dashboard.d.mts.map +1 -0
- package/dist/astro/routes/api/dashboard.mjs +26 -0
- package/dist/astro/routes/api/dashboard.mjs.map +1 -0
- package/dist/astro/routes/api/dev/emails.d.mts +9 -0
- package/dist/astro/routes/api/dev/emails.d.mts.map +1 -0
- package/dist/astro/routes/api/dev/emails.mjs +20 -0
- package/dist/astro/routes/api/dev/emails.mjs.map +1 -0
- package/dist/astro/routes/api/import/probe.d.mts +18 -0
- package/dist/astro/routes/api/import/probe.d.mts.map +1 -0
- package/dist/astro/routes/api/import/probe.mjs +35 -0
- package/dist/astro/routes/api/import/probe.mjs.map +1 -0
- package/dist/astro/routes/api/import/wordpress/analyze.d.mts +88 -0
- package/dist/astro/routes/api/import/wordpress/analyze.d.mts.map +1 -0
- package/dist/astro/routes/api/import/wordpress/analyze.mjs +313 -0
- package/dist/astro/routes/api/import/wordpress/analyze.mjs.map +1 -0
- package/dist/astro/routes/api/import/wordpress/execute.d.mts +93 -0
- package/dist/astro/routes/api/import/wordpress/execute.d.mts.map +1 -0
- package/dist/astro/routes/api/import/wordpress/execute.mjs +593 -0
- package/dist/astro/routes/api/import/wordpress/execute.mjs.map +1 -0
- package/dist/astro/routes/api/import/wordpress/media.d.mts +36 -0
- package/dist/astro/routes/api/import/wordpress/media.d.mts.map +1 -0
- package/dist/astro/routes/api/import/wordpress/media.mjs +225 -0
- package/dist/astro/routes/api/import/wordpress/media.mjs.map +1 -0
- package/dist/astro/routes/api/import/wordpress/prepare.d.mts +20 -0
- package/dist/astro/routes/api/import/wordpress/prepare.d.mts.map +1 -0
- package/dist/astro/routes/api/import/wordpress/prepare.mjs +120 -0
- package/dist/astro/routes/api/import/wordpress/prepare.mjs.map +1 -0
- package/dist/astro/routes/api/import/wordpress/rewrite-url-helpers.d.mts +49 -0
- package/dist/astro/routes/api/import/wordpress/rewrite-url-helpers.d.mts.map +1 -0
- package/dist/astro/routes/api/import/wordpress/rewrite-url-helpers.mjs +131 -0
- package/dist/astro/routes/api/import/wordpress/rewrite-url-helpers.mjs.map +1 -0
- package/dist/astro/routes/api/import/wordpress/rewrite-urls.d.mts +22 -0
- package/dist/astro/routes/api/import/wordpress/rewrite-urls.d.mts.map +1 -0
- package/dist/astro/routes/api/import/wordpress/rewrite-urls.mjs +139 -0
- package/dist/astro/routes/api/import/wordpress/rewrite-urls.mjs.map +1 -0
- package/dist/astro/routes/api/import/wordpress-plugin/analyze.d.mts +16 -0
- package/dist/astro/routes/api/import/wordpress-plugin/analyze.d.mts.map +1 -0
- package/dist/astro/routes/api/import/wordpress-plugin/analyze.mjs +71 -0
- package/dist/astro/routes/api/import/wordpress-plugin/analyze.mjs.map +1 -0
- package/dist/astro/routes/api/import/wordpress-plugin/callback.d.mts +8 -0
- package/dist/astro/routes/api/import/wordpress-plugin/callback.d.mts.map +1 -0
- package/dist/astro/routes/api/import/wordpress-plugin/callback.mjs +29 -0
- package/dist/astro/routes/api/import/wordpress-plugin/callback.mjs.map +1 -0
- package/dist/astro/routes/api/import/wordpress-plugin/execute.d.mts +20 -0
- package/dist/astro/routes/api/import/wordpress-plugin/execute.d.mts.map +1 -0
- package/dist/astro/routes/api/import/wordpress-plugin/execute.mjs +219 -0
- package/dist/astro/routes/api/import/wordpress-plugin/execute.mjs.map +1 -0
- package/dist/astro/routes/api/manifest.d.mts +8 -0
- package/dist/astro/routes/api/manifest.d.mts.map +1 -0
- package/dist/astro/routes/api/manifest.mjs +47 -0
- package/dist/astro/routes/api/manifest.mjs.map +1 -0
- package/dist/astro/routes/api/mcp.d.mts +16 -0
- package/dist/astro/routes/api/mcp.d.mts.map +1 -0
- package/dist/astro/routes/api/mcp.mjs +1414 -0
- package/dist/astro/routes/api/mcp.mjs.map +1 -0
- package/dist/astro/routes/api/media/_id_/confirm.d.mts +11 -0
- package/dist/astro/routes/api/media/_id_/confirm.d.mts.map +1 -0
- package/dist/astro/routes/api/media/_id_/confirm.mjs +61 -0
- package/dist/astro/routes/api/media/_id_/confirm.mjs.map +1 -0
- package/dist/astro/routes/api/media/_id_.d.mts +23 -0
- package/dist/astro/routes/api/media/_id_.d.mts.map +1 -0
- package/dist/astro/routes/api/media/_id_.mjs +83 -0
- package/dist/astro/routes/api/media/_id_.mjs.map +1 -0
- package/dist/astro/routes/api/media/file/_...key_.d.mts +8 -0
- package/dist/astro/routes/api/media/file/_...key_.d.mts.map +1 -0
- package/dist/astro/routes/api/media/file/_...key_.mjs +52 -0
- package/dist/astro/routes/api/media/file/_...key_.mjs.map +1 -0
- package/dist/astro/routes/api/media/providers/_providerId_/_itemId_.d.mts +15 -0
- package/dist/astro/routes/api/media/providers/_providerId_/_itemId_.d.mts.map +1 -0
- package/dist/astro/routes/api/media/providers/_providerId_/_itemId_.mjs +52 -0
- package/dist/astro/routes/api/media/providers/_providerId_/_itemId_.mjs.map +1 -0
- package/dist/astro/routes/api/media/providers/_providerId_/index.d.mts +15 -0
- package/dist/astro/routes/api/media/providers/_providerId_/index.d.mts.map +1 -0
- package/dist/astro/routes/api/media/providers/_providerId_/index.mjs +75 -0
- package/dist/astro/routes/api/media/providers/_providerId_/index.mjs.map +1 -0
- package/dist/astro/routes/api/media/providers/index.d.mts +11 -0
- package/dist/astro/routes/api/media/providers/index.d.mts.map +1 -0
- package/dist/astro/routes/api/media/providers/index.mjs +21 -0
- package/dist/astro/routes/api/media/providers/index.mjs.map +1 -0
- package/dist/astro/routes/api/media/upload-url.d.mts +11 -0
- package/dist/astro/routes/api/media/upload-url.d.mts.map +1 -0
- package/dist/astro/routes/api/media/upload-url.mjs +82 -0
- package/dist/astro/routes/api/media/upload-url.mjs.map +1 -0
- package/dist/astro/routes/api/media.d.mts +17 -0
- package/dist/astro/routes/api/media.d.mts.map +1 -0
- package/dist/astro/routes/api/media.mjs +138 -0
- package/dist/astro/routes/api/media.mjs.map +1 -0
- package/dist/astro/routes/api/menus/_name_/items/_id_.d.mts +9 -0
- package/dist/astro/routes/api/menus/_name_/items/_id_.d.mts.map +1 -0
- package/dist/astro/routes/api/menus/_name_/items/_id_.mjs +48 -0
- package/dist/astro/routes/api/menus/_name_/items/_id_.mjs.map +1 -0
- package/dist/astro/routes/api/menus/_name_/items.d.mts +8 -0
- package/dist/astro/routes/api/menus/_name_/items.d.mts.map +1 -0
- package/dist/astro/routes/api/menus/_name_/items.mjs +31 -0
- package/dist/astro/routes/api/menus/_name_/items.mjs.map +1 -0
- package/dist/astro/routes/api/menus/_name_/reorder.d.mts +8 -0
- package/dist/astro/routes/api/menus/_name_/reorder.d.mts.map +1 -0
- package/dist/astro/routes/api/menus/_name_/reorder.mjs +31 -0
- package/dist/astro/routes/api/menus/_name_/reorder.mjs.map +1 -0
- package/dist/astro/routes/api/menus/_name_/translations.d.mts +9 -0
- package/dist/astro/routes/api/menus/_name_/translations.d.mts.map +1 -0
- package/dist/astro/routes/api/menus/_name_/translations.mjs +62 -0
- package/dist/astro/routes/api/menus/_name_/translations.mjs.map +1 -0
- package/dist/astro/routes/api/menus/_name_.d.mts +10 -0
- package/dist/astro/routes/api/menus/_name_.d.mts.map +1 -0
- package/dist/astro/routes/api/menus/_name_.mjs +60 -0
- package/dist/astro/routes/api/menus/_name_.mjs.map +1 -0
- package/dist/astro/routes/api/menus/index.d.mts +9 -0
- package/dist/astro/routes/api/menus/index.d.mts.map +1 -0
- package/dist/astro/routes/api/menus/index.mjs +40 -0
- package/dist/astro/routes/api/menus/index.mjs.map +1 -0
- package/dist/astro/routes/api/oauth/authorize.d.mts +9 -0
- package/dist/astro/routes/api/oauth/authorize.d.mts.map +1 -0
- package/dist/astro/routes/api/oauth/authorize.mjs +260 -0
- package/dist/astro/routes/api/oauth/authorize.mjs.map +1 -0
- package/dist/astro/routes/api/oauth/device/authorize.d.mts +8 -0
- package/dist/astro/routes/api/oauth/device/authorize.d.mts.map +1 -0
- package/dist/astro/routes/api/oauth/device/authorize.mjs +32 -0
- package/dist/astro/routes/api/oauth/device/authorize.mjs.map +1 -0
- package/dist/astro/routes/api/oauth/device/code.d.mts +8 -0
- package/dist/astro/routes/api/oauth/device/code.d.mts.map +1 -0
- package/dist/astro/routes/api/oauth/device/code.mjs +36 -0
- package/dist/astro/routes/api/oauth/device/code.mjs.map +1 -0
- package/dist/astro/routes/api/oauth/device/token.d.mts +8 -0
- package/dist/astro/routes/api/oauth/device/token.d.mts.map +1 -0
- package/dist/astro/routes/api/oauth/device/token.mjs +47 -0
- package/dist/astro/routes/api/oauth/device/token.mjs.map +1 -0
- package/dist/astro/routes/api/oauth/register.d.mts +9 -0
- package/dist/astro/routes/api/oauth/register.d.mts.map +1 -0
- package/dist/astro/routes/api/oauth/register.mjs +113 -0
- package/dist/astro/routes/api/oauth/register.mjs.map +1 -0
- package/dist/astro/routes/api/oauth/token/refresh.d.mts +8 -0
- package/dist/astro/routes/api/oauth/token/refresh.d.mts.map +1 -0
- package/dist/astro/routes/api/oauth/token/refresh.mjs +30 -0
- package/dist/astro/routes/api/oauth/token/refresh.mjs.map +1 -0
- package/dist/astro/routes/api/oauth/token/revoke.d.mts +8 -0
- package/dist/astro/routes/api/oauth/token/revoke.d.mts.map +1 -0
- package/dist/astro/routes/api/oauth/token/revoke.mjs +27 -0
- package/dist/astro/routes/api/oauth/token/revoke.mjs.map +1 -0
- package/dist/astro/routes/api/oauth/token.d.mts +9 -0
- package/dist/astro/routes/api/oauth/token.d.mts.map +1 -0
- package/dist/astro/routes/api/oauth/token.mjs +141 -0
- package/dist/astro/routes/api/oauth/token.mjs.map +1 -0
- package/dist/astro/routes/api/openapi.json.d.mts +8 -0
- package/dist/astro/routes/api/openapi.json.d.mts.map +1 -0
- package/dist/astro/routes/api/openapi.json.mjs +2642 -0
- package/dist/astro/routes/api/openapi.json.mjs.map +1 -0
- package/dist/astro/routes/api/plugins/_pluginId_/_...path_.d.mts +12 -0
- package/dist/astro/routes/api/plugins/_pluginId_/_...path_.d.mts.map +1 -0
- package/dist/astro/routes/api/plugins/_pluginId_/_...path_.mjs +78 -0
- package/dist/astro/routes/api/plugins/_pluginId_/_...path_.mjs.map +1 -0
- package/dist/astro/routes/api/redirects/404s/index.d.mts +10 -0
- package/dist/astro/routes/api/redirects/404s/index.d.mts.map +1 -0
- package/dist/astro/routes/api/redirects/404s/index.mjs +62 -0
- package/dist/astro/routes/api/redirects/404s/index.mjs.map +1 -0
- package/dist/astro/routes/api/redirects/404s/summary.d.mts +8 -0
- package/dist/astro/routes/api/redirects/404s/summary.d.mts.map +1 -0
- package/dist/astro/routes/api/redirects/404s/summary.mjs +34 -0
- package/dist/astro/routes/api/redirects/404s/summary.mjs.map +1 -0
- package/dist/astro/routes/api/redirects/_id_.d.mts +10 -0
- package/dist/astro/routes/api/redirects/_id_.d.mts.map +1 -0
- package/dist/astro/routes/api/redirects/_id_.mjs +71 -0
- package/dist/astro/routes/api/redirects/_id_.mjs.map +1 -0
- package/dist/astro/routes/api/redirects/index.d.mts +9 -0
- package/dist/astro/routes/api/redirects/index.d.mts.map +1 -0
- package/dist/astro/routes/api/redirects/index.mjs +52 -0
- package/dist/astro/routes/api/redirects/index.mjs.map +1 -0
- package/dist/astro/routes/api/revisions/_revisionId_/index.d.mts +8 -0
- package/dist/astro/routes/api/revisions/_revisionId_/index.d.mts.map +1 -0
- package/dist/astro/routes/api/revisions/_revisionId_/index.mjs +19 -0
- package/dist/astro/routes/api/revisions/_revisionId_/index.mjs.map +1 -0
- package/dist/astro/routes/api/revisions/_revisionId_/restore.d.mts +8 -0
- package/dist/astro/routes/api/revisions/_revisionId_/restore.d.mts.map +1 -0
- package/dist/astro/routes/api/revisions/_revisionId_/restore.mjs +26 -0
- package/dist/astro/routes/api/revisions/_revisionId_/restore.mjs.map +1 -0
- package/dist/astro/routes/api/schema/collections/_slug_/fields/_fieldSlug_.d.mts +10 -0
- package/dist/astro/routes/api/schema/collections/_slug_/fields/_fieldSlug_.d.mts.map +1 -0
- package/dist/astro/routes/api/schema/collections/_slug_/fields/_fieldSlug_.mjs +75 -0
- package/dist/astro/routes/api/schema/collections/_slug_/fields/_fieldSlug_.mjs.map +1 -0
- package/dist/astro/routes/api/schema/collections/_slug_/fields/index.d.mts +9 -0
- package/dist/astro/routes/api/schema/collections/_slug_/fields/index.d.mts.map +1 -0
- package/dist/astro/routes/api/schema/collections/_slug_/fields/index.mjs +63 -0
- package/dist/astro/routes/api/schema/collections/_slug_/fields/index.mjs.map +1 -0
- package/dist/astro/routes/api/schema/collections/_slug_/fields/reorder.d.mts +8 -0
- package/dist/astro/routes/api/schema/collections/_slug_/fields/reorder.d.mts.map +1 -0
- package/dist/astro/routes/api/schema/collections/_slug_/fields/reorder.mjs +54 -0
- package/dist/astro/routes/api/schema/collections/_slug_/fields/reorder.mjs.map +1 -0
- package/dist/astro/routes/api/schema/collections/_slug_/index.d.mts +10 -0
- package/dist/astro/routes/api/schema/collections/_slug_/index.d.mts.map +1 -0
- package/dist/astro/routes/api/schema/collections/_slug_/index.mjs +79 -0
- package/dist/astro/routes/api/schema/collections/_slug_/index.mjs.map +1 -0
- package/dist/astro/routes/api/schema/collections/index.d.mts +9 -0
- package/dist/astro/routes/api/schema/collections/index.d.mts.map +1 -0
- package/dist/astro/routes/api/schema/collections/index.mjs +63 -0
- package/dist/astro/routes/api/schema/collections/index.mjs.map +1 -0
- package/dist/astro/routes/api/schema/index.d.mts +8 -0
- package/dist/astro/routes/api/schema/index.d.mts.map +1 -0
- package/dist/astro/routes/api/schema/index.mjs +82 -0
- package/dist/astro/routes/api/schema/index.mjs.map +1 -0
- package/dist/astro/routes/api/schema/orphans/_slug_.d.mts +8 -0
- package/dist/astro/routes/api/schema/orphans/_slug_.d.mts.map +1 -0
- package/dist/astro/routes/api/schema/orphans/_slug_.mjs +55 -0
- package/dist/astro/routes/api/schema/orphans/_slug_.mjs.map +1 -0
- package/dist/astro/routes/api/schema/orphans/index.d.mts +8 -0
- package/dist/astro/routes/api/schema/orphans/index.d.mts.map +1 -0
- package/dist/astro/routes/api/schema/orphans/index.mjs +50 -0
- package/dist/astro/routes/api/schema/orphans/index.mjs.map +1 -0
- package/dist/astro/routes/api/search/enable.d.mts +16 -0
- package/dist/astro/routes/api/search/enable.d.mts.map +1 -0
- package/dist/astro/routes/api/search/enable.mjs +55 -0
- package/dist/astro/routes/api/search/enable.mjs.map +1 -0
- package/dist/astro/routes/api/search/index.d.mts +17 -0
- package/dist/astro/routes/api/search/index.d.mts.map +1 -0
- package/dist/astro/routes/api/search/index.mjs +52 -0
- package/dist/astro/routes/api/search/index.mjs.map +1 -0
- package/dist/astro/routes/api/search/rebuild.d.mts +14 -0
- package/dist/astro/routes/api/search/rebuild.d.mts.map +1 -0
- package/dist/astro/routes/api/search/rebuild.mjs +48 -0
- package/dist/astro/routes/api/search/rebuild.mjs.map +1 -0
- package/dist/astro/routes/api/search/stats.d.mts +11 -0
- package/dist/astro/routes/api/search/stats.d.mts.map +1 -0
- package/dist/astro/routes/api/search/stats.mjs +29 -0
- package/dist/astro/routes/api/search/stats.mjs.map +1 -0
- package/dist/astro/routes/api/search/suggest.d.mts +16 -0
- package/dist/astro/routes/api/search/suggest.d.mts.map +1 -0
- package/dist/astro/routes/api/search/suggest.mjs +43 -0
- package/dist/astro/routes/api/search/suggest.mjs.map +1 -0
- package/dist/astro/routes/api/sections/_slug_.d.mts +10 -0
- package/dist/astro/routes/api/sections/_slug_.d.mts.map +1 -0
- package/dist/astro/routes/api/sections/_slug_.mjs +65 -0
- package/dist/astro/routes/api/sections/_slug_.mjs.map +1 -0
- package/dist/astro/routes/api/sections/index.d.mts +9 -0
- package/dist/astro/routes/api/sections/index.d.mts.map +1 -0
- package/dist/astro/routes/api/sections/index.mjs +48 -0
- package/dist/astro/routes/api/sections/index.mjs.map +1 -0
- package/dist/astro/routes/api/settings/email.d.mts +18 -0
- package/dist/astro/routes/api/settings/email.d.mts.map +1 -0
- package/dist/astro/routes/api/settings/email.mjs +105 -0
- package/dist/astro/routes/api/settings/email.mjs.map +1 -0
- package/dist/astro/routes/api/settings.d.mts +21 -0
- package/dist/astro/routes/api/settings.d.mts.map +1 -0
- package/dist/astro/routes/api/settings.mjs +58 -0
- package/dist/astro/routes/api/settings.mjs.map +1 -0
- package/dist/astro/routes/api/setup/admin-verify.d.mts +8 -0
- package/dist/astro/routes/api/setup/admin-verify.d.mts.map +1 -0
- package/dist/astro/routes/api/setup/admin-verify.mjs +68 -0
- package/dist/astro/routes/api/setup/admin-verify.mjs.map +1 -0
- package/dist/astro/routes/api/setup/admin.d.mts +8 -0
- package/dist/astro/routes/api/setup/admin.d.mts.map +1 -0
- package/dist/astro/routes/api/setup/admin.mjs +69 -0
- package/dist/astro/routes/api/setup/admin.mjs.map +1 -0
- package/dist/astro/routes/api/setup/dev-bypass.d.mts +9 -0
- package/dist/astro/routes/api/setup/dev-bypass.d.mts.map +1 -0
- package/dist/astro/routes/api/setup/dev-bypass.mjs +139 -0
- package/dist/astro/routes/api/setup/dev-bypass.mjs.map +1 -0
- package/dist/astro/routes/api/setup/dev-reset.d.mts +8 -0
- package/dist/astro/routes/api/setup/dev-reset.d.mts.map +1 -0
- package/dist/astro/routes/api/setup/dev-reset.mjs +25 -0
- package/dist/astro/routes/api/setup/dev-reset.mjs.map +1 -0
- package/dist/astro/routes/api/setup/index.d.mts +8 -0
- package/dist/astro/routes/api/setup/index.d.mts.map +1 -0
- package/dist/astro/routes/api/setup/index.mjs +93 -0
- package/dist/astro/routes/api/setup/index.mjs.map +1 -0
- package/dist/astro/routes/api/setup/status.d.mts +8 -0
- package/dist/astro/routes/api/setup/status.d.mts.map +1 -0
- package/dist/astro/routes/api/setup/status.mjs +60 -0
- package/dist/astro/routes/api/setup/status.mjs.map +1 -0
- package/dist/astro/routes/api/snapshot.d.mts +8 -0
- package/dist/astro/routes/api/snapshot.d.mts.map +1 -0
- package/dist/astro/routes/api/snapshot.mjs +270 -0
- package/dist/astro/routes/api/snapshot.mjs.map +1 -0
- package/dist/astro/routes/api/taxonomies/_name_/terms/_slug_/translations.d.mts +9 -0
- package/dist/astro/routes/api/taxonomies/_name_/terms/_slug_/translations.d.mts.map +1 -0
- package/dist/astro/routes/api/taxonomies/_name_/terms/_slug_/translations.mjs +72 -0
- package/dist/astro/routes/api/taxonomies/_name_/terms/_slug_/translations.mjs.map +1 -0
- package/dist/astro/routes/api/taxonomies/_name_/terms/_slug_.d.mts +19 -0
- package/dist/astro/routes/api/taxonomies/_name_/terms/_slug_.d.mts.map +1 -0
- package/dist/astro/routes/api/taxonomies/_name_/terms/_slug_.mjs +80 -0
- package/dist/astro/routes/api/taxonomies/_name_/terms/_slug_.mjs.map +1 -0
- package/dist/astro/routes/api/taxonomies/_name_/terms/index.d.mts +15 -0
- package/dist/astro/routes/api/taxonomies/_name_/terms/index.d.mts.map +1 -0
- package/dist/astro/routes/api/taxonomies/_name_/terms/index.mjs +59 -0
- package/dist/astro/routes/api/taxonomies/_name_/terms/index.mjs.map +1 -0
- package/dist/astro/routes/api/taxonomies/index.d.mts +15 -0
- package/dist/astro/routes/api/taxonomies/index.d.mts.map +1 -0
- package/dist/astro/routes/api/taxonomies/index.mjs +55 -0
- package/dist/astro/routes/api/taxonomies/index.mjs.map +1 -0
- package/dist/astro/routes/api/themes/preview.d.mts +8 -0
- package/dist/astro/routes/api/themes/preview.d.mts.map +1 -0
- package/dist/astro/routes/api/themes/preview.mjs +49 -0
- package/dist/astro/routes/api/themes/preview.mjs.map +1 -0
- package/dist/astro/routes/api/typegen.d.mts +18 -0
- package/dist/astro/routes/api/typegen.d.mts.map +1 -0
- package/dist/astro/routes/api/typegen.mjs +78 -0
- package/dist/astro/routes/api/typegen.mjs.map +1 -0
- package/dist/astro/routes/api/well-known/auth.d.mts +8 -0
- package/dist/astro/routes/api/well-known/auth.d.mts.map +1 -0
- package/dist/astro/routes/api/well-known/auth.mjs +42 -0
- package/dist/astro/routes/api/well-known/auth.mjs.map +1 -0
- package/dist/astro/routes/api/well-known/oauth-authorization-server.d.mts +8 -0
- package/dist/astro/routes/api/well-known/oauth-authorization-server.d.mts.map +1 -0
- package/dist/astro/routes/api/well-known/oauth-authorization-server.mjs +32 -0
- package/dist/astro/routes/api/well-known/oauth-authorization-server.mjs.map +1 -0
- package/dist/astro/routes/api/well-known/oauth-protected-resource.d.mts +8 -0
- package/dist/astro/routes/api/well-known/oauth-protected-resource.d.mts.map +1 -0
- package/dist/astro/routes/api/well-known/oauth-protected-resource.mjs +21 -0
- package/dist/astro/routes/api/well-known/oauth-protected-resource.mjs.map +1 -0
- package/dist/astro/routes/api/widget-areas/_name_/reorder.d.mts +8 -0
- package/dist/astro/routes/api/widget-areas/_name_/reorder.d.mts.map +1 -0
- package/dist/astro/routes/api/widget-areas/_name_/reorder.mjs +36 -0
- package/dist/astro/routes/api/widget-areas/_name_/reorder.mjs.map +1 -0
- package/dist/astro/routes/api/widget-areas/_name_/widgets/_id_.d.mts +9 -0
- package/dist/astro/routes/api/widget-areas/_name_/widgets/_id_.d.mts.map +1 -0
- package/dist/astro/routes/api/widget-areas/_name_/widgets/_id_.mjs +62 -0
- package/dist/astro/routes/api/widget-areas/_name_/widgets/_id_.mjs.map +1 -0
- package/dist/astro/routes/api/widget-areas/_name_/widgets.d.mts +8 -0
- package/dist/astro/routes/api/widget-areas/_name_/widgets.d.mts.map +1 -0
- package/dist/astro/routes/api/widget-areas/_name_/widgets.mjs +49 -0
- package/dist/astro/routes/api/widget-areas/_name_/widgets.mjs.map +1 -0
- package/dist/astro/routes/api/widget-areas/_name_.d.mts +9 -0
- package/dist/astro/routes/api/widget-areas/_name_.d.mts.map +1 -0
- package/dist/astro/routes/api/widget-areas/_name_.mjs +49 -0
- package/dist/astro/routes/api/widget-areas/_name_.mjs.map +1 -0
- package/dist/astro/routes/api/widget-areas/index.d.mts +9 -0
- package/dist/astro/routes/api/widget-areas/index.d.mts.map +1 -0
- package/dist/astro/routes/api/widget-areas/index.mjs +59 -0
- package/dist/astro/routes/api/widget-areas/index.mjs.map +1 -0
- package/dist/astro/routes/api/widget-components.d.mts +8 -0
- package/dist/astro/routes/api/widget-components.d.mts.map +1 -0
- package/dist/astro/routes/api/widget-components.mjs +18 -0
- package/dist/astro/routes/api/widget-components.mjs.map +1 -0
- package/dist/astro/routes/robots.txt.d.mts +8 -0
- package/dist/astro/routes/robots.txt.d.mts.map +1 -0
- package/dist/astro/routes/robots.txt.mjs +61 -0
- package/dist/astro/routes/robots.txt.mjs.map +1 -0
- package/dist/astro/routes/sitemap-_collection_.xml.d.mts +8 -0
- package/dist/astro/routes/sitemap-_collection_.xml.d.mts.map +1 -0
- package/dist/astro/routes/sitemap-_collection_.xml.mjs +71 -0
- package/dist/astro/routes/sitemap-_collection_.xml.mjs.map +1 -0
- package/dist/astro/routes/sitemap.xml.d.mts +8 -0
- package/dist/astro/routes/sitemap.xml.d.mts.map +1 -0
- package/dist/astro/routes/sitemap.xml.mjs +64 -0
- package/dist/astro/routes/sitemap.xml.mjs.map +1 -0
- package/dist/astro/types.d.mts +48 -9
- package/dist/astro/types.d.mts.map +1 -1
- package/dist/auth/providers/github.d.mts +13 -0
- package/dist/auth/providers/github.d.mts.map +1 -0
- package/dist/auth/providers/github.mjs +18 -0
- package/dist/auth/providers/github.mjs.map +1 -0
- package/dist/auth/providers/google.d.mts +13 -0
- package/dist/auth/providers/google.d.mts.map +1 -0
- package/dist/auth/providers/google.mjs +18 -0
- package/dist/auth/providers/google.mjs.map +1 -0
- package/dist/authorize-BlyCH-96.mjs +37 -0
- package/dist/authorize-BlyCH-96.mjs.map +1 -0
- package/dist/{base64-MBPo9ozB.mjs → base64-CqR-7kqF.mjs} +1 -1
- package/dist/{base64-MBPo9ozB.mjs.map → base64-CqR-7kqF.mjs.map} +1 -1
- package/dist/{byline-gFn1r0vA.mjs → byline-D09BaS4j.mjs} +4 -4
- package/dist/{byline-gFn1r0vA.mjs.map → byline-D09BaS4j.mjs.map} +1 -1
- package/dist/{bylines-DTFI8nDM.mjs → bylines-BTM2xtP8.mjs} +6 -6
- package/dist/{bylines-DTFI8nDM.mjs.map → bylines-BTM2xtP8.mjs.map} +1 -1
- package/dist/bylines-C6eYUWlZ.d.mts +1971 -0
- package/dist/bylines-C6eYUWlZ.d.mts.map +1 -0
- package/dist/{cache-BAJbeoZ8.mjs → cache-CXCpjWiL.mjs} +3 -3
- package/dist/{cache-BAJbeoZ8.mjs.map → cache-CXCpjWiL.mjs.map} +1 -1
- package/dist/challenge-store-CJ0OOHOr.mjs +49 -0
- package/dist/challenge-store-CJ0OOHOr.mjs.map +1 -0
- package/dist/{chunks-BK1oZS-l.mjs → chunks-DyGtu1Bv.mjs} +2 -2
- package/dist/{chunks-BK1oZS-l.mjs.map → chunks-DyGtu1Bv.mjs.map} +1 -1
- package/dist/cli/index.mjs +23 -18
- package/dist/cli/index.mjs.map +1 -1
- package/dist/client/cf-access.d.mts +1 -1
- package/dist/client/index.d.mts +1 -1
- package/dist/client/index.d.mts.map +1 -1
- package/dist/client/index.mjs +2 -2
- package/dist/client/index.mjs.map +1 -1
- package/dist/comment-Dd9MI82-.mjs +247 -0
- package/dist/comment-Dd9MI82-.mjs.map +1 -0
- package/dist/comments-koGI0FrK.mjs +204 -0
- package/dist/comments-koGI0FrK.mjs.map +1 -0
- package/dist/components-mZem7pbe.mjs +108 -0
- package/dist/components-mZem7pbe.mjs.map +1 -0
- package/dist/{content-CERxPUN0.mjs → content-D6YG26WG.mjs} +10 -34
- package/dist/content-D6YG26WG.mjs.map +1 -0
- package/dist/context-qF8d3IPR.mjs +879 -0
- package/dist/context-qF8d3IPR.mjs.map +1 -0
- package/dist/cron-H8eJ46dv.mjs +264 -0
- package/dist/cron-H8eJ46dv.mjs.map +1 -0
- package/dist/dashboard-BmWSIUwY.mjs +105 -0
- package/dist/dashboard-BmWSIUwY.mjs.map +1 -0
- package/dist/db/index.d.mts +3 -3
- package/dist/db/index.mjs +1 -1
- package/dist/db/libsql.d.mts +1 -1
- package/dist/db/postgres.d.mts +1 -1
- package/dist/db/sqlite.d.mts +1 -1
- package/dist/{db-errors-B7P2pSCn.mjs → db-errors-CGN9kJfo.mjs} +1 -1
- package/dist/{db-errors-B7P2pSCn.mjs.map → db-errors-CGN9kJfo.mjs.map} +1 -1
- package/dist/{default-pHuz9WF6.mjs → default-Dbs22Gg4.mjs} +1 -1
- package/dist/{default-pHuz9WF6.mjs.map → default-Dbs22Gg4.mjs.map} +1 -1
- package/dist/device-flow-BqJRxa0Q.mjs +467 -0
- package/dist/device-flow-BqJRxa0Q.mjs.map +1 -0
- package/dist/email-console-Dmp5Q-P2.mjs +50 -0
- package/dist/email-console-Dmp5Q-P2.mjs.map +1 -0
- package/dist/error-tSQWIl5U.mjs +437 -0
- package/dist/error-tSQWIl5U.mjs.map +1 -0
- package/dist/escape-B8bdIryO.mjs +9 -0
- package/dist/escape-B8bdIryO.mjs.map +1 -0
- package/dist/fts-manager-B633C-kQ.mjs +339 -0
- package/dist/fts-manager-B633C-kQ.mjs.map +1 -0
- package/dist/hash-DlUxGhQS.mjs +33 -0
- package/dist/hash-DlUxGhQS.mjs.map +1 -0
- package/dist/import-CNfLOgDE.mjs +1531 -0
- package/dist/import-CNfLOgDE.mjs.map +1 -0
- package/dist/index-D2gvztOP.d.mts +262 -0
- package/dist/index-D2gvztOP.d.mts.map +1 -0
- package/dist/{index-BogfvE-z.d.mts → index-UmOMt9T-.d.mts} +310 -911
- package/dist/index-UmOMt9T-.d.mts.map +1 -0
- package/dist/index.d.mts +17 -11
- package/dist/index.mjs +57 -28
- package/dist/{load-DR1VwFXR.mjs → load-QzYRpVN3.mjs} +2 -2
- package/dist/{load-DR1VwFXR.mjs.map → load-QzYRpVN3.mjs.map} +1 -1
- package/dist/{loader-ou_PXAjg.mjs → loader-Cs6-Bqe6.mjs} +4 -4
- package/dist/{loader-ou_PXAjg.mjs.map → loader-Cs6-Bqe6.mjs.map} +1 -1
- package/dist/{manifest-schema-CXAbd1vH.mjs → manifest-schema-HCtSh4Jq.mjs} +1 -1
- package/dist/{manifest-schema-CXAbd1vH.mjs.map → manifest-schema-HCtSh4Jq.mjs.map} +1 -1
- package/dist/media/index.d.mts +1 -1
- package/dist/media/index.mjs +2 -1
- package/dist/media/index.mjs.map +1 -1
- package/dist/media/local-runtime.d.mts +11 -7
- package/dist/media/local-runtime.d.mts.map +1 -1
- package/dist/media/local-runtime.mjs +9 -3
- package/dist/media/local-runtime.mjs.map +1 -1
- package/dist/{media-1fFhub9c.mjs → media-Dg7he9uK.mjs} +2 -2
- package/dist/{media-1fFhub9c.mjs.map → media-Dg7he9uK.mjs.map} +1 -1
- package/dist/media-allowlist-B8EX01DH.mjs +32 -0
- package/dist/media-allowlist-B8EX01DH.mjs.map +1 -0
- package/dist/menus-DOzIecHi.mjs +723 -0
- package/dist/menus-DOzIecHi.mjs.map +1 -0
- package/dist/menus-X4Z-eBA1.mjs +2788 -0
- package/dist/menus-X4Z-eBA1.mjs.map +1 -0
- package/dist/mime-KV5TqkMN.mjs +36 -0
- package/dist/mime-KV5TqkMN.mjs.map +1 -0
- package/dist/{mode-YhqNVef_.mjs → mode-DPRPvJYm.mjs} +1 -1
- package/dist/{mode-YhqNVef_.mjs.map → mode-DPRPvJYm.mjs.map} +1 -1
- package/dist/normalize-CN5kRSMC.mjs +151 -0
- package/dist/normalize-CN5kRSMC.mjs.map +1 -0
- package/dist/oauth-authorization-62GmpGIH.mjs +275 -0
- package/dist/oauth-authorization-62GmpGIH.mjs.map +1 -0
- package/dist/oauth-clients-D_B0_-Bz.mjs +266 -0
- package/dist/oauth-clients-D_B0_-Bz.mjs.map +1 -0
- package/dist/oauth-state-store-DpsZViTu.mjs +49 -0
- package/dist/oauth-state-store-DpsZViTu.mjs.map +1 -0
- package/dist/oauth-user-lookup-meyS2oB1.mjs +26 -0
- package/dist/oauth-user-lookup-meyS2oB1.mjs.map +1 -0
- package/dist/{options-nPxWnrya.mjs → options-BL4X94qY.mjs} +1 -1
- package/dist/{options-nPxWnrya.mjs.map → options-BL4X94qY.mjs.map} +1 -1
- package/dist/options-Cq64Wx0O.d.mts +207 -0
- package/dist/options-Cq64Wx0O.d.mts.map +1 -0
- package/dist/page/index.d.mts +15 -4
- package/dist/page/index.d.mts.map +1 -1
- package/dist/page/index.mjs +16 -5
- package/dist/page/index.mjs.map +1 -1
- package/dist/parse-BFTPon-J.mjs +89 -0
- package/dist/parse-BFTPon-J.mjs.map +1 -0
- package/dist/passkey-config-Cg86_ISa.mjs +46 -0
- package/dist/passkey-config-Cg86_ISa.mjs.map +1 -0
- package/dist/{patterns-DsUZ4uxI.mjs → patterns-CqG5Ya3i.mjs} +54 -2
- package/dist/{patterns-DsUZ4uxI.mjs.map → patterns-CqG5Ya3i.mjs.map} +1 -1
- package/dist/{placeholder-CDPtkelt.d.mts → placeholder-D3cFCU9y.d.mts} +2 -1
- package/dist/{placeholder-CDPtkelt.d.mts.map → placeholder-D3cFCU9y.d.mts.map} +1 -1
- package/dist/placeholder-LqmHqvBw.mjs +143 -0
- package/dist/placeholder-LqmHqvBw.mjs.map +1 -0
- package/dist/plugin-types.d.mts +122 -0
- package/dist/plugin-types.d.mts.map +1 -0
- package/dist/plugin-types.mjs +1 -0
- package/dist/plugins/adapt-sandbox-entry.d.mts +20 -12
- package/dist/plugins/adapt-sandbox-entry.d.mts.map +1 -1
- package/dist/plugins/adapt-sandbox-entry.mjs +46 -23
- package/dist/plugins/adapt-sandbox-entry.mjs.map +1 -1
- package/dist/preview-C1LOEbWZ.mjs +107 -0
- package/dist/preview-C1LOEbWZ.mjs.map +1 -0
- package/dist/{public-url-B1AxbbbQ.mjs → public-url-CseXl9Fv.mjs} +39 -2
- package/dist/{public-url-B1AxbbbQ.mjs.map → public-url-CseXl9Fv.mjs.map} +1 -1
- package/dist/{query-8c_meo_K.mjs → query-axZmO6Tn.mjs} +23 -12
- package/dist/query-axZmO6Tn.mjs.map +1 -0
- package/dist/rate-limit-t5CVjCO6.mjs +120 -0
- package/dist/rate-limit-t5CVjCO6.mjs.map +1 -0
- package/dist/redirect-DGRsLO2I.mjs +17 -0
- package/dist/redirect-DGRsLO2I.mjs.map +1 -0
- package/dist/{redirect-C5H7VGIX.mjs → redirect-DkaDxq8e.mjs} +3 -3
- package/dist/{redirect-C5H7VGIX.mjs.map → redirect-DkaDxq8e.mjs.map} +1 -1
- package/dist/redirects-D1fdd68T.mjs +573 -0
- package/dist/redirects-D1fdd68T.mjs.map +1 -0
- package/dist/redirects-Dmj6KRU3.mjs +1141 -0
- package/dist/redirects-Dmj6KRU3.mjs.map +1 -0
- package/dist/{registry-Do34mz_P.mjs → registry-BnCeHYsf.mjs} +8 -300
- package/dist/registry-BnCeHYsf.mjs.map +1 -0
- package/dist/{request-cache-D4I69LeL.mjs → request-cache-dzCt8TZB.mjs} +1 -1
- package/dist/{request-cache-D4I69LeL.mjs.map → request-cache-dzCt8TZB.mjs.map} +1 -1
- package/dist/request-meta-CLCwSQOS.mjs +140 -0
- package/dist/request-meta-CLCwSQOS.mjs.map +1 -0
- package/dist/{runner-Iu3IZSDM.d.mts → runner-DcfZewkO.d.mts} +2 -2
- package/dist/{runner-Iu3IZSDM.d.mts.map → runner-DcfZewkO.d.mts.map} +1 -1
- package/dist/{runner-DIcU2UCC.mjs → runner-DdnQIwz_.mjs} +436 -187
- package/dist/runner-DdnQIwz_.mjs.map +1 -0
- package/dist/runtime.d.mts +10 -6
- package/dist/runtime.d.mts.map +1 -1
- package/dist/runtime.mjs +3 -3
- package/dist/schema-BmqagCwG.mjs +41 -0
- package/dist/schema-BmqagCwG.mjs.map +1 -0
- package/dist/search-CPrvO5u8.mjs +376 -0
- package/dist/search-CPrvO5u8.mjs.map +1 -0
- package/dist/{secrets-CZ8rxLX3.mjs → secrets-6pgZyq0K.mjs} +3 -3
- package/dist/{secrets-CZ8rxLX3.mjs.map → secrets-6pgZyq0K.mjs.map} +1 -1
- package/dist/sections-Cm-zb-gZ.mjs +346 -0
- package/dist/sections-Cm-zb-gZ.mjs.map +1 -0
- package/dist/seed/index.d.mts +2 -2
- package/dist/seed/index.mjs +19 -15
- package/dist/seo/index.d.mts +1 -1
- package/dist/seo-BoR4wCUh.mjs +86 -0
- package/dist/seo-BoR4wCUh.mjs.map +1 -0
- package/dist/seo-DRq9-EPP.mjs +130 -0
- package/dist/seo-DRq9-EPP.mjs.map +1 -0
- package/dist/service-vByySp-2.mjs +195 -0
- package/dist/service-vByySp-2.mjs.map +1 -0
- package/dist/settings-CBBj7HUd.mjs +51 -0
- package/dist/settings-CBBj7HUd.mjs.map +1 -0
- package/dist/settings-xQKsWnzQ.mjs +235 -0
- package/dist/settings-xQKsWnzQ.mjs.map +1 -0
- package/dist/setup-BGAJ2uXs.mjs +137 -0
- package/dist/setup-BGAJ2uXs.mjs.map +1 -0
- package/dist/setup-complete-C6ZCLhKo.mjs +26 -0
- package/dist/setup-complete-C6ZCLhKo.mjs.map +1 -0
- package/dist/setup-nonce-CY1gQiAU.mjs +25 -0
- package/dist/setup-nonce-CY1gQiAU.mjs.map +1 -0
- package/dist/site-url-D-M4Fd8O.mjs +13 -0
- package/dist/site-url-D-M4Fd8O.mjs.map +1 -0
- package/dist/slugify-Cjh1ssOZ.mjs +30 -0
- package/dist/slugify-Cjh1ssOZ.mjs.map +1 -0
- package/dist/ssrf-CTul4uQi.mjs +1 -0
- package/dist/ssrf-DzFN_qV-.mjs +332 -0
- package/dist/ssrf-DzFN_qV-.mjs.map +1 -0
- package/dist/storage/local.d.mts +1 -1
- package/dist/storage/local.mjs +1 -1
- package/dist/storage/s3.d.mts +1 -1
- package/dist/storage/s3.mjs +1 -1
- package/dist/{taxonomies-Bw76xAxo.mjs → taxonomies-Cn9UpaR2.mjs} +7 -7
- package/dist/{taxonomies-Bw76xAxo.mjs.map → taxonomies-Cn9UpaR2.mjs.map} +1 -1
- package/dist/taxonomies-Dc0mzlms.mjs +508 -0
- package/dist/taxonomies-Dc0mzlms.mjs.map +1 -0
- package/dist/{taxonomy-D6NvlKo8.mjs → taxonomy-wPfusMK9.mjs} +3 -3
- package/dist/{taxonomy-D6NvlKo8.mjs.map → taxonomy-wPfusMK9.mjs.map} +1 -1
- package/dist/{tokens-CyRDPVW2.mjs → tokens-DILYNZMi.mjs} +2 -2
- package/dist/{tokens-CyRDPVW2.mjs.map → tokens-DILYNZMi.mjs.map} +1 -1
- package/dist/{transaction-D44LBXvU.mjs → transaction-NQj4VJ7Z.mjs} +1 -1
- package/dist/{transaction-D44LBXvU.mjs.map → transaction-NQj4VJ7Z.mjs.map} +1 -1
- package/dist/{transport-DX_5rpsq.d.mts → transport-GeXlLscf.d.mts} +1 -1
- package/dist/{transport-DX_5rpsq.d.mts.map → transport-GeXlLscf.d.mts.map} +1 -1
- package/dist/{transport-xpzIjCIB.mjs → transport-fw-mKJzT.mjs} +1 -1
- package/dist/{transport-xpzIjCIB.mjs.map → transport-fw-mKJzT.mjs.map} +1 -1
- package/dist/trusted-proxy-CJhQIk65.mjs +51 -0
- package/dist/trusted-proxy-CJhQIk65.mjs.map +1 -0
- package/dist/{types-IjUrQMVe.d.mts → types-B05e2naf.d.mts} +151 -60
- package/dist/types-B05e2naf.d.mts.map +1 -0
- package/dist/{types-BTe41zL6.d.mts → types-BWhaSS7U.d.mts} +2 -71
- package/dist/types-BWhaSS7U.d.mts.map +1 -0
- package/dist/{types-BQx6ZXpR.d.mts → types-C1KKK4VP.d.mts} +3 -1
- package/dist/{types-BQx6ZXpR.d.mts.map → types-C1KKK4VP.d.mts.map} +1 -1
- package/dist/types-Cb2UCDJg.d.mts +345 -0
- package/dist/types-Cb2UCDJg.d.mts.map +1 -0
- package/dist/{types-BIgulNsW.mjs → types-CwXMEPRr.mjs} +10 -3
- package/dist/types-CwXMEPRr.mjs.map +1 -0
- package/dist/{types-B_CXXnzh.d.mts → types-CzvJd1ND.d.mts} +7 -1
- package/dist/{types-B_CXXnzh.d.mts.map → types-CzvJd1ND.d.mts.map} +1 -1
- package/dist/types-DFowNO60.d.mts +198 -0
- package/dist/types-DFowNO60.d.mts.map +1 -0
- package/dist/{types-56BKbld_.mjs → types-DSZl1Dsv.mjs} +1 -1
- package/dist/{types-56BKbld_.mjs.map → types-DSZl1Dsv.mjs.map} +1 -1
- package/dist/types-DW1l0gCv.d.mts +75 -0
- package/dist/types-DW1l0gCv.d.mts.map +1 -0
- package/dist/types-Db67HHlU.mjs +3 -0
- package/dist/{types-C-aFbqmA.d.mts → types-DmxPPXGf.d.mts} +1 -1
- package/dist/{types-C-aFbqmA.d.mts.map → types-DmxPPXGf.d.mts.map} +1 -1
- package/dist/{types-K-EkEQCI.mjs → types-Dz9CGX_d.mjs} +1 -1
- package/dist/{types-K-EkEQCI.mjs.map → types-Dz9CGX_d.mjs.map} +1 -1
- package/dist/user-Dr1bOCqS.mjs +155 -0
- package/dist/user-Dr1bOCqS.mjs.map +1 -0
- package/dist/utils-_F-rWBTN.mjs +286 -0
- package/dist/utils-_F-rWBTN.mjs.map +1 -0
- package/dist/{validate-CcVQQpmH.d.mts → validate-BpQGsmd7.d.mts} +5 -4
- package/dist/validate-BpQGsmd7.d.mts.map +1 -0
- package/dist/{validate-UK4Ja1uo.mjs → validate-DlFxcVVK.mjs} +3 -3
- package/dist/{validate-UK4Ja1uo.mjs.map → validate-DlFxcVVK.mjs.map} +1 -1
- package/dist/{validation-Vc5DQkJa.mjs → validation-BiFJqUp5.mjs} +6 -5
- package/dist/{validation-Vc5DQkJa.mjs.map → validation-BiFJqUp5.mjs.map} +1 -1
- package/dist/version-Dw7Z5PVU.mjs +7 -0
- package/dist/{version-JjSqv90m.mjs.map → version-Dw7Z5PVU.mjs.map} +1 -1
- package/dist/widgets-B9j_yzlk.mjs +106 -0
- package/dist/widgets-B9j_yzlk.mjs.map +1 -0
- package/dist/zod-generator-DSyz01KE.mjs +234 -0
- package/dist/zod-generator-DSyz01KE.mjs.map +1 -0
- package/locals.d.ts +1 -1
- package/package.json +37 -14
- package/src/api/handlers/content.ts +1 -0
- package/src/api/handlers/index.ts +7 -0
- package/src/api/handlers/marketplace.ts +27 -6
- package/src/api/handlers/menus.ts +157 -580
- package/src/api/handlers/plugins.ts +77 -31
- package/src/api/handlers/registry.ts +1086 -0
- package/src/api/openapi/document.ts +10 -4
- package/src/api/schemas/content.ts +1 -0
- package/src/api/schemas/menus.ts +27 -23
- package/src/api/schemas/settings.ts +41 -9
- package/src/api/types.ts +6 -0
- package/src/astro/integration/index.ts +1 -0
- package/src/astro/integration/route-naming.ts +19 -0
- package/src/astro/integration/routes.ts +25 -3
- package/src/astro/integration/runtime.ts +35 -8
- package/src/astro/middleware/auth.ts +8 -2
- package/src/astro/middleware/csp.ts +25 -3
- package/src/astro/middleware.ts +3 -0
- package/src/astro/routes/api/admin/plugins/[id]/enable.ts +10 -0
- package/src/astro/routes/api/admin/plugins/registry/install.ts +107 -0
- package/src/astro/routes/api/auth/invite/register-options.ts +8 -1
- package/src/astro/routes/api/import/wordpress/execute.ts +185 -6
- package/src/astro/routes/api/media/[id].ts +2 -1
- package/src/astro/routes/api/menus/[name]/items/[id].ts +69 -0
- package/src/astro/routes/api/menus/[name]/items.ts +4 -65
- package/src/astro/types.ts +38 -0
- package/src/cli/wxr/parser.ts +263 -0
- package/src/client/index.ts +2 -1
- package/src/components/EmDashHead.astro +26 -5
- package/src/database/migrations/036_i18n_menus_and_taxonomies.ts +166 -49
- package/src/database/migrations/038_registry_plugin_state.ts +130 -0
- package/src/database/migrations/039_fix_fts5_triggers.ts +264 -0
- package/src/database/migrations/runner.ts +4 -0
- package/src/database/repositories/content.ts +5 -1
- package/src/database/repositories/index.ts +14 -0
- package/src/database/repositories/menu.ts +644 -0
- package/src/database/repositories/types.ts +6 -0
- package/src/database/types.ts +5 -1
- package/src/emdash-runtime.ts +143 -36
- package/src/import/sources/wordpress-plugin.ts +9 -2
- package/src/import/sources/wxr.ts +16 -2
- package/src/import/ssrf.ts +20 -500
- package/src/import/wxr-taxonomies.ts +730 -0
- package/src/index.ts +3 -10
- package/src/media/local-runtime.ts +7 -0
- package/src/media/normalize.ts +37 -4
- package/src/page/absolute-url.ts +146 -0
- package/src/page/jsonld.ts +10 -2
- package/src/page/seo-contributions.ts +17 -6
- package/src/plugin-types.ts +240 -0
- package/src/plugins/adapt-sandbox-entry.ts +115 -39
- package/src/plugins/context.ts +11 -1
- package/src/plugins/define-plugin.ts +34 -56
- package/src/plugins/index.ts +1 -9
- package/src/plugins/marketplace.ts +63 -4
- package/src/plugins/sandbox/index.ts +1 -1
- package/src/plugins/sandbox/noop.ts +2 -2
- package/src/plugins/sandbox/types.ts +7 -4
- package/src/plugins/state.ts +84 -38
- package/src/plugins/types.ts +2 -79
- package/src/query.ts +12 -0
- package/src/registry/config.ts +311 -0
- package/src/registry/plugin-id.ts +116 -0
- package/src/registry/types.ts +206 -0
- package/src/search/fts-manager.ts +77 -15
- package/src/security/ssrf.ts +501 -0
- package/src/settings/index.ts +20 -1
- package/src/settings/types.ts +12 -8
- package/dist/apply-Ded_1vng.mjs.map +0 -1
- package/dist/content-CERxPUN0.mjs.map +0 -1
- package/dist/error-DqnRMM5z.mjs +0 -27
- package/dist/error-DqnRMM5z.mjs.map +0 -1
- package/dist/index-BogfvE-z.d.mts.map +0 -1
- package/dist/placeholder-Ci0RLeCk.mjs +0 -268
- package/dist/placeholder-Ci0RLeCk.mjs.map +0 -1
- package/dist/query-8c_meo_K.mjs.map +0 -1
- package/dist/registry-Do34mz_P.mjs.map +0 -1
- package/dist/runner-DIcU2UCC.mjs.map +0 -1
- package/dist/search-DuWhx4NG.mjs +0 -9897
- package/dist/search-DuWhx4NG.mjs.map +0 -1
- package/dist/types-BIgulNsW.mjs.map +0 -1
- package/dist/types-BTe41zL6.d.mts.map +0 -1
- package/dist/types-DiI8NOG_.mjs +0 -16
- package/dist/types-DiI8NOG_.mjs.map +0 -1
- package/dist/types-IjUrQMVe.d.mts.map +0 -1
- package/dist/validate-CcVQQpmH.d.mts.map +0 -1
- package/dist/version-JjSqv90m.mjs +0 -7
- package/dist/zod-generator-CHnJUP2l.mjs +0 -137
- package/dist/zod-generator-CHnJUP2l.mjs.map +0 -1
|
@@ -11,28 +11,32 @@
|
|
|
11
11
|
* specific row id), so a single menu item target survives content translations.
|
|
12
12
|
*/
|
|
13
13
|
|
|
14
|
-
import type { Kysely
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
14
|
+
import type { Kysely } from "kysely";
|
|
15
|
+
|
|
16
|
+
import {
|
|
17
|
+
MenuGoneError,
|
|
18
|
+
MenuRepository,
|
|
19
|
+
type CreateMenuItemInput as CreateMenuItemRepoInput,
|
|
20
|
+
type Menu,
|
|
21
|
+
type MenuItem,
|
|
22
|
+
type MenuListItem,
|
|
23
|
+
type MenuWithItems,
|
|
24
|
+
type SetMenuItem,
|
|
25
|
+
type UpdateMenuItemInput as UpdateMenuItemRepoInput,
|
|
26
|
+
} from "../../database/repositories/menu.js";
|
|
27
|
+
import type { Database } from "../../database/types.js";
|
|
19
28
|
import { getI18nConfig } from "../../i18n/config.js";
|
|
20
29
|
import type { ApiResult } from "../types.js";
|
|
21
30
|
|
|
22
|
-
//
|
|
23
|
-
//
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
}
|
|
32
|
-
|
|
33
|
-
export interface MenuWithItems extends MenuRow {
|
|
34
|
-
items: MenuItemRow[];
|
|
35
|
-
}
|
|
31
|
+
// Re-export entity types so route files and tests can import them from the
|
|
32
|
+
// handler module without having to know about the repository layout.
|
|
33
|
+
export type {
|
|
34
|
+
Menu,
|
|
35
|
+
MenuItem,
|
|
36
|
+
MenuListItem,
|
|
37
|
+
MenuTranslation,
|
|
38
|
+
MenuWithItems,
|
|
39
|
+
} from "../../database/repositories/menu.js";
|
|
36
40
|
|
|
37
41
|
export interface MenuTranslationsResponse {
|
|
38
42
|
translationGroup: string | null;
|
|
@@ -45,6 +49,10 @@ export interface MenuTranslationsResponse {
|
|
|
45
49
|
}>;
|
|
46
50
|
}
|
|
47
51
|
|
|
52
|
+
// ---------------------------------------------------------------------------
|
|
53
|
+
// Internal helpers
|
|
54
|
+
// ---------------------------------------------------------------------------
|
|
55
|
+
|
|
48
56
|
/**
|
|
49
57
|
* Error returned when a menu lookup by `name` matches multiple locale
|
|
50
58
|
* variants and the caller did not pass `locale` to disambiguate. Maps to
|
|
@@ -67,62 +75,57 @@ function ambiguousMenuLocaleError(
|
|
|
67
75
|
};
|
|
68
76
|
}
|
|
69
77
|
|
|
78
|
+
type ResolveMenuResult =
|
|
79
|
+
| { success: true; menu: Menu }
|
|
80
|
+
| { success: false; error: { code: "NOT_FOUND" | "AMBIGUOUS_LOCALE"; message: string } };
|
|
81
|
+
|
|
82
|
+
/**
|
|
83
|
+
* Resolve a menu by name + optional locale to a single Menu, surfacing the
|
|
84
|
+
* canonical NOT_FOUND / AMBIGUOUS_LOCALE errors. Every item handler relies on
|
|
85
|
+
* this to translate (name, locale) into an unambiguous menu row.
|
|
86
|
+
*/
|
|
87
|
+
async function resolveMenu(
|
|
88
|
+
repo: MenuRepository,
|
|
89
|
+
name: string,
|
|
90
|
+
options: { locale?: string },
|
|
91
|
+
): Promise<ResolveMenuResult> {
|
|
92
|
+
const matches = await repo.findByName(name, options);
|
|
93
|
+
if (matches.length === 0) {
|
|
94
|
+
return {
|
|
95
|
+
success: false,
|
|
96
|
+
error: {
|
|
97
|
+
code: "NOT_FOUND",
|
|
98
|
+
message: `Menu '${name}' not found${options.locale ? ` in locale '${options.locale}'` : ""}`,
|
|
99
|
+
},
|
|
100
|
+
};
|
|
101
|
+
}
|
|
102
|
+
if (matches.length > 1) {
|
|
103
|
+
return {
|
|
104
|
+
success: false,
|
|
105
|
+
error: ambiguousMenuLocaleError(
|
|
106
|
+
name,
|
|
107
|
+
matches.map((m) => m.locale),
|
|
108
|
+
).error,
|
|
109
|
+
};
|
|
110
|
+
}
|
|
111
|
+
return { success: true, menu: matches[0] };
|
|
112
|
+
}
|
|
113
|
+
|
|
70
114
|
// ---------------------------------------------------------------------------
|
|
71
115
|
// Menu handlers
|
|
72
116
|
// ---------------------------------------------------------------------------
|
|
73
117
|
|
|
74
118
|
/**
|
|
75
|
-
* List menus with item counts. Filter by `locale` when provided
|
|
76
|
-
* return every menu row (each locale counts as its own menu for admin listing
|
|
77
|
-
* purposes).
|
|
119
|
+
* List menus with item counts. Filter by `locale` when provided.
|
|
78
120
|
*/
|
|
79
121
|
export async function handleMenuList(
|
|
80
122
|
db: Kysely<Database>,
|
|
81
123
|
options: { locale?: string } = {},
|
|
82
124
|
): Promise<ApiResult<MenuListItem[]>> {
|
|
83
125
|
try {
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
.selectFrom("_emdash_menus as m")
|
|
88
|
-
.leftJoin("_emdash_menu_items as i", "i.menu_id", "m.id")
|
|
89
|
-
.select(({ fn }) => [
|
|
90
|
-
"m.id",
|
|
91
|
-
"m.name",
|
|
92
|
-
"m.label",
|
|
93
|
-
"m.created_at",
|
|
94
|
-
"m.updated_at",
|
|
95
|
-
"m.locale",
|
|
96
|
-
"m.translation_group",
|
|
97
|
-
fn.count<number>("i.id").as("itemCount"),
|
|
98
|
-
])
|
|
99
|
-
.groupBy([
|
|
100
|
-
"m.id",
|
|
101
|
-
"m.name",
|
|
102
|
-
"m.label",
|
|
103
|
-
"m.created_at",
|
|
104
|
-
"m.updated_at",
|
|
105
|
-
"m.locale",
|
|
106
|
-
"m.translation_group",
|
|
107
|
-
])
|
|
108
|
-
.orderBy("m.name", "asc");
|
|
109
|
-
if (options.locale !== undefined) query = query.where("m.locale", "=", options.locale);
|
|
110
|
-
const rows = await query.execute();
|
|
111
|
-
|
|
112
|
-
// SQLite returns count as `number`, but some dialects (Postgres)
|
|
113
|
-
// return `string` from a count() aggregate. Normalize to number.
|
|
114
|
-
const menusWithCounts: MenuListItem[] = rows.map((row) => ({
|
|
115
|
-
id: row.id,
|
|
116
|
-
name: row.name,
|
|
117
|
-
label: row.label,
|
|
118
|
-
created_at: row.created_at,
|
|
119
|
-
updated_at: row.updated_at,
|
|
120
|
-
locale: row.locale,
|
|
121
|
-
translation_group: row.translation_group,
|
|
122
|
-
itemCount: typeof row.itemCount === "string" ? Number(row.itemCount) : row.itemCount,
|
|
123
|
-
}));
|
|
124
|
-
|
|
125
|
-
return { success: true, data: menusWithCounts };
|
|
126
|
+
const repo = new MenuRepository(db);
|
|
127
|
+
const items = await repo.findMany(options);
|
|
128
|
+
return { success: true, data: items };
|
|
126
129
|
} catch {
|
|
127
130
|
return {
|
|
128
131
|
success: false,
|
|
@@ -133,12 +136,13 @@ export async function handleMenuList(
|
|
|
133
136
|
|
|
134
137
|
/**
|
|
135
138
|
* Create a new menu. When `translationOf` is supplied the new menu joins the
|
|
136
|
-
* source menu's translation_group (and gets the source's items cloned
|
|
139
|
+
* source menu's translation_group (and gets the source's items cloned by the
|
|
140
|
+
* repository).
|
|
137
141
|
*/
|
|
138
142
|
export async function handleMenuCreate(
|
|
139
143
|
db: Kysely<Database>,
|
|
140
144
|
input: { name: string; label: string; locale?: string; translationOf?: string },
|
|
141
|
-
): Promise<ApiResult<
|
|
145
|
+
): Promise<ApiResult<Menu>> {
|
|
142
146
|
try {
|
|
143
147
|
// Translating from a source menu only makes sense when the caller
|
|
144
148
|
// names the target locale: otherwise we'd silently clone into the
|
|
@@ -155,35 +159,24 @@ export async function handleMenuCreate(
|
|
|
155
159
|
};
|
|
156
160
|
}
|
|
157
161
|
|
|
158
|
-
|
|
159
|
-
|
|
160
|
-
|
|
162
|
+
const repo = new MenuRepository(db);
|
|
163
|
+
|
|
164
|
+
// Existence check up front so the repo's "Source not found" throw
|
|
165
|
+
// becomes a clean NOT_FOUND on the API.
|
|
161
166
|
if (input.translationOf) {
|
|
162
|
-
const
|
|
163
|
-
|
|
164
|
-
.selectAll()
|
|
165
|
-
.where("id", "=", input.translationOf)
|
|
166
|
-
.executeTakeFirst();
|
|
167
|
-
if (!src) {
|
|
167
|
+
const source = await repo.findById(input.translationOf);
|
|
168
|
+
if (!source) {
|
|
168
169
|
return {
|
|
169
170
|
success: false,
|
|
170
171
|
error: { code: "NOT_FOUND", message: "Source menu for translation not found" },
|
|
171
172
|
};
|
|
172
173
|
}
|
|
173
|
-
sourceMenu = src;
|
|
174
|
-
translationGroup = src.translation_group ?? src.id;
|
|
175
174
|
}
|
|
176
175
|
|
|
177
176
|
// Duplicate guard: same (name, locale). Falls back to the configured
|
|
178
177
|
// defaultLocale to match the column DEFAULT set by migration 036.
|
|
179
178
|
const effectiveLocale = input.locale ?? getI18nConfig()?.defaultLocale ?? "en";
|
|
180
|
-
|
|
181
|
-
.selectFrom("_emdash_menus")
|
|
182
|
-
.select("id")
|
|
183
|
-
.where("name", "=", input.name)
|
|
184
|
-
.where("locale", "=", effectiveLocale)
|
|
185
|
-
.executeTakeFirst();
|
|
186
|
-
if (existing) {
|
|
179
|
+
if (await repo.existsByNameAndLocale(input.name, effectiveLocale)) {
|
|
187
180
|
return {
|
|
188
181
|
success: false,
|
|
189
182
|
error: {
|
|
@@ -195,69 +188,7 @@ export async function handleMenuCreate(
|
|
|
195
188
|
};
|
|
196
189
|
}
|
|
197
190
|
|
|
198
|
-
const
|
|
199
|
-
|
|
200
|
-
await withTransaction(db, async (trx) => {
|
|
201
|
-
await trx
|
|
202
|
-
.insertInto("_emdash_menus")
|
|
203
|
-
.values({
|
|
204
|
-
id,
|
|
205
|
-
name: input.name,
|
|
206
|
-
label: input.label,
|
|
207
|
-
...(input.locale !== undefined ? { locale: input.locale } : {}),
|
|
208
|
-
translation_group: translationGroup ?? id,
|
|
209
|
-
})
|
|
210
|
-
.execute();
|
|
211
|
-
|
|
212
|
-
// Clone items from the source menu (same reference_ids — they are
|
|
213
|
-
// translation_groups, which are locale-agnostic). Each clone
|
|
214
|
-
// inherits the source item's translation_group so a nav entry
|
|
215
|
-
// identifies as the same logical item across menu translations.
|
|
216
|
-
if (sourceMenu) {
|
|
217
|
-
const sourceItems = await trx
|
|
218
|
-
.selectFrom("_emdash_menu_items")
|
|
219
|
-
.selectAll()
|
|
220
|
-
.where("menu_id", "=", sourceMenu.id)
|
|
221
|
-
.orderBy("sort_order", "asc")
|
|
222
|
-
.execute();
|
|
223
|
-
if (sourceItems.length > 0) {
|
|
224
|
-
// Build old-id → new-id map so parent pointers land on the clones.
|
|
225
|
-
const idMap = new Map<string, string>();
|
|
226
|
-
for (const item of sourceItems) idMap.set(item.id, ulid());
|
|
227
|
-
|
|
228
|
-
await trx
|
|
229
|
-
.insertInto("_emdash_menu_items")
|
|
230
|
-
.values(
|
|
231
|
-
sourceItems.map((item) => {
|
|
232
|
-
const newId = idMap.get(item.id)!;
|
|
233
|
-
return {
|
|
234
|
-
id: newId,
|
|
235
|
-
menu_id: id,
|
|
236
|
-
parent_id: item.parent_id ? (idMap.get(item.parent_id) ?? null) : null,
|
|
237
|
-
sort_order: item.sort_order,
|
|
238
|
-
type: item.type,
|
|
239
|
-
reference_collection: item.reference_collection,
|
|
240
|
-
reference_id: item.reference_id,
|
|
241
|
-
custom_url: item.custom_url,
|
|
242
|
-
label: item.label,
|
|
243
|
-
title_attr: item.title_attr,
|
|
244
|
-
target: item.target,
|
|
245
|
-
css_classes: item.css_classes,
|
|
246
|
-
...(input.locale !== undefined ? { locale: input.locale } : {}),
|
|
247
|
-
translation_group: item.translation_group ?? item.id,
|
|
248
|
-
};
|
|
249
|
-
}),
|
|
250
|
-
)
|
|
251
|
-
.execute();
|
|
252
|
-
}
|
|
253
|
-
}
|
|
254
|
-
});
|
|
255
|
-
|
|
256
|
-
const menu = await db
|
|
257
|
-
.selectFrom("_emdash_menus")
|
|
258
|
-
.selectAll()
|
|
259
|
-
.where("id", "=", id)
|
|
260
|
-
.executeTakeFirstOrThrow();
|
|
191
|
+
const menu = await repo.create(input);
|
|
261
192
|
return { success: true, data: menu };
|
|
262
193
|
} catch {
|
|
263
194
|
return {
|
|
@@ -270,6 +201,9 @@ export async function handleMenuCreate(
|
|
|
270
201
|
/**
|
|
271
202
|
* Get a single menu by name. Honours an optional `locale` filter; when two
|
|
272
203
|
* menus share a name across locales, the locale distinguishes them.
|
|
204
|
+
*
|
|
205
|
+
* Historical behaviour: when `locale` is omitted, returns the lowest-locale
|
|
206
|
+
* match (deterministic). Mirrors the pre-repo handler.
|
|
273
207
|
*/
|
|
274
208
|
export async function handleMenuGet(
|
|
275
209
|
db: Kysely<Database>,
|
|
@@ -277,24 +211,16 @@ export async function handleMenuGet(
|
|
|
277
211
|
options: { locale?: string } = {},
|
|
278
212
|
): Promise<ApiResult<MenuWithItems>> {
|
|
279
213
|
try {
|
|
280
|
-
|
|
281
|
-
|
|
282
|
-
|
|
283
|
-
|
|
284
|
-
if (!menu) {
|
|
214
|
+
const repo = new MenuRepository(db);
|
|
215
|
+
const matches = await repo.findByName(name, options);
|
|
216
|
+
if (matches.length === 0) {
|
|
285
217
|
return {
|
|
286
218
|
success: false,
|
|
287
219
|
error: { code: "NOT_FOUND", message: `Menu '${name}' not found` },
|
|
288
220
|
};
|
|
289
221
|
}
|
|
290
|
-
|
|
291
|
-
const items = await
|
|
292
|
-
.selectFrom("_emdash_menu_items")
|
|
293
|
-
.selectAll()
|
|
294
|
-
.where("menu_id", "=", menu.id)
|
|
295
|
-
.orderBy("sort_order", "asc")
|
|
296
|
-
.execute();
|
|
297
|
-
|
|
222
|
+
const menu = matches[0];
|
|
223
|
+
const items = await repo.findItems(menu.id);
|
|
298
224
|
return { success: true, data: { ...menu, items } };
|
|
299
225
|
} catch {
|
|
300
226
|
return {
|
|
@@ -313,24 +239,15 @@ export async function handleMenuGetById(
|
|
|
313
239
|
id: string,
|
|
314
240
|
): Promise<ApiResult<MenuWithItems>> {
|
|
315
241
|
try {
|
|
316
|
-
const
|
|
317
|
-
|
|
318
|
-
.selectAll()
|
|
319
|
-
.where("id", "=", id)
|
|
320
|
-
.executeTakeFirst();
|
|
242
|
+
const repo = new MenuRepository(db);
|
|
243
|
+
const menu = await repo.findWithItems(id);
|
|
321
244
|
if (!menu) {
|
|
322
245
|
return {
|
|
323
246
|
success: false,
|
|
324
247
|
error: { code: "NOT_FOUND", message: `Menu '${id}' not found` },
|
|
325
248
|
};
|
|
326
249
|
}
|
|
327
|
-
|
|
328
|
-
.selectFrom("_emdash_menu_items")
|
|
329
|
-
.selectAll()
|
|
330
|
-
.where("menu_id", "=", menu.id)
|
|
331
|
-
.orderBy("sort_order", "asc")
|
|
332
|
-
.execute();
|
|
333
|
-
return { success: true, data: { ...menu, items } };
|
|
250
|
+
return { success: true, data: menu };
|
|
334
251
|
} catch {
|
|
335
252
|
return {
|
|
336
253
|
success: false,
|
|
@@ -346,46 +263,18 @@ export async function handleMenuUpdate(
|
|
|
346
263
|
db: Kysely<Database>,
|
|
347
264
|
name: string,
|
|
348
265
|
input: { label?: string; locale?: string },
|
|
349
|
-
): Promise<ApiResult<
|
|
266
|
+
): Promise<ApiResult<Menu>> {
|
|
350
267
|
try {
|
|
351
|
-
|
|
352
|
-
|
|
353
|
-
|
|
354
|
-
|
|
355
|
-
|
|
356
|
-
if (input.locale !== undefined) query = query.where("locale", "=", input.locale);
|
|
357
|
-
const matches = await query.execute();
|
|
358
|
-
|
|
359
|
-
if (matches.length === 0) {
|
|
268
|
+
const repo = new MenuRepository(db);
|
|
269
|
+
const resolved = await resolveMenu(repo, name, { locale: input.locale });
|
|
270
|
+
if (!resolved.success) return resolved;
|
|
271
|
+
const updated = await repo.update(resolved.menu.id, { label: input.label });
|
|
272
|
+
if (!updated) {
|
|
360
273
|
return {
|
|
361
274
|
success: false,
|
|
362
|
-
error: {
|
|
363
|
-
code: "NOT_FOUND",
|
|
364
|
-
message: `Menu '${name}' not found${input.locale ? ` in locale '${input.locale}'` : ""}`,
|
|
365
|
-
},
|
|
275
|
+
error: { code: "NOT_FOUND", message: `Menu '${name}' not found` },
|
|
366
276
|
};
|
|
367
277
|
}
|
|
368
|
-
if (matches.length > 1) {
|
|
369
|
-
return ambiguousMenuLocaleError(
|
|
370
|
-
name,
|
|
371
|
-
matches.map((m) => m.locale),
|
|
372
|
-
);
|
|
373
|
-
}
|
|
374
|
-
const menu = matches[0]!;
|
|
375
|
-
|
|
376
|
-
if (input.label) {
|
|
377
|
-
await db
|
|
378
|
-
.updateTable("_emdash_menus")
|
|
379
|
-
.set({ label: input.label })
|
|
380
|
-
.where("id", "=", menu.id)
|
|
381
|
-
.execute();
|
|
382
|
-
}
|
|
383
|
-
|
|
384
|
-
const updated = await db
|
|
385
|
-
.selectFrom("_emdash_menus")
|
|
386
|
-
.selectAll()
|
|
387
|
-
.where("id", "=", menu.id)
|
|
388
|
-
.executeTakeFirstOrThrow();
|
|
389
278
|
return { success: true, data: updated };
|
|
390
279
|
} catch {
|
|
391
280
|
return {
|
|
@@ -396,7 +285,7 @@ export async function handleMenuUpdate(
|
|
|
396
285
|
}
|
|
397
286
|
|
|
398
287
|
/**
|
|
399
|
-
* Delete a menu (and items, via
|
|
288
|
+
* Delete a menu (and its items, via the repository's explicit cleanup).
|
|
400
289
|
*/
|
|
401
290
|
export async function handleMenuDelete(
|
|
402
291
|
db: Kysely<Database>,
|
|
@@ -404,35 +293,10 @@ export async function handleMenuDelete(
|
|
|
404
293
|
options: { locale?: string } = {},
|
|
405
294
|
): Promise<ApiResult<{ deleted: true }>> {
|
|
406
295
|
try {
|
|
407
|
-
|
|
408
|
-
|
|
409
|
-
if (
|
|
410
|
-
|
|
411
|
-
|
|
412
|
-
if (matches.length === 0) {
|
|
413
|
-
return {
|
|
414
|
-
success: false,
|
|
415
|
-
error: {
|
|
416
|
-
code: "NOT_FOUND",
|
|
417
|
-
message: `Menu '${name}' not found${
|
|
418
|
-
options.locale ? ` in locale '${options.locale}'` : ""
|
|
419
|
-
}`,
|
|
420
|
-
},
|
|
421
|
-
};
|
|
422
|
-
}
|
|
423
|
-
if (matches.length > 1) {
|
|
424
|
-
return ambiguousMenuLocaleError(
|
|
425
|
-
name,
|
|
426
|
-
matches.map((m) => m.locale),
|
|
427
|
-
);
|
|
428
|
-
}
|
|
429
|
-
const menu = matches[0]!;
|
|
430
|
-
|
|
431
|
-
// D1 has FOREIGN KEYS off by default, so the migration's `ON DELETE
|
|
432
|
-
// CASCADE` won't fire there. Delete items explicitly first — this is
|
|
433
|
-
// idempotent on SQLite/Postgres where the cascade also fires.
|
|
434
|
-
await db.deleteFrom("_emdash_menu_items").where("menu_id", "=", menu.id).execute();
|
|
435
|
-
await db.deleteFrom("_emdash_menus").where("id", "=", menu.id).execute();
|
|
296
|
+
const repo = new MenuRepository(db);
|
|
297
|
+
const resolved = await resolveMenu(repo, name, options);
|
|
298
|
+
if (!resolved.success) return resolved;
|
|
299
|
+
await repo.delete(resolved.menu.id);
|
|
436
300
|
return { success: true, data: { deleted: true } };
|
|
437
301
|
} catch {
|
|
438
302
|
return {
|
|
@@ -450,37 +314,15 @@ export async function handleMenuTranslations(
|
|
|
450
314
|
idOrGroup: string,
|
|
451
315
|
): Promise<ApiResult<MenuTranslationsResponse>> {
|
|
452
316
|
try {
|
|
453
|
-
const
|
|
454
|
-
|
|
455
|
-
|
|
456
|
-
.where((eb) => eb.or([eb("id", "=", idOrGroup), eb("translation_group", "=", idOrGroup)]))
|
|
457
|
-
.executeTakeFirst();
|
|
458
|
-
if (!anchor) {
|
|
317
|
+
const repo = new MenuRepository(db);
|
|
318
|
+
const result = await repo.listTranslations(idOrGroup);
|
|
319
|
+
if (!result) {
|
|
459
320
|
return {
|
|
460
321
|
success: false,
|
|
461
322
|
error: { code: "NOT_FOUND", message: "Menu not found" },
|
|
462
323
|
};
|
|
463
324
|
}
|
|
464
|
-
|
|
465
|
-
const rows = await db
|
|
466
|
-
.selectFrom("_emdash_menus")
|
|
467
|
-
.selectAll()
|
|
468
|
-
.where("translation_group", "=", group)
|
|
469
|
-
.orderBy("locale", "asc")
|
|
470
|
-
.execute();
|
|
471
|
-
return {
|
|
472
|
-
success: true,
|
|
473
|
-
data: {
|
|
474
|
-
translationGroup: group,
|
|
475
|
-
translations: rows.map((row) => ({
|
|
476
|
-
id: row.id,
|
|
477
|
-
name: row.name,
|
|
478
|
-
locale: row.locale,
|
|
479
|
-
label: row.label,
|
|
480
|
-
updatedAt: row.updated_at,
|
|
481
|
-
})),
|
|
482
|
-
},
|
|
483
|
-
};
|
|
325
|
+
return { success: true, data: result };
|
|
484
326
|
} catch {
|
|
485
327
|
return {
|
|
486
328
|
success: false,
|
|
@@ -493,91 +335,25 @@ export async function handleMenuTranslations(
|
|
|
493
335
|
// Menu item handlers
|
|
494
336
|
// ---------------------------------------------------------------------------
|
|
495
337
|
|
|
496
|
-
export
|
|
497
|
-
|
|
498
|
-
|
|
499
|
-
referenceCollection?: string;
|
|
500
|
-
referenceId?: string;
|
|
501
|
-
customUrl?: string;
|
|
502
|
-
target?: string;
|
|
503
|
-
titleAttr?: string;
|
|
504
|
-
cssClasses?: string;
|
|
505
|
-
parentId?: string;
|
|
506
|
-
sortOrder?: number;
|
|
507
|
-
}
|
|
338
|
+
export type CreateMenuItemInput = CreateMenuItemRepoInput;
|
|
339
|
+
export type UpdateMenuItemInput = UpdateMenuItemRepoInput;
|
|
340
|
+
export type MenuSetItemsInput = SetMenuItem;
|
|
508
341
|
|
|
509
342
|
/**
|
|
510
|
-
* Add an item to a menu. The item inherits the menu's locale
|
|
511
|
-
* items by locale stays trivial).
|
|
343
|
+
* Add an item to a menu. The item inherits the menu's locale.
|
|
512
344
|
*/
|
|
513
345
|
export async function handleMenuItemCreate(
|
|
514
346
|
db: Kysely<Database>,
|
|
515
347
|
menuName: string,
|
|
516
348
|
input: CreateMenuItemInput,
|
|
517
349
|
options: { locale?: string } = {},
|
|
518
|
-
): Promise<ApiResult<
|
|
350
|
+
): Promise<ApiResult<MenuItem>> {
|
|
519
351
|
try {
|
|
520
|
-
|
|
521
|
-
|
|
522
|
-
|
|
523
|
-
.selectFrom("_emdash_menus")
|
|
524
|
-
.select(["id", "locale"])
|
|
525
|
-
.where("name", "=", menuName);
|
|
526
|
-
if (options.locale !== undefined) menuQuery = menuQuery.where("locale", "=", options.locale);
|
|
527
|
-
const matches = await menuQuery.execute();
|
|
352
|
+
const repo = new MenuRepository(db);
|
|
353
|
+
const resolved = await resolveMenu(repo, menuName, options);
|
|
354
|
+
if (!resolved.success) return resolved;
|
|
528
355
|
|
|
529
|
-
|
|
530
|
-
return {
|
|
531
|
-
success: false,
|
|
532
|
-
error: { code: "NOT_FOUND", message: "Menu not found" },
|
|
533
|
-
};
|
|
534
|
-
}
|
|
535
|
-
if (matches.length > 1) {
|
|
536
|
-
return ambiguousMenuLocaleError(
|
|
537
|
-
menuName,
|
|
538
|
-
matches.map((m) => m.locale),
|
|
539
|
-
);
|
|
540
|
-
}
|
|
541
|
-
const menu = matches[0]!;
|
|
542
|
-
|
|
543
|
-
let sortOrder = input.sortOrder ?? 0;
|
|
544
|
-
if (input.sortOrder === undefined) {
|
|
545
|
-
const maxOrder = await db
|
|
546
|
-
.selectFrom("_emdash_menu_items")
|
|
547
|
-
.select(({ fn }) => fn.max("sort_order").as("max"))
|
|
548
|
-
.where("menu_id", "=", menu.id)
|
|
549
|
-
.where("parent_id", "is", input.parentId ?? null)
|
|
550
|
-
.executeTakeFirst();
|
|
551
|
-
// eslint-disable-next-line typescript-eslint(no-unsafe-type-assertion) -- Kysely fn.max returns unknown; always a number for sort_order column
|
|
552
|
-
sortOrder = ((maxOrder?.max as number) ?? -1) + 1;
|
|
553
|
-
}
|
|
554
|
-
|
|
555
|
-
const id = ulid();
|
|
556
|
-
await db
|
|
557
|
-
.insertInto("_emdash_menu_items")
|
|
558
|
-
.values({
|
|
559
|
-
id,
|
|
560
|
-
menu_id: menu.id,
|
|
561
|
-
parent_id: input.parentId ?? null,
|
|
562
|
-
sort_order: sortOrder,
|
|
563
|
-
type: input.type,
|
|
564
|
-
reference_collection: input.referenceCollection ?? null,
|
|
565
|
-
reference_id: input.referenceId ?? null,
|
|
566
|
-
custom_url: input.customUrl ?? null,
|
|
567
|
-
label: input.label,
|
|
568
|
-
title_attr: input.titleAttr ?? null,
|
|
569
|
-
target: input.target ?? null,
|
|
570
|
-
css_classes: input.cssClasses ?? null,
|
|
571
|
-
locale: menu.locale,
|
|
572
|
-
translation_group: id,
|
|
573
|
-
})
|
|
574
|
-
.execute();
|
|
575
|
-
|
|
576
|
-
const item = await db
|
|
577
|
-
.selectFrom("_emdash_menu_items")
|
|
578
|
-
.selectAll()
|
|
579
|
-
.where("id", "=", id)
|
|
580
|
-
.executeTakeFirstOrThrow();
|
|
356
|
+
const item = await repo.createItem(resolved.menu.id, resolved.menu.locale, input);
|
|
581
357
|
return { success: true, data: item };
|
|
582
358
|
} catch {
|
|
583
359
|
return {
|
|
@@ -587,16 +363,6 @@ export async function handleMenuItemCreate(
|
|
|
587
363
|
}
|
|
588
364
|
}
|
|
589
365
|
|
|
590
|
-
export interface UpdateMenuItemInput {
|
|
591
|
-
label?: string;
|
|
592
|
-
customUrl?: string;
|
|
593
|
-
target?: string;
|
|
594
|
-
titleAttr?: string;
|
|
595
|
-
cssClasses?: string;
|
|
596
|
-
parentId?: string | null;
|
|
597
|
-
sortOrder?: number;
|
|
598
|
-
}
|
|
599
|
-
|
|
600
366
|
/**
|
|
601
367
|
* Update a menu item.
|
|
602
368
|
*/
|
|
@@ -606,62 +372,19 @@ export async function handleMenuItemUpdate(
|
|
|
606
372
|
itemId: string,
|
|
607
373
|
input: UpdateMenuItemInput,
|
|
608
374
|
options: { locale?: string } = {},
|
|
609
|
-
): Promise<ApiResult<
|
|
375
|
+
): Promise<ApiResult<MenuItem>> {
|
|
610
376
|
try {
|
|
611
|
-
|
|
612
|
-
|
|
613
|
-
|
|
614
|
-
.select(["id", "locale"])
|
|
615
|
-
.where("name", "=", menuName);
|
|
616
|
-
if (options.locale !== undefined) menuQuery = menuQuery.where("locale", "=", options.locale);
|
|
617
|
-
const matches = await menuQuery.execute();
|
|
618
|
-
|
|
619
|
-
if (matches.length === 0) {
|
|
620
|
-
return {
|
|
621
|
-
success: false,
|
|
622
|
-
error: { code: "NOT_FOUND", message: "Menu not found" },
|
|
623
|
-
};
|
|
624
|
-
}
|
|
625
|
-
if (matches.length > 1) {
|
|
626
|
-
return ambiguousMenuLocaleError(
|
|
627
|
-
menuName,
|
|
628
|
-
matches.map((m) => m.locale),
|
|
629
|
-
);
|
|
630
|
-
}
|
|
631
|
-
const menu = matches[0]!;
|
|
377
|
+
const repo = new MenuRepository(db);
|
|
378
|
+
const resolved = await resolveMenu(repo, menuName, options);
|
|
379
|
+
if (!resolved.success) return resolved;
|
|
632
380
|
|
|
633
|
-
const
|
|
634
|
-
|
|
635
|
-
.select("id")
|
|
636
|
-
.where("id", "=", itemId)
|
|
637
|
-
.where("menu_id", "=", menu.id)
|
|
638
|
-
.executeTakeFirst();
|
|
639
|
-
|
|
640
|
-
if (!item) {
|
|
381
|
+
const updated = await repo.updateItem(resolved.menu.id, itemId, input);
|
|
382
|
+
if (!updated) {
|
|
641
383
|
return {
|
|
642
384
|
success: false,
|
|
643
385
|
error: { code: "NOT_FOUND", message: "Menu item not found" },
|
|
644
386
|
};
|
|
645
387
|
}
|
|
646
|
-
|
|
647
|
-
const updates: Record<string, unknown> = {};
|
|
648
|
-
if (input.label !== undefined) updates.label = input.label;
|
|
649
|
-
if (input.customUrl !== undefined) updates.custom_url = input.customUrl;
|
|
650
|
-
if (input.target !== undefined) updates.target = input.target;
|
|
651
|
-
if (input.titleAttr !== undefined) updates.title_attr = input.titleAttr;
|
|
652
|
-
if (input.cssClasses !== undefined) updates.css_classes = input.cssClasses;
|
|
653
|
-
if (input.parentId !== undefined) updates.parent_id = input.parentId;
|
|
654
|
-
if (input.sortOrder !== undefined) updates.sort_order = input.sortOrder;
|
|
655
|
-
|
|
656
|
-
if (Object.keys(updates).length > 0) {
|
|
657
|
-
await db.updateTable("_emdash_menu_items").set(updates).where("id", "=", itemId).execute();
|
|
658
|
-
}
|
|
659
|
-
|
|
660
|
-
const updated = await db
|
|
661
|
-
.selectFrom("_emdash_menu_items")
|
|
662
|
-
.selectAll()
|
|
663
|
-
.where("id", "=", itemId)
|
|
664
|
-
.executeTakeFirstOrThrow();
|
|
665
388
|
return { success: true, data: updated };
|
|
666
389
|
} catch {
|
|
667
390
|
return {
|
|
@@ -681,41 +404,17 @@ export async function handleMenuItemDelete(
|
|
|
681
404
|
options: { locale?: string } = {},
|
|
682
405
|
): Promise<ApiResult<{ deleted: true }>> {
|
|
683
406
|
try {
|
|
684
|
-
|
|
685
|
-
|
|
686
|
-
|
|
687
|
-
.select(["id", "locale"])
|
|
688
|
-
.where("name", "=", menuName);
|
|
689
|
-
if (options.locale !== undefined) menuQuery = menuQuery.where("locale", "=", options.locale);
|
|
690
|
-
const matches = await menuQuery.execute();
|
|
691
|
-
|
|
692
|
-
if (matches.length === 0) {
|
|
693
|
-
return {
|
|
694
|
-
success: false,
|
|
695
|
-
error: { code: "NOT_FOUND", message: "Menu not found" },
|
|
696
|
-
};
|
|
697
|
-
}
|
|
698
|
-
if (matches.length > 1) {
|
|
699
|
-
return ambiguousMenuLocaleError(
|
|
700
|
-
menuName,
|
|
701
|
-
matches.map((m) => m.locale),
|
|
702
|
-
);
|
|
703
|
-
}
|
|
704
|
-
const menu = matches[0]!;
|
|
705
|
-
|
|
706
|
-
const result = await db
|
|
707
|
-
.deleteFrom("_emdash_menu_items")
|
|
708
|
-
.where("id", "=", itemId)
|
|
709
|
-
.where("menu_id", "=", menu.id)
|
|
710
|
-
.execute();
|
|
407
|
+
const repo = new MenuRepository(db);
|
|
408
|
+
const resolved = await resolveMenu(repo, menuName, options);
|
|
409
|
+
if (!resolved.success) return resolved;
|
|
711
410
|
|
|
712
|
-
|
|
411
|
+
const deleted = await repo.deleteItem(resolved.menu.id, itemId);
|
|
412
|
+
if (!deleted) {
|
|
713
413
|
return {
|
|
714
414
|
success: false,
|
|
715
415
|
error: { code: "NOT_FOUND", message: "Menu item not found" },
|
|
716
416
|
};
|
|
717
417
|
}
|
|
718
|
-
|
|
719
418
|
return { success: true, data: { deleted: true } };
|
|
720
419
|
} catch {
|
|
721
420
|
return {
|
|
@@ -732,26 +431,9 @@ export interface ReorderItem {
|
|
|
732
431
|
}
|
|
733
432
|
|
|
734
433
|
// ---------------------------------------------------------------------------
|
|
735
|
-
// Atomic-replace menu items (used by the MCP `menu_set_items` tool)
|
|
434
|
+
// Atomic-replace menu items (used by the MCP `menu_set_items` tool and admin)
|
|
736
435
|
// ---------------------------------------------------------------------------
|
|
737
436
|
|
|
738
|
-
export interface MenuSetItemsInput {
|
|
739
|
-
label: string;
|
|
740
|
-
type: "custom" | "page" | "post" | "taxonomy" | "collection";
|
|
741
|
-
customUrl?: string;
|
|
742
|
-
referenceCollection?: string;
|
|
743
|
-
referenceId?: string;
|
|
744
|
-
titleAttr?: string;
|
|
745
|
-
target?: string;
|
|
746
|
-
cssClasses?: string;
|
|
747
|
-
/**
|
|
748
|
-
* Index of the parent item in this same array. Must be strictly less
|
|
749
|
-
* than the current item's index so the insert order resolves parents
|
|
750
|
-
* before children. `undefined` makes the item top-level.
|
|
751
|
-
*/
|
|
752
|
-
parentIndex?: number;
|
|
753
|
-
}
|
|
754
|
-
|
|
755
437
|
/**
|
|
756
438
|
* Replace the entire set of items for a menu in one atomic transaction.
|
|
757
439
|
*
|
|
@@ -765,11 +447,10 @@ export async function handleMenuSetItems(
|
|
|
765
447
|
items: MenuSetItemsInput[],
|
|
766
448
|
options: { locale?: string } = {},
|
|
767
449
|
): Promise<ApiResult<{ name: string; itemCount: number }>> {
|
|
768
|
-
// Validate parentIndex references — must be strictly earlier so
|
|
769
|
-
//
|
|
770
|
-
//
|
|
771
|
-
//
|
|
772
|
-
// any caller that bypasses Zod (REST routes, direct handler use).
|
|
450
|
+
// Validate parentIndex references — must be strictly earlier so the array
|
|
451
|
+
// can be inserted in order with parents resolved first. Negative indices
|
|
452
|
+
// are caught by Zod's `.nonnegative()` at the MCP boundary, but we guard
|
|
453
|
+
// explicitly so REST routes / direct handler use get the same error.
|
|
773
454
|
for (let i = 0; i < items.length; i++) {
|
|
774
455
|
const item = items[i];
|
|
775
456
|
if (item?.parentIndex !== undefined) {
|
|
@@ -786,95 +467,29 @@ export async function handleMenuSetItems(
|
|
|
786
467
|
}
|
|
787
468
|
|
|
788
469
|
try {
|
|
789
|
-
|
|
790
|
-
|
|
791
|
-
|
|
792
|
-
// We capture the locale list rather than constructing the error
|
|
793
|
-
// inside the transaction, so the helper stays the single source
|
|
794
|
-
// of truth for AMBIGUOUS_LOCALE message shape.
|
|
795
|
-
let ambiguousLocales: string[] | null = null;
|
|
796
|
-
const ambiguousSentinel = Symbol("menu-ambiguous-locale");
|
|
797
|
-
|
|
798
|
-
try {
|
|
799
|
-
await withTransaction(db, async (trx) => {
|
|
800
|
-
// Existence check INSIDE the transaction so a concurrent
|
|
801
|
-
// menu_delete between lookup and write can't leave orphan
|
|
802
|
-
// items on D1 (FKs disabled by default). Same fail-loud
|
|
803
|
-
// rule as handleMenuUpdate / handleMenuDelete.
|
|
804
|
-
let menuQuery = trx
|
|
805
|
-
.selectFrom("_emdash_menus")
|
|
806
|
-
.select(["id", "locale"])
|
|
807
|
-
.where("name", "=", menuName);
|
|
808
|
-
if (options.locale !== undefined) {
|
|
809
|
-
menuQuery = menuQuery.where("locale", "=", options.locale);
|
|
810
|
-
}
|
|
811
|
-
const matches = await menuQuery.execute();
|
|
812
|
-
|
|
813
|
-
if (matches.length === 0) {
|
|
814
|
-
throw notFoundSentinel;
|
|
815
|
-
}
|
|
816
|
-
if (matches.length > 1) {
|
|
817
|
-
ambiguousLocales = matches.map((m) => m.locale);
|
|
818
|
-
throw ambiguousSentinel;
|
|
819
|
-
}
|
|
820
|
-
const menu = matches[0]!;
|
|
821
|
-
|
|
822
|
-
await trx.deleteFrom("_emdash_menu_items").where("menu_id", "=", menu.id).execute();
|
|
823
|
-
|
|
824
|
-
const insertedIds: string[] = [];
|
|
825
|
-
for (let i = 0; i < items.length; i++) {
|
|
826
|
-
const item = items[i];
|
|
827
|
-
if (!item) continue;
|
|
828
|
-
const id = ulid();
|
|
829
|
-
const parentId =
|
|
830
|
-
item.parentIndex !== undefined ? (insertedIds[item.parentIndex] ?? null) : null;
|
|
831
|
-
await trx
|
|
832
|
-
.insertInto("_emdash_menu_items")
|
|
833
|
-
.values({
|
|
834
|
-
id,
|
|
835
|
-
menu_id: menu.id,
|
|
836
|
-
parent_id: parentId,
|
|
837
|
-
sort_order: i,
|
|
838
|
-
type: item.type,
|
|
839
|
-
reference_collection: item.referenceCollection ?? null,
|
|
840
|
-
reference_id: item.referenceId ?? null,
|
|
841
|
-
custom_url: item.customUrl ?? null,
|
|
842
|
-
label: item.label,
|
|
843
|
-
title_attr: item.titleAttr ?? null,
|
|
844
|
-
target: item.target ?? null,
|
|
845
|
-
css_classes: item.cssClasses ?? null,
|
|
846
|
-
locale: menu.locale,
|
|
847
|
-
})
|
|
848
|
-
.execute();
|
|
849
|
-
insertedIds.push(id);
|
|
850
|
-
}
|
|
851
|
-
|
|
852
|
-
await trx
|
|
853
|
-
.updateTable("_emdash_menus")
|
|
854
|
-
.set({ updated_at: new Date().toISOString() })
|
|
855
|
-
.where("id", "=", menu.id)
|
|
856
|
-
.execute();
|
|
857
|
-
});
|
|
858
|
-
} catch (error) {
|
|
859
|
-
if (error === notFoundSentinel) {
|
|
860
|
-
return {
|
|
861
|
-
success: false,
|
|
862
|
-
error: {
|
|
863
|
-
code: "NOT_FOUND",
|
|
864
|
-
message: `Menu '${menuName}' not found${
|
|
865
|
-
options.locale ? ` in locale '${options.locale}'` : ""
|
|
866
|
-
}`,
|
|
867
|
-
},
|
|
868
|
-
};
|
|
869
|
-
}
|
|
870
|
-
if (error === ambiguousSentinel && ambiguousLocales) {
|
|
871
|
-
return ambiguousMenuLocaleError(menuName, ambiguousLocales);
|
|
872
|
-
}
|
|
873
|
-
throw error;
|
|
874
|
-
}
|
|
470
|
+
const repo = new MenuRepository(db);
|
|
471
|
+
const resolved = await resolveMenu(repo, menuName, options);
|
|
472
|
+
if (!resolved.success) return resolved;
|
|
875
473
|
|
|
876
|
-
|
|
474
|
+
const { itemCount } = await repo.setItems(resolved.menu.id, resolved.menu.locale, items);
|
|
475
|
+
return { success: true, data: { name: menuName, itemCount } };
|
|
877
476
|
} catch (error) {
|
|
477
|
+
// `MenuGoneError` is thrown from inside the repository transaction
|
|
478
|
+
// when the menu was deleted concurrently between `resolveMenu` and the
|
|
479
|
+
// setItems write. Returning NOT_FOUND mirrors the original handler's
|
|
480
|
+
// in-transaction `notFoundSentinel` branch and keeps the response
|
|
481
|
+
// shape stable for REST/MCP callers.
|
|
482
|
+
if (error instanceof MenuGoneError) {
|
|
483
|
+
return {
|
|
484
|
+
success: false,
|
|
485
|
+
error: {
|
|
486
|
+
code: "NOT_FOUND",
|
|
487
|
+
message: `Menu '${menuName}' not found${
|
|
488
|
+
options.locale ? ` in locale '${options.locale}'` : ""
|
|
489
|
+
}`,
|
|
490
|
+
},
|
|
491
|
+
};
|
|
492
|
+
}
|
|
878
493
|
console.error("[emdash] handleMenuSetItems failed:", error);
|
|
879
494
|
return {
|
|
880
495
|
success: false,
|
|
@@ -891,52 +506,14 @@ export async function handleMenuItemReorder(
|
|
|
891
506
|
menuName: string,
|
|
892
507
|
items: ReorderItem[],
|
|
893
508
|
options: { locale?: string } = {},
|
|
894
|
-
): Promise<ApiResult<
|
|
509
|
+
): Promise<ApiResult<MenuItem[]>> {
|
|
895
510
|
try {
|
|
896
|
-
|
|
897
|
-
|
|
898
|
-
|
|
899
|
-
.select(["id", "locale"])
|
|
900
|
-
.where("name", "=", menuName);
|
|
901
|
-
if (options.locale !== undefined) menuQuery = menuQuery.where("locale", "=", options.locale);
|
|
902
|
-
const matches = await menuQuery.execute();
|
|
511
|
+
const repo = new MenuRepository(db);
|
|
512
|
+
const resolved = await resolveMenu(repo, menuName, options);
|
|
513
|
+
if (!resolved.success) return resolved;
|
|
903
514
|
|
|
904
|
-
|
|
905
|
-
|
|
906
|
-
success: false,
|
|
907
|
-
error: { code: "NOT_FOUND", message: "Menu not found" },
|
|
908
|
-
};
|
|
909
|
-
}
|
|
910
|
-
if (matches.length > 1) {
|
|
911
|
-
return ambiguousMenuLocaleError(
|
|
912
|
-
menuName,
|
|
913
|
-
matches.map((m) => m.locale),
|
|
914
|
-
);
|
|
915
|
-
}
|
|
916
|
-
const menu = matches[0]!;
|
|
917
|
-
|
|
918
|
-
const updatedItems = await withTransaction(db, async (trx) => {
|
|
919
|
-
for (const item of items) {
|
|
920
|
-
await trx
|
|
921
|
-
.updateTable("_emdash_menu_items")
|
|
922
|
-
.set({
|
|
923
|
-
parent_id: item.parentId,
|
|
924
|
-
sort_order: item.sortOrder,
|
|
925
|
-
})
|
|
926
|
-
.where("id", "=", item.id)
|
|
927
|
-
.where("menu_id", "=", menu.id)
|
|
928
|
-
.execute();
|
|
929
|
-
}
|
|
930
|
-
|
|
931
|
-
return trx
|
|
932
|
-
.selectFrom("_emdash_menu_items")
|
|
933
|
-
.selectAll()
|
|
934
|
-
.where("menu_id", "=", menu.id)
|
|
935
|
-
.orderBy("sort_order", "asc")
|
|
936
|
-
.execute();
|
|
937
|
-
});
|
|
938
|
-
|
|
939
|
-
return { success: true, data: updatedItems };
|
|
515
|
+
const updated = await repo.reorderItems(resolved.menu.id, items);
|
|
516
|
+
return { success: true, data: updated };
|
|
940
517
|
} catch {
|
|
941
518
|
return {
|
|
942
519
|
success: false,
|