@friggframework/devtools 2.0.0-next.61 → 2.0.0-next.62
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/package.json +14 -7
- package/.eslintrc.json +0 -3
- package/CHANGELOG.md +0 -132
- package/infrastructure/ARCHITECTURE.md +0 -487
- package/infrastructure/CLAUDE.md +0 -481
- package/infrastructure/HEALTH.md +0 -468
- package/infrastructure/README.md +0 -522
- package/infrastructure/__tests__/fixtures/mock-aws-resources.js +0 -391
- package/infrastructure/__tests__/helpers/test-utils.js +0 -277
- package/infrastructure/__tests__/postgres-config.test.js +0 -914
- package/infrastructure/__tests__/template-generation.test.js +0 -687
- package/infrastructure/create-frigg-infrastructure.js +0 -147
- package/infrastructure/docs/POSTGRES-CONFIGURATION.md +0 -630
- package/infrastructure/docs/PRE-DEPLOYMENT-HEALTH-CHECK-SPEC.md +0 -1317
- package/infrastructure/docs/WEBSOCKET-CONFIGURATION.md +0 -105
- package/infrastructure/docs/deployment-instructions.md +0 -268
- package/infrastructure/docs/generate-iam-command.md +0 -278
- package/infrastructure/docs/iam-policy-templates.md +0 -193
- package/infrastructure/domains/database/aurora-builder.js +0 -809
- package/infrastructure/domains/database/aurora-builder.test.js +0 -950
- package/infrastructure/domains/database/aurora-discovery.js +0 -87
- package/infrastructure/domains/database/aurora-discovery.test.js +0 -188
- package/infrastructure/domains/database/aurora-resolver.js +0 -210
- package/infrastructure/domains/database/aurora-resolver.test.js +0 -347
- package/infrastructure/domains/database/migration-builder.js +0 -701
- package/infrastructure/domains/database/migration-builder.test.js +0 -321
- package/infrastructure/domains/database/migration-resolver.js +0 -163
- package/infrastructure/domains/database/migration-resolver.test.js +0 -337
- package/infrastructure/domains/health/application/ports/IPropertyReconciler.js +0 -164
- package/infrastructure/domains/health/application/ports/IResourceDetector.js +0 -129
- package/infrastructure/domains/health/application/ports/IResourceImporter.js +0 -142
- package/infrastructure/domains/health/application/ports/IStackRepository.js +0 -131
- package/infrastructure/domains/health/application/ports/index.js +0 -26
- package/infrastructure/domains/health/application/use-cases/__tests__/execute-resource-import-use-case.test.js +0 -679
- package/infrastructure/domains/health/application/use-cases/__tests__/mismatch-analyzer-method-name.test.js +0 -167
- package/infrastructure/domains/health/application/use-cases/__tests__/repair-via-import-use-case.test.js +0 -1130
- package/infrastructure/domains/health/application/use-cases/execute-resource-import-use-case.js +0 -221
- package/infrastructure/domains/health/application/use-cases/reconcile-properties-use-case.js +0 -152
- package/infrastructure/domains/health/application/use-cases/reconcile-properties-use-case.test.js +0 -343
- package/infrastructure/domains/health/application/use-cases/repair-via-import-use-case.js +0 -535
- package/infrastructure/domains/health/application/use-cases/repair-via-import-use-case.test.js +0 -376
- package/infrastructure/domains/health/application/use-cases/run-health-check-use-case.js +0 -213
- package/infrastructure/domains/health/application/use-cases/run-health-check-use-case.test.js +0 -441
- package/infrastructure/domains/health/docs/ACME-DEV-DRIFT-ANALYSIS.md +0 -267
- package/infrastructure/domains/health/docs/BUILD-VS-DEPLOYED-TEMPLATE-ANALYSIS.md +0 -324
- package/infrastructure/domains/health/docs/ORPHAN-DETECTION-ANALYSIS.md +0 -386
- package/infrastructure/domains/health/docs/SPEC-CLEANUP-COMMAND.md +0 -1419
- package/infrastructure/domains/health/docs/TDD-IMPLEMENTATION-SUMMARY.md +0 -391
- package/infrastructure/domains/health/docs/TEMPLATE-COMPARISON-IMPLEMENTATION.md +0 -551
- package/infrastructure/domains/health/domain/entities/issue.js +0 -299
- package/infrastructure/domains/health/domain/entities/issue.test.js +0 -528
- package/infrastructure/domains/health/domain/entities/property-mismatch.js +0 -108
- package/infrastructure/domains/health/domain/entities/property-mismatch.test.js +0 -275
- package/infrastructure/domains/health/domain/entities/resource.js +0 -159
- package/infrastructure/domains/health/domain/entities/resource.test.js +0 -432
- package/infrastructure/domains/health/domain/entities/stack-health-report.js +0 -306
- package/infrastructure/domains/health/domain/entities/stack-health-report.test.js +0 -601
- package/infrastructure/domains/health/domain/services/__tests__/health-score-percentage-based.test.js +0 -380
- package/infrastructure/domains/health/domain/services/__tests__/import-progress-monitor.test.js +0 -971
- package/infrastructure/domains/health/domain/services/__tests__/import-template-generator.test.js +0 -1150
- package/infrastructure/domains/health/domain/services/__tests__/logical-id-mapper.test.js +0 -672
- package/infrastructure/domains/health/domain/services/__tests__/template-parser.test.js +0 -496
- package/infrastructure/domains/health/domain/services/__tests__/update-progress-monitor.test.js +0 -419
- package/infrastructure/domains/health/domain/services/health-score-calculator.js +0 -248
- package/infrastructure/domains/health/domain/services/health-score-calculator.test.js +0 -504
- package/infrastructure/domains/health/domain/services/import-progress-monitor.js +0 -195
- package/infrastructure/domains/health/domain/services/import-template-generator.js +0 -435
- package/infrastructure/domains/health/domain/services/logical-id-mapper.js +0 -345
- package/infrastructure/domains/health/domain/services/mismatch-analyzer.js +0 -234
- package/infrastructure/domains/health/domain/services/mismatch-analyzer.test.js +0 -431
- package/infrastructure/domains/health/domain/services/property-mutability-config.js +0 -382
- package/infrastructure/domains/health/domain/services/template-parser.js +0 -245
- package/infrastructure/domains/health/domain/services/update-progress-monitor.js +0 -192
- package/infrastructure/domains/health/domain/value-objects/health-score.js +0 -138
- package/infrastructure/domains/health/domain/value-objects/health-score.test.js +0 -267
- package/infrastructure/domains/health/domain/value-objects/property-mutability.js +0 -161
- package/infrastructure/domains/health/domain/value-objects/property-mutability.test.js +0 -198
- package/infrastructure/domains/health/domain/value-objects/resource-state.js +0 -167
- package/infrastructure/domains/health/domain/value-objects/resource-state.test.js +0 -196
- package/infrastructure/domains/health/domain/value-objects/stack-identifier.js +0 -192
- package/infrastructure/domains/health/domain/value-objects/stack-identifier.test.js +0 -262
- package/infrastructure/domains/health/infrastructure/adapters/__tests__/orphan-detection-cfn-tagged.test.js +0 -312
- package/infrastructure/domains/health/infrastructure/adapters/__tests__/orphan-detection-multi-stack.test.js +0 -367
- package/infrastructure/domains/health/infrastructure/adapters/__tests__/orphan-detection-relationship-analysis.test.js +0 -432
- package/infrastructure/domains/health/infrastructure/adapters/aws-property-reconciler.js +0 -784
- package/infrastructure/domains/health/infrastructure/adapters/aws-property-reconciler.test.js +0 -1133
- package/infrastructure/domains/health/infrastructure/adapters/aws-resource-detector.js +0 -565
- package/infrastructure/domains/health/infrastructure/adapters/aws-resource-detector.test.js +0 -554
- package/infrastructure/domains/health/infrastructure/adapters/aws-resource-importer.js +0 -318
- package/infrastructure/domains/health/infrastructure/adapters/aws-resource-importer.test.js +0 -398
- package/infrastructure/domains/health/infrastructure/adapters/aws-stack-repository.js +0 -777
- package/infrastructure/domains/health/infrastructure/adapters/aws-stack-repository.test.js +0 -580
- package/infrastructure/domains/integration/integration-builder.js +0 -404
- package/infrastructure/domains/integration/integration-builder.test.js +0 -690
- package/infrastructure/domains/integration/integration-resolver.js +0 -170
- package/infrastructure/domains/integration/integration-resolver.test.js +0 -369
- package/infrastructure/domains/integration/websocket-builder.js +0 -69
- package/infrastructure/domains/integration/websocket-builder.test.js +0 -195
- package/infrastructure/domains/networking/vpc-builder.js +0 -2051
- package/infrastructure/domains/networking/vpc-builder.test.js +0 -1960
- package/infrastructure/domains/networking/vpc-discovery.js +0 -177
- package/infrastructure/domains/networking/vpc-discovery.test.js +0 -350
- package/infrastructure/domains/networking/vpc-resolver.js +0 -505
- package/infrastructure/domains/networking/vpc-resolver.test.js +0 -801
- package/infrastructure/domains/parameters/ssm-builder.js +0 -79
- package/infrastructure/domains/parameters/ssm-builder.test.js +0 -189
- package/infrastructure/domains/parameters/ssm-discovery.js +0 -84
- package/infrastructure/domains/parameters/ssm-discovery.test.js +0 -210
- package/infrastructure/domains/security/iam-generator.js +0 -816
- package/infrastructure/domains/security/iam-generator.test.js +0 -204
- package/infrastructure/domains/security/kms-builder.js +0 -415
- package/infrastructure/domains/security/kms-builder.test.js +0 -392
- package/infrastructure/domains/security/kms-discovery.js +0 -80
- package/infrastructure/domains/security/kms-discovery.test.js +0 -177
- package/infrastructure/domains/security/kms-resolver.js +0 -96
- package/infrastructure/domains/security/kms-resolver.test.js +0 -216
- package/infrastructure/domains/security/templates/frigg-deployment-iam-stack.yaml +0 -401
- package/infrastructure/domains/security/templates/iam-policy-basic.json +0 -218
- package/infrastructure/domains/security/templates/iam-policy-full.json +0 -288
- package/infrastructure/domains/shared/base-builder.js +0 -112
- package/infrastructure/domains/shared/base-resolver.js +0 -186
- package/infrastructure/domains/shared/base-resolver.test.js +0 -305
- package/infrastructure/domains/shared/builder-orchestrator.js +0 -212
- package/infrastructure/domains/shared/builder-orchestrator.test.js +0 -213
- package/infrastructure/domains/shared/cloudformation-discovery-v2.js +0 -334
- package/infrastructure/domains/shared/cloudformation-discovery.js +0 -672
- package/infrastructure/domains/shared/cloudformation-discovery.test.js +0 -985
- package/infrastructure/domains/shared/environment-builder.js +0 -119
- package/infrastructure/domains/shared/environment-builder.test.js +0 -247
- package/infrastructure/domains/shared/providers/aws-provider-adapter.js +0 -579
- package/infrastructure/domains/shared/providers/aws-provider-adapter.test.js +0 -416
- package/infrastructure/domains/shared/providers/azure-provider-adapter.stub.js +0 -93
- package/infrastructure/domains/shared/providers/cloud-provider-adapter.js +0 -136
- package/infrastructure/domains/shared/providers/gcp-provider-adapter.stub.js +0 -82
- package/infrastructure/domains/shared/providers/provider-factory.js +0 -108
- package/infrastructure/domains/shared/providers/provider-factory.test.js +0 -170
- package/infrastructure/domains/shared/resource-discovery.enhanced.test.js +0 -306
- package/infrastructure/domains/shared/resource-discovery.js +0 -233
- package/infrastructure/domains/shared/resource-discovery.test.js +0 -588
- package/infrastructure/domains/shared/types/app-definition.js +0 -205
- package/infrastructure/domains/shared/types/discovery-result.js +0 -106
- package/infrastructure/domains/shared/types/discovery-result.test.js +0 -258
- package/infrastructure/domains/shared/types/index.js +0 -46
- package/infrastructure/domains/shared/types/resource-ownership.js +0 -108
- package/infrastructure/domains/shared/types/resource-ownership.test.js +0 -101
- package/infrastructure/domains/shared/utilities/base-definition-factory.js +0 -394
- package/infrastructure/domains/shared/utilities/base-definition-factory.js.bak +0 -338
- package/infrastructure/domains/shared/utilities/base-definition-factory.test.js +0 -291
- package/infrastructure/domains/shared/utilities/handler-path-resolver.js +0 -134
- package/infrastructure/domains/shared/utilities/handler-path-resolver.test.js +0 -268
- package/infrastructure/domains/shared/utilities/prisma-layer-manager.js +0 -159
- package/infrastructure/domains/shared/utilities/prisma-layer-manager.test.js +0 -444
- package/infrastructure/domains/shared/validation/env-validator.js +0 -78
- package/infrastructure/domains/shared/validation/env-validator.test.js +0 -173
- package/infrastructure/domains/shared/validation/plugin-validator.js +0 -187
- package/infrastructure/domains/shared/validation/plugin-validator.test.js +0 -323
- package/infrastructure/esbuild.config.js +0 -53
- package/infrastructure/index.js +0 -4
- package/infrastructure/infrastructure-composer.js +0 -117
- package/infrastructure/infrastructure-composer.test.js +0 -1895
- package/infrastructure/integration.test.js +0 -383
- package/infrastructure/scripts/build-prisma-layer.js +0 -701
- package/infrastructure/scripts/build-prisma-layer.test.js +0 -170
- package/infrastructure/scripts/build-time-discovery.js +0 -238
- package/infrastructure/scripts/build-time-discovery.test.js +0 -379
- package/infrastructure/scripts/run-discovery.js +0 -110
- package/infrastructure/scripts/verify-prisma-layer.js +0 -72
- package/layers/prisma/.build-complete +0 -3
- package/layers/prisma/nodejs/package.json +0 -8
- package/management-ui/.eslintrc.js +0 -22
- package/management-ui/components.json +0 -21
- package/management-ui/docs/phase2-integration-guide.md +0 -320
- package/management-ui/index.html +0 -13
- package/management-ui/package.json +0 -76
- package/management-ui/packages/devtools/frigg-cli/ui-command/index.js +0 -302
- package/management-ui/postcss.config.js +0 -6
- package/management-ui/server/api/backend.js +0 -256
- package/management-ui/server/api/cli.js +0 -315
- package/management-ui/server/api/codegen.js +0 -663
- package/management-ui/server/api/connections.js +0 -857
- package/management-ui/server/api/discovery.js +0 -185
- package/management-ui/server/api/environment/index.js +0 -1
- package/management-ui/server/api/environment/router.js +0 -378
- package/management-ui/server/api/environment.js +0 -328
- package/management-ui/server/api/integrations.js +0 -876
- package/management-ui/server/api/logs.js +0 -248
- package/management-ui/server/api/monitoring.js +0 -282
- package/management-ui/server/api/open-ide.js +0 -31
- package/management-ui/server/api/project.js +0 -1029
- package/management-ui/server/api/users/sessions.js +0 -371
- package/management-ui/server/api/users/simulation.js +0 -254
- package/management-ui/server/api/users.js +0 -362
- package/management-ui/server/api-contract.md +0 -275
- package/management-ui/server/index.js +0 -873
- package/management-ui/server/middleware/errorHandler.js +0 -93
- package/management-ui/server/middleware/security.js +0 -32
- package/management-ui/server/processManager.js +0 -296
- package/management-ui/server/server.js +0 -346
- package/management-ui/server/services/aws-monitor.js +0 -413
- package/management-ui/server/services/npm-registry.js +0 -347
- package/management-ui/server/services/template-engine.js +0 -538
- package/management-ui/server/utils/cliIntegration.js +0 -220
- package/management-ui/server/utils/environment/auditLogger.js +0 -471
- package/management-ui/server/utils/environment/awsParameterStore.js +0 -275
- package/management-ui/server/utils/environment/encryption.js +0 -278
- package/management-ui/server/utils/environment/envFileManager.js +0 -286
- package/management-ui/server/utils/import-commonjs.js +0 -28
- package/management-ui/server/utils/response.js +0 -83
- package/management-ui/server/websocket/handler.js +0 -325
- package/management-ui/src/App.jsx +0 -25
- package/management-ui/src/assets/FriggLogo.svg +0 -1
- package/management-ui/src/components/AppRouter.jsx +0 -65
- package/management-ui/src/components/Button.jsx +0 -70
- package/management-ui/src/components/Card.jsx +0 -97
- package/management-ui/src/components/EnvironmentCompare.jsx +0 -400
- package/management-ui/src/components/EnvironmentEditor.jsx +0 -372
- package/management-ui/src/components/EnvironmentImportExport.jsx +0 -469
- package/management-ui/src/components/EnvironmentSchema.jsx +0 -491
- package/management-ui/src/components/EnvironmentSecurity.jsx +0 -463
- package/management-ui/src/components/ErrorBoundary.jsx +0 -73
- package/management-ui/src/components/IntegrationCard.jsx +0 -481
- package/management-ui/src/components/IntegrationCardEnhanced.jsx +0 -770
- package/management-ui/src/components/IntegrationExplorer.jsx +0 -379
- package/management-ui/src/components/IntegrationStatus.jsx +0 -336
- package/management-ui/src/components/Layout.jsx +0 -716
- package/management-ui/src/components/LoadingSpinner.jsx +0 -113
- package/management-ui/src/components/RepositoryPicker.jsx +0 -248
- package/management-ui/src/components/SessionMonitor.jsx +0 -350
- package/management-ui/src/components/StatusBadge.jsx +0 -208
- package/management-ui/src/components/UserContextSwitcher.jsx +0 -212
- package/management-ui/src/components/UserSimulation.jsx +0 -327
- package/management-ui/src/components/Welcome.jsx +0 -434
- package/management-ui/src/components/codegen/APIEndpointGenerator.jsx +0 -637
- package/management-ui/src/components/codegen/APIModuleSelector.jsx +0 -227
- package/management-ui/src/components/codegen/CodeGenerationWizard.jsx +0 -247
- package/management-ui/src/components/codegen/CodePreviewEditor.jsx +0 -316
- package/management-ui/src/components/codegen/DynamicModuleForm.jsx +0 -271
- package/management-ui/src/components/codegen/FormBuilder.jsx +0 -737
- package/management-ui/src/components/codegen/IntegrationGenerator.jsx +0 -855
- package/management-ui/src/components/codegen/ProjectScaffoldWizard.jsx +0 -797
- package/management-ui/src/components/codegen/SchemaBuilder.jsx +0 -303
- package/management-ui/src/components/codegen/TemplateSelector.jsx +0 -586
- package/management-ui/src/components/codegen/index.js +0 -10
- package/management-ui/src/components/connections/ConnectionConfigForm.jsx +0 -362
- package/management-ui/src/components/connections/ConnectionHealthMonitor.jsx +0 -182
- package/management-ui/src/components/connections/ConnectionTester.jsx +0 -200
- package/management-ui/src/components/connections/EntityRelationshipMapper.jsx +0 -292
- package/management-ui/src/components/connections/OAuthFlow.jsx +0 -204
- package/management-ui/src/components/connections/index.js +0 -5
- package/management-ui/src/components/index.js +0 -21
- package/management-ui/src/components/monitoring/APIGatewayMetrics.jsx +0 -222
- package/management-ui/src/components/monitoring/LambdaMetrics.jsx +0 -169
- package/management-ui/src/components/monitoring/MetricsChart.jsx +0 -197
- package/management-ui/src/components/monitoring/MonitoringDashboard.jsx +0 -393
- package/management-ui/src/components/monitoring/SQSMetrics.jsx +0 -246
- package/management-ui/src/components/monitoring/index.js +0 -6
- package/management-ui/src/components/monitoring/monitoring.css +0 -218
- package/management-ui/src/components/theme-provider.jsx +0 -52
- package/management-ui/src/components/theme-toggle.jsx +0 -39
- package/management-ui/src/components/ui/badge.tsx +0 -36
- package/management-ui/src/components/ui/button.test.jsx +0 -56
- package/management-ui/src/components/ui/button.tsx +0 -57
- package/management-ui/src/components/ui/card.tsx +0 -76
- package/management-ui/src/components/ui/dropdown-menu.tsx +0 -199
- package/management-ui/src/components/ui/select.tsx +0 -157
- package/management-ui/src/components/ui/skeleton.jsx +0 -15
- package/management-ui/src/hooks/useFrigg.jsx +0 -387
- package/management-ui/src/hooks/useSocket.jsx +0 -58
- package/management-ui/src/index.css +0 -193
- package/management-ui/src/lib/utils.ts +0 -6
- package/management-ui/src/main.jsx +0 -10
- package/management-ui/src/pages/CodeGeneration.jsx +0 -14
- package/management-ui/src/pages/Connections.jsx +0 -252
- package/management-ui/src/pages/ConnectionsEnhanced.jsx +0 -633
- package/management-ui/src/pages/Dashboard.jsx +0 -311
- package/management-ui/src/pages/Environment.jsx +0 -314
- package/management-ui/src/pages/IntegrationConfigure.jsx +0 -669
- package/management-ui/src/pages/IntegrationDiscovery.jsx +0 -567
- package/management-ui/src/pages/IntegrationTest.jsx +0 -742
- package/management-ui/src/pages/Integrations.jsx +0 -253
- package/management-ui/src/pages/Monitoring.jsx +0 -17
- package/management-ui/src/pages/Simulation.jsx +0 -155
- package/management-ui/src/pages/Users.jsx +0 -492
- package/management-ui/src/services/api.js +0 -41
- package/management-ui/src/services/apiModuleService.js +0 -193
- package/management-ui/src/services/websocket-handlers.js +0 -120
- package/management-ui/src/test/api/project.test.js +0 -273
- package/management-ui/src/test/components/Welcome.test.jsx +0 -378
- package/management-ui/src/test/mocks/server.js +0 -178
- package/management-ui/src/test/setup.js +0 -61
- package/management-ui/src/test/utils/test-utils.jsx +0 -134
- package/management-ui/src/utils/repository.js +0 -98
- package/management-ui/src/utils/repository.test.js +0 -118
- package/management-ui/src/workflows/phase2-integration-workflows.js +0 -884
- package/management-ui/tailwind.config.js +0 -63
- package/management-ui/tsconfig.json +0 -37
- package/management-ui/tsconfig.node.json +0 -10
- package/management-ui/vite.config.js +0 -26
- package/management-ui/vitest.config.js +0 -38
- package/test/auther-definition-method-tester.js +0 -45
- package/test/index.js +0 -9
- package/test/integration-validator.js +0 -2
- package/test/mock-api-readme.md +0 -102
- package/test/mock-api.js +0 -284
- package/test/mock-integration.js +0 -78
|
@@ -1,505 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* VPC Resource Resolver
|
|
3
|
-
*
|
|
4
|
-
* Resolves ownership for all VPC-related resources:
|
|
5
|
-
* - VPC
|
|
6
|
-
* - Security Group
|
|
7
|
-
* - Subnets
|
|
8
|
-
* - NAT Gateway
|
|
9
|
-
* - VPC Endpoints
|
|
10
|
-
*
|
|
11
|
-
* Concrete implementation of BaseResourceResolver for VPC domain.
|
|
12
|
-
*/
|
|
13
|
-
|
|
14
|
-
const BaseResourceResolver = require('../shared/base-resolver');
|
|
15
|
-
const { ResourceOwnership } = require('../shared/types');
|
|
16
|
-
|
|
17
|
-
class VpcResourceResolver extends BaseResourceResolver {
|
|
18
|
-
/**
|
|
19
|
-
* Resolve VPC ownership
|
|
20
|
-
* @param {Object} appDefinition - App definition
|
|
21
|
-
* @param {Object} discovery - Discovery result
|
|
22
|
-
* @returns {Object} Resource decision
|
|
23
|
-
*/
|
|
24
|
-
resolveVpc(appDefinition, discovery) {
|
|
25
|
-
const userIntent = appDefinition.vpc?.ownership?.vpc || 'auto';
|
|
26
|
-
const vpcManagement = appDefinition.vpc?.management; // Legacy config
|
|
27
|
-
|
|
28
|
-
// Explicit external
|
|
29
|
-
if (userIntent === 'external') {
|
|
30
|
-
const externalVpcId = appDefinition.vpc?.external?.vpcId;
|
|
31
|
-
|
|
32
|
-
// If hardcoded ID provided, use it
|
|
33
|
-
if (externalVpcId) {
|
|
34
|
-
return this.createExternalDecision(
|
|
35
|
-
externalVpcId,
|
|
36
|
-
'User specified ownership=external with hardcoded vpcId'
|
|
37
|
-
);
|
|
38
|
-
}
|
|
39
|
-
|
|
40
|
-
// No hardcoded ID - try discovery
|
|
41
|
-
const discoveredVpcId = discovery.defaultVpcId;
|
|
42
|
-
|
|
43
|
-
if (discoveredVpcId) {
|
|
44
|
-
return this.createExternalDecision(
|
|
45
|
-
discoveredVpcId,
|
|
46
|
-
'User specified ownership=external - using discovered VPC'
|
|
47
|
-
);
|
|
48
|
-
}
|
|
49
|
-
|
|
50
|
-
// Discovery found nothing - error
|
|
51
|
-
throw new Error(
|
|
52
|
-
"ownership='external' for VPC requires either:\n" +
|
|
53
|
-
" 1. Hardcoded external.vpcId, OR\n" +
|
|
54
|
-
" 2. A VPC discovered via AWS discovery"
|
|
55
|
-
);
|
|
56
|
-
}
|
|
57
|
-
|
|
58
|
-
// Explicit stack
|
|
59
|
-
if (userIntent === 'stack') {
|
|
60
|
-
const inStack = this.findInStack('FriggVPC', discovery);
|
|
61
|
-
return this.createStackDecision(
|
|
62
|
-
inStack?.physicalId,
|
|
63
|
-
'User specified ownership=stack for VPC'
|
|
64
|
-
);
|
|
65
|
-
}
|
|
66
|
-
|
|
67
|
-
// Auto-decide
|
|
68
|
-
const decision = this.resolveResourceOwnership(
|
|
69
|
-
'auto',
|
|
70
|
-
'FriggVPC',
|
|
71
|
-
'AWS::EC2::VPC',
|
|
72
|
-
discovery
|
|
73
|
-
);
|
|
74
|
-
|
|
75
|
-
// CRITICAL: If auto-resolution wants to create a VPC but management mode is 'discover' (or undefined),
|
|
76
|
-
// throw an error instead. Creating a VPC is expensive and should be explicit.
|
|
77
|
-
if (decision.ownership === ResourceOwnership.STACK &&
|
|
78
|
-
!decision.physicalId &&
|
|
79
|
-
vpcManagement !== 'create-new' &&
|
|
80
|
-
userIntent === 'auto') {
|
|
81
|
-
throw new Error(
|
|
82
|
-
'VPC discovery failed: No VPC found. ' +
|
|
83
|
-
'Either set vpc.management to "create-new" or provide vpc.vpcId with vpc.management "use-existing".'
|
|
84
|
-
);
|
|
85
|
-
}
|
|
86
|
-
|
|
87
|
-
return decision;
|
|
88
|
-
}
|
|
89
|
-
|
|
90
|
-
/**
|
|
91
|
-
* Resolve Security Group ownership
|
|
92
|
-
*
|
|
93
|
-
* Logic:
|
|
94
|
-
* - If FriggLambdaSecurityGroup exists in stack → STACK (keep it)
|
|
95
|
-
* - If default SG discovered from VPC → EXTERNAL (use it)
|
|
96
|
-
* - Otherwise → STACK (create FriggLambdaSecurityGroup)
|
|
97
|
-
*
|
|
98
|
-
* @param {Object} appDefinition - App definition
|
|
99
|
-
* @param {Object} discovery - Discovery result
|
|
100
|
-
* @returns {Object} Resource decision
|
|
101
|
-
*/
|
|
102
|
-
resolveSecurityGroup(appDefinition, discovery) {
|
|
103
|
-
const userIntent = appDefinition.vpc?.ownership?.securityGroup || 'auto';
|
|
104
|
-
|
|
105
|
-
// Explicit external
|
|
106
|
-
if (userIntent === 'external') {
|
|
107
|
-
const externalIds = appDefinition.vpc?.external?.securityGroupIds;
|
|
108
|
-
|
|
109
|
-
// If hardcoded IDs provided, use those
|
|
110
|
-
if (externalIds && externalIds.length > 0) {
|
|
111
|
-
return this.createExternalDecision(
|
|
112
|
-
externalIds,
|
|
113
|
-
'User specified ownership=external with hardcoded securityGroupIds'
|
|
114
|
-
);
|
|
115
|
-
}
|
|
116
|
-
|
|
117
|
-
// No hardcoded IDs - try discovery
|
|
118
|
-
const structured = discovery._structured || discovery;
|
|
119
|
-
|
|
120
|
-
// When ownership='external', use ONLY the default SG, not the stack-managed lambda SG
|
|
121
|
-
const lambdaSgId = structured.lambdaSecurityGroupId || discovery.lambdaSecurityGroupId;
|
|
122
|
-
const defaultSgId = structured.defaultSecurityGroupId || discovery.defaultSecurityGroupId;
|
|
123
|
-
|
|
124
|
-
// If we have a default SG AND it's different from the lambda SG, use the default
|
|
125
|
-
if (defaultSgId && defaultSgId !== lambdaSgId) {
|
|
126
|
-
return this.createExternalDecision(
|
|
127
|
-
[defaultSgId],
|
|
128
|
-
'User specified ownership=external - using discovered default security group'
|
|
129
|
-
);
|
|
130
|
-
}
|
|
131
|
-
|
|
132
|
-
// If only defaultSgId exists (no lambdaSgId), use it
|
|
133
|
-
if (defaultSgId && !lambdaSgId) {
|
|
134
|
-
return this.createExternalDecision(
|
|
135
|
-
[defaultSgId],
|
|
136
|
-
'User specified ownership=external - using discovered default security group'
|
|
137
|
-
);
|
|
138
|
-
}
|
|
139
|
-
|
|
140
|
-
// Discovery found nothing - error
|
|
141
|
-
throw new Error(
|
|
142
|
-
"ownership='external' for securityGroup requires either:\n" +
|
|
143
|
-
" 1. Hardcoded external.securityGroupIds array, OR\n" +
|
|
144
|
-
" 2. A default security group discovered via AWS discovery"
|
|
145
|
-
);
|
|
146
|
-
}
|
|
147
|
-
|
|
148
|
-
// Explicit stack - always create FriggLambdaSecurityGroup
|
|
149
|
-
if (userIntent === 'stack') {
|
|
150
|
-
const inStack = this.findInStack('FriggLambdaSecurityGroup', discovery);
|
|
151
|
-
return this.createStackDecision(
|
|
152
|
-
inStack?.physicalId,
|
|
153
|
-
inStack
|
|
154
|
-
? 'Found FriggLambdaSecurityGroup in CloudFormation stack'
|
|
155
|
-
: 'User specified ownership=stack - will create FriggLambdaSecurityGroup'
|
|
156
|
-
);
|
|
157
|
-
}
|
|
158
|
-
|
|
159
|
-
// Auto mode: Check stack first, then check for discovered default SG
|
|
160
|
-
const inStack = this.findInStack('FriggLambdaSecurityGroup', discovery);
|
|
161
|
-
|
|
162
|
-
if (inStack) {
|
|
163
|
-
return this.createStackDecision(
|
|
164
|
-
inStack.physicalId,
|
|
165
|
-
'Found FriggLambdaSecurityGroup in CloudFormation stack - must keep in template'
|
|
166
|
-
);
|
|
167
|
-
}
|
|
168
|
-
|
|
169
|
-
// Also check flat discovery for lambdaSecurityGroupId (from CloudFormation extraction)
|
|
170
|
-
const structured = discovery._structured || discovery;
|
|
171
|
-
const lambdaSgId = structured.lambdaSecurityGroupId || discovery.lambdaSecurityGroupId;
|
|
172
|
-
|
|
173
|
-
if (lambdaSgId) {
|
|
174
|
-
return this.createStackDecision(
|
|
175
|
-
lambdaSgId,
|
|
176
|
-
'Found FriggLambdaSecurityGroup in CloudFormation stack - must keep in template'
|
|
177
|
-
);
|
|
178
|
-
}
|
|
179
|
-
|
|
180
|
-
// Check for discovered default security group (from external VPC pattern)
|
|
181
|
-
const defaultSgId = structured.defaultSecurityGroupId || discovery.defaultSecurityGroupId;
|
|
182
|
-
|
|
183
|
-
if (defaultSgId) {
|
|
184
|
-
return this.createExternalDecision(
|
|
185
|
-
[defaultSgId],
|
|
186
|
-
'Found default security group via discovery - will reuse (matches canary behavior)'
|
|
187
|
-
);
|
|
188
|
-
}
|
|
189
|
-
|
|
190
|
-
// No SG found anywhere - create new FriggLambdaSecurityGroup
|
|
191
|
-
return this.createStackDecision(
|
|
192
|
-
null,
|
|
193
|
-
'No security group found - will create FriggLambdaSecurityGroup in stack'
|
|
194
|
-
);
|
|
195
|
-
}
|
|
196
|
-
|
|
197
|
-
/**
|
|
198
|
-
* Resolve Subnets ownership
|
|
199
|
-
* @param {Object} appDefinition - App definition
|
|
200
|
-
* @param {Object} discovery - Discovery result
|
|
201
|
-
* @returns {Object} Resource decision
|
|
202
|
-
*/
|
|
203
|
-
resolveSubnets(appDefinition, discovery) {
|
|
204
|
-
const userIntent = appDefinition.vpc?.ownership?.subnets || 'auto';
|
|
205
|
-
|
|
206
|
-
// Explicit external
|
|
207
|
-
if (userIntent === 'external') {
|
|
208
|
-
const externalSubnetIds = appDefinition.vpc?.external?.subnetIds;
|
|
209
|
-
|
|
210
|
-
// If hardcoded IDs provided, use those
|
|
211
|
-
if (externalSubnetIds && externalSubnetIds.length >= 2) {
|
|
212
|
-
return this.createExternalDecision(
|
|
213
|
-
externalSubnetIds,
|
|
214
|
-
'User specified ownership=external with hardcoded subnetIds'
|
|
215
|
-
);
|
|
216
|
-
}
|
|
217
|
-
|
|
218
|
-
// No hardcoded IDs - try discovery
|
|
219
|
-
const discoveredSubnet1 = discovery.privateSubnetId1;
|
|
220
|
-
const discoveredSubnet2 = discovery.privateSubnetId2;
|
|
221
|
-
|
|
222
|
-
if (discoveredSubnet1 && discoveredSubnet2) {
|
|
223
|
-
return this.createExternalDecision(
|
|
224
|
-
[discoveredSubnet1, discoveredSubnet2],
|
|
225
|
-
'User specified ownership=external - using discovered subnets'
|
|
226
|
-
);
|
|
227
|
-
}
|
|
228
|
-
|
|
229
|
-
// Discovery found nothing - error
|
|
230
|
-
throw new Error(
|
|
231
|
-
"ownership='external' for subnets requires either:\n" +
|
|
232
|
-
" 1. Hardcoded external.subnetIds array (minimum 2), OR\n" +
|
|
233
|
-
" 2. At least 2 subnets discovered via AWS discovery"
|
|
234
|
-
);
|
|
235
|
-
}
|
|
236
|
-
|
|
237
|
-
// Explicit stack
|
|
238
|
-
if (userIntent === 'stack') {
|
|
239
|
-
// Check if we have subnets in stack
|
|
240
|
-
const subnet1 = this.findInStack('FriggPrivateSubnet1', discovery);
|
|
241
|
-
const subnet2 = this.findInStack('FriggPrivateSubnet2', discovery);
|
|
242
|
-
|
|
243
|
-
if (subnet1 && subnet2) {
|
|
244
|
-
return {
|
|
245
|
-
ownership: ResourceOwnership.STACK,
|
|
246
|
-
physicalIds: [subnet1.physicalId, subnet2.physicalId],
|
|
247
|
-
reason: 'User specified ownership=stack for subnets',
|
|
248
|
-
metadata: {
|
|
249
|
-
subnet1: subnet1.physicalId,
|
|
250
|
-
subnet2: subnet2.physicalId
|
|
251
|
-
}
|
|
252
|
-
};
|
|
253
|
-
}
|
|
254
|
-
|
|
255
|
-
return this.createStackDecision(
|
|
256
|
-
null,
|
|
257
|
-
'User specified ownership=stack for subnets (will create new)'
|
|
258
|
-
);
|
|
259
|
-
}
|
|
260
|
-
|
|
261
|
-
// Auto-decide
|
|
262
|
-
const subnet1InStack = this.isInStack('FriggPrivateSubnet1', discovery);
|
|
263
|
-
const subnet2InStack = this.isInStack('FriggPrivateSubnet2', discovery);
|
|
264
|
-
|
|
265
|
-
if (subnet1InStack && subnet2InStack) {
|
|
266
|
-
const subnet1 = this.findInStack('FriggPrivateSubnet1', discovery);
|
|
267
|
-
const subnet2 = this.findInStack('FriggPrivateSubnet2', discovery);
|
|
268
|
-
|
|
269
|
-
return {
|
|
270
|
-
ownership: ResourceOwnership.STACK,
|
|
271
|
-
physicalIds: [subnet1.physicalId, subnet2.physicalId],
|
|
272
|
-
reason: 'Found subnets in CloudFormation stack (must keep in template to avoid deletion)',
|
|
273
|
-
metadata: {
|
|
274
|
-
subnet1: subnet1.physicalId,
|
|
275
|
-
subnet2: subnet2.physicalId
|
|
276
|
-
}
|
|
277
|
-
};
|
|
278
|
-
}
|
|
279
|
-
|
|
280
|
-
// Check for external subnets
|
|
281
|
-
const externalSubnets = this.findAllExternalResources(discovery, 'AWS::EC2::Subnet');
|
|
282
|
-
if (externalSubnets.length >= 2) {
|
|
283
|
-
return {
|
|
284
|
-
ownership: ResourceOwnership.EXTERNAL,
|
|
285
|
-
physicalIds: externalSubnets.slice(0, 2).map(s => s.physicalId),
|
|
286
|
-
reason: 'Found external subnets via discovery',
|
|
287
|
-
metadata: {
|
|
288
|
-
count: externalSubnets.length
|
|
289
|
-
}
|
|
290
|
-
};
|
|
291
|
-
}
|
|
292
|
-
|
|
293
|
-
// Create new
|
|
294
|
-
return this.createStackDecision(
|
|
295
|
-
null,
|
|
296
|
-
'No existing subnets found - will create in stack'
|
|
297
|
-
);
|
|
298
|
-
}
|
|
299
|
-
|
|
300
|
-
/**
|
|
301
|
-
* Resolve NAT Gateway ownership
|
|
302
|
-
* @param {Object} appDefinition - App definition
|
|
303
|
-
* @param {Object} discovery - Discovery result
|
|
304
|
-
* @returns {Object} Resource decision
|
|
305
|
-
*/
|
|
306
|
-
resolveNatGateway(appDefinition, discovery) {
|
|
307
|
-
const userIntent = appDefinition.vpc?.ownership?.natGateway || 'auto';
|
|
308
|
-
const natEnabled = appDefinition.vpc?.config?.natGateway?.enable !== false;
|
|
309
|
-
|
|
310
|
-
// If NAT is disabled, return null decision
|
|
311
|
-
if (!natEnabled) {
|
|
312
|
-
return {
|
|
313
|
-
ownership: null,
|
|
314
|
-
reason: 'NAT Gateway disabled in configuration',
|
|
315
|
-
metadata: { disabled: true }
|
|
316
|
-
};
|
|
317
|
-
}
|
|
318
|
-
|
|
319
|
-
// Explicit external
|
|
320
|
-
if (userIntent === 'external') {
|
|
321
|
-
const externalNatId = appDefinition.vpc?.external?.natGatewayId;
|
|
322
|
-
|
|
323
|
-
// If hardcoded ID provided, use it
|
|
324
|
-
if (externalNatId) {
|
|
325
|
-
return this.createExternalDecision(
|
|
326
|
-
externalNatId,
|
|
327
|
-
'User specified ownership=external with hardcoded natGatewayId'
|
|
328
|
-
);
|
|
329
|
-
}
|
|
330
|
-
|
|
331
|
-
// No hardcoded ID - try discovery
|
|
332
|
-
const discoveredNatId = discovery.natGatewayId;
|
|
333
|
-
|
|
334
|
-
if (discoveredNatId) {
|
|
335
|
-
return this.createExternalDecision(
|
|
336
|
-
discoveredNatId,
|
|
337
|
-
'User specified ownership=external - using discovered NAT gateway'
|
|
338
|
-
);
|
|
339
|
-
}
|
|
340
|
-
|
|
341
|
-
// Discovery found nothing - error
|
|
342
|
-
throw new Error(
|
|
343
|
-
"ownership='external' for NAT gateway requires either:\n" +
|
|
344
|
-
" 1. Hardcoded external.natGatewayId, OR\n" +
|
|
345
|
-
" 2. A NAT gateway discovered via AWS discovery"
|
|
346
|
-
);
|
|
347
|
-
}
|
|
348
|
-
|
|
349
|
-
// Explicit stack
|
|
350
|
-
if (userIntent === 'stack') {
|
|
351
|
-
const inStack = this.findInStack('FriggNatGateway', discovery);
|
|
352
|
-
return this.createStackDecision(
|
|
353
|
-
inStack?.physicalId,
|
|
354
|
-
'User specified ownership=stack for NAT gateway'
|
|
355
|
-
);
|
|
356
|
-
}
|
|
357
|
-
|
|
358
|
-
// Auto-decide
|
|
359
|
-
return this.resolveResourceOwnership(
|
|
360
|
-
'auto',
|
|
361
|
-
'FriggNatGateway',
|
|
362
|
-
'AWS::EC2::NatGateway',
|
|
363
|
-
discovery
|
|
364
|
-
);
|
|
365
|
-
}
|
|
366
|
-
|
|
367
|
-
/**
|
|
368
|
-
* Resolve VPC Endpoints ownership
|
|
369
|
-
* @param {Object} appDefinition - App definition
|
|
370
|
-
* @param {Object} discovery - Discovery result
|
|
371
|
-
* @returns {Object} Resource decision for each endpoint type
|
|
372
|
-
*/
|
|
373
|
-
resolveVpcEndpoints(appDefinition, discovery) {
|
|
374
|
-
const userIntent = appDefinition.vpc?.ownership?.vpcEndpoints || 'auto';
|
|
375
|
-
const endpointsEnabled = appDefinition.vpc?.config?.enableVpcEndpoints !== false;
|
|
376
|
-
|
|
377
|
-
// If endpoints disabled, return null decision
|
|
378
|
-
if (!endpointsEnabled) {
|
|
379
|
-
return {
|
|
380
|
-
s3: { ownership: null, reason: 'VPC Endpoints disabled' },
|
|
381
|
-
dynamodb: { ownership: null, reason: 'VPC Endpoints disabled' },
|
|
382
|
-
kms: { ownership: null, reason: 'VPC Endpoints disabled' },
|
|
383
|
-
secretsManager: { ownership: null, reason: 'VPC Endpoints disabled' },
|
|
384
|
-
sqs: { ownership: null, reason: 'VPC Endpoints disabled' }
|
|
385
|
-
};
|
|
386
|
-
}
|
|
387
|
-
|
|
388
|
-
// KMS endpoint only needed if encryption method is KMS
|
|
389
|
-
const encryptionMethod = appDefinition.encryption?.fieldLevelEncryptionMethod;
|
|
390
|
-
const needsKms = encryptionMethod === 'kms';
|
|
391
|
-
|
|
392
|
-
// DynamoDB endpoint only needed if using DynamoDB (not MongoDB or PostgreSQL)
|
|
393
|
-
// Currently framework only supports MongoDB (via Prisma) and PostgreSQL (via Aurora)
|
|
394
|
-
// If not using DynamoDB, skip the endpoint (CloudFormation will delete if it exists)
|
|
395
|
-
const usesDynamoDB = appDefinition.database?.dynamodb?.enable === true;
|
|
396
|
-
|
|
397
|
-
const endpoints = {
|
|
398
|
-
s3: this._resolveEndpoint('FriggS3VPCEndpoint', 's3', userIntent, appDefinition, discovery),
|
|
399
|
-
dynamodb: usesDynamoDB
|
|
400
|
-
? this._resolveEndpoint('FriggDynamoDBVPCEndpoint', 'dynamodb', userIntent, appDefinition, discovery)
|
|
401
|
-
: { ownership: null, reason: 'DynamoDB endpoint not needed (application uses MongoDB/PostgreSQL, not DynamoDB)' },
|
|
402
|
-
kms: needsKms
|
|
403
|
-
? this._resolveEndpoint('FriggKMSVPCEndpoint', 'kms', userIntent, appDefinition, discovery)
|
|
404
|
-
: { ownership: null, reason: 'KMS endpoint not needed (encryption method is not KMS)' },
|
|
405
|
-
secretsManager: this._resolveEndpoint('FriggSecretsManagerVPCEndpoint', 'secretsManager', userIntent, appDefinition, discovery),
|
|
406
|
-
sqs: this._resolveEndpoint('FriggSQSVPCEndpoint', 'sqs', userIntent, appDefinition, discovery)
|
|
407
|
-
};
|
|
408
|
-
|
|
409
|
-
return endpoints;
|
|
410
|
-
}
|
|
411
|
-
|
|
412
|
-
/**
|
|
413
|
-
* Resolve individual VPC endpoint
|
|
414
|
-
* Checks both old and new logical ID patterns for backwards compatibility
|
|
415
|
-
* @private
|
|
416
|
-
*/
|
|
417
|
-
_resolveEndpoint(logicalId, endpointType, userIntent, appDefinition, discovery) {
|
|
418
|
-
// Map of old logical IDs (for backwards compatibility with stacks created before naming standardization)
|
|
419
|
-
const oldLogicalIdMap = {
|
|
420
|
-
'FriggS3VPCEndpoint': 'VPCEndpointS3',
|
|
421
|
-
'FriggDynamoDBVPCEndpoint': 'VPCEndpointDynamoDB',
|
|
422
|
-
'FriggKMSVPCEndpoint': 'VPCEndpointKMS',
|
|
423
|
-
'FriggSecretsManagerVPCEndpoint': 'VPCEndpointSecretsManager',
|
|
424
|
-
'FriggSQSVPCEndpoint': 'VPCEndpointSQS'
|
|
425
|
-
};
|
|
426
|
-
const oldLogicalId = oldLogicalIdMap[logicalId];
|
|
427
|
-
|
|
428
|
-
// Explicit external
|
|
429
|
-
if (userIntent === 'external') {
|
|
430
|
-
const externalId = appDefinition.vpc?.external?.vpcEndpointIds?.[endpointType];
|
|
431
|
-
if (externalId) {
|
|
432
|
-
return this.createExternalDecision(
|
|
433
|
-
externalId,
|
|
434
|
-
`User specified ownership=external for ${endpointType} endpoint`
|
|
435
|
-
);
|
|
436
|
-
}
|
|
437
|
-
// User said external but didn't provide ID - skip this endpoint
|
|
438
|
-
return { ownership: null, reason: `External ${endpointType} endpoint ID not provided` };
|
|
439
|
-
}
|
|
440
|
-
|
|
441
|
-
// Explicit stack - check both old and new logical IDs
|
|
442
|
-
if (userIntent === 'stack') {
|
|
443
|
-
let inStack = this.findInStack(logicalId, discovery);
|
|
444
|
-
if (!inStack && oldLogicalId) {
|
|
445
|
-
inStack = this.findInStack(oldLogicalId, discovery);
|
|
446
|
-
}
|
|
447
|
-
return this.createStackDecision(
|
|
448
|
-
inStack?.physicalId,
|
|
449
|
-
`User specified ownership=stack for ${endpointType} endpoint`
|
|
450
|
-
);
|
|
451
|
-
}
|
|
452
|
-
|
|
453
|
-
// Auto-decide - check if in stack first (try both old and new logical IDs)
|
|
454
|
-
let inStack = this.isInStack(logicalId, discovery);
|
|
455
|
-
let stackResource = inStack ? this.findInStack(logicalId, discovery) : null;
|
|
456
|
-
let actualLogicalId = logicalId; // Track which ID we found
|
|
457
|
-
|
|
458
|
-
// If not found with new ID, try old ID pattern
|
|
459
|
-
if (!inStack && oldLogicalId) {
|
|
460
|
-
inStack = this.isInStack(oldLogicalId, discovery);
|
|
461
|
-
stackResource = inStack ? this.findInStack(oldLogicalId, discovery) : null;
|
|
462
|
-
if (inStack) {
|
|
463
|
-
actualLogicalId = oldLogicalId; // Found with old ID - use that for resolution
|
|
464
|
-
}
|
|
465
|
-
}
|
|
466
|
-
|
|
467
|
-
const decision = this.resolveResourceOwnership(
|
|
468
|
-
'auto',
|
|
469
|
-
actualLogicalId, // Use the actual ID we found (old or new)
|
|
470
|
-
'AWS::EC2::VPCEndpoint',
|
|
471
|
-
discovery
|
|
472
|
-
);
|
|
473
|
-
|
|
474
|
-
// Override reason with more detailed explanation
|
|
475
|
-
if (decision.ownership === 'stack' && decision.physicalId) {
|
|
476
|
-
decision.reason = `Found in CloudFormation stack (must keep in template to avoid deletion)`;
|
|
477
|
-
} else if (decision.ownership === 'stack' && !decision.physicalId) {
|
|
478
|
-
decision.reason = `No existing ${endpointType} endpoint found - will create in stack`;
|
|
479
|
-
} else if (decision.ownership === 'external') {
|
|
480
|
-
decision.reason = `Found external ${endpointType} endpoint via discovery`;
|
|
481
|
-
}
|
|
482
|
-
|
|
483
|
-
return decision;
|
|
484
|
-
}
|
|
485
|
-
|
|
486
|
-
/**
|
|
487
|
-
* Resolve all VPC resources at once
|
|
488
|
-
* Convenience method that returns decisions for all VPC resources
|
|
489
|
-
*
|
|
490
|
-
* @param {Object} appDefinition - App definition
|
|
491
|
-
* @param {Object} discovery - Discovery result
|
|
492
|
-
* @returns {Object} Decisions for all VPC resources
|
|
493
|
-
*/
|
|
494
|
-
resolveAll(appDefinition, discovery) {
|
|
495
|
-
return {
|
|
496
|
-
vpc: this.resolveVpc(appDefinition, discovery),
|
|
497
|
-
securityGroup: this.resolveSecurityGroup(appDefinition, discovery),
|
|
498
|
-
subnets: this.resolveSubnets(appDefinition, discovery),
|
|
499
|
-
natGateway: this.resolveNatGateway(appDefinition, discovery),
|
|
500
|
-
vpcEndpoints: this.resolveVpcEndpoints(appDefinition, discovery)
|
|
501
|
-
};
|
|
502
|
-
}
|
|
503
|
-
}
|
|
504
|
-
|
|
505
|
-
module.exports = VpcResourceResolver;
|