@aphexcms/cms-core 0.1.7 → 0.1.8
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/package.json +6 -4
- package/src/lib/api/assets.ts +75 -0
- package/src/lib/api/client.ts +150 -0
- package/src/lib/api/documents.ts +102 -0
- package/src/lib/api/index.ts +7 -0
- package/src/lib/api/organizations.ts +154 -0
- package/src/lib/api/types.ts +34 -0
- package/src/lib/auth/auth-errors.ts +23 -0
- package/src/lib/auth/auth-hooks.ts +132 -0
- package/src/lib/auth/provider.ts +25 -0
- package/{dist/client/index.js → src/lib/client/index.ts} +19 -8
- package/{dist → src/lib}/components/AdminApp.svelte +4 -5
- package/{dist → src/lib}/components/admin/DocumentEditor.svelte +7 -7
- package/{dist → src/lib}/components/admin/SchemaField.svelte +1 -1
- package/{dist → src/lib}/components/admin/fields/ArrayField.svelte +3 -3
- package/{dist → src/lib}/components/admin/fields/BooleanField.svelte +1 -1
- package/{dist → src/lib}/components/admin/fields/ImageField.svelte +40 -13
- package/{dist → src/lib}/components/admin/fields/NumberField.svelte +1 -1
- package/{dist → src/lib}/components/admin/fields/ReferenceField.svelte +2 -2
- package/{dist → src/lib}/components/admin/fields/SlugField.svelte +2 -2
- package/{dist → src/lib}/components/admin/fields/StringField.svelte +1 -1
- package/{dist → src/lib}/components/admin/fields/TextareaField.svelte +1 -1
- package/{dist/components/index.js → src/lib/components/index.ts} +5 -1
- package/{dist → src/lib}/components/layout/OrganizationSwitcher.svelte +2 -2
- package/{dist → src/lib}/components/layout/Sidebar.svelte +1 -1
- package/{dist → src/lib}/components/layout/sidebar/AppSidebar.svelte +1 -1
- package/{dist → src/lib}/components/layout/sidebar/NavUser.svelte +1 -1
- package/src/lib/config.ts +18 -0
- package/{dist/db/adapters/index.js → src/lib/db/adapters/index.ts} +0 -1
- package/{dist/db/index.js → src/lib/db/index.ts} +2 -1
- package/src/lib/db/interfaces/asset.ts +61 -0
- package/src/lib/db/interfaces/document.ts +53 -0
- package/src/lib/db/interfaces/index.ts +98 -0
- package/src/lib/db/interfaces/organization.ts +51 -0
- package/src/lib/db/interfaces/schema.ts +13 -0
- package/src/lib/db/interfaces/user.ts +16 -0
- package/src/lib/db/utils/reference-resolver.ts +119 -0
- package/src/lib/define.ts +7 -0
- package/{dist/email/index.js → src/lib/email/index.ts} +2 -1
- package/src/lib/email/interfaces/email.ts +45 -0
- package/src/lib/engine.ts +85 -0
- package/src/lib/field-validation/rule.ts +287 -0
- package/src/lib/field-validation/utils.ts +91 -0
- package/src/lib/hooks.ts +142 -0
- package/{dist/index.js → src/lib/index.ts} +2 -1
- package/{dist/is-mobile.svelte.js → src/lib/is-mobile.svelte.ts} +5 -3
- package/src/lib/routes/assets-by-id.ts +161 -0
- package/src/lib/routes/assets-cdn.ts +185 -0
- package/src/lib/routes/assets.ts +116 -0
- package/src/lib/routes/documents-by-id.ts +188 -0
- package/src/lib/routes/documents-publish.ts +211 -0
- package/src/lib/routes/documents.ts +172 -0
- package/src/lib/routes/index.ts +13 -0
- package/src/lib/routes/organizations-by-id.ts +258 -0
- package/src/lib/routes/organizations-invitations.ts +183 -0
- package/src/lib/routes/organizations-members.ts +301 -0
- package/src/lib/routes/organizations-switch.ts +74 -0
- package/src/lib/routes/organizations.ts +147 -0
- package/src/lib/routes/schemas-by-type.ts +35 -0
- package/src/lib/routes/schemas.ts +19 -0
- package/src/lib/routes-exports.ts +42 -0
- package/src/lib/schema-context.svelte.ts +24 -0
- package/src/lib/schema-utils/cleanup.ts +116 -0
- package/src/lib/schema-utils/index.ts +4 -0
- package/src/lib/schema-utils/utils.ts +47 -0
- package/src/lib/schema-utils/validator.ts +58 -0
- package/src/lib/server/index.ts +40 -0
- package/src/lib/services/asset-service.ts +256 -0
- package/src/lib/services/index.ts +6 -0
- package/src/lib/storage/adapters/index.ts +2 -0
- package/src/lib/storage/adapters/local-storage-adapter.ts +215 -0
- package/{dist/storage/index.js → src/lib/storage/index.ts} +4 -2
- package/src/lib/storage/interfaces/index.ts +2 -0
- package/src/lib/storage/interfaces/storage.ts +114 -0
- package/src/lib/storage/providers/storage.ts +83 -0
- package/src/lib/types/asset.ts +81 -0
- package/src/lib/types/auth.ts +80 -0
- package/src/lib/types/config.ts +45 -0
- package/src/lib/types/document.ts +38 -0
- package/src/lib/types/index.ts +8 -0
- package/src/lib/types/organization.ts +119 -0
- package/src/lib/types/schemas.ts +151 -0
- package/src/lib/types/sidebar.ts +37 -0
- package/src/lib/types/user.ts +17 -0
- package/src/lib/utils/content-hash.ts +75 -0
- package/src/lib/utils/image-url.ts +204 -0
- package/src/lib/utils/index.ts +12 -0
- package/src/lib/utils/slug.ts +33 -0
- package/src/lib/utils.ts +13 -0
- package/dist/api/assets.d.ts +0 -48
- package/dist/api/assets.d.ts.map +0 -1
- package/dist/api/assets.js +0 -52
- package/dist/api/client.d.ts +0 -37
- package/dist/api/client.d.ts.map +0 -1
- package/dist/api/client.js +0 -125
- package/dist/api/documents.d.ts +0 -56
- package/dist/api/documents.d.ts.map +0 -1
- package/dist/api/documents.js +0 -77
- package/dist/api/index.d.ts +0 -7
- package/dist/api/index.d.ts.map +0 -1
- package/dist/api/index.js +0 -5
- package/dist/api/organizations.d.ts +0 -101
- package/dist/api/organizations.d.ts.map +0 -1
- package/dist/api/organizations.js +0 -92
- package/dist/api/types.d.ts +0 -23
- package/dist/api/types.d.ts.map +0 -1
- package/dist/api/types.js +0 -1
- package/dist/auth/auth-errors.d.ts +0 -7
- package/dist/auth/auth-errors.d.ts.map +0 -1
- package/dist/auth/auth-errors.js +0 -13
- package/dist/auth/auth-hooks.d.ts +0 -6
- package/dist/auth/auth-hooks.d.ts.map +0 -1
- package/dist/auth/auth-hooks.js +0 -108
- package/dist/auth/provider.d.ts +0 -17
- package/dist/auth/provider.d.ts.map +0 -1
- package/dist/auth/provider.js +0 -1
- package/dist/client/index.d.ts +0 -24
- package/dist/client/index.d.ts.map +0 -1
- package/dist/components/AdminApp.svelte.d.ts +0 -24
- package/dist/components/AdminApp.svelte.d.ts.map +0 -1
- package/dist/components/admin/AdminLayout.svelte.d.ts +0 -15
- package/dist/components/admin/AdminLayout.svelte.d.ts.map +0 -1
- package/dist/components/admin/DocumentEditor.svelte.d.ts +0 -18
- package/dist/components/admin/DocumentEditor.svelte.d.ts.map +0 -1
- package/dist/components/admin/DocumentTypesList.svelte.d.ts +0 -14
- package/dist/components/admin/DocumentTypesList.svelte.d.ts.map +0 -1
- package/dist/components/admin/ObjectModal.svelte.d.ts +0 -15
- package/dist/components/admin/ObjectModal.svelte.d.ts.map +0 -1
- package/dist/components/admin/SchemaField.svelte.d.ts +0 -19
- package/dist/components/admin/SchemaField.svelte.d.ts.map +0 -1
- package/dist/components/admin/fields/ArrayField.svelte.d.ts +0 -12
- package/dist/components/admin/fields/ArrayField.svelte.d.ts.map +0 -1
- package/dist/components/admin/fields/BooleanField.svelte.d.ts +0 -13
- package/dist/components/admin/fields/BooleanField.svelte.d.ts.map +0 -1
- package/dist/components/admin/fields/ImageField.svelte.d.ts +0 -15
- package/dist/components/admin/fields/ImageField.svelte.d.ts.map +0 -1
- package/dist/components/admin/fields/NumberField.svelte.d.ts +0 -14
- package/dist/components/admin/fields/NumberField.svelte.d.ts.map +0 -1
- package/dist/components/admin/fields/ReferenceField.svelte.d.ts +0 -12
- package/dist/components/admin/fields/ReferenceField.svelte.d.ts.map +0 -1
- package/dist/components/admin/fields/SlugField.svelte.d.ts +0 -15
- package/dist/components/admin/fields/SlugField.svelte.d.ts.map +0 -1
- package/dist/components/admin/fields/StringField.svelte.d.ts +0 -14
- package/dist/components/admin/fields/StringField.svelte.d.ts.map +0 -1
- package/dist/components/admin/fields/TextareaField.svelte.d.ts +0 -14
- package/dist/components/admin/fields/TextareaField.svelte.d.ts.map +0 -1
- package/dist/components/fields/index.d.ts +0 -9
- package/dist/components/fields/index.d.ts.map +0 -1
- package/dist/components/index.d.ts +0 -7
- package/dist/components/index.d.ts.map +0 -1
- package/dist/components/layout/OrganizationSwitcher.svelte.d.ts +0 -11
- package/dist/components/layout/OrganizationSwitcher.svelte.d.ts.map +0 -1
- package/dist/components/layout/Sidebar.svelte.d.ts +0 -14
- package/dist/components/layout/Sidebar.svelte.d.ts.map +0 -1
- package/dist/components/layout/sidebar/AppSidebar.svelte.d.ts +0 -11
- package/dist/components/layout/sidebar/AppSidebar.svelte.d.ts.map +0 -1
- package/dist/components/layout/sidebar/NavMain.svelte.d.ts +0 -19
- package/dist/components/layout/sidebar/NavMain.svelte.d.ts.map +0 -1
- package/dist/components/layout/sidebar/NavSecondary.svelte.d.ts +0 -9
- package/dist/components/layout/sidebar/NavSecondary.svelte.d.ts.map +0 -1
- package/dist/components/layout/sidebar/NavUser.svelte.d.ts +0 -9
- package/dist/components/layout/sidebar/NavUser.svelte.d.ts.map +0 -1
- package/dist/config.d.ts +0 -3
- package/dist/config.d.ts.map +0 -1
- package/dist/config.js +0 -15
- package/dist/db/adapters/index.d.ts +0 -1
- package/dist/db/adapters/index.d.ts.map +0 -1
- package/dist/db/index.d.ts +0 -2
- package/dist/db/index.d.ts.map +0 -1
- package/dist/db/interfaces/asset.d.ts +0 -51
- package/dist/db/interfaces/asset.d.ts.map +0 -1
- package/dist/db/interfaces/asset.js +0 -1
- package/dist/db/interfaces/document.d.ts +0 -36
- package/dist/db/interfaces/document.d.ts.map +0 -1
- package/dist/db/interfaces/document.js +0 -1
- package/dist/db/interfaces/index.d.ts +0 -73
- package/dist/db/interfaces/index.d.ts.map +0 -1
- package/dist/db/interfaces/index.js +0 -1
- package/dist/db/interfaces/organization.d.ts +0 -27
- package/dist/db/interfaces/organization.d.ts.map +0 -1
- package/dist/db/interfaces/organization.js +0 -1
- package/dist/db/interfaces/schema.d.ts +0 -21
- package/dist/db/interfaces/schema.d.ts.map +0 -1
- package/dist/db/interfaces/schema.js +0 -1
- package/dist/db/interfaces/user.d.ts +0 -15
- package/dist/db/interfaces/user.d.ts.map +0 -1
- package/dist/db/interfaces/user.js +0 -1
- package/dist/db/utils/reference-resolver.d.ts +0 -18
- package/dist/db/utils/reference-resolver.d.ts.map +0 -1
- package/dist/db/utils/reference-resolver.js +0 -80
- package/dist/define.d.ts +0 -3
- package/dist/define.d.ts.map +0 -1
- package/dist/define.js +0 -4
- package/dist/email/index.d.ts +0 -2
- package/dist/email/index.d.ts.map +0 -1
- package/dist/email/interfaces/email.d.ts +0 -42
- package/dist/email/interfaces/email.d.ts.map +0 -1
- package/dist/email/interfaces/email.js +0 -1
- package/dist/engine.d.ts +0 -26
- package/dist/engine.d.ts.map +0 -1
- package/dist/engine.js +0 -66
- package/dist/field-validation/rule.d.ts +0 -51
- package/dist/field-validation/rule.d.ts.map +0 -1
- package/dist/field-validation/rule.js +0 -221
- package/dist/field-validation/utils.d.ts +0 -21
- package/dist/field-validation/utils.d.ts.map +0 -1
- package/dist/field-validation/utils.js +0 -66
- package/dist/hooks.d.ts +0 -23
- package/dist/hooks.d.ts.map +0 -1
- package/dist/hooks.js +0 -96
- package/dist/index.d.ts +0 -2
- package/dist/index.d.ts.map +0 -1
- package/dist/is-mobile.svelte.d.ts +0 -5
- package/dist/is-mobile.svelte.d.ts.map +0 -1
- package/dist/routes/assets-by-id.d.ts +0 -5
- package/dist/routes/assets-by-id.d.ts.map +0 -1
- package/dist/routes/assets-by-id.js +0 -138
- package/dist/routes/assets-cdn.d.ts +0 -3
- package/dist/routes/assets-cdn.d.ts.map +0 -1
- package/dist/routes/assets-cdn.js +0 -155
- package/dist/routes/assets.d.ts +0 -4
- package/dist/routes/assets.d.ts.map +0 -1
- package/dist/routes/assets.js +0 -94
- package/dist/routes/documents-by-id.d.ts +0 -5
- package/dist/routes/documents-by-id.d.ts.map +0 -1
- package/dist/routes/documents-by-id.js +0 -142
- package/dist/routes/documents-publish.d.ts +0 -4
- package/dist/routes/documents-publish.d.ts.map +0 -1
- package/dist/routes/documents-publish.js +0 -151
- package/dist/routes/documents.d.ts +0 -4
- package/dist/routes/documents.d.ts.map +0 -1
- package/dist/routes/documents.js +0 -131
- package/dist/routes/index.d.ts +0 -6
- package/dist/routes/index.d.ts.map +0 -1
- package/dist/routes/index.js +0 -10
- package/dist/routes/organizations-by-id.d.ts +0 -5
- package/dist/routes/organizations-by-id.d.ts.map +0 -1
- package/dist/routes/organizations-by-id.js +0 -187
- package/dist/routes/organizations-invitations.d.ts +0 -4
- package/dist/routes/organizations-invitations.d.ts.map +0 -1
- package/dist/routes/organizations-invitations.js +0 -125
- package/dist/routes/organizations-members.d.ts +0 -5
- package/dist/routes/organizations-members.d.ts.map +0 -1
- package/dist/routes/organizations-members.js +0 -206
- package/dist/routes/organizations-switch.d.ts +0 -3
- package/dist/routes/organizations-switch.d.ts.map +0 -1
- package/dist/routes/organizations-switch.js +0 -53
- package/dist/routes/organizations.d.ts +0 -4
- package/dist/routes/organizations.d.ts.map +0 -1
- package/dist/routes/organizations.js +0 -108
- package/dist/routes/schemas-by-type.d.ts +0 -3
- package/dist/routes/schemas-by-type.d.ts.map +0 -1
- package/dist/routes/schemas-by-type.js +0 -25
- package/dist/routes/schemas.d.ts +0 -3
- package/dist/routes/schemas.d.ts.map +0 -1
- package/dist/routes/schemas.js +0 -11
- package/dist/routes-exports.d.ts +0 -14
- package/dist/routes-exports.d.ts.map +0 -1
- package/dist/routes-exports.js +0 -19
- package/dist/schema-context.svelte.d.ts +0 -10
- package/dist/schema-context.svelte.d.ts.map +0 -1
- package/dist/schema-context.svelte.js +0 -18
- package/dist/schema-utils/cleanup.d.ts +0 -21
- package/dist/schema-utils/cleanup.d.ts.map +0 -1
- package/dist/schema-utils/cleanup.js +0 -80
- package/dist/schema-utils/index.d.ts +0 -4
- package/dist/schema-utils/index.d.ts.map +0 -1
- package/dist/schema-utils/index.js +0 -4
- package/dist/schema-utils/utils.d.ts +0 -30
- package/dist/schema-utils/utils.d.ts.map +0 -1
- package/dist/schema-utils/utils.js +0 -37
- package/dist/schema-utils/validator.d.ts +0 -6
- package/dist/schema-utils/validator.d.ts.map +0 -1
- package/dist/schema-utils/validator.js +0 -45
- package/dist/server/index.d.ts +0 -16
- package/dist/server/index.d.ts.map +0 -1
- package/dist/server/index.js +0 -28
- package/dist/services/asset-service.d.ts +0 -86
- package/dist/services/asset-service.d.ts.map +0 -1
- package/dist/services/asset-service.js +0 -187
- package/dist/services/index.d.ts +0 -3
- package/dist/services/index.d.ts.map +0 -1
- package/dist/services/index.js +0 -4
- package/dist/storage/adapters/index.d.ts +0 -2
- package/dist/storage/adapters/index.d.ts.map +0 -1
- package/dist/storage/adapters/index.js +0 -2
- package/dist/storage/adapters/local-storage-adapter.d.ts +0 -54
- package/dist/storage/adapters/local-storage-adapter.d.ts.map +0 -1
- package/dist/storage/adapters/local-storage-adapter.js +0 -187
- package/dist/storage/index.d.ts +0 -3
- package/dist/storage/index.d.ts.map +0 -1
- package/dist/storage/interfaces/index.d.ts +0 -2
- package/dist/storage/interfaces/index.d.ts.map +0 -1
- package/dist/storage/interfaces/index.js +0 -2
- package/dist/storage/interfaces/storage.d.ts +0 -91
- package/dist/storage/interfaces/storage.d.ts.map +0 -1
- package/dist/storage/interfaces/storage.js +0 -1
- package/dist/storage/providers/storage.d.ts +0 -43
- package/dist/storage/providers/storage.d.ts.map +0 -1
- package/dist/storage/providers/storage.js +0 -64
- package/dist/types/asset.d.ts +0 -73
- package/dist/types/asset.d.ts.map +0 -1
- package/dist/types/asset.js +0 -2
- package/dist/types/auth.d.ts +0 -50
- package/dist/types/auth.d.ts.map +0 -1
- package/dist/types/auth.js +0 -41
- package/dist/types/config.d.ts +0 -47
- package/dist/types/config.d.ts.map +0 -1
- package/dist/types/config.js +0 -1
- package/dist/types/document.d.ts +0 -34
- package/dist/types/document.d.ts.map +0 -1
- package/dist/types/document.js +0 -1
- package/dist/types/index.d.ts +0 -9
- package/dist/types/index.d.ts.map +0 -1
- package/dist/types/index.js +0 -8
- package/dist/types/organization.d.ts +0 -105
- package/dist/types/organization.d.ts.map +0 -1
- package/dist/types/organization.js +0 -3
- package/dist/types/schemas.d.ts +0 -114
- package/dist/types/schemas.d.ts.map +0 -1
- package/dist/types/schemas.js +0 -1
- package/dist/types/sidebar.d.ts +0 -33
- package/dist/types/sidebar.d.ts.map +0 -1
- package/dist/types/sidebar.js +0 -1
- package/dist/types/user.d.ts +0 -14
- package/dist/types/user.d.ts.map +0 -1
- package/dist/types/user.js +0 -1
- package/dist/utils/content-hash.d.ts +0 -22
- package/dist/utils/content-hash.d.ts.map +0 -1
- package/dist/utils/content-hash.js +0 -67
- package/dist/utils/image-url.d.ts +0 -88
- package/dist/utils/image-url.d.ts.map +0 -1
- package/dist/utils/image-url.js +0 -165
- package/dist/utils/index.d.ts +0 -6
- package/dist/utils/index.d.ts.map +0 -1
- package/dist/utils/index.js +0 -9
- package/dist/utils/slug.d.ts +0 -13
- package/dist/utils/slug.d.ts.map +0 -1
- package/dist/utils/slug.js +0 -30
- package/dist/utils.d.ts +0 -13
- package/dist/utils.d.ts.map +0 -1
- package/dist/utils.js +0 -5
- /package/{dist → src/lib}/app.d.ts +0 -0
- /package/{dist → src/lib}/auth/MULTI_TENANCY_PLAN.md +0 -0
- /package/{dist → src/lib}/components/admin/AdminLayout.svelte +0 -0
- /package/{dist → src/lib}/components/admin/DocumentTypesList.svelte +0 -0
- /package/{dist → src/lib}/components/admin/ObjectModal.svelte +0 -0
- /package/{dist/components/fields/index.js → src/lib/components/fields/index.ts} +0 -0
- /package/{dist → src/lib}/components/layout/sidebar/NavMain.svelte +0 -0
- /package/{dist → src/lib}/components/layout/sidebar/NavSecondary.svelte +0 -0
- /package/{dist → src/lib}/plugins/README.md +0 -0
|
@@ -1,155 +0,0 @@
|
|
|
1
|
-
export const GET = async ({ params, locals, setHeaders, request }) => {
|
|
2
|
-
console.log('[Asset CDN] ========== ROUTE HIT ==========');
|
|
3
|
-
console.log('[Asset CDN] Params:', params);
|
|
4
|
-
try {
|
|
5
|
-
const { assetService, databaseAdapter, storageAdapter, cmsEngine, config } = locals.aphexCMS;
|
|
6
|
-
let auth = locals.auth;
|
|
7
|
-
const { id, filename } = params;
|
|
8
|
-
console.log('[Asset CDN] Request for asset:', id, filename);
|
|
9
|
-
console.log('[Asset CDN] Has auth?', !!auth);
|
|
10
|
-
// If no session auth, check for API key in headers
|
|
11
|
-
if (!auth) {
|
|
12
|
-
const apiKey = request.headers.get('x-api-key');
|
|
13
|
-
console.log('[Asset CDN] API key present?', !!apiKey);
|
|
14
|
-
if (apiKey && config.auth?.provider) {
|
|
15
|
-
try {
|
|
16
|
-
const apiKeyAuth = await config.auth.provider.validateApiKey(request, databaseAdapter);
|
|
17
|
-
if (apiKeyAuth) {
|
|
18
|
-
auth = apiKeyAuth;
|
|
19
|
-
console.log('[Asset CDN] Authenticated via API key, org:', apiKeyAuth.organizationId);
|
|
20
|
-
}
|
|
21
|
-
}
|
|
22
|
-
catch (err) {
|
|
23
|
-
console.warn('[Asset CDN] API key validation failed:', err);
|
|
24
|
-
}
|
|
25
|
-
}
|
|
26
|
-
}
|
|
27
|
-
console.log('[Asset CDN] Auth type:', auth?.type);
|
|
28
|
-
if (!id) {
|
|
29
|
-
return new Response('Asset ID is required', { status: 400 });
|
|
30
|
-
}
|
|
31
|
-
// Try to fetch asset globally first (bypasses RLS for public assets)
|
|
32
|
-
const asset = await assetService.findAssetByIdGlobal(id);
|
|
33
|
-
console.log('[Asset CDN] Asset found globally?', !!asset);
|
|
34
|
-
if (!asset) {
|
|
35
|
-
console.warn('[Asset CDN] Asset not found:', id);
|
|
36
|
-
return new Response('Asset not found', { status: 404 });
|
|
37
|
-
}
|
|
38
|
-
const organizationId = auth?.organizationId;
|
|
39
|
-
console.log('[Asset CDN] Auth object:', JSON.stringify(auth, null, 2));
|
|
40
|
-
console.log('[Asset CDN] Auth organizationId:', organizationId);
|
|
41
|
-
console.log('[Asset CDN] Asset organizationId:', asset.organizationId);
|
|
42
|
-
// Check if this asset is used in a private field
|
|
43
|
-
// The field metadata (schemaType and fieldPath) is stored when the asset is uploaded
|
|
44
|
-
let isPrivate = false;
|
|
45
|
-
const schemaType = asset.metadata?.schemaType;
|
|
46
|
-
const fieldPath = asset.metadata?.fieldPath;
|
|
47
|
-
if (schemaType && fieldPath) {
|
|
48
|
-
// Get the schema definition from IN-MEMORY config (always up-to-date with code changes)
|
|
49
|
-
const schema = cmsEngine.getSchemaTypeByName(schemaType);
|
|
50
|
-
console.log(`[Asset CDN] Schema lookup for ${schemaType}:`, {
|
|
51
|
-
found: !!schema,
|
|
52
|
-
fieldCount: schema?.fields?.length
|
|
53
|
-
});
|
|
54
|
-
if (schema && schema.fields) {
|
|
55
|
-
// Navigate the field path to find the field definition
|
|
56
|
-
const findField = (fields, path) => {
|
|
57
|
-
const parts = path.split('.');
|
|
58
|
-
let current = null;
|
|
59
|
-
for (let i = 0; i < parts.length; i++) {
|
|
60
|
-
const part = parts[i];
|
|
61
|
-
current = fields.find((f) => f.name === part);
|
|
62
|
-
if (!current)
|
|
63
|
-
return null;
|
|
64
|
-
// If not the last part, navigate into nested fields
|
|
65
|
-
if (i < parts.length - 1) {
|
|
66
|
-
if (current.type === 'object' && current.fields) {
|
|
67
|
-
fields = current.fields;
|
|
68
|
-
}
|
|
69
|
-
else {
|
|
70
|
-
return null;
|
|
71
|
-
}
|
|
72
|
-
}
|
|
73
|
-
}
|
|
74
|
-
return current;
|
|
75
|
-
};
|
|
76
|
-
const field = findField(schema.fields, fieldPath);
|
|
77
|
-
console.log(`[Asset CDN] Field lookup for ${fieldPath}:`, {
|
|
78
|
-
found: !!field,
|
|
79
|
-
type: field?.type,
|
|
80
|
-
private: field?.private
|
|
81
|
-
});
|
|
82
|
-
if (field && field.type === 'image') {
|
|
83
|
-
isPrivate = field.private === true;
|
|
84
|
-
console.log(`[Asset CDN] Field check: ${schemaType}.${fieldPath} - private: ${isPrivate}`);
|
|
85
|
-
}
|
|
86
|
-
else {
|
|
87
|
-
console.warn(`[Asset CDN] Could not find field: ${schemaType}.${fieldPath}`);
|
|
88
|
-
}
|
|
89
|
-
}
|
|
90
|
-
}
|
|
91
|
-
else {
|
|
92
|
-
console.log('[Asset CDN] No field metadata - treating as public');
|
|
93
|
-
}
|
|
94
|
-
console.log('[Asset CDN] Asset privacy result:', { isPrivate, schemaType, fieldPath });
|
|
95
|
-
// If asset is private, require auth
|
|
96
|
-
if (isPrivate && !organizationId) {
|
|
97
|
-
console.warn('[Asset CDN] Private asset accessed without auth - DENIED');
|
|
98
|
-
return new Response('Unauthorized - This asset is private', { status: 401 });
|
|
99
|
-
}
|
|
100
|
-
// If asset is private, verify org matches
|
|
101
|
-
if (isPrivate && organizationId && organizationId !== asset.organizationId) {
|
|
102
|
-
console.warn('[Asset CDN] Org mismatch for private asset - FORBIDDEN');
|
|
103
|
-
return new Response('Forbidden', { status: 403 });
|
|
104
|
-
}
|
|
105
|
-
// Log the decision
|
|
106
|
-
if (isPrivate && organizationId) {
|
|
107
|
-
console.log('[Asset CDN] Private asset access ALLOWED - user has auth and org matches');
|
|
108
|
-
}
|
|
109
|
-
else if (!isPrivate) {
|
|
110
|
-
console.log('[Asset CDN] Public asset access ALLOWED');
|
|
111
|
-
}
|
|
112
|
-
console.log('[Asset CDN] Asset found:', {
|
|
113
|
-
id: asset.id,
|
|
114
|
-
path: asset.path,
|
|
115
|
-
mimeType: asset.mimeType,
|
|
116
|
-
storageAdapter: asset.storageAdapter
|
|
117
|
-
});
|
|
118
|
-
// If asset has a direct URL (S3/R2), redirect to it
|
|
119
|
-
if (asset.url && asset.url.startsWith('http')) {
|
|
120
|
-
console.log('[Asset CDN] Redirecting to external URL:', asset.url);
|
|
121
|
-
return new Response(null, {
|
|
122
|
-
status: 302,
|
|
123
|
-
headers: { Location: asset.url }
|
|
124
|
-
});
|
|
125
|
-
}
|
|
126
|
-
// Otherwise, serve from local storage
|
|
127
|
-
if (!storageAdapter?.getObject) {
|
|
128
|
-
console.error('[Asset CDN] Storage adapter does not support getObject');
|
|
129
|
-
return new Response('Storage adapter does not support file serving', { status: 500 });
|
|
130
|
-
}
|
|
131
|
-
console.log('[Asset CDN] Reading file from storage:', asset.path);
|
|
132
|
-
const fileBuffer = await storageAdapter.getObject(asset.path);
|
|
133
|
-
console.log('[Asset CDN] Serving file:', {
|
|
134
|
-
size: fileBuffer.length,
|
|
135
|
-
mimeType: asset.mimeType
|
|
136
|
-
});
|
|
137
|
-
// Set appropriate headers for the asset
|
|
138
|
-
setHeaders({
|
|
139
|
-
'Content-Type': asset.mimeType || 'application/octet-stream',
|
|
140
|
-
'Content-Length': fileBuffer.length.toString(),
|
|
141
|
-
'Cache-Control': 'public, max-age=31536000, immutable', // Cache for 1 year
|
|
142
|
-
'Content-Disposition': `inline; filename="${encodeURIComponent(asset.originalFilename || asset.filename)}"`,
|
|
143
|
-
...(asset.mimeType?.startsWith('image/') && {
|
|
144
|
-
'Accept-Ranges': 'bytes'
|
|
145
|
-
})
|
|
146
|
-
});
|
|
147
|
-
// Convert Buffer to ArrayBuffer for Response
|
|
148
|
-
const arrayBuffer = fileBuffer.buffer.slice(fileBuffer.byteOffset, fileBuffer.byteOffset + fileBuffer.byteLength);
|
|
149
|
-
return new Response(arrayBuffer);
|
|
150
|
-
}
|
|
151
|
-
catch (error) {
|
|
152
|
-
console.error('[Asset CDN] Error serving asset:', error);
|
|
153
|
-
return new Response('Failed to serve asset', { status: 500 });
|
|
154
|
-
}
|
|
155
|
-
};
|
package/dist/routes/assets.d.ts
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"assets.d.ts","sourceRoot":"","sources":["../../src/lib/routes/assets.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,eAAe,CAAC;AAEpD,eAAO,MAAM,IAAI,EAAE,cAiElB,CAAC;AAEF,eAAO,MAAM,GAAG,EAAE,cA4CjB,CAAC"}
|
package/dist/routes/assets.js
DELETED
|
@@ -1,94 +0,0 @@
|
|
|
1
|
-
// Aphex CMS Asset API Handlers
|
|
2
|
-
import { json } from '@sveltejs/kit';
|
|
3
|
-
export const POST = async ({ request, locals }) => {
|
|
4
|
-
try {
|
|
5
|
-
const { assetService } = locals.aphexCMS;
|
|
6
|
-
const auth = locals.auth;
|
|
7
|
-
if (!auth) {
|
|
8
|
-
return json({ success: false, error: 'Unauthorized' }, { status: 401 });
|
|
9
|
-
}
|
|
10
|
-
const formData = await request.formData();
|
|
11
|
-
const file = formData.get('file');
|
|
12
|
-
if (!file) {
|
|
13
|
-
return json({ success: false, error: 'No file provided' }, { status: 400 });
|
|
14
|
-
}
|
|
15
|
-
// Convert file to buffer
|
|
16
|
-
const arrayBuffer = await file.arrayBuffer();
|
|
17
|
-
const buffer = Buffer.from(arrayBuffer);
|
|
18
|
-
// Get optional metadata from form data
|
|
19
|
-
const title = formData.get('title') || undefined;
|
|
20
|
-
const description = formData.get('description') || undefined;
|
|
21
|
-
const alt = formData.get('alt') || undefined;
|
|
22
|
-
const creditLine = formData.get('creditLine') || undefined;
|
|
23
|
-
// Get field metadata for privacy checking
|
|
24
|
-
const schemaType = formData.get('schemaType') || undefined;
|
|
25
|
-
const fieldPath = formData.get('fieldPath') || undefined;
|
|
26
|
-
// Create asset upload data
|
|
27
|
-
const uploadData = {
|
|
28
|
-
buffer,
|
|
29
|
-
originalFilename: file.name,
|
|
30
|
-
mimeType: file.type,
|
|
31
|
-
size: file.size,
|
|
32
|
-
title,
|
|
33
|
-
description,
|
|
34
|
-
alt,
|
|
35
|
-
creditLine,
|
|
36
|
-
createdBy: auth.type === 'session' ? auth.user.id : undefined,
|
|
37
|
-
metadata: {
|
|
38
|
-
schemaType,
|
|
39
|
-
fieldPath
|
|
40
|
-
}
|
|
41
|
-
};
|
|
42
|
-
// Upload asset using the service
|
|
43
|
-
const asset = await assetService.uploadAsset(auth.organizationId, uploadData);
|
|
44
|
-
return json({
|
|
45
|
-
success: true,
|
|
46
|
-
data: asset
|
|
47
|
-
});
|
|
48
|
-
}
|
|
49
|
-
catch (error) {
|
|
50
|
-
console.error('Asset upload failed:', error);
|
|
51
|
-
return json({
|
|
52
|
-
success: false,
|
|
53
|
-
error: 'Asset upload failed',
|
|
54
|
-
message: error instanceof Error ? error.message : 'Unknown error'
|
|
55
|
-
}, { status: 500 });
|
|
56
|
-
}
|
|
57
|
-
};
|
|
58
|
-
export const GET = async ({ url, locals }) => {
|
|
59
|
-
try {
|
|
60
|
-
const { assetService } = locals.aphexCMS;
|
|
61
|
-
const auth = locals.auth;
|
|
62
|
-
if (!auth) {
|
|
63
|
-
return json({ success: false, error: 'Unauthorized' }, { status: 401 });
|
|
64
|
-
}
|
|
65
|
-
// Parse query parameters
|
|
66
|
-
const assetType = url.searchParams.get('assetType');
|
|
67
|
-
const mimeType = url.searchParams.get('mimeType') || undefined;
|
|
68
|
-
const search = url.searchParams.get('search') || undefined;
|
|
69
|
-
const limitParam = url.searchParams.get('limit');
|
|
70
|
-
const offsetParam = url.searchParams.get('offset');
|
|
71
|
-
const limit = limitParam ? parseInt(limitParam) : 20;
|
|
72
|
-
const offset = offsetParam ? parseInt(offsetParam) : 0;
|
|
73
|
-
const filters = {
|
|
74
|
-
assetType,
|
|
75
|
-
mimeType,
|
|
76
|
-
search,
|
|
77
|
-
limit: isNaN(limit) ? 20 : limit,
|
|
78
|
-
offset: isNaN(offset) ? 0 : offset
|
|
79
|
-
};
|
|
80
|
-
const assets = await assetService.findAssets(auth.organizationId, filters);
|
|
81
|
-
return json({
|
|
82
|
-
success: true,
|
|
83
|
-
data: assets
|
|
84
|
-
});
|
|
85
|
-
}
|
|
86
|
-
catch (error) {
|
|
87
|
-
console.error('Failed to fetch assets:', error);
|
|
88
|
-
return json({
|
|
89
|
-
success: false,
|
|
90
|
-
error: 'Failed to fetch assets',
|
|
91
|
-
message: error instanceof Error ? error.message : 'Unknown error'
|
|
92
|
-
}, { status: 500 });
|
|
93
|
-
}
|
|
94
|
-
};
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"documents-by-id.d.ts","sourceRoot":"","sources":["../../src/lib/routes/documents-by-id.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,eAAe,CAAC;AAKpD,eAAO,MAAM,GAAG,EAAE,cA2DjB,CAAC;AAGF,eAAO,MAAM,GAAG,EAAE,cAoEjB,CAAC;AAGF,eAAO,MAAM,MAAM,EAAE,cA+CpB,CAAC"}
|
|
@@ -1,142 +0,0 @@
|
|
|
1
|
-
// Aphex CMS Document by ID API Handlers
|
|
2
|
-
import { json } from '@sveltejs/kit';
|
|
3
|
-
import { canWrite } from '../types/auth.js';
|
|
4
|
-
// GET /api/documents/[id] - Get document by ID
|
|
5
|
-
export const GET = async ({ params, url, locals }) => {
|
|
6
|
-
try {
|
|
7
|
-
const { databaseAdapter, auth: authProvider } = locals.aphexCMS;
|
|
8
|
-
const auth = locals.auth;
|
|
9
|
-
const { id } = params;
|
|
10
|
-
if (!auth) {
|
|
11
|
-
return json({ success: false, error: 'Unauthorized' }, { status: 401 });
|
|
12
|
-
}
|
|
13
|
-
if (!id) {
|
|
14
|
-
return json({ success: false, error: 'Document ID is required' }, { status: 400 });
|
|
15
|
-
}
|
|
16
|
-
// Parse depth parameter
|
|
17
|
-
const depthParam = url.searchParams.get('depth');
|
|
18
|
-
const depth = depthParam ? parseInt(depthParam) : 0;
|
|
19
|
-
const clampedDepth = isNaN(depth) ? 0 : Math.max(0, Math.min(depth, 5)); // Clamp between 0-5
|
|
20
|
-
const document = await databaseAdapter.findByDocId(auth.organizationId, id, clampedDepth);
|
|
21
|
-
if (!document) {
|
|
22
|
-
return json({ success: false, error: 'Document not found' }, { status: 404 });
|
|
23
|
-
}
|
|
24
|
-
// Populate createdBy user info if available
|
|
25
|
-
if (document.createdBy && authProvider) {
|
|
26
|
-
try {
|
|
27
|
-
if (typeof document.createdBy === 'string') {
|
|
28
|
-
const user = await authProvider.getUserById(document.createdBy);
|
|
29
|
-
if (user) {
|
|
30
|
-
document.createdBy = {
|
|
31
|
-
id: user.id,
|
|
32
|
-
name: user.name,
|
|
33
|
-
email: user.email
|
|
34
|
-
};
|
|
35
|
-
}
|
|
36
|
-
}
|
|
37
|
-
}
|
|
38
|
-
catch (err) {
|
|
39
|
-
// If user fetch fails, keep the user ID
|
|
40
|
-
console.warn('[documents-by-id] Failed to populate createdBy user:', err);
|
|
41
|
-
}
|
|
42
|
-
}
|
|
43
|
-
return json({
|
|
44
|
-
success: true,
|
|
45
|
-
data: document
|
|
46
|
-
});
|
|
47
|
-
}
|
|
48
|
-
catch (error) {
|
|
49
|
-
console.error('Failed to fetch document:', error);
|
|
50
|
-
return json({
|
|
51
|
-
success: false,
|
|
52
|
-
error: 'Failed to fetch document',
|
|
53
|
-
message: error instanceof Error ? error.message : 'Unknown error'
|
|
54
|
-
}, { status: 500 });
|
|
55
|
-
}
|
|
56
|
-
};
|
|
57
|
-
// PUT /api/documents/[id] - Update document
|
|
58
|
-
export const PUT = async ({ params, request, locals }) => {
|
|
59
|
-
try {
|
|
60
|
-
const { databaseAdapter } = locals.aphexCMS;
|
|
61
|
-
const auth = locals.auth;
|
|
62
|
-
const { id } = params;
|
|
63
|
-
const body = await request.json();
|
|
64
|
-
if (!auth) {
|
|
65
|
-
return json({ success: false, error: 'Unauthorized' }, { status: 401 });
|
|
66
|
-
}
|
|
67
|
-
// Check write permissions (viewers are read-only)
|
|
68
|
-
if (!canWrite(auth)) {
|
|
69
|
-
return json({
|
|
70
|
-
success: false,
|
|
71
|
-
error: 'Forbidden',
|
|
72
|
-
message: 'You do not have permission to update documents. Viewers have read-only access.'
|
|
73
|
-
}, { status: 403 });
|
|
74
|
-
}
|
|
75
|
-
const documentData = body.draftData;
|
|
76
|
-
if (!id) {
|
|
77
|
-
return json({ success: false, error: 'Document ID is required' }, { status: 400 });
|
|
78
|
-
}
|
|
79
|
-
let updatedDocument;
|
|
80
|
-
// NO VALIDATION FOR DRAFTS - Sanity-style: drafts can have any state
|
|
81
|
-
// Validation only happens on publish
|
|
82
|
-
if (auth.type == 'session') {
|
|
83
|
-
updatedDocument = await databaseAdapter.updateDocDraft(auth.organizationId, id, documentData, auth.user.id);
|
|
84
|
-
}
|
|
85
|
-
else {
|
|
86
|
-
updatedDocument = await databaseAdapter.updateDocDraft(auth.organizationId, id, documentData, auth.keyId);
|
|
87
|
-
}
|
|
88
|
-
if (!updatedDocument) {
|
|
89
|
-
return json({ success: false, error: 'Document not found' }, { status: 404 });
|
|
90
|
-
}
|
|
91
|
-
return json({
|
|
92
|
-
success: true,
|
|
93
|
-
data: updatedDocument
|
|
94
|
-
});
|
|
95
|
-
}
|
|
96
|
-
catch (error) {
|
|
97
|
-
console.error('Failed to update document:', error);
|
|
98
|
-
return json({
|
|
99
|
-
success: false,
|
|
100
|
-
error: 'Failed to update document',
|
|
101
|
-
message: error instanceof Error ? error.message : 'Unknown error'
|
|
102
|
-
}, { status: 500 });
|
|
103
|
-
}
|
|
104
|
-
};
|
|
105
|
-
// DELETE /api/documents/[id] - Delete document
|
|
106
|
-
export const DELETE = async ({ params, locals }) => {
|
|
107
|
-
try {
|
|
108
|
-
const { databaseAdapter } = locals.aphexCMS;
|
|
109
|
-
const auth = locals.auth;
|
|
110
|
-
const { id } = params;
|
|
111
|
-
if (!auth) {
|
|
112
|
-
return json({ success: false, error: 'Unauthorized' }, { status: 401 });
|
|
113
|
-
}
|
|
114
|
-
// Check write permissions (viewers are read-only)
|
|
115
|
-
if (!canWrite(auth)) {
|
|
116
|
-
return json({
|
|
117
|
-
success: false,
|
|
118
|
-
error: 'Forbidden',
|
|
119
|
-
message: 'You do not have permission to delete documents. Viewers have read-only access.'
|
|
120
|
-
}, { status: 403 });
|
|
121
|
-
}
|
|
122
|
-
if (!id) {
|
|
123
|
-
return json({ success: false, error: 'Document ID is required' }, { status: 400 });
|
|
124
|
-
}
|
|
125
|
-
const success = await databaseAdapter.deleteDocById(auth.organizationId, id);
|
|
126
|
-
if (!success) {
|
|
127
|
-
return json({ success: false, error: 'Document not found' }, { status: 404 });
|
|
128
|
-
}
|
|
129
|
-
return json({
|
|
130
|
-
success: true,
|
|
131
|
-
message: 'Document deleted successfully'
|
|
132
|
-
});
|
|
133
|
-
}
|
|
134
|
-
catch (error) {
|
|
135
|
-
console.error('Failed to delete document:', error);
|
|
136
|
-
return json({
|
|
137
|
-
success: false,
|
|
138
|
-
error: 'Failed to delete document',
|
|
139
|
-
message: error instanceof Error ? error.message : 'Unknown error'
|
|
140
|
-
}, { status: 500 });
|
|
141
|
-
}
|
|
142
|
-
};
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"documents-publish.d.ts","sourceRoot":"","sources":["../../src/lib/routes/documents-publish.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,eAAe,CAAC;AAKpD,eAAO,MAAM,IAAI,EAAE,cAkIlB,CAAC;AAGF,eAAO,MAAM,MAAM,EAAE,cAsEpB,CAAC"}
|
|
@@ -1,151 +0,0 @@
|
|
|
1
|
-
// Aphex CMS Document Publish API Handlers
|
|
2
|
-
import { json } from '@sveltejs/kit';
|
|
3
|
-
import { validateField } from '../field-validation/utils.js';
|
|
4
|
-
import { canWrite } from '../types/auth.js';
|
|
5
|
-
// POST /api/documents/[id]/publish - Publish document
|
|
6
|
-
export const POST = async ({ params, locals }) => {
|
|
7
|
-
try {
|
|
8
|
-
const { databaseAdapter, cmsEngine } = locals.aphexCMS;
|
|
9
|
-
const auth = locals.auth;
|
|
10
|
-
const { id } = params;
|
|
11
|
-
if (!auth) {
|
|
12
|
-
return json({
|
|
13
|
-
success: false,
|
|
14
|
-
error: 'Unauthorized',
|
|
15
|
-
message: 'Authentication required'
|
|
16
|
-
}, { status: 401 });
|
|
17
|
-
}
|
|
18
|
-
// Check write permissions (viewers are read-only)
|
|
19
|
-
if (!canWrite(auth)) {
|
|
20
|
-
return json({
|
|
21
|
-
success: false,
|
|
22
|
-
error: 'Forbidden',
|
|
23
|
-
message: 'You do not have permission to publish documents. Viewers have read-only access.'
|
|
24
|
-
}, { status: 403 });
|
|
25
|
-
}
|
|
26
|
-
if (!id) {
|
|
27
|
-
return json({
|
|
28
|
-
success: false,
|
|
29
|
-
error: 'Missing document ID',
|
|
30
|
-
message: 'Document ID is required'
|
|
31
|
-
}, { status: 400 });
|
|
32
|
-
}
|
|
33
|
-
// Get document to validate
|
|
34
|
-
const document = await databaseAdapter.findByDocId(auth.organizationId, id);
|
|
35
|
-
if (!document || !document.draftData) {
|
|
36
|
-
return json({
|
|
37
|
-
success: false,
|
|
38
|
-
error: 'Document not found or cannot be published',
|
|
39
|
-
message: 'Document may not exist or may not have draft content'
|
|
40
|
-
}, { status: 404 });
|
|
41
|
-
}
|
|
42
|
-
// Get schema for validation (from config to preserve validation functions)
|
|
43
|
-
const schema = cmsEngine.getSchemaTypeByName(document.type);
|
|
44
|
-
if (!schema) {
|
|
45
|
-
return json({
|
|
46
|
-
success: false,
|
|
47
|
-
error: 'Invalid document type',
|
|
48
|
-
message: `Schema type '${document.type}' not found`
|
|
49
|
-
}, { status: 400 });
|
|
50
|
-
}
|
|
51
|
-
// VALIDATE before publishing - block if errors exist
|
|
52
|
-
const validationErrors = [];
|
|
53
|
-
for (const field of schema.fields) {
|
|
54
|
-
const value = document.draftData[field.name];
|
|
55
|
-
const result = await validateField(field, value, document.draftData);
|
|
56
|
-
if (!result.isValid) {
|
|
57
|
-
const errorMessages = result.errors
|
|
58
|
-
.filter((e) => e.level === 'error')
|
|
59
|
-
.map((e) => e.message);
|
|
60
|
-
if (errorMessages.length > 0) {
|
|
61
|
-
validationErrors.push({
|
|
62
|
-
field: field.name,
|
|
63
|
-
errors: errorMessages
|
|
64
|
-
});
|
|
65
|
-
}
|
|
66
|
-
}
|
|
67
|
-
}
|
|
68
|
-
// Block publishing if validation errors exist
|
|
69
|
-
if (validationErrors.length > 0) {
|
|
70
|
-
return json({
|
|
71
|
-
success: false,
|
|
72
|
-
error: 'Cannot publish: validation errors',
|
|
73
|
-
message: 'Please fix all validation errors before publishing',
|
|
74
|
-
validationErrors
|
|
75
|
-
}, { status: 400 });
|
|
76
|
-
}
|
|
77
|
-
// All validation passed - proceed with publish
|
|
78
|
-
const publishedDocument = await databaseAdapter.publishDoc(auth.organizationId, id);
|
|
79
|
-
if (!publishedDocument) {
|
|
80
|
-
return json({
|
|
81
|
-
success: false,
|
|
82
|
-
error: 'Document not found or cannot be published',
|
|
83
|
-
message: 'Document may not exist or may not have draft content'
|
|
84
|
-
}, { status: 404 });
|
|
85
|
-
}
|
|
86
|
-
return json({
|
|
87
|
-
success: true,
|
|
88
|
-
data: publishedDocument,
|
|
89
|
-
message: 'Document published successfully'
|
|
90
|
-
});
|
|
91
|
-
}
|
|
92
|
-
catch (error) {
|
|
93
|
-
console.error('Failed to publish document:', error);
|
|
94
|
-
return json({
|
|
95
|
-
success: false,
|
|
96
|
-
error: 'Failed to publish document',
|
|
97
|
-
message: error instanceof Error ? error.message : 'Unknown error'
|
|
98
|
-
}, { status: 500 });
|
|
99
|
-
}
|
|
100
|
-
};
|
|
101
|
-
// DELETE /api/documents/[id]/publish - Unpublish document
|
|
102
|
-
export const DELETE = async ({ params, locals }) => {
|
|
103
|
-
try {
|
|
104
|
-
const { databaseAdapter } = locals.aphexCMS;
|
|
105
|
-
const auth = locals.auth;
|
|
106
|
-
const { id } = params;
|
|
107
|
-
if (!auth) {
|
|
108
|
-
return json({
|
|
109
|
-
success: false,
|
|
110
|
-
error: 'Unauthorized',
|
|
111
|
-
message: 'Authentication required'
|
|
112
|
-
}, { status: 401 });
|
|
113
|
-
}
|
|
114
|
-
// Check write permissions (viewers are read-only)
|
|
115
|
-
if (!canWrite(auth)) {
|
|
116
|
-
return json({
|
|
117
|
-
success: false,
|
|
118
|
-
error: 'Forbidden',
|
|
119
|
-
message: 'You do not have permission to unpublish documents. Viewers have read-only access.'
|
|
120
|
-
}, { status: 403 });
|
|
121
|
-
}
|
|
122
|
-
if (!id) {
|
|
123
|
-
return json({
|
|
124
|
-
success: false,
|
|
125
|
-
error: 'Missing document ID',
|
|
126
|
-
message: 'Document ID is required'
|
|
127
|
-
}, { status: 400 });
|
|
128
|
-
}
|
|
129
|
-
const unpublishedDocument = await databaseAdapter.unpublishDoc(auth.organizationId, id);
|
|
130
|
-
if (!unpublishedDocument) {
|
|
131
|
-
return json({
|
|
132
|
-
success: false,
|
|
133
|
-
error: 'Document not found',
|
|
134
|
-
message: `No document found with ID: ${id}`
|
|
135
|
-
}, { status: 404 });
|
|
136
|
-
}
|
|
137
|
-
return json({
|
|
138
|
-
success: true,
|
|
139
|
-
data: unpublishedDocument,
|
|
140
|
-
message: 'Document unpublished successfully'
|
|
141
|
-
});
|
|
142
|
-
}
|
|
143
|
-
catch (error) {
|
|
144
|
-
console.error('Failed to unpublish document:', error);
|
|
145
|
-
return json({
|
|
146
|
-
success: false,
|
|
147
|
-
error: 'Failed to unpublish document',
|
|
148
|
-
message: error instanceof Error ? error.message : 'Unknown error'
|
|
149
|
-
}, { status: 500 });
|
|
150
|
-
}
|
|
151
|
-
};
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"documents.d.ts","sourceRoot":"","sources":["../../src/lib/routes/documents.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,eAAe,CAAC;AAQpD,eAAO,MAAM,GAAG,EAAE,cAsEjB,CAAC;AAGF,eAAO,MAAM,IAAI,EAAE,cAwFlB,CAAC"}
|