@worktif/runtime 0.3.0-edge.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (68) hide show
  1. package/LICENSE +101 -0
  2. package/README.md +495 -0
  3. package/out/dist/bin/index.js +212 -0
  4. package/out/dist/bin/purenow.js +218 -0
  5. package/out/dist/bin/templates/runtime-web/cdk/.gitignore.template +25 -0
  6. package/out/dist/bin/templates/runtime-web/cdk/README.md.template +267 -0
  7. package/out/dist/bin/templates/runtime-web/cdk/bin/app.ts.template +173 -0
  8. package/out/dist/bin/templates/runtime-web/cdk/cdk.json.template +79 -0
  9. package/out/dist/bin/templates/runtime-web/cdk/package.json.template +28 -0
  10. package/out/dist/bin/templates/runtime-web/cdk/tsconfig.json.template +38 -0
  11. package/out/dist/bin/templates/runtime-web/purenow-basic/.env.example +15 -0
  12. package/out/dist/bin/templates/runtime-web/purenow-basic/README.md +118 -0
  13. package/out/dist/bin/templates/runtime-web/purenow-basic/gitignore.template +64 -0
  14. package/out/dist/bin/templates/runtime-web/purenow-basic/package.json +34 -0
  15. package/out/dist/bin/templates/runtime-web/purenow-basic/purenow.config.ts +105 -0
  16. package/out/dist/bin/templates/runtime-web/purenow-basic/src/app.tsx +35 -0
  17. package/out/dist/bin/templates/runtime-web/purenow-basic/src/handlers/users/index.ts +17 -0
  18. package/out/dist/bin/templates/runtime-web/purenow-basic/src/handlers/users/users.handlers.ts +222 -0
  19. package/out/dist/bin/templates/runtime-web/purenow-basic/src/index.tsx +71 -0
  20. package/out/dist/bin/templates/runtime-web/purenow-basic/src/pages/about-page.tsx +65 -0
  21. package/out/dist/bin/templates/runtime-web/purenow-basic/src/pages/home-page.tsx +55 -0
  22. package/out/dist/bin/templates/runtime-web/purenow-basic/src/pages/users-page.tsx +66 -0
  23. package/out/dist/bin/templates/runtime-web/purenow-basic/src/routes.tsx +61 -0
  24. package/out/dist/bin/templates/runtime-web/purenow-basic/src/services/index.ts +17 -0
  25. package/out/dist/bin/templates/runtime-web/purenow-basic/src/services/users.service.ts +133 -0
  26. package/out/dist/bin/templates/runtime-web/purenow-basic/src/ties/index.ts +17 -0
  27. package/out/dist/bin/templates/runtime-web/purenow-basic/src/ties/users.ties.ts +53 -0
  28. package/out/dist/bin/templates/runtime-web/purenow-basic/tsconfig.json +53 -0
  29. package/out/dist/lib/index.d.ts +4 -0
  30. package/out/dist/lib/index.js +4 -0
  31. package/out/dist/lib/lib/index.d.ts +3 -0
  32. package/out/dist/lib/lib/runtime-web/index.d.ts +17 -0
  33. package/out/dist/lib/lib/runtime-web/pipelines/browser-pipeline.d.ts +110 -0
  34. package/out/dist/lib/lib/runtime-web/pipelines/index.d.ts +2 -0
  35. package/out/dist/lib/lib/runtime-web/pureweb.d.ts +65 -0
  36. package/out/dist/lib/lib/runtime-web/types/config.types.d.ts +301 -0
  37. package/out/dist/lib/lib/runtime-web/types/http.types.d.ts +171 -0
  38. package/out/dist/lib/lib/runtime-web/types/index.d.ts +14 -0
  39. package/out/dist/lib/lib/runtime-web/types/infra.types.d.ts +225 -0
  40. package/out/dist/lib/lib/runtime-web/types/lambda.types.d.ts +175 -0
  41. package/out/dist/lib/lib/runtime-web/types/microservice.types.d.ts +70 -0
  42. package/out/dist/lib/lib/runtime-web/types/runtime.types.d.ts +55 -0
  43. package/out/dist/lib/utils/index.d.ts +2 -0
  44. package/out/dist/lib/utils/types/index.d.ts +3 -0
  45. package/out/dist/lib/utils/types/runtime.config.types.d.ts +71 -0
  46. package/out/dist/src/bin/index.d.ts +5 -0
  47. package/out/dist/src/bin/index.unix.d.ts +5 -0
  48. package/out/dist/src/bin/purenow-runtime-cli.d.ts +31 -0
  49. package/out/dist/src/bin/services/index.d.ts +8 -0
  50. package/out/dist/src/bin/services/purenow-runtime-deployment.strategy.d.ts +37 -0
  51. package/out/dist/src/bin/services/purenow-runtime-stacks-deploy.service.d.ts +58 -0
  52. package/out/dist/src/bin/services/purenow-runtime-stacks-deploy.service.types.d.ts +18 -0
  53. package/out/dist/src/bin/services/runtime-web-cli-extensions.d.ts +2 -0
  54. package/out/dist/src/bin/services/template.service.d.ts +53 -0
  55. package/out/dist/src/bin/services/utils/index.d.ts +2 -0
  56. package/out/dist/src/bin/utils/errors.d.ts +68 -0
  57. package/out/dist/src/lib/runtime-web/index.d.ts +17 -0
  58. package/out/dist/src/lib/runtime-web/pipelines/browser-pipeline.d.ts +110 -0
  59. package/out/dist/src/lib/runtime-web/pipelines/index.d.ts +2 -0
  60. package/out/dist/src/lib/runtime-web/pureweb.d.ts +65 -0
  61. package/out/dist/src/lib/runtime-web/types/config.types.d.ts +301 -0
  62. package/out/dist/src/lib/runtime-web/types/http.types.d.ts +171 -0
  63. package/out/dist/src/lib/runtime-web/types/index.d.ts +14 -0
  64. package/out/dist/src/lib/runtime-web/types/infra.types.d.ts +225 -0
  65. package/out/dist/src/lib/runtime-web/types/lambda.types.d.ts +175 -0
  66. package/out/dist/src/lib/runtime-web/types/microservice.types.d.ts +70 -0
  67. package/out/dist/src/lib/runtime-web/types/runtime.types.d.ts +55 -0
  68. package/package.json +133 -0
@@ -0,0 +1,65 @@
1
+ /*
2
+ * Elastic License 2.0
3
+ * Copyright (C) 2025–present Raman Marozau, Work Target Insight Function. All rights reserved.
4
+ * Contact: raman@worktif.com
5
+ *
6
+ * This file is part of the Licensed Work: worktif.purenow.cdk <worktif_purenow_cdk>.
7
+ * Use of this software is governed by the Elastic License 2.0; see the LICENSE file
8
+ * or https://www.elastic.co/licensing/elastic-license for details.
9
+ *
10
+ * Re-licensing notice:
11
+ * This file was previously distributed under the Business Source License 1.1 (BUSL-1.1).
12
+ * As of 2025-09-22, it is re-licensed under Elastic License 2.0.
13
+ *
14
+ * SPDX-License-Identifier: Elastic-2.0
15
+ */
16
+
17
+ import * as React from 'react';
18
+ import { Link } from 'react-router';
19
+
20
+ /**
21
+ * About page component demonstrating client-side navigation
22
+ */
23
+ const AboutPage: React.FC = () => {
24
+ return (
25
+ <div style={{ padding: '2rem', fontFamily: 'system-ui, sans-serif' }}>
26
+ <h1>About This Project</h1>
27
+
28
+ <div style={{ marginTop: '2rem' }}>
29
+ <h2>What is Purenow?</h2>
30
+ <p>
31
+ Purenow is a serverless framework for building React applications with
32
+ server-side rendering (SSR) on AWS Lambda. It provides a seamless developer
33
+ experience for creating high-performance web applications that scale automatically.
34
+ </p>
35
+ </div>
36
+
37
+ <div style={{ marginTop: '2rem' }}>
38
+ <h2>Architecture</h2>
39
+ <ul>
40
+ <li><strong>AWS Lambda:</strong> Handles SSR requests with minimal cold start times</li>
41
+ <li><strong>CloudFront:</strong> Global CDN for fast content delivery</li>
42
+ <li><strong>S3:</strong> Static asset hosting with intelligent caching</li>
43
+ <li><strong>API Gateway:</strong> Routes requests to Lambda handlers</li>
44
+ <li><strong>DynamoDB:</strong> Optional SEO metadata storage</li>
45
+ </ul>
46
+ </div>
47
+
48
+ <div style={{ marginTop: '2rem' }}>
49
+ <h2>Getting Started</h2>
50
+ <p>
51
+ To learn more about Purenow and how to build your own serverless React applications,
52
+ visit the documentation or explore the source code.
53
+ </p>
54
+ </div>
55
+
56
+ <div style={{ marginTop: '2rem' }}>
57
+ <Link to="/" style={{ color: '#0066cc', textDecoration: 'none' }}>
58
+ ← Back to Home
59
+ </Link>
60
+ </div>
61
+ </div>
62
+ );
63
+ };
64
+
65
+ export default AboutPage;
@@ -0,0 +1,55 @@
1
+ /*
2
+ * Elastic License 2.0
3
+ * Copyright (C) 2025–present Raman Marozau, Work Target Insight Function. All rights reserved.
4
+ * Contact: raman@worktif.com
5
+ *
6
+ * This file is part of the Licensed Work: worktif.purenow.cdk <worktif_purenow_cdk>.
7
+ * Use of this software is governed by the Elastic License 2.0; see the LICENSE file
8
+ * or https://www.elastic.co/licensing/elastic-license for details.
9
+ *
10
+ * Re-licensing notice:
11
+ * This file was previously distributed under the Business Source License 1.1 (BUSL-1.1).
12
+ * As of 2025-09-22, it is re-licensed under Elastic License 2.0.
13
+ *
14
+ * SPDX-License-Identifier: Elastic-2.0
15
+ */
16
+
17
+ import * as React from 'react';
18
+ import { Link } from 'react-router';
19
+
20
+ /**
21
+ * Home page component demonstrating Purenow SSR capabilities
22
+ */
23
+ const HomePage: React.FC = () => {
24
+ return (
25
+ <div style={{ padding: '2rem', fontFamily: 'system-ui, sans-serif' }}>
26
+ <h1>Welcome to Purenow</h1>
27
+ <p>
28
+ This is a serverless React SSR application powered by AWS Lambda and CloudFront.
29
+ </p>
30
+
31
+ <div style={{ marginTop: '2rem' }}>
32
+ <h2>Features</h2>
33
+ <ul>
34
+ <li>Server-Side Rendering (SSR) on AWS Lambda</li>
35
+ <li>React Router v7 integration</li>
36
+ <li>CloudFront CDN distribution</li>
37
+ <li>S3 caching with ETag support</li>
38
+ <li>TypeScript support</li>
39
+ </ul>
40
+ </div>
41
+
42
+ <div style={{ marginTop: '2rem' }}>
43
+ <Link to="/about" style={{ color: '#0066cc', textDecoration: 'none' }}>
44
+ Learn more about this project →
45
+ </Link>
46
+ </div>
47
+
48
+ <footer style={{ marginTop: '4rem', color: '#666', fontSize: '0.875rem' }}>
49
+ <p>Built with Purenow &copy; 2025</p>
50
+ </footer>
51
+ </div>
52
+ );
53
+ };
54
+
55
+ export default HomePage;
@@ -0,0 +1,66 @@
1
+ /*
2
+ * Elastic License 2.0
3
+ * Copyright (C) 2025–present Raman Marozau, Work Target Insight Function. All rights reserved.
4
+ * Contact: raman@worktif.com
5
+ *
6
+ * This file is part of the Licensed Work: worktif.purenow.cdk <worktif_purenow_cdk>.
7
+ * Use of this software is governed by the Elastic License 2.0; see the LICENSE file
8
+ * or https://www.elastic.co/licensing/elastic-license for details.
9
+ *
10
+ * Re-licensing notice:
11
+ * This file was previously distributed under the Business Source License 1.1 (BUSL-1.1).
12
+ * As of 2025-09-22, it is re-licensed under Elastic License 2.0.
13
+ *
14
+ * SPDX-License-Identifier: Elastic-2.0
15
+ */
16
+
17
+ import * as React from 'react';
18
+ import { Link } from 'react-router';
19
+
20
+ /**
21
+ * About page component demonstrating client-side navigation
22
+ */
23
+ const UsersPage: React.FC = () => {
24
+ return (
25
+ <div style={{ padding: '2rem', fontFamily: 'system-ui, sans-serif' }}>
26
+ <h1>Users Page – Example</h1>
27
+
28
+ <div style={{ marginTop: '2rem' }}>
29
+ <h2>What is Purenow?</h2>
30
+ <p>
31
+ Purenow is a serverless framework for building React applications with
32
+ server-side rendering (SSR) on AWS Lambda. It provides a seamless developer
33
+ experience for creating high-performance web applications that scale automatically.
34
+ </p>
35
+ </div>
36
+
37
+ <div style={{ marginTop: '2rem' }}>
38
+ <p>Manage user accounts and profiles.</p>
39
+ <h2>Available Endpoints</h2>
40
+ <ul>
41
+ <li><strong>POST /api/users</strong> - Create a user</li>
42
+ <li><strong>GET /api/users/:id</strong> - Get a user</li>
43
+ <li><strong>PUT /api/users/:id</strong> - Update a user</li>
44
+ <li><strong>DELETE /api/users/:id</strong> - Delete a user</li>
45
+ </ul>
46
+ </div>
47
+
48
+
49
+ <div style={{ marginTop: '2rem' }}>
50
+ <h2>Getting Started</h2>
51
+ <p>
52
+ To learn more about Purenow and how to build your own serverless React applications,
53
+ visit the documentation or explore the source code.
54
+ </p>
55
+ </div>
56
+
57
+ <div style={{ marginTop: '2rem' }}>
58
+ <Link to="/" style={{ color: '#0066cc', textDecoration: 'none' }}>
59
+ ← Back to Home
60
+ </Link>
61
+ </div>
62
+ </div>
63
+ );
64
+ };
65
+
66
+ export default UsersPage;
@@ -0,0 +1,61 @@
1
+ /*
2
+ * Elastic License 2.0
3
+ * Copyright (C) 2025–present Raman Marozau, Work Target Insight Function. All rights reserved.
4
+ * Contact: raman@worktif.com
5
+ *
6
+ * This file is part of the Licensed Work: worktif.purenow.cdk <worktif_purenow_cdk>.
7
+ * Use of this software is governed by the Elastic License 2.0; see the LICENSE file
8
+ * or https://www.elastic.co/licensing/elastic-license for details.
9
+ *
10
+ * Re-licensing notice:
11
+ * This file was previously distributed under the Business Source License 1.1 (BUSL-1.1).
12
+ * As of 2025-09-22, it is re-licensed under Elastic License 2.0.
13
+ *
14
+ * SPDX-License-Identifier: Elastic-2.0
15
+ */
16
+
17
+ import * as React from 'react';
18
+ import { Outlet } from 'react-router';
19
+ import { PurenowHeadManager } from '@worktif/purenow';
20
+
21
+ import HomePage from './pages/HomePage';
22
+ import AboutPage from './pages/AboutPage';
23
+ import UsersPage from './pages/UsersPage';
24
+
25
+ /**
26
+ * Purenow routes definition for React Router v7.
27
+ *
28
+ * The root route provides a shared layout that mounts the PurenowHeadManager
29
+ * above the Outlet so SEO metadata are managed centrally for all child routes.
30
+ * Paths are constructed via Purenow's routePath helper to keep URLs consistent
31
+ * across different deployment stages (dev, staging, prod).
32
+ */
33
+ export const routes = [
34
+ {
35
+ path: '/',
36
+ id: 'root',
37
+ Component: () => (
38
+ <>
39
+ <PurenowHeadManager/>
40
+ <Outlet/>
41
+ </>
42
+ ),
43
+ children: [
44
+ {
45
+ path: '/',
46
+ id: 'home',
47
+ Component: HomePage,
48
+ },
49
+ {
50
+ path: '/about',
51
+ id: 'about',
52
+ Component: AboutPage,
53
+ },
54
+ {
55
+ id: '3',
56
+ path: '/users',
57
+ element: <UsersPage/>
58
+ },
59
+ ],
60
+ },
61
+ ];
@@ -0,0 +1,17 @@
1
+ /*
2
+ * Elastic License 2.0
3
+ * Copyright (C) 2025–present Raman Marozau, Work Target Insight Function. All rights reserved.
4
+ * Contact: raman@worktif.com
5
+ *
6
+ * This file is part of the Licensed Work: React Serverless <react-serverless>.
7
+ * Use of this software is governed by the Elastic License 2.0; see the LICENSE file
8
+ * or https://www.elastic.co/licensing/elastic-license for details.
9
+ *
10
+ * Re-licensing notice:
11
+ * This file was previously distributed under the Business Source License 1.1 (BUSL-1.1).
12
+ * As of 2025-09-15, it is re-licensed under Elastic License 2.0.
13
+ *
14
+ * SPDX-License-Identifier: Elastic-2.0
15
+ */
16
+
17
+ export * from './users.service';
@@ -0,0 +1,133 @@
1
+ /*
2
+ * Elastic License 2.0
3
+ * Copyright (C) 2025–present Raman Marozau, Work Target Insight Function. All rights reserved.
4
+ * Contact: raman@worktif.com
5
+ *
6
+ * This file is part of the Licensed Work: worktif.purenow.cdk <worktif_purenow_cdk>.
7
+ * Use of this software is governed by the Elastic License 2.0; see the LICENSE file
8
+ * or https://www.elastic.co/licensing/elastic-license for details.
9
+ *
10
+ * SPDX-License-Identifier: Elastic-2.0
11
+ */
12
+
13
+ /**
14
+ * User data structure
15
+ */
16
+ export interface User {
17
+ id: string;
18
+ email: string;
19
+ name: string;
20
+ createdAt: string;
21
+ updatedAt: string;
22
+ }
23
+
24
+ /**
25
+ * User creation input
26
+ */
27
+ export interface CreateUserInput {
28
+ email: string;
29
+ name: string;
30
+ password: string;
31
+ }
32
+
33
+ export interface PurenowServiceInterface {
34
+ }
35
+
36
+ /**
37
+ * Users Service
38
+ *
39
+ * Handles user management, profile operations, and user data.
40
+ * This service is registered as a singleton in the DI container.
41
+ */
42
+ export class UsersService implements PurenowServiceInterface {
43
+ /**
44
+ * Create a new user
45
+ *
46
+ * @param input - User creation data
47
+ * @returns Created user
48
+ */
49
+ async createUser(input: CreateUserInput): Promise<User> {
50
+ if (!input.email) {
51
+ throw new Error('Email is required');
52
+ }
53
+ if (!input.name) {
54
+ throw new Error('Name is required');
55
+ }
56
+ if (!input.password || input.password.length < 8) {
57
+ throw new Error('Password must be at least 8 characters');
58
+ }
59
+
60
+ const userId = `user_${Date.now()}_${Math.random().toString(36).substr(2, 9)}`;
61
+ const now = new Date().toISOString();
62
+
63
+ return {
64
+ id: userId,
65
+ email: input.email,
66
+ name: input.name,
67
+ createdAt: now,
68
+ updatedAt: now,
69
+ };
70
+ }
71
+
72
+ /**
73
+ * Get user by ID
74
+ *
75
+ * @param userId - User identifier
76
+ * @returns User data or null if not found
77
+ */
78
+ async getUser(userId: string): Promise<User | null> {
79
+ if (!userId) {
80
+ throw new Error('User ID is required');
81
+ }
82
+
83
+ // Simulate user lookup (would query database in real implementation)
84
+ return {
85
+ id: userId,
86
+ email: 'user@example.com',
87
+ name: 'Example User',
88
+ createdAt: new Date().toISOString(),
89
+ updatedAt: new Date().toISOString(),
90
+ };
91
+ }
92
+
93
+ /**
94
+ * Update user profile
95
+ *
96
+ * @param userId - User identifier
97
+ * @param updates - Fields to update
98
+ * @returns Updated user
99
+ */
100
+ async updateUser(userId: string, updates: Partial<Pick<User, 'name' | 'email'>>): Promise<User> {
101
+ if (!userId) {
102
+ throw new Error('User ID is required');
103
+ }
104
+
105
+ const existingUser = await this.getUser(userId);
106
+ if (!existingUser) {
107
+ throw new Error('User not found');
108
+ }
109
+
110
+ return {
111
+ ...existingUser,
112
+ ...updates,
113
+ updatedAt: new Date().toISOString(),
114
+ };
115
+ }
116
+
117
+ /**
118
+ * Delete user
119
+ *
120
+ * @param userId - User identifier
121
+ * @returns Deletion result
122
+ */
123
+ async deleteUser(userId: string): Promise<{ success: boolean; userId: string }> {
124
+ if (!userId) {
125
+ throw new Error('User ID is required');
126
+ }
127
+
128
+ return {
129
+ success: true,
130
+ userId,
131
+ };
132
+ }
133
+ }
@@ -0,0 +1,17 @@
1
+ /*
2
+ * Elastic License 2.0
3
+ * Copyright (C) 2025–present Raman Marozau, Work Target Insight Function. All rights reserved.
4
+ * Contact: raman@worktif.com
5
+ *
6
+ * This file is part of the Licensed Work: React Serverless <react-serverless>.
7
+ * Use of this software is governed by the Elastic License 2.0; see the LICENSE file
8
+ * or https://www.elastic.co/licensing/elastic-license for details.
9
+ *
10
+ * Re-licensing notice:
11
+ * This file was previously distributed under the Business Source License 1.1 (BUSL-1.1).
12
+ * As of 2025-09-15, it is re-licensed under Elastic License 2.0.
13
+ *
14
+ * SPDX-License-Identifier: Elastic-2.0
15
+ */
16
+
17
+ export * from './users.ties';
@@ -0,0 +1,53 @@
1
+ /*
2
+ * Elastic License 2.0
3
+ * Copyright (C) 2025–present Raman Marozau, Work Target Insight Function. All rights reserved.
4
+ * Contact: raman@worktif.com
5
+ *
6
+ * This file is part of the Licensed Work: worktif.purenow.cdk <worktif_purenow_cdk>.
7
+ * Use of this software is governed by the Elastic License 2.0; see the LICENSE file
8
+ * or https://www.elastic.co/licensing/elastic-license for details.
9
+ *
10
+ * SPDX-License-Identifier: Elastic-2.0
11
+ */
12
+
13
+ import type { PureContainer } from '@worktif/utils';
14
+
15
+ import { UsersService } from '@bin/templates/runtime-web/purenow-basic/src/services/users.service';
16
+
17
+ /**
18
+ * Users configuration
19
+ */
20
+ export interface UsersConfig {
21
+ sessionTimeout: number;
22
+ maxLoginAttempts: number;
23
+ }
24
+
25
+ /**
26
+ * Users Ties Class
27
+ *
28
+ * Registers all user-related services and configuration in the DI container.
29
+ *
30
+ * @example
31
+ * ```typescript
32
+ * const definition: MicroserviceDefinition = {
33
+ * ties: [UsersTies],
34
+ * lambdas: [createUserHandler, getUserHandler]
35
+ * };
36
+ * ```
37
+ */
38
+ export class UsersTies {
39
+ /**
40
+ * Register services and constants in the container
41
+ *
42
+ * @param container - PureContainer instance
43
+ */
44
+ register(container: PureContainer<string>): void {
45
+ // Register singleton services
46
+ container.tie({
47
+ ['usersService']: {
48
+ instance: UsersService,
49
+ dependencies: [],
50
+ },
51
+ });
52
+ }
53
+ }
@@ -0,0 +1,53 @@
1
+ {
2
+ "compilerOptions": {
3
+ "target": "ES2020",
4
+ "module": "commonjs",
5
+ "lib": [
6
+ "ES2020",
7
+ "dom",
8
+ "dom.iterable"
9
+ ],
10
+ "jsx": "react",
11
+ "sourceMap": true,
12
+ "declaration": true,
13
+ "outDir": "./out/dist",
14
+ "rootDir": "./",
15
+ "baseUrl": "./",
16
+ "strict": true,
17
+ "esModuleInterop": true,
18
+ "skipLibCheck": true,
19
+ "forceConsistentCasingInFileNames": true,
20
+ "resolveJsonModule": true,
21
+ "moduleResolution": "node16",
22
+ "allowSyntheticDefaultImports": true,
23
+ "experimentalDecorators": true,
24
+ "emitDecoratorMetadata": true,
25
+ "isolatedModules": false,
26
+ "downlevelIteration": true,
27
+ "allowJs": true,
28
+ "types": [
29
+ "node"
30
+ ],
31
+ "paths": {
32
+ "@core/*": [
33
+ "src/core/*"
34
+ ],
35
+ "@lib/*": [
36
+ "src/lib/*"
37
+ ],
38
+ "@utils/*": [
39
+ "src/utils/*"
40
+ ]
41
+ }
42
+ },
43
+ "include": [
44
+ "src/**/*.ts",
45
+ "src/**/*.tsx"
46
+ ],
47
+ "exclude": [
48
+ "node_modules",
49
+ "out",
50
+ "dist",
51
+ "build"
52
+ ]
53
+ }
@@ -0,0 +1,4 @@
1
+ export * from '@worktif/purenow';
2
+ export * from './lib/runtime-web';
3
+ export * from './utils';
4
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1,4 @@
1
+ "use strict";var w=Object.create;var a=Object.defineProperty;var y=Object.getOwnPropertyDescriptor;var R=Object.getOwnPropertyNames;var v=Object.getPrototypeOf,h=Object.prototype.hasOwnProperty;var b=(t,r)=>{for(var e in r)a(t,e,{get:r[e],enumerable:!0})},m=(t,r,e,o)=>{if(r&&typeof r=="object"||typeof r=="function")for(let n of R(r))!h.call(t,n)&&n!==e&&a(t,n,{get:()=>r[n],enumerable:!(o=y(r,n))||o.enumerable});return t};var E=(t,r,e)=>(e=t!=null?w(v(t)):{},m(r||!t||!t.__esModule?a(e,"default",{value:t,enumerable:!0}):e,t)),C=t=>m(a({},"__esModule",{value:!0}),t);var S={};b(S,{BrowserPipeline:()=>s,ConfigValidationError:()=>d,EnvironmentDetectionError:()=>p,isValidServiceName:()=>g,pureweb:()=>N});module.exports=C(S);var c=E(require("react")),l=require("react-dom/client"),u=require("react-router"),s=class{async execute(r,e){try{console.info("Starting browser pipeline execution",{serviceName:r.serviceName,stage:r.stage,url:e.metadata.url,userAgent:e.metadata.userAgent,viewport:e.metadata.viewport});let o=this.createBrowserRouter(r),n=this.createAppElement(r),f=c.createElement(u.RouterProvider,{router:o},n);this.hydrateApplication(f),this.setupHttpClient(r),console.info("Browser pipeline execution completed successfully",{serviceName:r.serviceName,stage:r.stage})}catch(o){throw console.error("Browser pipeline execution failed",{serviceName:r.serviceName,stage:r.stage,error:o instanceof Error?o.message:String(o),stack:o instanceof Error?o.stack:void 0}),o}}createBrowserRouter(r){console.debug("Creating browser router",{routeCount:r.router.getRoutes().length});let e=r.router.getRoutes(),o=(0,u.createBrowserRouter)(e);return console.debug("Browser router created successfully",{routeCount:e.length}),o}createAppElement(r){console.debug("Creating app element from factory");try{let e=r.app({router:r.router});if(!c.isValidElement(e))throw new Error("App factory must return a valid React element");return console.debug("App element created successfully"),e}catch(e){throw console.error("Failed to create app element",{error:e instanceof Error?e.message:String(e)}),new Error(`Failed to create app element: ${e instanceof Error?e.message:String(e)}`)}}hydrateApplication(r){console.debug("Starting React hydration");try{let e=document.getElementById("root");if(!e)throw new Error('Root container element not found. Expected element with id="root"');(0,l.hydrateRoot)(e,r),console.info("React hydration completed successfully")}catch(e){throw console.error("React hydration failed",{error:e instanceof Error?e.message:String(e)}),new Error(`React hydration failed: ${e instanceof Error?e.message:String(e)}`)}}setupHttpClient(r){console.debug("Setting up HTTP client for Lambda endpoints");try{let e=this.getApiBaseUrl(r.stage);typeof window<"u"&&(window.__PURENOW_CONFIG__={serviceName:r.serviceName,stage:r.stage,apiBaseUrl:e}),console.info("HTTP client configured successfully",{baseUrl:e,stage:r.stage})}catch(e){throw console.error("Failed to setup HTTP client",{error:e instanceof Error?e.message:String(e)}),new Error(`Failed to setup HTTP client: ${e instanceof Error?e.message:String(e)}`)}}getApiBaseUrl(r){return`${typeof window<"u"?window.location.origin:""}/api`}};function g(t){return/^[a-zA-Z][a-zA-Z0-9-]{0,127}$/.test(t)}var i=require("@worktif/purenow"),d=class extends Error{constructor(r){super(`Configuration validation failed:
2
+ ${r.map(e=>` - ${e}`).join(`
3
+ `)}`),this.name="ConfigValidationError",this.errors=r,Error.captureStackTrace(this,this.constructor)}},p=class extends Error{constructor(r){super(r),this.name="EnvironmentDetectionError",Error.captureStackTrace(this,this.constructor)}};function T(){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(t=>t.includes("cdk")||t.includes("synth"))),"cdk")}function x(t,r){let e=[];return(!t.serviceName||!/^[a-zA-Z][a-zA-Z0-9-]{0,127}$/.test(t.serviceName))&&e.push("serviceName must start with a letter, contain only alphanumeric characters and hyphens, and be max 128 characters"),["dev","staging","prod"].includes(t.stage)||e.push("stage must be one of: dev, staging, prod"),r&&!t.infra&&e.push("infra configuration is required in CDK context"),{valid:e.length===0,errors:e}}function N(t){let r=T(),o=x(t,r==="cdk");if(!o.valid)throw new d(o.errors);switch(r){case"browser":{(0,i.purenow)({app:({router:n})=>t.app({router:n}),router:(0,i.purenowRouter)({router:t.router.getRoutes(),defaults:t.router.defaults}),config:{serviceName:t.serviceName,stage:t.stage}});break}case"lambda":case"cdk":{console.log("[Runtime Target] Server-side pipeline detected (%s)",r),(0,i.purenow)({app:({router:n})=>t.app({router:n}),router:(0,i.purenowRouter)({router:t.router.getRoutes(),defaults:t.router.defaults}),config:{serviceName:t.serviceName,stage:t.stage}});break}default:console.log("[Runtime Target] Unknown environment type: %s",r);break}}0&&(module.exports={BrowserPipeline,ConfigValidationError,EnvironmentDetectionError,isValidServiceName,pureweb});
4
+ //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../src/lib/runtime-web/index.ts", "../../../src/lib/runtime-web/pipelines/browser-pipeline.ts", "../../../src/lib/runtime-web/types/config.types.ts", "../../../src/lib/runtime-web/pureweb.ts"],
  "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-licensing under Elastic License 2.0.\n *\n * SPDX-License-Identifier: Elastic-2.0\n */\n\n/**\n * Runtime Web Core - Library (Isomorphic/Browser)\n *\n * **ARCHITECTURE NOTE**: This module contains browser-safe code that:\n * - Runs in browser environment (client-side)\n * - Uses browser APIs (window, document, hydrateRoot)\n * - Must be isomorphic-safe (no Node.js APIs)\n * - NEVER runs in Lambda\n * - Bundled into browser builds\n *\n * **Exports**:\n * - BrowserPipeline: Client-side React hydration and routing\n */\n\nexport * from './pipelines';\nexport * from './types';\nexport * from './pureweb';\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 type { RuntimeWebConfig } from './types';\nimport { purenow, PurenowRoute, purenowRouter, PurenowRouterDefaults } from '@worktif/purenow';\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 Target] 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('[Purenow] 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 Target] Unknown environment type: %s', envType);\n      break;\n    // throw new EnvironmentDetectionError(\n    //   `Unknown environment type: ${envType}`,\n    // );\n  }\n}\n\n/**\n * Execute the browser pipeline for React hydration.\n * This is browser-safe code that doesn't import from @core/.\n */\nasync function executeBrowserPipeline(config: RuntimeWebConfig): Promise<void> {\n  // Ensure we're in a browser environment\n  if (typeof window === 'undefined') {\n    throw new EnvironmentDetectionError('Browser environment required for browser pipeline');\n  }\n\n  // Import React DOM for hydration\n  const { hydrateRoot, createRoot } = await import('react-dom/client');\n  const { createBrowserRouter } = await import('react-router');\n  const React = await import('react');\n\n  // Get DOM elements\n  const rootPurenow = document.getElementById('root-purenow');\n  const rootInternal = document.getElementById('root-internal');\n\n  // Determine which root element to use\n  const rootElement = rootPurenow || rootInternal;\n\n  if (!rootElement) {\n    throw new Error(\n      '[Runtime Target] Root element not found. ' +\n      'Ensure your HTML includes <div id=\"root-purenow\"></div> or <div id=\"root-internal\"></div>',\n    );\n  }\n\n  // Get routes from the router - use routes property or getRoutes method\n  const routes = config.router.routes || (config.router as any).getRoutes?.() || [];\n\n  // Create browser router - cast routes to any to avoid type issues with different react-router versions\n  const browserRouter = createBrowserRouter(routes as any);\n\n  // Create the app element - pass the browser router\n  const AppElement = config.app({ router: browserRouter as any });\n\n  // Check if we should hydrate (SSR HTML exists) or render fresh\n  if (rootPurenow?.hasChildNodes()) {\n    // Hydrate SSR HTML\n    console.log('[Runtime Target] Hydrating SSR HTML...');\n    hydrateRoot(rootElement, React.createElement(React.StrictMode, null, AppElement));\n    console.log('[Runtime Target] Hydration complete');\n  } else {\n    // Fresh render\n    console.log('[Runtime Target] Creating fresh React root...');\n    const root = createRoot(rootElement);\n    root.render(React.createElement(React.StrictMode, null, AppElement));\n    console.log('[Runtime Target] Render complete');\n  }\n}\n"],
  "mappings": "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",
  "names": ["index_exports", "__export", "BrowserPipeline", "ConfigValidationError", "EnvironmentDetectionError", "isValidServiceName", "pureweb", "__toCommonJS", "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"]
}

@@ -0,0 +1,3 @@
1
+ export * from '@worktif/purenow';
2
+ export * from './runtime-web';
3
+ //# sourceMappingURL=index.d.ts.map