@sonicjs-cms/core 2.0.0-alpha.5 → 2.0.0-alpha.7

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.
Files changed (41) hide show
  1. package/dist/{chunk-CXZDAR6S.js → chunk-7N3HK7ZK.js} +3 -3
  2. package/dist/{chunk-CXZDAR6S.js.map → chunk-7N3HK7ZK.js.map} +1 -1
  3. package/dist/{chunk-NRSL6BQI.js → chunk-BITQ4MFX.js} +3 -3
  4. package/dist/{chunk-NRSL6BQI.js.map → chunk-BITQ4MFX.js.map} +1 -1
  5. package/dist/{chunk-24PWAFUT.cjs → chunk-BUKT6HP5.cjs} +13 -13
  6. package/dist/{chunk-24PWAFUT.cjs.map → chunk-BUKT6HP5.cjs.map} +1 -1
  7. package/dist/{chunk-L3NXO7Y4.cjs → chunk-FVMV5DKA.cjs} +49 -49
  8. package/dist/{chunk-L3NXO7Y4.cjs.map → chunk-FVMV5DKA.cjs.map} +1 -1
  9. package/dist/{chunk-EMMSS5I5.cjs → chunk-IGJUBJBW.cjs} +8 -2
  10. package/dist/{chunk-EMMSS5I5.cjs.map → chunk-IGJUBJBW.cjs.map} +1 -1
  11. package/dist/{chunk-WJ7QYVR2.cjs → chunk-RNR4HA23.cjs} +4 -4
  12. package/dist/{chunk-WJ7QYVR2.cjs.map → chunk-RNR4HA23.cjs.map} +1 -1
  13. package/dist/{chunk-G3PMV62Z.js → chunk-V4OQ3NZ2.js} +7 -3
  14. package/dist/{chunk-G3PMV62Z.js.map → chunk-V4OQ3NZ2.js.map} +1 -1
  15. package/dist/{chunk-5RDID2QZ.js → chunk-VY6FDZ6Y.js} +5301 -2361
  16. package/dist/chunk-VY6FDZ6Y.js.map +1 -0
  17. package/dist/{chunk-PTQZ5FEI.js → chunk-WESS2U3K.js} +3 -3
  18. package/dist/{chunk-PTQZ5FEI.js.map → chunk-WESS2U3K.js.map} +1 -1
  19. package/dist/{chunk-KWFUNPSQ.cjs → chunk-Y6VF3YFA.cjs} +5322 -2381
  20. package/dist/chunk-Y6VF3YFA.cjs.map +1 -0
  21. package/dist/index.cjs +97 -93
  22. package/dist/index.cjs.map +1 -1
  23. package/dist/index.js +11 -7
  24. package/dist/index.js.map +1 -1
  25. package/dist/middleware.cjs +23 -23
  26. package/dist/middleware.js +3 -3
  27. package/dist/plugins.cjs +8 -8
  28. package/dist/plugins.js +2 -2
  29. package/dist/routes.cjs +16 -12
  30. package/dist/routes.js +4 -4
  31. package/dist/services.cjs +18 -18
  32. package/dist/services.js +2 -2
  33. package/dist/templates.cjs +1 -1
  34. package/dist/templates.js +1 -1
  35. package/dist/types.cjs +1 -1
  36. package/dist/types.js +1 -1
  37. package/dist/utils.cjs +1 -1
  38. package/dist/utils.js +1 -1
  39. package/package.json +1 -1
  40. package/dist/chunk-5RDID2QZ.js.map +0 -1
  41. package/dist/chunk-KWFUNPSQ.cjs.map +0 -1
package/dist/index.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/app.ts","../src/db/index.ts","../src/index.ts"],"names":[],"mappings":"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","file":"index.js","sourcesContent":["/**\n * Main Application Factory\n *\n * Creates a configured SonicJS application with all core functionality\n */\n\nimport { Hono } from 'hono'\nimport type { Context } from 'hono'\nimport type { D1Database, KVNamespace, R2Bucket } from '@cloudflare/workers-types'\nimport { apiRoutes, apiMediaRoutes, apiSystemRoutes, adminApiRoutes, authRoutes, adminContentRoutes } from './routes'\n\n// ============================================================================\n// Type Definitions\n// ============================================================================\n\nexport interface Bindings {\n DB: D1Database\n CACHE_KV: KVNamespace\n MEDIA_BUCKET: R2Bucket\n ASSETS: Fetcher\n EMAIL_QUEUE?: Queue\n SENDGRID_API_KEY?: string\n DEFAULT_FROM_EMAIL?: string\n IMAGES_ACCOUNT_ID?: string\n IMAGES_API_TOKEN?: string\n ENVIRONMENT?: string\n}\n\nexport interface Variables {\n user?: {\n userId: string\n email: string\n role: string\n exp: number\n iat: number\n }\n requestId?: string\n startTime?: number\n appVersion?: string\n}\n\nexport interface SonicJSConfig {\n // Collections configuration\n collections?: {\n directory?: string\n autoSync?: boolean\n }\n\n // Plugins configuration\n plugins?: {\n directory?: string\n autoLoad?: boolean\n }\n\n // Custom routes\n routes?: Array<{\n path: string\n handler: Hono\n }>\n\n // Custom middleware\n middleware?: {\n beforeAuth?: Array<(c: Context, next: () => Promise<void>) => Promise<void>>\n afterAuth?: Array<(c: Context, next: () => Promise<void>) => Promise<void>>\n }\n\n // App metadata\n version?: string\n name?: string\n}\n\nexport type SonicJSApp = Hono<{ Bindings: Bindings; Variables: Variables }>\n\n// ============================================================================\n// Application Factory\n// ============================================================================\n\n/**\n * Create a SonicJS application with core functionality\n *\n * @param config - Application configuration\n * @returns Configured Hono application\n *\n * @example\n * ```typescript\n * import { createSonicJSApp } from '@sonicjs/core'\n *\n * const app = createSonicJSApp({\n * collections: {\n * directory: './src/collections',\n * autoSync: true\n * },\n * plugins: {\n * directory: './src/plugins',\n * autoLoad: true\n * }\n * })\n *\n * export default app\n * ```\n */\nexport function createSonicJSApp(config: SonicJSConfig = {}): SonicJSApp {\n const app = new Hono<{ Bindings: Bindings; Variables: Variables }>()\n\n // Set app metadata\n const appVersion = config.version || '1.0.0'\n const appName = config.name || 'SonicJS'\n\n // App version middleware\n app.use('*', async (c, next) => {\n c.set('appVersion', appVersion)\n await next()\n })\n\n // Bootstrap middleware\n // Note: Implementation will be imported from middleware/bootstrap\n // This is a placeholder for the factory pattern\n app.use('*', async (_c, next) => {\n // Bootstrap logic here (migrations, collections, plugins)\n await next()\n })\n\n // Custom middleware - before auth\n if (config.middleware?.beforeAuth) {\n for (const middleware of config.middleware.beforeAuth) {\n app.use('*', middleware)\n }\n }\n\n // Logging middleware\n app.use('*', async (_c, next) => {\n // Logging logic here\n await next()\n })\n\n // Security middleware\n app.use('*', async (_c, next) => {\n // Security headers, CORS, etc.\n await next()\n })\n\n // Custom middleware - after auth\n if (config.middleware?.afterAuth) {\n for (const middleware of config.middleware.afterAuth) {\n app.use('*', middleware)\n }\n }\n\n // Core routes\n // Routes are being imported incrementally from routes/*\n // Each route is tested and migrated one-by-one\n app.route('/api', apiRoutes)\n app.route('/api/media', apiMediaRoutes)\n app.route('/api/system', apiSystemRoutes)\n app.route('/admin/api', adminApiRoutes)\n app.route('/admin/content', adminContentRoutes)\n app.route('/auth', authRoutes)\n\n // Custom routes - User-defined routes\n if (config.routes) {\n for (const route of config.routes) {\n app.route(route.path, route.handler)\n }\n }\n\n // Health check\n app.get('/health', (c) => {\n return c.json({\n name: appName,\n version: appVersion,\n status: 'running',\n timestamp: new Date().toISOString()\n })\n })\n\n // 404 handler\n app.notFound((c) => {\n return c.json({ error: 'Not Found', status: 404 }, 404)\n })\n\n // Error handler\n app.onError((err, c) => {\n console.error(err)\n return c.json({ error: 'Internal Server Error', status: 500 }, 500)\n })\n\n return app\n}\n\n/**\n * Setup core middleware (backward compatibility)\n *\n * @param _app - Hono application\n * @deprecated Use createSonicJSApp() instead\n */\nexport function setupCoreMiddleware(_app: SonicJSApp): void {\n console.warn('setupCoreMiddleware is deprecated. Use createSonicJSApp() instead.')\n // Backward compatibility implementation\n}\n\n/**\n * Setup core routes (backward compatibility)\n *\n * @param _app - Hono application\n * @deprecated Use createSonicJSApp() instead\n */\nexport function setupCoreRoutes(_app: SonicJSApp): void {\n console.warn('setupCoreRoutes is deprecated. Use createSonicJSApp() instead.')\n // Backward compatibility implementation\n}\n","import { drizzle } from 'drizzle-orm/d1';\nimport * as schema from './schema';\n\nexport function createDb(d1: D1Database) {\n return drizzle(d1, { schema });\n}\n\nexport * from './schema';","/**\n * @sonicjs/core - Main Entry Point\n *\n * Core framework for SonicJS headless CMS\n * Built for Cloudflare's edge platform with TypeScript\n *\n * Phase 2 Migration Status:\n * - Week 1: Types, Utils, Database (COMPLETED ✓)\n * - Week 2: Services, Middleware, Plugins (COMPLETED ✓)\n * - Week 3: Routes, Templates (COMPLETED ✓)\n * - Week 4: Integration & Testing (COMPLETED ✓)\n *\n * Test Coverage:\n * - Utilities: 48 tests (sanitize, query-filter, metrics)\n * - Middleware: 51 tests (auth, logging, security, performance)\n * - Total: 99 tests passing\n */\n\n// ============================================================================\n// Main Application API (Phase 2 Week 1)\n// ============================================================================\n\nexport { createSonicJSApp, setupCoreMiddleware, setupCoreRoutes } from './app'\nexport type { SonicJSConfig, SonicJSApp, Bindings, Variables } from './app'\n\n// ============================================================================\n// Placeholders - To be populated in Phase 2\n// ============================================================================\n\n// Services - Week 2 (COMPLETED)\nexport {\n // Collection Management\n loadCollectionConfigs,\n loadCollectionConfig,\n getAvailableCollectionNames,\n validateCollectionConfig,\n syncCollections,\n syncCollection,\n isCollectionManaged,\n getManagedCollections,\n cleanupRemovedCollections,\n fullCollectionSync,\n // Database Migrations\n MigrationService,\n // Logging\n Logger,\n getLogger,\n initLogger,\n // Plugin Services - Class implementations\n PluginService as PluginServiceClass,\n PluginBootstrapService,\n} from './services'\n\nexport type { Migration, MigrationStatus, LogLevel, LogCategory, LogEntry, LogFilter, CorePlugin } from './services'\n\n// Middleware - Week 2 (COMPLETED)\nexport {\n // Authentication\n AuthManager,\n requireAuth,\n requireRole,\n optionalAuth,\n // Logging\n loggingMiddleware,\n detailedLoggingMiddleware,\n securityLoggingMiddleware,\n performanceLoggingMiddleware,\n // Performance\n cacheHeaders,\n compressionMiddleware,\n securityHeaders,\n // Permissions\n PermissionManager,\n requirePermission,\n requireAnyPermission,\n logActivity,\n // Plugin middleware\n requireActivePlugin,\n requireActivePlugins,\n getActivePlugins,\n isPluginActive,\n // Bootstrap\n bootstrapMiddleware,\n} from './middleware'\n\nexport type { Permission, UserPermissions } from './middleware'\n\n// Plugins - Week 2 (COMPLETED)\nexport {\n // Hook System - Class implementations\n HookSystemImpl,\n ScopedHookSystem as ScopedHookSystemClass,\n HookUtils,\n // Plugin Registry\n PluginRegistryImpl,\n // Plugin Manager - Class implementation\n PluginManager as PluginManagerClass,\n // Plugin Validator - Class implementation\n PluginValidator as PluginValidatorClass,\n} from './plugins'\n\n// Routes - Week 3 (COMPLETED)\nexport { ROUTES_INFO } from './routes'\n\n// Templates - Week 3 (COMPLETED)\nexport {\n // Form templates\n renderForm,\n renderFormField,\n // Table templates\n renderTable,\n // Pagination templates\n renderPagination,\n // Alert templates\n renderAlert,\n // Confirmation dialog templates\n renderConfirmationDialog,\n getConfirmationDialogScript,\n // Filter bar templates\n renderFilterBar,\n} from './templates'\n\nexport type {\n FormField,\n FormData,\n TableColumn,\n TableData,\n PaginationData,\n AlertData,\n ConfirmationDialogOptions,\n FilterBarData,\n Filter,\n FilterOption,\n} from './templates'\n\n// Types - Week 1 (COMPLETED)\nexport type {\n // Collection types\n FieldType,\n FieldConfig,\n CollectionSchema,\n CollectionConfig,\n CollectionConfigModule,\n CollectionSyncResult,\n // Plugin types\n Plugin,\n PluginContext,\n PluginConfig,\n PluginRoutes,\n PluginMiddleware,\n PluginModel,\n PluginService,\n PluginAdminPage,\n PluginComponent,\n PluginMenuItem,\n PluginHook,\n HookHandler,\n HookContext,\n HookSystem,\n ScopedHookSystem,\n PluginRegistry,\n PluginManager,\n PluginStatus,\n AuthService,\n ContentService,\n MediaService,\n PluginLogger,\n PluginBuilderOptions,\n PluginValidator,\n PluginValidationResult,\n HookName,\n // Plugin manifest\n PluginManifest,\n} from './types'\n\nexport { HOOKS } from './types'\n\n// Utils - Week 1 (COMPLETED)\nexport {\n // Sanitization\n escapeHtml,\n sanitizeInput,\n sanitizeObject,\n // Template rendering\n TemplateRenderer,\n templateRenderer,\n renderTemplate,\n // Query filtering\n QueryFilterBuilder,\n buildQuery,\n // Metrics\n metricsTracker,\n} from './utils'\n\nexport type {\n FilterOperator,\n FilterCondition,\n FilterGroup,\n QueryFilter,\n QueryResult,\n} from './utils'\n\n// Database - Week 1 (COMPLETED)\nexport {\n createDb,\n // Schema exports\n users,\n collections,\n content,\n contentVersions,\n media,\n apiTokens,\n workflowHistory,\n plugins,\n pluginHooks,\n pluginRoutes,\n pluginAssets,\n pluginActivityLog,\n systemLogs,\n logConfig,\n // Zod validation schemas\n insertUserSchema,\n selectUserSchema,\n insertCollectionSchema,\n selectCollectionSchema,\n insertContentSchema,\n selectContentSchema,\n insertMediaSchema,\n selectMediaSchema,\n insertWorkflowHistorySchema,\n selectWorkflowHistorySchema,\n insertPluginSchema,\n selectPluginSchema,\n insertPluginHookSchema,\n selectPluginHookSchema,\n insertPluginRouteSchema,\n selectPluginRouteSchema,\n insertPluginAssetSchema,\n selectPluginAssetSchema,\n insertPluginActivityLogSchema,\n selectPluginActivityLogSchema,\n insertSystemLogSchema,\n selectSystemLogSchema,\n insertLogConfigSchema,\n selectLogConfigSchema,\n} from './db'\n\nexport type {\n User,\n NewUser,\n Collection,\n NewCollection,\n Content,\n NewContent,\n Media,\n NewMedia,\n WorkflowHistory,\n NewWorkflowHistory,\n Plugin as DbPlugin,\n NewPlugin,\n PluginHook as DbPluginHook,\n NewPluginHook,\n PluginRoute,\n NewPluginRoute,\n PluginAsset,\n NewPluginAsset,\n PluginActivityLog,\n NewPluginActivityLog,\n SystemLog,\n NewSystemLog,\n LogConfig,\n NewLogConfig,\n} from './db'\n\n// Plugins - Week 2\n// export { PluginBuilder, HookSystem } from './plugins/sdk'\n\n// ============================================================================\n// Version\n// ============================================================================\n\nexport const VERSION = '2.0.0-alpha.3'\n\n// ============================================================================\n// Phase 2 Migration Notes\n// ============================================================================\n\n/**\n * This is a work-in-progress package being extracted from the main SonicJS codebase.\n *\n * Current Phase: 2 (Core Module Migration)\n * Current Week: 1 (Types, Utils, Database)\n *\n * Expected completion: 4 weeks from 2025-01-17\n *\n * DO NOT USE IN PRODUCTION - Alpha release for development only\n */\n"]}
1
+ {"version":3,"sources":["../src/app.ts","../src/db/index.ts","../src/index.ts"],"names":[],"mappings":"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","file":"index.js","sourcesContent":["/**\n * Main Application Factory\n *\n * Creates a configured SonicJS application with all core functionality\n */\n\nimport { Hono } from 'hono'\nimport type { Context } from 'hono'\nimport type { D1Database, KVNamespace, R2Bucket } from '@cloudflare/workers-types'\nimport { apiRoutes, apiMediaRoutes, apiSystemRoutes, adminApiRoutes, authRoutes, adminContentRoutes, adminUsersRoutes } from './routes'\n\n// ============================================================================\n// Type Definitions\n// ============================================================================\n\nexport interface Bindings {\n DB: D1Database\n CACHE_KV: KVNamespace\n MEDIA_BUCKET: R2Bucket\n ASSETS: Fetcher\n EMAIL_QUEUE?: Queue\n SENDGRID_API_KEY?: string\n DEFAULT_FROM_EMAIL?: string\n IMAGES_ACCOUNT_ID?: string\n IMAGES_API_TOKEN?: string\n ENVIRONMENT?: string\n}\n\nexport interface Variables {\n user?: {\n userId: string\n email: string\n role: string\n exp: number\n iat: number\n }\n requestId?: string\n startTime?: number\n appVersion?: string\n}\n\nexport interface SonicJSConfig {\n // Collections configuration\n collections?: {\n directory?: string\n autoSync?: boolean\n }\n\n // Plugins configuration\n plugins?: {\n directory?: string\n autoLoad?: boolean\n }\n\n // Custom routes\n routes?: Array<{\n path: string\n handler: Hono\n }>\n\n // Custom middleware\n middleware?: {\n beforeAuth?: Array<(c: Context, next: () => Promise<void>) => Promise<void>>\n afterAuth?: Array<(c: Context, next: () => Promise<void>) => Promise<void>>\n }\n\n // App metadata\n version?: string\n name?: string\n}\n\nexport type SonicJSApp = Hono<{ Bindings: Bindings; Variables: Variables }>\n\n// ============================================================================\n// Application Factory\n// ============================================================================\n\n/**\n * Create a SonicJS application with core functionality\n *\n * @param config - Application configuration\n * @returns Configured Hono application\n *\n * @example\n * ```typescript\n * import { createSonicJSApp } from '@sonicjs/core'\n *\n * const app = createSonicJSApp({\n * collections: {\n * directory: './src/collections',\n * autoSync: true\n * },\n * plugins: {\n * directory: './src/plugins',\n * autoLoad: true\n * }\n * })\n *\n * export default app\n * ```\n */\nexport function createSonicJSApp(config: SonicJSConfig = {}): SonicJSApp {\n const app = new Hono<{ Bindings: Bindings; Variables: Variables }>()\n\n // Set app metadata\n const appVersion = config.version || '1.0.0'\n const appName = config.name || 'SonicJS'\n\n // App version middleware\n app.use('*', async (c, next) => {\n c.set('appVersion', appVersion)\n await next()\n })\n\n // Bootstrap middleware\n // Note: Implementation will be imported from middleware/bootstrap\n // This is a placeholder for the factory pattern\n app.use('*', async (_c, next) => {\n // Bootstrap logic here (migrations, collections, plugins)\n await next()\n })\n\n // Custom middleware - before auth\n if (config.middleware?.beforeAuth) {\n for (const middleware of config.middleware.beforeAuth) {\n app.use('*', middleware)\n }\n }\n\n // Logging middleware\n app.use('*', async (_c, next) => {\n // Logging logic here\n await next()\n })\n\n // Security middleware\n app.use('*', async (_c, next) => {\n // Security headers, CORS, etc.\n await next()\n })\n\n // Custom middleware - after auth\n if (config.middleware?.afterAuth) {\n for (const middleware of config.middleware.afterAuth) {\n app.use('*', middleware)\n }\n }\n\n // Core routes\n // Routes are being imported incrementally from routes/*\n // Each route is tested and migrated one-by-one\n app.route('/api', apiRoutes)\n app.route('/api/media', apiMediaRoutes)\n app.route('/api/system', apiSystemRoutes)\n app.route('/admin/api', adminApiRoutes)\n app.route('/admin/content', adminContentRoutes)\n app.route('/admin', adminUsersRoutes)\n app.route('/auth', authRoutes)\n\n // Custom routes - User-defined routes\n if (config.routes) {\n for (const route of config.routes) {\n app.route(route.path, route.handler)\n }\n }\n\n // Root redirect to login\n app.get('/', (c) => {\n return c.redirect('/auth/login')\n })\n\n // Health check\n app.get('/health', (c) => {\n return c.json({\n name: appName,\n version: appVersion,\n status: 'running',\n timestamp: new Date().toISOString()\n })\n })\n\n // 404 handler\n app.notFound((c) => {\n return c.json({ error: 'Not Found', status: 404 }, 404)\n })\n\n // Error handler\n app.onError((err, c) => {\n console.error(err)\n return c.json({ error: 'Internal Server Error', status: 500 }, 500)\n })\n\n return app\n}\n\n/**\n * Setup core middleware (backward compatibility)\n *\n * @param _app - Hono application\n * @deprecated Use createSonicJSApp() instead\n */\nexport function setupCoreMiddleware(_app: SonicJSApp): void {\n console.warn('setupCoreMiddleware is deprecated. Use createSonicJSApp() instead.')\n // Backward compatibility implementation\n}\n\n/**\n * Setup core routes (backward compatibility)\n *\n * @param _app - Hono application\n * @deprecated Use createSonicJSApp() instead\n */\nexport function setupCoreRoutes(_app: SonicJSApp): void {\n console.warn('setupCoreRoutes is deprecated. Use createSonicJSApp() instead.')\n // Backward compatibility implementation\n}\n","import { drizzle } from 'drizzle-orm/d1';\nimport * as schema from './schema';\n\nexport function createDb(d1: D1Database) {\n return drizzle(d1, { schema });\n}\n\nexport * from './schema';","/**\n * @sonicjs/core - Main Entry Point\n *\n * Core framework for SonicJS headless CMS\n * Built for Cloudflare's edge platform with TypeScript\n *\n * Phase 2 Migration Status:\n * - Week 1: Types, Utils, Database (COMPLETED ✓)\n * - Week 2: Services, Middleware, Plugins (COMPLETED ✓)\n * - Week 3: Routes, Templates (COMPLETED ✓)\n * - Week 4: Integration & Testing (COMPLETED ✓)\n *\n * Test Coverage:\n * - Utilities: 48 tests (sanitize, query-filter, metrics)\n * - Middleware: 51 tests (auth, logging, security, performance)\n * - Total: 99 tests passing\n */\n\n// ============================================================================\n// Main Application API (Phase 2 Week 1)\n// ============================================================================\n\nexport { createSonicJSApp, setupCoreMiddleware, setupCoreRoutes } from './app'\nexport type { SonicJSConfig, SonicJSApp, Bindings, Variables } from './app'\n\n// ============================================================================\n// Placeholders - To be populated in Phase 2\n// ============================================================================\n\n// Services - Week 2 (COMPLETED)\nexport {\n // Collection Management\n loadCollectionConfigs,\n loadCollectionConfig,\n getAvailableCollectionNames,\n validateCollectionConfig,\n syncCollections,\n syncCollection,\n isCollectionManaged,\n getManagedCollections,\n cleanupRemovedCollections,\n fullCollectionSync,\n // Database Migrations\n MigrationService,\n // Logging\n Logger,\n getLogger,\n initLogger,\n // Plugin Services - Class implementations\n PluginService as PluginServiceClass,\n PluginBootstrapService,\n} from './services'\n\nexport type { Migration, MigrationStatus, LogLevel, LogCategory, LogEntry, LogFilter, CorePlugin } from './services'\n\n// Middleware - Week 2 (COMPLETED)\nexport {\n // Authentication\n AuthManager,\n requireAuth,\n requireRole,\n optionalAuth,\n // Logging\n loggingMiddleware,\n detailedLoggingMiddleware,\n securityLoggingMiddleware,\n performanceLoggingMiddleware,\n // Performance\n cacheHeaders,\n compressionMiddleware,\n securityHeaders,\n // Permissions\n PermissionManager,\n requirePermission,\n requireAnyPermission,\n logActivity,\n // Plugin middleware\n requireActivePlugin,\n requireActivePlugins,\n getActivePlugins,\n isPluginActive,\n // Bootstrap\n bootstrapMiddleware,\n} from './middleware'\n\nexport type { Permission, UserPermissions } from './middleware'\n\n// Plugins - Week 2 (COMPLETED)\nexport {\n // Hook System - Class implementations\n HookSystemImpl,\n ScopedHookSystem as ScopedHookSystemClass,\n HookUtils,\n // Plugin Registry\n PluginRegistryImpl,\n // Plugin Manager - Class implementation\n PluginManager as PluginManagerClass,\n // Plugin Validator - Class implementation\n PluginValidator as PluginValidatorClass,\n} from './plugins'\n\n// Routes - Week 3 (COMPLETED)\nexport { ROUTES_INFO } from './routes'\n\n// Templates - Week 3 (COMPLETED)\nexport {\n // Form templates\n renderForm,\n renderFormField,\n // Table templates\n renderTable,\n // Pagination templates\n renderPagination,\n // Alert templates\n renderAlert,\n // Confirmation dialog templates\n renderConfirmationDialog,\n getConfirmationDialogScript,\n // Filter bar templates\n renderFilterBar,\n} from './templates'\n\nexport type {\n FormField,\n FormData,\n TableColumn,\n TableData,\n PaginationData,\n AlertData,\n ConfirmationDialogOptions,\n FilterBarData,\n Filter,\n FilterOption,\n} from './templates'\n\n// Types - Week 1 (COMPLETED)\nexport type {\n // Collection types\n FieldType,\n FieldConfig,\n CollectionSchema,\n CollectionConfig,\n CollectionConfigModule,\n CollectionSyncResult,\n // Plugin types\n Plugin,\n PluginContext,\n PluginConfig,\n PluginRoutes,\n PluginMiddleware,\n PluginModel,\n PluginService,\n PluginAdminPage,\n PluginComponent,\n PluginMenuItem,\n PluginHook,\n HookHandler,\n HookContext,\n HookSystem,\n ScopedHookSystem,\n PluginRegistry,\n PluginManager,\n PluginStatus,\n AuthService,\n ContentService,\n MediaService,\n PluginLogger,\n PluginBuilderOptions,\n PluginValidator,\n PluginValidationResult,\n HookName,\n // Plugin manifest\n PluginManifest,\n} from './types'\n\nexport { HOOKS } from './types'\n\n// Utils - Week 1 (COMPLETED)\nexport {\n // Sanitization\n escapeHtml,\n sanitizeInput,\n sanitizeObject,\n // Template rendering\n TemplateRenderer,\n templateRenderer,\n renderTemplate,\n // Query filtering\n QueryFilterBuilder,\n buildQuery,\n // Metrics\n metricsTracker,\n} from './utils'\n\nexport type {\n FilterOperator,\n FilterCondition,\n FilterGroup,\n QueryFilter,\n QueryResult,\n} from './utils'\n\n// Database - Week 1 (COMPLETED)\nexport {\n createDb,\n // Schema exports\n users,\n collections,\n content,\n contentVersions,\n media,\n apiTokens,\n workflowHistory,\n plugins,\n pluginHooks,\n pluginRoutes,\n pluginAssets,\n pluginActivityLog,\n systemLogs,\n logConfig,\n // Zod validation schemas\n insertUserSchema,\n selectUserSchema,\n insertCollectionSchema,\n selectCollectionSchema,\n insertContentSchema,\n selectContentSchema,\n insertMediaSchema,\n selectMediaSchema,\n insertWorkflowHistorySchema,\n selectWorkflowHistorySchema,\n insertPluginSchema,\n selectPluginSchema,\n insertPluginHookSchema,\n selectPluginHookSchema,\n insertPluginRouteSchema,\n selectPluginRouteSchema,\n insertPluginAssetSchema,\n selectPluginAssetSchema,\n insertPluginActivityLogSchema,\n selectPluginActivityLogSchema,\n insertSystemLogSchema,\n selectSystemLogSchema,\n insertLogConfigSchema,\n selectLogConfigSchema,\n} from './db'\n\nexport type {\n User,\n NewUser,\n Collection,\n NewCollection,\n Content,\n NewContent,\n Media,\n NewMedia,\n WorkflowHistory,\n NewWorkflowHistory,\n Plugin as DbPlugin,\n NewPlugin,\n PluginHook as DbPluginHook,\n NewPluginHook,\n PluginRoute,\n NewPluginRoute,\n PluginAsset,\n NewPluginAsset,\n PluginActivityLog,\n NewPluginActivityLog,\n SystemLog,\n NewSystemLog,\n LogConfig,\n NewLogConfig,\n} from './db'\n\n// Plugins - Week 2\n// export { PluginBuilder, HookSystem } from './plugins/sdk'\n\n// ============================================================================\n// Version\n// ============================================================================\n\nexport const VERSION = '2.0.0-alpha.3'\n\n// ============================================================================\n// Phase 2 Migration Notes\n// ============================================================================\n\n/**\n * This is a work-in-progress package being extracted from the main SonicJS codebase.\n *\n * Current Phase: 2 (Core Module Migration)\n * Current Week: 1 (Types, Utils, Database)\n *\n * Expected completion: 4 weeks from 2025-01-17\n *\n * DO NOT USE IN PRODUCTION - Alpha release for development only\n */\n"]}
@@ -1,90 +1,90 @@
1
1
  'use strict';
2
2
 
3
- var chunk24PWAFUT_cjs = require('./chunk-24PWAFUT.cjs');
4
- require('./chunk-WJ7QYVR2.cjs');
5
- require('./chunk-EMMSS5I5.cjs');
3
+ var chunkBUKT6HP5_cjs = require('./chunk-BUKT6HP5.cjs');
4
+ require('./chunk-RNR4HA23.cjs');
5
+ require('./chunk-IGJUBJBW.cjs');
6
6
 
7
7
 
8
8
 
9
9
  Object.defineProperty(exports, "AuthManager", {
10
10
  enumerable: true,
11
- get: function () { return chunk24PWAFUT_cjs.AuthManager; }
11
+ get: function () { return chunkBUKT6HP5_cjs.AuthManager; }
12
12
  });
13
13
  Object.defineProperty(exports, "PermissionManager", {
14
14
  enumerable: true,
15
- get: function () { return chunk24PWAFUT_cjs.PermissionManager; }
15
+ get: function () { return chunkBUKT6HP5_cjs.PermissionManager; }
16
16
  });
17
17
  Object.defineProperty(exports, "bootstrapMiddleware", {
18
18
  enumerable: true,
19
- get: function () { return chunk24PWAFUT_cjs.bootstrapMiddleware; }
19
+ get: function () { return chunkBUKT6HP5_cjs.bootstrapMiddleware; }
20
20
  });
21
21
  Object.defineProperty(exports, "cacheHeaders", {
22
22
  enumerable: true,
23
- get: function () { return chunk24PWAFUT_cjs.cacheHeaders; }
23
+ get: function () { return chunkBUKT6HP5_cjs.cacheHeaders; }
24
24
  });
25
25
  Object.defineProperty(exports, "compressionMiddleware", {
26
26
  enumerable: true,
27
- get: function () { return chunk24PWAFUT_cjs.compressionMiddleware; }
27
+ get: function () { return chunkBUKT6HP5_cjs.compressionMiddleware; }
28
28
  });
29
29
  Object.defineProperty(exports, "detailedLoggingMiddleware", {
30
30
  enumerable: true,
31
- get: function () { return chunk24PWAFUT_cjs.detailedLoggingMiddleware; }
31
+ get: function () { return chunkBUKT6HP5_cjs.detailedLoggingMiddleware; }
32
32
  });
33
33
  Object.defineProperty(exports, "getActivePlugins", {
34
34
  enumerable: true,
35
- get: function () { return chunk24PWAFUT_cjs.getActivePlugins; }
35
+ get: function () { return chunkBUKT6HP5_cjs.getActivePlugins; }
36
36
  });
37
37
  Object.defineProperty(exports, "isPluginActive", {
38
38
  enumerable: true,
39
- get: function () { return chunk24PWAFUT_cjs.isPluginActive; }
39
+ get: function () { return chunkBUKT6HP5_cjs.isPluginActive; }
40
40
  });
41
41
  Object.defineProperty(exports, "logActivity", {
42
42
  enumerable: true,
43
- get: function () { return chunk24PWAFUT_cjs.logActivity; }
43
+ get: function () { return chunkBUKT6HP5_cjs.logActivity; }
44
44
  });
45
45
  Object.defineProperty(exports, "loggingMiddleware", {
46
46
  enumerable: true,
47
- get: function () { return chunk24PWAFUT_cjs.loggingMiddleware; }
47
+ get: function () { return chunkBUKT6HP5_cjs.loggingMiddleware; }
48
48
  });
49
49
  Object.defineProperty(exports, "optionalAuth", {
50
50
  enumerable: true,
51
- get: function () { return chunk24PWAFUT_cjs.optionalAuth; }
51
+ get: function () { return chunkBUKT6HP5_cjs.optionalAuth; }
52
52
  });
53
53
  Object.defineProperty(exports, "performanceLoggingMiddleware", {
54
54
  enumerable: true,
55
- get: function () { return chunk24PWAFUT_cjs.performanceLoggingMiddleware; }
55
+ get: function () { return chunkBUKT6HP5_cjs.performanceLoggingMiddleware; }
56
56
  });
57
57
  Object.defineProperty(exports, "requireActivePlugin", {
58
58
  enumerable: true,
59
- get: function () { return chunk24PWAFUT_cjs.requireActivePlugin; }
59
+ get: function () { return chunkBUKT6HP5_cjs.requireActivePlugin; }
60
60
  });
61
61
  Object.defineProperty(exports, "requireActivePlugins", {
62
62
  enumerable: true,
63
- get: function () { return chunk24PWAFUT_cjs.requireActivePlugins; }
63
+ get: function () { return chunkBUKT6HP5_cjs.requireActivePlugins; }
64
64
  });
65
65
  Object.defineProperty(exports, "requireAnyPermission", {
66
66
  enumerable: true,
67
- get: function () { return chunk24PWAFUT_cjs.requireAnyPermission; }
67
+ get: function () { return chunkBUKT6HP5_cjs.requireAnyPermission; }
68
68
  });
69
69
  Object.defineProperty(exports, "requireAuth", {
70
70
  enumerable: true,
71
- get: function () { return chunk24PWAFUT_cjs.requireAuth; }
71
+ get: function () { return chunkBUKT6HP5_cjs.requireAuth; }
72
72
  });
73
73
  Object.defineProperty(exports, "requirePermission", {
74
74
  enumerable: true,
75
- get: function () { return chunk24PWAFUT_cjs.requirePermission; }
75
+ get: function () { return chunkBUKT6HP5_cjs.requirePermission; }
76
76
  });
77
77
  Object.defineProperty(exports, "requireRole", {
78
78
  enumerable: true,
79
- get: function () { return chunk24PWAFUT_cjs.requireRole; }
79
+ get: function () { return chunkBUKT6HP5_cjs.requireRole; }
80
80
  });
81
81
  Object.defineProperty(exports, "securityHeaders", {
82
82
  enumerable: true,
83
- get: function () { return chunk24PWAFUT_cjs.securityHeaders; }
83
+ get: function () { return chunkBUKT6HP5_cjs.securityHeaders; }
84
84
  });
85
85
  Object.defineProperty(exports, "securityLoggingMiddleware", {
86
86
  enumerable: true,
87
- get: function () { return chunk24PWAFUT_cjs.securityLoggingMiddleware; }
87
+ get: function () { return chunkBUKT6HP5_cjs.securityLoggingMiddleware; }
88
88
  });
89
89
  //# sourceMappingURL=middleware.cjs.map
90
90
  //# sourceMappingURL=middleware.cjs.map
@@ -1,5 +1,5 @@
1
- export { AuthManager, PermissionManager, bootstrapMiddleware, cacheHeaders, compressionMiddleware, detailedLoggingMiddleware, getActivePlugins, isPluginActive, logActivity, loggingMiddleware, optionalAuth, performanceLoggingMiddleware, requireActivePlugin, requireActivePlugins, requireAnyPermission, requireAuth, requirePermission, requireRole, securityHeaders, securityLoggingMiddleware } from './chunk-PTQZ5FEI.js';
2
- import './chunk-CXZDAR6S.js';
3
- import './chunk-G3PMV62Z.js';
1
+ export { AuthManager, PermissionManager, bootstrapMiddleware, cacheHeaders, compressionMiddleware, detailedLoggingMiddleware, getActivePlugins, isPluginActive, logActivity, loggingMiddleware, optionalAuth, performanceLoggingMiddleware, requireActivePlugin, requireActivePlugins, requireAnyPermission, requireAuth, requirePermission, requireRole, securityHeaders, securityLoggingMiddleware } from './chunk-WESS2U3K.js';
2
+ import './chunk-7N3HK7ZK.js';
3
+ import './chunk-V4OQ3NZ2.js';
4
4
  //# sourceMappingURL=middleware.js.map
5
5
  //# sourceMappingURL=middleware.js.map
package/dist/plugins.cjs CHANGED
@@ -1,34 +1,34 @@
1
1
  'use strict';
2
2
 
3
- var chunkL3NXO7Y4_cjs = require('./chunk-L3NXO7Y4.cjs');
3
+ var chunkFVMV5DKA_cjs = require('./chunk-FVMV5DKA.cjs');
4
4
  require('./chunk-KYGRJCZM.cjs');
5
- require('./chunk-EMMSS5I5.cjs');
5
+ require('./chunk-IGJUBJBW.cjs');
6
6
 
7
7
 
8
8
 
9
9
  Object.defineProperty(exports, "HookSystemImpl", {
10
10
  enumerable: true,
11
- get: function () { return chunkL3NXO7Y4_cjs.HookSystemImpl; }
11
+ get: function () { return chunkFVMV5DKA_cjs.HookSystemImpl; }
12
12
  });
13
13
  Object.defineProperty(exports, "HookUtils", {
14
14
  enumerable: true,
15
- get: function () { return chunkL3NXO7Y4_cjs.HookUtils; }
15
+ get: function () { return chunkFVMV5DKA_cjs.HookUtils; }
16
16
  });
17
17
  Object.defineProperty(exports, "PluginManager", {
18
18
  enumerable: true,
19
- get: function () { return chunkL3NXO7Y4_cjs.PluginManager; }
19
+ get: function () { return chunkFVMV5DKA_cjs.PluginManager; }
20
20
  });
21
21
  Object.defineProperty(exports, "PluginRegistryImpl", {
22
22
  enumerable: true,
23
- get: function () { return chunkL3NXO7Y4_cjs.PluginRegistryImpl; }
23
+ get: function () { return chunkFVMV5DKA_cjs.PluginRegistryImpl; }
24
24
  });
25
25
  Object.defineProperty(exports, "PluginValidator", {
26
26
  enumerable: true,
27
- get: function () { return chunkL3NXO7Y4_cjs.PluginValidator; }
27
+ get: function () { return chunkFVMV5DKA_cjs.PluginValidator; }
28
28
  });
29
29
  Object.defineProperty(exports, "ScopedHookSystem", {
30
30
  enumerable: true,
31
- get: function () { return chunkL3NXO7Y4_cjs.ScopedHookSystem; }
31
+ get: function () { return chunkFVMV5DKA_cjs.ScopedHookSystem; }
32
32
  });
33
33
  //# sourceMappingURL=plugins.cjs.map
34
34
  //# sourceMappingURL=plugins.cjs.map
package/dist/plugins.js CHANGED
@@ -1,5 +1,5 @@
1
- export { HookSystemImpl, HookUtils, PluginManager, PluginRegistryImpl, PluginValidator, ScopedHookSystem } from './chunk-NRSL6BQI.js';
1
+ export { HookSystemImpl, HookUtils, PluginManager, PluginRegistryImpl, PluginValidator, ScopedHookSystem } from './chunk-BITQ4MFX.js';
2
2
  import './chunk-LOUJRBXV.js';
3
- import './chunk-G3PMV62Z.js';
3
+ import './chunk-V4OQ3NZ2.js';
4
4
  //# sourceMappingURL=plugins.js.map
5
5
  //# sourceMappingURL=plugins.js.map
package/dist/routes.cjs CHANGED
@@ -1,45 +1,49 @@
1
1
  'use strict';
2
2
 
3
- var chunkKWFUNPSQ_cjs = require('./chunk-KWFUNPSQ.cjs');
3
+ var chunkY6VF3YFA_cjs = require('./chunk-Y6VF3YFA.cjs');
4
4
  require('./chunk-AGOE25LF.cjs');
5
- require('./chunk-24PWAFUT.cjs');
6
- require('./chunk-WJ7QYVR2.cjs');
5
+ require('./chunk-BUKT6HP5.cjs');
6
+ require('./chunk-RNR4HA23.cjs');
7
7
  require('./chunk-RGCQSFKC.cjs');
8
- require('./chunk-EMMSS5I5.cjs');
8
+ require('./chunk-IGJUBJBW.cjs');
9
9
 
10
10
 
11
11
 
12
12
  Object.defineProperty(exports, "ROUTES_INFO", {
13
13
  enumerable: true,
14
- get: function () { return chunkKWFUNPSQ_cjs.ROUTES_INFO; }
14
+ get: function () { return chunkY6VF3YFA_cjs.ROUTES_INFO; }
15
15
  });
16
16
  Object.defineProperty(exports, "adminApiRoutes", {
17
17
  enumerable: true,
18
- get: function () { return chunkKWFUNPSQ_cjs.admin_api_default; }
18
+ get: function () { return chunkY6VF3YFA_cjs.admin_api_default; }
19
19
  });
20
20
  Object.defineProperty(exports, "adminContentRoutes", {
21
21
  enumerable: true,
22
- get: function () { return chunkKWFUNPSQ_cjs.admin_content_default; }
22
+ get: function () { return chunkY6VF3YFA_cjs.admin_content_default; }
23
+ });
24
+ Object.defineProperty(exports, "adminUsersRoutes", {
25
+ enumerable: true,
26
+ get: function () { return chunkY6VF3YFA_cjs.userRoutes; }
23
27
  });
24
28
  Object.defineProperty(exports, "apiContentCrudRoutes", {
25
29
  enumerable: true,
26
- get: function () { return chunkKWFUNPSQ_cjs.api_content_crud_default; }
30
+ get: function () { return chunkY6VF3YFA_cjs.api_content_crud_default; }
27
31
  });
28
32
  Object.defineProperty(exports, "apiMediaRoutes", {
29
33
  enumerable: true,
30
- get: function () { return chunkKWFUNPSQ_cjs.api_media_default; }
34
+ get: function () { return chunkY6VF3YFA_cjs.api_media_default; }
31
35
  });
32
36
  Object.defineProperty(exports, "apiRoutes", {
33
37
  enumerable: true,
34
- get: function () { return chunkKWFUNPSQ_cjs.api_default; }
38
+ get: function () { return chunkY6VF3YFA_cjs.api_default; }
35
39
  });
36
40
  Object.defineProperty(exports, "apiSystemRoutes", {
37
41
  enumerable: true,
38
- get: function () { return chunkKWFUNPSQ_cjs.api_system_default; }
42
+ get: function () { return chunkY6VF3YFA_cjs.api_system_default; }
39
43
  });
40
44
  Object.defineProperty(exports, "authRoutes", {
41
45
  enumerable: true,
42
- get: function () { return chunkKWFUNPSQ_cjs.auth_default; }
46
+ get: function () { return chunkY6VF3YFA_cjs.auth_default; }
43
47
  });
44
48
  //# sourceMappingURL=routes.cjs.map
45
49
  //# sourceMappingURL=routes.cjs.map
package/dist/routes.js CHANGED
@@ -1,8 +1,8 @@
1
- export { ROUTES_INFO, admin_api_default as adminApiRoutes, admin_content_default as adminContentRoutes, api_content_crud_default as apiContentCrudRoutes, api_media_default as apiMediaRoutes, api_default as apiRoutes, api_system_default as apiSystemRoutes, auth_default as authRoutes } from './chunk-5RDID2QZ.js';
1
+ export { ROUTES_INFO, admin_api_default as adminApiRoutes, admin_content_default as adminContentRoutes, userRoutes as adminUsersRoutes, api_content_crud_default as apiContentCrudRoutes, api_media_default as apiMediaRoutes, api_default as apiRoutes, api_system_default as apiSystemRoutes, auth_default as authRoutes } from './chunk-VY6FDZ6Y.js';
2
2
  import './chunk-3MNMOLSA.js';
3
- import './chunk-PTQZ5FEI.js';
4
- import './chunk-CXZDAR6S.js';
3
+ import './chunk-WESS2U3K.js';
4
+ import './chunk-7N3HK7ZK.js';
5
5
  import './chunk-JIINOD2W.js';
6
- import './chunk-G3PMV62Z.js';
6
+ import './chunk-V4OQ3NZ2.js';
7
7
  //# sourceMappingURL=routes.js.map
8
8
  //# sourceMappingURL=routes.js.map
package/dist/services.cjs CHANGED
@@ -1,8 +1,8 @@
1
1
  'use strict';
2
2
 
3
3
  var chunkAGOE25LF_cjs = require('./chunk-AGOE25LF.cjs');
4
- var chunkWJ7QYVR2_cjs = require('./chunk-WJ7QYVR2.cjs');
5
- require('./chunk-EMMSS5I5.cjs');
4
+ var chunkRNR4HA23_cjs = require('./chunk-RNR4HA23.cjs');
5
+ require('./chunk-IGJUBJBW.cjs');
6
6
 
7
7
 
8
8
 
@@ -20,67 +20,67 @@ Object.defineProperty(exports, "getCacheService", {
20
20
  });
21
21
  Object.defineProperty(exports, "Logger", {
22
22
  enumerable: true,
23
- get: function () { return chunkWJ7QYVR2_cjs.Logger; }
23
+ get: function () { return chunkRNR4HA23_cjs.Logger; }
24
24
  });
25
25
  Object.defineProperty(exports, "MigrationService", {
26
26
  enumerable: true,
27
- get: function () { return chunkWJ7QYVR2_cjs.MigrationService; }
27
+ get: function () { return chunkRNR4HA23_cjs.MigrationService; }
28
28
  });
29
29
  Object.defineProperty(exports, "PluginBootstrapService", {
30
30
  enumerable: true,
31
- get: function () { return chunkWJ7QYVR2_cjs.PluginBootstrapService; }
31
+ get: function () { return chunkRNR4HA23_cjs.PluginBootstrapService; }
32
32
  });
33
33
  Object.defineProperty(exports, "PluginService", {
34
34
  enumerable: true,
35
- get: function () { return chunkWJ7QYVR2_cjs.PluginService; }
35
+ get: function () { return chunkRNR4HA23_cjs.PluginService; }
36
36
  });
37
37
  Object.defineProperty(exports, "cleanupRemovedCollections", {
38
38
  enumerable: true,
39
- get: function () { return chunkWJ7QYVR2_cjs.cleanupRemovedCollections; }
39
+ get: function () { return chunkRNR4HA23_cjs.cleanupRemovedCollections; }
40
40
  });
41
41
  Object.defineProperty(exports, "fullCollectionSync", {
42
42
  enumerable: true,
43
- get: function () { return chunkWJ7QYVR2_cjs.fullCollectionSync; }
43
+ get: function () { return chunkRNR4HA23_cjs.fullCollectionSync; }
44
44
  });
45
45
  Object.defineProperty(exports, "getAvailableCollectionNames", {
46
46
  enumerable: true,
47
- get: function () { return chunkWJ7QYVR2_cjs.getAvailableCollectionNames; }
47
+ get: function () { return chunkRNR4HA23_cjs.getAvailableCollectionNames; }
48
48
  });
49
49
  Object.defineProperty(exports, "getLogger", {
50
50
  enumerable: true,
51
- get: function () { return chunkWJ7QYVR2_cjs.getLogger; }
51
+ get: function () { return chunkRNR4HA23_cjs.getLogger; }
52
52
  });
53
53
  Object.defineProperty(exports, "getManagedCollections", {
54
54
  enumerable: true,
55
- get: function () { return chunkWJ7QYVR2_cjs.getManagedCollections; }
55
+ get: function () { return chunkRNR4HA23_cjs.getManagedCollections; }
56
56
  });
57
57
  Object.defineProperty(exports, "initLogger", {
58
58
  enumerable: true,
59
- get: function () { return chunkWJ7QYVR2_cjs.initLogger; }
59
+ get: function () { return chunkRNR4HA23_cjs.initLogger; }
60
60
  });
61
61
  Object.defineProperty(exports, "isCollectionManaged", {
62
62
  enumerable: true,
63
- get: function () { return chunkWJ7QYVR2_cjs.isCollectionManaged; }
63
+ get: function () { return chunkRNR4HA23_cjs.isCollectionManaged; }
64
64
  });
65
65
  Object.defineProperty(exports, "loadCollectionConfig", {
66
66
  enumerable: true,
67
- get: function () { return chunkWJ7QYVR2_cjs.loadCollectionConfig; }
67
+ get: function () { return chunkRNR4HA23_cjs.loadCollectionConfig; }
68
68
  });
69
69
  Object.defineProperty(exports, "loadCollectionConfigs", {
70
70
  enumerable: true,
71
- get: function () { return chunkWJ7QYVR2_cjs.loadCollectionConfigs; }
71
+ get: function () { return chunkRNR4HA23_cjs.loadCollectionConfigs; }
72
72
  });
73
73
  Object.defineProperty(exports, "syncCollection", {
74
74
  enumerable: true,
75
- get: function () { return chunkWJ7QYVR2_cjs.syncCollection; }
75
+ get: function () { return chunkRNR4HA23_cjs.syncCollection; }
76
76
  });
77
77
  Object.defineProperty(exports, "syncCollections", {
78
78
  enumerable: true,
79
- get: function () { return chunkWJ7QYVR2_cjs.syncCollections; }
79
+ get: function () { return chunkRNR4HA23_cjs.syncCollections; }
80
80
  });
81
81
  Object.defineProperty(exports, "validateCollectionConfig", {
82
82
  enumerable: true,
83
- get: function () { return chunkWJ7QYVR2_cjs.validateCollectionConfig; }
83
+ get: function () { return chunkRNR4HA23_cjs.validateCollectionConfig; }
84
84
  });
85
85
  //# sourceMappingURL=services.cjs.map
86
86
  //# sourceMappingURL=services.cjs.map
package/dist/services.js CHANGED
@@ -1,5 +1,5 @@
1
1
  export { CACHE_CONFIGS, CacheService, getCacheService } from './chunk-3MNMOLSA.js';
2
- export { Logger, MigrationService, PluginBootstrapService, PluginService, cleanupRemovedCollections, fullCollectionSync, getAvailableCollectionNames, getLogger, getManagedCollections, initLogger, isCollectionManaged, loadCollectionConfig, loadCollectionConfigs, syncCollection, syncCollections, validateCollectionConfig } from './chunk-CXZDAR6S.js';
3
- import './chunk-G3PMV62Z.js';
2
+ export { Logger, MigrationService, PluginBootstrapService, PluginService, cleanupRemovedCollections, fullCollectionSync, getAvailableCollectionNames, getLogger, getManagedCollections, initLogger, isCollectionManaged, loadCollectionConfig, loadCollectionConfigs, syncCollection, syncCollections, validateCollectionConfig } from './chunk-7N3HK7ZK.js';
3
+ import './chunk-V4OQ3NZ2.js';
4
4
  //# sourceMappingURL=services.js.map
5
5
  //# sourceMappingURL=services.js.map
@@ -1,7 +1,7 @@
1
1
  'use strict';
2
2
 
3
3
  var chunkBRC3F4CG_cjs = require('./chunk-BRC3F4CG.cjs');
4
- require('./chunk-EMMSS5I5.cjs');
4
+ require('./chunk-IGJUBJBW.cjs');
5
5
 
6
6
 
7
7
 
package/dist/templates.js CHANGED
@@ -1,4 +1,4 @@
1
1
  export { getConfirmationDialogScript, renderAlert, renderConfirmationDialog, renderFilterBar, renderForm, renderFormField, renderPagination, renderTable } from './chunk-KRJMGD4E.js';
2
- import './chunk-G3PMV62Z.js';
2
+ import './chunk-V4OQ3NZ2.js';
3
3
  //# sourceMappingURL=templates.js.map
4
4
  //# sourceMappingURL=templates.js.map
package/dist/types.cjs CHANGED
@@ -1,7 +1,7 @@
1
1
  'use strict';
2
2
 
3
3
  var chunkKYGRJCZM_cjs = require('./chunk-KYGRJCZM.cjs');
4
- require('./chunk-EMMSS5I5.cjs');
4
+ require('./chunk-IGJUBJBW.cjs');
5
5
 
6
6
 
7
7
 
package/dist/types.js CHANGED
@@ -1,4 +1,4 @@
1
1
  export { HOOKS } from './chunk-LOUJRBXV.js';
2
- import './chunk-G3PMV62Z.js';
2
+ import './chunk-V4OQ3NZ2.js';
3
3
  //# sourceMappingURL=types.js.map
4
4
  //# sourceMappingURL=types.js.map
package/dist/utils.cjs CHANGED
@@ -1,7 +1,7 @@
1
1
  'use strict';
2
2
 
3
3
  var chunkRGCQSFKC_cjs = require('./chunk-RGCQSFKC.cjs');
4
- require('./chunk-EMMSS5I5.cjs');
4
+ require('./chunk-IGJUBJBW.cjs');
5
5
 
6
6
 
7
7
 
package/dist/utils.js CHANGED
@@ -1,4 +1,4 @@
1
1
  export { QueryFilterBuilder, TemplateRenderer, buildQuery, escapeHtml, metricsTracker, renderTemplate, sanitizeInput, sanitizeObject, templateRenderer } from './chunk-JIINOD2W.js';
2
- import './chunk-G3PMV62Z.js';
2
+ import './chunk-V4OQ3NZ2.js';
3
3
  //# sourceMappingURL=utils.js.map
4
4
  //# sourceMappingURL=utils.js.map
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@sonicjs-cms/core",
3
- "version": "2.0.0-alpha.5",
3
+ "version": "2.0.0-alpha.7",
4
4
  "description": "Core framework for SonicJS headless CMS - Edge-first, TypeScript-native CMS built for Cloudflare Workers",
5
5
  "type": "module",
6
6
  "main": "./dist/index.cjs",