@aphexcms/cms-core 0.1.3 → 0.1.5
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/api/assets.d.ts +48 -0
- package/dist/api/assets.d.ts.map +1 -0
- package/dist/api/assets.js +52 -0
- package/dist/api/client.d.ts +37 -0
- package/dist/api/client.d.ts.map +1 -0
- package/dist/api/client.js +125 -0
- package/dist/api/documents.d.ts +56 -0
- package/dist/api/documents.d.ts.map +1 -0
- package/dist/api/documents.js +77 -0
- package/dist/api/index.d.ts +7 -0
- package/dist/api/index.d.ts.map +1 -0
- package/dist/api/index.js +5 -0
- package/dist/api/organizations.d.ts +101 -0
- package/dist/api/organizations.d.ts.map +1 -0
- package/dist/api/organizations.js +92 -0
- package/dist/api/types.d.ts +23 -0
- package/dist/api/types.d.ts.map +1 -0
- package/dist/api/types.js +1 -0
- package/dist/app.d.ts +19 -0
- package/dist/auth/MULTI_TENANCY_PLAN.md +1183 -0
- package/dist/auth/auth-errors.d.ts +7 -0
- package/dist/auth/auth-errors.d.ts.map +1 -0
- package/dist/auth/auth-errors.js +13 -0
- package/dist/auth/auth-hooks.d.ts +6 -0
- package/dist/auth/auth-hooks.d.ts.map +1 -0
- package/dist/auth/auth-hooks.js +108 -0
- package/dist/auth/provider.d.ts +17 -0
- package/dist/auth/provider.d.ts.map +1 -0
- package/dist/auth/provider.js +1 -0
- package/dist/client/index.d.ts +24 -0
- package/dist/client/index.d.ts.map +1 -0
- package/dist/client/index.js +31 -0
- package/dist/components/AdminApp.svelte +1077 -0
- package/dist/components/AdminApp.svelte.d.ts +24 -0
- package/dist/components/AdminApp.svelte.d.ts.map +1 -0
- package/dist/components/admin/AdminLayout.svelte +115 -0
- package/dist/components/admin/AdminLayout.svelte.d.ts +15 -0
- package/dist/components/admin/AdminLayout.svelte.d.ts.map +1 -0
- package/dist/components/admin/DocumentEditor.svelte +795 -0
- package/dist/components/admin/DocumentEditor.svelte.d.ts +18 -0
- package/dist/components/admin/DocumentEditor.svelte.d.ts.map +1 -0
- package/dist/components/admin/DocumentTypesList.svelte +97 -0
- package/dist/components/admin/DocumentTypesList.svelte.d.ts +14 -0
- package/dist/components/admin/DocumentTypesList.svelte.d.ts.map +1 -0
- package/dist/components/admin/ObjectModal.svelte +135 -0
- package/dist/components/admin/ObjectModal.svelte.d.ts +15 -0
- package/dist/components/admin/ObjectModal.svelte.d.ts.map +1 -0
- package/dist/components/admin/SchemaField.svelte +171 -0
- package/dist/components/admin/SchemaField.svelte.d.ts +19 -0
- package/dist/components/admin/SchemaField.svelte.d.ts.map +1 -0
- package/dist/components/admin/fields/ArrayField.svelte +266 -0
- package/dist/components/admin/fields/ArrayField.svelte.d.ts +12 -0
- package/dist/components/admin/fields/ArrayField.svelte.d.ts.map +1 -0
- package/dist/components/admin/fields/BooleanField.svelte +35 -0
- package/dist/components/admin/fields/BooleanField.svelte.d.ts +13 -0
- package/dist/components/admin/fields/BooleanField.svelte.d.ts.map +1 -0
- package/dist/components/admin/fields/ImageField.svelte +284 -0
- package/dist/components/admin/fields/ImageField.svelte.d.ts +15 -0
- package/dist/components/admin/fields/ImageField.svelte.d.ts.map +1 -0
- package/dist/components/admin/fields/NumberField.svelte +82 -0
- package/dist/components/admin/fields/NumberField.svelte.d.ts +14 -0
- package/dist/components/admin/fields/NumberField.svelte.d.ts.map +1 -0
- package/dist/components/admin/fields/ReferenceField.svelte +260 -0
- package/dist/components/admin/fields/ReferenceField.svelte.d.ts +12 -0
- package/dist/components/admin/fields/ReferenceField.svelte.d.ts.map +1 -0
- package/dist/components/admin/fields/SlugField.svelte +74 -0
- package/dist/components/admin/fields/SlugField.svelte.d.ts +15 -0
- package/dist/components/admin/fields/SlugField.svelte.d.ts.map +1 -0
- package/dist/components/admin/fields/StringField.svelte +40 -0
- package/dist/components/admin/fields/StringField.svelte.d.ts +14 -0
- package/dist/components/admin/fields/StringField.svelte.d.ts.map +1 -0
- package/dist/components/admin/fields/TextareaField.svelte +40 -0
- package/dist/components/admin/fields/TextareaField.svelte.d.ts +14 -0
- package/dist/components/admin/fields/TextareaField.svelte.d.ts.map +1 -0
- package/dist/components/fields/index.d.ts +9 -0
- package/dist/components/fields/index.d.ts.map +1 -0
- package/dist/components/fields/index.js +9 -0
- package/dist/components/index.d.ts +7 -0
- package/dist/components/index.d.ts.map +1 -0
- package/dist/components/index.js +12 -0
- package/dist/components/layout/OrganizationSwitcher.svelte +218 -0
- package/dist/components/layout/OrganizationSwitcher.svelte.d.ts +11 -0
- package/dist/components/layout/OrganizationSwitcher.svelte.d.ts.map +1 -0
- package/dist/components/layout/Sidebar.svelte +88 -0
- package/dist/components/layout/Sidebar.svelte.d.ts +14 -0
- package/dist/components/layout/Sidebar.svelte.d.ts.map +1 -0
- package/dist/components/layout/sidebar/AppSidebar.svelte +63 -0
- package/dist/components/layout/sidebar/AppSidebar.svelte.d.ts +11 -0
- package/dist/components/layout/sidebar/AppSidebar.svelte.d.ts.map +1 -0
- package/dist/components/layout/sidebar/NavMain.svelte +95 -0
- package/dist/components/layout/sidebar/NavMain.svelte.d.ts +19 -0
- package/dist/components/layout/sidebar/NavMain.svelte.d.ts.map +1 -0
- package/dist/components/layout/sidebar/NavSecondary.svelte +69 -0
- package/dist/components/layout/sidebar/NavSecondary.svelte.d.ts +9 -0
- package/dist/components/layout/sidebar/NavSecondary.svelte.d.ts.map +1 -0
- package/dist/components/layout/sidebar/NavUser.svelte +85 -0
- package/dist/components/layout/sidebar/NavUser.svelte.d.ts +9 -0
- package/dist/components/layout/sidebar/NavUser.svelte.d.ts.map +1 -0
- package/dist/config.d.ts +3 -0
- package/dist/config.d.ts.map +1 -0
- package/dist/config.js +15 -0
- package/dist/db/adapters/index.d.ts +1 -0
- package/dist/db/adapters/index.d.ts.map +1 -0
- package/dist/db/adapters/index.js +4 -0
- package/dist/db/index.d.ts +2 -0
- package/dist/db/index.d.ts.map +1 -0
- package/dist/db/index.js +4 -0
- package/dist/db/interfaces/asset.d.ts +51 -0
- package/dist/db/interfaces/asset.d.ts.map +1 -0
- package/dist/db/interfaces/asset.js +1 -0
- package/dist/db/interfaces/document.d.ts +36 -0
- package/dist/db/interfaces/document.d.ts.map +1 -0
- package/dist/db/interfaces/document.js +1 -0
- package/dist/db/interfaces/index.d.ts +73 -0
- package/dist/db/interfaces/index.d.ts.map +1 -0
- package/dist/db/interfaces/index.js +1 -0
- package/dist/db/interfaces/organization.d.ts +27 -0
- package/dist/db/interfaces/organization.d.ts.map +1 -0
- package/dist/db/interfaces/organization.js +1 -0
- package/dist/db/interfaces/schema.d.ts +21 -0
- package/dist/db/interfaces/schema.d.ts.map +1 -0
- package/dist/db/interfaces/schema.js +1 -0
- package/dist/db/interfaces/user.d.ts +15 -0
- package/dist/db/interfaces/user.d.ts.map +1 -0
- package/dist/db/interfaces/user.js +1 -0
- package/dist/db/utils/reference-resolver.d.ts +18 -0
- package/dist/db/utils/reference-resolver.d.ts.map +1 -0
- package/dist/db/utils/reference-resolver.js +80 -0
- package/dist/define.d.ts +3 -0
- package/dist/define.d.ts.map +1 -0
- package/dist/define.js +4 -0
- package/dist/email/index.d.ts +2 -0
- package/dist/email/index.d.ts.map +1 -0
- package/dist/email/index.js +4 -0
- package/dist/email/interfaces/email.d.ts +42 -0
- package/dist/email/interfaces/email.d.ts.map +1 -0
- package/dist/email/interfaces/email.js +1 -0
- package/dist/engine.d.ts +26 -0
- package/dist/engine.d.ts.map +1 -0
- package/dist/engine.js +66 -0
- package/dist/field-validation/rule.d.ts +51 -0
- package/dist/field-validation/rule.d.ts.map +1 -0
- package/dist/field-validation/rule.js +221 -0
- package/dist/field-validation/utils.d.ts +21 -0
- package/dist/field-validation/utils.d.ts.map +1 -0
- package/dist/field-validation/utils.js +66 -0
- package/dist/hooks.d.ts +23 -0
- package/dist/hooks.d.ts.map +1 -0
- package/dist/hooks.js +96 -0
- package/dist/index.d.ts +2 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +4 -0
- package/dist/plugins/README.md +154 -0
- package/dist/routes/assets-by-id.d.ts +5 -0
- package/dist/routes/assets-by-id.d.ts.map +1 -0
- package/dist/routes/assets-by-id.js +138 -0
- package/dist/routes/assets-cdn.d.ts +3 -0
- package/dist/routes/assets-cdn.d.ts.map +1 -0
- package/dist/routes/assets-cdn.js +155 -0
- package/dist/routes/assets.d.ts +4 -0
- package/dist/routes/assets.d.ts.map +1 -0
- package/dist/routes/assets.js +94 -0
- package/dist/routes/documents-by-id.d.ts +5 -0
- package/dist/routes/documents-by-id.d.ts.map +1 -0
- package/dist/routes/documents-by-id.js +142 -0
- package/dist/routes/documents-publish.d.ts +4 -0
- package/dist/routes/documents-publish.d.ts.map +1 -0
- package/dist/routes/documents-publish.js +151 -0
- package/dist/routes/documents.d.ts +4 -0
- package/dist/routes/documents.d.ts.map +1 -0
- package/dist/routes/documents.js +131 -0
- package/dist/routes/index.d.ts +6 -0
- package/dist/routes/index.d.ts.map +1 -0
- package/dist/routes/index.js +10 -0
- package/dist/routes/organizations-by-id.d.ts +5 -0
- package/dist/routes/organizations-by-id.d.ts.map +1 -0
- package/dist/routes/organizations-by-id.js +187 -0
- package/dist/routes/organizations-invitations.d.ts +4 -0
- package/dist/routes/organizations-invitations.d.ts.map +1 -0
- package/dist/routes/organizations-invitations.js +125 -0
- package/dist/routes/organizations-members.d.ts +5 -0
- package/dist/routes/organizations-members.d.ts.map +1 -0
- package/dist/routes/organizations-members.js +206 -0
- package/dist/routes/organizations-switch.d.ts +3 -0
- package/dist/routes/organizations-switch.d.ts.map +1 -0
- package/dist/routes/organizations-switch.js +53 -0
- package/dist/routes/organizations.d.ts +4 -0
- package/dist/routes/organizations.d.ts.map +1 -0
- package/dist/routes/organizations.js +108 -0
- package/dist/routes/schemas-by-type.d.ts +3 -0
- package/dist/routes/schemas-by-type.d.ts.map +1 -0
- package/dist/routes/schemas-by-type.js +25 -0
- package/dist/routes/schemas.d.ts +3 -0
- package/dist/routes/schemas.d.ts.map +1 -0
- package/dist/routes/schemas.js +11 -0
- package/dist/routes-exports.d.ts +14 -0
- package/dist/routes-exports.d.ts.map +1 -0
- package/dist/routes-exports.js +19 -0
- package/dist/schema-context.svelte.d.ts +10 -0
- package/dist/schema-context.svelte.d.ts.map +1 -0
- package/dist/schema-context.svelte.js +18 -0
- package/dist/schema-utils/cleanup.d.ts +21 -0
- package/dist/schema-utils/cleanup.d.ts.map +1 -0
- package/dist/schema-utils/cleanup.js +80 -0
- package/dist/schema-utils/index.d.ts +4 -0
- package/dist/schema-utils/index.d.ts.map +1 -0
- package/dist/schema-utils/index.js +4 -0
- package/dist/schema-utils/utils.d.ts +30 -0
- package/dist/schema-utils/utils.d.ts.map +1 -0
- package/dist/schema-utils/utils.js +37 -0
- package/dist/schema-utils/validator.d.ts +6 -0
- package/dist/schema-utils/validator.d.ts.map +1 -0
- package/dist/schema-utils/validator.js +45 -0
- package/dist/server/index.d.ts +16 -0
- package/dist/server/index.d.ts.map +1 -0
- package/dist/server/index.js +28 -0
- package/dist/services/asset-service.d.ts +86 -0
- package/dist/services/asset-service.d.ts.map +1 -0
- package/dist/services/asset-service.js +187 -0
- package/dist/services/index.d.ts +3 -0
- package/dist/services/index.d.ts.map +1 -0
- package/dist/services/index.js +4 -0
- package/dist/storage/adapters/index.d.ts +2 -0
- package/dist/storage/adapters/index.d.ts.map +1 -0
- package/dist/storage/adapters/index.js +2 -0
- package/dist/storage/adapters/local-storage-adapter.d.ts +54 -0
- package/dist/storage/adapters/local-storage-adapter.d.ts.map +1 -0
- package/dist/storage/adapters/local-storage-adapter.js +187 -0
- package/dist/storage/index.d.ts +3 -0
- package/dist/storage/index.d.ts.map +1 -0
- package/dist/storage/index.js +6 -0
- package/dist/storage/interfaces/index.d.ts +2 -0
- package/dist/storage/interfaces/index.d.ts.map +1 -0
- package/dist/storage/interfaces/index.js +2 -0
- package/dist/storage/interfaces/storage.d.ts +91 -0
- package/dist/storage/interfaces/storage.d.ts.map +1 -0
- package/dist/storage/interfaces/storage.js +1 -0
- package/dist/storage/providers/storage.d.ts +43 -0
- package/dist/storage/providers/storage.d.ts.map +1 -0
- package/dist/storage/providers/storage.js +64 -0
- package/dist/types/asset.d.ts +73 -0
- package/dist/types/asset.d.ts.map +1 -0
- package/dist/types/asset.js +2 -0
- package/dist/types/auth.d.ts +50 -0
- package/dist/types/auth.d.ts.map +1 -0
- package/dist/types/auth.js +41 -0
- package/dist/types/config.d.ts +47 -0
- package/dist/types/config.d.ts.map +1 -0
- package/dist/types/config.js +1 -0
- package/dist/types/document.d.ts +34 -0
- package/dist/types/document.d.ts.map +1 -0
- package/dist/types/document.js +1 -0
- package/dist/types/index.d.ts +9 -0
- package/dist/types/index.d.ts.map +1 -0
- package/dist/types/index.js +8 -0
- package/dist/types/organization.d.ts +105 -0
- package/dist/types/organization.d.ts.map +1 -0
- package/dist/types/organization.js +3 -0
- package/dist/types/schemas.d.ts +114 -0
- package/dist/types/schemas.d.ts.map +1 -0
- package/dist/types/schemas.js +1 -0
- package/dist/types/sidebar.d.ts +33 -0
- package/dist/types/sidebar.d.ts.map +1 -0
- package/dist/types/sidebar.js +1 -0
- package/dist/types/user.d.ts +14 -0
- package/dist/types/user.d.ts.map +1 -0
- package/dist/types/user.js +1 -0
- package/dist/utils/content-hash.d.ts +22 -0
- package/dist/utils/content-hash.d.ts.map +1 -0
- package/dist/utils/content-hash.js +67 -0
- package/dist/utils/image-url.d.ts +88 -0
- package/dist/utils/image-url.d.ts.map +1 -0
- package/dist/utils/image-url.js +165 -0
- package/dist/utils/index.d.ts +6 -0
- package/dist/utils/index.d.ts.map +1 -0
- package/dist/utils/index.js +9 -0
- package/dist/utils/slug.d.ts +13 -0
- package/dist/utils/slug.d.ts.map +1 -0
- package/dist/utils/slug.js +30 -0
- package/package.json +11 -41
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
export type AuthErrorCode = 'no_session' | 'session_expired' | 'no_organization' | 'kicked_from_org' | 'unauthorized';
|
|
2
|
+
export declare class AuthError extends Error {
|
|
3
|
+
code: AuthErrorCode;
|
|
4
|
+
constructor(code: AuthErrorCode, message: string);
|
|
5
|
+
}
|
|
6
|
+
export declare function createAuthError(code: AuthErrorCode, message: string): AuthError;
|
|
7
|
+
//# sourceMappingURL=auth-errors.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"auth-errors.d.ts","sourceRoot":"","sources":["../../src/lib/auth/auth-errors.ts"],"names":[],"mappings":"AAEA,MAAM,MAAM,aAAa,GACtB,YAAY,GACZ,iBAAiB,GACjB,iBAAiB,GACjB,iBAAiB,GACjB,cAAc,CAAC;AAElB,qBAAa,SAAU,SAAQ,KAAK;IACnC,IAAI,EAAE,aAAa,CAAC;gBAER,IAAI,EAAE,aAAa,EAAE,OAAO,EAAE,MAAM;CAKhD;AAGD,wBAAgB,eAAe,CAAC,IAAI,EAAE,aAAa,EAAE,OAAO,EAAE,MAAM,GAAG,SAAS,CAE/E"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
// Custom authentication errors with error codes for better error handling
|
|
2
|
+
export class AuthError extends Error {
|
|
3
|
+
code;
|
|
4
|
+
constructor(code, message) {
|
|
5
|
+
super(message);
|
|
6
|
+
this.code = code;
|
|
7
|
+
this.name = 'AuthError';
|
|
8
|
+
}
|
|
9
|
+
}
|
|
10
|
+
// Helper function to create auth errors
|
|
11
|
+
export function createAuthError(code, message) {
|
|
12
|
+
return new AuthError(code, message);
|
|
13
|
+
}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
import type { RequestEvent } from '@sveltejs/kit';
|
|
2
|
+
import type { DatabaseAdapter } from '../db/';
|
|
3
|
+
import type { CMSConfig } from '../types/index.js';
|
|
4
|
+
import type { AuthProvider } from './provider.js';
|
|
5
|
+
export declare function handleAuthHook(event: RequestEvent, config: CMSConfig, authProvider: AuthProvider, db: DatabaseAdapter): Promise<Response | null>;
|
|
6
|
+
//# sourceMappingURL=auth-hooks.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"auth-hooks.d.ts","sourceRoot":"","sources":["../../src/lib/auth/auth-hooks.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,eAAe,CAAC;AAElD,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,QAAQ,CAAC;AAC9C,OAAO,KAAK,EAAE,SAAS,EAAQ,MAAM,mBAAmB,CAAC;AACzD,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,eAAe,CAAC;AAGlD,wBAAsB,cAAc,CACnC,KAAK,EAAE,YAAY,EACnB,MAAM,EAAE,SAAS,EACjB,YAAY,EAAE,YAAY,EAC1B,EAAE,EAAE,eAAe,GACjB,OAAO,CAAC,QAAQ,GAAG,IAAI,CAAC,CAuH1B"}
|
|
@@ -0,0 +1,108 @@
|
|
|
1
|
+
import { redirect } from '@sveltejs/kit';
|
|
2
|
+
import { AuthError } from './auth-errors.js';
|
|
3
|
+
export async function handleAuthHook(event, config, authProvider, db) {
|
|
4
|
+
const path = event.url.pathname;
|
|
5
|
+
// 1. Admin UI routes - require session authentication
|
|
6
|
+
if (path.startsWith('/admin')) {
|
|
7
|
+
try {
|
|
8
|
+
const session = await authProvider.requireSession(event.request, db);
|
|
9
|
+
event.locals.auth = session;
|
|
10
|
+
}
|
|
11
|
+
catch (error) {
|
|
12
|
+
// If it's an AuthError, redirect to login with error code
|
|
13
|
+
if (error instanceof AuthError) {
|
|
14
|
+
const loginUrl = config.auth?.loginUrl || '/login';
|
|
15
|
+
throw redirect(302, `${loginUrl}?error=${error.code}`);
|
|
16
|
+
}
|
|
17
|
+
// For other errors, redirect without error code
|
|
18
|
+
throw redirect(302, config.auth?.loginUrl || '/login');
|
|
19
|
+
}
|
|
20
|
+
}
|
|
21
|
+
// 2. Asset CDN routes - accept session OR API key OR signed token
|
|
22
|
+
// Support both /assets/ and /media/ paths (media is Sanity-style URL)
|
|
23
|
+
if (path.startsWith('/assets/') || path.startsWith('/media/')) {
|
|
24
|
+
// Try session first (for admin UI)
|
|
25
|
+
let auth = await authProvider.getSession(event.request, db);
|
|
26
|
+
// If no session, try API key
|
|
27
|
+
if (!auth) {
|
|
28
|
+
auth = await authProvider.validateApiKey(event.request, db);
|
|
29
|
+
}
|
|
30
|
+
// Make auth available (can be null, route will check for signed token)
|
|
31
|
+
if (auth) {
|
|
32
|
+
event.locals.auth = auth;
|
|
33
|
+
}
|
|
34
|
+
}
|
|
35
|
+
// 3. API routes - accept session OR API key
|
|
36
|
+
if (path.startsWith('/api/')) {
|
|
37
|
+
// Skip auth routes (Better Auth handles these)
|
|
38
|
+
if (path.startsWith('/api/auth')) {
|
|
39
|
+
return null; // Let the main hook continue
|
|
40
|
+
}
|
|
41
|
+
// If API key is explicitly provided, prioritize it over session
|
|
42
|
+
// This allows public content access even when user is logged in to a different org
|
|
43
|
+
const hasApiKey = event.request.headers.has('x-api-key');
|
|
44
|
+
let auth = null;
|
|
45
|
+
if (hasApiKey) {
|
|
46
|
+
// API key takes precedence when explicitly provided
|
|
47
|
+
auth = await authProvider.validateApiKey(event.request, db);
|
|
48
|
+
}
|
|
49
|
+
else {
|
|
50
|
+
// Otherwise, try session (for admin UI making API calls)
|
|
51
|
+
auth = await authProvider.getSession(event.request, db);
|
|
52
|
+
}
|
|
53
|
+
// Dynamically find the GraphQL endpoint from plugins
|
|
54
|
+
let graphqlEndpoint;
|
|
55
|
+
const graphqlPlugin = config.plugins?.find((p) => p.name === '@aphexcms/graphql-plugin');
|
|
56
|
+
if (graphqlPlugin && graphqlPlugin.routes) {
|
|
57
|
+
graphqlEndpoint = Object.keys(graphqlPlugin.routes)[0];
|
|
58
|
+
}
|
|
59
|
+
// Require authentication for protected API routes
|
|
60
|
+
const protectedApiRoutes = [
|
|
61
|
+
'/api/documents',
|
|
62
|
+
'/api/assets',
|
|
63
|
+
'/api/schemas',
|
|
64
|
+
'/api/organizations',
|
|
65
|
+
'/api/settings'
|
|
66
|
+
];
|
|
67
|
+
if (graphqlEndpoint) {
|
|
68
|
+
protectedApiRoutes.push(graphqlEndpoint);
|
|
69
|
+
}
|
|
70
|
+
const isProtectedRoute = protectedApiRoutes.some((route) => path.startsWith(route));
|
|
71
|
+
if (isProtectedRoute && !auth) {
|
|
72
|
+
return new Response(JSON.stringify({ error: 'Unauthorized' }), {
|
|
73
|
+
status: 401,
|
|
74
|
+
headers: { 'Content-Type': 'application/json' }
|
|
75
|
+
});
|
|
76
|
+
}
|
|
77
|
+
// Check write permission for mutations
|
|
78
|
+
if (auth && ['POST', 'PUT', 'PATCH', 'DELETE'].includes(event.request.method)) {
|
|
79
|
+
// Special handling for GraphQL
|
|
80
|
+
if (graphqlEndpoint && path.startsWith(graphqlEndpoint)) {
|
|
81
|
+
// We need to read the body to check if it's a mutation.
|
|
82
|
+
// It's important to clone the request so we don't consume the body stream.
|
|
83
|
+
const requestBody = await event.request.clone().text();
|
|
84
|
+
const isMutation = requestBody.trim().startsWith('mutation');
|
|
85
|
+
if (isMutation && auth.type === 'api_key' && !auth.permissions.includes('write')) {
|
|
86
|
+
return new Response(JSON.stringify({ error: 'Forbidden: Write permission required for mutations' }), {
|
|
87
|
+
status: 403,
|
|
88
|
+
headers: { 'Content-Type': 'application/json' }
|
|
89
|
+
});
|
|
90
|
+
}
|
|
91
|
+
}
|
|
92
|
+
else {
|
|
93
|
+
// Existing logic for other API routes
|
|
94
|
+
if (auth.type === 'api_key' && !auth.permissions.includes('write')) {
|
|
95
|
+
return new Response(JSON.stringify({ error: 'Forbidden: Write permission required' }), {
|
|
96
|
+
status: 403,
|
|
97
|
+
headers: { 'Content-Type': 'application/json' }
|
|
98
|
+
});
|
|
99
|
+
}
|
|
100
|
+
}
|
|
101
|
+
}
|
|
102
|
+
// Make auth available in API routes
|
|
103
|
+
if (auth) {
|
|
104
|
+
event.locals.auth = auth;
|
|
105
|
+
}
|
|
106
|
+
}
|
|
107
|
+
return null; // Tell the main hook to continue
|
|
108
|
+
}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import type { SessionAuth, ApiKeyAuth } from '../types/index.js';
|
|
2
|
+
import type { DatabaseAdapter } from '../db/interfaces/index.js';
|
|
3
|
+
export interface AuthProvider {
|
|
4
|
+
getSession(request: Request, db: DatabaseAdapter): Promise<SessionAuth | null>;
|
|
5
|
+
requireSession(request: Request, db: DatabaseAdapter): Promise<SessionAuth>;
|
|
6
|
+
validateApiKey(request: Request, db: DatabaseAdapter): Promise<ApiKeyAuth | null>;
|
|
7
|
+
requireApiKey(request: Request, db: DatabaseAdapter, permission?: 'read' | 'write'): Promise<ApiKeyAuth>;
|
|
8
|
+
getUserById(userId: string): Promise<{
|
|
9
|
+
id: string;
|
|
10
|
+
name?: string;
|
|
11
|
+
email: string;
|
|
12
|
+
} | null>;
|
|
13
|
+
changeUserName(userId: string, name: string): Promise<void>;
|
|
14
|
+
requestPasswordReset(email: string, redirectTo?: string): Promise<void>;
|
|
15
|
+
resetPassword(token: string, newPassword: string): Promise<void>;
|
|
16
|
+
}
|
|
17
|
+
//# sourceMappingURL=provider.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"provider.d.ts","sourceRoot":"","sources":["../../src/lib/auth/provider.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,WAAW,EAAE,UAAU,EAAE,MAAM,mBAAmB,CAAC;AACjE,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,2BAA2B,CAAC;AAEjE,MAAM,WAAW,YAAY;IAE5B,UAAU,CAAC,OAAO,EAAE,OAAO,EAAE,EAAE,EAAE,eAAe,GAAG,OAAO,CAAC,WAAW,GAAG,IAAI,CAAC,CAAC;IAC/E,cAAc,CAAC,OAAO,EAAE,OAAO,EAAE,EAAE,EAAE,eAAe,GAAG,OAAO,CAAC,WAAW,CAAC,CAAC;IAG5E,cAAc,CAAC,OAAO,EAAE,OAAO,EAAE,EAAE,EAAE,eAAe,GAAG,OAAO,CAAC,UAAU,GAAG,IAAI,CAAC,CAAC;IAClF,aAAa,CACZ,OAAO,EAAE,OAAO,EAChB,EAAE,EAAE,eAAe,EACnB,UAAU,CAAC,EAAE,MAAM,GAAG,OAAO,GAC3B,OAAO,CAAC,UAAU,CAAC,CAAC;IAGvB,WAAW,CAAC,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC;QAAE,EAAE,EAAE,MAAM,CAAC;QAAC,IAAI,CAAC,EAAE,MAAM,CAAC;QAAC,KAAK,EAAE,MAAM,CAAA;KAAE,GAAG,IAAI,CAAC,CAAC;IAC1F,cAAc,CAAC,MAAM,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IAG5D,oBAAoB,CAAC,KAAK,EAAE,MAAM,EAAE,UAAU,CAAC,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IACxE,aAAa,CAAC,KAAK,EAAE,MAAM,EAAE,WAAW,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;CACjE"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
export * from '../types/index.js';
|
|
2
|
+
export type { SidebarUser, SidebarNavItem, SidebarBranding, SidebarData } from '../types/sidebar.js';
|
|
3
|
+
export * from '../field-validation/rule.js';
|
|
4
|
+
export * from '../field-validation/utils.js';
|
|
5
|
+
export { createContentHash, hasUnpublishedChanges } from '../utils/content-hash.js';
|
|
6
|
+
export { setSchemaContext, getSchemaContext } from '../schema-context.svelte.js';
|
|
7
|
+
export * from '../schema-utils/index.js';
|
|
8
|
+
export { default as DocumentEditor } from '../components/admin/DocumentEditor.svelte';
|
|
9
|
+
export { default as DocumentTypesList } from '../components/admin/DocumentTypesList.svelte';
|
|
10
|
+
export { default as SchemaField } from '../components/admin/SchemaField.svelte';
|
|
11
|
+
export { default as AdminApp } from '../components/AdminApp.svelte';
|
|
12
|
+
export { default as Sidebar } from '../components/layout/Sidebar.svelte';
|
|
13
|
+
export { default as StringField } from '../components/admin/fields/StringField.svelte';
|
|
14
|
+
export { default as TextareaField } from '../components/admin/fields/TextareaField.svelte';
|
|
15
|
+
export { default as NumberField } from '../components/admin/fields/NumberField.svelte';
|
|
16
|
+
export { default as BooleanField } from '../components/admin/fields/BooleanField.svelte';
|
|
17
|
+
export { default as ImageField } from '../components/admin/fields/ImageField.svelte';
|
|
18
|
+
export { default as SlugField } from '../components/admin/fields/SlugField.svelte';
|
|
19
|
+
export { default as ArrayField } from '../components/admin/fields/ArrayField.svelte';
|
|
20
|
+
export { default as ReferenceField } from '../components/admin/fields/ReferenceField.svelte';
|
|
21
|
+
export * from '../utils/index.js';
|
|
22
|
+
export * from '../api/index.js';
|
|
23
|
+
export type { ApiResponse } from '../api/index.js';
|
|
24
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/lib/client/index.ts"],"names":[],"mappings":"AAIA,cAAc,mBAAmB,CAAC;AAClC,YAAY,EACX,WAAW,EACX,cAAc,EACd,eAAe,EACf,WAAW,EACX,MAAM,qBAAqB,CAAC;AAG7B,cAAc,6BAA6B,CAAC;AAC5C,cAAc,8BAA8B,CAAC;AAG7C,OAAO,EAAE,iBAAiB,EAAE,qBAAqB,EAAE,MAAM,0BAA0B,CAAC;AAGpF,OAAO,EAAE,gBAAgB,EAAE,gBAAgB,EAAE,MAAM,6BAA6B,CAAC;AAGjF,cAAc,0BAA0B,CAAC;AAGzC,OAAO,EAAE,OAAO,IAAI,cAAc,EAAE,MAAM,2CAA2C,CAAC;AACtF,OAAO,EAAE,OAAO,IAAI,iBAAiB,EAAE,MAAM,8CAA8C,CAAC;AAC5F,OAAO,EAAE,OAAO,IAAI,WAAW,EAAE,MAAM,wCAAwC,CAAC;AAChF,OAAO,EAAE,OAAO,IAAI,QAAQ,EAAE,MAAM,+BAA+B,CAAC;AACpE,OAAO,EAAE,OAAO,IAAI,OAAO,EAAE,MAAM,qCAAqC,CAAC;AAGzE,OAAO,EAAE,OAAO,IAAI,WAAW,EAAE,MAAM,+CAA+C,CAAC;AACvF,OAAO,EAAE,OAAO,IAAI,aAAa,EAAE,MAAM,iDAAiD,CAAC;AAC3F,OAAO,EAAE,OAAO,IAAI,WAAW,EAAE,MAAM,+CAA+C,CAAC;AACvF,OAAO,EAAE,OAAO,IAAI,YAAY,EAAE,MAAM,gDAAgD,CAAC;AACzF,OAAO,EAAE,OAAO,IAAI,UAAU,EAAE,MAAM,8CAA8C,CAAC;AACrF,OAAO,EAAE,OAAO,IAAI,SAAS,EAAE,MAAM,6CAA6C,CAAC;AACnF,OAAO,EAAE,OAAO,IAAI,UAAU,EAAE,MAAM,8CAA8C,CAAC;AACrF,OAAO,EAAE,OAAO,IAAI,cAAc,EAAE,MAAM,kDAAkD,CAAC;AAG7F,cAAc,mBAAmB,CAAC;AAElC,cAAc,iBAAiB,CAAC;AAChC,YAAY,EAAE,WAAW,EAAE,MAAM,iBAAiB,CAAC"}
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
// Aphex CMS Core - Client-side exports
|
|
2
|
+
// These are safe to import in the browser (no Node.js dependencies)
|
|
3
|
+
// Core types (shared between client and server)
|
|
4
|
+
export * from '../types/index.js';
|
|
5
|
+
// Field validation (client-side validation)
|
|
6
|
+
export * from '../field-validation/rule.js';
|
|
7
|
+
export * from '../field-validation/utils.js';
|
|
8
|
+
// Content hashing utilities (for client-side change detection)
|
|
9
|
+
export { createContentHash, hasUnpublishedChanges } from '../utils/content-hash.js';
|
|
10
|
+
// Schema context (for providing schemas to components)
|
|
11
|
+
export { setSchemaContext, getSchemaContext } from '../schema-context.svelte.js';
|
|
12
|
+
// Schema utilities (for working with schemas)
|
|
13
|
+
export * from '../schema-utils/index.js';
|
|
14
|
+
// Components (UI components for the admin interface)
|
|
15
|
+
export { default as DocumentEditor } from '../components/admin/DocumentEditor.svelte';
|
|
16
|
+
export { default as DocumentTypesList } from '../components/admin/DocumentTypesList.svelte';
|
|
17
|
+
export { default as SchemaField } from '../components/admin/SchemaField.svelte';
|
|
18
|
+
export { default as AdminApp } from '../components/AdminApp.svelte';
|
|
19
|
+
export { default as Sidebar } from '../components/layout/Sidebar.svelte';
|
|
20
|
+
// Field components
|
|
21
|
+
export { default as StringField } from '../components/admin/fields/StringField.svelte';
|
|
22
|
+
export { default as TextareaField } from '../components/admin/fields/TextareaField.svelte';
|
|
23
|
+
export { default as NumberField } from '../components/admin/fields/NumberField.svelte';
|
|
24
|
+
export { default as BooleanField } from '../components/admin/fields/BooleanField.svelte';
|
|
25
|
+
export { default as ImageField } from '../components/admin/fields/ImageField.svelte';
|
|
26
|
+
export { default as SlugField } from '../components/admin/fields/SlugField.svelte';
|
|
27
|
+
export { default as ArrayField } from '../components/admin/fields/ArrayField.svelte';
|
|
28
|
+
export { default as ReferenceField } from '../components/admin/fields/ReferenceField.svelte';
|
|
29
|
+
// Utility functions (browser-safe)
|
|
30
|
+
export * from '../utils/index.js';
|
|
31
|
+
export * from '../api/index.js';
|