@worktif/runtime 0.3.0-edge.15 → 0.3.0-edge.16
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/out/dist/lib/index.d.ts
CHANGED
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
export
|
|
2
|
-
export
|
|
1
|
+
export { pureweb, ConfigValidationError, EnvironmentDetectionError, createRuntimeConfig, extractRuntimeConfig, isRuntimeConfig, mergeRuntimeConfig, isValidServiceName, } from './lib/runtime-web';
|
|
2
|
+
export type { RuntimeWebConfig, TypeSafePurenowConfig, Stage, ServiceNames, LambdaIds, ValidServiceName, RuntimeConfig, } from './lib/runtime-web';
|
|
3
3
|
//# sourceMappingURL=index.d.ts.map
|
package/out/dist/lib/index.js
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
"use strict";var
|
|
2
|
-
${r.map(
|
|
3
|
-
`)}`),this.name="ConfigValidationError",this.errors=r,Error.captureStackTrace(this,this.constructor)}},
|
|
4
|
-
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../src/index.tsx", "../../../src/lib/runtime-web/pipelines/browser-pipeline.ts", "../../../src/lib/runtime-web/types/config.types.ts", "../../../src/lib/runtime-web/pureweb.ts", "../../../src/lib/runtime-web/runtime.config.types.tsx"],
  "sourcesContent": ["/*\n * Elastic License 2.0\n * Copyright (C) 2025\u2013present Raman Marozau, Work Target Insight Function. All rights reserved.\n * Contact: raman@worktif.com\n *\n * This file is part of the Licensed Work: worktif.purenow.cdk <worktif_purenow_cdk>.\n * Use of this software is governed by the Elastic License 2.0; see the LICENSE file\n * or https://www.elastic.co/licensing/elastic-license for details.\n *\n * Re-licensing notice:\n *   This file was previously distributed under the Business Source License 1.1 (BUSL-1.1).\n *   As of 2025-09-22, it is re-licensed under Elastic License 2.0.\n *\n * SPDX-License-Identifier: Elastic-2.0\n */\n\n// Re-export everything from the base Purenow framework\nexport * from '@worktif/purenow';\n\n// Export runtime-web specific functionality\nexport * from './lib/runtime-web';\n\n// Export runtime configuration types and utilities\n// export * from './utils';\n\n\n// Re-export purenow bin functionality\n// export * from '@worktif/purenow';\n", "/*\n * Elastic License 2.0\n * Copyright (C) 2025\u2013present Raman Marozau, Work Target Insight Function. All rights reserved.\n * Contact: raman@worktif.com\n *\n * This file is part of the Licensed Work: worktif.purenow.cdk <worktif_purenow_cdk>.\n * Use of this software is governed by the Elastic License 2.0; see the LICENSE file\n * or https://www.elastic.co/licensing/elastic-license for details.\n *\n * Re-licensing notice:\n *   This file was previously distributed under the Business Source License 1.1 (BUSL-1.1).\n *   As of 2025-09-22, it is re-licensing under Elastic License 2.0.\n *\n * SPDX-License-Identifier: Elastic-2.0\n */\n\nimport * as React from 'react';\nimport { hydrateRoot } from 'react-dom/client';\nimport { createBrowserRouter, RouterProvider } from 'react-router';\n\nimport type { BrowserMetadata, RuntimeWebConfig } from '@lib/runtime-web/types';\n\n// import { logger } from '@worktif/utils';\n\n/**\n * Browser execution pipeline for Runtime Target Core.\n *\n * @todo: ordinate this class to infra or core cause we have Node.js responsibility\n *      ---- OR \u2013> REMOVE LOGGER\n *\n * **ARCHITECTURE NOTE**: This file is in `src/lib/` because it:\n * - Uses browser-only APIs (window, document, hydrateRoot)\n * - Runs ONLY in browser environment\n * - Must be isomorphic-safe (no Node.js APIs)\n * - NEVER runs in Lambda\n *\n * Handles client-side hydration of React applications with pre-loaded data\n * from server-side rendering. Sets up client-side routing and HTTP client\n * for post-hydration API calls to Lambda endpoints.\n *\n * **Execution Flow**:\n * 1. Hydrate React app with existing PurenowRouter\n * 2. Call config.app({ router }) to get React element\n * 3. Initialize client-side navigation\n * 4. Set up HTTP client for Lambda endpoint calls\n *\n * **Requirements**: REQ-06, REQ-12\n */\nexport class BrowserPipeline {\n  // private readonly logger = logger({\n  //   serviceName: '@lib/runtime-web/pipelines/browser-pipeline',\n  // });\n\n  /**\n   * Execute browser pipeline for client-side hydration.\n   *\n   * Hydrates the React application with pre-loaded data from SSR and sets up\n   * client-side routing. Uses React hydration (not render) to match the\n   * server-rendered HTML exactly.\n   *\n   * @param config - Purenow configuration with app factory and router\n   * @param context - Browser environment context with metadata\n   *\n   * @example\n   * ```typescript\n   * const pipeline = new BrowserPipeline();\n   * await pipeline.execute(config, {\n   *   type: 'browser',\n   *   metadata: {\n   *     userAgent: navigator.userAgent,\n   *     url: window.location.href,\n   *     viewport: { width: window.innerWidth, height: window.innerHeight }\n   *   }\n   * });\n   * ```\n   */\n  async execute(config: RuntimeWebConfig, context: { type: 'browser'; metadata: BrowserMetadata }): Promise<void> {\n    try {\n      console.info('Starting browser pipeline execution', {\n        serviceName: config.serviceName,\n        stage: config.stage,\n        url: context.metadata.url,\n        userAgent: context.metadata.userAgent,\n        viewport: context.metadata.viewport,\n      });\n\n      // 1. Create browser router from PurenowRouter\n      const browserRouter = this.createBrowserRouter(config);\n\n      // 2. Get React element from app factory\n      const appElement = this.createAppElement(config);\n\n      // 3. Create router provider with the app\n      const routerProvider = React.createElement(RouterProvider, {\n        router: browserRouter,\n      }, appElement);\n\n      // 4. Hydrate the application (use hydration, not render)\n      this.hydrateApplication(routerProvider);\n\n      // 5. Set up HTTP client for post-hydration API calls\n      this.setupHttpClient(config);\n\n      console.info('Browser pipeline execution completed successfully', {\n        serviceName: config.serviceName,\n        stage: config.stage,\n      });\n\n    } catch (error) {\n      console.error('Browser pipeline execution failed', {\n        serviceName: config.serviceName,\n        stage: config.stage,\n        error: error instanceof Error ? error.message : String(error),\n        stack: error instanceof Error ? error.stack : undefined,\n      });\n      throw error;\n    }\n  }\n\n  /**\n   * Create browser router from PurenowRouter configuration.\n   *\n   * Uses the existing PurenowRouter to get routes and creates a React Router\n   * browser router for client-side navigation.\n   *\n   * @param config - Purenow configuration\n   * @returns Browser router instance\n   * @private\n   */\n  private createBrowserRouter(config: RuntimeWebConfig) {\n    console.debug('Creating browser router', {\n      routeCount: config.router.getRoutes().length,\n    });\n\n    // Get routes from PurenowRouter\n    const routes = config.router.getRoutes();\n\n    // Create browser router with routes (cast to RouteObject[] for compatibility)\n    const browserRouter = createBrowserRouter(routes as any);\n\n    console.debug('Browser router created successfully', {\n      routeCount: routes.length,\n    });\n\n    return browserRouter;\n  }\n\n  /**\n   * Create React element from app factory function.\n   *\n   * Calls the user's app factory function with the router dependency\n   * to get the root React element for the application.\n   *\n   * @param config - Purenow configuration\n   * @returns Root React element\n   * @private\n   */\n  private createAppElement(config: RuntimeWebConfig): React.ReactElement {\n    console.debug('Creating app element from factory');\n\n    try {\n      // Call app factory with router dependency\n      const appElement = config.app({ router: config.router });\n\n      if (!React.isValidElement(appElement)) {\n        throw new Error('App factory must return a valid React element');\n      }\n\n      console.debug('App element created successfully');\n      return appElement;\n\n    } catch (error) {\n      console.error('Failed to create app element', {\n        error: error instanceof Error ? error.message : String(error),\n      });\n      throw new Error(`Failed to create app element: ${error instanceof Error ? error.message : String(error)}`);\n    }\n  }\n\n  /**\n   * Hydrate the React application in the browser.\n   *\n   * Uses React's hydrateRoot to hydrate the server-rendered HTML with\n   * the client-side React application. This ensures the client matches\n   * the server exactly to avoid hydration mismatches.\n   *\n   * @param routerProvider - Router provider element to hydrate\n   * @private\n   */\n  private hydrateApplication(routerProvider: React.ReactElement): void {\n    console.debug('Starting React hydration');\n\n    try {\n      // Get the root container element\n      const container = document.getElementById('root');\n      if (!container) {\n        throw new Error('Root container element not found. Expected element with id=\"root\"');\n      }\n\n      // Hydrate the application (not render - must match server HTML)\n      hydrateRoot(container, routerProvider);\n\n      console.info('React hydration completed successfully');\n\n    } catch (error) {\n      console.error('React hydration failed', {\n        error: error instanceof Error ? error.message : String(error),\n      });\n      throw new Error(`React hydration failed: ${error instanceof Error ? error.message : String(error)}`);\n    }\n  }\n\n  /**\n   * Set up HTTP client for Lambda endpoint calls.\n   *\n   * Configures the HTTP client for making API calls to Lambda endpoints\n   * after hydration. This is used for post-hydration interactions that\n   * require server-side data.\n   *\n   * @param config - Purenow configuration\n   * @private\n   */\n  private setupHttpClient(config: RuntimeWebConfig): void {\n    console.debug('Setting up HTTP client for Lambda endpoints');\n\n    try {\n      // Set up base URL for API calls based on stage\n      const baseUrl = this.getApiBaseUrl(config.stage);\n\n      // Store configuration globally for use by data loaders\n      if (typeof window !== 'undefined') {\n        (window as any).__PURENOW_CONFIG__ = {\n          serviceName: config.serviceName,\n          stage: config.stage,\n          apiBaseUrl: baseUrl,\n        };\n      }\n\n      console.info('HTTP client configured successfully', {\n        baseUrl,\n        stage: config.stage,\n      });\n\n    } catch (error) {\n      console.error('Failed to setup HTTP client', {\n        error: error instanceof Error ? error.message : String(error),\n      });\n      throw new Error(`Failed to setup HTTP client: ${error instanceof Error ? error.message : String(error)}`);\n    }\n  }\n\n  /**\n   * Get API base URL based on deployment stage.\n   *\n   * Determines the appropriate API base URL for making HTTP requests\n   * to Lambda endpoints based on the deployment stage.\n   *\n   * @param stage - Deployment stage\n   * @returns API base URL\n   * @private\n   */\n  private getApiBaseUrl(stage: 'dev' | 'staging' | 'prod'): string {\n    // In browser context, API calls go through the same origin\n    // The actual API Gateway URL is handled by CloudFront routing\n    const origin = typeof window !== 'undefined' ? window.location.origin : '';\n\n    // API endpoints are typically under /api path\n    return `${origin}/api`;\n  }\n}\n", "/*\n * Elastic License 2.0\n * Copyright (C) 2025\u2013present Raman Marozau, Work Target Insight Function. All rights reserved.\n * Contact: raman@worktif.com\n *\n * This file is part of the Licensed Work: worktif.purenow.cdk <worktif_purenow_cdk>.\n * Use of this software is governed by the Elastic License 2.0; see the LICENSE file\n * or https://www.elastic.co/licensing/elastic-license for details.\n *\n * Re-licensing notice:\n *   This file was previously distributed under the Business Source License 1.1 (BUSL-1.1).\n *   As of 2025-09-22, it is re-licensed under Elastic License 2.0.\n *\n * SPDX-License-Identifier: Elastic-2.0\n */\n\nimport * as React from 'react';\nimport type { InfraOptions } from './infra.types';\nimport type { MicroserviceDefinition } from './microservice.types';\n\n/**\n * PurenowRouter interface for runtime-web integration.\n *\n * Defines the essential methods needed by the runtime-web pipelines.\n * This interface matches the actual PurenowRouter class from @lib/react/purenow.router.\n */\ninterface PurenowRouter {\n  /**\n   * Get all route objects as an array.\n   * Used for creating browser routers and SSR static handlers.\n   */\n  getRoutes(): Array<{\n    path?: string;\n    element?: unknown;\n    loader?: unknown;\n    children?: unknown;\n    [key: string]: unknown;\n  }>;\n\n  /**\n   * Find a route by its ID.\n   */\n  getRouteById?(id: string): unknown;\n\n  /**\n   * Find a route by its path.\n   */\n  getRouteByPath?(path: string): unknown;\n\n  /**\n   * Get the routes array (getter).\n   */\n  routes?: Array<unknown>;\n\n  /**\n   * Get the default configuration.\n   */\n  defaults?: unknown;\n}\n\n/**\n * Stage environment for deployment.\n *\n * - `dev`: Development environment\n * - `staging`: Staging/pre-production environment\n * - `prod`: Production environment\n */\nexport type Stage = 'dev' | 'staging' | 'prod';\n\n/**\n * Utility type to extract service names from register configuration.\n *\n * This enables compile-time validation of service names and provides\n * type-safe access to service identifiers throughout the framework.\n *\n * @template T - The register configuration object type\n */\nexport type ServiceNames<T extends Record<string, MicroserviceDefinition>> = keyof T;\n\n/**\n * Utility type to generate Lambda IDs from service configuration.\n *\n * Combines service names with Lambda IDs to create fully qualified\n * Lambda identifiers for type-safe Lambda resolution.\n *\n * @template T - The register configuration object type\n */\nexport type LambdaIds<T extends Record<string, MicroserviceDefinition>> = {\n  [K in keyof T]: T[K]['lambdas'][number] extends { id: infer I }\n    ? I extends string\n      ? `${K & string}.${I}`\n      : never\n    : never;\n}[keyof T];\n\n/**\n * Type constraint for valid service names.\n *\n * Ensures service names follow the validation pattern:\n * - Must start with a letter (a-z, A-Z)\n * - Can contain letters, numbers, and hyphens\n * - Maximum length: 128 characters\n *\n * This is a branded type that provides compile-time validation.\n */\nexport type ValidServiceName = string & { readonly __brand: 'ValidServiceName' };\n\n/**\n * Type guard to validate service name format.\n *\n * @param serviceName - The service name to validate\n * @returns Type predicate indicating if the service name is valid\n */\nexport function isValidServiceName(serviceName: string): serviceName is ValidServiceName {\n  return /^[a-zA-Z][a-zA-Z0-9-]{0,127}$/.test(serviceName);\n}\n\n/**\n * Main configuration interface for Runtime Target Core.\n *\n * This interface provides a unified configuration that works across all execution contexts:\n * - Browser: Hydrates React application with client-side routing\n * - Lambda: Executes server-side rendering and business logic\n * - CDK: Synthesizes CloudFormation infrastructure\n *\n * @template TRegister - The register configuration type for type-safe service names\n *\n * @example\n * ```typescript\n * import { purenow } from '@worktif/purenow/runtime-web';\n * import { PurenowRouter } from '@worktif/purenow';\n *\n * const config = {\n *   app: ({ router }) => <App router={router} />,\n *   router: new PurenowRouter({ router: routes, defaults: {} }),\n *   serviceName: 'my-app',\n *   stage: 'dev',\n *   register: {\n *     payments: {\n *       ties: [PaymentsTies],\n *       lambdas: [chargeHandler, refundHandler]\n *     },\n *     users: {\n *       ties: [UsersTies],\n *       lambdas: [createUserHandler, getUserHandler]\n *     }\n *   } as const,  // Use 'as const' for better type inference\n *   infra: {\n *     env: { account: '123456789012', region: 'us-east-1' },\n *     stage: 'dev',\n *     reactEntry: './src/index.tsx',\n *     apiMode: 'apiGateway'\n *   }\n * } satisfies PurenowConfig;\n *\n * purenow(config);\n * ```\n *\n * @todo: after RuntimeWeb repo will be resolved, RuntimeWebConfig MUST extend PurenowConfig Core\n */\nexport interface RuntimeWebConfig<TRegister extends Record<string, MicroserviceDefinition> = Record<string, MicroserviceDefinition>> {\n  /**\n   * React application component factory function.\n   *\n   * Receives the router instance as a dependency and returns the root React element.\n   * This pattern enables dependency injection of the router into your application.\n   *\n   * @param deps - Dependencies object containing the router\n   * @param deps.router - PurenowRouter instance for navigation and routing\n   * @returns Root React element (React.ReactElement)\n   *\n   * @example\n   * ```typescript\n   * app: ({ router }) => <App router={router} />\n   * ```\n   */\n  app: (deps: { router: PurenowRouter }) => React.ReactElement;\n\n  /**\n   * PurenowRouter instance for application routing.\n   *\n   * Defines all routes, loaders, and navigation configuration.\n   * The router is used in both server-side rendering (Lambda) and client-side hydration (browser).\n   *\n   * @see {@link PurenowRouter} for router configuration\n   *\n   * @example\n   * ```typescript\n   * router: new PurenowRouter({\n   *   router: [\n   *     { path: '/', element: <Home /> },\n   *     { path: '/about', element: <About /> }\n   *   ],\n   *   defaults: {}\n   * })\n   * ```\n   */\n  router: PurenowRouter;\n\n  /**\n   * Service name identifier for the application.\n   *\n   * Used as a prefix for all AWS resources (Lambda functions, API Gateway, S3 buckets, etc.).\n   * Must be unique within your AWS account and region.\n   *\n   * **Validation Rules**:\n   * - Must start with a letter (a-z, A-Z)\n   * - Can contain letters, numbers, and hyphens\n   * - Maximum length: 128 characters\n   * - Pattern: `/^[a-zA-Z][a-zA-Z0-9-]{0,127}$/`\n   *\n   * **Examples**:\n   * - Valid: `my-app`, `MyApp`, `app123`, `my-app-v2`\n   * - Invalid: `123app` (starts with number), `my_app` (underscore), `my app` (space)\n   *\n   * @example\n   * ```typescript\n   * serviceName: 'my-application'\n   * ```\n   */\n  serviceName: string;\n\n  /**\n   * Deployment stage/environment.\n   *\n   * Determines the environment-specific configuration and resource naming.\n   * Used to create separate infrastructure stacks for different environments.\n   *\n   * **Values**:\n   * - `dev`: Development environment (local testing, rapid iteration)\n   * - `staging`: Staging/pre-production environment (QA, integration testing)\n   * - `prod`: Production environment (live users)\n   *\n   * **Impact**:\n   * - Resource naming: `{serviceName}-{resource}-{stage}`\n   * - Environment variables: Different configs per stage\n   * - Cache TTL: Shorter in dev, longer in prod\n   * - Logging: More verbose in dev, structured in prod\n   *\n   * @example\n   * ```typescript\n   * stage: 'dev'\n   * ```\n   */\n  stage: Stage;\n\n  /**\n   * Microservice registry (runtime-level configuration).\n   *\n   * **Required**: Defines all microservices, their DI containers, and Lambda endpoints.\n   * **Used in all contexts**: Browser (for type generation), Lambda (for DI), CDK (for infrastructure).\n   * **Architecture**: This is runtime configuration, separate from infrastructure concerns.\n   *\n   * Each microservice gets its own PureContainer instance built from the Ties classes.\n   * Lambda functions are automatically created and wired with dependency injection.\n   *\n   * **Type Safety**: Service names are derived from object keys, ensuring compile-time validation.\n   * **No Magic Strings**: All service identifiers are type-safe and auto-generated.\n   *\n   * @see {@link MicroserviceDefinition} for microservice structure\n   *\n   * @example\n   * ```typescript\n   * register: {\n   *   payments: {\n   *     ties: [PaymentsTies, BillingTies],\n   *     lambdas: [chargeHandler, refundHandler, webhookHandler]\n   *   },\n   *   users: {\n   *     ties: [UsersTies, AuthTies],\n   *     lambdas: [createUserHandler, getUserHandler, loginHandler]\n   *   }\n   * } as const  // Use 'as const' for better type inference\n   * ```\n   */\n  register: TRegister;\n\n  /**\n   * Infrastructure configuration for CDK deployment.\n   *\n   * **Optional**: Only required when running in CDK context (synthesizing CloudFormation templates).\n   * **Not used**: In browser and Lambda contexts (runtime configuration is in register).\n   * **Pure infrastructure**: Contains only AWS resource configuration, no business logic.\n   *\n   * Defines:\n   * - AWS account and region\n   * - Lambda configuration (memory, timeout, VPC)\n   * - API Gateway or Lambda URL mode\n   * - Custom domain configuration\n   * - React entry point for SSR Lambda\n   *\n   * @see {@link InfraOptions} for detailed configuration options\n   *\n   * @example\n   * ```typescript\n   * infra: {\n   *   env: { account: '123456789012', region: 'us-east-1' },\n   *   stage: 'dev',\n   *   reactEntry: './src/index.tsx',\n   *   apiMode: 'apiGateway',\n   *   lambdaMemorySize: 1024,\n   *   lambdaTimeout: 30,\n   *   domain: {\n   *     rootDomain: 'myapp.com',\n   *     subdomain: 'api'\n   *   }\n   * }\n   * ```\n   */\n  infra?: InfraOptions;\n}\n\n/**\n * Type-safe Purenow configuration with inferred service names.\n *\n * This type provides Runtime Core type safety by inferring service names from the register\n * configuration, enabling compile-time validation of service references.\n *\n * @template TRegister - The register configuration type\n */\nexport type TypeSafePurenowConfig<TRegister extends Record<string, MicroserviceDefinition>> =\n  RuntimeWebConfig<TRegister> & {\n  /**\n   * Type-safe service names derived from register keys.\n   * Available at compile-time for type checking and IDE autocomplete.\n   */\n  readonly serviceNames?: ServiceNames<TRegister>;\n\n  /**\n   * Type-safe Lambda IDs derived from register configuration.\n   * Available at compile-time for type checking and IDE autocomplete.\n   */\n  readonly lambdaIds?: LambdaIds<TRegister>;\n};\n", "/*\n * Elastic License 2.0\n * Copyright (C) 2025\u2013present Raman Marozau, Work Target Insight Function. All rights reserved.\n * Contact: raman@worktif.com\n *\n * This file is part of the Licensed Work: worktif.purenow.cdk <worktif_purenow_cdk>.\n * Use of this software is governed by the Elastic License 2.0; see the LICENSE file\n * or https://www.elastic.co/licensing/elastic-license for details.\n *\n * Re-licensing notice:\n *   This file was previously distributed under the Business Source License 1.1 (BUSL-1.1).\n *   As of 2025-09-22, it is re-licensed under Elastic License 2.0.\n *\n * SPDX-License-Identifier: Elastic-2.0\n */\n\nimport { purenow, PurenowRoute, purenowRouter, PurenowRouterDefaults } from '@worktif/purenow';\nimport { RuntimeWebConfig } from '@lib/runtime-web/types';\n\n/**\n * Error thrown when configuration validation fails.\n * Follows purenow error patterns without emoji.\n */\nexport class ConfigValidationError extends Error {\n  /** Array of validation error messages */\n  readonly errors: string[];\n\n  constructor(errors: string[]) {\n    super(`Configuration validation failed:\\n${errors.map(e => `  - ${e}`).join('\\n')}`);\n    this.name = 'ConfigValidationError';\n    this.errors = errors;\n    Error.captureStackTrace(this, this.constructor);\n  }\n}\n\n/**\n * Error thrown when environment detection fails.\n * Follows purenow error patterns without emoji.\n */\nexport class EnvironmentDetectionError extends Error {\n  constructor(message: string) {\n    super(message);\n    this.name = 'EnvironmentDetectionError';\n    Error.captureStackTrace(this, this.constructor);\n  }\n}\n\n/**\n * Detect the current runtime environment.\n * This is a lightweight detection that works in all environments.\n */\nfunction detectEnvironment(): 'browser' | 'lambda' | 'cdk' {\n  // Browser detection\n  if (typeof window !== 'undefined') {\n    return 'browser';\n  }\n\n  // Lambda detection\n  if (typeof process !== 'undefined' && process.env?.AWS_LAMBDA_FUNCTION_NAME) {\n    return 'lambda';\n  }\n\n  // CDK detection\n  if (typeof process !== 'undefined') {\n    if (process.env?.PURENOW_MODE === 'cdk') {\n      return 'cdk';\n    }\n    if (process.env?.CDK_DEFAULT_ACCOUNT || process.env?.CDK_DEFAULT_REGION) {\n      return 'cdk';\n    }\n    if (process.argv?.some(arg => arg.includes('cdk') || arg.includes('synth'))) {\n      return 'cdk';\n    }\n  }\n\n  // Default to CDK for Node.js environments (build time)\n  return 'cdk';\n}\n\n/**\n * Validate configuration for the given environment.\n * Lightweight validation that works in all environments.\n */\nfunction validateConfig(config: RuntimeWebConfig, isCDKContext: boolean): { valid: boolean; errors: string[] } {\n  const errors: string[] = [];\n\n  // Service name validation\n  if (!config.serviceName || !/^[a-zA-Z][a-zA-Z0-9-]{0,127}$/.test(config.serviceName)) {\n    errors.push('serviceName must start with a letter, contain only alphanumeric characters and hyphens, and be max 128 characters');\n  }\n\n  // Stage validation\n  if (!['dev', 'staging', 'prod'].includes(config.stage)) {\n    errors.push('stage must be one of: dev, staging, prod');\n  }\n\n  // Infra validation for CDK context\n  if (isCDKContext && !config.infra) {\n    errors.push('infra configuration is required in CDK context');\n  }\n\n  return { valid: errors.length === 0, errors };\n}\n\n/**\n * Unified entry point for Runtime Target Core.\n *\n * This function provides a single API that works across all execution contexts:\n * - **Browser**: Hydrates React application with client-side routing\n * - **Lambda**: Executes server-side rendering and business logic with DI\n * - **CDK**: Synthesizes CloudFormation infrastructure templates\n *\n * The function automatically detects the runtime environment and routes\n * execution to the appropriate pipeline without user intervention.\n *\n * **Note**: For Lambda and CDK contexts, use the server-side entry point\n * from `@core/runtime-web` instead. This browser-compatible version\n * only supports browser hydration.\n *\n * @param config - Unified configuration for all contexts\n * @returns Promise that resolves when execution completes\n * @throws ConfigValidationError if configuration is invalid\n * @throws EnvironmentDetectionError if environment cannot be detected\n * @throws Error if execution fails\n *\n * @example\n * ```typescript\n * import { purenow } from '@worktif/purenow/runtime-web';\n * import { PurenowRouter } from '@worktif/purenow';\n *\n * purenow({\n *   app: ({ router }) => <App router={router} />,\n *   router: new PurenowRouter({ routes, defaults: {} }),\n *   serviceName: 'my-app',\n *   stage: 'dev',\n *   register: {\n *     payments: {\n *       ties: [PaymentsTies],\n *       lambdas: [chargeHandler, refundHandler]\n *     }\n *   },\n *   infra: {\n *     env: { account: '123456789012', region: 'us-east-1' },\n *     stage: 'dev',\n *     reactEntry: './src/index.tsx',\n *     apiMode: 'apiGateway'\n *   }\n * });\n * ```\n */\nexport function pureweb(config: RuntimeWebConfig): void {\n  // 1. Detect runtime environment using lightweight detection\n  const envType = detectEnvironment();\n  const isCDKContext = envType === 'cdk';\n\n  // 2. Validate configuration\n  const validationResult = validateConfig(config, isCDKContext);\n\n  if (!validationResult.valid) {\n    throw new ConfigValidationError(validationResult.errors);\n  }\n\n  // 3. Route to appropriate pipeline based on environment\n  switch (envType) {\n    case 'browser': {\n      // Browser pipeline - hydrate React app\n      // This is the only path that runs in the browser\n      purenow({\n        app: ({ router }) => config.app({ router }),\n        router: purenowRouter({\n          router: config.router.getRoutes() as PurenowRoute[],\n          defaults: config.router.defaults as PurenowRouterDefaults,\n        }),\n        config: {\n          serviceName: config.serviceName,\n          stage: config.stage,\n        },\n      });\n      break;\n    }\n\n    case 'lambda':\n    case 'cdk': {\n      // Lambda and CDK pipelines require server-side code\n      // These should use the server-side entry point from @core/runtime-web\n      console.log('[Runtime] Server-side pipeline detected (%s)', envType);\n      purenow({\n        app: ({ router }) => config.app({ router }),\n        router: purenowRouter({\n          router: config.router.getRoutes() as PurenowRoute[],\n          defaults: config.router.defaults as PurenowRouterDefaults,\n        }),\n        config: {\n          serviceName: config.serviceName,\n          stage: config.stage,\n        },\n      });\n      break;\n      // console.log('[Runtime Web] Lambda runtime detected, skipping browser rendering pipeline');\n      // throw new EnvironmentDetectionError(\n      //   `Server-side environment detected (${envType}). ` +\n      //   `Use the server-side entry point from '@core/runtime-web' for Lambda and CDK contexts.`,\n      // );\n    }\n\n    default:\n      console.log('[Runtime Web] Unknown environment type: %s', envType);\n      break;\n    // throw new EnvironmentDetectionError(\n    //   `Unknown environment type: ${envType}`,\n    // );\n  }\n}\n\n\n", "/*\n * Elastic License 2.0\n * Copyright (C) 2025\u2013present Raman Marozau, Work Target Insight Function. All rights reserved.\n * Contact: raman@worktif.com\n *\n * This file is part of the Licensed Work: worktif.purenow.cdk <worktif_purenow_cdk>.\n * Use of this software is governed by the Elastic License 2.0; see the LICENSE file\n * or https://www.elastic.co/licensing/elastic-license for details.\n *\n * Re-licensing notice:\n *   This file was previously distributed under the Business Source License 1.1 (BUSL-1.1).\n *   As of 2025-09-22, it is re-licensed under Elastic License 2.0.\n *\n * SPDX-License-Identifier: Elastic-2.0\n */\n\n\nimport type { PurenowConfig } from '@worktif/purenow';\n\n/**\n * Runtime-specific configuration that extends PurenowConfig.\n *\n * This interface adds runtime workspace functionality while preserving\n * all existing purenow configuration options. The runtime configuration\n * is merged with purenow configuration rather than replacing it.\n */\nexport interface RuntimeConfig extends PurenowConfig {\n  /**\n   * Runtime-specific configuration options.\n   * These settings extend purenow functionality without replacing it.\n   */\n  runtime?: {\n    /** Enable Runtime Core stack deployment (extends purenow's two-stack architecture) */\n    enableThirdStack?: boolean;\n\n    /** Runtime web mode configuration */\n    runtimeWebMode?: 'development' | 'production';\n\n    /** Additional runtime features to enable */\n    additionalFeatures?: string[];\n\n    /** Development server enhancements */\n    devServerEnhancements?: {\n      /** Enable hot module replacement */\n      hotReload?: boolean;\n      /** Enable debug mode with additional logging */\n      debugMode?: boolean;\n      /** Enable performance monitoring */\n      performanceMonitoring?: boolean;\n    };\n\n    /** Build optimizations */\n    buildOptimizations?: {\n      /** Enable bundle analysis */\n      bundleAnalysis?: boolean;\n      /** Enable tree shaking */\n      treeshaking?: boolean;\n      /** Enable code minification */\n      codeMinification?: boolean;\n    };\n  };\n}\n\n/**\n * Configuration merging utility that preserves all purenow settings\n * while adding runtime-specific extensions.\n *\n * @param purenowConfig - Base purenow configuration\n * @param runtimeConfig - Runtime-specific configuration to merge\n * @returns Merged configuration with all purenow settings preserved\n */\nexport function mergeRuntimeConfig(\n  purenowConfig: PurenowConfig,\n  runtimeConfig?: Partial<RuntimeConfig['runtime']>,\n): RuntimeConfig {\n  return {\n    ...purenowConfig,\n    runtime: {\n      enableThirdStack: false,\n      runtimeWebMode: 'development',\n      additionalFeatures: [],\n\n      // @todo: critial to improve this solution. Otherwise \u2013> UNNECESSARY OPTIONS TOTALLY\n      devServerEnhancements: {\n        hotReload: true,\n        debugMode: false,\n        performanceMonitoring: false,\n      },\n      buildOptimizations: {\n        bundleAnalysis: false,\n        treeshaking: true,\n        codeMinification: true,\n      },\n      ...runtimeConfig,\n    },\n  };\n}\n\n/**\n * Type guard to check if a configuration is a RuntimeConfig.\n *\n * @param config - Configuration to check\n * @returns True if the configuration has runtime-specific properties\n */\nexport function isRuntimeConfig(config: any): config is RuntimeConfig {\n  return !!(config && typeof config === 'object' && 'runtime' in config);\n}\n\n/**\n * Extract runtime-specific configuration from a RuntimeConfig.\n *\n * @param config - RuntimeConfig to extract from\n * @returns Runtime-specific configuration or undefined\n */\nexport function extractRuntimeConfig(config: RuntimeConfig): RuntimeConfig['runtime'] {\n  return config.runtime;\n}\n\n/**\n * Create a RuntimeConfig from a base PurenowConfig with default runtime settings.\n *\n * @param purenowConfig - Base purenow configuration\n * @returns RuntimeConfig with default runtime settings\n */\nexport function createRuntimeConfig(purenowConfig: PurenowConfig): RuntimeConfig {\n  return mergeRuntimeConfig(purenowConfig);\n}\n"],
  "mappings": "wmBAAA,IAAAA,EAAA,GAAAC,EAAAD,EAAA,qBAAAE,EAAA,0BAAAC,EAAA,8BAAAC,EAAA,wBAAAC,EAAA,yBAAAC,EAAA,oBAAAC,EAAA,uBAAAC,EAAA,uBAAAC,EAAA,YAAAC,IAAA,eAAAC,EAAAX,GAiBAY,EAAAZ,EAAc,4BAjBd,gBCgBA,IAAAa,EAAuB,oBACvBC,EAA4B,4BAC5BC,EAAoD,wBA8BvCC,EAAN,KAAsB,CA4B3B,MAAM,QAAQC,EAA0BC,EAAwE,CAC9G,GAAI,CACF,QAAQ,KAAK,sCAAuC,CAClD,YAAaD,EAAO,YACpB,MAAOA,EAAO,MACd,IAAKC,EAAQ,SAAS,IACtB,UAAWA,EAAQ,SAAS,UAC5B,SAAUA,EAAQ,SAAS,QAC7B,CAAC,EAGD,IAAMC,EAAgB,KAAK,oBAAoBF,CAAM,EAG/CG,EAAa,KAAK,iBAAiBH,CAAM,EAGzCI,EAAuB,gBAAc,iBAAgB,CACzD,OAAQF,CACV,EAAGC,CAAU,EAGb,KAAK,mBAAmBC,CAAc,EAGtC,KAAK,gBAAgBJ,CAAM,EAE3B,QAAQ,KAAK,oDAAqD,CAChE,YAAaA,EAAO,YACpB,MAAOA,EAAO,KAChB,CAAC,CAEH,OAASK,EAAO,CACd,cAAQ,MAAM,oCAAqC,CACjD,YAAaL,EAAO,YACpB,MAAOA,EAAO,MACd,MAAOK,aAAiB,MAAQA,EAAM,QAAU,OAAOA,CAAK,EAC5D,MAAOA,aAAiB,MAAQA,EAAM,MAAQ,MAChD,CAAC,EACKA,CACR,CACF,CAYQ,oBAAoBL,EAA0B,CACpD,QAAQ,MAAM,0BAA2B,CACvC,WAAYA,EAAO,OAAO,UAAU,EAAE,MACxC,CAAC,EAGD,IAAMM,EAASN,EAAO,OAAO,UAAU,EAGjCE,KAAgB,uBAAoBI,CAAa,EAEvD,eAAQ,MAAM,sCAAuC,CACnD,WAAYA,EAAO,MACrB,CAAC,EAEMJ,CACT,CAYQ,iBAAiBF,EAA8C,CACrE,QAAQ,MAAM,mCAAmC,EAEjD,GAAI,CAEF,IAAMG,EAAaH,EAAO,IAAI,CAAE,OAAQA,EAAO,MAAO,CAAC,EAEvD,GAAI,CAAO,iBAAeG,CAAU,EAClC,MAAM,IAAI,MAAM,+CAA+C,EAGjE,eAAQ,MAAM,kCAAkC,EACzCA,CAET,OAASE,EAAO,CACd,cAAQ,MAAM,+BAAgC,CAC5C,MAAOA,aAAiB,MAAQA,EAAM,QAAU,OAAOA,CAAK,CAC9D,CAAC,EACK,IAAI,MAAM,iCAAiCA,aAAiB,MAAQA,EAAM,QAAU,OAAOA,CAAK,CAAC,EAAE,CAC3G,CACF,CAYQ,mBAAmBD,EAA0C,CACnE,QAAQ,MAAM,0BAA0B,EAExC,GAAI,CAEF,IAAMG,EAAY,SAAS,eAAe,MAAM,EAChD,GAAI,CAACA,EACH,MAAM,IAAI,MAAM,mEAAmE,KAIrF,eAAYA,EAAWH,CAAc,EAErC,QAAQ,KAAK,wCAAwC,CAEvD,OAASC,EAAO,CACd,cAAQ,MAAM,yBAA0B,CACtC,MAAOA,aAAiB,MAAQA,EAAM,QAAU,OAAOA,CAAK,CAC9D,CAAC,EACK,IAAI,MAAM,2BAA2BA,aAAiB,MAAQA,EAAM,QAAU,OAAOA,CAAK,CAAC,EAAE,CACrG,CACF,CAYQ,gBAAgBL,EAAgC,CACtD,QAAQ,MAAM,6CAA6C,EAE3D,GAAI,CAEF,IAAMQ,EAAU,KAAK,cAAcR,EAAO,KAAK,EAG3C,OAAO,OAAW,MACnB,OAAe,mBAAqB,CACnC,YAAaA,EAAO,YACpB,MAAOA,EAAO,MACd,WAAYQ,CACd,GAGF,QAAQ,KAAK,sCAAuC,CAClD,QAAAA,EACA,MAAOR,EAAO,KAChB,CAAC,CAEH,OAASK,EAAO,CACd,cAAQ,MAAM,8BAA+B,CAC3C,MAAOA,aAAiB,MAAQA,EAAM,QAAU,OAAOA,CAAK,CAC9D,CAAC,EACK,IAAI,MAAM,gCAAgCA,aAAiB,MAAQA,EAAM,QAAU,OAAOA,CAAK,CAAC,EAAE,CAC1G,CACF,CAYQ,cAAcI,EAA2C,CAM/D,MAAO,GAHQ,OAAO,OAAW,IAAc,OAAO,SAAS,OAAS,EAGxD,MAClB,CACF,EC5JO,SAASC,EAAmBC,EAAsD,CACvF,MAAO,gCAAgC,KAAKA,CAAW,CACzD,CCnGA,IAAAC,EAA4E,4BAO/DC,EAAN,cAAoC,KAAM,CAI/C,YAAYC,EAAkB,CAC5B,MAAM;AAAA,EAAqCA,EAAO,IAAI,GAAK,OAAO,CAAC,EAAE,EAAE,KAAK;AAAA,CAAI,CAAC,EAAE,EACnF,KAAK,KAAO,wBACZ,KAAK,OAASA,EACd,MAAM,kBAAkB,KAAM,KAAK,WAAW,CAChD,CACF,EAMaC,EAAN,cAAwC,KAAM,CACnD,YAAYC,EAAiB,CAC3B,MAAMA,CAAO,EACb,KAAK,KAAO,4BACZ,MAAM,kBAAkB,KAAM,KAAK,WAAW,CAChD,CACF,EAMA,SAASC,GAAkD,CAEzD,OAAI,OAAO,OAAW,IACb,UAIL,OAAO,QAAY,KAAe,QAAQ,KAAK,yBAC1C,UAIL,OAAO,QAAY,MACjB,QAAQ,KAAK,eAAiB,OAG9B,QAAQ,KAAK,qBAAuB,QAAQ,KAAK,oBAGjD,QAAQ,MAAM,KAAKC,GAAOA,EAAI,SAAS,KAAK,GAAKA,EAAI,SAAS,OAAO,CAAC,GACjE,MAMb,CAMA,SAASC,EAAeC,EAA0BC,EAA6D,CAC7G,IAAMP,EAAmB,CAAC,EAG1B,OAAI,CAACM,EAAO,aAAe,CAAC,gCAAgC,KAAKA,EAAO,WAAW,IACjFN,EAAO,KAAK,mHAAmH,EAI5H,CAAC,MAAO,UAAW,MAAM,EAAE,SAASM,EAAO,KAAK,GACnDN,EAAO,KAAK,0CAA0C,EAIpDO,GAAgB,CAACD,EAAO,OAC1BN,EAAO,KAAK,gDAAgD,EAGvD,CAAE,MAAOA,EAAO,SAAW,EAAG,OAAAA,CAAO,CAC9C,CAgDO,SAASQ,EAAQF,EAAgC,CAEtD,IAAMG,EAAUN,EAAkB,EAI5BO,EAAmBL,EAAeC,EAHnBG,IAAY,KAG2B,EAE5D,GAAI,CAACC,EAAiB,MACpB,MAAM,IAAIX,EAAsBW,EAAiB,MAAM,EAIzD,OAAQD,EAAS,CACf,IAAK,UAAW,IAGd,WAAQ,CACN,IAAK,CAAC,CAAE,OAAAE,CAAO,IAAML,EAAO,IAAI,CAAE,OAAAK,CAAO,CAAC,EAC1C,UAAQ,iBAAc,CACpB,OAAQL,EAAO,OAAO,UAAU,EAChC,SAAUA,EAAO,OAAO,QAC1B,CAAC,EACD,OAAQ,CACN,YAAaA,EAAO,YACpB,MAAOA,EAAO,KAChB,CACF,CAAC,EACD,KACF,CAEA,IAAK,SACL,IAAK,MAAO,CAGV,QAAQ,IAAI,+CAAgDG,CAAO,KACnE,WAAQ,CACN,IAAK,CAAC,CAAE,OAAAE,CAAO,IAAML,EAAO,IAAI,CAAE,OAAAK,CAAO,CAAC,EAC1C,UAAQ,iBAAc,CACpB,OAAQL,EAAO,OAAO,UAAU,EAChC,SAAUA,EAAO,OAAO,QAC1B,CAAC,EACD,OAAQ,CACN,YAAaA,EAAO,YACpB,MAAOA,EAAO,KAChB,CACF,CAAC,EACD,KAMF,CAEA,QACE,QAAQ,IAAI,6CAA8CG,CAAO,EACjE,KAIJ,CACF,CC7IO,SAASG,EACdC,EACAC,EACe,CACf,MAAO,CACL,GAAGD,EACH,QAAS,CACP,iBAAkB,GAClB,eAAgB,cAChB,mBAAoB,CAAC,EAGrB,sBAAuB,CACrB,UAAW,GACX,UAAW,GACX,sBAAuB,EACzB,EACA,mBAAoB,CAClB,eAAgB,GAChB,YAAa,GACb,iBAAkB,EACpB,EACA,GAAGC,CACL,CACF,CACF,CAQO,SAASC,EAAgBC,EAAsC,CACpE,MAAO,CAAC,EAAEA,GAAU,OAAOA,GAAW,UAAY,YAAaA,EACjE,CAQO,SAASC,EAAqBD,EAAiD,CACpF,OAAOA,EAAO,OAChB,CAQO,SAASE,EAAoBL,EAA6C,CAC/E,OAAOD,EAAmBC,CAAa,CACzC",
  "names": ["index_exports", "__export", "BrowserPipeline", "ConfigValidationError", "EnvironmentDetectionError", "createRuntimeConfig", "extractRuntimeConfig", "isRuntimeConfig", "isValidServiceName", "mergeRuntimeConfig", "pureweb", "__toCommonJS", "__reExport", "React", "import_client", "import_react_router", "BrowserPipeline", "config", "context", "browserRouter", "appElement", "routerProvider", "error", "routes", "container", "baseUrl", "stage", "isValidServiceName", "serviceName", "import_purenow", "ConfigValidationError", "errors", "EnvironmentDetectionError", "message", "detectEnvironment", "arg", "validateConfig", "config", "isCDKContext", "pureweb", "envType", "validationResult", "router", "mergeRuntimeConfig", "purenowConfig", "runtimeConfig", "isRuntimeConfig", "config", "extractRuntimeConfig", "createRuntimeConfig"]
}

|
|
1
|
+
"use strict";var d=Object.defineProperty;var y=Object.getOwnPropertyDescriptor;var C=Object.getOwnPropertyNames;var x=Object.prototype.hasOwnProperty;var w=(e,r)=>{for(var t in r)d(e,t,{get:r[t],enumerable:!0})},k=(e,r,t,i)=>{if(r&&typeof r=="object"||typeof r=="function")for(let n of C(r))!x.call(e,n)&&n!==t&&d(e,n,{get:()=>r[n],enumerable:!(i=y(r,n))||i.enumerable});return e};var h=e=>k(d({},"__esModule",{value:!0}),e);var S={};w(S,{ConfigValidationError:()=>o,EnvironmentDetectionError:()=>a,createRuntimeConfig:()=>v,extractRuntimeConfig:()=>l,isRuntimeConfig:()=>g,isValidServiceName:()=>f,mergeRuntimeConfig:()=>s,pureweb:()=>R});module.exports=h(S);function f(e){return/^[a-zA-Z][a-zA-Z0-9-]{0,127}$/.test(e)}var o=class extends Error{constructor(r){super(`Configuration validation failed:
|
|
2
|
+
${r.map(t=>` - ${t}`).join(`
|
|
3
|
+
`)}`),this.name="ConfigValidationError",this.errors=r,Error.captureStackTrace(this,this.constructor)}},a=class extends Error{constructor(r){super(r),this.name="EnvironmentDetectionError",Error.captureStackTrace(this,this.constructor)}};function N(){return typeof window<"u"?"browser":typeof process<"u"&&process.env?.AWS_LAMBDA_FUNCTION_NAME?"lambda":(typeof process<"u"&&(process.env?.PURENOW_MODE==="cdk"||process.env?.CDK_DEFAULT_ACCOUNT||process.env?.CDK_DEFAULT_REGION||process.argv?.some(e=>e.includes("cdk")||e.includes("synth"))),"cdk")}function T(e,r){let t=[];return(!e.serviceName||!/^[a-zA-Z][a-zA-Z0-9-]{0,127}$/.test(e.serviceName))&&t.push("serviceName must start with a letter, contain only alphanumeric characters and hyphens, and be max 128 characters"),["dev","staging","prod"].includes(e.stage)||t.push("stage must be one of: dev, staging, prod"),r&&!e.infra&&t.push("infra configuration is required in CDK context"),{valid:t.length===0,errors:t}}function R(e){let r=N(),i=T(e,r==="cdk");if(!i.valid)throw new o(i.errors);switch(r){case"browser":{let u=(globalThis.require||require)("@worktif/purenow"),{purenow:c,purenowRouter:m}=u;c({app:({router:p})=>e.app({router:p}),router:m({router:e.router.getRoutes(),defaults:e.router.defaults}),config:{serviceName:e.serviceName,stage:e.stage}});break}case"lambda":case"cdk":{console.log("[Runtime] Server-side pipeline detected (%s)",r);let u=(globalThis.require||require)("@worktif/purenow"),{purenow:c,purenowRouter:m}=u;c({app:({router:p})=>e.app({router:p}),router:m({router:e.router.getRoutes(),defaults:e.router.defaults}),config:{serviceName:e.serviceName,stage:e.stage}});break}default:console.log("[Runtime Web] Unknown environment type: %s",r);break}}function s(e,r){return{...e,runtime:{enableThirdStack:!1,runtimeWebMode:"development",additionalFeatures:[],devServerEnhancements:{hotReload:!0,debugMode:!1,performanceMonitoring:!1},buildOptimizations:{bundleAnalysis:!1,treeshaking:!0,codeMinification:!0},...r}}}function g(e){return!!(e&&typeof e=="object"&&"runtime"in e)}function l(e){return e.runtime}function v(e){return s(e)}0&&(module.exports={ConfigValidationError,EnvironmentDetectionError,createRuntimeConfig,extractRuntimeConfig,isRuntimeConfig,isValidServiceName,mergeRuntimeConfig,pureweb});
|
|
4
|
+
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../src/index.tsx", "../../../src/lib/runtime-web/types/config.types.ts", "../../../src/lib/runtime-web/pureweb.ts", "../../../src/lib/runtime-web/runtime.config.types.tsx"],
  "sourcesContent": ["/*\n * Elastic License 2.0\n * Copyright (C) 2025\u2013present Raman Marozau, Work Target Insight Function. All rights reserved.\n * Contact: raman@worktif.com\n *\n * This file is part of the Licensed Work: worktif.purenow.cdk <worktif_purenow_cdk>.\n * Use of this software is governed by the Elastic License 2.0; see the LICENSE file\n * or https://www.elastic.co/licensing/elastic-license for details.\n *\n * Re-licensing notice:\n *   This file was previously distributed under the Business Source License 1.1 (BUSL-1.1).\n *   As of 2025-09-22, it is re-licensed under Elastic License 2.0.\n *\n * SPDX-License-Identifier: Elastic-2.0\n */\n\n// Export runtime-web specific functionality (excluding BrowserPipeline to reduce bundle size)\nexport {\n    pureweb,\n    ConfigValidationError,\n    EnvironmentDetectionError,\n    createRuntimeConfig,\n    extractRuntimeConfig,\n    isRuntimeConfig,\n    mergeRuntimeConfig,\n    isValidServiceName,\n} from './lib/runtime-web';\n\n// Export types\nexport type {\n    RuntimeWebConfig,\n    TypeSafePurenowConfig,\n    Stage,\n    ServiceNames,\n    LambdaIds,\n    ValidServiceName,\n    RuntimeConfig,\n} from './lib/runtime-web';\n\n// Export runtime configuration types and utilities\n// export * from './utils';\n\n// Note: We don't re-export from @worktif/purenow to avoid bundling it in user applications\n// Users should import from @worktif/purenow directly if they need those functions\n", "/*\n * Elastic License 2.0\n * Copyright (C) 2025\u2013present Raman Marozau, Work Target Insight Function. All rights reserved.\n * Contact: raman@worktif.com\n *\n * This file is part of the Licensed Work: worktif.purenow.cdk <worktif_purenow_cdk>.\n * Use of this software is governed by the Elastic License 2.0; see the LICENSE file\n * or https://www.elastic.co/licensing/elastic-license for details.\n *\n * Re-licensing notice:\n *   This file was previously distributed under the Business Source License 1.1 (BUSL-1.1).\n *   As of 2025-09-22, it is re-licensed under Elastic License 2.0.\n *\n * SPDX-License-Identifier: Elastic-2.0\n */\n\nimport * as React from 'react';\nimport type { InfraOptions } from './infra.types';\nimport type { MicroserviceDefinition } from './microservice.types';\n\n/**\n * PurenowRouter interface for runtime-web integration.\n *\n * Defines the essential methods needed by the runtime-web pipelines.\n * This interface matches the actual PurenowRouter class from @lib/react/purenow.router.\n */\ninterface PurenowRouter {\n  /**\n   * Get all route objects as an array.\n   * Used for creating browser routers and SSR static handlers.\n   */\n  getRoutes(): Array<{\n    path?: string;\n    element?: unknown;\n    loader?: unknown;\n    children?: unknown;\n    [key: string]: unknown;\n  }>;\n\n  /**\n   * Find a route by its ID.\n   */\n  getRouteById?(id: string): unknown;\n\n  /**\n   * Find a route by its path.\n   */\n  getRouteByPath?(path: string): unknown;\n\n  /**\n   * Get the routes array (getter).\n   */\n  routes?: Array<unknown>;\n\n  /**\n   * Get the default configuration.\n   */\n  defaults?: unknown;\n}\n\n/**\n * Stage environment for deployment.\n *\n * - `dev`: Development environment\n * - `staging`: Staging/pre-production environment\n * - `prod`: Production environment\n */\nexport type Stage = 'dev' | 'staging' | 'prod';\n\n/**\n * Utility type to extract service names from register configuration.\n *\n * This enables compile-time validation of service names and provides\n * type-safe access to service identifiers throughout the framework.\n *\n * @template T - The register configuration object type\n */\nexport type ServiceNames<T extends Record<string, MicroserviceDefinition>> = keyof T;\n\n/**\n * Utility type to generate Lambda IDs from service configuration.\n *\n * Combines service names with Lambda IDs to create fully qualified\n * Lambda identifiers for type-safe Lambda resolution.\n *\n * @template T - The register configuration object type\n */\nexport type LambdaIds<T extends Record<string, MicroserviceDefinition>> = {\n  [K in keyof T]: T[K]['lambdas'][number] extends { id: infer I }\n    ? I extends string\n      ? `${K & string}.${I}`\n      : never\n    : never;\n}[keyof T];\n\n/**\n * Type constraint for valid service names.\n *\n * Ensures service names follow the validation pattern:\n * - Must start with a letter (a-z, A-Z)\n * - Can contain letters, numbers, and hyphens\n * - Maximum length: 128 characters\n *\n * This is a branded type that provides compile-time validation.\n */\nexport type ValidServiceName = string & { readonly __brand: 'ValidServiceName' };\n\n/**\n * Type guard to validate service name format.\n *\n * @param serviceName - The service name to validate\n * @returns Type predicate indicating if the service name is valid\n */\nexport function isValidServiceName(serviceName: string): serviceName is ValidServiceName {\n  return /^[a-zA-Z][a-zA-Z0-9-]{0,127}$/.test(serviceName);\n}\n\n/**\n * Main configuration interface for Runtime Target Core.\n *\n * This interface provides a unified configuration that works across all execution contexts:\n * - Browser: Hydrates React application with client-side routing\n * - Lambda: Executes server-side rendering and business logic\n * - CDK: Synthesizes CloudFormation infrastructure\n *\n * @template TRegister - The register configuration type for type-safe service names\n *\n * @example\n * ```typescript\n * import { purenow } from '@worktif/purenow/runtime-web';\n * import { PurenowRouter } from '@worktif/purenow';\n *\n * const config = {\n *   app: ({ router }) => <App router={router} />,\n *   router: new PurenowRouter({ router: routes, defaults: {} }),\n *   serviceName: 'my-app',\n *   stage: 'dev',\n *   register: {\n *     payments: {\n *       ties: [PaymentsTies],\n *       lambdas: [chargeHandler, refundHandler]\n *     },\n *     users: {\n *       ties: [UsersTies],\n *       lambdas: [createUserHandler, getUserHandler]\n *     }\n *   } as const,  // Use 'as const' for better type inference\n *   infra: {\n *     env: { account: '123456789012', region: 'us-east-1' },\n *     stage: 'dev',\n *     reactEntry: './src/index.tsx',\n *     apiMode: 'apiGateway'\n *   }\n * } satisfies PurenowConfig;\n *\n * purenow(config);\n * ```\n *\n * @todo: after RuntimeWeb repo will be resolved, RuntimeWebConfig MUST extend PurenowConfig Core\n */\nexport interface RuntimeWebConfig<TRegister extends Record<string, MicroserviceDefinition> = Record<string, MicroserviceDefinition>> {\n  /**\n   * React application component factory function.\n   *\n   * Receives the router instance as a dependency and returns the root React element.\n   * This pattern enables dependency injection of the router into your application.\n   *\n   * @param deps - Dependencies object containing the router\n   * @param deps.router - PurenowRouter instance for navigation and routing\n   * @returns Root React element (React.ReactElement)\n   *\n   * @example\n   * ```typescript\n   * app: ({ router }) => <App router={router} />\n   * ```\n   */\n  app: (deps: { router: PurenowRouter }) => React.ReactElement;\n\n  /**\n   * PurenowRouter instance for application routing.\n   *\n   * Defines all routes, loaders, and navigation configuration.\n   * The router is used in both server-side rendering (Lambda) and client-side hydration (browser).\n   *\n   * @see {@link PurenowRouter} for router configuration\n   *\n   * @example\n   * ```typescript\n   * router: new PurenowRouter({\n   *   router: [\n   *     { path: '/', element: <Home /> },\n   *     { path: '/about', element: <About /> }\n   *   ],\n   *   defaults: {}\n   * })\n   * ```\n   */\n  router: PurenowRouter;\n\n  /**\n   * Service name identifier for the application.\n   *\n   * Used as a prefix for all AWS resources (Lambda functions, API Gateway, S3 buckets, etc.).\n   * Must be unique within your AWS account and region.\n   *\n   * **Validation Rules**:\n   * - Must start with a letter (a-z, A-Z)\n   * - Can contain letters, numbers, and hyphens\n   * - Maximum length: 128 characters\n   * - Pattern: `/^[a-zA-Z][a-zA-Z0-9-]{0,127}$/`\n   *\n   * **Examples**:\n   * - Valid: `my-app`, `MyApp`, `app123`, `my-app-v2`\n   * - Invalid: `123app` (starts with number), `my_app` (underscore), `my app` (space)\n   *\n   * @example\n   * ```typescript\n   * serviceName: 'my-application'\n   * ```\n   */\n  serviceName: string;\n\n  /**\n   * Deployment stage/environment.\n   *\n   * Determines the environment-specific configuration and resource naming.\n   * Used to create separate infrastructure stacks for different environments.\n   *\n   * **Values**:\n   * - `dev`: Development environment (local testing, rapid iteration)\n   * - `staging`: Staging/pre-production environment (QA, integration testing)\n   * - `prod`: Production environment (live users)\n   *\n   * **Impact**:\n   * - Resource naming: `{serviceName}-{resource}-{stage}`\n   * - Environment variables: Different configs per stage\n   * - Cache TTL: Shorter in dev, longer in prod\n   * - Logging: More verbose in dev, structured in prod\n   *\n   * @example\n   * ```typescript\n   * stage: 'dev'\n   * ```\n   */\n  stage: Stage;\n\n  /**\n   * Microservice registry (runtime-level configuration).\n   *\n   * **Required**: Defines all microservices, their DI containers, and Lambda endpoints.\n   * **Used in all contexts**: Browser (for type generation), Lambda (for DI), CDK (for infrastructure).\n   * **Architecture**: This is runtime configuration, separate from infrastructure concerns.\n   *\n   * Each microservice gets its own PureContainer instance built from the Ties classes.\n   * Lambda functions are automatically created and wired with dependency injection.\n   *\n   * **Type Safety**: Service names are derived from object keys, ensuring compile-time validation.\n   * **No Magic Strings**: All service identifiers are type-safe and auto-generated.\n   *\n   * @see {@link MicroserviceDefinition} for microservice structure\n   *\n   * @example\n   * ```typescript\n   * register: {\n   *   payments: {\n   *     ties: [PaymentsTies, BillingTies],\n   *     lambdas: [chargeHandler, refundHandler, webhookHandler]\n   *   },\n   *   users: {\n   *     ties: [UsersTies, AuthTies],\n   *     lambdas: [createUserHandler, getUserHandler, loginHandler]\n   *   }\n   * } as const  // Use 'as const' for better type inference\n   * ```\n   */\n  register: TRegister;\n\n  /**\n   * Infrastructure configuration for CDK deployment.\n   *\n   * **Optional**: Only required when running in CDK context (synthesizing CloudFormation templates).\n   * **Not used**: In browser and Lambda contexts (runtime configuration is in register).\n   * **Pure infrastructure**: Contains only AWS resource configuration, no business logic.\n   *\n   * Defines:\n   * - AWS account and region\n   * - Lambda configuration (memory, timeout, VPC)\n   * - API Gateway or Lambda URL mode\n   * - Custom domain configuration\n   * - React entry point for SSR Lambda\n   *\n   * @see {@link InfraOptions} for detailed configuration options\n   *\n   * @example\n   * ```typescript\n   * infra: {\n   *   env: { account: '123456789012', region: 'us-east-1' },\n   *   stage: 'dev',\n   *   reactEntry: './src/index.tsx',\n   *   apiMode: 'apiGateway',\n   *   lambdaMemorySize: 1024,\n   *   lambdaTimeout: 30,\n   *   domain: {\n   *     rootDomain: 'myapp.com',\n   *     subdomain: 'api'\n   *   }\n   * }\n   * ```\n   */\n  infra?: InfraOptions;\n}\n\n/**\n * Type-safe Purenow configuration with inferred service names.\n *\n * This type provides Runtime Core type safety by inferring service names from the register\n * configuration, enabling compile-time validation of service references.\n *\n * @template TRegister - The register configuration type\n */\nexport type TypeSafePurenowConfig<TRegister extends Record<string, MicroserviceDefinition>> =\n  RuntimeWebConfig<TRegister> & {\n  /**\n   * Type-safe service names derived from register keys.\n   * Available at compile-time for type checking and IDE autocomplete.\n   */\n  readonly serviceNames?: ServiceNames<TRegister>;\n\n  /**\n   * Type-safe Lambda IDs derived from register configuration.\n   * Available at compile-time for type checking and IDE autocomplete.\n   */\n  readonly lambdaIds?: LambdaIds<TRegister>;\n};\n", "/*\n * Elastic License 2.0\n * Copyright (C) 2025\u2013present Raman Marozau, Work Target Insight Function. All rights reserved.\n * Contact: raman@worktif.com\n *\n * This file is part of the Licensed Work: worktif.purenow.cdk <worktif_purenow_cdk>.\n * Use of this software is governed by the Elastic License 2.0; see the LICENSE file\n * or https://www.elastic.co/licensing/elastic-license for details.\n *\n * Re-licensing notice:\n *   This file was previously distributed under the Business Source License 1.1 (BUSL-1.1).\n *   As of 2025-09-22, it is re-licensed under Elastic License 2.0.\n *\n * SPDX-License-Identifier: Elastic-2.0\n */\n\nimport { RuntimeWebConfig } from '@lib/runtime-web/types';\n\n// Dynamic imports to avoid bundling @worktif/purenow in browser\n// These will be resolved at runtime when the functions are called\n\n/**\n * Error thrown when configuration validation fails.\n * Follows purenow error patterns without emoji.\n */\nexport class ConfigValidationError extends Error {\n  /** Array of validation error messages */\n  readonly errors: string[];\n\n  constructor(errors: string[]) {\n    super(`Configuration validation failed:\\n${errors.map(e => `  - ${e}`).join('\\n')}`);\n    this.name = 'ConfigValidationError';\n    this.errors = errors;\n    Error.captureStackTrace(this, this.constructor);\n  }\n}\n\n/**\n * Error thrown when environment detection fails.\n * Follows purenow error patterns without emoji.\n */\nexport class EnvironmentDetectionError extends Error {\n  constructor(message: string) {\n    super(message);\n    this.name = 'EnvironmentDetectionError';\n    Error.captureStackTrace(this, this.constructor);\n  }\n}\n\n/**\n * Detect the current runtime environment.\n * This is a lightweight detection that works in all environments.\n */\nfunction detectEnvironment(): 'browser' | 'lambda' | 'cdk' {\n  // Browser detection\n  if (typeof window !== 'undefined') {\n    return 'browser';\n  }\n\n  // Lambda detection\n  if (typeof process !== 'undefined' && process.env?.AWS_LAMBDA_FUNCTION_NAME) {\n    return 'lambda';\n  }\n\n  // CDK detection\n  if (typeof process !== 'undefined') {\n    if (process.env?.PURENOW_MODE === 'cdk') {\n      return 'cdk';\n    }\n    if (process.env?.CDK_DEFAULT_ACCOUNT || process.env?.CDK_DEFAULT_REGION) {\n      return 'cdk';\n    }\n    if (process.argv?.some(arg => arg.includes('cdk') || arg.includes('synth'))) {\n      return 'cdk';\n    }\n  }\n\n  // Default to CDK for Node.js environments (build time)\n  return 'cdk';\n}\n\n/**\n * Validate configuration for the given environment.\n * Lightweight validation that works in all environments.\n */\nfunction validateConfig(config: RuntimeWebConfig, isCDKContext: boolean): { valid: boolean; errors: string[] } {\n  const errors: string[] = [];\n\n  // Service name validation\n  if (!config.serviceName || !/^[a-zA-Z][a-zA-Z0-9-]{0,127}$/.test(config.serviceName)) {\n    errors.push('serviceName must start with a letter, contain only alphanumeric characters and hyphens, and be max 128 characters');\n  }\n\n  // Stage validation\n  if (!['dev', 'staging', 'prod'].includes(config.stage)) {\n    errors.push('stage must be one of: dev, staging, prod');\n  }\n\n  // Infra validation for CDK context\n  if (isCDKContext && !config.infra) {\n    errors.push('infra configuration is required in CDK context');\n  }\n\n  return { valid: errors.length === 0, errors };\n}\n\n/**\n * Unified entry point for Runtime Target Core.\n *\n * This function provides a single API that works across all execution contexts:\n * - **Browser**: Hydrates React application with client-side routing\n * - **Lambda**: Executes server-side rendering and business logic with DI\n * - **CDK**: Synthesizes CloudFormation infrastructure templates\n *\n * The function automatically detects the runtime environment and routes\n * execution to the appropriate pipeline without user intervention.\n *\n * **Note**: For Lambda and CDK contexts, use the server-side entry point\n * from `@core/runtime-web` instead. This browser-compatible version\n * only supports browser hydration.\n *\n * @param config - Unified configuration for all contexts\n * @returns Promise that resolves when execution completes\n * @throws ConfigValidationError if configuration is invalid\n * @throws EnvironmentDetectionError if environment cannot be detected\n * @throws Error if execution fails\n *\n * @example\n * ```typescript\n * import { purenow } from '@worktif/purenow/runtime-web';\n * import { PurenowRouter } from '@worktif/purenow';\n *\n * purenow({\n *   app: ({ router }) => <App router={router} />,\n *   router: new PurenowRouter({ routes, defaults: {} }),\n *   serviceName: 'my-app',\n *   stage: 'dev',\n *   register: {\n *     payments: {\n *       ties: [PaymentsTies],\n *       lambdas: [chargeHandler, refundHandler]\n *     }\n *   },\n *   infra: {\n *     env: { account: '123456789012', region: 'us-east-1' },\n *     stage: 'dev',\n *     reactEntry: './src/index.tsx',\n *     apiMode: 'apiGateway'\n *   }\n * });\n * ```\n */\nexport function pureweb(config: RuntimeWebConfig): void {\n  // 1. Detect runtime environment using lightweight detection\n  const envType = detectEnvironment();\n  const isCDKContext = envType === 'cdk';\n\n  // 2. Validate configuration\n  const validationResult = validateConfig(config, isCDKContext);\n\n  if (!validationResult.valid) {\n    throw new ConfigValidationError(validationResult.errors);\n  }\n\n  // 3. Route to appropriate pipeline based on environment\n  switch (envType) {\n    case 'browser': {\n      // Browser pipeline - hydrate React app\n      // This is the only path that runs in the browser\n      // Dynamic require to avoid bundling @worktif/purenow\n      const requireFn = (globalThis as any).require || require;\n      const packageName = '@worktif/purenow';\n      const purenowPackage = requireFn(packageName);\n      const { purenow, purenowRouter } = purenowPackage;\n\n      purenow({\n        app: ({ router }: any) => config.app({ router }),\n        router: purenowRouter({\n          router: config.router.getRoutes(),\n          defaults: config.router.defaults,\n        }),\n        config: {\n          serviceName: config.serviceName,\n          stage: config.stage,\n        },\n      });\n      break;\n    }\n\n    case 'lambda':\n    case 'cdk': {\n      // Lambda and CDK pipelines require server-side code\n      // These should use the server-side entry point from @core/runtime-web\n      console.log('[Runtime] Server-side pipeline detected (%s)', envType);\n\n      // Dynamic require to avoid bundling @worktif/purenow\n      const requireFn = (globalThis as any).require || require;\n      const packageName = '@worktif/purenow';\n      const purenowPackage = requireFn(packageName);\n      const { purenow, purenowRouter } = purenowPackage;\n\n      purenow({\n        app: ({ router }: any) => config.app({ router }),\n        router: purenowRouter({\n          router: config.router.getRoutes(),\n          defaults: config.router.defaults,\n        }),\n        config: {\n          serviceName: config.serviceName,\n          stage: config.stage,\n        },\n      });\n      break;\n      // console.log('[Runtime Web] Lambda runtime detected, skipping browser rendering pipeline');\n      // throw new EnvironmentDetectionError(\n      //   `Server-side environment detected (${envType}). ` +\n      //   `Use the server-side entry point from '@core/runtime-web' for Lambda and CDK contexts.`,\n      // );\n    }\n\n    default:\n      console.log('[Runtime Web] Unknown environment type: %s', envType);\n      break;\n    // throw new EnvironmentDetectionError(\n    //   `Unknown environment type: ${envType}`,\n    // );\n  }\n}\n\n\n", "/*\n * Elastic License 2.0\n * Copyright (C) 2025\u2013present Raman Marozau, Work Target Insight Function. All rights reserved.\n * Contact: raman@worktif.com\n *\n * This file is part of the Licensed Work: worktif.purenow.cdk <worktif_purenow_cdk>.\n * Use of this software is governed by the Elastic License 2.0; see the LICENSE file\n * or https://www.elastic.co/licensing/elastic-license for details.\n *\n * Re-licensing notice:\n *   This file was previously distributed under the Business Source License 1.1 (BUSL-1.1).\n *   As of 2025-09-22, it is re-licensed under Elastic License 2.0.\n *\n * SPDX-License-Identifier: Elastic-2.0\n */\n\n\nimport type { PurenowConfig } from '@worktif/purenow';\n\n/**\n * Runtime-specific configuration that extends PurenowConfig.\n *\n * This interface adds runtime workspace functionality while preserving\n * all existing purenow configuration options. The runtime configuration\n * is merged with purenow configuration rather than replacing it.\n */\nexport interface RuntimeConfig extends PurenowConfig {\n  /**\n   * Runtime-specific configuration options.\n   * These settings extend purenow functionality without replacing it.\n   */\n  runtime?: {\n    /** Enable Runtime Core stack deployment (extends purenow's two-stack architecture) */\n    enableThirdStack?: boolean;\n\n    /** Runtime web mode configuration */\n    runtimeWebMode?: 'development' | 'production';\n\n    /** Additional runtime features to enable */\n    additionalFeatures?: string[];\n\n    /** Development server enhancements */\n    devServerEnhancements?: {\n      /** Enable hot module replacement */\n      hotReload?: boolean;\n      /** Enable debug mode with additional logging */\n      debugMode?: boolean;\n      /** Enable performance monitoring */\n      performanceMonitoring?: boolean;\n    };\n\n    /** Build optimizations */\n    buildOptimizations?: {\n      /** Enable bundle analysis */\n      bundleAnalysis?: boolean;\n      /** Enable tree shaking */\n      treeshaking?: boolean;\n      /** Enable code minification */\n      codeMinification?: boolean;\n    };\n  };\n}\n\n/**\n * Configuration merging utility that preserves all purenow settings\n * while adding runtime-specific extensions.\n *\n * @param purenowConfig - Base purenow configuration\n * @param runtimeConfig - Runtime-specific configuration to merge\n * @returns Merged configuration with all purenow settings preserved\n */\nexport function mergeRuntimeConfig(\n  purenowConfig: PurenowConfig,\n  runtimeConfig?: Partial<RuntimeConfig['runtime']>,\n): RuntimeConfig {\n  return {\n    ...purenowConfig,\n    runtime: {\n      enableThirdStack: false,\n      runtimeWebMode: 'development',\n      additionalFeatures: [],\n\n      // @todo: critial to improve this solution. Otherwise \u2013> UNNECESSARY OPTIONS TOTALLY\n      devServerEnhancements: {\n        hotReload: true,\n        debugMode: false,\n        performanceMonitoring: false,\n      },\n      buildOptimizations: {\n        bundleAnalysis: false,\n        treeshaking: true,\n        codeMinification: true,\n      },\n      ...runtimeConfig,\n    },\n  };\n}\n\n/**\n * Type guard to check if a configuration is a RuntimeConfig.\n *\n * @param config - Configuration to check\n * @returns True if the configuration has runtime-specific properties\n */\nexport function isRuntimeConfig(config: any): config is RuntimeConfig {\n  return !!(config && typeof config === 'object' && 'runtime' in config);\n}\n\n/**\n * Extract runtime-specific configuration from a RuntimeConfig.\n *\n * @param config - RuntimeConfig to extract from\n * @returns Runtime-specific configuration or undefined\n */\nexport function extractRuntimeConfig(config: RuntimeConfig): RuntimeConfig['runtime'] {\n  return config.runtime;\n}\n\n/**\n * Create a RuntimeConfig from a base PurenowConfig with default runtime settings.\n *\n * @param purenowConfig - Base purenow configuration\n * @returns RuntimeConfig with default runtime settings\n */\nexport function createRuntimeConfig(purenowConfig: PurenowConfig): RuntimeConfig {\n  return mergeRuntimeConfig(purenowConfig);\n}\n"],
  "mappings": "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",
  "names": ["index_exports", "__export", "ConfigValidationError", "EnvironmentDetectionError", "createRuntimeConfig", "extractRuntimeConfig", "isRuntimeConfig", "isValidServiceName", "mergeRuntimeConfig", "pureweb", "__toCommonJS", "isValidServiceName", "serviceName", "ConfigValidationError", "errors", "e", "EnvironmentDetectionError", "message", "detectEnvironment", "arg", "validateConfig", "config", "isCDKContext", "pureweb", "envType", "validationResult", "purenowPackage", "purenow", "purenowRouter", "router", "mergeRuntimeConfig", "purenowConfig", "runtimeConfig", "isRuntimeConfig", "config", "extractRuntimeConfig", "createRuntimeConfig"]
}

|
package/out/dist/lib/index.mjs
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
|
|
2
|
-
${r.map(
|
|
3
|
-
`)}`),this.name="ConfigValidationError",this.errors=r,Error.captureStackTrace(this,this.constructor)}},
|
|
4
|
-
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../src/index.tsx", "../../../src/lib/runtime-web/pipelines/browser-pipeline.ts", "../../../src/lib/runtime-web/types/config.types.ts", "../../../src/lib/runtime-web/pureweb.ts", "../../../src/lib/runtime-web/runtime.config.types.tsx"],
  "sourcesContent": ["/*\n * Elastic License 2.0\n * Copyright (C) 2025\u2013present Raman Marozau, Work Target Insight Function. All rights reserved.\n * Contact: raman@worktif.com\n *\n * This file is part of the Licensed Work: worktif.purenow.cdk <worktif_purenow_cdk>.\n * Use of this software is governed by the Elastic License 2.0; see the LICENSE file\n * or https://www.elastic.co/licensing/elastic-license for details.\n *\n * Re-licensing notice:\n *   This file was previously distributed under the Business Source License 1.1 (BUSL-1.1).\n *   As of 2025-09-22, it is re-licensed under Elastic License 2.0.\n *\n * SPDX-License-Identifier: Elastic-2.0\n */\n\n// Re-export everything from the base Purenow framework\nexport * from '@worktif/purenow';\n\n// Export runtime-web specific functionality\nexport * from './lib/runtime-web';\n\n// Export runtime configuration types and utilities\n// export * from './utils';\n\n\n// Re-export purenow bin functionality\n// export * from '@worktif/purenow';\n", "/*\n * Elastic License 2.0\n * Copyright (C) 2025\u2013present Raman Marozau, Work Target Insight Function. All rights reserved.\n * Contact: raman@worktif.com\n *\n * This file is part of the Licensed Work: worktif.purenow.cdk <worktif_purenow_cdk>.\n * Use of this software is governed by the Elastic License 2.0; see the LICENSE file\n * or https://www.elastic.co/licensing/elastic-license for details.\n *\n * Re-licensing notice:\n *   This file was previously distributed under the Business Source License 1.1 (BUSL-1.1).\n *   As of 2025-09-22, it is re-licensing under Elastic License 2.0.\n *\n * SPDX-License-Identifier: Elastic-2.0\n */\n\nimport * as React from 'react';\nimport { hydrateRoot } from 'react-dom/client';\nimport { createBrowserRouter, RouterProvider } from 'react-router';\n\nimport type { BrowserMetadata, RuntimeWebConfig } from '@lib/runtime-web/types';\n\n// import { logger } from '@worktif/utils';\n\n/**\n * Browser execution pipeline for Runtime Target Core.\n *\n * @todo: ordinate this class to infra or core cause we have Node.js responsibility\n *      ---- OR \u2013> REMOVE LOGGER\n *\n * **ARCHITECTURE NOTE**: This file is in `src/lib/` because it:\n * - Uses browser-only APIs (window, document, hydrateRoot)\n * - Runs ONLY in browser environment\n * - Must be isomorphic-safe (no Node.js APIs)\n * - NEVER runs in Lambda\n *\n * Handles client-side hydration of React applications with pre-loaded data\n * from server-side rendering. Sets up client-side routing and HTTP client\n * for post-hydration API calls to Lambda endpoints.\n *\n * **Execution Flow**:\n * 1. Hydrate React app with existing PurenowRouter\n * 2. Call config.app({ router }) to get React element\n * 3. Initialize client-side navigation\n * 4. Set up HTTP client for Lambda endpoint calls\n *\n * **Requirements**: REQ-06, REQ-12\n */\nexport class BrowserPipeline {\n  // private readonly logger = logger({\n  //   serviceName: '@lib/runtime-web/pipelines/browser-pipeline',\n  // });\n\n  /**\n   * Execute browser pipeline for client-side hydration.\n   *\n   * Hydrates the React application with pre-loaded data from SSR and sets up\n   * client-side routing. Uses React hydration (not render) to match the\n   * server-rendered HTML exactly.\n   *\n   * @param config - Purenow configuration with app factory and router\n   * @param context - Browser environment context with metadata\n   *\n   * @example\n   * ```typescript\n   * const pipeline = new BrowserPipeline();\n   * await pipeline.execute(config, {\n   *   type: 'browser',\n   *   metadata: {\n   *     userAgent: navigator.userAgent,\n   *     url: window.location.href,\n   *     viewport: { width: window.innerWidth, height: window.innerHeight }\n   *   }\n   * });\n   * ```\n   */\n  async execute(config: RuntimeWebConfig, context: { type: 'browser'; metadata: BrowserMetadata }): Promise<void> {\n    try {\n      console.info('Starting browser pipeline execution', {\n        serviceName: config.serviceName,\n        stage: config.stage,\n        url: context.metadata.url,\n        userAgent: context.metadata.userAgent,\n        viewport: context.metadata.viewport,\n      });\n\n      // 1. Create browser router from PurenowRouter\n      const browserRouter = this.createBrowserRouter(config);\n\n      // 2. Get React element from app factory\n      const appElement = this.createAppElement(config);\n\n      // 3. Create router provider with the app\n      const routerProvider = React.createElement(RouterProvider, {\n        router: browserRouter,\n      }, appElement);\n\n      // 4. Hydrate the application (use hydration, not render)\n      this.hydrateApplication(routerProvider);\n\n      // 5. Set up HTTP client for post-hydration API calls\n      this.setupHttpClient(config);\n\n      console.info('Browser pipeline execution completed successfully', {\n        serviceName: config.serviceName,\n        stage: config.stage,\n      });\n\n    } catch (error) {\n      console.error('Browser pipeline execution failed', {\n        serviceName: config.serviceName,\n        stage: config.stage,\n        error: error instanceof Error ? error.message : String(error),\n        stack: error instanceof Error ? error.stack : undefined,\n      });\n      throw error;\n    }\n  }\n\n  /**\n   * Create browser router from PurenowRouter configuration.\n   *\n   * Uses the existing PurenowRouter to get routes and creates a React Router\n   * browser router for client-side navigation.\n   *\n   * @param config - Purenow configuration\n   * @returns Browser router instance\n   * @private\n   */\n  private createBrowserRouter(config: RuntimeWebConfig) {\n    console.debug('Creating browser router', {\n      routeCount: config.router.getRoutes().length,\n    });\n\n    // Get routes from PurenowRouter\n    const routes = config.router.getRoutes();\n\n    // Create browser router with routes (cast to RouteObject[] for compatibility)\n    const browserRouter = createBrowserRouter(routes as any);\n\n    console.debug('Browser router created successfully', {\n      routeCount: routes.length,\n    });\n\n    return browserRouter;\n  }\n\n  /**\n   * Create React element from app factory function.\n   *\n   * Calls the user's app factory function with the router dependency\n   * to get the root React element for the application.\n   *\n   * @param config - Purenow configuration\n   * @returns Root React element\n   * @private\n   */\n  private createAppElement(config: RuntimeWebConfig): React.ReactElement {\n    console.debug('Creating app element from factory');\n\n    try {\n      // Call app factory with router dependency\n      const appElement = config.app({ router: config.router });\n\n      if (!React.isValidElement(appElement)) {\n        throw new Error('App factory must return a valid React element');\n      }\n\n      console.debug('App element created successfully');\n      return appElement;\n\n    } catch (error) {\n      console.error('Failed to create app element', {\n        error: error instanceof Error ? error.message : String(error),\n      });\n      throw new Error(`Failed to create app element: ${error instanceof Error ? error.message : String(error)}`);\n    }\n  }\n\n  /**\n   * Hydrate the React application in the browser.\n   *\n   * Uses React's hydrateRoot to hydrate the server-rendered HTML with\n   * the client-side React application. This ensures the client matches\n   * the server exactly to avoid hydration mismatches.\n   *\n   * @param routerProvider - Router provider element to hydrate\n   * @private\n   */\n  private hydrateApplication(routerProvider: React.ReactElement): void {\n    console.debug('Starting React hydration');\n\n    try {\n      // Get the root container element\n      const container = document.getElementById('root');\n      if (!container) {\n        throw new Error('Root container element not found. Expected element with id=\"root\"');\n      }\n\n      // Hydrate the application (not render - must match server HTML)\n      hydrateRoot(container, routerProvider);\n\n      console.info('React hydration completed successfully');\n\n    } catch (error) {\n      console.error('React hydration failed', {\n        error: error instanceof Error ? error.message : String(error),\n      });\n      throw new Error(`React hydration failed: ${error instanceof Error ? error.message : String(error)}`);\n    }\n  }\n\n  /**\n   * Set up HTTP client for Lambda endpoint calls.\n   *\n   * Configures the HTTP client for making API calls to Lambda endpoints\n   * after hydration. This is used for post-hydration interactions that\n   * require server-side data.\n   *\n   * @param config - Purenow configuration\n   * @private\n   */\n  private setupHttpClient(config: RuntimeWebConfig): void {\n    console.debug('Setting up HTTP client for Lambda endpoints');\n\n    try {\n      // Set up base URL for API calls based on stage\n      const baseUrl = this.getApiBaseUrl(config.stage);\n\n      // Store configuration globally for use by data loaders\n      if (typeof window !== 'undefined') {\n        (window as any).__PURENOW_CONFIG__ = {\n          serviceName: config.serviceName,\n          stage: config.stage,\n          apiBaseUrl: baseUrl,\n        };\n      }\n\n      console.info('HTTP client configured successfully', {\n        baseUrl,\n        stage: config.stage,\n      });\n\n    } catch (error) {\n      console.error('Failed to setup HTTP client', {\n        error: error instanceof Error ? error.message : String(error),\n      });\n      throw new Error(`Failed to setup HTTP client: ${error instanceof Error ? error.message : String(error)}`);\n    }\n  }\n\n  /**\n   * Get API base URL based on deployment stage.\n   *\n   * Determines the appropriate API base URL for making HTTP requests\n   * to Lambda endpoints based on the deployment stage.\n   *\n   * @param stage - Deployment stage\n   * @returns API base URL\n   * @private\n   */\n  private getApiBaseUrl(stage: 'dev' | 'staging' | 'prod'): string {\n    // In browser context, API calls go through the same origin\n    // The actual API Gateway URL is handled by CloudFront routing\n    const origin = typeof window !== 'undefined' ? window.location.origin : '';\n\n    // API endpoints are typically under /api path\n    return `${origin}/api`;\n  }\n}\n", "/*\n * Elastic License 2.0\n * Copyright (C) 2025\u2013present Raman Marozau, Work Target Insight Function. All rights reserved.\n * Contact: raman@worktif.com\n *\n * This file is part of the Licensed Work: worktif.purenow.cdk <worktif_purenow_cdk>.\n * Use of this software is governed by the Elastic License 2.0; see the LICENSE file\n * or https://www.elastic.co/licensing/elastic-license for details.\n *\n * Re-licensing notice:\n *   This file was previously distributed under the Business Source License 1.1 (BUSL-1.1).\n *   As of 2025-09-22, it is re-licensed under Elastic License 2.0.\n *\n * SPDX-License-Identifier: Elastic-2.0\n */\n\nimport * as React from 'react';\nimport type { InfraOptions } from './infra.types';\nimport type { MicroserviceDefinition } from './microservice.types';\n\n/**\n * PurenowRouter interface for runtime-web integration.\n *\n * Defines the essential methods needed by the runtime-web pipelines.\n * This interface matches the actual PurenowRouter class from @lib/react/purenow.router.\n */\ninterface PurenowRouter {\n  /**\n   * Get all route objects as an array.\n   * Used for creating browser routers and SSR static handlers.\n   */\n  getRoutes(): Array<{\n    path?: string;\n    element?: unknown;\n    loader?: unknown;\n    children?: unknown;\n    [key: string]: unknown;\n  }>;\n\n  /**\n   * Find a route by its ID.\n   */\n  getRouteById?(id: string): unknown;\n\n  /**\n   * Find a route by its path.\n   */\n  getRouteByPath?(path: string): unknown;\n\n  /**\n   * Get the routes array (getter).\n   */\n  routes?: Array<unknown>;\n\n  /**\n   * Get the default configuration.\n   */\n  defaults?: unknown;\n}\n\n/**\n * Stage environment for deployment.\n *\n * - `dev`: Development environment\n * - `staging`: Staging/pre-production environment\n * - `prod`: Production environment\n */\nexport type Stage = 'dev' | 'staging' | 'prod';\n\n/**\n * Utility type to extract service names from register configuration.\n *\n * This enables compile-time validation of service names and provides\n * type-safe access to service identifiers throughout the framework.\n *\n * @template T - The register configuration object type\n */\nexport type ServiceNames<T extends Record<string, MicroserviceDefinition>> = keyof T;\n\n/**\n * Utility type to generate Lambda IDs from service configuration.\n *\n * Combines service names with Lambda IDs to create fully qualified\n * Lambda identifiers for type-safe Lambda resolution.\n *\n * @template T - The register configuration object type\n */\nexport type LambdaIds<T extends Record<string, MicroserviceDefinition>> = {\n  [K in keyof T]: T[K]['lambdas'][number] extends { id: infer I }\n    ? I extends string\n      ? `${K & string}.${I}`\n      : never\n    : never;\n}[keyof T];\n\n/**\n * Type constraint for valid service names.\n *\n * Ensures service names follow the validation pattern:\n * - Must start with a letter (a-z, A-Z)\n * - Can contain letters, numbers, and hyphens\n * - Maximum length: 128 characters\n *\n * This is a branded type that provides compile-time validation.\n */\nexport type ValidServiceName = string & { readonly __brand: 'ValidServiceName' };\n\n/**\n * Type guard to validate service name format.\n *\n * @param serviceName - The service name to validate\n * @returns Type predicate indicating if the service name is valid\n */\nexport function isValidServiceName(serviceName: string): serviceName is ValidServiceName {\n  return /^[a-zA-Z][a-zA-Z0-9-]{0,127}$/.test(serviceName);\n}\n\n/**\n * Main configuration interface for Runtime Target Core.\n *\n * This interface provides a unified configuration that works across all execution contexts:\n * - Browser: Hydrates React application with client-side routing\n * - Lambda: Executes server-side rendering and business logic\n * - CDK: Synthesizes CloudFormation infrastructure\n *\n * @template TRegister - The register configuration type for type-safe service names\n *\n * @example\n * ```typescript\n * import { purenow } from '@worktif/purenow/runtime-web';\n * import { PurenowRouter } from '@worktif/purenow';\n *\n * const config = {\n *   app: ({ router }) => <App router={router} />,\n *   router: new PurenowRouter({ router: routes, defaults: {} }),\n *   serviceName: 'my-app',\n *   stage: 'dev',\n *   register: {\n *     payments: {\n *       ties: [PaymentsTies],\n *       lambdas: [chargeHandler, refundHandler]\n *     },\n *     users: {\n *       ties: [UsersTies],\n *       lambdas: [createUserHandler, getUserHandler]\n *     }\n *   } as const,  // Use 'as const' for better type inference\n *   infra: {\n *     env: { account: '123456789012', region: 'us-east-1' },\n *     stage: 'dev',\n *     reactEntry: './src/index.tsx',\n *     apiMode: 'apiGateway'\n *   }\n * } satisfies PurenowConfig;\n *\n * purenow(config);\n * ```\n *\n * @todo: after RuntimeWeb repo will be resolved, RuntimeWebConfig MUST extend PurenowConfig Core\n */\nexport interface RuntimeWebConfig<TRegister extends Record<string, MicroserviceDefinition> = Record<string, MicroserviceDefinition>> {\n  /**\n   * React application component factory function.\n   *\n   * Receives the router instance as a dependency and returns the root React element.\n   * This pattern enables dependency injection of the router into your application.\n   *\n   * @param deps - Dependencies object containing the router\n   * @param deps.router - PurenowRouter instance for navigation and routing\n   * @returns Root React element (React.ReactElement)\n   *\n   * @example\n   * ```typescript\n   * app: ({ router }) => <App router={router} />\n   * ```\n   */\n  app: (deps: { router: PurenowRouter }) => React.ReactElement;\n\n  /**\n   * PurenowRouter instance for application routing.\n   *\n   * Defines all routes, loaders, and navigation configuration.\n   * The router is used in both server-side rendering (Lambda) and client-side hydration (browser).\n   *\n   * @see {@link PurenowRouter} for router configuration\n   *\n   * @example\n   * ```typescript\n   * router: new PurenowRouter({\n   *   router: [\n   *     { path: '/', element: <Home /> },\n   *     { path: '/about', element: <About /> }\n   *   ],\n   *   defaults: {}\n   * })\n   * ```\n   */\n  router: PurenowRouter;\n\n  /**\n   * Service name identifier for the application.\n   *\n   * Used as a prefix for all AWS resources (Lambda functions, API Gateway, S3 buckets, etc.).\n   * Must be unique within your AWS account and region.\n   *\n   * **Validation Rules**:\n   * - Must start with a letter (a-z, A-Z)\n   * - Can contain letters, numbers, and hyphens\n   * - Maximum length: 128 characters\n   * - Pattern: `/^[a-zA-Z][a-zA-Z0-9-]{0,127}$/`\n   *\n   * **Examples**:\n   * - Valid: `my-app`, `MyApp`, `app123`, `my-app-v2`\n   * - Invalid: `123app` (starts with number), `my_app` (underscore), `my app` (space)\n   *\n   * @example\n   * ```typescript\n   * serviceName: 'my-application'\n   * ```\n   */\n  serviceName: string;\n\n  /**\n   * Deployment stage/environment.\n   *\n   * Determines the environment-specific configuration and resource naming.\n   * Used to create separate infrastructure stacks for different environments.\n   *\n   * **Values**:\n   * - `dev`: Development environment (local testing, rapid iteration)\n   * - `staging`: Staging/pre-production environment (QA, integration testing)\n   * - `prod`: Production environment (live users)\n   *\n   * **Impact**:\n   * - Resource naming: `{serviceName}-{resource}-{stage}`\n   * - Environment variables: Different configs per stage\n   * - Cache TTL: Shorter in dev, longer in prod\n   * - Logging: More verbose in dev, structured in prod\n   *\n   * @example\n   * ```typescript\n   * stage: 'dev'\n   * ```\n   */\n  stage: Stage;\n\n  /**\n   * Microservice registry (runtime-level configuration).\n   *\n   * **Required**: Defines all microservices, their DI containers, and Lambda endpoints.\n   * **Used in all contexts**: Browser (for type generation), Lambda (for DI), CDK (for infrastructure).\n   * **Architecture**: This is runtime configuration, separate from infrastructure concerns.\n   *\n   * Each microservice gets its own PureContainer instance built from the Ties classes.\n   * Lambda functions are automatically created and wired with dependency injection.\n   *\n   * **Type Safety**: Service names are derived from object keys, ensuring compile-time validation.\n   * **No Magic Strings**: All service identifiers are type-safe and auto-generated.\n   *\n   * @see {@link MicroserviceDefinition} for microservice structure\n   *\n   * @example\n   * ```typescript\n   * register: {\n   *   payments: {\n   *     ties: [PaymentsTies, BillingTies],\n   *     lambdas: [chargeHandler, refundHandler, webhookHandler]\n   *   },\n   *   users: {\n   *     ties: [UsersTies, AuthTies],\n   *     lambdas: [createUserHandler, getUserHandler, loginHandler]\n   *   }\n   * } as const  // Use 'as const' for better type inference\n   * ```\n   */\n  register: TRegister;\n\n  /**\n   * Infrastructure configuration for CDK deployment.\n   *\n   * **Optional**: Only required when running in CDK context (synthesizing CloudFormation templates).\n   * **Not used**: In browser and Lambda contexts (runtime configuration is in register).\n   * **Pure infrastructure**: Contains only AWS resource configuration, no business logic.\n   *\n   * Defines:\n   * - AWS account and region\n   * - Lambda configuration (memory, timeout, VPC)\n   * - API Gateway or Lambda URL mode\n   * - Custom domain configuration\n   * - React entry point for SSR Lambda\n   *\n   * @see {@link InfraOptions} for detailed configuration options\n   *\n   * @example\n   * ```typescript\n   * infra: {\n   *   env: { account: '123456789012', region: 'us-east-1' },\n   *   stage: 'dev',\n   *   reactEntry: './src/index.tsx',\n   *   apiMode: 'apiGateway',\n   *   lambdaMemorySize: 1024,\n   *   lambdaTimeout: 30,\n   *   domain: {\n   *     rootDomain: 'myapp.com',\n   *     subdomain: 'api'\n   *   }\n   * }\n   * ```\n   */\n  infra?: InfraOptions;\n}\n\n/**\n * Type-safe Purenow configuration with inferred service names.\n *\n * This type provides Runtime Core type safety by inferring service names from the register\n * configuration, enabling compile-time validation of service references.\n *\n * @template TRegister - The register configuration type\n */\nexport type TypeSafePurenowConfig<TRegister extends Record<string, MicroserviceDefinition>> =\n  RuntimeWebConfig<TRegister> & {\n  /**\n   * Type-safe service names derived from register keys.\n   * Available at compile-time for type checking and IDE autocomplete.\n   */\n  readonly serviceNames?: ServiceNames<TRegister>;\n\n  /**\n   * Type-safe Lambda IDs derived from register configuration.\n   * Available at compile-time for type checking and IDE autocomplete.\n   */\n  readonly lambdaIds?: LambdaIds<TRegister>;\n};\n", "/*\n * Elastic License 2.0\n * Copyright (C) 2025\u2013present Raman Marozau, Work Target Insight Function. All rights reserved.\n * Contact: raman@worktif.com\n *\n * This file is part of the Licensed Work: worktif.purenow.cdk <worktif_purenow_cdk>.\n * Use of this software is governed by the Elastic License 2.0; see the LICENSE file\n * or https://www.elastic.co/licensing/elastic-license for details.\n *\n * Re-licensing notice:\n *   This file was previously distributed under the Business Source License 1.1 (BUSL-1.1).\n *   As of 2025-09-22, it is re-licensed under Elastic License 2.0.\n *\n * SPDX-License-Identifier: Elastic-2.0\n */\n\nimport { purenow, PurenowRoute, purenowRouter, PurenowRouterDefaults } from '@worktif/purenow';\nimport { RuntimeWebConfig } from '@lib/runtime-web/types';\n\n/**\n * Error thrown when configuration validation fails.\n * Follows purenow error patterns without emoji.\n */\nexport class ConfigValidationError extends Error {\n  /** Array of validation error messages */\n  readonly errors: string[];\n\n  constructor(errors: string[]) {\n    super(`Configuration validation failed:\\n${errors.map(e => `  - ${e}`).join('\\n')}`);\n    this.name = 'ConfigValidationError';\n    this.errors = errors;\n    Error.captureStackTrace(this, this.constructor);\n  }\n}\n\n/**\n * Error thrown when environment detection fails.\n * Follows purenow error patterns without emoji.\n */\nexport class EnvironmentDetectionError extends Error {\n  constructor(message: string) {\n    super(message);\n    this.name = 'EnvironmentDetectionError';\n    Error.captureStackTrace(this, this.constructor);\n  }\n}\n\n/**\n * Detect the current runtime environment.\n * This is a lightweight detection that works in all environments.\n */\nfunction detectEnvironment(): 'browser' | 'lambda' | 'cdk' {\n  // Browser detection\n  if (typeof window !== 'undefined') {\n    return 'browser';\n  }\n\n  // Lambda detection\n  if (typeof process !== 'undefined' && process.env?.AWS_LAMBDA_FUNCTION_NAME) {\n    return 'lambda';\n  }\n\n  // CDK detection\n  if (typeof process !== 'undefined') {\n    if (process.env?.PURENOW_MODE === 'cdk') {\n      return 'cdk';\n    }\n    if (process.env?.CDK_DEFAULT_ACCOUNT || process.env?.CDK_DEFAULT_REGION) {\n      return 'cdk';\n    }\n    if (process.argv?.some(arg => arg.includes('cdk') || arg.includes('synth'))) {\n      return 'cdk';\n    }\n  }\n\n  // Default to CDK for Node.js environments (build time)\n  return 'cdk';\n}\n\n/**\n * Validate configuration for the given environment.\n * Lightweight validation that works in all environments.\n */\nfunction validateConfig(config: RuntimeWebConfig, isCDKContext: boolean): { valid: boolean; errors: string[] } {\n  const errors: string[] = [];\n\n  // Service name validation\n  if (!config.serviceName || !/^[a-zA-Z][a-zA-Z0-9-]{0,127}$/.test(config.serviceName)) {\n    errors.push('serviceName must start with a letter, contain only alphanumeric characters and hyphens, and be max 128 characters');\n  }\n\n  // Stage validation\n  if (!['dev', 'staging', 'prod'].includes(config.stage)) {\n    errors.push('stage must be one of: dev, staging, prod');\n  }\n\n  // Infra validation for CDK context\n  if (isCDKContext && !config.infra) {\n    errors.push('infra configuration is required in CDK context');\n  }\n\n  return { valid: errors.length === 0, errors };\n}\n\n/**\n * Unified entry point for Runtime Target Core.\n *\n * This function provides a single API that works across all execution contexts:\n * - **Browser**: Hydrates React application with client-side routing\n * - **Lambda**: Executes server-side rendering and business logic with DI\n * - **CDK**: Synthesizes CloudFormation infrastructure templates\n *\n * The function automatically detects the runtime environment and routes\n * execution to the appropriate pipeline without user intervention.\n *\n * **Note**: For Lambda and CDK contexts, use the server-side entry point\n * from `@core/runtime-web` instead. This browser-compatible version\n * only supports browser hydration.\n *\n * @param config - Unified configuration for all contexts\n * @returns Promise that resolves when execution completes\n * @throws ConfigValidationError if configuration is invalid\n * @throws EnvironmentDetectionError if environment cannot be detected\n * @throws Error if execution fails\n *\n * @example\n * ```typescript\n * import { purenow } from '@worktif/purenow/runtime-web';\n * import { PurenowRouter } from '@worktif/purenow';\n *\n * purenow({\n *   app: ({ router }) => <App router={router} />,\n *   router: new PurenowRouter({ routes, defaults: {} }),\n *   serviceName: 'my-app',\n *   stage: 'dev',\n *   register: {\n *     payments: {\n *       ties: [PaymentsTies],\n *       lambdas: [chargeHandler, refundHandler]\n *     }\n *   },\n *   infra: {\n *     env: { account: '123456789012', region: 'us-east-1' },\n *     stage: 'dev',\n *     reactEntry: './src/index.tsx',\n *     apiMode: 'apiGateway'\n *   }\n * });\n * ```\n */\nexport function pureweb(config: RuntimeWebConfig): void {\n  // 1. Detect runtime environment using lightweight detection\n  const envType = detectEnvironment();\n  const isCDKContext = envType === 'cdk';\n\n  // 2. Validate configuration\n  const validationResult = validateConfig(config, isCDKContext);\n\n  if (!validationResult.valid) {\n    throw new ConfigValidationError(validationResult.errors);\n  }\n\n  // 3. Route to appropriate pipeline based on environment\n  switch (envType) {\n    case 'browser': {\n      // Browser pipeline - hydrate React app\n      // This is the only path that runs in the browser\n      purenow({\n        app: ({ router }) => config.app({ router }),\n        router: purenowRouter({\n          router: config.router.getRoutes() as PurenowRoute[],\n          defaults: config.router.defaults as PurenowRouterDefaults,\n        }),\n        config: {\n          serviceName: config.serviceName,\n          stage: config.stage,\n        },\n      });\n      break;\n    }\n\n    case 'lambda':\n    case 'cdk': {\n      // Lambda and CDK pipelines require server-side code\n      // These should use the server-side entry point from @core/runtime-web\n      console.log('[Runtime] Server-side pipeline detected (%s)', envType);\n      purenow({\n        app: ({ router }) => config.app({ router }),\n        router: purenowRouter({\n          router: config.router.getRoutes() as PurenowRoute[],\n          defaults: config.router.defaults as PurenowRouterDefaults,\n        }),\n        config: {\n          serviceName: config.serviceName,\n          stage: config.stage,\n        },\n      });\n      break;\n      // console.log('[Runtime Web] Lambda runtime detected, skipping browser rendering pipeline');\n      // throw new EnvironmentDetectionError(\n      //   `Server-side environment detected (${envType}). ` +\n      //   `Use the server-side entry point from '@core/runtime-web' for Lambda and CDK contexts.`,\n      // );\n    }\n\n    default:\n      console.log('[Runtime Web] Unknown environment type: %s', envType);\n      break;\n    // throw new EnvironmentDetectionError(\n    //   `Unknown environment type: ${envType}`,\n    // );\n  }\n}\n\n\n", "/*\n * Elastic License 2.0\n * Copyright (C) 2025\u2013present Raman Marozau, Work Target Insight Function. All rights reserved.\n * Contact: raman@worktif.com\n *\n * This file is part of the Licensed Work: worktif.purenow.cdk <worktif_purenow_cdk>.\n * Use of this software is governed by the Elastic License 2.0; see the LICENSE file\n * or https://www.elastic.co/licensing/elastic-license for details.\n *\n * Re-licensing notice:\n *   This file was previously distributed under the Business Source License 1.1 (BUSL-1.1).\n *   As of 2025-09-22, it is re-licensed under Elastic License 2.0.\n *\n * SPDX-License-Identifier: Elastic-2.0\n */\n\n\nimport type { PurenowConfig } from '@worktif/purenow';\n\n/**\n * Runtime-specific configuration that extends PurenowConfig.\n *\n * This interface adds runtime workspace functionality while preserving\n * all existing purenow configuration options. The runtime configuration\n * is merged with purenow configuration rather than replacing it.\n */\nexport interface RuntimeConfig extends PurenowConfig {\n  /**\n   * Runtime-specific configuration options.\n   * These settings extend purenow functionality without replacing it.\n   */\n  runtime?: {\n    /** Enable Runtime Core stack deployment (extends purenow's two-stack architecture) */\n    enableThirdStack?: boolean;\n\n    /** Runtime web mode configuration */\n    runtimeWebMode?: 'development' | 'production';\n\n    /** Additional runtime features to enable */\n    additionalFeatures?: string[];\n\n    /** Development server enhancements */\n    devServerEnhancements?: {\n      /** Enable hot module replacement */\n      hotReload?: boolean;\n      /** Enable debug mode with additional logging */\n      debugMode?: boolean;\n      /** Enable performance monitoring */\n      performanceMonitoring?: boolean;\n    };\n\n    /** Build optimizations */\n    buildOptimizations?: {\n      /** Enable bundle analysis */\n      bundleAnalysis?: boolean;\n      /** Enable tree shaking */\n      treeshaking?: boolean;\n      /** Enable code minification */\n      codeMinification?: boolean;\n    };\n  };\n}\n\n/**\n * Configuration merging utility that preserves all purenow settings\n * while adding runtime-specific extensions.\n *\n * @param purenowConfig - Base purenow configuration\n * @param runtimeConfig - Runtime-specific configuration to merge\n * @returns Merged configuration with all purenow settings preserved\n */\nexport function mergeRuntimeConfig(\n  purenowConfig: PurenowConfig,\n  runtimeConfig?: Partial<RuntimeConfig['runtime']>,\n): RuntimeConfig {\n  return {\n    ...purenowConfig,\n    runtime: {\n      enableThirdStack: false,\n      runtimeWebMode: 'development',\n      additionalFeatures: [],\n\n      // @todo: critial to improve this solution. Otherwise \u2013> UNNECESSARY OPTIONS TOTALLY\n      devServerEnhancements: {\n        hotReload: true,\n        debugMode: false,\n        performanceMonitoring: false,\n      },\n      buildOptimizations: {\n        bundleAnalysis: false,\n        treeshaking: true,\n        codeMinification: true,\n      },\n      ...runtimeConfig,\n    },\n  };\n}\n\n/**\n * Type guard to check if a configuration is a RuntimeConfig.\n *\n * @param config - Configuration to check\n * @returns True if the configuration has runtime-specific properties\n */\nexport function isRuntimeConfig(config: any): config is RuntimeConfig {\n  return !!(config && typeof config === 'object' && 'runtime' in config);\n}\n\n/**\n * Extract runtime-specific configuration from a RuntimeConfig.\n *\n * @param config - RuntimeConfig to extract from\n * @returns Runtime-specific configuration or undefined\n */\nexport function extractRuntimeConfig(config: RuntimeConfig): RuntimeConfig['runtime'] {\n  return config.runtime;\n}\n\n/**\n * Create a RuntimeConfig from a base PurenowConfig with default runtime settings.\n *\n * @param purenowConfig - Base purenow configuration\n * @returns RuntimeConfig with default runtime settings\n */\nexport function createRuntimeConfig(purenowConfig: PurenowConfig): RuntimeConfig {\n  return mergeRuntimeConfig(purenowConfig);\n}\n"],
  "mappings": "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",
  "names": ["React", "hydrateRoot", "createBrowserRouter", "RouterProvider", "BrowserPipeline", "config", "context", "browserRouter", "appElement", "routerProvider", "error", "routes", "container", "baseUrl", "stage", "isValidServiceName", "serviceName", "purenow", "purenowRouter", "ConfigValidationError", "errors", "EnvironmentDetectionError", "message", "detectEnvironment", "arg", "validateConfig", "config", "isCDKContext", "pureweb", "envType", "validationResult", "router", "mergeRuntimeConfig", "purenowConfig", "runtimeConfig", "isRuntimeConfig", "config", "extractRuntimeConfig", "createRuntimeConfig"]
}

|
|
1
|
+
var u=(e=>typeof require<"u"?require:typeof Proxy<"u"?new Proxy(e,{get:(r,t)=>(typeof require<"u"?require:r)[t]}):e)(function(e){if(typeof require<"u")return require.apply(this,arguments);throw Error('Dynamic require of "'+e+'" is not supported')});function d(e){return/^[a-zA-Z][a-zA-Z0-9-]{0,127}$/.test(e)}var n=class extends Error{constructor(r){super(`Configuration validation failed:
|
|
2
|
+
${r.map(t=>` - ${t}`).join(`
|
|
3
|
+
`)}`),this.name="ConfigValidationError",this.errors=r,Error.captureStackTrace(this,this.constructor)}},c=class extends Error{constructor(r){super(r),this.name="EnvironmentDetectionError",Error.captureStackTrace(this,this.constructor)}};function b(){return typeof window<"u"?"browser":typeof process<"u"&&process.env?.AWS_LAMBDA_FUNCTION_NAME?"lambda":(typeof process<"u"&&(process.env?.PURENOW_MODE==="cdk"||process.env?.CDK_DEFAULT_ACCOUNT||process.env?.CDK_DEFAULT_REGION||process.argv?.some(e=>e.includes("cdk")||e.includes("synth"))),"cdk")}function y(e,r){let t=[];return(!e.serviceName||!/^[a-zA-Z][a-zA-Z0-9-]{0,127}$/.test(e.serviceName))&&t.push("serviceName must start with a letter, contain only alphanumeric characters and hyphens, and be max 128 characters"),["dev","staging","prod"].includes(e.stage)||t.push("stage must be one of: dev, staging, prod"),r&&!e.infra&&t.push("infra configuration is required in CDK context"),{valid:t.length===0,errors:t}}function C(e){let r=b(),p=y(e,r==="cdk");if(!p.valid)throw new n(p.errors);switch(r){case"browser":{let i=(globalThis.require||u)("@worktif/purenow"),{purenow:o,purenowRouter:a}=i;o({app:({router:s})=>e.app({router:s}),router:a({router:e.router.getRoutes(),defaults:e.router.defaults}),config:{serviceName:e.serviceName,stage:e.stage}});break}case"lambda":case"cdk":{console.log("[Runtime] Server-side pipeline detected (%s)",r);let i=(globalThis.require||u)("@worktif/purenow"),{purenow:o,purenowRouter:a}=i;o({app:({router:s})=>e.app({router:s}),router:a({router:e.router.getRoutes(),defaults:e.router.defaults}),config:{serviceName:e.serviceName,stage:e.stage}});break}default:console.log("[Runtime Web] Unknown environment type: %s",r);break}}function m(e,r){return{...e,runtime:{enableThirdStack:!1,runtimeWebMode:"development",additionalFeatures:[],devServerEnhancements:{hotReload:!0,debugMode:!1,performanceMonitoring:!1},buildOptimizations:{bundleAnalysis:!1,treeshaking:!0,codeMinification:!0},...r}}}function f(e){return!!(e&&typeof e=="object"&&"runtime"in e)}function g(e){return e.runtime}function l(e){return m(e)}export{n as ConfigValidationError,c as EnvironmentDetectionError,l as createRuntimeConfig,g as extractRuntimeConfig,f as isRuntimeConfig,d as isValidServiceName,m as mergeRuntimeConfig,C as pureweb};
|
|
4
|
+
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../src/lib/runtime-web/types/config.types.ts", "../../../src/lib/runtime-web/pureweb.ts", "../../../src/lib/runtime-web/runtime.config.types.tsx"],
  "sourcesContent": ["/*\n * Elastic License 2.0\n * Copyright (C) 2025\u2013present Raman Marozau, Work Target Insight Function. All rights reserved.\n * Contact: raman@worktif.com\n *\n * This file is part of the Licensed Work: worktif.purenow.cdk <worktif_purenow_cdk>.\n * Use of this software is governed by the Elastic License 2.0; see the LICENSE file\n * or https://www.elastic.co/licensing/elastic-license for details.\n *\n * Re-licensing notice:\n *   This file was previously distributed under the Business Source License 1.1 (BUSL-1.1).\n *   As of 2025-09-22, it is re-licensed under Elastic License 2.0.\n *\n * SPDX-License-Identifier: Elastic-2.0\n */\n\nimport * as React from 'react';\nimport type { InfraOptions } from './infra.types';\nimport type { MicroserviceDefinition } from './microservice.types';\n\n/**\n * PurenowRouter interface for runtime-web integration.\n *\n * Defines the essential methods needed by the runtime-web pipelines.\n * This interface matches the actual PurenowRouter class from @lib/react/purenow.router.\n */\ninterface PurenowRouter {\n  /**\n   * Get all route objects as an array.\n   * Used for creating browser routers and SSR static handlers.\n   */\n  getRoutes(): Array<{\n    path?: string;\n    element?: unknown;\n    loader?: unknown;\n    children?: unknown;\n    [key: string]: unknown;\n  }>;\n\n  /**\n   * Find a route by its ID.\n   */\n  getRouteById?(id: string): unknown;\n\n  /**\n   * Find a route by its path.\n   */\n  getRouteByPath?(path: string): unknown;\n\n  /**\n   * Get the routes array (getter).\n   */\n  routes?: Array<unknown>;\n\n  /**\n   * Get the default configuration.\n   */\n  defaults?: unknown;\n}\n\n/**\n * Stage environment for deployment.\n *\n * - `dev`: Development environment\n * - `staging`: Staging/pre-production environment\n * - `prod`: Production environment\n */\nexport type Stage = 'dev' | 'staging' | 'prod';\n\n/**\n * Utility type to extract service names from register configuration.\n *\n * This enables compile-time validation of service names and provides\n * type-safe access to service identifiers throughout the framework.\n *\n * @template T - The register configuration object type\n */\nexport type ServiceNames<T extends Record<string, MicroserviceDefinition>> = keyof T;\n\n/**\n * Utility type to generate Lambda IDs from service configuration.\n *\n * Combines service names with Lambda IDs to create fully qualified\n * Lambda identifiers for type-safe Lambda resolution.\n *\n * @template T - The register configuration object type\n */\nexport type LambdaIds<T extends Record<string, MicroserviceDefinition>> = {\n  [K in keyof T]: T[K]['lambdas'][number] extends { id: infer I }\n    ? I extends string\n      ? `${K & string}.${I}`\n      : never\n    : never;\n}[keyof T];\n\n/**\n * Type constraint for valid service names.\n *\n * Ensures service names follow the validation pattern:\n * - Must start with a letter (a-z, A-Z)\n * - Can contain letters, numbers, and hyphens\n * - Maximum length: 128 characters\n *\n * This is a branded type that provides compile-time validation.\n */\nexport type ValidServiceName = string & { readonly __brand: 'ValidServiceName' };\n\n/**\n * Type guard to validate service name format.\n *\n * @param serviceName - The service name to validate\n * @returns Type predicate indicating if the service name is valid\n */\nexport function isValidServiceName(serviceName: string): serviceName is ValidServiceName {\n  return /^[a-zA-Z][a-zA-Z0-9-]{0,127}$/.test(serviceName);\n}\n\n/**\n * Main configuration interface for Runtime Target Core.\n *\n * This interface provides a unified configuration that works across all execution contexts:\n * - Browser: Hydrates React application with client-side routing\n * - Lambda: Executes server-side rendering and business logic\n * - CDK: Synthesizes CloudFormation infrastructure\n *\n * @template TRegister - The register configuration type for type-safe service names\n *\n * @example\n * ```typescript\n * import { purenow } from '@worktif/purenow/runtime-web';\n * import { PurenowRouter } from '@worktif/purenow';\n *\n * const config = {\n *   app: ({ router }) => <App router={router} />,\n *   router: new PurenowRouter({ router: routes, defaults: {} }),\n *   serviceName: 'my-app',\n *   stage: 'dev',\n *   register: {\n *     payments: {\n *       ties: [PaymentsTies],\n *       lambdas: [chargeHandler, refundHandler]\n *     },\n *     users: {\n *       ties: [UsersTies],\n *       lambdas: [createUserHandler, getUserHandler]\n *     }\n *   } as const,  // Use 'as const' for better type inference\n *   infra: {\n *     env: { account: '123456789012', region: 'us-east-1' },\n *     stage: 'dev',\n *     reactEntry: './src/index.tsx',\n *     apiMode: 'apiGateway'\n *   }\n * } satisfies PurenowConfig;\n *\n * purenow(config);\n * ```\n *\n * @todo: after RuntimeWeb repo will be resolved, RuntimeWebConfig MUST extend PurenowConfig Core\n */\nexport interface RuntimeWebConfig<TRegister extends Record<string, MicroserviceDefinition> = Record<string, MicroserviceDefinition>> {\n  /**\n   * React application component factory function.\n   *\n   * Receives the router instance as a dependency and returns the root React element.\n   * This pattern enables dependency injection of the router into your application.\n   *\n   * @param deps - Dependencies object containing the router\n   * @param deps.router - PurenowRouter instance for navigation and routing\n   * @returns Root React element (React.ReactElement)\n   *\n   * @example\n   * ```typescript\n   * app: ({ router }) => <App router={router} />\n   * ```\n   */\n  app: (deps: { router: PurenowRouter }) => React.ReactElement;\n\n  /**\n   * PurenowRouter instance for application routing.\n   *\n   * Defines all routes, loaders, and navigation configuration.\n   * The router is used in both server-side rendering (Lambda) and client-side hydration (browser).\n   *\n   * @see {@link PurenowRouter} for router configuration\n   *\n   * @example\n   * ```typescript\n   * router: new PurenowRouter({\n   *   router: [\n   *     { path: '/', element: <Home /> },\n   *     { path: '/about', element: <About /> }\n   *   ],\n   *   defaults: {}\n   * })\n   * ```\n   */\n  router: PurenowRouter;\n\n  /**\n   * Service name identifier for the application.\n   *\n   * Used as a prefix for all AWS resources (Lambda functions, API Gateway, S3 buckets, etc.).\n   * Must be unique within your AWS account and region.\n   *\n   * **Validation Rules**:\n   * - Must start with a letter (a-z, A-Z)\n   * - Can contain letters, numbers, and hyphens\n   * - Maximum length: 128 characters\n   * - Pattern: `/^[a-zA-Z][a-zA-Z0-9-]{0,127}$/`\n   *\n   * **Examples**:\n   * - Valid: `my-app`, `MyApp`, `app123`, `my-app-v2`\n   * - Invalid: `123app` (starts with number), `my_app` (underscore), `my app` (space)\n   *\n   * @example\n   * ```typescript\n   * serviceName: 'my-application'\n   * ```\n   */\n  serviceName: string;\n\n  /**\n   * Deployment stage/environment.\n   *\n   * Determines the environment-specific configuration and resource naming.\n   * Used to create separate infrastructure stacks for different environments.\n   *\n   * **Values**:\n   * - `dev`: Development environment (local testing, rapid iteration)\n   * - `staging`: Staging/pre-production environment (QA, integration testing)\n   * - `prod`: Production environment (live users)\n   *\n   * **Impact**:\n   * - Resource naming: `{serviceName}-{resource}-{stage}`\n   * - Environment variables: Different configs per stage\n   * - Cache TTL: Shorter in dev, longer in prod\n   * - Logging: More verbose in dev, structured in prod\n   *\n   * @example\n   * ```typescript\n   * stage: 'dev'\n   * ```\n   */\n  stage: Stage;\n\n  /**\n   * Microservice registry (runtime-level configuration).\n   *\n   * **Required**: Defines all microservices, their DI containers, and Lambda endpoints.\n   * **Used in all contexts**: Browser (for type generation), Lambda (for DI), CDK (for infrastructure).\n   * **Architecture**: This is runtime configuration, separate from infrastructure concerns.\n   *\n   * Each microservice gets its own PureContainer instance built from the Ties classes.\n   * Lambda functions are automatically created and wired with dependency injection.\n   *\n   * **Type Safety**: Service names are derived from object keys, ensuring compile-time validation.\n   * **No Magic Strings**: All service identifiers are type-safe and auto-generated.\n   *\n   * @see {@link MicroserviceDefinition} for microservice structure\n   *\n   * @example\n   * ```typescript\n   * register: {\n   *   payments: {\n   *     ties: [PaymentsTies, BillingTies],\n   *     lambdas: [chargeHandler, refundHandler, webhookHandler]\n   *   },\n   *   users: {\n   *     ties: [UsersTies, AuthTies],\n   *     lambdas: [createUserHandler, getUserHandler, loginHandler]\n   *   }\n   * } as const  // Use 'as const' for better type inference\n   * ```\n   */\n  register: TRegister;\n\n  /**\n   * Infrastructure configuration for CDK deployment.\n   *\n   * **Optional**: Only required when running in CDK context (synthesizing CloudFormation templates).\n   * **Not used**: In browser and Lambda contexts (runtime configuration is in register).\n   * **Pure infrastructure**: Contains only AWS resource configuration, no business logic.\n   *\n   * Defines:\n   * - AWS account and region\n   * - Lambda configuration (memory, timeout, VPC)\n   * - API Gateway or Lambda URL mode\n   * - Custom domain configuration\n   * - React entry point for SSR Lambda\n   *\n   * @see {@link InfraOptions} for detailed configuration options\n   *\n   * @example\n   * ```typescript\n   * infra: {\n   *   env: { account: '123456789012', region: 'us-east-1' },\n   *   stage: 'dev',\n   *   reactEntry: './src/index.tsx',\n   *   apiMode: 'apiGateway',\n   *   lambdaMemorySize: 1024,\n   *   lambdaTimeout: 30,\n   *   domain: {\n   *     rootDomain: 'myapp.com',\n   *     subdomain: 'api'\n   *   }\n   * }\n   * ```\n   */\n  infra?: InfraOptions;\n}\n\n/**\n * Type-safe Purenow configuration with inferred service names.\n *\n * This type provides Runtime Core type safety by inferring service names from the register\n * configuration, enabling compile-time validation of service references.\n *\n * @template TRegister - The register configuration type\n */\nexport type TypeSafePurenowConfig<TRegister extends Record<string, MicroserviceDefinition>> =\n  RuntimeWebConfig<TRegister> & {\n  /**\n   * Type-safe service names derived from register keys.\n   * Available at compile-time for type checking and IDE autocomplete.\n   */\n  readonly serviceNames?: ServiceNames<TRegister>;\n\n  /**\n   * Type-safe Lambda IDs derived from register configuration.\n   * Available at compile-time for type checking and IDE autocomplete.\n   */\n  readonly lambdaIds?: LambdaIds<TRegister>;\n};\n", "/*\n * Elastic License 2.0\n * Copyright (C) 2025\u2013present Raman Marozau, Work Target Insight Function. All rights reserved.\n * Contact: raman@worktif.com\n *\n * This file is part of the Licensed Work: worktif.purenow.cdk <worktif_purenow_cdk>.\n * Use of this software is governed by the Elastic License 2.0; see the LICENSE file\n * or https://www.elastic.co/licensing/elastic-license for details.\n *\n * Re-licensing notice:\n *   This file was previously distributed under the Business Source License 1.1 (BUSL-1.1).\n *   As of 2025-09-22, it is re-licensed under Elastic License 2.0.\n *\n * SPDX-License-Identifier: Elastic-2.0\n */\n\nimport { RuntimeWebConfig } from '@lib/runtime-web/types';\n\n// Dynamic imports to avoid bundling @worktif/purenow in browser\n// These will be resolved at runtime when the functions are called\n\n/**\n * Error thrown when configuration validation fails.\n * Follows purenow error patterns without emoji.\n */\nexport class ConfigValidationError extends Error {\n  /** Array of validation error messages */\n  readonly errors: string[];\n\n  constructor(errors: string[]) {\n    super(`Configuration validation failed:\\n${errors.map(e => `  - ${e}`).join('\\n')}`);\n    this.name = 'ConfigValidationError';\n    this.errors = errors;\n    Error.captureStackTrace(this, this.constructor);\n  }\n}\n\n/**\n * Error thrown when environment detection fails.\n * Follows purenow error patterns without emoji.\n */\nexport class EnvironmentDetectionError extends Error {\n  constructor(message: string) {\n    super(message);\n    this.name = 'EnvironmentDetectionError';\n    Error.captureStackTrace(this, this.constructor);\n  }\n}\n\n/**\n * Detect the current runtime environment.\n * This is a lightweight detection that works in all environments.\n */\nfunction detectEnvironment(): 'browser' | 'lambda' | 'cdk' {\n  // Browser detection\n  if (typeof window !== 'undefined') {\n    return 'browser';\n  }\n\n  // Lambda detection\n  if (typeof process !== 'undefined' && process.env?.AWS_LAMBDA_FUNCTION_NAME) {\n    return 'lambda';\n  }\n\n  // CDK detection\n  if (typeof process !== 'undefined') {\n    if (process.env?.PURENOW_MODE === 'cdk') {\n      return 'cdk';\n    }\n    if (process.env?.CDK_DEFAULT_ACCOUNT || process.env?.CDK_DEFAULT_REGION) {\n      return 'cdk';\n    }\n    if (process.argv?.some(arg => arg.includes('cdk') || arg.includes('synth'))) {\n      return 'cdk';\n    }\n  }\n\n  // Default to CDK for Node.js environments (build time)\n  return 'cdk';\n}\n\n/**\n * Validate configuration for the given environment.\n * Lightweight validation that works in all environments.\n */\nfunction validateConfig(config: RuntimeWebConfig, isCDKContext: boolean): { valid: boolean; errors: string[] } {\n  const errors: string[] = [];\n\n  // Service name validation\n  if (!config.serviceName || !/^[a-zA-Z][a-zA-Z0-9-]{0,127}$/.test(config.serviceName)) {\n    errors.push('serviceName must start with a letter, contain only alphanumeric characters and hyphens, and be max 128 characters');\n  }\n\n  // Stage validation\n  if (!['dev', 'staging', 'prod'].includes(config.stage)) {\n    errors.push('stage must be one of: dev, staging, prod');\n  }\n\n  // Infra validation for CDK context\n  if (isCDKContext && !config.infra) {\n    errors.push('infra configuration is required in CDK context');\n  }\n\n  return { valid: errors.length === 0, errors };\n}\n\n/**\n * Unified entry point for Runtime Target Core.\n *\n * This function provides a single API that works across all execution contexts:\n * - **Browser**: Hydrates React application with client-side routing\n * - **Lambda**: Executes server-side rendering and business logic with DI\n * - **CDK**: Synthesizes CloudFormation infrastructure templates\n *\n * The function automatically detects the runtime environment and routes\n * execution to the appropriate pipeline without user intervention.\n *\n * **Note**: For Lambda and CDK contexts, use the server-side entry point\n * from `@core/runtime-web` instead. This browser-compatible version\n * only supports browser hydration.\n *\n * @param config - Unified configuration for all contexts\n * @returns Promise that resolves when execution completes\n * @throws ConfigValidationError if configuration is invalid\n * @throws EnvironmentDetectionError if environment cannot be detected\n * @throws Error if execution fails\n *\n * @example\n * ```typescript\n * import { purenow } from '@worktif/purenow/runtime-web';\n * import { PurenowRouter } from '@worktif/purenow';\n *\n * purenow({\n *   app: ({ router }) => <App router={router} />,\n *   router: new PurenowRouter({ routes, defaults: {} }),\n *   serviceName: 'my-app',\n *   stage: 'dev',\n *   register: {\n *     payments: {\n *       ties: [PaymentsTies],\n *       lambdas: [chargeHandler, refundHandler]\n *     }\n *   },\n *   infra: {\n *     env: { account: '123456789012', region: 'us-east-1' },\n *     stage: 'dev',\n *     reactEntry: './src/index.tsx',\n *     apiMode: 'apiGateway'\n *   }\n * });\n * ```\n */\nexport function pureweb(config: RuntimeWebConfig): void {\n  // 1. Detect runtime environment using lightweight detection\n  const envType = detectEnvironment();\n  const isCDKContext = envType === 'cdk';\n\n  // 2. Validate configuration\n  const validationResult = validateConfig(config, isCDKContext);\n\n  if (!validationResult.valid) {\n    throw new ConfigValidationError(validationResult.errors);\n  }\n\n  // 3. Route to appropriate pipeline based on environment\n  switch (envType) {\n    case 'browser': {\n      // Browser pipeline - hydrate React app\n      // This is the only path that runs in the browser\n      // Dynamic require to avoid bundling @worktif/purenow\n      const requireFn = (globalThis as any).require || require;\n      const packageName = '@worktif/purenow';\n      const purenowPackage = requireFn(packageName);\n      const { purenow, purenowRouter } = purenowPackage;\n\n      purenow({\n        app: ({ router }: any) => config.app({ router }),\n        router: purenowRouter({\n          router: config.router.getRoutes(),\n          defaults: config.router.defaults,\n        }),\n        config: {\n          serviceName: config.serviceName,\n          stage: config.stage,\n        },\n      });\n      break;\n    }\n\n    case 'lambda':\n    case 'cdk': {\n      // Lambda and CDK pipelines require server-side code\n      // These should use the server-side entry point from @core/runtime-web\n      console.log('[Runtime] Server-side pipeline detected (%s)', envType);\n\n      // Dynamic require to avoid bundling @worktif/purenow\n      const requireFn = (globalThis as any).require || require;\n      const packageName = '@worktif/purenow';\n      const purenowPackage = requireFn(packageName);\n      const { purenow, purenowRouter } = purenowPackage;\n\n      purenow({\n        app: ({ router }: any) => config.app({ router }),\n        router: purenowRouter({\n          router: config.router.getRoutes(),\n          defaults: config.router.defaults,\n        }),\n        config: {\n          serviceName: config.serviceName,\n          stage: config.stage,\n        },\n      });\n      break;\n      // console.log('[Runtime Web] Lambda runtime detected, skipping browser rendering pipeline');\n      // throw new EnvironmentDetectionError(\n      //   `Server-side environment detected (${envType}). ` +\n      //   `Use the server-side entry point from '@core/runtime-web' for Lambda and CDK contexts.`,\n      // );\n    }\n\n    default:\n      console.log('[Runtime Web] Unknown environment type: %s', envType);\n      break;\n    // throw new EnvironmentDetectionError(\n    //   `Unknown environment type: ${envType}`,\n    // );\n  }\n}\n\n\n", "/*\n * Elastic License 2.0\n * Copyright (C) 2025\u2013present Raman Marozau, Work Target Insight Function. All rights reserved.\n * Contact: raman@worktif.com\n *\n * This file is part of the Licensed Work: worktif.purenow.cdk <worktif_purenow_cdk>.\n * Use of this software is governed by the Elastic License 2.0; see the LICENSE file\n * or https://www.elastic.co/licensing/elastic-license for details.\n *\n * Re-licensing notice:\n *   This file was previously distributed under the Business Source License 1.1 (BUSL-1.1).\n *   As of 2025-09-22, it is re-licensed under Elastic License 2.0.\n *\n * SPDX-License-Identifier: Elastic-2.0\n */\n\n\nimport type { PurenowConfig } from '@worktif/purenow';\n\n/**\n * Runtime-specific configuration that extends PurenowConfig.\n *\n * This interface adds runtime workspace functionality while preserving\n * all existing purenow configuration options. The runtime configuration\n * is merged with purenow configuration rather than replacing it.\n */\nexport interface RuntimeConfig extends PurenowConfig {\n  /**\n   * Runtime-specific configuration options.\n   * These settings extend purenow functionality without replacing it.\n   */\n  runtime?: {\n    /** Enable Runtime Core stack deployment (extends purenow's two-stack architecture) */\n    enableThirdStack?: boolean;\n\n    /** Runtime web mode configuration */\n    runtimeWebMode?: 'development' | 'production';\n\n    /** Additional runtime features to enable */\n    additionalFeatures?: string[];\n\n    /** Development server enhancements */\n    devServerEnhancements?: {\n      /** Enable hot module replacement */\n      hotReload?: boolean;\n      /** Enable debug mode with additional logging */\n      debugMode?: boolean;\n      /** Enable performance monitoring */\n      performanceMonitoring?: boolean;\n    };\n\n    /** Build optimizations */\n    buildOptimizations?: {\n      /** Enable bundle analysis */\n      bundleAnalysis?: boolean;\n      /** Enable tree shaking */\n      treeshaking?: boolean;\n      /** Enable code minification */\n      codeMinification?: boolean;\n    };\n  };\n}\n\n/**\n * Configuration merging utility that preserves all purenow settings\n * while adding runtime-specific extensions.\n *\n * @param purenowConfig - Base purenow configuration\n * @param runtimeConfig - Runtime-specific configuration to merge\n * @returns Merged configuration with all purenow settings preserved\n */\nexport function mergeRuntimeConfig(\n  purenowConfig: PurenowConfig,\n  runtimeConfig?: Partial<RuntimeConfig['runtime']>,\n): RuntimeConfig {\n  return {\n    ...purenowConfig,\n    runtime: {\n      enableThirdStack: false,\n      runtimeWebMode: 'development',\n      additionalFeatures: [],\n\n      // @todo: critial to improve this solution. Otherwise \u2013> UNNECESSARY OPTIONS TOTALLY\n      devServerEnhancements: {\n        hotReload: true,\n        debugMode: false,\n        performanceMonitoring: false,\n      },\n      buildOptimizations: {\n        bundleAnalysis: false,\n        treeshaking: true,\n        codeMinification: true,\n      },\n      ...runtimeConfig,\n    },\n  };\n}\n\n/**\n * Type guard to check if a configuration is a RuntimeConfig.\n *\n * @param config - Configuration to check\n * @returns True if the configuration has runtime-specific properties\n */\nexport function isRuntimeConfig(config: any): config is RuntimeConfig {\n  return !!(config && typeof config === 'object' && 'runtime' in config);\n}\n\n/**\n * Extract runtime-specific configuration from a RuntimeConfig.\n *\n * @param config - RuntimeConfig to extract from\n * @returns Runtime-specific configuration or undefined\n */\nexport function extractRuntimeConfig(config: RuntimeConfig): RuntimeConfig['runtime'] {\n  return config.runtime;\n}\n\n/**\n * Create a RuntimeConfig from a base PurenowConfig with default runtime settings.\n *\n * @param purenowConfig - Base purenow configuration\n * @returns RuntimeConfig with default runtime settings\n */\nexport function createRuntimeConfig(purenowConfig: PurenowConfig): RuntimeConfig {\n  return mergeRuntimeConfig(purenowConfig);\n}\n"],
  "mappings": "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",
  "names": ["isValidServiceName", "serviceName", "ConfigValidationError", "errors", "e", "EnvironmentDetectionError", "message", "detectEnvironment", "arg", "validateConfig", "config", "isCDKContext", "pureweb", "envType", "validationResult", "purenowPackage", "__require", "purenow", "purenowRouter", "router", "mergeRuntimeConfig", "purenowConfig", "runtimeConfig", "isRuntimeConfig", "config", "extractRuntimeConfig", "createRuntimeConfig"]
}

|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@worktif/runtime",
|
|
3
|
-
"version": "0.3.0-edge.
|
|
3
|
+
"version": "0.3.0-edge.16",
|
|
4
4
|
"description": "Serverless web framework running on AWS Lambda with support for server-side rendering, caching, and CI/CD.",
|
|
5
5
|
"repository": "git@bitbucket.org:worktif/runtime-target.git",
|
|
6
6
|
"author": "Raman Marozau <raman@worktif.com>",
|
|
@@ -32,6 +32,16 @@
|
|
|
32
32
|
"import": "./out/dist/lib/index.mjs",
|
|
33
33
|
"require": "./out/dist/lib/index.js"
|
|
34
34
|
},
|
|
35
|
+
"./browser": {
|
|
36
|
+
"types": "./out/dist/src/browser.d.ts",
|
|
37
|
+
"import": "./out/dist/src/browser.mjs",
|
|
38
|
+
"require": "./out/dist/src/browser.js"
|
|
39
|
+
},
|
|
40
|
+
"./minimal": {
|
|
41
|
+
"types": "./out/dist/src/minimal.d.ts",
|
|
42
|
+
"import": "./out/dist/src/minimal.mjs",
|
|
43
|
+
"require": "./out/dist/src/minimal.js"
|
|
44
|
+
},
|
|
35
45
|
"./infra": {
|
|
36
46
|
"types": "./out/dist/src/infra/index.d.ts",
|
|
37
47
|
"require": "./out/dist/infra/index.js"
|