@friggframework/devtools 2.0.0--canary.522.cbd3d5a.0 → 2.0.0--canary.517.21b69ac.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 (247) hide show
  1. package/.eslintrc.json +3 -0
  2. package/CHANGELOG.md +132 -0
  3. package/frigg-cli/README.md +1 -1
  4. package/frigg-cli/__tests__/unit/commands/doctor.test.js +2 -0
  5. package/frigg-cli/__tests__/unit/commands/install.test.js +17 -21
  6. package/frigg-cli/doctor-command/index.js +16 -17
  7. package/frigg-cli/index.js +6 -21
  8. package/frigg-cli/index.test.js +1 -7
  9. package/frigg-cli/init-command/backend-first-handler.js +42 -124
  10. package/frigg-cli/init-command/index.js +1 -2
  11. package/frigg-cli/init-command/template-handler.js +3 -13
  12. package/frigg-cli/install-command/backend-js.js +3 -3
  13. package/frigg-cli/install-command/environment-variables.js +19 -16
  14. package/frigg-cli/install-command/environment-variables.test.js +13 -12
  15. package/frigg-cli/install-command/index.js +9 -14
  16. package/frigg-cli/install-command/integration-file.js +3 -3
  17. package/frigg-cli/install-command/logger.js +12 -0
  18. package/frigg-cli/install-command/validate-package.js +9 -5
  19. package/frigg-cli/jest.config.js +1 -4
  20. package/frigg-cli/repair-command/index.js +128 -101
  21. package/frigg-cli/start-command/index.js +2 -246
  22. package/frigg-cli/ui-command/index.js +36 -58
  23. package/frigg-cli/utils/repo-detection.js +37 -85
  24. package/infrastructure/docs/iam-policy-templates.md +1 -1
  25. package/infrastructure/domains/networking/vpc-builder.test.js +4 -2
  26. package/infrastructure/domains/networking/vpc-resolver.test.js +1 -1
  27. package/infrastructure/domains/shared/cloudformation-discovery.test.js +7 -4
  28. package/infrastructure/domains/shared/resource-discovery.js +5 -5
  29. package/infrastructure/domains/shared/types/discovery-result.test.js +1 -1
  30. package/infrastructure/domains/shared/utilities/base-definition-factory.js +2 -25
  31. package/infrastructure/domains/shared/utilities/base-definition-factory.test.js +2 -2
  32. package/infrastructure/infrastructure-composer.test.js +2 -2
  33. package/layers/prisma/.build-complete +3 -0
  34. package/layers/prisma/nodejs/package.json +8 -0
  35. package/management-ui/.eslintrc.js +22 -0
  36. package/management-ui/README.md +109 -245
  37. package/management-ui/components.json +21 -0
  38. package/management-ui/docs/phase2-integration-guide.md +320 -0
  39. package/management-ui/index.html +13 -0
  40. package/management-ui/package.json +76 -0
  41. package/management-ui/packages/devtools/frigg-cli/ui-command/index.js +302 -0
  42. package/management-ui/postcss.config.js +6 -0
  43. package/management-ui/server/api/backend.js +256 -0
  44. package/management-ui/server/api/cli.js +315 -0
  45. package/management-ui/server/api/codegen.js +663 -0
  46. package/management-ui/server/api/connections.js +857 -0
  47. package/management-ui/server/api/discovery.js +185 -0
  48. package/management-ui/server/api/environment/index.js +1 -0
  49. package/management-ui/server/api/environment/router.js +378 -0
  50. package/management-ui/server/api/environment.js +328 -0
  51. package/management-ui/server/api/integrations.js +876 -0
  52. package/management-ui/server/api/logs.js +248 -0
  53. package/management-ui/server/api/monitoring.js +282 -0
  54. package/management-ui/server/api/open-ide.js +31 -0
  55. package/management-ui/server/api/project.js +1029 -0
  56. package/management-ui/server/api/users/sessions.js +371 -0
  57. package/management-ui/server/api/users/simulation.js +254 -0
  58. package/management-ui/server/api/users.js +362 -0
  59. package/management-ui/server/api-contract.md +275 -0
  60. package/management-ui/server/index.js +873 -0
  61. package/management-ui/server/middleware/errorHandler.js +93 -0
  62. package/management-ui/server/middleware/security.js +32 -0
  63. package/management-ui/server/processManager.js +296 -0
  64. package/management-ui/server/server.js +346 -0
  65. package/management-ui/server/services/aws-monitor.js +413 -0
  66. package/management-ui/server/services/npm-registry.js +347 -0
  67. package/management-ui/server/services/template-engine.js +538 -0
  68. package/management-ui/server/utils/cliIntegration.js +220 -0
  69. package/management-ui/server/utils/environment/auditLogger.js +471 -0
  70. package/management-ui/server/utils/environment/awsParameterStore.js +275 -0
  71. package/management-ui/server/utils/environment/encryption.js +278 -0
  72. package/management-ui/server/utils/environment/envFileManager.js +286 -0
  73. package/management-ui/server/utils/import-commonjs.js +28 -0
  74. package/management-ui/server/utils/response.js +83 -0
  75. package/management-ui/server/websocket/handler.js +325 -0
  76. package/management-ui/src/App.jsx +25 -0
  77. package/management-ui/src/assets/FriggLogo.svg +1 -0
  78. package/management-ui/src/components/AppRouter.jsx +65 -0
  79. package/management-ui/src/components/Button.jsx +70 -0
  80. package/management-ui/src/components/Card.jsx +97 -0
  81. package/management-ui/src/components/EnvironmentCompare.jsx +400 -0
  82. package/management-ui/src/components/EnvironmentEditor.jsx +372 -0
  83. package/management-ui/src/components/EnvironmentImportExport.jsx +469 -0
  84. package/management-ui/src/components/EnvironmentSchema.jsx +491 -0
  85. package/management-ui/src/components/EnvironmentSecurity.jsx +463 -0
  86. package/management-ui/src/components/ErrorBoundary.jsx +73 -0
  87. package/management-ui/src/components/IntegrationCard.jsx +481 -0
  88. package/management-ui/src/components/IntegrationCardEnhanced.jsx +770 -0
  89. package/management-ui/src/components/IntegrationExplorer.jsx +379 -0
  90. package/management-ui/src/components/IntegrationStatus.jsx +336 -0
  91. package/management-ui/src/components/Layout.jsx +716 -0
  92. package/management-ui/src/components/LoadingSpinner.jsx +113 -0
  93. package/management-ui/src/components/RepositoryPicker.jsx +248 -0
  94. package/management-ui/src/components/SessionMonitor.jsx +350 -0
  95. package/management-ui/src/components/StatusBadge.jsx +208 -0
  96. package/management-ui/src/components/UserContextSwitcher.jsx +212 -0
  97. package/management-ui/src/components/UserSimulation.jsx +327 -0
  98. package/management-ui/src/components/Welcome.jsx +434 -0
  99. package/management-ui/src/components/codegen/APIEndpointGenerator.jsx +637 -0
  100. package/management-ui/src/components/codegen/APIModuleSelector.jsx +227 -0
  101. package/management-ui/src/components/codegen/CodeGenerationWizard.jsx +247 -0
  102. package/management-ui/src/components/codegen/CodePreviewEditor.jsx +316 -0
  103. package/management-ui/src/components/codegen/DynamicModuleForm.jsx +271 -0
  104. package/management-ui/src/components/codegen/FormBuilder.jsx +737 -0
  105. package/management-ui/src/components/codegen/IntegrationGenerator.jsx +855 -0
  106. package/management-ui/src/components/codegen/ProjectScaffoldWizard.jsx +797 -0
  107. package/management-ui/src/components/codegen/SchemaBuilder.jsx +303 -0
  108. package/management-ui/src/components/codegen/TemplateSelector.jsx +586 -0
  109. package/management-ui/src/components/codegen/index.js +10 -0
  110. package/management-ui/src/components/connections/ConnectionConfigForm.jsx +362 -0
  111. package/management-ui/src/components/connections/ConnectionHealthMonitor.jsx +182 -0
  112. package/management-ui/src/components/connections/ConnectionTester.jsx +200 -0
  113. package/management-ui/src/components/connections/EntityRelationshipMapper.jsx +292 -0
  114. package/management-ui/src/components/connections/OAuthFlow.jsx +204 -0
  115. package/management-ui/src/components/connections/index.js +5 -0
  116. package/management-ui/src/components/index.js +21 -0
  117. package/management-ui/src/components/monitoring/APIGatewayMetrics.jsx +222 -0
  118. package/management-ui/src/components/monitoring/LambdaMetrics.jsx +169 -0
  119. package/management-ui/src/components/monitoring/MetricsChart.jsx +197 -0
  120. package/management-ui/src/components/monitoring/MonitoringDashboard.jsx +393 -0
  121. package/management-ui/src/components/monitoring/SQSMetrics.jsx +246 -0
  122. package/management-ui/src/components/monitoring/index.js +6 -0
  123. package/management-ui/src/components/monitoring/monitoring.css +218 -0
  124. package/management-ui/src/components/theme-provider.jsx +52 -0
  125. package/management-ui/src/components/theme-toggle.jsx +39 -0
  126. package/management-ui/src/components/ui/badge.tsx +36 -0
  127. package/management-ui/src/components/ui/button.test.jsx +56 -0
  128. package/management-ui/src/components/ui/button.tsx +57 -0
  129. package/management-ui/src/components/ui/card.tsx +76 -0
  130. package/management-ui/src/components/ui/dropdown-menu.tsx +199 -0
  131. package/management-ui/src/components/ui/select.tsx +157 -0
  132. package/management-ui/src/components/ui/skeleton.jsx +15 -0
  133. package/management-ui/src/hooks/useFrigg.jsx +387 -0
  134. package/management-ui/src/hooks/useSocket.jsx +58 -0
  135. package/management-ui/src/index.css +193 -0
  136. package/management-ui/src/lib/utils.ts +6 -0
  137. package/management-ui/src/main.jsx +10 -0
  138. package/management-ui/src/pages/CodeGeneration.jsx +14 -0
  139. package/management-ui/src/pages/Connections.jsx +252 -0
  140. package/management-ui/src/pages/ConnectionsEnhanced.jsx +633 -0
  141. package/management-ui/src/pages/Dashboard.jsx +311 -0
  142. package/management-ui/src/pages/Environment.jsx +314 -0
  143. package/management-ui/src/pages/IntegrationConfigure.jsx +669 -0
  144. package/management-ui/src/pages/IntegrationDiscovery.jsx +567 -0
  145. package/management-ui/src/pages/IntegrationTest.jsx +742 -0
  146. package/management-ui/src/pages/Integrations.jsx +253 -0
  147. package/management-ui/src/pages/Monitoring.jsx +17 -0
  148. package/management-ui/src/pages/Simulation.jsx +155 -0
  149. package/management-ui/src/pages/Users.jsx +492 -0
  150. package/management-ui/src/services/api.js +41 -0
  151. package/management-ui/src/services/apiModuleService.js +193 -0
  152. package/management-ui/src/services/websocket-handlers.js +120 -0
  153. package/management-ui/src/test/api/project.test.js +273 -0
  154. package/management-ui/src/test/components/Welcome.test.jsx +378 -0
  155. package/management-ui/src/test/mocks/server.js +178 -0
  156. package/management-ui/src/test/setup.js +61 -0
  157. package/management-ui/src/test/utils/test-utils.jsx +134 -0
  158. package/management-ui/src/utils/repository.js +98 -0
  159. package/management-ui/src/utils/repository.test.js +118 -0
  160. package/management-ui/src/workflows/phase2-integration-workflows.js +884 -0
  161. package/management-ui/tailwind.config.js +63 -0
  162. package/management-ui/tsconfig.json +37 -0
  163. package/management-ui/tsconfig.node.json +10 -0
  164. package/management-ui/vite.config.js +26 -0
  165. package/management-ui/vitest.config.js +38 -0
  166. package/package.json +7 -17
  167. package/frigg-cli/__tests__/application/use-cases/AddApiModuleToIntegrationUseCase.test.js +0 -326
  168. package/frigg-cli/__tests__/application/use-cases/CreateApiModuleUseCase.test.js +0 -337
  169. package/frigg-cli/__tests__/domain/entities/ApiModule.test.js +0 -373
  170. package/frigg-cli/__tests__/domain/entities/AppDefinition.test.js +0 -313
  171. package/frigg-cli/__tests__/domain/services/IntegrationValidator.test.js +0 -269
  172. package/frigg-cli/__tests__/domain/value-objects/IntegrationName.test.js +0 -82
  173. package/frigg-cli/__tests__/infrastructure/adapters/IntegrationJsUpdater.test.js +0 -408
  174. package/frigg-cli/__tests__/infrastructure/repositories/FileSystemApiModuleRepository.test.js +0 -583
  175. package/frigg-cli/__tests__/infrastructure/repositories/FileSystemAppDefinitionRepository.test.js +0 -314
  176. package/frigg-cli/__tests__/infrastructure/repositories/FileSystemIntegrationRepository.test.js +0 -430
  177. package/frigg-cli/__tests__/unit/commands/init.test.js +0 -406
  178. package/frigg-cli/__tests__/unit/commands/repair.test.js +0 -275
  179. package/frigg-cli/__tests__/unit/start-command/application/RunPreflightChecksUseCase.test.js +0 -411
  180. package/frigg-cli/__tests__/unit/start-command/infrastructure/DatabaseAdapter.test.js +0 -405
  181. package/frigg-cli/__tests__/unit/start-command/infrastructure/DockerAdapter.test.js +0 -496
  182. package/frigg-cli/__tests__/unit/start-command/presentation/InteractivePromptAdapter.test.js +0 -474
  183. package/frigg-cli/__tests__/unit/utils/output.test.js +0 -196
  184. package/frigg-cli/application/use-cases/AddApiModuleToIntegrationUseCase.js +0 -93
  185. package/frigg-cli/application/use-cases/CreateApiModuleUseCase.js +0 -93
  186. package/frigg-cli/application/use-cases/CreateIntegrationUseCase.js +0 -103
  187. package/frigg-cli/container.js +0 -172
  188. package/frigg-cli/docs/OUTPUT_MIGRATION_GUIDE.md +0 -286
  189. package/frigg-cli/domain/entities/ApiModule.js +0 -272
  190. package/frigg-cli/domain/entities/AppDefinition.js +0 -227
  191. package/frigg-cli/domain/entities/Integration.js +0 -198
  192. package/frigg-cli/domain/exceptions/DomainException.js +0 -24
  193. package/frigg-cli/domain/ports/IApiModuleRepository.js +0 -53
  194. package/frigg-cli/domain/ports/IAppDefinitionRepository.js +0 -43
  195. package/frigg-cli/domain/ports/IIntegrationRepository.js +0 -61
  196. package/frigg-cli/domain/services/IntegrationValidator.js +0 -185
  197. package/frigg-cli/domain/value-objects/IntegrationId.js +0 -42
  198. package/frigg-cli/domain/value-objects/IntegrationName.js +0 -60
  199. package/frigg-cli/domain/value-objects/SemanticVersion.js +0 -70
  200. package/frigg-cli/infrastructure/UnitOfWork.js +0 -46
  201. package/frigg-cli/infrastructure/adapters/BackendJsUpdater.js +0 -197
  202. package/frigg-cli/infrastructure/adapters/FileSystemAdapter.js +0 -224
  203. package/frigg-cli/infrastructure/adapters/IntegrationJsUpdater.js +0 -249
  204. package/frigg-cli/infrastructure/adapters/SchemaValidator.js +0 -92
  205. package/frigg-cli/infrastructure/repositories/FileSystemApiModuleRepository.js +0 -373
  206. package/frigg-cli/infrastructure/repositories/FileSystemAppDefinitionRepository.js +0 -116
  207. package/frigg-cli/infrastructure/repositories/FileSystemIntegrationRepository.js +0 -277
  208. package/frigg-cli/package-lock.json +0 -16226
  209. package/frigg-cli/start-command/application/RunPreflightChecksUseCase.js +0 -376
  210. package/frigg-cli/start-command/infrastructure/DatabaseAdapter.js +0 -591
  211. package/frigg-cli/start-command/infrastructure/DockerAdapter.js +0 -306
  212. package/frigg-cli/start-command/presentation/InteractivePromptAdapter.js +0 -329
  213. package/frigg-cli/templates/backend/.env.example +0 -62
  214. package/frigg-cli/templates/backend/.eslintrc.json +0 -12
  215. package/frigg-cli/templates/backend/.prettierrc +0 -6
  216. package/frigg-cli/templates/backend/docker-compose.yml +0 -22
  217. package/frigg-cli/templates/backend/index.js +0 -96
  218. package/frigg-cli/templates/backend/infrastructure.js +0 -12
  219. package/frigg-cli/templates/backend/jest.config.js +0 -17
  220. package/frigg-cli/templates/backend/package.json +0 -50
  221. package/frigg-cli/templates/backend/src/api-modules/.gitkeep +0 -10
  222. package/frigg-cli/templates/backend/src/base/.gitkeep +0 -7
  223. package/frigg-cli/templates/backend/src/integrations/.gitkeep +0 -10
  224. package/frigg-cli/templates/backend/src/integrations/ExampleIntegration.js +0 -65
  225. package/frigg-cli/templates/backend/src/utils/.gitkeep +0 -7
  226. package/frigg-cli/templates/backend/test/setup.js +0 -30
  227. package/frigg-cli/templates/backend/ui-extensions/.gitkeep +0 -0
  228. package/frigg-cli/templates/backend/ui-extensions/README.md +0 -77
  229. package/frigg-cli/utils/__tests__/repo-detection.test.js +0 -436
  230. package/frigg-cli/utils/output.js +0 -382
  231. package/frigg-cli/validate-command/__tests__/adapters/validate-command.test.js +0 -205
  232. package/frigg-cli/validate-command/__tests__/application/validate-app-use-case.test.js +0 -104
  233. package/frigg-cli/validate-command/__tests__/domain/fix-suggestion.test.js +0 -153
  234. package/frigg-cli/validate-command/__tests__/domain/validation-error.test.js +0 -162
  235. package/frigg-cli/validate-command/__tests__/domain/validation-result.test.js +0 -152
  236. package/frigg-cli/validate-command/__tests__/infrastructure/api-module-validator.test.js +0 -332
  237. package/frigg-cli/validate-command/__tests__/infrastructure/app-definition-validator.test.js +0 -191
  238. package/frigg-cli/validate-command/__tests__/infrastructure/integration-class-validator.test.js +0 -146
  239. package/frigg-cli/validate-command/__tests__/infrastructure/template-validation.test.js +0 -155
  240. package/frigg-cli/validate-command/adapters/cli/validate-command.js +0 -199
  241. package/frigg-cli/validate-command/application/use-cases/validate-app-use-case.js +0 -35
  242. package/frigg-cli/validate-command/domain/entities/validation-result.js +0 -74
  243. package/frigg-cli/validate-command/domain/value-objects/fix-suggestion.js +0 -74
  244. package/frigg-cli/validate-command/domain/value-objects/validation-error.js +0 -68
  245. package/frigg-cli/validate-command/infrastructure/validators/api-module-validator.js +0 -181
  246. package/frigg-cli/validate-command/infrastructure/validators/app-definition-validator.js +0 -128
  247. package/frigg-cli/validate-command/infrastructure/validators/integration-class-validator.js +0 -113
@@ -0,0 +1,320 @@
1
+ # Phase 2 Integration Guide
2
+
3
+ ## Overview
4
+
5
+ This guide covers the complete integration of all Phase 2 features for the Frigg Management UI as specified in RFC 0001. Phase 2 introduces core features that transform the developer experience with visual tools for integration management, testing, and deployment.
6
+
7
+ ## Phase 2 Core Features
8
+
9
+ ### 1. Integration Discovery and Installation
10
+
11
+ The integration discovery system connects to the npm registry to find and install @friggframework modules.
12
+
13
+ #### Key Components:
14
+ - **IntegrationDiscoveryService**: Searches npm registry for Frigg integrations
15
+ - **IntegrationInstallerService**: Handles package installation and dependency management
16
+ - **UI Components**: Visual interface for browsing and installing integrations
17
+
18
+ #### Usage:
19
+ ```javascript
20
+ // Discover integrations
21
+ const discoveries = await discoveryService.searchIntegrations({
22
+ query: 'hubspot',
23
+ limit: 20
24
+ });
25
+
26
+ // Install integration
27
+ const result = await installerService.installIntegration({
28
+ packageName: '@friggframework/api-module-hubspot'
29
+ });
30
+ ```
31
+
32
+ ### 2. Dummy User Management System
33
+
34
+ Create and manage test users for development and testing purposes.
35
+
36
+ #### Features:
37
+ - Generate unique test IDs for each user
38
+ - Create OAuth credentials for testing
39
+ - Bulk user creation support
40
+ - Complete isolation from production data
41
+
42
+ #### API Endpoints:
43
+ - `POST /api/users/dummy` - Create a dummy user
44
+ - `GET /api/users/dummy` - List all dummy users
45
+ - `POST /api/users/dummy/:id/credentials` - Generate test credentials
46
+ - `POST /api/users/dummy/bulk` - Create multiple users
47
+
48
+ ### 3. Connection/Entity Management
49
+
50
+ Manage connections between users and integrations with full entity synchronization.
51
+
52
+ #### Capabilities:
53
+ - Create and manage user-integration connections
54
+ - Health monitoring for active connections
55
+ - Entity CRUD operations
56
+ - Bulk synchronization support
57
+
58
+ #### Connection Lifecycle:
59
+ 1. Create connection with user credentials
60
+ 2. Test connection health
61
+ 3. Manage entities (contacts, deals, messages, etc.)
62
+ 4. Monitor connection status
63
+ 5. Handle refresh/reconnection
64
+
65
+ ### 4. Environment Variable Editor
66
+
67
+ Visual interface for managing environment variables across development and production.
68
+
69
+ #### Features:
70
+ - Read and display current variables
71
+ - Mask sensitive values (passwords, keys, secrets)
72
+ - Validate variable names
73
+ - Differentiate local vs production environments
74
+ - Bulk update support
75
+
76
+ #### Security:
77
+ - Automatic masking of sensitive values
78
+ - Validation to prevent invalid variable names
79
+ - Production update confirmation required
80
+ - AWS Parameter Store integration for production
81
+
82
+ ## Integration Workflows
83
+
84
+ ### Complete Integration Setup Flow
85
+
86
+ ```javascript
87
+ const workflow = await phase2Workflows.setupIntegration('hubspot', {
88
+ config: {
89
+ clientId: 'your-client-id',
90
+ clientSecret: 'your-client-secret'
91
+ },
92
+ testUserName: 'HubSpot Test User',
93
+ environment: 'development'
94
+ });
95
+ ```
96
+
97
+ This workflow automatically:
98
+ 1. Discovers integration details
99
+ 2. Installs the package
100
+ 3. Configures the integration
101
+ 4. Creates a test user
102
+ 5. Generates credentials
103
+ 6. Creates a connection
104
+ 7. Tests the connection
105
+ 8. Sets up environment variables
106
+
107
+ ### Bulk Integration Management
108
+
109
+ ```javascript
110
+ const bulkResult = await phase2Workflows.bulkIntegrationSetup([
111
+ { name: 'slack', options: { /* config */ } },
112
+ { name: 'salesforce', options: { /* config */ } },
113
+ { name: 'stripe', options: { /* config */ } }
114
+ ], {
115
+ batchSize: 3 // Process in parallel
116
+ });
117
+ ```
118
+
119
+ ### Development Environment Setup
120
+
121
+ ```javascript
122
+ const devEnv = await phase2Workflows.setupDevelopmentEnvironment({
123
+ projectType: 'saas',
124
+ integrations: ['stripe', 'hubspot', 'slack'],
125
+ testUserCount: 10,
126
+ mockDataTypes: ['contacts', 'messages', 'payments']
127
+ });
128
+ ```
129
+
130
+ ## Testing Phase 2 Features
131
+
132
+ ### Integration Tests
133
+
134
+ Run the comprehensive integration test suite:
135
+
136
+ ```bash
137
+ npm run test:integration
138
+ ```
139
+
140
+ Key test areas:
141
+ - End-to-end user flows
142
+ - WebSocket real-time updates
143
+ - Concurrent operation handling
144
+ - Error recovery
145
+ - Data consistency
146
+
147
+ ### Performance Benchmarks
148
+
149
+ Run performance benchmarks:
150
+
151
+ ```bash
152
+ npm run benchmark:phase2
153
+ ```
154
+
155
+ Benchmark metrics:
156
+ - Integration discovery speed
157
+ - Installation throughput
158
+ - API response times
159
+ - WebSocket latency
160
+ - Memory usage under load
161
+ - Concurrent user capacity
162
+
163
+ ### Validation Tests
164
+
165
+ Ensure RFC compliance:
166
+
167
+ ```bash
168
+ npm run test:validation
169
+ ```
170
+
171
+ Validates:
172
+ - All RFC requirements are met
173
+ - Security requirements
174
+ - Performance targets
175
+ - API contracts
176
+ - Migration compatibility
177
+
178
+ ## Performance Optimization
179
+
180
+ ### Caching Strategy
181
+
182
+ The discovery service implements a 1-hour cache for npm queries:
183
+ - Cold start: First request fetches from npm
184
+ - Cached: Subsequent requests use in-memory cache
185
+ - Cache invalidation: Manual or time-based
186
+
187
+ ### Batch Processing
188
+
189
+ For optimal performance with multiple operations:
190
+ - Use bulk endpoints when available
191
+ - Process in configurable batch sizes
192
+ - Implement proper error handling per batch
193
+
194
+ ### WebSocket Updates
195
+
196
+ Real-time updates for long-running operations:
197
+ - Installation progress
198
+ - Connection status changes
199
+ - Environment updates
200
+ - Error notifications
201
+
202
+ ## Security Considerations
203
+
204
+ ### Environment Variables
205
+ - Automatic masking of sensitive values
206
+ - Patterns detected: PASSWORD, SECRET, KEY, TOKEN, etc.
207
+ - Read-only access for discovery operations
208
+ - Production updates require explicit confirmation
209
+
210
+ ### Test Data Isolation
211
+ - All dummy users marked with `isDummy: true`
212
+ - Test IDs include 'test' prefix
213
+ - Separate storage from production data
214
+ - No cross-contamination possible
215
+
216
+ ### Input Validation
217
+ - Variable name validation (alphanumeric + underscore)
218
+ - Package name verification
219
+ - Credential format checking
220
+ - SQL injection prevention
221
+
222
+ ## Migration from create-frigg-app
223
+
224
+ ### Automated Migration
225
+
226
+ ```javascript
227
+ const migration = await phase2Workflows.migrateProject('/path/to/project', {
228
+ preserveCustom: true,
229
+ integrationMapping: {
230
+ 'old-integration': 'new-integration'
231
+ }
232
+ });
233
+ ```
234
+
235
+ ### Manual Migration Steps
236
+
237
+ 1. **Backup existing project**
238
+ 2. **Update dependencies**:
239
+ ```json
240
+ {
241
+ "devDependencies": {
242
+ "@friggframework/cli": "latest"
243
+ }
244
+ }
245
+ ```
246
+ 3. **Run migration command**:
247
+ ```bash
248
+ frigg migrate --from-create-frigg-app
249
+ ```
250
+ 4. **Verify integration configurations**
251
+ 5. **Update environment variables**
252
+ 6. **Test all connections**
253
+
254
+ ## Troubleshooting
255
+
256
+ ### Common Issues
257
+
258
+ #### Integration Discovery Fails
259
+ - Check network connectivity
260
+ - Verify npm registry access
261
+ - Clear discovery cache
262
+ - Check for proxy settings
263
+
264
+ #### Connection Test Failures
265
+ - Verify credentials are correct
266
+ - Check integration configuration
267
+ - Review API rate limits
268
+ - Inspect WebSocket connection
269
+
270
+ #### Environment Variable Issues
271
+ - Ensure valid variable names
272
+ - Check file permissions for .env
273
+ - Verify AWS credentials for production
274
+ - Look for conflicting variables
275
+
276
+ ### Debug Mode
277
+
278
+ Enable debug logging:
279
+ ```bash
280
+ DEBUG=frigg:* npm run dev:server
281
+ ```
282
+
283
+ ### Health Checks
284
+
285
+ Monitor system health:
286
+ ```javascript
287
+ // API endpoint
288
+ GET /api/health
289
+
290
+ // Returns
291
+ {
292
+ "status": "healthy",
293
+ "services": {
294
+ "discovery": "operational",
295
+ "installer": "operational",
296
+ "websocket": "connected",
297
+ "environment": "configured"
298
+ }
299
+ }
300
+ ```
301
+
302
+ ## Best Practices
303
+
304
+ 1. **Use Workflows**: Leverage the provided workflows for complex operations
305
+ 2. **Monitor Performance**: Regularly run benchmarks to ensure optimal performance
306
+ 3. **Test Thoroughly**: Use the comprehensive test suites before deployment
307
+ 4. **Handle Errors**: Implement proper error handling for all async operations
308
+ 5. **Cache Wisely**: Use caching for frequently accessed data
309
+ 6. **Secure Sensitive Data**: Always mask sensitive environment variables
310
+ 7. **Document Custom Integrations**: Maintain clear documentation for custom work
311
+
312
+ ## Next Steps
313
+
314
+ After Phase 2 implementation:
315
+
316
+ 1. **Phase 3**: Advanced features including production monitoring
317
+ 2. **Phase 4**: Multi-framework UI support
318
+ 3. **Phase 5**: Complete migration and deprecation of create-frigg-app
319
+
320
+ For questions or issues, refer to the [Frigg documentation](https://docs.frigg.dev) or open an issue on GitHub.
@@ -0,0 +1,13 @@
1
+ <!DOCTYPE html>
2
+ <html lang="en">
3
+ <head>
4
+ <meta charset="UTF-8" />
5
+ <link rel="icon" type="image/svg+xml" href="/vite.svg" />
6
+ <meta name="viewport" content="width=device-width, initial-scale=1.0" />
7
+ <title>Frigg Management UI</title>
8
+ </head>
9
+ <body>
10
+ <div id="root"></div>
11
+ <script type="module" src="/src/main.jsx"></script>
12
+ </body>
13
+ </html>
@@ -0,0 +1,76 @@
1
+ {
2
+ "name": "@friggframework/management-ui",
3
+ "version": "0.1.0",
4
+ "private": true,
5
+ "type": "module",
6
+ "scripts": {
7
+ "dev": "vite",
8
+ "dev:server": "concurrently \"npm run server\" \"npm run dev\"",
9
+ "build": "vite build",
10
+ "preview": "vite preview",
11
+ "server": "node server/server.js",
12
+ "server:old": "node server/index.js",
13
+ "server:dev": "nodemon server/server.js",
14
+ "test": "vitest",
15
+ "test:ui": "vitest --ui",
16
+ "test:watch": "vitest --watch",
17
+ "test:coverage": "vitest --coverage",
18
+ "lint": "eslint src --ext js,jsx --report-unused-disable-directives --max-warnings 0",
19
+ "lint:fix": "eslint src --ext js,jsx --fix",
20
+ "typecheck": "tsc --noEmit"
21
+ },
22
+ "dependencies": {
23
+ "@aws-sdk/client-api-gateway": "^3.478.0",
24
+ "@aws-sdk/client-cloudwatch": "^3.478.0",
25
+ "@aws-sdk/client-lambda": "^3.478.0",
26
+ "@aws-sdk/client-sqs": "^3.478.0",
27
+ "@friggframework/ui": "^2.0.0-next.0",
28
+ "@friggframework/ui-react": "file:../../ui/react",
29
+ "@radix-ui/react-dropdown-menu": "^2.1.15",
30
+ "@radix-ui/react-select": "^2.2.5",
31
+ "@radix-ui/react-slot": "^1.2.3",
32
+ "axios": "^1.6.7",
33
+ "class-variance-authority": "^0.7.1",
34
+ "clsx": "^2.1.1",
35
+ "cors": "^2.8.5",
36
+ "express": "^4.18.2",
37
+ "framer-motion": "^12.20.1",
38
+ "fs-extra": "^11.2.0",
39
+ "handlebars": "^4.7.8",
40
+ "lucide-react": "^0.473.0",
41
+ "node-cache": "^5.1.2",
42
+ "node-fetch": "^3.3.2",
43
+ "react": "^18.3.1",
44
+ "react-dom": "^18.3.1",
45
+ "react-router-dom": "^6.22.0",
46
+ "semver": "^7.5.4",
47
+ "socket.io": "^4.7.4",
48
+ "socket.io-client": "^4.7.4",
49
+ "tailwind-merge": "^2.6.0",
50
+ "tailwindcss-animate": "^1.0.7"
51
+ },
52
+ "devDependencies": {
53
+ "@types/react": "^18.3.3",
54
+ "@types/react-dom": "^18.3.0",
55
+ "@vitejs/plugin-react": "^4.3.1",
56
+ "autoprefixer": "^10.4.20",
57
+ "concurrently": "^8.2.2",
58
+ "eslint": "^8.57.0",
59
+ "eslint-plugin-react": "^7.34.3",
60
+ "eslint-plugin-react-hooks": "^4.6.2",
61
+ "eslint-plugin-react-refresh": "^0.4.7",
62
+ "nodemon": "^3.0.3",
63
+ "postcss": "^8.4.41",
64
+ "tailwindcss": "^3.4.10",
65
+ "typescript": "^5.2.2",
66
+ "vite": "^5.3.4",
67
+ "vitest": "^1.6.0",
68
+ "@vitest/ui": "^1.6.0",
69
+ "@vitest/coverage-v8": "^1.6.0",
70
+ "@testing-library/react": "^14.3.1",
71
+ "@testing-library/jest-dom": "^6.4.6",
72
+ "@testing-library/user-event": "^14.5.2",
73
+ "jsdom": "^24.1.0",
74
+ "msw": "^2.3.1"
75
+ }
76
+ }