studiocms 0.2.0 → 0.4.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/CHANGELOG.md +122 -0
- package/dist/cli/add/index.d.ts +2 -2
- package/dist/cli/add/index.js +4 -3
- package/dist/cli/add/npm-utils.d.ts +6 -6
- package/dist/cli/add/tryToInstallPlugins.d.ts +1 -1
- package/dist/cli/add/tryToInstallPlugins.js +6 -5
- package/dist/cli/add/updateStudioCMSConfig.d.ts +1 -1
- package/dist/cli/add/updateStudioCMSConfig.js +3 -4
- package/dist/cli/add/validatePlugins.d.ts +1 -2
- package/dist/cli/add/validatePlugins.js +15 -9
- package/dist/cli/crypto/genJWT/index.d.ts +1 -1
- package/dist/cli/crypto/genJWT/index.js +8 -9
- package/dist/cli/crypto/index.d.ts +1 -1
- package/dist/cli/init/steps/env.js +14 -4
- package/dist/cli/init/steps/next.d.ts +1 -1
- package/dist/cli/init/steps/next.js +6 -5
- package/dist/cli/migrator/index.d.ts +1 -1
- package/dist/cli/migrator/index.js +2 -2
- package/dist/cli/users/index.d.ts +1 -1
- package/dist/cli/users/shared.js +2 -2
- package/dist/cli/users/steps/createUsers.js +7 -7
- package/dist/cli/users/steps/modifyUsers.js +2 -2
- package/dist/cli/users/steps/next.d.ts +1 -1
- package/dist/cli/utils/checkRequiredEnvVars.js +2 -2
- package/dist/cli/utils/context.d.ts +2 -4
- package/dist/cli/utils/context.js +1 -3
- package/dist/cli/utils/getCliDbClient.d.ts +1 -1
- package/dist/cli/utils/intro.d.ts +1 -1
- package/dist/cli/utils/loadConfig.d.ts +54 -49
- package/dist/cli/utils/loadConfig.js +5 -8
- package/dist/cli/utils/logger.js +3 -3
- package/dist/cli/utils/user-utils.d.ts +1 -1
- package/dist/cli/utils/user-utils.js +4 -3
- package/dist/client/apiClient.d.ts +4923 -0
- package/dist/client/apiClient.js +72 -0
- package/dist/config.d.ts +1734 -1
- package/dist/consts.d.ts +5 -5
- package/dist/consts.js +3 -2
- package/dist/db/plugins.d.ts +1 -1
- package/dist/db/plugins.js +5 -8
- package/dist/handlers/frontend/routes.d.ts +4 -18
- package/dist/handlers/frontend/routes.js +13 -152
- package/dist/handlers/frontend/types.d.ts +1 -1
- package/dist/handlers/frontend/utils.js +0 -18
- package/dist/handlers/pluginHandler.d.ts +34 -257
- package/dist/handlers/pluginHandler.js +92 -46
- package/dist/handlers/routeHandler.js +32 -11
- package/dist/handlers/setupDbStudio.d.ts +3 -1
- package/dist/handlers/setupDbStudio.js +19 -10
- package/dist/handlers/storage-manager/core/effectify-astro-context.d.ts +25 -0
- package/dist/handlers/storage-manager/core/effectify-astro-context.js +78 -0
- package/dist/handlers/storage-manager/no-op.d.ts +2 -2
- package/dist/handlers/storage-manager/no-op.js +2 -3
- package/dist/index.d.ts +0 -1
- package/dist/index.js +10 -20
- package/dist/integrations/robots/index.d.ts +2 -2
- package/dist/integrations/robots/index.js +1 -3
- package/dist/integrations/robots/schema.d.ts +102 -273
- package/dist/integrations/robots/schema.js +220 -209
- package/dist/plugins/analytics/assets/schemas.d.ts +14 -9
- package/dist/plugins/analytics/assets/schemas.js +25 -17
- package/dist/plugins/analytics/db-client.d.ts +1 -1
- package/dist/plugins/analytics/index.d.ts +823 -3
- package/dist/plugins/analytics/index.js +4 -5
- package/dist/plugins/analytics/schemas.d.ts +54 -62
- package/dist/plugins/analytics/schemas.js +64 -13
- package/dist/plugins/analytics/table.d.ts +1 -1
- package/dist/plugins.d.ts +0 -1
- package/dist/schemas/config/api.d.ts +17 -0
- package/dist/schemas/config/api.js +14 -0
- package/dist/schemas/config/auth.d.ts +55 -59
- package/dist/schemas/config/auth.js +34 -11
- package/dist/schemas/config/dashboard.d.ts +43 -79
- package/dist/schemas/config/dashboard.js +43 -12
- package/dist/schemas/config/db.d.ts +15 -17
- package/dist/schemas/config/db.js +13 -5
- package/dist/schemas/config/developer.d.ts +33 -45
- package/dist/schemas/config/developer.js +22 -5
- package/dist/schemas/config/index.d.ts +398 -521
- package/dist/schemas/config/index.js +115 -57
- package/dist/schemas/config/sdk.d.ts +50 -196
- package/dist/schemas/config/sdk.js +61 -73
- package/dist/schemas/custom.d.ts +40 -0
- package/dist/schemas/custom.js +41 -0
- package/dist/schemas/external-schemas.d.ts +171 -0
- package/dist/schemas/external-schemas.js +179 -0
- package/dist/schemas/index.d.ts +2 -0
- package/dist/schemas/index.js +2 -0
- package/dist/schemas/plugins/i18n.d.ts +59 -39
- package/dist/schemas/plugins/i18n.js +42 -5
- package/dist/schemas/plugins/index.d.ts +7126 -10296
- package/dist/schemas/plugins/index.js +260 -276
- package/dist/schemas/plugins/shared.d.ts +1293 -3718
- package/dist/schemas/plugins/shared.js +320 -329
- package/dist/test-utils.d.ts +15 -4
- package/dist/test-utils.js +27 -11
- package/dist/toolbar/db-viewer/db-shared-types.d.ts +6 -6
- package/dist/toolbar/db-viewer/studio/connection.d.ts +8 -4
- package/dist/toolbar/db-viewer/studio/connection.js +2 -28
- package/dist/toolbar/db-viewer/studio/env/libsql.d.ts +7 -0
- package/dist/toolbar/db-viewer/studio/env/libsql.js +17 -0
- package/dist/toolbar/db-viewer/studio/env/mysql.d.ts +7 -0
- package/dist/toolbar/db-viewer/studio/env/mysql.js +23 -0
- package/dist/toolbar/db-viewer/studio/env/postgres.d.ts +7 -0
- package/dist/toolbar/db-viewer/studio/env/postgres.js +23 -0
- package/dist/toolbar/db-viewer/studio/index.js +20 -56
- package/dist/toolbar/db-viewer/studio/type.d.ts +1 -2
- package/dist/toolbar/db-viewer/studio/virtual-connection/libsql.d.ts +3 -0
- package/dist/toolbar/db-viewer/studio/virtual-connection/libsql.js +24 -0
- package/dist/toolbar/db-viewer/studio/virtual-connection/mysql.d.ts +3 -0
- package/dist/toolbar/db-viewer/studio/virtual-connection/mysql.js +9 -0
- package/dist/toolbar/db-viewer/studio/virtual-connection/postgres.d.ts +3 -0
- package/dist/toolbar/db-viewer/studio/virtual-connection/postgres.js +9 -0
- package/dist/toolbar/db-viewer/viewer.js +20 -21
- package/dist/types.d.ts +30 -0
- package/dist/utils/effects/smtp.d.ts +1 -1
- package/dist/utils/lang-helper.d.ts +10 -2
- package/dist/virtual.d.ts +35 -28
- package/dist/virtuals/auth/core.d.ts +5 -5
- package/dist/virtuals/auth/verify-email.d.ts +6 -6
- package/dist/virtuals/components/Generator.astro +2 -2
- package/dist/virtuals/components/Renderer.astro +9 -1
- package/dist/virtuals/components/renderFn.d.ts +3 -1
- package/dist/virtuals/components/renderFn.js +18 -0
- package/dist/virtuals/lib/headDefaults.d.ts +4 -2
- package/dist/virtuals/lib/headDefaults.js +0 -2
- package/dist/virtuals/lib/routeMap.d.ts +0 -12
- package/dist/virtuals/lib/routeMap.js +2 -14
- package/dist/virtuals/mailer/index.d.ts +3 -3
- package/dist/virtuals/notifier/index.d.ts +5 -5
- package/dist/virtuals/plugins/dashboard-pages.d.ts +2 -64
- package/dist/virtuals/scripts/StorageFileBrowser.d.ts +1 -172
- package/dist/virtuals/scripts/StorageFileBrowser.js +216 -119
- package/dist/virtuals/template-engine/index.d.ts +4 -4
- package/frontend/components/dashboard/configuration/ConfigForm.astro +218 -110
- package/frontend/components/dashboard/content-mgmt/ContentSearch.astro +21 -22
- package/frontend/components/dashboard/content-mgmt/CreateFolder.astro +66 -54
- package/frontend/components/dashboard/content-mgmt/CreatePage.astro +58 -104
- package/frontend/components/dashboard/content-mgmt/EditFolder.astro +65 -67
- package/frontend/components/dashboard/content-mgmt/EditPage.astro +86 -134
- package/frontend/components/dashboard/content-mgmt/InnerSidebarElement.astro +0 -1
- package/frontend/components/dashboard/content-mgmt/PageHeader.astro +33 -52
- package/frontend/components/dashboard/content-mgmt/PageTypeHandler.astro +2 -2
- package/frontend/components/dashboard/profile/APITokens.astro +219 -158
- package/frontend/components/dashboard/profile/BasicInfo.astro +165 -106
- package/frontend/components/dashboard/profile/Notifications.astro +27 -18
- package/frontend/components/dashboard/profile/UpdatePassword.astro +134 -94
- package/frontend/components/dashboard/sidebar/VersionCheck.astro +31 -16
- package/frontend/components/dashboard/sidebar/VersionCheckChangelog.astro +18 -11
- package/frontend/components/dashboard/sidebar-modals/VersionModal.astro +2 -2
- package/frontend/components/dashboard/smtp-config/TemplateEditor.astro +14 -14
- package/frontend/components/dashboard/taxonomy/InnerSidebarElement.astro +0 -1
- package/frontend/components/dashboard/taxonomy/MetaContainer.astro +0 -2
- package/frontend/components/dashboard/taxonomy/PageHeader.astro +16 -24
- package/frontend/components/dashboard/taxonomy/TaxonomySearch.astro +23 -27
- package/frontend/components/dashboard/user-mgmt/InnerSidebarElement.astro +111 -104
- package/frontend/components/dashboard/user-mgmt/UserListItem.astro +9 -22
- package/frontend/components/dashboard/user-mgmt/UserListItems.astro +18 -0
- package/frontend/components/first-time-setup/snippets/{opt2-studiocms.config.diff → studiocms.config.diff} +1 -0
- package/frontend/components/shared/Code.astro +1 -4
- package/frontend/components/shared/DynamicSettingsRenderer.astro +1 -1
- package/frontend/components/shared/SSRUser.astro +2 -4
- package/frontend/components/shared/foldertree/FolderTreeNode.astro +0 -6
- package/frontend/components/shared/storage-manager/StorageCopyOutput.astro +0 -1
- package/frontend/components/shared/taxonomy/TaxonomyTreeNode.astro +0 -6
- package/frontend/layouts/DashboardLayout.astro +1 -10
- package/frontend/layouts/TaxonomyLayout.astro +0 -1
- package/frontend/middleware/index.ts +102 -61
- package/frontend/pages/404.astro +5 -9
- package/frontend/pages/[dashboard]/[...pluginPage].astro +10 -1
- package/frontend/pages/[dashboard]/configuration.astro +10 -1
- package/frontend/pages/[dashboard]/content-management/createfolder.astro +10 -1
- package/frontend/pages/[dashboard]/content-management/createpage.astro +10 -1
- package/frontend/pages/[dashboard]/content-management/diff.astro +39 -14
- package/frontend/pages/[dashboard]/content-management/editfolder.astro +10 -1
- package/frontend/pages/[dashboard]/content-management/editpage.astro +10 -1
- package/frontend/pages/[dashboard]/content-management/index.astro +10 -1
- package/frontend/pages/[dashboard]/index.astro +10 -1
- package/frontend/pages/[dashboard]/login.astro +86 -25
- package/frontend/pages/[dashboard]/password-reset.astro +22 -16
- package/frontend/pages/[dashboard]/plugins/[plugin].astro +10 -1
- package/frontend/pages/[dashboard]/profile.astro +10 -1
- package/frontend/pages/[dashboard]/signup.astro +153 -52
- package/frontend/pages/[dashboard]/smtp-configuration.astro +77 -75
- package/frontend/pages/[dashboard]/system-management.astro +10 -1
- package/frontend/pages/[dashboard]/taxonomy/categories.astro +30 -41
- package/frontend/pages/[dashboard]/taxonomy/index.astro +10 -0
- package/frontend/pages/[dashboard]/taxonomy/tags.astro +33 -43
- package/frontend/pages/[dashboard]/unverified-email.astro +29 -21
- package/frontend/pages/[dashboard]/user-management/edit.astro +170 -90
- package/frontend/pages/[dashboard]/user-management/index.astro +10 -1
- package/frontend/pages/studiocms_api/[...all].ts +106 -0
- package/frontend/pages/studiocms_api/_handlers/_utils/auth.ts +26 -0
- package/frontend/pages/studiocms_api/_handlers/_utils/changelog.ts +147 -0
- package/frontend/pages/studiocms_api/_handlers/_utils/db-studio-driver.ts +46 -0
- package/frontend/pages/studiocms_api/_handlers/_utils/parseLogLevel.ts +27 -0
- package/frontend/pages/studiocms_api/_handlers/auth/auth.ts +459 -0
- package/frontend/pages/studiocms_api/_handlers/auth/index.ts +17 -0
- package/frontend/pages/studiocms_api/_handlers/auth/oauth.ts +91 -0
- package/frontend/pages/studiocms_api/_handlers/dashboard/_shared.ts +57 -0
- package/frontend/pages/studiocms_api/_handlers/dashboard/apiTokens.ts +134 -0
- package/frontend/pages/studiocms_api/_handlers/dashboard/config.ts +64 -0
- package/frontend/pages/studiocms_api/_handlers/dashboard/content.ts +741 -0
- package/frontend/pages/studiocms_api/_handlers/dashboard/create.ts +480 -0
- package/frontend/pages/studiocms_api/_handlers/dashboard/emailNotifications.ts +49 -0
- package/frontend/pages/studiocms_api/_handlers/dashboard/index.ts +45 -0
- package/frontend/pages/studiocms_api/_handlers/dashboard/mailer.ts +136 -0
- package/frontend/pages/studiocms_api/_handlers/dashboard/plugins.ts +80 -0
- package/frontend/pages/studiocms_api/_handlers/dashboard/profile.ts +275 -0
- package/frontend/pages/studiocms_api/_handlers/dashboard/resetPassword.ts +140 -0
- package/frontend/pages/studiocms_api/_handlers/dashboard/search.ts +63 -0
- package/frontend/pages/studiocms_api/_handlers/dashboard/taxonomy.ts +285 -0
- package/frontend/pages/studiocms_api/_handlers/dashboard/templates.ts +75 -0
- package/frontend/pages/studiocms_api/_handlers/dashboard/users.ts +312 -0
- package/frontend/pages/studiocms_api/_handlers/dashboard/verifyEndpoints.ts +307 -0
- package/frontend/pages/studiocms_api/_handlers/integration/dbStudio.ts +98 -0
- package/frontend/pages/studiocms_api/_handlers/integration/index.ts +17 -0
- package/frontend/pages/studiocms_api/_handlers/integration/storageManager.ts +107 -0
- package/frontend/pages/studiocms_api/_handlers/rest-api/index.ts +8 -0
- package/frontend/pages/studiocms_api/_handlers/rest-api/v1/_shared.ts +41 -0
- package/frontend/pages/studiocms_api/_handlers/rest-api/v1/index.ts +17 -0
- package/frontend/pages/studiocms_api/_handlers/rest-api/v1/public.ts +195 -0
- package/frontend/pages/studiocms_api/_handlers/rest-api/v1/secure.ts +1726 -0
- package/frontend/pages/studiocms_api/_handlers/sdk.ts +129 -0
- package/frontend/pages/studiocms_api/_middleware/astroLocals.ts +36 -0
- package/frontend/pages/studiocms_api/_middleware/restApi.ts +56 -0
- package/frontend/pages/studiocms_api/integrations/[...all].ts +8 -0
- package/frontend/scripts/formdata.ts +219 -0
- package/frontend/setup-pages/3-done.astro +4 -20
- package/frontend/setup-pages/studiocms_api/dashboard/step-2.ts +3 -6
- package/frontend/styles/dashboard-base.css +0 -1
- package/frontend/web-vitals/endpoint.ts +2 -1
- package/package.json +35 -31
- package/dist/global.d.ts +0 -9
- package/frontend/components/dashboard/LoginChecker.astro +0 -68
- package/frontend/components/dashboard/user-mgmt/RankCheck.astro +0 -57
- package/frontend/components/first-time-setup/snippets/opt1-astro.config.diff +0 -14
- package/frontend/components/first-time-setup/snippets/opt2-astro.config.diff +0 -9
- package/frontend/middleware/_authmap.ts +0 -63
- package/frontend/pages/studiocms_api/auth/[path].ts +0 -390
- package/frontend/pages/studiocms_api/auth/[provider]/[...id].ts +0 -64
- package/frontend/pages/studiocms_api/auth/[provider]/_effects/index.ts +0 -101
- package/frontend/pages/studiocms_api/auth/_shared.ts +0 -52
- package/frontend/pages/studiocms_api/dashboard/api-tokens.ts +0 -115
- package/frontend/pages/studiocms_api/dashboard/config.ts +0 -74
- package/frontend/pages/studiocms_api/dashboard/content/diff.ts +0 -73
- package/frontend/pages/studiocms_api/dashboard/content/folder.ts +0 -220
- package/frontend/pages/studiocms_api/dashboard/content/page.ts +0 -359
- package/frontend/pages/studiocms_api/dashboard/create-reset-link.ts +0 -77
- package/frontend/pages/studiocms_api/dashboard/create-user-invite.ts +0 -231
- package/frontend/pages/studiocms_api/dashboard/create-user.ts +0 -186
- package/frontend/pages/studiocms_api/dashboard/email-notification-settings-site.ts +0 -74
- package/frontend/pages/studiocms_api/dashboard/mailer/check-email.ts +0 -75
- package/frontend/pages/studiocms_api/dashboard/mailer/config.ts +0 -136
- package/frontend/pages/studiocms_api/dashboard/plugins/[plugin].ts +0 -80
- package/frontend/pages/studiocms_api/dashboard/profile.ts +0 -245
- package/frontend/pages/studiocms_api/dashboard/resend-verify-email.ts +0 -77
- package/frontend/pages/studiocms_api/dashboard/reset-password.ts +0 -124
- package/frontend/pages/studiocms_api/dashboard/search-list.ts +0 -59
- package/frontend/pages/studiocms_api/dashboard/taxonomy-search.ts +0 -47
- package/frontend/pages/studiocms_api/dashboard/taxonomy.ts +0 -230
- package/frontend/pages/studiocms_api/dashboard/templates.ts +0 -74
- package/frontend/pages/studiocms_api/dashboard/update-user-notifications.ts +0 -86
- package/frontend/pages/studiocms_api/dashboard/users.ts +0 -236
- package/frontend/pages/studiocms_api/dashboard/verify-email.ts +0 -83
- package/frontend/pages/studiocms_api/dashboard/verify-session.ts +0 -187
- package/frontend/pages/studiocms_api/integrations/[type]/[...id].ts +0 -15
- package/frontend/pages/studiocms_api/integrations/[type]/_routes/db-studio.ts +0 -173
- package/frontend/pages/studiocms_api/integrations/[type]/_routes/storage.ts +0 -88
- package/frontend/pages/studiocms_api/partials/editor.astro +0 -74
- package/frontend/pages/studiocms_api/partials/render.astro +0 -39
- package/frontend/pages/studiocms_api/partials/user-list-items.astro +0 -43
- package/frontend/pages/studiocms_api/rest/utils/auth-token.ts +0 -59
- package/frontend/pages/studiocms_api/rest/v1/[type]/[...id].ts +0 -23
- package/frontend/pages/studiocms_api/rest/v1/[type]/_routes/categories.ts +0 -267
- package/frontend/pages/studiocms_api/rest/v1/[type]/_routes/folders.ts +0 -283
- package/frontend/pages/studiocms_api/rest/v1/[type]/_routes/pages.ts +0 -505
- package/frontend/pages/studiocms_api/rest/v1/[type]/_routes/settings.ts +0 -100
- package/frontend/pages/studiocms_api/rest/v1/[type]/_routes/tags.ts +0 -229
- package/frontend/pages/studiocms_api/rest/v1/[type]/_routes/users.ts +0 -553
- package/frontend/pages/studiocms_api/rest/v1/public/[type]/[...id].ts +0 -19
- package/frontend/pages/studiocms_api/rest/v1/public/[type]/_routes/categories.ts +0 -74
- package/frontend/pages/studiocms_api/rest/v1/public/[type]/_routes/folders.ts +0 -85
- package/frontend/pages/studiocms_api/rest/v1/public/[type]/_routes/pages.ts +0 -103
- package/frontend/pages/studiocms_api/rest/v1/public/[type]/_routes/tags.ts +0 -67
- package/frontend/pages/studiocms_api/sdk/[...path].ts +0 -97
- package/frontend/pages/studiocms_api/sdk/utils/changelog.ts +0 -119
- package/frontend/scripts/auth/formListener.ts +0 -81
- package/frontend/scripts/formdata-utils.ts +0 -116
- package/frontend/utils/build-partial-schema.ts +0 -46
- package/frontend/utils/errors.ts +0 -6
- package/frontend/utils/param-extractor.ts +0 -83
- package/frontend/utils/rest-router.ts +0 -444
|
@@ -0,0 +1,195 @@
|
|
|
1
|
+
import { SDKCore } from 'studiocms:sdk';
|
|
2
|
+
import routeConfig from 'virtual:studiocms/route-config';
|
|
3
|
+
import { HttpApiBuilder } from '@effect/platform';
|
|
4
|
+
import { StudioCMSRestApiV1Spec } from '@withstudiocms/api-spec';
|
|
5
|
+
import { RestAPIError } from '@withstudiocms/api-spec/rest-api';
|
|
6
|
+
import { Effect } from 'effect';
|
|
7
|
+
import { sharedDBErrors, sharedPageCollectionErrors } from './_shared.js';
|
|
8
|
+
|
|
9
|
+
const restAPIEnabled = routeConfig.restAPIEnabled;
|
|
10
|
+
|
|
11
|
+
/**
|
|
12
|
+
* Helper function to convert undefined values into a failed Effect with a RestAPIError. This is useful for handling cases where a resource is not found, allowing us to return a consistent error response.
|
|
13
|
+
*
|
|
14
|
+
* @param error The error message to use if the value is undefined.
|
|
15
|
+
* @returns An Effect that fails with a RestAPIError if the value is undefined, or succeeds with the value otherwise.
|
|
16
|
+
*/
|
|
17
|
+
const undefinedMeansFail =
|
|
18
|
+
(error: string) =>
|
|
19
|
+
<T>(val: T | undefined): Effect.Effect<T, RestAPIError, never> =>
|
|
20
|
+
val === undefined ? Effect.fail(new RestAPIError({ error })) : Effect.succeed(val);
|
|
21
|
+
|
|
22
|
+
/**
|
|
23
|
+
* Helper function to convert values with a `draft` property into a failed Effect with a RestAPIError if the `draft` property is true. This is useful for handling cases where a resource is in draft state and should not be accessible through the public API, allowing us to return a consistent error response.
|
|
24
|
+
*
|
|
25
|
+
* @param error The error message to use if the value is a draft.
|
|
26
|
+
* @returns An Effect that fails with a RestAPIError if the value has a `draft` property that is true, or succeeds with the value otherwise.
|
|
27
|
+
*/
|
|
28
|
+
const draftMeansFail =
|
|
29
|
+
(error: string) =>
|
|
30
|
+
<T extends { draft?: boolean }>(val: T): Effect.Effect<T, RestAPIError, never> =>
|
|
31
|
+
val.draft ? Effect.fail(new RestAPIError({ error })) : Effect.succeed(val);
|
|
32
|
+
|
|
33
|
+
/**
|
|
34
|
+
* REST API v1 Public Handler
|
|
35
|
+
*/
|
|
36
|
+
export const RestApiPublicHandler = HttpApiBuilder.group(
|
|
37
|
+
StudioCMSRestApiV1Spec,
|
|
38
|
+
'restV1Public',
|
|
39
|
+
(handlers) =>
|
|
40
|
+
handlers
|
|
41
|
+
.handle(
|
|
42
|
+
'getCategory',
|
|
43
|
+
Effect.fn(({ path: { id } }) => {
|
|
44
|
+
if (!restAPIEnabled) {
|
|
45
|
+
return Effect.fail(new RestAPIError({ error: 'Endpoint not found' }));
|
|
46
|
+
}
|
|
47
|
+
return SDKCore.pipe(
|
|
48
|
+
Effect.flatMap((sdk) => sdk.GET.categories.byId(id)),
|
|
49
|
+
Effect.flatMap(undefinedMeansFail('Category not found')),
|
|
50
|
+
Effect.catchTags(sharedDBErrors)
|
|
51
|
+
);
|
|
52
|
+
})
|
|
53
|
+
)
|
|
54
|
+
.handle(
|
|
55
|
+
'getCategories',
|
|
56
|
+
Effect.fn(({ urlParams: { name, parent } }) => {
|
|
57
|
+
if (!restAPIEnabled) {
|
|
58
|
+
return Effect.fail(new RestAPIError({ error: 'Endpoint not found' }));
|
|
59
|
+
}
|
|
60
|
+
return SDKCore.pipe(
|
|
61
|
+
Effect.flatMap((sdk) => sdk.GET.categories.getAll()),
|
|
62
|
+
Effect.map((categories) => {
|
|
63
|
+
let filteredCategories = categories;
|
|
64
|
+
if (name) {
|
|
65
|
+
filteredCategories = filteredCategories.filter((category) =>
|
|
66
|
+
category.name.includes(name)
|
|
67
|
+
);
|
|
68
|
+
}
|
|
69
|
+
if (parent) {
|
|
70
|
+
filteredCategories = filteredCategories.filter(
|
|
71
|
+
(category) => category.parent === parent
|
|
72
|
+
);
|
|
73
|
+
}
|
|
74
|
+
return filteredCategories;
|
|
75
|
+
}),
|
|
76
|
+
Effect.catchTags(sharedDBErrors)
|
|
77
|
+
);
|
|
78
|
+
})
|
|
79
|
+
)
|
|
80
|
+
.handle(
|
|
81
|
+
'getFolder',
|
|
82
|
+
Effect.fn(({ path: { id } }) => {
|
|
83
|
+
if (!restAPIEnabled) {
|
|
84
|
+
return Effect.fail(new RestAPIError({ error: 'Endpoint not found' }));
|
|
85
|
+
}
|
|
86
|
+
return SDKCore.pipe(
|
|
87
|
+
Effect.flatMap((sdk) => sdk.GET.folder(id)),
|
|
88
|
+
Effect.flatMap(undefinedMeansFail('Folder not found')),
|
|
89
|
+
Effect.catchTags(sharedDBErrors)
|
|
90
|
+
);
|
|
91
|
+
})
|
|
92
|
+
)
|
|
93
|
+
.handle(
|
|
94
|
+
'getFolders',
|
|
95
|
+
Effect.fn(({ urlParams: { name, parent } }) => {
|
|
96
|
+
if (!restAPIEnabled) {
|
|
97
|
+
return Effect.fail(new RestAPIError({ error: 'Endpoint not found' }));
|
|
98
|
+
}
|
|
99
|
+
return SDKCore.pipe(
|
|
100
|
+
Effect.flatMap((sdk) => sdk.GET.folderList()),
|
|
101
|
+
Effect.map((folders) => {
|
|
102
|
+
let filteredFolders = folders;
|
|
103
|
+
if (name) {
|
|
104
|
+
filteredFolders = filteredFolders.filter((folder) => folder.name.includes(name));
|
|
105
|
+
}
|
|
106
|
+
if (parent) {
|
|
107
|
+
filteredFolders = filteredFolders.filter((folder) => folder.parent === parent);
|
|
108
|
+
}
|
|
109
|
+
return filteredFolders;
|
|
110
|
+
}),
|
|
111
|
+
Effect.catchTags(sharedDBErrors)
|
|
112
|
+
);
|
|
113
|
+
})
|
|
114
|
+
)
|
|
115
|
+
.handle(
|
|
116
|
+
'getPage',
|
|
117
|
+
Effect.fn(({ path: { id } }) => {
|
|
118
|
+
if (!restAPIEnabled) {
|
|
119
|
+
return Effect.fail(new RestAPIError({ error: 'Endpoint not found' }));
|
|
120
|
+
}
|
|
121
|
+
return SDKCore.pipe(
|
|
122
|
+
Effect.flatMap((sdk) => sdk.GET.page.byId(id)),
|
|
123
|
+
Effect.flatMap(undefinedMeansFail('Page not found')),
|
|
124
|
+
Effect.flatMap(draftMeansFail('Page not found')),
|
|
125
|
+
Effect.catchTags({
|
|
126
|
+
...sharedDBErrors,
|
|
127
|
+
...sharedPageCollectionErrors,
|
|
128
|
+
})
|
|
129
|
+
);
|
|
130
|
+
})
|
|
131
|
+
)
|
|
132
|
+
.handle(
|
|
133
|
+
'getPages',
|
|
134
|
+
Effect.fn(({ urlParams: { author, parentFolder, slug, title } }) => {
|
|
135
|
+
if (!restAPIEnabled) {
|
|
136
|
+
return Effect.fail(new RestAPIError({ error: 'Endpoint not found' }));
|
|
137
|
+
}
|
|
138
|
+
return SDKCore.pipe(
|
|
139
|
+
Effect.flatMap((sdk) => sdk.GET.pages()),
|
|
140
|
+
Effect.map((pages) => {
|
|
141
|
+
let filteredPages = pages;
|
|
142
|
+
if (title) {
|
|
143
|
+
filteredPages = filteredPages.filter((page) => page.title.includes(title));
|
|
144
|
+
}
|
|
145
|
+
if (slug) {
|
|
146
|
+
filteredPages = filteredPages.filter((page) => page.slug.includes(slug));
|
|
147
|
+
}
|
|
148
|
+
if (author) {
|
|
149
|
+
filteredPages = filteredPages.filter((page) => page.authorId === author);
|
|
150
|
+
}
|
|
151
|
+
if (parentFolder) {
|
|
152
|
+
filteredPages = filteredPages.filter((page) => page.parentFolder === parentFolder);
|
|
153
|
+
}
|
|
154
|
+
return filteredPages;
|
|
155
|
+
}),
|
|
156
|
+
Effect.catchTags({
|
|
157
|
+
...sharedDBErrors,
|
|
158
|
+
...sharedPageCollectionErrors,
|
|
159
|
+
})
|
|
160
|
+
);
|
|
161
|
+
})
|
|
162
|
+
)
|
|
163
|
+
.handle(
|
|
164
|
+
'getTag',
|
|
165
|
+
Effect.fn(({ path: { id } }) => {
|
|
166
|
+
if (!restAPIEnabled) {
|
|
167
|
+
return Effect.fail(new RestAPIError({ error: 'Endpoint not found' }));
|
|
168
|
+
}
|
|
169
|
+
return SDKCore.pipe(
|
|
170
|
+
Effect.flatMap((sdk) => sdk.GET.tags.byId(id)),
|
|
171
|
+
Effect.flatMap(undefinedMeansFail('Tag not found')),
|
|
172
|
+
Effect.catchTags(sharedDBErrors)
|
|
173
|
+
);
|
|
174
|
+
})
|
|
175
|
+
)
|
|
176
|
+
.handle(
|
|
177
|
+
'getTags',
|
|
178
|
+
Effect.fn(({ urlParams: { name } }) => {
|
|
179
|
+
if (!restAPIEnabled) {
|
|
180
|
+
return Effect.fail(new RestAPIError({ error: 'Endpoint not found' }));
|
|
181
|
+
}
|
|
182
|
+
return SDKCore.pipe(
|
|
183
|
+
Effect.flatMap((sdk) => sdk.GET.tags.getAll()),
|
|
184
|
+
Effect.map((tags) => {
|
|
185
|
+
let filteredTags = tags;
|
|
186
|
+
if (name) {
|
|
187
|
+
filteredTags = filteredTags.filter((tag) => tag.name.includes(name));
|
|
188
|
+
}
|
|
189
|
+
return filteredTags;
|
|
190
|
+
}),
|
|
191
|
+
Effect.catchTags(sharedDBErrors)
|
|
192
|
+
);
|
|
193
|
+
})
|
|
194
|
+
)
|
|
195
|
+
);
|