@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,538 @@
1
+ import fs from 'fs-extra';
2
+ import path from 'path';
3
+ import { spawn } from 'child_process';
4
+ import handlebars from 'handlebars';
5
+
6
+ /**
7
+ * Template Engine Service for Code Generation
8
+ * Handles template processing, file generation, and CLI integration
9
+ */
10
+ class TemplateEngine {
11
+ constructor() {
12
+ this.templates = new Map();
13
+ this.helpers = new Map();
14
+ this.setupDefaultHelpers();
15
+ }
16
+
17
+ /**
18
+ * Setup default Handlebars helpers
19
+ */
20
+ setupDefaultHelpers() {
21
+ // String manipulation helpers
22
+ handlebars.registerHelper('capitalize', (str) => {
23
+ return str.charAt(0).toUpperCase() + str.slice(1);
24
+ });
25
+
26
+ handlebars.registerHelper('camelCase', (str) => {
27
+ return str.replace(/-([a-z])/g, (g) => g[1].toUpperCase());
28
+ });
29
+
30
+ handlebars.registerHelper('pascalCase', (str) => {
31
+ return str.replace(/(^|-)([a-z])/g, (g) => g.replace('-', '').toUpperCase());
32
+ });
33
+
34
+ handlebars.registerHelper('kebabCase', (str) => {
35
+ return str.replace(/([A-Z])/g, '-$1').toLowerCase().replace(/^-/, '');
36
+ });
37
+
38
+ handlebars.registerHelper('snakeCase', (str) => {
39
+ return str.replace(/([A-Z])/g, '_$1').toLowerCase().replace(/^_/, '');
40
+ });
41
+
42
+ handlebars.registerHelper('upperCase', (str) => {
43
+ return str.toUpperCase();
44
+ });
45
+
46
+ // Array helpers
47
+ handlebars.registerHelper('each', handlebars.helpers.each);
48
+ handlebars.registerHelper('join', (array, separator) => {
49
+ return Array.isArray(array) ? array.join(separator || ', ') : '';
50
+ });
51
+
52
+ // Conditional helpers
53
+ handlebars.registerHelper('if', handlebars.helpers.if);
54
+ handlebars.registerHelper('unless', handlebars.helpers.unless);
55
+ handlebars.registerHelper('eq', (a, b) => a === b);
56
+ handlebars.registerHelper('ne', (a, b) => a !== b);
57
+ handlebars.registerHelper('gt', (a, b) => a > b);
58
+ handlebars.registerHelper('lt', (a, b) => a < b);
59
+
60
+ // JSON helpers
61
+ handlebars.registerHelper('json', (obj) => {
62
+ return JSON.stringify(obj, null, 2);
63
+ });
64
+
65
+ handlebars.registerHelper('jsonInline', (obj) => {
66
+ return JSON.stringify(obj);
67
+ });
68
+
69
+ // Date helpers
70
+ handlebars.registerHelper('now', () => {
71
+ return new Date().toISOString();
72
+ });
73
+
74
+ handlebars.registerHelper('year', () => {
75
+ return new Date().getFullYear();
76
+ });
77
+
78
+ // Code generation specific helpers
79
+ handlebars.registerHelper('indent', (text, spaces = 2) => {
80
+ const indent = ' '.repeat(spaces);
81
+ return text.split('\n').map(line => line.trim() ? indent + line : line).join('\n');
82
+ });
83
+
84
+ handlebars.registerHelper('comment', (text, style = 'js') => {
85
+ switch (style) {
86
+ case 'js':
87
+ return `// ${text}`;
88
+ case 'block':
89
+ return `/*\n * ${text}\n */`;
90
+ case 'jsx':
91
+ return `{/* ${text} */}`;
92
+ case 'html':
93
+ return `<!-- ${text} -->`;
94
+ default:
95
+ return `// ${text}`;
96
+ }
97
+ });
98
+ }
99
+
100
+ /**
101
+ * Register a custom template
102
+ */
103
+ registerTemplate(name, template, metadata = {}) {
104
+ this.templates.set(name, {
105
+ template: handlebars.compile(template),
106
+ raw: template,
107
+ metadata
108
+ });
109
+ }
110
+
111
+ /**
112
+ * Register a custom helper
113
+ */
114
+ registerHelper(name, helper) {
115
+ this.helpers.set(name, helper);
116
+ handlebars.registerHelper(name, helper);
117
+ }
118
+
119
+ /**
120
+ * Process template with data
121
+ */
122
+ processTemplate(templateName, data) {
123
+ const template = this.templates.get(templateName);
124
+ if (!template) {
125
+ throw new Error(`Template '${templateName}' not found`);
126
+ }
127
+
128
+ try {
129
+ return template.template(data);
130
+ } catch (error) {
131
+ throw new Error(`Template processing error: ${error.message}`);
132
+ }
133
+ }
134
+
135
+ /**
136
+ * Generate integration module
137
+ */
138
+ generateIntegration(config) {
139
+ const {
140
+ name,
141
+ displayName,
142
+ description,
143
+ type,
144
+ baseURL,
145
+ authorizationURL,
146
+ tokenURL,
147
+ scope,
148
+ apiEndpoints = [],
149
+ entitySchema = []
150
+ } = config;
151
+
152
+ const className = this.pascalCase(name);
153
+ const authFields = this.getAuthFields(type);
154
+ const allEntityFields = [...authFields, ...entitySchema, {
155
+ name: 'user_id',
156
+ label: 'User ID',
157
+ type: 'string',
158
+ required: true
159
+ }];
160
+
161
+ const data = {
162
+ name,
163
+ displayName,
164
+ description,
165
+ type,
166
+ className,
167
+ baseURL,
168
+ authorizationURL,
169
+ tokenURL,
170
+ scope,
171
+ apiEndpoints,
172
+ entitySchema: allEntityFields,
173
+ authFields,
174
+ hasOAuth2: type === 'oauth2',
175
+ hasApiKey: type === 'api',
176
+ hasBasicAuth: type === 'basic-auth'
177
+ };
178
+
179
+ const integrationCode = this.generateIntegrationCode(data);
180
+ const testCode = this.generateTestCode(data);
181
+ const packageJson = this.generatePackageJson(data);
182
+ const readme = this.generateReadme(data);
183
+
184
+ return {
185
+ files: [
186
+ { name: 'index.js', content: integrationCode },
187
+ { name: '__tests__/index.test.js', content: testCode },
188
+ { name: 'package.json', content: packageJson },
189
+ { name: 'README.md', content: readme }
190
+ ],
191
+ metadata: {
192
+ name,
193
+ className,
194
+ type,
195
+ generatedAt: new Date().toISOString()
196
+ }
197
+ };
198
+ }
199
+
200
+ /**
201
+ * Generate API endpoints
202
+ */
203
+ generateAPIEndpoints(config) {
204
+ const { name, description, baseURL, version, authentication, endpoints = [] } = config;
205
+
206
+ const data = {
207
+ name,
208
+ description,
209
+ baseURL,
210
+ version,
211
+ authentication,
212
+ endpoints,
213
+ serviceName: this.pascalCase(name) + 'Service',
214
+ routerName: this.camelCase(name) + 'Router'
215
+ };
216
+
217
+ const routerCode = this.generateRouterCode(data);
218
+ const serviceCode = this.generateServiceCode(data);
219
+ const openApiSpec = this.generateOpenAPISpec(data);
220
+ const readme = this.generateAPIReadme(data);
221
+
222
+ return {
223
+ files: [
224
+ { name: 'router.js', content: routerCode },
225
+ { name: 'service.js', content: serviceCode },
226
+ { name: 'openapi.json', content: openApiSpec },
227
+ { name: 'README.md', content: readme }
228
+ ],
229
+ metadata: {
230
+ name,
231
+ type: 'api-endpoints',
232
+ endpointCount: endpoints.length,
233
+ generatedAt: new Date().toISOString()
234
+ }
235
+ };
236
+ }
237
+
238
+ /**
239
+ * Generate project scaffold
240
+ */
241
+ generateProjectScaffold(config) {
242
+ const {
243
+ name,
244
+ description,
245
+ template,
246
+ database,
247
+ integrations = [],
248
+ features = {},
249
+ deployment = {}
250
+ } = config;
251
+
252
+ const data = {
253
+ name,
254
+ description,
255
+ template,
256
+ database,
257
+ integrations,
258
+ features,
259
+ deployment,
260
+ year: new Date().getFullYear()
261
+ };
262
+
263
+ const files = [];
264
+
265
+ // Generate package.json
266
+ files.push({
267
+ name: 'package.json',
268
+ content: this.generateScaffoldPackageJson(data)
269
+ });
270
+
271
+ // Generate main app file
272
+ files.push({
273
+ name: 'app.js',
274
+ content: this.generateAppJs(data)
275
+ });
276
+
277
+ // Generate README
278
+ files.push({
279
+ name: 'README.md',
280
+ content: this.generateScaffoldReadme(data)
281
+ });
282
+
283
+ // Generate environment files
284
+ files.push({
285
+ name: '.env.example',
286
+ content: this.generateEnvExample(data)
287
+ });
288
+
289
+ // Generate serverless.yml if serverless template
290
+ if (template === 'serverless') {
291
+ files.push({
292
+ name: 'serverless.yml',
293
+ content: this.generateServerlessYml(data)
294
+ });
295
+ }
296
+
297
+ // Generate Docker files if enabled
298
+ if (features.docker) {
299
+ files.push({
300
+ name: 'Dockerfile',
301
+ content: this.generateDockerfile(data)
302
+ });
303
+ files.push({
304
+ name: 'docker-compose.yml',
305
+ content: this.generateDockerCompose(data)
306
+ });
307
+ }
308
+
309
+ // Generate CI configuration if enabled
310
+ if (features.ci) {
311
+ files.push({
312
+ name: '.github/workflows/ci.yml',
313
+ content: this.generateCIConfig(data)
314
+ });
315
+ }
316
+
317
+ return {
318
+ files,
319
+ metadata: {
320
+ name,
321
+ template,
322
+ type: 'project-scaffold',
323
+ integrationCount: integrations.length,
324
+ generatedAt: new Date().toISOString()
325
+ }
326
+ };
327
+ }
328
+
329
+ /**
330
+ * Write generated files to filesystem
331
+ */
332
+ async writeFiles(files, outputDir) {
333
+ await fs.ensureDir(outputDir);
334
+ const writtenFiles = [];
335
+
336
+ for (const file of files) {
337
+ const filePath = path.join(outputDir, file.name);
338
+ await fs.ensureDir(path.dirname(filePath));
339
+ await fs.writeFile(filePath, file.content, 'utf8');
340
+ writtenFiles.push(filePath);
341
+ }
342
+
343
+ return writtenFiles;
344
+ }
345
+
346
+ /**
347
+ * Execute Frigg CLI commands
348
+ */
349
+ async executeFriggCommand(command, args = [], cwd = process.cwd()) {
350
+ return new Promise((resolve, reject) => {
351
+ const friggCli = path.join(__dirname, '../../../frigg-cli/index.js');
352
+ const child = spawn('node', [friggCli, command, ...args], {
353
+ cwd,
354
+ stdio: 'pipe'
355
+ });
356
+
357
+ let stdout = '';
358
+ let stderr = '';
359
+
360
+ child.stdout.on('data', (data) => {
361
+ stdout += data.toString();
362
+ });
363
+
364
+ child.stderr.on('data', (data) => {
365
+ stderr += data.toString();
366
+ });
367
+
368
+ child.on('close', (code) => {
369
+ if (code === 0) {
370
+ resolve({ stdout, stderr, code });
371
+ } else {
372
+ reject(new Error(`Frigg CLI command failed: ${stderr || stdout}`));
373
+ }
374
+ });
375
+
376
+ child.on('error', reject);
377
+ });
378
+ }
379
+
380
+ /**
381
+ * Generate and install integration using CLI
382
+ */
383
+ async generateAndInstallIntegration(config, projectPath) {
384
+ try {
385
+ // Generate integration files
386
+ const result = this.generateIntegration(config);
387
+
388
+ // Create integration directory
389
+ const integrationDir = path.join(projectPath, 'src', 'integrations', config.name);
390
+ const writtenFiles = await this.writeFiles(result.files, integrationDir);
391
+
392
+ // Use CLI to install the integration
393
+ await this.executeFriggCommand('install', [config.name], projectPath);
394
+
395
+ return {
396
+ success: true,
397
+ files: writtenFiles,
398
+ metadata: result.metadata
399
+ };
400
+ } catch (error) {
401
+ return {
402
+ success: false,
403
+ error: error.message
404
+ };
405
+ }
406
+ }
407
+
408
+ // Helper methods for code generation
409
+ getAuthFields(type) {
410
+ const authFields = {
411
+ api: [
412
+ { name: 'api_key', label: 'API Key', type: 'string', required: true, encrypted: false }
413
+ ],
414
+ oauth2: [
415
+ { name: 'access_token', label: 'Access Token', type: 'string', required: true, encrypted: false },
416
+ { name: 'refresh_token', label: 'Refresh Token', type: 'string', required: false, encrypted: false },
417
+ { name: 'expires_at', label: 'Expires At', type: 'date', required: false, encrypted: false },
418
+ { name: 'scope', label: 'Scope', type: 'string', required: false, encrypted: false }
419
+ ],
420
+ 'basic-auth': [
421
+ { name: 'username', label: 'Username', type: 'string', required: true, encrypted: false },
422
+ { name: 'password', label: 'Password', type: 'string', required: true, encrypted: true }
423
+ ],
424
+ oauth1: [
425
+ { name: 'oauth_token', label: 'OAuth Token', type: 'string', required: true, encrypted: false },
426
+ { name: 'oauth_token_secret', label: 'OAuth Token Secret', type: 'string', required: true, encrypted: true }
427
+ ]
428
+ };
429
+
430
+ return authFields[type] || [];
431
+ }
432
+
433
+ pascalCase(str) {
434
+ return str.replace(/(^|-)([a-z])/g, (g) => g.replace('-', '').toUpperCase());
435
+ }
436
+
437
+ camelCase(str) {
438
+ return str.replace(/-([a-z])/g, (g) => g[1].toUpperCase());
439
+ }
440
+
441
+ // Code generation methods (implementations would go here)
442
+ generateIntegrationCode(data) {
443
+ // Implementation for integration code generation
444
+ // This would use the template patterns from the CLI
445
+ return `// Generated integration code for ${data.name}`;
446
+ }
447
+
448
+ generateTestCode(data) {
449
+ // Implementation for test code generation
450
+ return `// Generated test code for ${data.name}`;
451
+ }
452
+
453
+ generatePackageJson(data) {
454
+ // Implementation for package.json generation
455
+ return JSON.stringify({
456
+ name: `@friggframework/${data.name}`,
457
+ version: '0.1.0',
458
+ description: data.description
459
+ }, null, 2);
460
+ }
461
+
462
+ generateReadme(data) {
463
+ // Implementation for README generation
464
+ return `# ${data.displayName}\n\n${data.description}`;
465
+ }
466
+
467
+ generateRouterCode(data) {
468
+ // Implementation for router code generation
469
+ return `// Generated router code for ${data.name}`;
470
+ }
471
+
472
+ generateServiceCode(data) {
473
+ // Implementation for service code generation
474
+ return `// Generated service code for ${data.name}`;
475
+ }
476
+
477
+ generateOpenAPISpec(data) {
478
+ // Implementation for OpenAPI spec generation
479
+ return JSON.stringify({
480
+ openapi: '3.0.0',
481
+ info: {
482
+ title: data.name,
483
+ version: data.version
484
+ }
485
+ }, null, 2);
486
+ }
487
+
488
+ generateAPIReadme(data) {
489
+ // Implementation for API README generation
490
+ return `# ${data.name} API\n\n${data.description}`;
491
+ }
492
+
493
+ generateScaffoldPackageJson(data) {
494
+ // Implementation for scaffold package.json generation
495
+ return JSON.stringify({
496
+ name: data.name,
497
+ version: '1.0.0',
498
+ description: data.description
499
+ }, null, 2);
500
+ }
501
+
502
+ generateAppJs(data) {
503
+ // Implementation for app.js generation
504
+ return `// Generated app.js for ${data.name}`;
505
+ }
506
+
507
+ generateScaffoldReadme(data) {
508
+ // Implementation for scaffold README generation
509
+ return `# ${data.name}\n\n${data.description}`;
510
+ }
511
+
512
+ generateEnvExample(data) {
513
+ // Implementation for .env.example generation
514
+ return `# Environment variables for ${data.name}`;
515
+ }
516
+
517
+ generateServerlessYml(data) {
518
+ // Implementation for serverless.yml generation
519
+ return `service: ${data.name}`;
520
+ }
521
+
522
+ generateDockerfile(data) {
523
+ // Implementation for Dockerfile generation
524
+ return `FROM node:18-alpine`;
525
+ }
526
+
527
+ generateDockerCompose(data) {
528
+ // Implementation for docker-compose.yml generation
529
+ return `version: '3.8'`;
530
+ }
531
+
532
+ generateCIConfig(data) {
533
+ // Implementation for CI configuration generation
534
+ return `name: CI`;
535
+ }
536
+ }
537
+
538
+ export default TemplateEngine;