@friggframework/devtools 2.0.0-next.61 → 2.0.0-next.63

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 (142) hide show
  1. package/infrastructure/domains/shared/utilities/base-definition-factory.js +15 -1
  2. package/package.json +15 -7
  3. package/.eslintrc.json +0 -3
  4. package/CHANGELOG.md +0 -132
  5. package/layers/prisma/.build-complete +0 -3
  6. package/layers/prisma/nodejs/package.json +0 -8
  7. package/management-ui/.eslintrc.js +0 -22
  8. package/management-ui/components.json +0 -21
  9. package/management-ui/docs/phase2-integration-guide.md +0 -320
  10. package/management-ui/index.html +0 -13
  11. package/management-ui/package.json +0 -76
  12. package/management-ui/packages/devtools/frigg-cli/ui-command/index.js +0 -302
  13. package/management-ui/postcss.config.js +0 -6
  14. package/management-ui/server/api/backend.js +0 -256
  15. package/management-ui/server/api/cli.js +0 -315
  16. package/management-ui/server/api/codegen.js +0 -663
  17. package/management-ui/server/api/connections.js +0 -857
  18. package/management-ui/server/api/discovery.js +0 -185
  19. package/management-ui/server/api/environment/index.js +0 -1
  20. package/management-ui/server/api/environment/router.js +0 -378
  21. package/management-ui/server/api/environment.js +0 -328
  22. package/management-ui/server/api/integrations.js +0 -876
  23. package/management-ui/server/api/logs.js +0 -248
  24. package/management-ui/server/api/monitoring.js +0 -282
  25. package/management-ui/server/api/open-ide.js +0 -31
  26. package/management-ui/server/api/project.js +0 -1029
  27. package/management-ui/server/api/users/sessions.js +0 -371
  28. package/management-ui/server/api/users/simulation.js +0 -254
  29. package/management-ui/server/api/users.js +0 -362
  30. package/management-ui/server/api-contract.md +0 -275
  31. package/management-ui/server/index.js +0 -873
  32. package/management-ui/server/middleware/errorHandler.js +0 -93
  33. package/management-ui/server/middleware/security.js +0 -32
  34. package/management-ui/server/processManager.js +0 -296
  35. package/management-ui/server/server.js +0 -346
  36. package/management-ui/server/services/aws-monitor.js +0 -413
  37. package/management-ui/server/services/npm-registry.js +0 -347
  38. package/management-ui/server/services/template-engine.js +0 -538
  39. package/management-ui/server/utils/cliIntegration.js +0 -220
  40. package/management-ui/server/utils/environment/auditLogger.js +0 -471
  41. package/management-ui/server/utils/environment/awsParameterStore.js +0 -275
  42. package/management-ui/server/utils/environment/encryption.js +0 -278
  43. package/management-ui/server/utils/environment/envFileManager.js +0 -286
  44. package/management-ui/server/utils/import-commonjs.js +0 -28
  45. package/management-ui/server/utils/response.js +0 -83
  46. package/management-ui/server/websocket/handler.js +0 -325
  47. package/management-ui/src/App.jsx +0 -25
  48. package/management-ui/src/assets/FriggLogo.svg +0 -1
  49. package/management-ui/src/components/AppRouter.jsx +0 -65
  50. package/management-ui/src/components/Button.jsx +0 -70
  51. package/management-ui/src/components/Card.jsx +0 -97
  52. package/management-ui/src/components/EnvironmentCompare.jsx +0 -400
  53. package/management-ui/src/components/EnvironmentEditor.jsx +0 -372
  54. package/management-ui/src/components/EnvironmentImportExport.jsx +0 -469
  55. package/management-ui/src/components/EnvironmentSchema.jsx +0 -491
  56. package/management-ui/src/components/EnvironmentSecurity.jsx +0 -463
  57. package/management-ui/src/components/ErrorBoundary.jsx +0 -73
  58. package/management-ui/src/components/IntegrationCard.jsx +0 -481
  59. package/management-ui/src/components/IntegrationCardEnhanced.jsx +0 -770
  60. package/management-ui/src/components/IntegrationExplorer.jsx +0 -379
  61. package/management-ui/src/components/IntegrationStatus.jsx +0 -336
  62. package/management-ui/src/components/Layout.jsx +0 -716
  63. package/management-ui/src/components/LoadingSpinner.jsx +0 -113
  64. package/management-ui/src/components/RepositoryPicker.jsx +0 -248
  65. package/management-ui/src/components/SessionMonitor.jsx +0 -350
  66. package/management-ui/src/components/StatusBadge.jsx +0 -208
  67. package/management-ui/src/components/UserContextSwitcher.jsx +0 -212
  68. package/management-ui/src/components/UserSimulation.jsx +0 -327
  69. package/management-ui/src/components/Welcome.jsx +0 -434
  70. package/management-ui/src/components/codegen/APIEndpointGenerator.jsx +0 -637
  71. package/management-ui/src/components/codegen/APIModuleSelector.jsx +0 -227
  72. package/management-ui/src/components/codegen/CodeGenerationWizard.jsx +0 -247
  73. package/management-ui/src/components/codegen/CodePreviewEditor.jsx +0 -316
  74. package/management-ui/src/components/codegen/DynamicModuleForm.jsx +0 -271
  75. package/management-ui/src/components/codegen/FormBuilder.jsx +0 -737
  76. package/management-ui/src/components/codegen/IntegrationGenerator.jsx +0 -855
  77. package/management-ui/src/components/codegen/ProjectScaffoldWizard.jsx +0 -797
  78. package/management-ui/src/components/codegen/SchemaBuilder.jsx +0 -303
  79. package/management-ui/src/components/codegen/TemplateSelector.jsx +0 -586
  80. package/management-ui/src/components/codegen/index.js +0 -10
  81. package/management-ui/src/components/connections/ConnectionConfigForm.jsx +0 -362
  82. package/management-ui/src/components/connections/ConnectionHealthMonitor.jsx +0 -182
  83. package/management-ui/src/components/connections/ConnectionTester.jsx +0 -200
  84. package/management-ui/src/components/connections/EntityRelationshipMapper.jsx +0 -292
  85. package/management-ui/src/components/connections/OAuthFlow.jsx +0 -204
  86. package/management-ui/src/components/connections/index.js +0 -5
  87. package/management-ui/src/components/index.js +0 -21
  88. package/management-ui/src/components/monitoring/APIGatewayMetrics.jsx +0 -222
  89. package/management-ui/src/components/monitoring/LambdaMetrics.jsx +0 -169
  90. package/management-ui/src/components/monitoring/MetricsChart.jsx +0 -197
  91. package/management-ui/src/components/monitoring/MonitoringDashboard.jsx +0 -393
  92. package/management-ui/src/components/monitoring/SQSMetrics.jsx +0 -246
  93. package/management-ui/src/components/monitoring/index.js +0 -6
  94. package/management-ui/src/components/monitoring/monitoring.css +0 -218
  95. package/management-ui/src/components/theme-provider.jsx +0 -52
  96. package/management-ui/src/components/theme-toggle.jsx +0 -39
  97. package/management-ui/src/components/ui/badge.tsx +0 -36
  98. package/management-ui/src/components/ui/button.test.jsx +0 -56
  99. package/management-ui/src/components/ui/button.tsx +0 -57
  100. package/management-ui/src/components/ui/card.tsx +0 -76
  101. package/management-ui/src/components/ui/dropdown-menu.tsx +0 -199
  102. package/management-ui/src/components/ui/select.tsx +0 -157
  103. package/management-ui/src/components/ui/skeleton.jsx +0 -15
  104. package/management-ui/src/hooks/useFrigg.jsx +0 -387
  105. package/management-ui/src/hooks/useSocket.jsx +0 -58
  106. package/management-ui/src/index.css +0 -193
  107. package/management-ui/src/lib/utils.ts +0 -6
  108. package/management-ui/src/main.jsx +0 -10
  109. package/management-ui/src/pages/CodeGeneration.jsx +0 -14
  110. package/management-ui/src/pages/Connections.jsx +0 -252
  111. package/management-ui/src/pages/ConnectionsEnhanced.jsx +0 -633
  112. package/management-ui/src/pages/Dashboard.jsx +0 -311
  113. package/management-ui/src/pages/Environment.jsx +0 -314
  114. package/management-ui/src/pages/IntegrationConfigure.jsx +0 -669
  115. package/management-ui/src/pages/IntegrationDiscovery.jsx +0 -567
  116. package/management-ui/src/pages/IntegrationTest.jsx +0 -742
  117. package/management-ui/src/pages/Integrations.jsx +0 -253
  118. package/management-ui/src/pages/Monitoring.jsx +0 -17
  119. package/management-ui/src/pages/Simulation.jsx +0 -155
  120. package/management-ui/src/pages/Users.jsx +0 -492
  121. package/management-ui/src/services/api.js +0 -41
  122. package/management-ui/src/services/apiModuleService.js +0 -193
  123. package/management-ui/src/services/websocket-handlers.js +0 -120
  124. package/management-ui/src/test/api/project.test.js +0 -273
  125. package/management-ui/src/test/components/Welcome.test.jsx +0 -378
  126. package/management-ui/src/test/mocks/server.js +0 -178
  127. package/management-ui/src/test/setup.js +0 -61
  128. package/management-ui/src/test/utils/test-utils.jsx +0 -134
  129. package/management-ui/src/utils/repository.js +0 -98
  130. package/management-ui/src/utils/repository.test.js +0 -118
  131. package/management-ui/src/workflows/phase2-integration-workflows.js +0 -884
  132. package/management-ui/tailwind.config.js +0 -63
  133. package/management-ui/tsconfig.json +0 -37
  134. package/management-ui/tsconfig.node.json +0 -10
  135. package/management-ui/vite.config.js +0 -26
  136. package/management-ui/vitest.config.js +0 -38
  137. package/test/auther-definition-method-tester.js +0 -45
  138. package/test/index.js +0 -9
  139. package/test/integration-validator.js +0 -2
  140. package/test/mock-api-readme.md +0 -102
  141. package/test/mock-api.js +0 -284
  142. package/test/mock-integration.js +0 -78
@@ -1,303 +0,0 @@
1
- import React, { useState, useCallback } from 'react';
2
- import { Card } from '../Card';
3
- import { Button } from '../Button';
4
-
5
- const FIELD_TYPES = [
6
- { value: 'string', label: 'String' },
7
- { value: 'number', label: 'Number' },
8
- { value: 'boolean', label: 'Boolean' },
9
- { value: 'date', label: 'Date' },
10
- { value: 'array', label: 'Array' },
11
- { value: 'object', label: 'Object' },
12
- { value: 'json', label: 'JSON' }
13
- ];
14
-
15
- const SchemaBuilder = ({ schema = [], onChange }) => {
16
- const [editingField, setEditingField] = useState(null);
17
-
18
- const handleAddField = useCallback(() => {
19
- const newField = {
20
- id: Date.now(),
21
- name: '',
22
- label: '',
23
- type: 'string',
24
- required: false,
25
- encrypted: false,
26
- default: '',
27
- validation: {}
28
- };
29
- onChange([...schema, newField]);
30
- setEditingField(newField.id);
31
- }, [schema, onChange]);
32
-
33
- const handleUpdateField = useCallback((id, updates) => {
34
- const updatedSchema = schema.map(field =>
35
- field.id === id ? { ...field, ...updates } : field
36
- );
37
- onChange(updatedSchema);
38
- }, [schema, onChange]);
39
-
40
- const handleRemoveField = useCallback((id) => {
41
- const updatedSchema = schema.filter(field => field.id !== id);
42
- onChange(updatedSchema);
43
- if (editingField === id) {
44
- setEditingField(null);
45
- }
46
- }, [schema, onChange, editingField]);
47
-
48
- const handleSaveField = useCallback(() => {
49
- setEditingField(null);
50
- }, []);
51
-
52
- const renderFieldEditor = (field) => {
53
- if (editingField !== field.id) {
54
- return (
55
- <div className="flex items-center justify-between p-4 border rounded-md">
56
- <div>
57
- <div className="font-medium">{field.label || field.name || 'Unnamed Field'}</div>
58
- <div className="text-sm text-gray-500">
59
- {field.type} {field.required && '• Required'} {field.encrypted && '• Encrypted'}
60
- </div>
61
- </div>
62
- <div className="flex space-x-2">
63
- <Button
64
- size="sm"
65
- variant="outline"
66
- onClick={() => setEditingField(field.id)}
67
- >
68
- Edit
69
- </Button>
70
- <Button
71
- size="sm"
72
- variant="outline"
73
- onClick={() => handleRemoveField(field.id)}
74
- className="text-red-600 hover:text-red-700"
75
- >
76
- Remove
77
- </Button>
78
- </div>
79
- </div>
80
- );
81
- }
82
-
83
- return (
84
- <Card className="p-4">
85
- <div className="space-y-4">
86
- <div className="grid grid-cols-1 md:grid-cols-2 gap-4">
87
- <div>
88
- <label className="block text-sm font-medium text-gray-700 mb-2">
89
- Field Name *
90
- </label>
91
- <input
92
- type="text"
93
- value={field.name}
94
- onChange={(e) => handleUpdateField(field.id, { name: e.target.value })}
95
- placeholder="field_name"
96
- className="w-full px-3 py-2 border border-gray-300 rounded-md focus:outline-none focus:ring-2 focus:ring-blue-500"
97
- />
98
- <p className="text-xs text-gray-500 mt-1">Used in code (snake_case recommended)</p>
99
- </div>
100
- <div>
101
- <label className="block text-sm font-medium text-gray-700 mb-2">
102
- Display Label
103
- </label>
104
- <input
105
- type="text"
106
- value={field.label}
107
- onChange={(e) => handleUpdateField(field.id, { label: e.target.value })}
108
- placeholder="Field Label"
109
- className="w-full px-3 py-2 border border-gray-300 rounded-md focus:outline-none focus:ring-2 focus:ring-blue-500"
110
- />
111
- <p className="text-xs text-gray-500 mt-1">Human-readable label</p>
112
- </div>
113
- </div>
114
-
115
- <div className="grid grid-cols-1 md:grid-cols-3 gap-4">
116
- <div>
117
- <label className="block text-sm font-medium text-gray-700 mb-2">
118
- Type
119
- </label>
120
- <select
121
- value={field.type}
122
- onChange={(e) => handleUpdateField(field.id, { type: e.target.value })}
123
- className="w-full px-3 py-2 border border-gray-300 rounded-md focus:outline-none focus:ring-2 focus:ring-blue-500"
124
- >
125
- {FIELD_TYPES.map(type => (
126
- <option key={type.value} value={type.value}>
127
- {type.label}
128
- </option>
129
- ))}
130
- </select>
131
- </div>
132
- <div>
133
- <label className="block text-sm font-medium text-gray-700 mb-2">
134
- Default Value
135
- </label>
136
- <input
137
- type="text"
138
- value={field.default}
139
- onChange={(e) => handleUpdateField(field.id, { default: e.target.value })}
140
- placeholder="Optional default"
141
- className="w-full px-3 py-2 border border-gray-300 rounded-md focus:outline-none focus:ring-2 focus:ring-blue-500"
142
- />
143
- </div>
144
- <div className="flex flex-col justify-center space-y-2">
145
- <label className="flex items-center">
146
- <input
147
- type="checkbox"
148
- checked={field.required}
149
- onChange={(e) => handleUpdateField(field.id, { required: e.target.checked })}
150
- className="mr-2"
151
- />
152
- <span className="text-sm">Required</span>
153
- </label>
154
- <label className="flex items-center">
155
- <input
156
- type="checkbox"
157
- checked={field.encrypted}
158
- onChange={(e) => handleUpdateField(field.id, { encrypted: e.target.checked })}
159
- className="mr-2"
160
- />
161
- <span className="text-sm">Encrypted</span>
162
- </label>
163
- </div>
164
- </div>
165
-
166
- {(field.type === 'string' || field.type === 'number') && (
167
- <div className="bg-gray-50 p-4 rounded-md">
168
- <h4 className="font-medium text-gray-900 mb-3">Validation Rules</h4>
169
- <div className="grid grid-cols-1 md:grid-cols-2 gap-4">
170
- {field.type === 'string' && (
171
- <>
172
- <div>
173
- <label className="block text-sm font-medium text-gray-700 mb-2">
174
- Min Length
175
- </label>
176
- <input
177
- type="number"
178
- value={field.validation?.minLength || ''}
179
- onChange={(e) => handleUpdateField(field.id, {
180
- validation: { ...field.validation, minLength: parseInt(e.target.value) || undefined }
181
- })}
182
- className="w-full px-3 py-2 border border-gray-300 rounded-md focus:outline-none focus:ring-2 focus:ring-blue-500"
183
- />
184
- </div>
185
- <div>
186
- <label className="block text-sm font-medium text-gray-700 mb-2">
187
- Max Length
188
- </label>
189
- <input
190
- type="number"
191
- value={field.validation?.maxLength || ''}
192
- onChange={(e) => handleUpdateField(field.id, {
193
- validation: { ...field.validation, maxLength: parseInt(e.target.value) || undefined }
194
- })}
195
- className="w-full px-3 py-2 border border-gray-300 rounded-md focus:outline-none focus:ring-2 focus:ring-blue-500"
196
- />
197
- </div>
198
- <div className="md:col-span-2">
199
- <label className="block text-sm font-medium text-gray-700 mb-2">
200
- Pattern (Regex)
201
- </label>
202
- <input
203
- type="text"
204
- value={field.validation?.pattern || ''}
205
- onChange={(e) => handleUpdateField(field.id, {
206
- validation: { ...field.validation, pattern: e.target.value || undefined }
207
- })}
208
- placeholder="^[a-zA-Z0-9]+$"
209
- className="w-full px-3 py-2 border border-gray-300 rounded-md focus:outline-none focus:ring-2 focus:ring-blue-500"
210
- />
211
- </div>
212
- </>
213
- )}
214
- {field.type === 'number' && (
215
- <>
216
- <div>
217
- <label className="block text-sm font-medium text-gray-700 mb-2">
218
- Minimum Value
219
- </label>
220
- <input
221
- type="number"
222
- value={field.validation?.min || ''}
223
- onChange={(e) => handleUpdateField(field.id, {
224
- validation: { ...field.validation, min: parseFloat(e.target.value) || undefined }
225
- })}
226
- className="w-full px-3 py-2 border border-gray-300 rounded-md focus:outline-none focus:ring-2 focus:ring-blue-500"
227
- />
228
- </div>
229
- <div>
230
- <label className="block text-sm font-medium text-gray-700 mb-2">
231
- Maximum Value
232
- </label>
233
- <input
234
- type="number"
235
- value={field.validation?.max || ''}
236
- onChange={(e) => handleUpdateField(field.id, {
237
- validation: { ...field.validation, max: parseFloat(e.target.value) || undefined }
238
- })}
239
- className="w-full px-3 py-2 border border-gray-300 rounded-md focus:outline-none focus:ring-2 focus:ring-blue-500"
240
- />
241
- </div>
242
- </>
243
- )}
244
- </div>
245
- </div>
246
- )}
247
-
248
- <div className="flex justify-end space-x-2">
249
- <Button
250
- variant="outline"
251
- onClick={() => setEditingField(null)}
252
- >
253
- Cancel
254
- </Button>
255
- <Button
256
- onClick={handleSaveField}
257
- disabled={!field.name}
258
- >
259
- Save Field
260
- </Button>
261
- </div>
262
- </div>
263
- </Card>
264
- );
265
- };
266
-
267
- return (
268
- <div className="space-y-4">
269
- <div className="flex justify-between items-center">
270
- <h4 className="font-medium text-gray-900">Schema Fields</h4>
271
- <Button onClick={handleAddField}>Add Field</Button>
272
- </div>
273
-
274
- {schema.length === 0 && (
275
- <div className="text-center py-8 text-gray-500 border-2 border-dashed border-gray-300 rounded-md">
276
- No custom fields defined. Click "Add Field" to create your first field.
277
- </div>
278
- )}
279
-
280
- <div className="space-y-3">
281
- {schema.map((field) => (
282
- <div key={field.id}>
283
- {renderFieldEditor(field)}
284
- </div>
285
- ))}
286
- </div>
287
-
288
- {schema.length > 0 && (
289
- <div className="bg-blue-50 p-4 rounded-md">
290
- <h5 className="font-medium text-blue-900 mb-2">Generated Schema Preview</h5>
291
- <pre className="text-sm text-blue-800 bg-blue-100 p-3 rounded overflow-x-auto">
292
- {schema.map(field => {
293
- const validation = field.validation && Object.keys(field.validation).length > 0 ? `, validation: ${JSON.stringify(field.validation)}` : '';
294
- return ` ${field.name}: { type: '${field.type}', required: ${field.required}${field.encrypted ? ', encrypted: true' : ''}${field.default ? `, default: '${field.default}'` : ''}${validation} }`;
295
- }).join(',\n')}
296
- </pre>
297
- </div>
298
- )}
299
- </div>
300
- );
301
- };
302
-
303
- export default SchemaBuilder;