pangea 0.0.45 → 0.0.47
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.
- checksums.yaml +4 -4
- data/.claude/skills/pangea-cloud-resource-creation/SKILL.md +169 -0
- data/.claude/skills/pangea-cloud-resource-creation/references/hetzner-volume-example.md +133 -0
- data/.claude/skills/pangea-cloud-resource-creation/references/patterns-antipatterns.md +149 -0
- data/.claude/skills/pangea-cloud-resource-creation/references/resource-templates.md +288 -0
- data/.claude/skills/pangea-cloud-resource-creation/references/tracker-cli.md +77 -0
- data/.claude/skills/pangea-cloud-resource-creation/references/type-system.md +105 -0
- data/.claude/skills/pangea-infrastructure/SKILL.md +300 -0
- data/.claude/skills/pangea-infrastructure/references/kubernetes-integration.md +149 -0
- data/.claude/skills/pangea-infrastructure/references/resource-patterns.md +206 -0
- data/.claude/skills/pangea-infrastructure/references/troubleshooting.md +86 -0
- data/.claude/skills/pangea-infrastructure/references/workflow-examples.md +98 -0
- data/.claude/skills/pangea-refactoring/SKILL.md +478 -0
- data/.claude/skills/pangea-resource-testing/SKILL.md +256 -0
- data/.claude/skills/pangea-rspec-resource-testing/SKILL.md +258 -0
- data/.claude/skills/pangea-rspec-resource-testing/references/cloudflare-zone-example.md +57 -0
- data/.claude/skills/pangea-rspec-resource-testing/references/common-patterns.md +109 -0
- data/.claude/skills/pangea-rspec-resource-testing/references/debugging.md +63 -0
- data/.claude/skills/pangea-rspec-resource-testing/references/integration-tests.md +55 -0
- data/.claude/skills/pangea-rspec-resource-testing/references/synthesis-tests.md +169 -0
- data/.claude/skills/pangea-rspec-resource-testing/references/troubleshooting.md +129 -0
- data/.claude/skills/pangea-rspec-resource-testing/references/type-validation-tests.md +92 -0
- data/.github/workflows/ci.yml +54 -53
- data/.gitignore +6 -1
- data/.rspec_status +17894 -0
- data/AGENT_GUIDE.md +24 -8
- data/CONTRIBUTING.md +35 -35
- data/Gemfile.lock +103 -57
- data/README.md +22 -13
- data/README_backend_configuration.md +16 -9
- data/bin/generate-hetzner-resource +204 -0
- data/bin/hetzner-tracker +280 -0
- data/bin/pangea +13 -0
- data/bin/pangea-compiler +15 -0
- data/bin/pangea-compiler-server +133 -0
- data/docs/KUBERNETES_OPERATOR_PLAN.md +2626 -0
- data/examples/test_simple/pangea.yml +7 -0
- data/examples/test_simple/simple.rb +39 -0
- data/flake.lock +748 -6
- data/flake.nix +501 -29
- data/gemset.nix +115 -104
- data/lib/pangea/agent/analysis.rb +128 -0
- data/lib/pangea/agent/compilation.rb +62 -0
- data/lib/pangea/agent/helpers.rb +29 -0
- data/lib/pangea/agent/listing.rb +108 -0
- data/lib/pangea/agent.rb +13 -349
- data/lib/pangea/architectures/base/architecture_reference/cost.rb +30 -0
- data/lib/pangea/architectures/base/architecture_reference/high_availability.rb +57 -0
- data/lib/pangea/architectures/base/architecture_reference/performance.rb +58 -0
- data/lib/pangea/architectures/base/architecture_reference/security.rb +61 -0
- data/lib/pangea/architectures/base/architecture_reference/validation.rb +46 -0
- data/lib/pangea/architectures/base/architecture_reference.rb +109 -0
- data/lib/pangea/architectures/base/vpc_networking.rb +155 -0
- data/lib/pangea/architectures/base.rb +9 -503
- data/lib/pangea/architectures/examples/architectures/devops_platform.rb +129 -0
- data/lib/pangea/architectures/examples/architectures/ecommerce_platform.rb +104 -0
- data/lib/pangea/architectures/examples/architectures/helpers.rb +47 -0
- data/lib/pangea/architectures/examples/architectures/ml_platform.rb +113 -0
- data/lib/pangea/architectures/examples/architectures/multi_region_saas.rb +95 -0
- data/lib/pangea/architectures/examples/web_application/analytics.rb +108 -0
- data/lib/pangea/architectures/examples/web_application/basic.rb +40 -0
- data/lib/pangea/architectures/examples/web_application/custom_database.rb +86 -0
- data/lib/pangea/architectures/examples/web_application/ecommerce.rb +103 -0
- data/lib/pangea/architectures/examples/web_application/microservices.rb +120 -0
- data/lib/pangea/architectures/examples/web_application/multi_environment.rb +88 -0
- data/lib/pangea/architectures/examples/web_application_examples.rb +7 -571
- data/lib/pangea/architectures/examples.rb +14 -480
- data/lib/pangea/architectures/patterns/data_processing/analytics.rb +70 -0
- data/lib/pangea/architectures/patterns/data_processing/iam_roles.rb +131 -0
- data/lib/pangea/architectures/patterns/data_processing/ingestion.rb +73 -0
- data/lib/pangea/architectures/patterns/data_processing/monitoring.rb +66 -0
- data/lib/pangea/architectures/patterns/data_processing/processing.rb +78 -0
- data/lib/pangea/architectures/patterns/data_processing/security.rb +34 -0
- data/lib/pangea/architectures/patterns/data_processing/storage.rb +74 -0
- data/lib/pangea/architectures/patterns/data_processing/streaming.rb +121 -0
- data/lib/pangea/architectures/patterns/data_processing/types.rb +79 -0
- data/lib/pangea/architectures/patterns/data_processing.rb +51 -619
- data/lib/pangea/architectures/patterns/microservices/helpers.rb +67 -0
- data/lib/pangea/architectures/patterns/microservices/observability.rb +83 -0
- data/lib/pangea/architectures/patterns/microservices/orchestration.rb +67 -0
- data/lib/pangea/architectures/patterns/microservices/platform_security.rb +56 -0
- data/lib/pangea/architectures/patterns/microservices/service.rb +117 -0
- data/lib/pangea/architectures/patterns/microservices/service_mesh.rb +49 -0
- data/lib/pangea/architectures/patterns/microservices/shared_services.rb +90 -0
- data/lib/pangea/architectures/patterns/microservices/types.rb +84 -0
- data/lib/pangea/architectures/patterns/microservices.rb +52 -563
- data/lib/pangea/architectures/patterns/web_application/compute_tier.rb +98 -0
- data/lib/pangea/architectures/patterns/web_application/database_tier.rb +76 -0
- data/lib/pangea/architectures/patterns/web_application/load_balancer_tier.rb +81 -0
- data/lib/pangea/architectures/patterns/web_application/monitoring_tier.rb +97 -0
- data/lib/pangea/architectures/patterns/web_application/security_tier.rb +76 -0
- data/lib/pangea/architectures/patterns/web_application/storage_tier.rb +58 -0
- data/lib/pangea/architectures/patterns/web_application/types.rb +99 -0
- data/lib/pangea/architectures/patterns/web_application/user_data.rb +107 -0
- data/lib/pangea/architectures/patterns/web_application.rb +46 -507
- data/lib/pangea/architectures/types/base_types.rb +58 -0
- data/lib/pangea/architectures/types/config_schemas.rb +112 -0
- data/lib/pangea/architectures/types/defaults.rb +62 -0
- data/lib/pangea/architectures/types/validators.rb +110 -0
- data/lib/pangea/architectures/types.rb +17 -257
- data/lib/pangea/architectures/web_application_architecture/architecture/component_creation.rb +146 -0
- data/lib/pangea/architectures/web_application_architecture/architecture/cost_estimation.rb +71 -0
- data/lib/pangea/architectures/web_application_architecture/architecture/fallback_resources.rb +63 -0
- data/lib/pangea/architectures/web_application_architecture/architecture/helpers.rb +50 -0
- data/lib/pangea/architectures/web_application_architecture/architecture/outputs.rb +73 -0
- data/lib/pangea/architectures/web_application_architecture/architecture/resource_creation.rb +54 -0
- data/lib/pangea/architectures/web_application_architecture/architecture.rb +18 -454
- data/lib/pangea/architectures/web_application_architecture/types/cost_estimation.rb +88 -0
- data/lib/pangea/architectures/web_application_architecture/types/defaults.rb +90 -0
- data/lib/pangea/architectures/web_application_architecture/types/input_schema.rb +91 -0
- data/lib/pangea/architectures/web_application_architecture/types/output_schema.rb +49 -0
- data/lib/pangea/architectures/web_application_architecture/types/validation.rb +81 -0
- data/lib/pangea/architectures/web_application_architecture/types.rb +35 -260
- data/lib/pangea/backends/local.rb +2 -2
- data/lib/pangea/backends/s3/dynamodb_lock.rb +115 -0
- data/lib/pangea/backends/s3.rb +47 -131
- data/lib/pangea/cli/application/command_router.rb +129 -0
- data/lib/pangea/cli/application/options.rb +128 -0
- data/lib/pangea/cli/application.rb +55 -156
- data/lib/pangea/cli/commands/agent/analysis.rb +107 -0
- data/lib/pangea/cli/commands/agent/complexity.rb +67 -0
- data/lib/pangea/cli/commands/agent/cost.rb +59 -0
- data/lib/pangea/cli/commands/agent/dependencies.rb +63 -0
- data/lib/pangea/cli/commands/agent/explanation.rb +81 -0
- data/lib/pangea/cli/commands/agent/security.rb +69 -0
- data/lib/pangea/cli/commands/agent/suggestions.rb +55 -0
- data/lib/pangea/cli/commands/agent/validation.rb +77 -0
- data/lib/pangea/cli/commands/agent.rb +36 -560
- data/lib/pangea/cli/commands/apply.rb +93 -185
- data/lib/pangea/cli/commands/base_command.rb +5 -0
- data/lib/pangea/cli/commands/destroy.rb +130 -62
- data/lib/pangea/cli/commands/enhanced_plan/metrics.rb +53 -0
- data/lib/pangea/cli/commands/enhanced_plan/plan_generation.rb +93 -0
- data/lib/pangea/cli/commands/enhanced_plan/template_operations.rb +106 -0
- data/lib/pangea/cli/commands/enhanced_plan.rb +63 -0
- data/lib/pangea/cli/commands/import/import_command_generator.rb +71 -0
- data/lib/pangea/cli/commands/import/resource_analyzer.rb +72 -0
- data/lib/pangea/cli/commands/import.rb +180 -0
- data/lib/pangea/cli/commands/init.rb +100 -0
- data/lib/pangea/cli/commands/inspect/config_inspection.rb +130 -0
- data/lib/pangea/cli/commands/inspect/resource_inspection.rb +105 -0
- data/lib/pangea/cli/commands/inspect/template_analysis.rb +124 -0
- data/lib/pangea/cli/commands/inspect.rb +30 -372
- data/lib/pangea/cli/commands/plan/json_analysis.rb +179 -0
- data/lib/pangea/cli/commands/plan/json_formatting.rb +53 -0
- data/lib/pangea/cli/commands/plan/plan_output.rb +152 -0
- data/lib/pangea/cli/commands/plan/resource_display.rb +98 -0
- data/lib/pangea/cli/commands/plan.rb +81 -138
- data/lib/pangea/cli/commands/sync.rb +110 -0
- data/lib/pangea/cli/commands/template_processor.rb +116 -0
- data/lib/pangea/cli/commands/workspace_operations.rb +154 -0
- data/lib/pangea/cli/error_handler.rb +169 -0
- data/lib/pangea/cli/errors.rb +57 -0
- data/lib/pangea/cli/ui/README.md +255 -0
- data/lib/pangea/cli/ui/banner/operation_summary.rb +120 -0
- data/lib/pangea/cli/ui/banner.rb +179 -0
- data/lib/pangea/cli/ui/command_display/cost_estimation.rb +82 -0
- data/lib/pangea/cli/ui/command_display/state_display.rb +116 -0
- data/lib/pangea/cli/ui/command_display/value_formatters.rb +68 -0
- data/lib/pangea/cli/ui/command_display.rb +147 -0
- data/lib/pangea/cli/ui/diff/formatting.rb +65 -0
- data/lib/pangea/cli/ui/diff/plan_parser.rb +84 -0
- data/lib/pangea/cli/ui/diff.rb +115 -202
- data/lib/pangea/cli/ui/logger/display_helpers.rb +98 -0
- data/lib/pangea/cli/ui/logger/info_panels.rb +99 -0
- data/lib/pangea/cli/ui/logger/resource_display.rb +66 -0
- data/lib/pangea/cli/ui/logger/styles.rb +63 -0
- data/lib/pangea/cli/ui/logger.rb +47 -122
- data/lib/pangea/cli/ui/output_formatter/constants.rb +28 -0
- data/lib/pangea/cli/ui/output_formatter/display.rb +156 -0
- data/lib/pangea/cli/ui/output_formatter/formatting.rb +44 -0
- data/lib/pangea/cli/ui/output_formatter.rb +28 -0
- data/lib/pangea/cli/ui/plan_display/action_group_display.rb +101 -0
- data/lib/pangea/cli/ui/plan_display.rb +150 -0
- data/lib/pangea/cli/ui/progress/animations.rb +69 -0
- data/lib/pangea/cli/ui/progress/wrappers.rb +111 -0
- data/lib/pangea/cli/ui/progress.rb +15 -153
- data/lib/pangea/cli/ui/spinner.rb +102 -10
- data/lib/pangea/cli/ui/table/formatters.rb +141 -0
- data/lib/pangea/cli/ui/table.rb +88 -11
- data/lib/pangea/cli/ui/template_display/resource_extractor.rb +109 -0
- data/lib/pangea/cli/ui/template_display.rb +185 -0
- data/lib/pangea/cli/ui/visualizer/cost.rb +37 -0
- data/lib/pangea/cli/ui/visualizer/display.rb +98 -0
- data/lib/pangea/cli/ui/visualizer/graph.rb +94 -0
- data/lib/pangea/cli/ui/visualizer/statistics.rb +58 -0
- data/lib/pangea/cli/ui/visualizer.rb +41 -270
- data/lib/pangea/compilation/backend_injector.rb +78 -0
- data/lib/pangea/compilation/compilation_helpers.rb +136 -0
- data/lib/pangea/compilation/template_compiler.rb +56 -317
- data/lib/pangea/compilation/template_extractor.rb +81 -0
- data/lib/pangea/compilation/template_validator.rb +88 -0
- data/lib/pangea/compiler_server.rb +133 -0
- data/lib/pangea/components/api_gateway_microservices/component.rb +79 -584
- data/lib/pangea/components/api_gateway_microservices/cors.rb +94 -0
- data/lib/pangea/components/api_gateway_microservices/deployment.rb +102 -0
- data/lib/pangea/components/api_gateway_microservices/helpers.rb +104 -0
- data/lib/pangea/components/api_gateway_microservices/methods.rb +111 -0
- data/lib/pangea/components/api_gateway_microservices/monitoring.rb +77 -0
- data/lib/pangea/components/api_gateway_microservices/rate_limiting.rb +75 -0
- data/lib/pangea/components/api_gateway_microservices/resources.rb +155 -0
- data/lib/pangea/components/api_gateway_microservices/types/core.rb +63 -0
- data/lib/pangea/components/api_gateway_microservices/types/endpoint.rb +53 -0
- data/lib/pangea/components/api_gateway_microservices/types/policy.rb +59 -0
- data/lib/pangea/components/api_gateway_microservices/types.rb +83 -176
- data/lib/pangea/components/application_load_balancer/component.rb +81 -264
- data/lib/pangea/components/application_load_balancer/listeners.rb +139 -0
- data/lib/pangea/components/application_load_balancer/monitoring.rb +93 -0
- data/lib/pangea/components/application_load_balancer/target_groups.rb +101 -0
- data/lib/pangea/components/auto_scaling_web_servers/component/launch_template.rb +79 -0
- data/lib/pangea/components/auto_scaling_web_servers/component/lifecycle.rb +90 -0
- data/lib/pangea/components/auto_scaling_web_servers/component/scaling_policies.rb +152 -0
- data/lib/pangea/components/auto_scaling_web_servers/component.rb +49 -347
- data/lib/pangea/components/carbon_aware_compute/component.rb +52 -1062
- data/lib/pangea/components/carbon_aware_compute/modules/code_generators/executor_code.rb +137 -0
- data/lib/pangea/components/carbon_aware_compute/modules/code_generators/monitor_code.rb +129 -0
- data/lib/pangea/components/carbon_aware_compute/modules/code_generators/scheduler_code.rb +145 -0
- data/lib/pangea/components/carbon_aware_compute/modules/code_generators.rb +31 -0
- data/lib/pangea/components/carbon_aware_compute/modules/functions.rb +99 -0
- data/lib/pangea/components/carbon_aware_compute/modules/helpers.rb +60 -0
- data/lib/pangea/components/carbon_aware_compute/modules/monitoring.rb +178 -0
- data/lib/pangea/components/carbon_aware_compute/modules/roles.rb +113 -0
- data/lib/pangea/components/carbon_aware_compute/modules/schedules.rb +51 -0
- data/lib/pangea/components/carbon_aware_compute/modules/tables.rb +80 -0
- data/lib/pangea/components/disaster_recovery_pilot_light/component.rb +78 -1514
- data/lib/pangea/components/disaster_recovery_pilot_light/modules/automation.rb +177 -0
- data/lib/pangea/components/disaster_recovery_pilot_light/modules/backup.rb +132 -0
- data/lib/pangea/components/disaster_recovery_pilot_light/modules/code_generators/lambda_code.rb +152 -0
- data/lib/pangea/components/disaster_recovery_pilot_light/modules/code_generators/runbook.rb +86 -0
- data/lib/pangea/components/disaster_recovery_pilot_light/modules/code_generators/workflow.rb +137 -0
- data/lib/pangea/components/disaster_recovery_pilot_light/modules/code_generators.rb +31 -0
- data/lib/pangea/components/disaster_recovery_pilot_light/modules/compliance.rb +86 -0
- data/lib/pangea/components/disaster_recovery_pilot_light/modules/dr_region.rb +167 -0
- data/lib/pangea/components/disaster_recovery_pilot_light/modules/helpers.rb +164 -0
- data/lib/pangea/components/disaster_recovery_pilot_light/modules/monitoring/alarms.rb +79 -0
- data/lib/pangea/components/disaster_recovery_pilot_light/modules/monitoring/dashboards.rb +167 -0
- data/lib/pangea/components/disaster_recovery_pilot_light/modules/monitoring.rb +55 -0
- data/lib/pangea/components/disaster_recovery_pilot_light/modules/networking.rb +94 -0
- data/lib/pangea/components/disaster_recovery_pilot_light/modules/primary_region.rb +134 -0
- data/lib/pangea/components/disaster_recovery_pilot_light/modules/replication/database.rb +103 -0
- data/lib/pangea/components/disaster_recovery_pilot_light/modules/replication/efs.rb +45 -0
- data/lib/pangea/components/disaster_recovery_pilot_light/modules/replication/s3.rb +120 -0
- data/lib/pangea/components/disaster_recovery_pilot_light/modules/replication.rb +61 -0
- data/lib/pangea/components/disaster_recovery_pilot_light/modules/testing.rb +93 -0
- data/lib/pangea/components/disaster_recovery_pilot_light/types/data_configs.rb +50 -0
- data/lib/pangea/components/disaster_recovery_pilot_light/types/operational_configs.rb +50 -0
- data/lib/pangea/components/disaster_recovery_pilot_light/types/optimization_configs.rb +63 -0
- data/lib/pangea/components/disaster_recovery_pilot_light/types/region_configs.rb +50 -0
- data/lib/pangea/components/disaster_recovery_pilot_light/types.rb +38 -140
- data/lib/pangea/components/event_driven_microservice/api_gateway.rb +25 -0
- data/lib/pangea/components/event_driven_microservice/component.rb +56 -626
- data/lib/pangea/components/event_driven_microservice/event_sources.rb +113 -0
- data/lib/pangea/components/event_driven_microservice/functions.rb +91 -0
- data/lib/pangea/components/event_driven_microservice/helpers.rb +90 -0
- data/lib/pangea/components/event_driven_microservice/iam.rb +117 -0
- data/lib/pangea/components/event_driven_microservice/monitoring.rb +191 -0
- data/lib/pangea/components/event_driven_microservice/storage.rb +126 -0
- data/lib/pangea/components/event_driven_microservice/types/cqrs_config.rb +37 -0
- data/lib/pangea/components/event_driven_microservice/types/event_replay_config.rb +36 -0
- data/lib/pangea/components/event_driven_microservice/types/event_source.rb +42 -0
- data/lib/pangea/components/event_driven_microservice/types/event_store_config.rb +40 -0
- data/lib/pangea/components/event_driven_microservice/types/function_config.rb +40 -0
- data/lib/pangea/components/event_driven_microservice/types/monitoring_config.rb +37 -0
- data/lib/pangea/components/event_driven_microservice/types/saga_config.rb +37 -0
- data/lib/pangea/components/event_driven_microservice/types.rb +35 -112
- data/lib/pangea/components/examples/enterprise_application.rb +166 -0
- data/lib/pangea/components/examples/three_tier_web_application.rb +159 -0
- data/lib/pangea/components/examples.rb +7 -492
- data/lib/pangea/components/global_service_mesh/component.rb +94 -1271
- data/lib/pangea/components/global_service_mesh/modules/connectivity.rb +133 -0
- data/lib/pangea/components/global_service_mesh/modules/gateways.rb +197 -0
- data/lib/pangea/components/global_service_mesh/modules/helpers.rb +172 -0
- data/lib/pangea/components/global_service_mesh/modules/mesh_components.rb +126 -0
- data/lib/pangea/components/global_service_mesh/modules/observability.rb +106 -0
- data/lib/pangea/components/global_service_mesh/modules/regional_mesh.rb +109 -0
- data/lib/pangea/components/global_service_mesh/modules/resilience.rb +116 -0
- data/lib/pangea/components/global_service_mesh/modules/security.rb +125 -0
- data/lib/pangea/components/global_service_mesh/types/infrastructure_types.rb +49 -0
- data/lib/pangea/components/global_service_mesh/types/operational_types.rb +49 -0
- data/lib/pangea/components/global_service_mesh/types/policy_types.rb +63 -0
- data/lib/pangea/components/global_service_mesh/types/service_types.rb +52 -0
- data/lib/pangea/components/global_service_mesh/types.rb +59 -206
- data/lib/pangea/components/global_traffic_manager/component.rb +86 -1111
- data/lib/pangea/components/global_traffic_manager/modules/accelerator.rb +112 -0
- data/lib/pangea/components/global_traffic_manager/modules/advanced_routing.rb +85 -0
- data/lib/pangea/components/global_traffic_manager/modules/cloudfront.rb +188 -0
- data/lib/pangea/components/global_traffic_manager/modules/edge_functions.rb +56 -0
- data/lib/pangea/components/global_traffic_manager/modules/health_checks.rb +77 -0
- data/lib/pangea/components/global_traffic_manager/modules/helpers.rb +164 -0
- data/lib/pangea/components/global_traffic_manager/modules/monitoring.rb +180 -0
- data/lib/pangea/components/global_traffic_manager/modules/routing.rb +168 -0
- data/lib/pangea/components/global_traffic_manager/modules/security.rb +152 -0
- data/lib/pangea/components/global_traffic_manager/modules/synthetic.rb +70 -0
- data/lib/pangea/components/global_traffic_manager/types/advanced_routing_config.rb +36 -0
- data/lib/pangea/components/global_traffic_manager/types/cloudfront_config.rb +38 -0
- data/lib/pangea/components/global_traffic_manager/types/endpoint_config.rb +39 -0
- data/lib/pangea/components/global_traffic_manager/types/geo_routing_config.rb +35 -0
- data/lib/pangea/components/global_traffic_manager/types/observability_config.rb +38 -0
- data/lib/pangea/components/global_traffic_manager/types/performance_config.rb +36 -0
- data/lib/pangea/components/global_traffic_manager/types/security_config.rb +38 -0
- data/lib/pangea/components/global_traffic_manager/types/traffic_policy_config.rb +40 -0
- data/lib/pangea/components/global_traffic_manager/types/validators.rb +158 -0
- data/lib/pangea/components/global_traffic_manager/types.rb +27 -223
- data/lib/pangea/components/green_data_lifecycle/component.rb +80 -1343
- data/lib/pangea/components/green_data_lifecycle/modules/code_generators/access_analyzer_code.rb +159 -0
- data/lib/pangea/components/green_data_lifecycle/modules/code_generators/carbon_optimizer_code.rb +170 -0
- data/lib/pangea/components/green_data_lifecycle/modules/code_generators/lifecycle_manager_code.rb +169 -0
- data/lib/pangea/components/green_data_lifecycle/modules/code_generators.rb +31 -0
- data/lib/pangea/components/green_data_lifecycle/modules/functions.rb +97 -0
- data/lib/pangea/components/green_data_lifecycle/modules/glacier.rb +58 -0
- data/lib/pangea/components/green_data_lifecycle/modules/helpers.rb +40 -0
- data/lib/pangea/components/green_data_lifecycle/modules/inventory.rb +57 -0
- data/lib/pangea/components/green_data_lifecycle/modules/lifecycle.rb +158 -0
- data/lib/pangea/components/green_data_lifecycle/modules/monitoring.rb +180 -0
- data/lib/pangea/components/green_data_lifecycle/modules/roles.rb +107 -0
- data/lib/pangea/components/green_data_lifecycle/modules/storage.rb +47 -0
- data/lib/pangea/components/microservice_deployment/component/autoscaling.rb +67 -0
- data/lib/pangea/components/microservice_deployment/component/container_definitions.rb +73 -0
- data/lib/pangea/components/microservice_deployment/component/logging.rb +28 -0
- data/lib/pangea/components/microservice_deployment/component/monitoring.rb +66 -0
- data/lib/pangea/components/microservice_deployment/component/outputs.rb +66 -0
- data/lib/pangea/components/microservice_deployment/component/service.rb +87 -0
- data/lib/pangea/components/microservice_deployment/component.rb +41 -419
- data/lib/pangea/components/microservice_deployment/types/auto_scaling_config.rb +36 -0
- data/lib/pangea/components/microservice_deployment/types/circuit_breaker_config.rb +33 -0
- data/lib/pangea/components/microservice_deployment/types/container_definition.rb +43 -0
- data/lib/pangea/components/microservice_deployment/types/health_check_config.rb +35 -0
- data/lib/pangea/components/microservice_deployment/types/service_discovery_config.rb +41 -0
- data/lib/pangea/components/microservice_deployment/types/tracing_config.rb +34 -0
- data/lib/pangea/components/microservice_deployment/types.rb +75 -146
- data/lib/pangea/components/microservices_examples/platform.rb +91 -0
- data/lib/pangea/components/microservices_examples/saga.rb +49 -0
- data/lib/pangea/components/microservices_examples.rb +7 -435
- data/lib/pangea/components/multi_region_active_active/component.rb +110 -1164
- data/lib/pangea/components/multi_region_active_active/modules/applications.rb +117 -0
- data/lib/pangea/components/multi_region_active_active/modules/aurora.rb +121 -0
- data/lib/pangea/components/multi_region_active_active/modules/chaos.rb +103 -0
- data/lib/pangea/components/multi_region_active_active/modules/dynamodb.rb +77 -0
- data/lib/pangea/components/multi_region_active_active/modules/helpers.rb +193 -0
- data/lib/pangea/components/multi_region_active_active/modules/monitoring.rb +113 -0
- data/lib/pangea/components/multi_region_active_active/modules/networking.rb +134 -0
- data/lib/pangea/components/multi_region_active_active/modules/routing.rb +185 -0
- data/lib/pangea/components/multi_region_active_active/types/application_config.rb +38 -0
- data/lib/pangea/components/multi_region_active_active/types/consistency_config.rb +36 -0
- data/lib/pangea/components/multi_region_active_active/types/cost_config.rb +35 -0
- data/lib/pangea/components/multi_region_active_active/types/database_config.rb +37 -0
- data/lib/pangea/components/multi_region_active_active/types/failover_config.rb +37 -0
- data/lib/pangea/components/multi_region_active_active/types/monitoring_config.rb +37 -0
- data/lib/pangea/components/multi_region_active_active/types/region_config.rb +37 -0
- data/lib/pangea/components/multi_region_active_active/types/routing_config.rb +35 -0
- data/lib/pangea/components/multi_region_active_active/types/validators.rb +139 -0
- data/lib/pangea/components/multi_region_active_active/types.rb +28 -192
- data/lib/pangea/components/mysql_database/component/database.rb +167 -0
- data/lib/pangea/components/mysql_database/component/helpers.rb +105 -0
- data/lib/pangea/components/mysql_database/component/monitoring.rb +126 -0
- data/lib/pangea/components/mysql_database/component.rb +33 -295
- data/lib/pangea/components/public_private_subnets/component/outputs.rb +49 -0
- data/lib/pangea/components/public_private_subnets/component/routing/nat_gateways.rb +89 -0
- data/lib/pangea/components/public_private_subnets/component/routing.rb +145 -0
- data/lib/pangea/components/public_private_subnets/component/subnets.rb +70 -0
- data/lib/pangea/components/public_private_subnets/component.rb +47 -341
- data/lib/pangea/components/secure_s3_bucket/component/bucket_config.rb +51 -0
- data/lib/pangea/components/secure_s3_bucket/component/features.rb +75 -0
- data/lib/pangea/components/secure_s3_bucket/component/monitoring.rb +65 -0
- data/lib/pangea/components/secure_s3_bucket/component/outputs.rb +58 -0
- data/lib/pangea/components/secure_s3_bucket/component.rb +39 -421
- data/lib/pangea/components/secure_s3_bucket/types/bucket_configs.rb +51 -0
- data/lib/pangea/components/secure_s3_bucket/types/feature_configs.rb +60 -0
- data/lib/pangea/components/secure_s3_bucket/types/lifecycle_rule.rb +59 -0
- data/lib/pangea/components/secure_s3_bucket/types/monitoring_configs.rb +57 -0
- data/lib/pangea/components/secure_s3_bucket/types.rb +38 -168
- data/lib/pangea/components/service_mesh_observability/alerting.rb +165 -0
- data/lib/pangea/components/service_mesh_observability/anomaly.rb +51 -0
- data/lib/pangea/components/service_mesh_observability/component.rb +50 -567
- data/lib/pangea/components/service_mesh_observability/dashboard.rb +144 -0
- data/lib/pangea/components/service_mesh_observability/helpers.rb +92 -0
- data/lib/pangea/components/service_mesh_observability/logging.rb +73 -0
- data/lib/pangea/components/service_mesh_observability/types/dashboard_widget.rb +35 -0
- data/lib/pangea/components/service_mesh_observability/types/observability_configs.rb +57 -0
- data/lib/pangea/components/service_mesh_observability/types/operational_configs.rb +46 -0
- data/lib/pangea/components/service_mesh_observability/types/service_config.rb +37 -0
- data/lib/pangea/components/service_mesh_observability/types.rb +39 -129
- data/lib/pangea/components/service_mesh_observability/xray.rb +64 -0
- data/lib/pangea/components/siem_security_platform/component.rb +60 -2827
- data/lib/pangea/components/siem_security_platform/modules/helpers.rb +87 -0
- data/lib/pangea/components/siem_security_platform/modules/incident_response/branches.rb +78 -0
- data/lib/pangea/components/siem_security_platform/modules/incident_response/lambdas.rb +200 -0
- data/lib/pangea/components/siem_security_platform/modules/incident_response/state_machine.rb +157 -0
- data/lib/pangea/components/siem_security_platform/modules/incident_response.rb +84 -0
- data/lib/pangea/components/siem_security_platform/modules/ingestion/firehose_config.rb +84 -0
- data/lib/pangea/components/siem_security_platform/modules/ingestion/iam_policies.rb +109 -0
- data/lib/pangea/components/siem_security_platform/modules/ingestion.rb +85 -0
- data/lib/pangea/components/siem_security_platform/modules/integrations.rb +193 -0
- data/lib/pangea/components/siem_security_platform/modules/monitoring.rb +154 -0
- data/lib/pangea/components/siem_security_platform/modules/processing/code_generators.rb +159 -0
- data/lib/pangea/components/siem_security_platform/modules/processing.rb +181 -0
- data/lib/pangea/components/siem_security_platform/modules/security.rb +107 -0
- data/lib/pangea/components/siem_security_platform/modules/storage.rb +197 -0
- data/lib/pangea/components/siem_security_platform/modules/threat_detection.rb +135 -0
- data/lib/pangea/components/siem_security_platform/types/detection_configs.rb +73 -0
- data/lib/pangea/components/siem_security_platform/types/log_collection_configs.rb +55 -0
- data/lib/pangea/components/siem_security_platform/types/opensearch_config.rb +48 -0
- data/lib/pangea/components/siem_security_platform/types/operational_configs.rb +69 -0
- data/lib/pangea/components/siem_security_platform/types/response_configs.rb +68 -0
- data/lib/pangea/components/siem_security_platform/types/security_configs.rb +49 -0
- data/lib/pangea/components/siem_security_platform/types.rb +36 -174
- data/lib/pangea/components/spot_instance_carbon_optimizer/component.rb +54 -1560
- data/lib/pangea/components/spot_instance_carbon_optimizer/modules/code_generators/carbon_monitor.rb +156 -0
- data/lib/pangea/components/spot_instance_carbon_optimizer/modules/code_generators/fleet_optimizer.rb +148 -0
- data/lib/pangea/components/spot_instance_carbon_optimizer/modules/code_generators/migration_orchestrator.rb +200 -0
- data/lib/pangea/components/spot_instance_carbon_optimizer/modules/code_generators.rb +31 -0
- data/lib/pangea/components/spot_instance_carbon_optimizer/modules/fleets.rb +112 -0
- data/lib/pangea/components/spot_instance_carbon_optimizer/modules/functions.rb +103 -0
- data/lib/pangea/components/spot_instance_carbon_optimizer/modules/helpers.rb +97 -0
- data/lib/pangea/components/spot_instance_carbon_optimizer/modules/monitoring.rb +180 -0
- data/lib/pangea/components/spot_instance_carbon_optimizer/modules/roles.rb +114 -0
- data/lib/pangea/components/spot_instance_carbon_optimizer/modules/schedules.rb +68 -0
- data/lib/pangea/components/spot_instance_carbon_optimizer/modules/tables.rb +99 -0
- data/lib/pangea/components/spot_instance_carbon_optimizer/types/enums.rb +51 -0
- data/lib/pangea/components/spot_instance_carbon_optimizer/types/input.rb +109 -0
- data/lib/pangea/components/spot_instance_carbon_optimizer/types/output.rb +68 -0
- data/lib/pangea/components/spot_instance_carbon_optimizer/types.rb +6 -156
- data/lib/pangea/components/sustainable_ml_training/component.rb +52 -1676
- data/lib/pangea/components/sustainable_ml_training/modules/code_generators/carbon_scheduler.rb +151 -0
- data/lib/pangea/components/sustainable_ml_training/modules/code_generators/efficiency_monitor.rb +141 -0
- data/lib/pangea/components/sustainable_ml_training/modules/code_generators/training_optimizer.rb +151 -0
- data/lib/pangea/components/sustainable_ml_training/modules/code_generators.rb +31 -0
- data/lib/pangea/components/sustainable_ml_training/modules/compute.rb +98 -0
- data/lib/pangea/components/sustainable_ml_training/modules/functions.rb +101 -0
- data/lib/pangea/components/sustainable_ml_training/modules/helpers.rb +100 -0
- data/lib/pangea/components/sustainable_ml_training/modules/monitoring.rb +195 -0
- data/lib/pangea/components/sustainable_ml_training/modules/roles.rb +127 -0
- data/lib/pangea/components/sustainable_ml_training/modules/storage.rb +85 -0
- data/lib/pangea/components/sustainable_ml_training/modules/tables.rb +71 -0
- data/lib/pangea/components/sustainable_ml_training/modules/training.rb +83 -0
- data/lib/pangea/components/sustainable_ml_training/types/constants.rb +42 -0
- data/lib/pangea/components/sustainable_ml_training/types/enums.rb +56 -0
- data/lib/pangea/components/sustainable_ml_training/types/validations.rb +63 -0
- data/lib/pangea/components/sustainable_ml_training/types.rb +32 -94
- data/lib/pangea/components/threat_intelligence_platform/types/correlation_rule.rb +38 -0
- data/lib/pangea/components/threat_intelligence_platform/types/enrichment_source.rb +35 -0
- data/lib/pangea/components/threat_intelligence_platform/types/threat_feed.rb +37 -0
- data/lib/pangea/components/threat_intelligence_platform/types/threat_source.rb +48 -0
- data/lib/pangea/components/threat_intelligence_platform/types.rb +23 -69
- data/lib/pangea/components/web_security_group/component.rb +19 -103
- data/lib/pangea/components/web_security_group/rules.rb +136 -0
- data/lib/pangea/components/web_security_group/types/port_methods.rb +58 -0
- data/lib/pangea/components/web_security_group/types/rules_summary.rb +130 -0
- data/lib/pangea/components/web_security_group/types/security_analysis.rb +79 -0
- data/lib/pangea/components/web_security_group/types/validation.rb +67 -0
- data/lib/pangea/components/web_security_group/types.rb +12 -207
- data/lib/pangea/components/web_tier_subnets/component/outputs.rb +70 -0
- data/lib/pangea/components/web_tier_subnets/component.rb +7 -54
- data/lib/pangea/components/zero_trust_network/audit.rb +61 -0
- data/lib/pangea/components/zero_trust_network/compliance.rb +65 -0
- data/lib/pangea/components/zero_trust_network/component.rb +108 -608
- data/lib/pangea/components/zero_trust_network/endpoints.rb +46 -0
- data/lib/pangea/components/zero_trust_network/monitoring.rb +75 -0
- data/lib/pangea/components/zero_trust_network/networking.rb +43 -0
- data/lib/pangea/components/zero_trust_network/policies.rb +70 -0
- data/lib/pangea/components/zero_trust_network/security_automation.rb +130 -0
- data/lib/pangea/components/zero_trust_network/segments.rb +59 -0
- data/lib/pangea/components/zero_trust_network/threat_detection.rb +87 -0
- data/lib/pangea/configuration/config_loader.rb +86 -0
- data/lib/pangea/configuration/defaults.rb +58 -0
- data/lib/pangea/configuration/namespace_manager.rb +95 -0
- data/lib/pangea/configuration/types/backends.rb +95 -0
- data/lib/pangea/configuration/types/base.rb +33 -0
- data/lib/pangea/configuration/types/configuration_schema.rb +105 -0
- data/lib/pangea/configuration/types/settings.rb +56 -0
- data/lib/pangea/configuration/types/state.rb +91 -0
- data/lib/pangea/configuration/types.rb +6 -279
- data/lib/pangea/configuration.rb +28 -167
- data/lib/pangea/entities/namespace.rb +9 -1
- data/lib/pangea/errors.rb +76 -10
- data/lib/pangea/execution/terraform_command_builder.rb +87 -0
- data/lib/pangea/execution/terraform_command_executor.rb +152 -0
- data/lib/pangea/execution/terraform_executor.rb +58 -189
- data/lib/pangea/execution/terraform_operations.rb +91 -0
- data/lib/pangea/execution/terraform_output_parser.rb +129 -0
- data/lib/pangea/execution/terraform_retry.rb +99 -0
- data/lib/pangea/logging/formatters.rb +92 -0
- data/lib/pangea/logging/structured_logger.rb +195 -0
- data/lib/pangea/logging.rb +22 -0
- data/lib/pangea/resources/aws/cloudformation/types/stack_instances_attributes.rb +91 -0
- data/lib/pangea/resources/aws/cloudformation/types/stack_set_attributes.rb +150 -0
- data/lib/pangea/resources/aws/cloudformation/types/stack_set_instance_attributes.rb +96 -0
- data/lib/pangea/resources/aws/cloudformation/types/type_attributes.rb +102 -0
- data/lib/pangea/resources/aws/cloudformation/types.rb +15 -274
- data/lib/pangea/resources/aws/comprehendmedical/jobs/entities_detection_v2_job.rb +58 -0
- data/lib/pangea/resources/aws/comprehendmedical/jobs/icd10_cm_inference_job.rb +58 -0
- data/lib/pangea/resources/aws/comprehendmedical/jobs/job_builder.rb +77 -0
- data/lib/pangea/resources/aws/comprehendmedical/jobs/phi_detection_job.rb +58 -0
- data/lib/pangea/resources/aws/comprehendmedical/jobs/rx_norm_inference_job.rb +58 -0
- data/lib/pangea/resources/aws/comprehendmedical/jobs/snomed_ct_inference_job.rb +58 -0
- data/lib/pangea/resources/aws/comprehendmedical/jobs.rb +14 -290
- data/lib/pangea/resources/aws/ec2/access_control.rb +72 -0
- data/lib/pangea/resources/aws/ec2/account_settings.rb +57 -0
- data/lib/pangea/resources/aws/ec2/capacity.rb +87 -0
- data/lib/pangea/resources/aws/ec2/host.rb +57 -0
- data/lib/pangea/resources/aws/ec2/spot.rb +72 -0
- data/lib/pangea/resources/aws/ec2/transit_gateway_multicast.rb +72 -0
- data/lib/pangea/resources/aws/ec2.rb +25 -256
- data/lib/pangea/resources/aws/elasticache_extended.disabled/reserved_cache_node.rb +1 -1
- data/lib/pangea/resources/aws/elasticache_extended.disabled/serverless_cache.rb +3 -3
- data/lib/pangea/resources/aws/elasticache_extended.disabled/user_group.rb +1 -1
- data/lib/pangea/resources/aws/frauddetector/detector.rb +12 -190
- data/lib/pangea/resources/aws/frauddetector/entity_type.rb +65 -0
- data/lib/pangea/resources/aws/frauddetector/event_type.rb +84 -0
- data/lib/pangea/resources/aws/frauddetector/outcome.rb +66 -0
- data/lib/pangea/resources/aws/frauddetector/variable.rb +77 -0
- data/lib/pangea/resources/aws/gamelift/attributes.rb +104 -0
- data/lib/pangea/resources/aws/gamelift.rb +19 -98
- data/lib/pangea/resources/aws/gamesparks/types.rb +87 -0
- data/lib/pangea/resources/aws/gamesparks.rb +10 -103
- data/lib/pangea/resources/aws/healthlake/fhir_datastore.rb +4 -108
- data/lib/pangea/resources/aws/healthlake/fhir_export_job.rb +76 -0
- data/lib/pangea/resources/aws/healthlake/fhir_import_job.rb +82 -0
- data/lib/pangea/resources/aws/healthlake.rb +4 -0
- data/lib/pangea/resources/aws/load_balancing/classic_elb_dsl.rb +146 -0
- data/lib/pangea/resources/aws/load_balancing/modules/attachments.rb +65 -0
- data/lib/pangea/resources/aws/load_balancing/modules/policies.rb +85 -0
- data/lib/pangea/resources/aws/load_balancing/modules/trust_stores.rb +45 -0
- data/lib/pangea/resources/aws/load_balancing.rb +4 -122
- data/lib/pangea/resources/aws/lookout/equipment/dataset.rb +85 -0
- data/lib/pangea/resources/aws/lookout/equipment/inference_scheduler.rb +103 -0
- data/lib/pangea/resources/aws/lookout/equipment/model.rb +90 -0
- data/lib/pangea/resources/aws/lookout/equipment.rb +7 -197
- data/lib/pangea/resources/aws/opensearch.disabled/package.rb +1 -1
- data/lib/pangea/resources/aws/opensearch.disabled/serverless_collection.rb +1 -1
- data/lib/pangea/resources/aws/sfn_extended.disabled/activity.rb +1 -1
- data/lib/pangea/resources/aws/sumerian/attributes.rb +93 -0
- data/lib/pangea/resources/aws/sumerian.rb +14 -82
- data/lib/pangea/resources/aws/vpc/functions/defaults.rb +87 -0
- data/lib/pangea/resources/aws/vpc/functions/endpoints.rb +102 -0
- data/lib/pangea/resources/aws/vpc.rb +6 -136
- data/lib/pangea/resources/aws_acmpca_certificate_authority/types/attributes.rb +93 -0
- data/lib/pangea/resources/aws_acmpca_certificate_authority/types/helpers.rb +118 -0
- data/lib/pangea/resources/aws_acmpca_certificate_authority/types/templates.rb +140 -0
- data/lib/pangea/resources/aws_acmpca_certificate_authority/types/validators.rb +70 -0
- data/lib/pangea/resources/aws_acmpca_certificate_authority/types.rb +5 -328
- data/lib/pangea/resources/aws_alb_target_group_attachment/types.rb +1 -1
- data/lib/pangea/resources/aws_ami/types.rb +1 -1
- data/lib/pangea/resources/aws_api_gateway_api_key/types/configs.rb +125 -0
- data/lib/pangea/resources/aws_api_gateway_api_key/types.rb +96 -198
- data/lib/pangea/resources/aws_api_gateway_integration/types/factory_methods.rb +99 -0
- data/lib/pangea/resources/aws_api_gateway_integration/types/predicates.rb +57 -0
- data/lib/pangea/resources/aws_api_gateway_integration/types/uri_helpers.rb +58 -0
- data/lib/pangea/resources/aws_api_gateway_integration/types/validators.rb +98 -0
- data/lib/pangea/resources/aws_api_gateway_integration/types.rb +43 -202
- data/lib/pangea/resources/aws_api_gateway_rest_api/types.rb +1 -1
- data/lib/pangea/resources/aws_api_gateway_stage/resource/helpers/basic.rb +67 -0
- data/lib/pangea/resources/aws_api_gateway_stage/resource/helpers/configuration.rb +132 -0
- data/lib/pangea/resources/aws_api_gateway_stage/resource/helpers/method_settings.rb +88 -0
- data/lib/pangea/resources/aws_api_gateway_stage/resource/helpers.rb +47 -0
- data/lib/pangea/resources/aws_api_gateway_stage/resource/main.rb +127 -0
- data/lib/pangea/resources/aws_api_gateway_stage/resource.rb +13 -298
- data/lib/pangea/resources/aws_api_gateway_stage/types/helpers.rb +75 -0
- data/lib/pangea/resources/aws_api_gateway_stage/types/validators.rb +133 -0
- data/lib/pangea/resources/aws_api_gateway_stage/types.rb +36 -143
- data/lib/pangea/resources/aws_api_gateway_usage_plan/types/attributes.rb +64 -0
- data/lib/pangea/resources/aws_api_gateway_usage_plan/types/configs.rb +81 -0
- data/lib/pangea/resources/aws_api_gateway_usage_plan/types/helpers.rb +103 -0
- data/lib/pangea/resources/aws_api_gateway_usage_plan/types/settings.rb +53 -0
- data/lib/pangea/resources/aws_api_gateway_usage_plan/types/validation.rb +80 -0
- data/lib/pangea/resources/aws_api_gateway_usage_plan/types.rb +7 -295
- data/lib/pangea/resources/aws_appstream_fleet/types/attributes.rb +80 -0
- data/lib/pangea/resources/aws_appstream_fleet/types/cost_estimation.rb +54 -0
- data/lib/pangea/resources/aws_appstream_fleet/types/nested_types.rb +82 -0
- data/lib/pangea/resources/aws_appstream_fleet/types.rb +4 -218
- data/lib/pangea/resources/aws_athena_named_query/types/query_analysis.rb +148 -0
- data/lib/pangea/resources/aws_athena_named_query/types/query_templates.rb +88 -0
- data/lib/pangea/resources/aws_athena_named_query/types.rb +40 -208
- data/lib/pangea/resources/aws_athena_workgroup/types/attributes.rb +101 -0
- data/lib/pangea/resources/aws_athena_workgroup/types/class_methods.rb +102 -0
- data/lib/pangea/resources/aws_athena_workgroup/types/instance_methods.rb +104 -0
- data/lib/pangea/resources/aws_athena_workgroup/types/validation.rb +56 -0
- data/lib/pangea/resources/aws_athena_workgroup/types.rb +5 -235
- data/lib/pangea/resources/aws_autoscaling_group/types/auto_scaling_tag.rb +42 -0
- data/lib/pangea/resources/aws_autoscaling_group/types/instance_refresh_preferences.rb +39 -0
- data/lib/pangea/resources/aws_autoscaling_group/types/launch_template_specification.rb +57 -0
- data/lib/pangea/resources/aws_autoscaling_group/types.rb +90 -141
- data/lib/pangea/resources/aws_autoscaling_group_tag/types.rb +1 -1
- data/lib/pangea/resources/aws_autoscaling_lifecycle_hook/types.rb +1 -1
- data/lib/pangea/resources/aws_autoscaling_notification/types.rb +1 -1
- data/lib/pangea/resources/aws_autoscaling_policy/types/predictive_scaling_configuration.rb +42 -0
- data/lib/pangea/resources/aws_autoscaling_policy/types/step_adjustment.rb +38 -0
- data/lib/pangea/resources/aws_autoscaling_policy/types/target_tracking_configuration.rb +89 -0
- data/lib/pangea/resources/aws_autoscaling_policy/types.rb +88 -151
- data/lib/pangea/resources/aws_autoscaling_policy_step_adjustment/types.rb +1 -1
- data/lib/pangea/resources/aws_autoscaling_policy_target_tracking_scaling_policy/types.rb +1 -1
- data/lib/pangea/resources/aws_autoscaling_schedule/types.rb +1 -1
- data/lib/pangea/resources/aws_autoscaling_tag/types/tag_queries.rb +121 -0
- data/lib/pangea/resources/aws_autoscaling_tag/types/tag_specification.rb +42 -0
- data/lib/pangea/resources/aws_autoscaling_tag/types/tag_validator.rb +103 -0
- data/lib/pangea/resources/aws_autoscaling_tag/types.rb +13 -186
- data/lib/pangea/resources/aws_autoscaling_traffic_source_attachment/types.rb +1 -1
- data/lib/pangea/resources/aws_autoscaling_warm_pool/types.rb +1 -1
- data/lib/pangea/resources/aws_batch_compute_environment/types/attributes.rb +88 -0
- data/lib/pangea/resources/aws_batch_compute_environment/types/helpers.rb +54 -0
- data/lib/pangea/resources/aws_batch_compute_environment/types/templates.rb +153 -0
- data/lib/pangea/resources/aws_batch_compute_environment/types/validators.rb +144 -0
- data/lib/pangea/resources/aws_batch_compute_environment/types.rb +5 -314
- data/lib/pangea/resources/aws_batch_job_definition/resource.rb +21 -189
- data/lib/pangea/resources/aws_batch_job_definition/synthesis/synthesizer.rb +144 -0
- data/lib/pangea/resources/aws_batch_job_definition/types/computed.rb +60 -0
- data/lib/pangea/resources/aws_batch_job_definition/types/configurations.rb +75 -0
- data/lib/pangea/resources/aws_batch_job_definition/types/templates.rb +156 -0
- data/lib/pangea/resources/aws_batch_job_definition/types/validation.rb +154 -0
- data/lib/pangea/resources/aws_batch_job_definition/types.rb +31 -502
- data/lib/pangea/resources/aws_batch_job_queue/types/attributes.rb +75 -0
- data/lib/pangea/resources/aws_batch_job_queue/types/templates.rb +132 -0
- data/lib/pangea/resources/aws_batch_job_queue/types.rb +6 -359
- data/lib/pangea/resources/aws_blockchain_query/types/attributes.rb +75 -0
- data/lib/pangea/resources/aws_blockchain_query/types/helpers.rb +187 -0
- data/lib/pangea/resources/aws_blockchain_query/types/validators.rb +95 -0
- data/lib/pangea/resources/aws_blockchain_query/types.rb +4 -324
- data/lib/pangea/resources/aws_blockchain_token_balance/types/attributes.rb +71 -0
- data/lib/pangea/resources/aws_blockchain_token_balance/types/network_helpers.rb +83 -0
- data/lib/pangea/resources/aws_blockchain_token_balance/types/query_helpers.rb +94 -0
- data/lib/pangea/resources/aws_blockchain_token_balance/types/token_helpers.rb +89 -0
- data/lib/pangea/resources/aws_blockchain_token_balance/types/validation.rb +86 -0
- data/lib/pangea/resources/aws_blockchain_token_balance/types.rb +6 -302
- data/lib/pangea/resources/aws_braket_device/types/helpers.rb +113 -0
- data/lib/pangea/resources/aws_braket_device/types/validations.rb +80 -0
- data/lib/pangea/resources/aws_braket_device/types.rb +73 -203
- data/lib/pangea/resources/aws_braket_device_capabilities/types/capability_support.rb +60 -0
- data/lib/pangea/resources/aws_braket_device_capabilities/types/device_classification.rb +66 -0
- data/lib/pangea/resources/aws_braket_device_capabilities/types/device_specs.rb +93 -0
- data/lib/pangea/resources/aws_braket_device_capabilities/types/execution_params.rb +60 -0
- data/lib/pangea/resources/aws_braket_device_capabilities/types.rb +47 -220
- data/lib/pangea/resources/aws_braket_job/types/attributes.rb +81 -0
- data/lib/pangea/resources/aws_braket_job/types/constants.rb +43 -0
- data/lib/pangea/resources/aws_braket_job/types/instance_methods.rb +71 -0
- data/lib/pangea/resources/aws_braket_job/types/validation.rb +69 -0
- data/lib/pangea/resources/aws_braket_job/types.rb +5 -260
- data/lib/pangea/resources/aws_braket_job_queue/types/cost_estimation.rb +64 -0
- data/lib/pangea/resources/aws_braket_job_queue/types/helpers.rb +100 -0
- data/lib/pangea/resources/aws_braket_job_queue/types/validators.rb +72 -0
- data/lib/pangea/resources/aws_braket_job_queue/types.rb +46 -206
- data/lib/pangea/resources/aws_braket_local_simulator/types/helpers.rb +143 -0
- data/lib/pangea/resources/aws_braket_local_simulator/types/validators.rb +91 -0
- data/lib/pangea/resources/aws_braket_local_simulator/types.rb +64 -263
- data/lib/pangea/resources/aws_budgets_budget/types/attributes.rb +68 -0
- data/lib/pangea/resources/aws_budgets_budget/types/enums.rb +60 -0
- data/lib/pangea/resources/aws_budgets_budget/types/helpers.rb +122 -0
- data/lib/pangea/resources/aws_budgets_budget/types/schemas.rb +175 -0
- data/lib/pangea/resources/aws_budgets_budget/types.rb +5 -319
- data/lib/pangea/resources/aws_budgets_budget_action/types/attributes.rb +104 -0
- data/lib/pangea/resources/aws_budgets_budget_action/types/definitions.rb +53 -0
- data/lib/pangea/resources/aws_budgets_budget_action/types.rb +6 -404
- data/lib/pangea/resources/aws_ce_cost_category/expression_builder.rb +84 -0
- data/lib/pangea/resources/aws_ce_cost_category/resource.rb +2 -54
- data/lib/pangea/resources/aws_ce_cost_category/types/attributes.rb +152 -0
- data/lib/pangea/resources/aws_ce_cost_category/types/expressions.rb +157 -0
- data/lib/pangea/resources/aws_ce_cost_category/types.rb +5 -386
- data/lib/pangea/resources/aws_cloudformation_stack/types/configs.rb +91 -0
- data/lib/pangea/resources/aws_cloudformation_stack/types/instance_methods.rb +79 -0
- data/lib/pangea/resources/aws_cloudformation_stack/types/validation.rb +88 -0
- data/lib/pangea/resources/aws_cloudformation_stack/types.rb +47 -206
- data/lib/pangea/resources/aws_cloudformation_stack_set/types/configs.rb +120 -0
- data/lib/pangea/resources/aws_cloudformation_stack_set/types/helpers.rb +89 -0
- data/lib/pangea/resources/aws_cloudformation_stack_set/types/validators.rb +120 -0
- data/lib/pangea/resources/aws_cloudformation_stack_set/types.rb +73 -283
- data/lib/pangea/resources/aws_cloudfront_distribution/builders/cache_behavior_builder.rb +86 -0
- data/lib/pangea/resources/aws_cloudfront_distribution/builders/origin_builder.rb +81 -0
- data/lib/pangea/resources/aws_cloudfront_distribution/builders/reference_builder.rb +62 -0
- data/lib/pangea/resources/aws_cloudfront_distribution/builders/settings_builder.rb +81 -0
- data/lib/pangea/resources/aws_cloudfront_distribution/resource.rb +23 -213
- data/lib/pangea/resources/aws_cloudfront_distribution/types/attributes.rb +47 -0
- data/lib/pangea/resources/aws_cloudfront_distribution/types/instance_methods.rb +59 -0
- data/lib/pangea/resources/aws_cloudfront_distribution/types/validation.rb +55 -0
- data/lib/pangea/resources/aws_cloudfront_distribution/types.rb +6 -402
- data/lib/pangea/resources/aws_cloudfront_response_headers_policy/types/attributes.rb +153 -0
- data/lib/pangea/resources/aws_cloudfront_response_headers_policy/types/configs.rb +81 -0
- data/lib/pangea/resources/aws_cloudfront_response_headers_policy/types.rb +6 -373
- data/lib/pangea/resources/aws_cloudtrail/types/attributes.rb +92 -0
- data/lib/pangea/resources/aws_cloudtrail/types/configs.rb +87 -0
- data/lib/pangea/resources/aws_cloudtrail/types/selectors.rb +42 -0
- data/lib/pangea/resources/aws_cloudtrail/types.rb +9 -352
- data/lib/pangea/resources/aws_cloudwatch_dashboard/types/cloudwatch_dashboard_attributes.rb +158 -0
- data/lib/pangea/resources/aws_cloudwatch_dashboard/types/dashboard_metric.rb +57 -0
- data/lib/pangea/resources/aws_cloudwatch_dashboard/types/dashboard_widget.rb +83 -0
- data/lib/pangea/resources/aws_cloudwatch_dashboard/types/dashboard_widget_properties.rb +75 -0
- data/lib/pangea/resources/aws_cloudwatch_dashboard/types.rb +6 -283
- data/lib/pangea/resources/aws_cloudwatch_event_target/resource.rb +51 -136
- data/lib/pangea/resources/aws_cloudwatch_event_target/target_builders.rb +97 -0
- data/lib/pangea/resources/aws_cloudwatch_event_target/types/dead_letter_config.rb +36 -0
- data/lib/pangea/resources/aws_cloudwatch_event_target/types/input_transformer.rb +40 -0
- data/lib/pangea/resources/aws_cloudwatch_event_target/types/retry_policy.rb +40 -0
- data/lib/pangea/resources/aws_cloudwatch_event_target/types/target_service_detection.rb +80 -0
- data/lib/pangea/resources/aws_cloudwatch_event_target/types/validators.rb +66 -0
- data/lib/pangea/resources/aws_cloudwatch_event_target/types.rb +60 -144
- data/lib/pangea/resources/aws_cloudwatch_metric_alarm/types/instance_methods.rb +94 -0
- data/lib/pangea/resources/aws_cloudwatch_metric_alarm/types/metric_query.rb +71 -0
- data/lib/pangea/resources/aws_cloudwatch_metric_alarm/types/validation.rb +83 -0
- data/lib/pangea/resources/aws_cloudwatch_metric_alarm/types.rb +36 -179
- data/lib/pangea/resources/aws_codeartifact_repository/types.rb +1 -1
- data/lib/pangea/resources/aws_codebuild_project/block_builders.rb +163 -0
- data/lib/pangea/resources/aws_codebuild_project/resource.rb +21 -154
- data/lib/pangea/resources/aws_codebuild_project/types/instance_methods.rb +74 -0
- data/lib/pangea/resources/aws_codebuild_project/types/schemas.rb +155 -0
- data/lib/pangea/resources/aws_codebuild_project/types/validation.rb +88 -0
- data/lib/pangea/resources/aws_codebuild_project/types.rb +58 -238
- data/lib/pangea/resources/aws_codecommit_repository/types.rb +2 -2
- data/lib/pangea/resources/aws_codedeploy_application/types.rb +1 -1
- data/lib/pangea/resources/aws_codedeploy_deployment_config/types.rb +1 -1
- data/lib/pangea/resources/aws_codedeploy_deployment_group/block_builders.rb +104 -0
- data/lib/pangea/resources/aws_codedeploy_deployment_group/resource.rb +5 -70
- data/lib/pangea/resources/aws_codedeploy_deployment_group/types/deployment.rb +65 -0
- data/lib/pangea/resources/aws_codedeploy_deployment_group/types/helpers.rb +85 -0
- data/lib/pangea/resources/aws_codedeploy_deployment_group/types/infrastructure.rb +78 -0
- data/lib/pangea/resources/aws_codedeploy_deployment_group/types/tag_filters.rb +43 -0
- data/lib/pangea/resources/aws_codedeploy_deployment_group/types.rb +55 -208
- data/lib/pangea/resources/aws_codepipeline/types/attributes.rb +130 -0
- data/lib/pangea/resources/aws_codepipeline/types/instance_methods.rb +85 -0
- data/lib/pangea/resources/aws_codepipeline/types/validation.rb +64 -0
- data/lib/pangea/resources/aws_codepipeline/types.rb +5 -194
- data/lib/pangea/resources/aws_codepipeline_webhook/types.rb +2 -2
- data/lib/pangea/resources/aws_cognito_identity_pool/types/attributes.rb +105 -0
- data/lib/pangea/resources/aws_cognito_identity_pool/types/providers.rb +38 -0
- data/lib/pangea/resources/aws_cognito_identity_pool/types/templates.rb +75 -0
- data/lib/pangea/resources/aws_cognito_identity_pool/types.rb +5 -340
- data/lib/pangea/resources/aws_cognito_identity_provider/types/attributes.rb +61 -0
- data/lib/pangea/resources/aws_cognito_identity_provider/types/templates.rb +69 -0
- data/lib/pangea/resources/aws_cognito_identity_provider/types/validation.rb +66 -0
- data/lib/pangea/resources/aws_cognito_identity_provider/types.rb +4 -476
- data/lib/pangea/resources/aws_cognito_user_pool/resource/dsl_builder/authentication_config.rb +63 -0
- data/lib/pangea/resources/aws_cognito_user_pool/resource/dsl_builder/messaging_config.rb +73 -0
- data/lib/pangea/resources/aws_cognito_user_pool/resource/dsl_builder/mfa_config.rb +57 -0
- data/lib/pangea/resources/aws_cognito_user_pool/resource/dsl_builder/schema_and_settings.rb +146 -0
- data/lib/pangea/resources/aws_cognito_user_pool/resource/dsl_builder.rb +42 -0
- data/lib/pangea/resources/aws_cognito_user_pool/resource.rb +49 -204
- data/lib/pangea/resources/aws_cognito_user_pool/types/attributes.rb +87 -0
- data/lib/pangea/resources/aws_cognito_user_pool/types/nested_types.rb +112 -0
- data/lib/pangea/resources/aws_cognito_user_pool/types/templates.rb +57 -0
- data/lib/pangea/resources/aws_cognito_user_pool/types.rb +8 -347
- data/lib/pangea/resources/aws_cognito_user_pool_client/types/attributes.rb +109 -0
- data/lib/pangea/resources/aws_cognito_user_pool_client/types/nested_types.rb +27 -0
- data/lib/pangea/resources/aws_cognito_user_pool_client/types/templates.rb +85 -0
- data/lib/pangea/resources/aws_cognito_user_pool_client/types.rb +8 -382
- data/lib/pangea/resources/aws_cognito_user_pool_domain/types/attributes.rb +124 -0
- data/lib/pangea/resources/aws_cognito_user_pool_domain/types/templates.rb +84 -0
- data/lib/pangea/resources/aws_cognito_user_pool_domain/types/validation.rb +73 -0
- data/lib/pangea/resources/aws_cognito_user_pool_domain/types.rb +4 -237
- data/lib/pangea/resources/aws_config_config_rule/types/cost_estimator.rb +77 -0
- data/lib/pangea/resources/aws_config_config_rule/types/validators.rb +94 -0
- data/lib/pangea/resources/aws_config_config_rule/types.rb +22 -150
- data/lib/pangea/resources/aws_config_remediation_configuration/types.rb +1 -1
- data/lib/pangea/resources/aws_customer_gateway/types.rb +1 -1
- data/lib/pangea/resources/aws_db_cluster_snapshot/types/configs.rb +117 -0
- data/lib/pangea/resources/aws_db_cluster_snapshot/types.rb +2 -96
- data/lib/pangea/resources/aws_db_instance/types/backup_attributes.rb +38 -0
- data/lib/pangea/resources/aws_db_instance/types/core_attributes.rb +60 -0
- data/lib/pangea/resources/aws_db_instance/types/engine_configs.rb +68 -0
- data/lib/pangea/resources/aws_db_instance/types/helpers.rb +92 -0
- data/lib/pangea/resources/aws_db_instance/types/monitoring_attributes.rb +38 -0
- data/lib/pangea/resources/aws_db_instance/types/network_attributes.rb +44 -0
- data/lib/pangea/resources/aws_db_instance/types/options_attributes.rb +44 -0
- data/lib/pangea/resources/aws_db_instance/types/storage_attributes.rb +44 -0
- data/lib/pangea/resources/aws_db_instance/types/validations.rb +85 -0
- data/lib/pangea/resources/aws_db_instance/types.rb +38 -228
- data/lib/pangea/resources/aws_db_parameter_group/types/db_parameter.rb +57 -0
- data/lib/pangea/resources/aws_db_parameter_group/types/db_parameter_configs.rb +82 -0
- data/lib/pangea/resources/aws_db_parameter_group/types/parameter_validators.rb +73 -0
- data/lib/pangea/resources/aws_db_parameter_group/types.rb +121 -259
- data/lib/pangea/resources/aws_db_snapshot/types.rb +1 -1
- data/lib/pangea/resources/aws_db_subnet_group/types.rb +1 -1
- data/lib/pangea/resources/aws_default_network_acl/types.rb +1 -1
- data/lib/pangea/resources/aws_default_route_table/types.rb +1 -1
- data/lib/pangea/resources/aws_default_security_group/types.rb +1 -1
- data/lib/pangea/resources/aws_default_vpc_dhcp_options/types.rb +1 -1
- data/lib/pangea/resources/aws_docdb_certificate/types.rb +1 -1
- data/lib/pangea/resources/aws_docdb_cluster/types.rb +1 -1
- data/lib/pangea/resources/aws_docdb_cluster_endpoint/types.rb +1 -1
- data/lib/pangea/resources/aws_docdb_cluster_instance/types.rb +1 -1
- data/lib/pangea/resources/aws_docdb_cluster_parameter_group/types.rb +1 -1
- data/lib/pangea/resources/aws_docdb_cluster_snapshot/types.rb +1 -1
- data/lib/pangea/resources/aws_docdb_event_subscription/types.rb +1 -1
- data/lib/pangea/resources/aws_docdb_global_cluster/types.rb +1 -1
- data/lib/pangea/resources/aws_docdb_subnet_group/types.rb +1 -1
- data/lib/pangea/resources/aws_dynamodb_global_table/types/configs.rb +105 -0
- data/lib/pangea/resources/aws_dynamodb_global_table/types/instance_methods.rb +68 -0
- data/lib/pangea/resources/aws_dynamodb_global_table/types.rb +87 -234
- data/lib/pangea/resources/aws_dynamodb_table/builders/config_builder.rb +153 -0
- data/lib/pangea/resources/aws_dynamodb_table/builders/index_builder.rb +62 -0
- data/lib/pangea/resources/aws_dynamodb_table/builders/reference_builder.rb +64 -0
- data/lib/pangea/resources/aws_dynamodb_table/builders/table_builder.rb +62 -0
- data/lib/pangea/resources/aws_dynamodb_table/resource.rb +8 -186
- data/lib/pangea/resources/aws_dynamodb_table/types/attributes.rb +150 -0
- data/lib/pangea/resources/aws_dynamodb_table/types/configs.rb +109 -0
- data/lib/pangea/resources/aws_dynamodb_table/types/instance_methods.rb +82 -0
- data/lib/pangea/resources/aws_dynamodb_table/types/validations.rb +131 -0
- data/lib/pangea/resources/aws_dynamodb_table/types.rb +5 -381
- data/lib/pangea/resources/aws_ebs_volume/types/attributes.rb +76 -0
- data/lib/pangea/resources/aws_ebs_volume/types/instance_methods.rb +121 -0
- data/lib/pangea/resources/aws_ebs_volume/types/validation.rb +114 -0
- data/lib/pangea/resources/aws_ebs_volume/types.rb +7 -228
- data/lib/pangea/resources/aws_ec2_ami_launch_permission/types.rb +1 -1
- data/lib/pangea/resources/aws_ec2_availability_zone_group/types.rb +1 -1
- data/lib/pangea/resources/aws_ec2_capacity_block_reservation/types.rb +1 -1
- data/lib/pangea/resources/aws_ec2_capacity_reservation/types.rb +1 -1
- data/lib/pangea/resources/aws_ec2_dedicated_host/types.rb +1 -1
- data/lib/pangea/resources/aws_ec2_fleet/types.rb +1 -1
- data/lib/pangea/resources/aws_ec2_host_resource_group_association/types.rb +1 -1
- data/lib/pangea/resources/aws_ec2_image_block_public_access/types.rb +1 -1
- data/lib/pangea/resources/aws_ec2_instance_metadata_defaults/types.rb +1 -1
- data/lib/pangea/resources/aws_ec2_serial_console_access/types.rb +1 -1
- data/lib/pangea/resources/aws_ec2_snapshot_block_public_access/types.rb +1 -1
- data/lib/pangea/resources/aws_ec2_spot_datafeed_subscription/types.rb +1 -1
- data/lib/pangea/resources/aws_ec2_spot_fleet_request/types.rb +1 -1
- data/lib/pangea/resources/aws_ec2_spot_instance_request/types.rb +1 -1
- data/lib/pangea/resources/aws_ec2_tag/types.rb +1 -1
- data/lib/pangea/resources/aws_ec2_transit_gateway_multicast_domain/types.rb +1 -1
- data/lib/pangea/resources/aws_ec2_transit_gateway_multicast_domain_association/types.rb +1 -1
- data/lib/pangea/resources/aws_ec2_transit_gateway_multicast_group_member/types.rb +1 -1
- data/lib/pangea/resources/aws_ec2_transit_gateway_route/types/network_analysis.rb +91 -0
- data/lib/pangea/resources/aws_ec2_transit_gateway_route/types/security_analysis.rb +144 -0
- data/lib/pangea/resources/aws_ec2_transit_gateway_route/types.rb +41 -190
- data/lib/pangea/resources/aws_ec2_transit_gateway_route_table_propagation/types/propagation_insights.rb +100 -0
- data/lib/pangea/resources/aws_ec2_transit_gateway_route_table_propagation/types/security_concerns.rb +67 -0
- data/lib/pangea/resources/aws_ec2_transit_gateway_route_table_propagation/types/troubleshooting_support.rb +68 -0
- data/lib/pangea/resources/aws_ec2_transit_gateway_route_table_propagation/types.rb +14 -169
- data/lib/pangea/resources/aws_ecr_lifecycle_policy/types/computed.rb +110 -0
- data/lib/pangea/resources/aws_ecr_lifecycle_policy/types/validation.rb +69 -0
- data/lib/pangea/resources/aws_ecr_lifecycle_policy/types.rb +42 -167
- data/lib/pangea/resources/aws_ecr_repository/types.rb +1 -1
- data/lib/pangea/resources/aws_ecs_capacity_provider/types.rb +1 -1
- data/lib/pangea/resources/aws_ecs_cluster/types.rb +1 -1
- data/lib/pangea/resources/aws_ecs_service/dsl_builders.rb +193 -0
- data/lib/pangea/resources/aws_ecs_service/reference_builder.rb +53 -0
- data/lib/pangea/resources/aws_ecs_service/resource.rb +21 -201
- data/lib/pangea/resources/aws_ecs_service/types/attributes.rb +56 -0
- data/lib/pangea/resources/aws_ecs_service/types/helpers.rb +34 -0
- data/lib/pangea/resources/aws_ecs_service/types/nested.rb +74 -0
- data/lib/pangea/resources/aws_ecs_service/types.rb +4 -324
- data/lib/pangea/resources/aws_ecs_task_definition/container_definitions.rb +191 -0
- data/lib/pangea/resources/aws_ecs_task_definition/resource.rb +107 -255
- data/lib/pangea/resources/aws_ecs_task_definition/types/container_definition.rb +121 -0
- data/lib/pangea/resources/aws_ecs_task_definition/types/task_definition.rb +100 -0
- data/lib/pangea/resources/aws_ecs_task_definition/types.rb +6 -427
- data/lib/pangea/resources/aws_ecs_task_definition/volumes.rb +105 -0
- data/lib/pangea/resources/aws_eip/types.rb +1 -1
- data/lib/pangea/resources/aws_eip_association/types.rb +1 -1
- data/lib/pangea/resources/aws_eks_access_entry/types.rb +1 -1
- data/lib/pangea/resources/aws_eks_node_group/builders/dsl_builder.rb +108 -0
- data/lib/pangea/resources/aws_eks_node_group/builders/reference_builder.rb +76 -0
- data/lib/pangea/resources/aws_eks_node_group/resource.rb +7 -114
- data/lib/pangea/resources/aws_eks_node_group/types/eks_node_group_attributes.rb +132 -0
- data/lib/pangea/resources/aws_eks_node_group/types/launch_template.rb +58 -0
- data/lib/pangea/resources/aws_eks_node_group/types/remote_access.rb +41 -0
- data/lib/pangea/resources/aws_eks_node_group/types/scaling_config.rb +62 -0
- data/lib/pangea/resources/aws_eks_node_group/types/taint.rb +43 -0
- data/lib/pangea/resources/aws_eks_node_group/types/update_config.rb +54 -0
- data/lib/pangea/resources/aws_eks_node_group/types.rb +8 -242
- data/lib/pangea/resources/aws_elasticache_cluster/types/configs.rb +69 -0
- data/lib/pangea/resources/aws_elasticache_cluster/types/helpers.rb +97 -0
- data/lib/pangea/resources/aws_elasticache_cluster/types/node_types.rb +51 -0
- data/lib/pangea/resources/aws_elasticache_cluster/types/validators.rb +114 -0
- data/lib/pangea/resources/aws_elasticache_cluster/types.rb +29 -196
- data/lib/pangea/resources/aws_elasticache_parameter_group/types/attributes.rb +132 -0
- data/lib/pangea/resources/aws_elasticache_parameter_group/types/configs.rb +102 -0
- data/lib/pangea/resources/aws_elasticache_parameter_group/types/parameter_helpers.rb +133 -0
- data/lib/pangea/resources/aws_elasticache_parameter_group/types.rb +4 -279
- data/lib/pangea/resources/aws_elasticache_subnet_group/types.rb +1 -1
- data/lib/pangea/resources/aws_elb_attachment/types.rb +1 -1
- data/lib/pangea/resources/aws_elb_service_account/types.rb +1 -1
- data/lib/pangea/resources/aws_elemental_data_plane_channel/types.rb +2 -2
- data/lib/pangea/resources/aws_emr_cluster/resource/dsl_builder/auto_scaling.rb +93 -0
- data/lib/pangea/resources/aws_emr_cluster/resource/dsl_builder/cluster_settings.rb +106 -0
- data/lib/pangea/resources/aws_emr_cluster/resource/dsl_builder/configurations.rb +75 -0
- data/lib/pangea/resources/aws_emr_cluster/resource/dsl_builder/ec2_attributes.rb +56 -0
- data/lib/pangea/resources/aws_emr_cluster/resource/dsl_builder/instance_groups.rb +101 -0
- data/lib/pangea/resources/aws_emr_cluster/resource/dsl_builder.rb +44 -0
- data/lib/pangea/resources/aws_emr_cluster/resource.rb +63 -279
- data/lib/pangea/resources/aws_emr_cluster/types/attributes.rb +97 -0
- data/lib/pangea/resources/aws_emr_cluster/types/class_methods.rb +114 -0
- data/lib/pangea/resources/aws_emr_cluster/types/instance_methods.rb +113 -0
- data/lib/pangea/resources/aws_emr_cluster/types/validation.rb +51 -0
- data/lib/pangea/resources/aws_emr_cluster/types.rb +5 -480
- data/lib/pangea/resources/aws_emr_instance_group/types/attributes.rb +90 -0
- data/lib/pangea/resources/aws_emr_instance_group/types/configs.rb +63 -0
- data/lib/pangea/resources/aws_emr_instance_group/types.rb +6 -408
- data/lib/pangea/resources/aws_emr_step/types/attributes.rb +92 -0
- data/lib/pangea/resources/aws_emr_step/types/step_builders.rb +90 -0
- data/lib/pangea/resources/aws_emr_step/types.rb +6 -377
- data/lib/pangea/resources/aws_eventbridge_bus/types.rb +1 -1
- data/lib/pangea/resources/aws_eventbridge_rule/types/attributes.rb +80 -0
- data/lib/pangea/resources/aws_eventbridge_rule/types/helpers.rb +101 -0
- data/lib/pangea/resources/aws_eventbridge_rule/types/templates.rb +131 -0
- data/lib/pangea/resources/aws_eventbridge_rule/types/validators.rb +87 -0
- data/lib/pangea/resources/aws_eventbridge_rule/types.rb +5 -313
- data/lib/pangea/resources/aws_eventbridge_target/batch_target_builder.rb +48 -0
- data/lib/pangea/resources/aws_eventbridge_target/ecs_target_builder.rb +101 -0
- data/lib/pangea/resources/aws_eventbridge_target/resource.rb +4 -76
- data/lib/pangea/resources/aws_eventbridge_target/types/attributes.rb +115 -0
- data/lib/pangea/resources/aws_eventbridge_target/types/configs.rb +75 -0
- data/lib/pangea/resources/aws_eventbridge_target/types/parameters.rb +58 -0
- data/lib/pangea/resources/aws_eventbridge_target/types.rb +4 -466
- data/lib/pangea/resources/aws_fsx_lustre_filesystem/types/helpers.rb +101 -0
- data/lib/pangea/resources/aws_fsx_lustre_filesystem/types.rb +61 -164
- data/lib/pangea/resources/aws_glue_catalog_table/types/format_helpers.rb +80 -0
- data/lib/pangea/resources/aws_glue_catalog_table/types/storage_descriptor.rb +60 -0
- data/lib/pangea/resources/aws_glue_catalog_table/types/table_helpers.rb +95 -0
- data/lib/pangea/resources/aws_glue_catalog_table/types/validators.rb +72 -0
- data/lib/pangea/resources/aws_glue_catalog_table/types.rb +55 -248
- data/lib/pangea/resources/aws_glue_job/types/attributes.rb +99 -0
- data/lib/pangea/resources/aws_glue_job/types/class_methods.rb +86 -0
- data/lib/pangea/resources/aws_glue_job/types/instance_methods.rb +97 -0
- data/lib/pangea/resources/aws_glue_job/types/validation.rb +68 -0
- data/lib/pangea/resources/aws_glue_job/types.rb +5 -268
- data/lib/pangea/resources/aws_glue_trigger/types/attributes.rb +91 -0
- data/lib/pangea/resources/aws_glue_trigger/types/helpers/class_methods.rb +109 -0
- data/lib/pangea/resources/aws_glue_trigger/types/helpers/instance_methods.rb +140 -0
- data/lib/pangea/resources/aws_glue_trigger/types/helpers.rb +35 -0
- data/lib/pangea/resources/aws_glue_trigger/types/validation.rb +97 -0
- data/lib/pangea/resources/aws_glue_trigger/types.rb +9 -306
- data/lib/pangea/resources/aws_ground_station/config.rb +145 -0
- data/lib/pangea/resources/aws_ground_station/contact.rb +48 -0
- data/lib/pangea/resources/aws_ground_station/dataflow_endpoint_group.rb +46 -0
- data/lib/pangea/resources/aws_ground_station/mission_profile.rb +50 -0
- data/lib/pangea/resources/aws_ground_station.rb +15 -362
- data/lib/pangea/resources/aws_iam_group/types/access_patterns.rb +82 -0
- data/lib/pangea/resources/aws_iam_group/types/attributes.rb +97 -0
- data/lib/pangea/resources/aws_iam_group/types/group_classification.rb +132 -0
- data/lib/pangea/resources/aws_iam_group/types/patterns.rb +96 -0
- data/lib/pangea/resources/aws_iam_group/types.rb +10 -394
- data/lib/pangea/resources/aws_iam_policy/types/attributes.rb +117 -0
- data/lib/pangea/resources/aws_iam_policy/types/templates.rb +56 -0
- data/lib/pangea/resources/aws_iam_policy/types.rb +7 -346
- data/lib/pangea/resources/aws_iam_role/types/trust_policies.rb +90 -0
- data/lib/pangea/resources/aws_iam_role/types.rb +103 -174
- data/lib/pangea/resources/aws_iam_role_policy_attachment/types/attachment_patterns.rb +75 -0
- data/lib/pangea/resources/aws_iam_role_policy_attachment/types/aws_managed_policies.rb +93 -0
- data/lib/pangea/resources/aws_iam_role_policy_attachment/types.rb +101 -222
- data/lib/pangea/resources/aws_iam_user/types/attributes.rb +45 -0
- data/lib/pangea/resources/aws_iam_user/types/helpers.rb +123 -0
- data/lib/pangea/resources/aws_iam_user/types/templates.rb +147 -0
- data/lib/pangea/resources/aws_iam_user/types/validators.rb +68 -0
- data/lib/pangea/resources/aws_iam_user/types.rb +5 -323
- data/lib/pangea/resources/aws_instance/types.rb +1 -1
- data/lib/pangea/resources/aws_internet_gateway/resource.rb +3 -9
- data/lib/pangea/resources/aws_iot_analytics_channel/types.rb +1 -1
- data/lib/pangea/resources/aws_iot_analytics_datastore/types.rb +1 -1
- data/lib/pangea/resources/aws_iot_certificate/types/helpers.rb +164 -0
- data/lib/pangea/resources/aws_iot_certificate/types/validators.rb +84 -0
- data/lib/pangea/resources/aws_iot_certificate/types.rb +46 -208
- data/lib/pangea/resources/aws_iot_device_defender_security_profile/types.rb +3 -3
- data/lib/pangea/resources/aws_iot_policy/types.rb +1 -1
- data/lib/pangea/resources/aws_iot_security_profile/types.rb +2 -2
- data/lib/pangea/resources/aws_iot_thing_type/types/analysis.rb +107 -0
- data/lib/pangea/resources/aws_iot_thing_type/types/properties.rb +64 -0
- data/lib/pangea/resources/aws_iot_thing_type/types/recommendations.rb +65 -0
- data/lib/pangea/resources/aws_iot_thing_type/types/templates.rb +69 -0
- data/lib/pangea/resources/aws_iot_thing_type/types.rb +35 -215
- data/lib/pangea/resources/aws_iot_topic_rule/types.rb +2 -2
- data/lib/pangea/resources/aws_iot_topic_rule_destination/types.rb +1 -1
- data/lib/pangea/resources/aws_iotanalytics_dataset/builders/action_builder.rb +76 -0
- data/lib/pangea/resources/aws_iotanalytics_dataset/resource.rb +2 -41
- data/lib/pangea/resources/aws_iotanalytics_dataset/types/action.rb +91 -0
- data/lib/pangea/resources/aws_iotanalytics_dataset/types/attributes.rb +81 -0
- data/lib/pangea/resources/aws_iotanalytics_dataset/types/content_delivery_rule.rb +67 -0
- data/lib/pangea/resources/aws_iotanalytics_dataset/types/trigger.rb +49 -0
- data/lib/pangea/resources/aws_iotanalytics_dataset/types.rb +6 -202
- data/lib/pangea/resources/aws_key_pair/types.rb +1 -1
- data/lib/pangea/resources/aws_kinesis_analytics_application/builders/application_code_builder.rb +62 -0
- data/lib/pangea/resources/aws_kinesis_analytics_application/builders/flink_builder.rb +76 -0
- data/lib/pangea/resources/aws_kinesis_analytics_application/builders/sql_builder.rb +197 -0
- data/lib/pangea/resources/aws_kinesis_analytics_application/resource.rb +67 -243
- data/lib/pangea/resources/aws_kinesis_analytics_application/types/computed.rb +131 -0
- data/lib/pangea/resources/aws_kinesis_analytics_application/types/configs.rb +86 -0
- data/lib/pangea/resources/aws_kinesis_analytics_application/types/sql_configs.rb +113 -0
- data/lib/pangea/resources/aws_kinesis_analytics_application/types/validation.rb +109 -0
- data/lib/pangea/resources/aws_kinesis_analytics_application/types.rb +25 -280
- data/lib/pangea/resources/aws_kinesis_firehose_delivery_stream/destination_builders.rb +108 -0
- data/lib/pangea/resources/aws_kinesis_firehose_delivery_stream/resource.rb +20 -210
- data/lib/pangea/resources/aws_kinesis_firehose_delivery_stream/s3_builders.rb +127 -0
- data/lib/pangea/resources/aws_kinesis_firehose_delivery_stream/types/computed_properties.rb +65 -0
- data/lib/pangea/resources/aws_kinesis_firehose_delivery_stream/types/validation.rb +73 -0
- data/lib/pangea/resources/aws_kinesis_firehose_delivery_stream/types.rb +121 -242
- data/lib/pangea/resources/aws_kinesis_stream/types.rb +1 -1
- data/lib/pangea/resources/aws_kinesis_video_stream/types/kms_validation.rb +52 -0
- data/lib/pangea/resources/aws_kinesis_video_stream/types/media_type_helpers.rb +58 -0
- data/lib/pangea/resources/aws_kinesis_video_stream/types/storage_estimation.rb +75 -0
- data/lib/pangea/resources/aws_kinesis_video_stream/types.rb +60 -161
- data/lib/pangea/resources/aws_lambda_function/block_builders.rb +112 -0
- data/lib/pangea/resources/aws_lambda_function/resource.rb +13 -78
- data/lib/pangea/resources/aws_lambda_function/types/helpers.rb +58 -0
- data/lib/pangea/resources/aws_lambda_function/types/validators.rb +99 -0
- data/lib/pangea/resources/aws_lambda_function/types.rb +16 -156
- data/lib/pangea/resources/aws_launch_configuration/types.rb +1 -1
- data/lib/pangea/resources/aws_launch_template/types/block_device_mapping.rb +57 -0
- data/lib/pangea/resources/aws_launch_template/types/iam_instance_profile.rb +48 -0
- data/lib/pangea/resources/aws_launch_template/types/network_interface.rb +43 -0
- data/lib/pangea/resources/aws_launch_template/types/tag_specification.rb +43 -0
- data/lib/pangea/resources/aws_launch_template/types.rb +25 -111
- data/lib/pangea/resources/aws_lb/types.rb +1 -1
- data/lib/pangea/resources/aws_lb_cookie_stickiness_policy/types.rb +1 -1
- data/lib/pangea/resources/aws_lb_listener/types.rb +1 -1
- data/lib/pangea/resources/aws_lb_listener_rule/action_builders.rb +123 -0
- data/lib/pangea/resources/aws_lb_listener_rule/resource.rb +3 -88
- data/lib/pangea/resources/aws_lb_listener_rule/types.rb +1 -1
- data/lib/pangea/resources/aws_lb_ssl_negotiation_policy/types.rb +1 -1
- data/lib/pangea/resources/aws_lb_target_group_attachment/types.rb +1 -1
- data/lib/pangea/resources/aws_lb_trust_store/types.rb +1 -1
- data/lib/pangea/resources/aws_lb_trust_store_revocation/types.rb +1 -1
- data/lib/pangea/resources/aws_licensemanager_association/types.rb +1 -1
- data/lib/pangea/resources/aws_licensemanager_grant/types.rb +1 -1
- data/lib/pangea/resources/aws_licensemanager_grant_accepter/types.rb +1 -1
- data/lib/pangea/resources/aws_licensemanager_license_configuration/types.rb +1 -1
- data/lib/pangea/resources/aws_licensemanager_license_grant_accepter/types.rb +1 -1
- data/lib/pangea/resources/aws_licensemanager_report_generator/types.rb +2 -2
- data/lib/pangea/resources/aws_licensemanager_token/types.rb +2 -2
- data/lib/pangea/resources/aws_lightsail/compute.rb +83 -0
- data/lib/pangea/resources/aws_lightsail/database.rb +66 -0
- data/lib/pangea/resources/aws_lightsail/load_balancer.rb +68 -0
- data/lib/pangea/resources/aws_lightsail/networking.rb +118 -0
- data/lib/pangea/resources/aws_lightsail/storage.rb +101 -0
- data/lib/pangea/resources/aws_lightsail.rb +20 -499
- data/lib/pangea/resources/aws_load_balancer_backend_server_policy/types.rb +1 -1
- data/lib/pangea/resources/aws_load_balancer_listener_policy/types.rb +1 -1
- data/lib/pangea/resources/aws_load_balancer_policy/types.rb +1 -1
- data/lib/pangea/resources/aws_local_zones/data_sources.rb +133 -0
- data/lib/pangea/resources/aws_local_zones/resources.rb +90 -0
- data/lib/pangea/resources/aws_local_zones.rb +9 -207
- data/lib/pangea/resources/aws_managedblockchain_accessor/types/blockchain_helpers.rb +76 -0
- data/lib/pangea/resources/aws_managedblockchain_accessor/types/cost_helpers.rb +68 -0
- data/lib/pangea/resources/aws_managedblockchain_accessor/types/network_helpers.rb +95 -0
- data/lib/pangea/resources/aws_managedblockchain_accessor/types.rb +58 -218
- data/lib/pangea/resources/aws_managedblockchain_ethereum_node/types/attributes.rb +84 -0
- data/lib/pangea/resources/aws_managedblockchain_ethereum_node/types/helpers.rb +97 -0
- data/lib/pangea/resources/aws_managedblockchain_ethereum_node/types.rb +4 -346
- data/lib/pangea/resources/aws_managedblockchain_member/types/instance_methods.rb +102 -0
- data/lib/pangea/resources/aws_managedblockchain_member/types/validation.rb +80 -0
- data/lib/pangea/resources/aws_managedblockchain_member/types.rb +49 -189
- data/lib/pangea/resources/aws_managedblockchain_network/types/helpers.rb +107 -0
- data/lib/pangea/resources/aws_managedblockchain_network/types/validation.rb +91 -0
- data/lib/pangea/resources/aws_managedblockchain_network/types.rb +73 -223
- data/lib/pangea/resources/aws_managedblockchain_node/types/attributes.rb +87 -0
- data/lib/pangea/resources/aws_managedblockchain_node/types/cost_and_specs.rb +75 -0
- data/lib/pangea/resources/aws_managedblockchain_node/types/instance_methods.rb +96 -0
- data/lib/pangea/resources/aws_managedblockchain_node/types/validation.rb +56 -0
- data/lib/pangea/resources/aws_managedblockchain_node/types.rb +5 -235
- data/lib/pangea/resources/aws_media_convert_queue/types.rb +2 -2
- data/lib/pangea/resources/aws_media_live_channel/resource/dsl_builder/configurations.rb +74 -0
- data/lib/pangea/resources/aws_media_live_channel/resource/dsl_builder/destinations.rb +67 -0
- data/lib/pangea/resources/aws_media_live_channel/resource/dsl_builder/encoder_settings/audio_descriptions.rb +101 -0
- data/lib/pangea/resources/aws_media_live_channel/resource/dsl_builder/encoder_settings/output_groups.rb +163 -0
- data/lib/pangea/resources/aws_media_live_channel/resource/dsl_builder/encoder_settings/video_descriptions.rb +86 -0
- data/lib/pangea/resources/aws_media_live_channel/resource/dsl_builder/encoder_settings.rb +52 -0
- data/lib/pangea/resources/aws_media_live_channel/resource/dsl_builder/input_attachments.rb +131 -0
- data/lib/pangea/resources/aws_media_live_channel/resource/dsl_builder.rb +42 -0
- data/lib/pangea/resources/aws_media_live_channel/resource.rb +22 -527
- data/lib/pangea/resources/aws_media_live_channel/types/audio_codec_settings.rb +103 -0
- data/lib/pangea/resources/aws_media_live_channel/types/caption_settings.rb +112 -0
- data/lib/pangea/resources/aws_media_live_channel/types/channel_config.rb +77 -0
- data/lib/pangea/resources/aws_media_live_channel/types/encoder_config.rb +108 -0
- data/lib/pangea/resources/aws_media_live_channel/types/helpers.rb +58 -0
- data/lib/pangea/resources/aws_media_live_channel/types/hls_group_settings.rb +113 -0
- data/lib/pangea/resources/aws_media_live_channel/types/input_settings.rb +106 -0
- data/lib/pangea/resources/aws_media_live_channel/types/output_group_settings.rb +102 -0
- data/lib/pangea/resources/aws_media_live_channel/types/output_groups.rb +43 -0
- data/lib/pangea/resources/aws_media_live_channel/types/output_settings.rb +153 -0
- data/lib/pangea/resources/aws_media_live_channel/types/schedule_settings.rb +191 -0
- data/lib/pangea/resources/aws_media_live_channel/types/video_codec_h265_mpeg2.rb +111 -0
- data/lib/pangea/resources/aws_media_live_channel/types/video_codec_settings.rb +89 -0
- data/lib/pangea/resources/aws_media_live_channel/types.rb +98 -961
- data/lib/pangea/resources/aws_media_live_input/types/helpers.rb +100 -0
- data/lib/pangea/resources/aws_media_live_input/types/validation.rb +86 -0
- data/lib/pangea/resources/aws_media_live_input/types.rb +92 -218
- data/lib/pangea/resources/aws_media_package_channel/types.rb +2 -2
- data/lib/pangea/resources/aws_media_package_origin_endpoint/types.rb +7 -7
- data/lib/pangea/resources/aws_media_store_container/types.rb +1 -1
- data/lib/pangea/resources/aws_memorydb_acl/types.rb +1 -1
- data/lib/pangea/resources/aws_memorydb_cluster/types.rb +1 -1
- data/lib/pangea/resources/aws_memorydb_cluster_endpoint/types.rb +1 -1
- data/lib/pangea/resources/aws_memorydb_multi_region_cluster/types.rb +1 -1
- data/lib/pangea/resources/aws_memorydb_parameter_group/types.rb +1 -1
- data/lib/pangea/resources/aws_memorydb_snapshot/types.rb +1 -1
- data/lib/pangea/resources/aws_memorydb_subnet_group/types.rb +1 -1
- data/lib/pangea/resources/aws_memorydb_user/types.rb +2 -2
- data/lib/pangea/resources/aws_minimal/requires/compute_network_resources.rb +77 -0
- data/lib/pangea/resources/aws_minimal/requires/database_resources.rb +76 -0
- data/lib/pangea/resources/aws_minimal/requires/extended_services.rb +74 -0
- data/lib/pangea/resources/aws_minimal/requires/service_modules.rb +60 -0
- data/lib/pangea/resources/aws_minimal.rb +13 -228
- data/lib/pangea/resources/aws_neptune_cluster/types.rb +2 -2
- data/lib/pangea/resources/aws_neptune_cluster_endpoint/types.rb +1 -1
- data/lib/pangea/resources/aws_neptune_cluster_instance/types.rb +1 -1
- data/lib/pangea/resources/aws_neptune_cluster_parameter_group/types.rb +1 -1
- data/lib/pangea/resources/aws_neptune_cluster_snapshot/types.rb +1 -1
- data/lib/pangea/resources/aws_neptune_event_subscription/types.rb +1 -1
- data/lib/pangea/resources/aws_neptune_parameter_group/types.rb +1 -1
- data/lib/pangea/resources/aws_neptune_subnet_group/types.rb +1 -1
- data/lib/pangea/resources/aws_network_acl/types.rb +1 -1
- data/lib/pangea/resources/aws_network_acl_rule/types.rb +1 -1
- data/lib/pangea/resources/aws_network_interface/types.rb +2 -2
- data/lib/pangea/resources/aws_organizations_organization/types.rb +2 -2
- data/lib/pangea/resources/aws_outposts/outpost.rb +64 -0
- data/lib/pangea/resources/aws_outposts/resources.rb +173 -0
- data/lib/pangea/resources/aws_outposts/site.rb +75 -0
- data/lib/pangea/resources/aws_outposts.rb +10 -343
- data/lib/pangea/resources/aws_placement_group/types.rb +1 -1
- data/lib/pangea/resources/aws_proxy_protocol_policy/types.rb +1 -1
- data/lib/pangea/resources/aws_qldb_stream/types/stream_helpers.rb +134 -0
- data/lib/pangea/resources/aws_qldb_stream/types.rb +66 -172
- data/lib/pangea/resources/aws_ram_invitation_accepter/types.rb +1 -1
- data/lib/pangea/resources/aws_ram_managed_permission/types.rb +1 -1
- data/lib/pangea/resources/aws_ram_permission/types.rb +1 -1
- data/lib/pangea/resources/aws_ram_permission_association/types.rb +1 -1
- data/lib/pangea/resources/aws_ram_principal_association/types.rb +1 -1
- data/lib/pangea/resources/aws_ram_resource_association/types.rb +1 -1
- data/lib/pangea/resources/aws_ram_resource_share/types.rb +1 -1
- data/lib/pangea/resources/aws_ram_resource_share_accepter/types.rb +1 -1
- data/lib/pangea/resources/aws_ram_resource_share_invitation/types.rb +1 -1
- data/lib/pangea/resources/aws_ram_sharing_with_organization/types.rb +1 -1
- data/lib/pangea/resources/aws_rds_cluster/types/attributes.rb +84 -0
- data/lib/pangea/resources/aws_rds_cluster/types/configs.rb +44 -0
- data/lib/pangea/resources/aws_rds_cluster/types/nested_types.rb +45 -0
- data/lib/pangea/resources/aws_rds_cluster/types/validation.rb +26 -0
- data/lib/pangea/resources/aws_rds_cluster/types.rb +5 -460
- data/lib/pangea/resources/aws_rds_cluster_endpoint/types/configs.rb +97 -0
- data/lib/pangea/resources/aws_rds_cluster_endpoint/types/members.rb +36 -0
- data/lib/pangea/resources/aws_rds_cluster_endpoint/types.rb +104 -193
- data/lib/pangea/resources/aws_rds_cluster_instance/types/attributes.rb +59 -0
- data/lib/pangea/resources/aws_rds_cluster_instance/types/configs.rb +58 -0
- data/lib/pangea/resources/aws_rds_cluster_instance/types/instance_methods.rb +106 -0
- data/lib/pangea/resources/aws_rds_cluster_instance/types.rb +6 -425
- data/lib/pangea/resources/aws_rds_cluster_parameter_group/types/attributes.rb +101 -0
- data/lib/pangea/resources/aws_rds_cluster_parameter_group/types/configs.rb +102 -0
- data/lib/pangea/resources/aws_rds_cluster_parameter_group/types/parameter.rb +36 -0
- data/lib/pangea/resources/aws_rds_cluster_parameter_group/types.rb +8 -349
- data/lib/pangea/resources/aws_rds_global_cluster/types/attributes.rb +90 -0
- data/lib/pangea/resources/aws_rds_global_cluster/types/backup_config.rb +52 -0
- data/lib/pangea/resources/aws_rds_global_cluster/types/configs.rb +47 -0
- data/lib/pangea/resources/aws_rds_global_cluster/types.rb +8 -413
- data/lib/pangea/resources/aws_rds_proxy/types/attributes.rb +73 -0
- data/lib/pangea/resources/aws_rds_proxy/types/configs.rb +43 -0
- data/lib/pangea/resources/aws_rds_proxy/types/nested_types.rb +61 -0
- data/lib/pangea/resources/aws_rds_proxy/types.rb +9 -398
- data/lib/pangea/resources/aws_redshift_cluster/types/capacity_calculator.rb +88 -0
- data/lib/pangea/resources/aws_redshift_cluster/types/cost_estimator.rb +66 -0
- data/lib/pangea/resources/aws_redshift_cluster/types/feature_checks.rb +46 -0
- data/lib/pangea/resources/aws_redshift_cluster/types/validators.rb +73 -0
- data/lib/pangea/resources/aws_redshift_cluster/types/workload_parameters.rb +67 -0
- data/lib/pangea/resources/aws_redshift_cluster/types.rb +114 -284
- data/lib/pangea/resources/aws_redshift_parameter_group/types/class_methods.rb +114 -0
- data/lib/pangea/resources/aws_redshift_parameter_group/types/instance_methods.rb +88 -0
- data/lib/pangea/resources/aws_redshift_parameter_group/types/validation.rb +53 -0
- data/lib/pangea/resources/aws_redshift_parameter_group/types.rb +35 -188
- data/lib/pangea/resources/aws_redshift_snapshot_schedule/types/attributes.rb +46 -0
- data/lib/pangea/resources/aws_redshift_snapshot_schedule/types/instance_methods.rb +92 -0
- data/lib/pangea/resources/aws_redshift_snapshot_schedule/types/templates.rb +53 -0
- data/lib/pangea/resources/aws_redshift_snapshot_schedule/types/validation.rb +71 -0
- data/lib/pangea/resources/aws_redshift_snapshot_schedule/types.rb +7 -205
- data/lib/pangea/resources/aws_resources/analytics.rb +22 -0
- data/lib/pangea/resources/aws_resources/compute.rb +31 -0
- data/lib/pangea/resources/aws_resources/core.rb +35 -0
- data/lib/pangea/resources/aws_resources/database.rb +27 -0
- data/lib/pangea/resources/aws_resources/devops.rb +19 -0
- data/lib/pangea/resources/aws_resources/governance.rb +20 -0
- data/lib/pangea/resources/aws_resources/integration.rb +24 -0
- data/lib/pangea/resources/aws_resources/management.rb +33 -0
- data/lib/pangea/resources/aws_resources/ml.rb +15 -0
- data/lib/pangea/resources/aws_resources/security.rb +30 -0
- data/lib/pangea/resources/aws_resources/specialty.rb +67 -0
- data/lib/pangea/resources/aws_resources/storage.rb +23 -0
- data/lib/pangea/resources/aws_resources.rb +15 -338
- data/lib/pangea/resources/aws_route/types.rb +1 -1
- data/lib/pangea/resources/aws_route53_delegation_set/types.rb +1 -1
- data/lib/pangea/resources/aws_route53_health_check/types/attributes.rb +193 -0
- data/lib/pangea/resources/aws_route53_health_check/types/configs.rb +84 -0
- data/lib/pangea/resources/aws_route53_health_check/types.rb +6 -375
- data/lib/pangea/resources/aws_route53_query_log/types.rb +1 -1
- data/lib/pangea/resources/aws_route53_record/types/attributes.rb +149 -0
- data/lib/pangea/resources/aws_route53_record/types/configs.rb +124 -0
- data/lib/pangea/resources/aws_route53_record/types/instance_methods.rb +80 -0
- data/lib/pangea/resources/aws_route53_record/types/validation.rb +82 -0
- data/lib/pangea/resources/aws_route53_record/types.rb +6 -383
- data/lib/pangea/resources/aws_route53_zone/types/attributes.rb +85 -0
- data/lib/pangea/resources/aws_route53_zone/types/configs.rb +73 -0
- data/lib/pangea/resources/aws_route53_zone/types/instance_methods.rb +90 -0
- data/lib/pangea/resources/aws_route53_zone/types/validation.rb +42 -0
- data/lib/pangea/resources/aws_route53_zone/types.rb +5 -234
- data/lib/pangea/resources/aws_s3_access_point/types.rb +1 -1
- data/lib/pangea/resources/aws_s3_bucket/builders/configuration_builder.rb +105 -0
- data/lib/pangea/resources/aws_s3_bucket/builders/lifecycle_builder.rb +101 -0
- data/lib/pangea/resources/aws_s3_bucket/resource.rb +56 -175
- data/lib/pangea/resources/aws_s3_bucket/types/cors_rule.rb +37 -0
- data/lib/pangea/resources/aws_s3_bucket/types/lifecycle_rule.rb +57 -0
- data/lib/pangea/resources/aws_s3_bucket/types/server_side_encryption.rb +51 -0
- data/lib/pangea/resources/aws_s3_bucket/types.rb +130 -162
- data/lib/pangea/resources/aws_s3_bucket_inventory/types/helpers.rb +113 -0
- data/lib/pangea/resources/aws_s3_bucket_inventory/types.rb +3 -99
- data/lib/pangea/resources/aws_s3_bucket_lifecycle_configuration/types/attributes.rb +55 -0
- data/lib/pangea/resources/aws_s3_bucket_lifecycle_configuration/types/expiration.rb +39 -0
- data/lib/pangea/resources/aws_s3_bucket_lifecycle_configuration/types/filter.rb +54 -0
- data/lib/pangea/resources/aws_s3_bucket_lifecycle_configuration/types/rule.rb +49 -0
- data/lib/pangea/resources/aws_s3_bucket_lifecycle_configuration/types/transition.rb +51 -0
- data/lib/pangea/resources/aws_s3_bucket_lifecycle_configuration/types.rb +14 -202
- data/lib/pangea/resources/aws_s3_bucket_notification/types/helpers.rb +76 -0
- data/lib/pangea/resources/aws_s3_bucket_notification/types/notification_config.rb +74 -0
- data/lib/pangea/resources/aws_s3_bucket_notification/types/s3_events.rb +54 -0
- data/lib/pangea/resources/aws_s3_bucket_notification/types/validators.rb +64 -0
- data/lib/pangea/resources/aws_s3_bucket_notification/types.rb +26 -188
- data/lib/pangea/resources/aws_s3_bucket_object_lock_configuration/types/instance_methods.rb +130 -0
- data/lib/pangea/resources/aws_s3_bucket_object_lock_configuration/types/validation.rb +75 -0
- data/lib/pangea/resources/aws_s3_bucket_object_lock_configuration/types.rb +39 -202
- data/lib/pangea/resources/aws_s3_bucket_replication_configuration/types/destination.rb +84 -0
- data/lib/pangea/resources/aws_s3_bucket_replication_configuration/types/filter.rb +47 -0
- data/lib/pangea/resources/aws_s3_bucket_replication_configuration/types/helpers.rb +108 -0
- data/lib/pangea/resources/aws_s3_bucket_replication_configuration/types/rule.rb +78 -0
- data/lib/pangea/resources/aws_s3_bucket_replication_configuration/types/validators.rb +117 -0
- data/lib/pangea/resources/aws_s3_bucket_replication_configuration/types.rb +22 -272
- data/lib/pangea/resources/aws_s3_bucket_website_configuration/types/attributes.rb +57 -0
- data/lib/pangea/resources/aws_s3_bucket_website_configuration/types/documents.rb +61 -0
- data/lib/pangea/resources/aws_s3_bucket_website_configuration/types/redirect.rb +41 -0
- data/lib/pangea/resources/aws_s3_bucket_website_configuration/types/routing_rules.rb +99 -0
- data/lib/pangea/resources/aws_s3_bucket_website_configuration/types.rb +7 -385
- data/lib/pangea/resources/aws_s3_multi_region_access_point/types.rb +1 -1
- data/lib/pangea/resources/aws_s3_object/types/attributes.rb +112 -0
- data/lib/pangea/resources/aws_s3_object/types/instance_methods.rb +112 -0
- data/lib/pangea/resources/aws_s3_object/types/validation.rb +57 -0
- data/lib/pangea/resources/aws_s3_object/types.rb +4 -198
- data/lib/pangea/resources/aws_sagemaker_domain/types/app_settings_types.rb +91 -0
- data/lib/pangea/resources/aws_sagemaker_domain/types/base_types.rb +70 -0
- data/lib/pangea/resources/aws_sagemaker_domain/types/user_settings_types.rb +45 -0
- data/lib/pangea/resources/aws_sagemaker_domain/types.rb +80 -207
- data/lib/pangea/resources/aws_sagemaker_endpoint/reference_attributes.rb +119 -0
- data/lib/pangea/resources/aws_sagemaker_endpoint/resource.rb +2 -80
- data/lib/pangea/resources/aws_sagemaker_endpoint/types/computed_properties.rb +100 -0
- data/lib/pangea/resources/aws_sagemaker_endpoint/types/deployment_analysis.rb +108 -0
- data/lib/pangea/resources/aws_sagemaker_endpoint/types/deployment_config.rb +54 -0
- data/lib/pangea/resources/aws_sagemaker_endpoint/types.rb +62 -235
- data/lib/pangea/resources/aws_sagemaker_endpoint_configuration/reference_attributes.rb +130 -0
- data/lib/pangea/resources/aws_sagemaker_endpoint_configuration/resource.rb +5 -45
- data/lib/pangea/resources/aws_sagemaker_endpoint_configuration/types/attributes.rb +155 -0
- data/lib/pangea/resources/aws_sagemaker_endpoint_configuration/types/variant_types.rb +73 -0
- data/lib/pangea/resources/aws_sagemaker_endpoint_configuration/types.rb +8 -347
- data/lib/pangea/resources/aws_sagemaker_model/types/attributes.rb +62 -0
- data/lib/pangea/resources/aws_sagemaker_model/types/helpers.rb +73 -0
- data/lib/pangea/resources/aws_sagemaker_model/types/validators.rb +70 -0
- data/lib/pangea/resources/aws_sagemaker_model/types.rb +4 -327
- data/lib/pangea/resources/aws_sagemaker_notebook_instance/types/helpers.rb +73 -0
- data/lib/pangea/resources/aws_sagemaker_notebook_instance/types/pricing.rb +118 -0
- data/lib/pangea/resources/aws_sagemaker_notebook_instance/types/security.rb +81 -0
- data/lib/pangea/resources/aws_sagemaker_notebook_instance/types/validators.rb +97 -0
- data/lib/pangea/resources/aws_sagemaker_notebook_instance/types.rb +29 -240
- data/lib/pangea/resources/aws_sagemaker_training_job/types/attributes.rb +86 -0
- data/lib/pangea/resources/aws_sagemaker_training_job/types/configs.rb +38 -0
- data/lib/pangea/resources/aws_sagemaker_training_job/types/enums.rb +27 -0
- data/lib/pangea/resources/aws_sagemaker_training_job/types/validation.rb +70 -0
- data/lib/pangea/resources/aws_sagemaker_training_job/types.rb +5 -466
- data/lib/pangea/resources/aws_sagemaker_user_profile/types/attributes.rb +68 -0
- data/lib/pangea/resources/aws_sagemaker_user_profile/types/helpers.rb +67 -0
- data/lib/pangea/resources/aws_sagemaker_user_profile/types/validators.rb +60 -0
- data/lib/pangea/resources/aws_sagemaker_user_profile/types.rb +4 -327
- data/lib/pangea/resources/aws_security_group/types.rb +3 -3
- data/lib/pangea/resources/aws_sfn_state_machine/types/attributes.rb +51 -0
- data/lib/pangea/resources/aws_sfn_state_machine/types/builders.rb +88 -0
- data/lib/pangea/resources/aws_sfn_state_machine/types/validators.rb +86 -0
- data/lib/pangea/resources/aws_sfn_state_machine/types.rb +5 -344
- data/lib/pangea/resources/aws_snow_family/datasync.rb +124 -0
- data/lib/pangea/resources/aws_snow_family/snowball.rb +95 -0
- data/lib/pangea/resources/aws_snow_family/snowcone.rb +82 -0
- data/lib/pangea/resources/aws_snow_family/snowmobile.rb +51 -0
- data/lib/pangea/resources/aws_snow_family.rb +10 -392
- data/lib/pangea/resources/aws_sns_subscription/types/helpers.rb +73 -0
- data/lib/pangea/resources/aws_sns_subscription/types/validators.rb +144 -0
- data/lib/pangea/resources/aws_sns_subscription/types.rb +28 -191
- data/lib/pangea/resources/aws_sns_topic/types.rb +1 -1
- data/lib/pangea/resources/aws_sqs_queue/types.rb +1 -1
- data/lib/pangea/resources/aws_ssm_document/types/attributes.rb +101 -0
- data/lib/pangea/resources/aws_ssm_document/types/configs.rb +56 -0
- data/lib/pangea/resources/aws_ssm_document/types.rb +6 -405
- data/lib/pangea/resources/aws_ssm_maintenance_window/types/attributes.rb +188 -0
- data/lib/pangea/resources/aws_ssm_maintenance_window/types/configs.rb +88 -0
- data/lib/pangea/resources/aws_ssm_maintenance_window/types.rb +6 -362
- data/lib/pangea/resources/aws_ssm_parameter/types/configs.rb +118 -0
- data/lib/pangea/resources/aws_ssm_parameter/types/helpers.rb +101 -0
- data/lib/pangea/resources/aws_ssm_parameter/types/validation.rb +83 -0
- data/lib/pangea/resources/aws_ssm_parameter/types.rb +32 -250
- data/lib/pangea/resources/aws_ssm_patch_baseline/types/attributes.rb +75 -0
- data/lib/pangea/resources/aws_ssm_patch_baseline/types/configs.rb +94 -0
- data/lib/pangea/resources/aws_ssm_patch_baseline/types/instance_methods.rb +97 -0
- data/lib/pangea/resources/aws_ssm_patch_baseline/types/validation.rb +99 -0
- data/lib/pangea/resources/aws_ssm_patch_baseline/types.rb +7 -428
- data/lib/pangea/resources/aws_subnet/resource.rb +7 -13
- data/lib/pangea/resources/aws_subnet/types.rb +1 -1
- data/lib/pangea/resources/aws_timestream_access_policy/types.rb +1 -1
- data/lib/pangea/resources/aws_timestream_batch_load_task/types.rb +4 -4
- data/lib/pangea/resources/aws_timestream_database/types.rb +1 -1
- data/lib/pangea/resources/aws_timestream_influx_db_instance/types.rb +1 -1
- data/lib/pangea/resources/aws_timestream_scheduled_query/types.rb +5 -5
- data/lib/pangea/resources/aws_timestream_table/types.rb +4 -4
- data/lib/pangea/resources/aws_timestream_table_retention_properties/types.rb +1 -1
- data/lib/pangea/resources/aws_volume_attachment/types.rb +1 -1
- data/lib/pangea/resources/aws_vpc_dhcp_options_association/types.rb +1 -1
- data/lib/pangea/resources/aws_vpc_endpoint/types.rb +1 -1
- data/lib/pangea/resources/aws_vpc_endpoint_connection_accepter/types.rb +1 -1
- data/lib/pangea/resources/aws_vpc_endpoint_connection_notification/types.rb +1 -1
- data/lib/pangea/resources/aws_vpc_endpoint_route_table_association/types.rb +1 -1
- data/lib/pangea/resources/aws_vpc_endpoint_service/types.rb +1 -1
- data/lib/pangea/resources/aws_vpc_endpoint_service_allowed_principal/types.rb +1 -1
- data/lib/pangea/resources/aws_vpc_endpoint_subnet_association/types.rb +1 -1
- data/lib/pangea/resources/aws_vpc_network_performance_metric_subscription/types.rb +1 -1
- data/lib/pangea/resources/aws_vpc_peering_connection/types.rb +3 -3
- data/lib/pangea/resources/aws_vpc_peering_connection_accepter/types.rb +1 -1
- data/lib/pangea/resources/aws_vpc_peering_connection_options/types.rb +1 -1
- data/lib/pangea/resources/aws_vpc_security_group_egress_rule/types.rb +1 -1
- data/lib/pangea/resources/aws_vpc_security_group_ingress_rule/types.rb +1 -1
- data/lib/pangea/resources/aws_vpn_connection/types.rb +1 -1
- data/lib/pangea/resources/aws_vpn_gateway/types.rb +1 -1
- data/lib/pangea/resources/aws_wafv2_regex_pattern_set/types/configs.rb +116 -0
- data/lib/pangea/resources/aws_wafv2_regex_pattern_set/types/helpers.rb +106 -0
- data/lib/pangea/resources/aws_wafv2_regex_pattern_set/types.rb +66 -226
- data/lib/pangea/resources/aws_wafv2_rule_group/resource/actions.rb +83 -0
- data/lib/pangea/resources/aws_wafv2_rule_group/resource/dsl_builder.rb +107 -0
- data/lib/pangea/resources/aws_wafv2_rule_group/resource/field_to_match.rb +45 -0
- data/lib/pangea/resources/aws_wafv2_rule_group/resource/statements.rb +137 -0
- data/lib/pangea/resources/aws_wafv2_rule_group/resource.rb +127 -379
- data/lib/pangea/resources/aws_wafv2_rule_group/types/actions.rb +78 -0
- data/lib/pangea/resources/aws_wafv2_rule_group/types/computed.rb +65 -0
- data/lib/pangea/resources/aws_wafv2_rule_group/types/rule_schema.rb +53 -0
- data/lib/pangea/resources/aws_wafv2_rule_group/types/schemas.rb +74 -0
- data/lib/pangea/resources/aws_wafv2_rule_group/types/validators.rb +121 -0
- data/lib/pangea/resources/aws_wafv2_rule_group/types.rb +14 -231
- data/lib/pangea/resources/aws_wafv2_web_acl/resource/dsl_builder/default_action.rb +60 -0
- data/lib/pangea/resources/aws_wafv2_web_acl/resource/dsl_builder/field_to_match.rb +65 -0
- data/lib/pangea/resources/aws_wafv2_web_acl/resource/dsl_builder/rules.rb +89 -0
- data/lib/pangea/resources/aws_wafv2_web_acl/resource/dsl_builder/statements.rb +166 -0
- data/lib/pangea/resources/aws_wafv2_web_acl/resource/dsl_builder.rb +42 -0
- data/lib/pangea/resources/aws_wafv2_web_acl/resource.rb +48 -450
- data/lib/pangea/resources/aws_wafv2_web_acl/types/default_action.rb +57 -0
- data/lib/pangea/resources/aws_wafv2_web_acl/types/rule.rb +60 -0
- data/lib/pangea/resources/aws_wafv2_web_acl/types/rule_action.rb +76 -0
- data/lib/pangea/resources/aws_wafv2_web_acl/types/statement.rb +176 -0
- data/lib/pangea/resources/aws_wafv2_web_acl/types/visibility_config.rb +35 -0
- data/lib/pangea/resources/aws_wafv2_web_acl/types/web_acl_attributes.rb +158 -0
- data/lib/pangea/resources/aws_wafv2_web_acl/types.rb +8 -526
- data/lib/pangea/resources/aws_wavelength/application_deployment.rb +78 -0
- data/lib/pangea/resources/aws_wavelength/carrier_gateway.rb +62 -0
- data/lib/pangea/resources/aws_wavelength/deployment.rb +68 -0
- data/lib/pangea/resources/aws_wavelength/edge_location.rb +66 -0
- data/lib/pangea/resources/aws_wavelength/network_interface.rb +77 -0
- data/lib/pangea/resources/aws_wavelength/workload.rb +74 -0
- data/lib/pangea/resources/aws_wavelength.rb +11 -307
- data/lib/pangea/resources/aws_workspaces_bundle/types/compute.rb +70 -0
- data/lib/pangea/resources/aws_workspaces_bundle/types/storage.rb +71 -0
- data/lib/pangea/resources/aws_workspaces_bundle/types.rb +40 -165
- data/lib/pangea/resources/aws_workspaces_directory/types/self_service_permissions_type.rb +54 -0
- data/lib/pangea/resources/aws_workspaces_directory/types/workspace_access_properties_type.rb +68 -0
- data/lib/pangea/resources/aws_workspaces_directory/types/workspace_creation_properties_type.rb +61 -0
- data/lib/pangea/resources/aws_workspaces_directory/types.rb +13 -168
- data/lib/pangea/resources/builders/output_builder.rb +158 -0
- data/lib/pangea/resources/cloudflare_access_rule/resource.rb +71 -0
- data/lib/pangea/resources/cloudflare_access_rule/types.rb +93 -0
- data/lib/pangea/resources/cloudflare_account/resource.rb +28 -0
- data/lib/pangea/resources/cloudflare_account/types.rb +12 -0
- data/lib/pangea/resources/cloudflare_account_dns_settings/resource.rb +27 -0
- data/lib/pangea/resources/cloudflare_account_dns_settings/types.rb +11 -0
- data/lib/pangea/resources/cloudflare_account_dns_settings_internal_view/resource.rb +27 -0
- data/lib/pangea/resources/cloudflare_account_dns_settings_internal_view/types.rb +11 -0
- data/lib/pangea/resources/cloudflare_account_member/resource.rb +29 -0
- data/lib/pangea/resources/cloudflare_account_member/types.rb +13 -0
- data/lib/pangea/resources/cloudflare_account_subscription/resource.rb +27 -0
- data/lib/pangea/resources/cloudflare_account_subscription/types.rb +11 -0
- data/lib/pangea/resources/cloudflare_account_token/resource.rb +27 -0
- data/lib/pangea/resources/cloudflare_account_token/types.rb +11 -0
- data/lib/pangea/resources/cloudflare_address_map/resource.rb +26 -0
- data/lib/pangea/resources/cloudflare_address_map/types.rb +10 -0
- data/lib/pangea/resources/cloudflare_api_shield/resource.rb +27 -0
- data/lib/pangea/resources/cloudflare_api_shield/types.rb +11 -0
- data/lib/pangea/resources/cloudflare_api_shield_discovery_operation/resource.rb +27 -0
- data/lib/pangea/resources/cloudflare_api_shield_discovery_operation/types.rb +11 -0
- data/lib/pangea/resources/cloudflare_api_shield_operation/resource.rb +29 -0
- data/lib/pangea/resources/cloudflare_api_shield_operation/types.rb +13 -0
- data/lib/pangea/resources/cloudflare_api_shield_operation_schema_validation_settings/resource.rb +27 -0
- data/lib/pangea/resources/cloudflare_api_shield_operation_schema_validation_settings/types.rb +11 -0
- data/lib/pangea/resources/cloudflare_api_shield_schema/resource.rb +30 -0
- data/lib/pangea/resources/cloudflare_api_shield_schema/types.rb +14 -0
- data/lib/pangea/resources/cloudflare_api_shield_schema_validation_settings/resource.rb +27 -0
- data/lib/pangea/resources/cloudflare_api_shield_schema_validation_settings/types.rb +11 -0
- data/lib/pangea/resources/cloudflare_api_token/resource.rb +33 -0
- data/lib/pangea/resources/cloudflare_api_token/types.rb +14 -0
- data/lib/pangea/resources/cloudflare_argo/resource.rb +91 -0
- data/lib/pangea/resources/cloudflare_argo/types.rb +92 -0
- data/lib/pangea/resources/cloudflare_authenticated_origin_pulls/resource.rb +29 -0
- data/lib/pangea/resources/cloudflare_authenticated_origin_pulls/types.rb +13 -0
- data/lib/pangea/resources/cloudflare_authenticated_origin_pulls_certificate/resource.rb +33 -0
- data/lib/pangea/resources/cloudflare_authenticated_origin_pulls_certificate/types.rb +13 -0
- data/lib/pangea/resources/cloudflare_authenticated_origin_pulls_settings/resource.rb +26 -0
- data/lib/pangea/resources/cloudflare_authenticated_origin_pulls_settings/types.rb +10 -0
- data/lib/pangea/resources/cloudflare_bot_management/resource.rb +31 -0
- data/lib/pangea/resources/cloudflare_bot_management/types.rb +15 -0
- data/lib/pangea/resources/cloudflare_byo_ip_prefix/resource.rb +27 -0
- data/lib/pangea/resources/cloudflare_byo_ip_prefix/types.rb +11 -0
- data/lib/pangea/resources/cloudflare_calls_sfu_app/resource.rb +27 -0
- data/lib/pangea/resources/cloudflare_calls_sfu_app/types.rb +11 -0
- data/lib/pangea/resources/cloudflare_calls_turn_app/resource.rb +27 -0
- data/lib/pangea/resources/cloudflare_calls_turn_app/types.rb +11 -0
- data/lib/pangea/resources/cloudflare_certificate_pack/resource.rb +26 -0
- data/lib/pangea/resources/cloudflare_certificate_pack/types.rb +10 -0
- data/lib/pangea/resources/cloudflare_cloud_connector_rules/resource.rb +27 -0
- data/lib/pangea/resources/cloudflare_cloud_connector_rules/types.rb +11 -0
- data/lib/pangea/resources/cloudflare_cloudforce_one_request/resource.rb +27 -0
- data/lib/pangea/resources/cloudflare_cloudforce_one_request/types.rb +11 -0
- data/lib/pangea/resources/cloudflare_cloudforce_one_request_asset/resource.rb +27 -0
- data/lib/pangea/resources/cloudflare_cloudforce_one_request_asset/types.rb +11 -0
- data/lib/pangea/resources/cloudflare_cloudforce_one_request_message/resource.rb +27 -0
- data/lib/pangea/resources/cloudflare_cloudforce_one_request_message/types.rb +11 -0
- data/lib/pangea/resources/cloudflare_cloudforce_one_request_priority/resource.rb +27 -0
- data/lib/pangea/resources/cloudflare_cloudforce_one_request_priority/types.rb +11 -0
- data/lib/pangea/resources/cloudflare_content_scanning/resource.rb +27 -0
- data/lib/pangea/resources/cloudflare_content_scanning/types.rb +11 -0
- data/lib/pangea/resources/cloudflare_content_scanning_expression/resource.rb +27 -0
- data/lib/pangea/resources/cloudflare_content_scanning_expression/types.rb +11 -0
- data/lib/pangea/resources/cloudflare_custom_hostname/resource.rb +157 -0
- data/lib/pangea/resources/cloudflare_custom_hostname/types/ssl_types.rb +145 -0
- data/lib/pangea/resources/cloudflare_custom_hostname/types.rb +107 -0
- data/lib/pangea/resources/cloudflare_custom_hostname_fallback_origin/resource.rb +27 -0
- data/lib/pangea/resources/cloudflare_custom_hostname_fallback_origin/types.rb +11 -0
- data/lib/pangea/resources/cloudflare_custom_pages/resource.rb +27 -0
- data/lib/pangea/resources/cloudflare_custom_pages/types.rb +11 -0
- data/lib/pangea/resources/cloudflare_custom_ssl/resource.rb +36 -0
- data/lib/pangea/resources/cloudflare_custom_ssl/types.rb +16 -0
- data/lib/pangea/resources/cloudflare_d1_database/resource.rb +92 -0
- data/lib/pangea/resources/cloudflare_d1_database/types.rb +110 -0
- data/lib/pangea/resources/cloudflare_dns_firewall/resource.rb +27 -0
- data/lib/pangea/resources/cloudflare_dns_firewall/types.rb +11 -0
- data/lib/pangea/resources/cloudflare_dns_zone_transfers_acl/resource.rb +27 -0
- data/lib/pangea/resources/cloudflare_dns_zone_transfers_acl/types.rb +11 -0
- data/lib/pangea/resources/cloudflare_dns_zone_transfers_incoming/resource.rb +27 -0
- data/lib/pangea/resources/cloudflare_dns_zone_transfers_incoming/types.rb +11 -0
- data/lib/pangea/resources/cloudflare_dns_zone_transfers_outgoing/resource.rb +26 -0
- data/lib/pangea/resources/cloudflare_dns_zone_transfers_outgoing/types.rb +10 -0
- data/lib/pangea/resources/cloudflare_dns_zone_transfers_peer/resource.rb +26 -0
- data/lib/pangea/resources/cloudflare_dns_zone_transfers_peer/types.rb +10 -0
- data/lib/pangea/resources/cloudflare_dns_zone_transfers_tsig/resource.rb +26 -0
- data/lib/pangea/resources/cloudflare_dns_zone_transfers_tsig/types.rb +10 -0
- data/lib/pangea/resources/cloudflare_email_routing_address/resource.rb +26 -0
- data/lib/pangea/resources/cloudflare_email_routing_address/types.rb +10 -0
- data/lib/pangea/resources/cloudflare_email_routing_catch_all/resource.rb +26 -0
- data/lib/pangea/resources/cloudflare_email_routing_catch_all/types.rb +10 -0
- data/lib/pangea/resources/cloudflare_email_routing_dns/resource.rb +27 -0
- data/lib/pangea/resources/cloudflare_email_routing_dns/types.rb +11 -0
- data/lib/pangea/resources/cloudflare_email_routing_rule/resource.rb +26 -0
- data/lib/pangea/resources/cloudflare_email_routing_rule/types.rb +10 -0
- data/lib/pangea/resources/cloudflare_email_routing_settings/resource.rb +26 -0
- data/lib/pangea/resources/cloudflare_email_routing_settings/types.rb +10 -0
- data/lib/pangea/resources/cloudflare_email_security_block_sender/resource.rb +27 -0
- data/lib/pangea/resources/cloudflare_email_security_block_sender/types.rb +11 -0
- data/lib/pangea/resources/cloudflare_email_security_impersonation_registry/resource.rb +27 -0
- data/lib/pangea/resources/cloudflare_email_security_impersonation_registry/types.rb +11 -0
- data/lib/pangea/resources/cloudflare_email_security_trusted_domains/resource.rb +27 -0
- data/lib/pangea/resources/cloudflare_email_security_trusted_domains/types.rb +11 -0
- data/lib/pangea/resources/cloudflare_filter/resource.rb +64 -0
- data/lib/pangea/resources/cloudflare_filter/types.rb +54 -0
- data/lib/pangea/resources/cloudflare_firewall_rule/resource.rb +70 -0
- data/lib/pangea/resources/cloudflare_firewall_rule/types.rb +64 -0
- data/lib/pangea/resources/cloudflare_healthcheck/resource.rb +138 -0
- data/lib/pangea/resources/cloudflare_healthcheck/types.rb +192 -0
- data/lib/pangea/resources/cloudflare_hostname_tls_setting/resource.rb +26 -0
- data/lib/pangea/resources/cloudflare_hostname_tls_setting/types.rb +10 -0
- data/lib/pangea/resources/cloudflare_hyperdrive_config/resource.rb +176 -0
- data/lib/pangea/resources/cloudflare_hyperdrive_config/types/attributes.rb +125 -0
- data/lib/pangea/resources/cloudflare_hyperdrive_config/types/caching.rb +52 -0
- data/lib/pangea/resources/cloudflare_hyperdrive_config/types/enums.rb +37 -0
- data/lib/pangea/resources/cloudflare_hyperdrive_config/types/mtls.rb +52 -0
- data/lib/pangea/resources/cloudflare_hyperdrive_config/types/origin.rb +89 -0
- data/lib/pangea/resources/cloudflare_hyperdrive_config/types.rb +23 -0
- data/lib/pangea/resources/cloudflare_image/resource.rb +27 -0
- data/lib/pangea/resources/cloudflare_image/types.rb +11 -0
- data/lib/pangea/resources/cloudflare_image_variant/resource.rb +26 -0
- data/lib/pangea/resources/cloudflare_image_variant/types.rb +10 -0
- data/lib/pangea/resources/cloudflare_keyless_certificate/resource.rb +26 -0
- data/lib/pangea/resources/cloudflare_keyless_certificate/types.rb +10 -0
- data/lib/pangea/resources/cloudflare_leaked_credential_check/resource.rb +27 -0
- data/lib/pangea/resources/cloudflare_leaked_credential_check/types.rb +11 -0
- data/lib/pangea/resources/cloudflare_leaked_credential_check_rule/resource.rb +27 -0
- data/lib/pangea/resources/cloudflare_leaked_credential_check_rule/types.rb +11 -0
- data/lib/pangea/resources/cloudflare_list/resource.rb +57 -0
- data/lib/pangea/resources/cloudflare_list/types.rb +49 -0
- data/lib/pangea/resources/cloudflare_list_item/resource.rb +130 -0
- data/lib/pangea/resources/cloudflare_list_item/types.rb +183 -0
- data/lib/pangea/resources/cloudflare_load_balancer/resource.rb +97 -0
- data/lib/pangea/resources/cloudflare_load_balancer/types.rb +75 -0
- data/lib/pangea/resources/cloudflare_load_balancer_monitor/resource.rb +78 -0
- data/lib/pangea/resources/cloudflare_load_balancer_monitor/types.rb +62 -0
- data/lib/pangea/resources/cloudflare_load_balancer_pool/resource.rb +78 -0
- data/lib/pangea/resources/cloudflare_load_balancer_pool/types.rb +81 -0
- data/lib/pangea/resources/cloudflare_logpull_retention/resource.rb +27 -0
- data/lib/pangea/resources/cloudflare_logpull_retention/types.rb +11 -0
- data/lib/pangea/resources/cloudflare_logpush_job/resource.rb +40 -0
- data/lib/pangea/resources/cloudflare_logpush_job/types.rb +24 -0
- data/lib/pangea/resources/cloudflare_logpush_ownership_challenge/resource.rb +27 -0
- data/lib/pangea/resources/cloudflare_logpush_ownership_challenge/types.rb +11 -0
- data/lib/pangea/resources/cloudflare_magic_network_monitoring_configuration/resource.rb +27 -0
- data/lib/pangea/resources/cloudflare_magic_network_monitoring_configuration/types.rb +11 -0
- data/lib/pangea/resources/cloudflare_magic_network_monitoring_rule/resource.rb +27 -0
- data/lib/pangea/resources/cloudflare_magic_network_monitoring_rule/types.rb +11 -0
- data/lib/pangea/resources/cloudflare_magic_transit_connector/resource.rb +27 -0
- data/lib/pangea/resources/cloudflare_magic_transit_connector/types.rb +11 -0
- data/lib/pangea/resources/cloudflare_magic_transit_site/resource.rb +27 -0
- data/lib/pangea/resources/cloudflare_magic_transit_site/types.rb +11 -0
- data/lib/pangea/resources/cloudflare_magic_transit_site_acl/resource.rb +27 -0
- data/lib/pangea/resources/cloudflare_magic_transit_site_acl/types.rb +11 -0
- data/lib/pangea/resources/cloudflare_magic_transit_site_lan/resource.rb +27 -0
- data/lib/pangea/resources/cloudflare_magic_transit_site_lan/types.rb +11 -0
- data/lib/pangea/resources/cloudflare_magic_transit_site_wan/resource.rb +27 -0
- data/lib/pangea/resources/cloudflare_magic_transit_site_wan/types.rb +11 -0
- data/lib/pangea/resources/cloudflare_magic_wan_gre_tunnel/resource.rb +27 -0
- data/lib/pangea/resources/cloudflare_magic_wan_gre_tunnel/types.rb +11 -0
- data/lib/pangea/resources/cloudflare_magic_wan_ipsec_tunnel/resource.rb +27 -0
- data/lib/pangea/resources/cloudflare_magic_wan_ipsec_tunnel/types.rb +11 -0
- data/lib/pangea/resources/cloudflare_magic_wan_static_route/resource.rb +27 -0
- data/lib/pangea/resources/cloudflare_magic_wan_static_route/types.rb +11 -0
- data/lib/pangea/resources/cloudflare_managed_transforms/resource.rb +36 -0
- data/lib/pangea/resources/cloudflare_managed_transforms/types.rb +12 -0
- data/lib/pangea/resources/cloudflare_mtls_certificate/resource.rb +34 -0
- data/lib/pangea/resources/cloudflare_mtls_certificate/types.rb +14 -0
- data/lib/pangea/resources/cloudflare_notification_policy/resource.rb +34 -0
- data/lib/pangea/resources/cloudflare_notification_policy/types.rb +18 -0
- data/lib/pangea/resources/cloudflare_notification_policy_webhooks/resource.rb +27 -0
- data/lib/pangea/resources/cloudflare_notification_policy_webhooks/types.rb +11 -0
- data/lib/pangea/resources/cloudflare_observatory_scheduled_test/resource.rb +27 -0
- data/lib/pangea/resources/cloudflare_observatory_scheduled_test/types.rb +11 -0
- data/lib/pangea/resources/cloudflare_organization/resource.rb +27 -0
- data/lib/pangea/resources/cloudflare_organization/types.rb +11 -0
- data/lib/pangea/resources/cloudflare_organization_profile/resource.rb +27 -0
- data/lib/pangea/resources/cloudflare_organization_profile/types.rb +11 -0
- data/lib/pangea/resources/cloudflare_origin_ca_certificate/resource.rb +97 -0
- data/lib/pangea/resources/cloudflare_origin_ca_certificate/types.rb +125 -0
- data/lib/pangea/resources/cloudflare_page_rule/resource.rb +78 -0
- data/lib/pangea/resources/cloudflare_page_rule/types.rb +71 -0
- data/lib/pangea/resources/cloudflare_page_shield_policy/resource.rb +27 -0
- data/lib/pangea/resources/cloudflare_page_shield_policy/types.rb +11 -0
- data/lib/pangea/resources/cloudflare_pages_domain/resource.rb +28 -0
- data/lib/pangea/resources/cloudflare_pages_domain/types.rb +12 -0
- data/lib/pangea/resources/cloudflare_pages_project/resource/deployment_config.rb +80 -0
- data/lib/pangea/resources/cloudflare_pages_project/resource/main.rb +75 -0
- data/lib/pangea/resources/cloudflare_pages_project/resource.rb +19 -0
- data/lib/pangea/resources/cloudflare_pages_project/types/attributes.rb +51 -0
- data/lib/pangea/resources/cloudflare_pages_project/types/bindings.rb +38 -0
- data/lib/pangea/resources/cloudflare_pages_project/types/build_config.rb +55 -0
- data/lib/pangea/resources/cloudflare_pages_project/types/deployment_config.rb +83 -0
- data/lib/pangea/resources/cloudflare_pages_project/types.rb +27 -0
- data/lib/pangea/resources/cloudflare_queue/resource.rb +108 -0
- data/lib/pangea/resources/cloudflare_queue/types.rb +132 -0
- data/lib/pangea/resources/cloudflare_queue_consumer/resource.rb +31 -0
- data/lib/pangea/resources/cloudflare_queue_consumer/types.rb +15 -0
- data/lib/pangea/resources/cloudflare_r2_bucket/resource.rb +91 -0
- data/lib/pangea/resources/cloudflare_r2_bucket/types.rb +101 -0
- data/lib/pangea/resources/cloudflare_r2_bucket_cors/resource.rb +130 -0
- data/lib/pangea/resources/cloudflare_r2_bucket_cors/types/attributes.rb +105 -0
- data/lib/pangea/resources/cloudflare_r2_bucket_cors/types/cors_allowed.rb +59 -0
- data/lib/pangea/resources/cloudflare_r2_bucket_cors/types/cors_method.rb +34 -0
- data/lib/pangea/resources/cloudflare_r2_bucket_cors/types/cors_rule.rb +74 -0
- data/lib/pangea/resources/cloudflare_r2_bucket_cors/types.rb +22 -0
- data/lib/pangea/resources/cloudflare_r2_bucket_event_notification/resource.rb +31 -0
- data/lib/pangea/resources/cloudflare_r2_bucket_event_notification/types.rb +15 -0
- data/lib/pangea/resources/cloudflare_r2_bucket_lifecycle/resource.rb +31 -0
- data/lib/pangea/resources/cloudflare_r2_bucket_lifecycle/types.rb +26 -0
- data/lib/pangea/resources/cloudflare_r2_bucket_lock/resource.rb +29 -0
- data/lib/pangea/resources/cloudflare_r2_bucket_lock/types.rb +13 -0
- data/lib/pangea/resources/cloudflare_r2_bucket_sippy/resource.rb +26 -0
- data/lib/pangea/resources/cloudflare_r2_bucket_sippy/types.rb +10 -0
- data/lib/pangea/resources/cloudflare_r2_custom_domain/resource.rb +28 -0
- data/lib/pangea/resources/cloudflare_r2_custom_domain/types.rb +12 -0
- data/lib/pangea/resources/cloudflare_r2_managed_domain/resource.rb +26 -0
- data/lib/pangea/resources/cloudflare_r2_managed_domain/types.rb +10 -0
- data/lib/pangea/resources/cloudflare_rate_limit/resource.rb +129 -0
- data/lib/pangea/resources/cloudflare_rate_limit/types.rb +143 -0
- data/lib/pangea/resources/cloudflare_record/resource.rb +91 -0
- data/lib/pangea/resources/cloudflare_record/types.rb +114 -0
- data/lib/pangea/resources/cloudflare_regional_hostname/resource.rb +27 -0
- data/lib/pangea/resources/cloudflare_regional_hostname/types.rb +11 -0
- data/lib/pangea/resources/cloudflare_regional_tiered_cache/resource.rb +82 -0
- data/lib/pangea/resources/cloudflare_regional_tiered_cache/types.rb +73 -0
- data/lib/pangea/resources/cloudflare_registrar_domain/resource.rb +27 -0
- data/lib/pangea/resources/cloudflare_registrar_domain/types.rb +11 -0
- data/lib/pangea/resources/cloudflare_ruleset/resource.rb +113 -0
- data/lib/pangea/resources/cloudflare_ruleset/types/ruleset_rule.rb +84 -0
- data/lib/pangea/resources/cloudflare_ruleset/types.rb +155 -0
- data/lib/pangea/resources/cloudflare_schema_validation_operation_settings/resource.rb +27 -0
- data/lib/pangea/resources/cloudflare_schema_validation_operation_settings/types.rb +11 -0
- data/lib/pangea/resources/cloudflare_schema_validation_schemas/resource.rb +27 -0
- data/lib/pangea/resources/cloudflare_schema_validation_schemas/types.rb +11 -0
- data/lib/pangea/resources/cloudflare_schema_validation_settings/resource.rb +27 -0
- data/lib/pangea/resources/cloudflare_schema_validation_settings/types.rb +11 -0
- data/lib/pangea/resources/cloudflare_snippet/resource.rb +27 -0
- data/lib/pangea/resources/cloudflare_snippet/types.rb +11 -0
- data/lib/pangea/resources/cloudflare_snippet_rules/resource.rb +27 -0
- data/lib/pangea/resources/cloudflare_snippet_rules/types.rb +11 -0
- data/lib/pangea/resources/cloudflare_spectrum_application/resource.rb +122 -0
- data/lib/pangea/resources/cloudflare_spectrum_application/types.rb +147 -0
- data/lib/pangea/resources/cloudflare_static_route/resource.rb +119 -0
- data/lib/pangea/resources/cloudflare_static_route/types.rb +131 -0
- data/lib/pangea/resources/cloudflare_stream/resource.rb +35 -0
- data/lib/pangea/resources/cloudflare_stream/types.rb +15 -0
- data/lib/pangea/resources/cloudflare_stream_audio_track/resource.rb +27 -0
- data/lib/pangea/resources/cloudflare_stream_audio_track/types.rb +11 -0
- data/lib/pangea/resources/cloudflare_stream_caption_language/resource.rb +27 -0
- data/lib/pangea/resources/cloudflare_stream_caption_language/types.rb +11 -0
- data/lib/pangea/resources/cloudflare_stream_download/resource.rb +27 -0
- data/lib/pangea/resources/cloudflare_stream_download/types.rb +11 -0
- data/lib/pangea/resources/cloudflare_stream_key/resource.rb +27 -0
- data/lib/pangea/resources/cloudflare_stream_key/types.rb +11 -0
- data/lib/pangea/resources/cloudflare_stream_live_input/resource.rb +27 -0
- data/lib/pangea/resources/cloudflare_stream_live_input/types.rb +11 -0
- data/lib/pangea/resources/cloudflare_stream_watermark/resource.rb +27 -0
- data/lib/pangea/resources/cloudflare_stream_watermark/types.rb +11 -0
- data/lib/pangea/resources/cloudflare_stream_webhook/resource.rb +27 -0
- data/lib/pangea/resources/cloudflare_stream_webhook/types.rb +11 -0
- data/lib/pangea/resources/cloudflare_tiered_cache/resource.rb +83 -0
- data/lib/pangea/resources/cloudflare_tiered_cache/types.rb +74 -0
- data/lib/pangea/resources/cloudflare_total_tls/resource.rb +26 -0
- data/lib/pangea/resources/cloudflare_total_tls/types.rb +10 -0
- data/lib/pangea/resources/cloudflare_turnstile_widget/resource.rb +34 -0
- data/lib/pangea/resources/cloudflare_turnstile_widget/types.rb +15 -0
- data/lib/pangea/resources/cloudflare_url_normalization_settings/resource.rb +27 -0
- data/lib/pangea/resources/cloudflare_url_normalization_settings/types.rb +11 -0
- data/lib/pangea/resources/cloudflare_user/resource.rb +27 -0
- data/lib/pangea/resources/cloudflare_user/types.rb +11 -0
- data/lib/pangea/resources/cloudflare_user_agent_blocking_rule/resource.rb +27 -0
- data/lib/pangea/resources/cloudflare_user_agent_blocking_rule/types.rb +11 -0
- data/lib/pangea/resources/cloudflare_waiting_room/resource.rb +122 -0
- data/lib/pangea/resources/cloudflare_waiting_room/types.rb +171 -0
- data/lib/pangea/resources/cloudflare_waiting_room_event/resource.rb +118 -0
- data/lib/pangea/resources/cloudflare_waiting_room_event/types.rb +153 -0
- data/lib/pangea/resources/cloudflare_waiting_room_rules/resource.rb +40 -0
- data/lib/pangea/resources/cloudflare_waiting_room_rules/types.rb +32 -0
- data/lib/pangea/resources/cloudflare_waiting_room_settings/resource.rb +27 -0
- data/lib/pangea/resources/cloudflare_waiting_room_settings/types.rb +11 -0
- data/lib/pangea/resources/cloudflare_web3_hostname/resource.rb +27 -0
- data/lib/pangea/resources/cloudflare_web3_hostname/types.rb +11 -0
- data/lib/pangea/resources/cloudflare_web_analytics_rule/resource.rb +27 -0
- data/lib/pangea/resources/cloudflare_web_analytics_rule/types.rb +11 -0
- data/lib/pangea/resources/cloudflare_web_analytics_site/resource.rb +33 -0
- data/lib/pangea/resources/cloudflare_web_analytics_site/types.rb +13 -0
- data/lib/pangea/resources/cloudflare_worker/resource.rb +27 -0
- data/lib/pangea/resources/cloudflare_worker/types.rb +11 -0
- data/lib/pangea/resources/cloudflare_worker_route/resource.rb +62 -0
- data/lib/pangea/resources/cloudflare_worker_route/types.rb +50 -0
- data/lib/pangea/resources/cloudflare_worker_script/resource.rb +90 -0
- data/lib/pangea/resources/cloudflare_worker_script/types.rb +109 -0
- data/lib/pangea/resources/cloudflare_worker_version/resource.rb +27 -0
- data/lib/pangea/resources/cloudflare_worker_version/types.rb +11 -0
- data/lib/pangea/resources/cloudflare_workers_cron_trigger/resource.rb +94 -0
- data/lib/pangea/resources/cloudflare_workers_cron_trigger/types.rb +102 -0
- data/lib/pangea/resources/cloudflare_workers_custom_domain/resource.rb +93 -0
- data/lib/pangea/resources/cloudflare_workers_custom_domain/types.rb +93 -0
- data/lib/pangea/resources/cloudflare_workers_deployment/resource.rb +28 -0
- data/lib/pangea/resources/cloudflare_workers_deployment/types.rb +12 -0
- data/lib/pangea/resources/cloudflare_workers_for_platforms_dispatch_namespace/resource.rb +27 -0
- data/lib/pangea/resources/cloudflare_workers_for_platforms_dispatch_namespace/types.rb +11 -0
- data/lib/pangea/resources/cloudflare_workers_kv/resource.rb +98 -0
- data/lib/pangea/resources/cloudflare_workers_kv/types.rb +103 -0
- data/lib/pangea/resources/cloudflare_workers_kv_namespace/resource.rb +84 -0
- data/lib/pangea/resources/cloudflare_workers_kv_namespace/types.rb +74 -0
- data/lib/pangea/resources/cloudflare_workers_script_subdomain/resource.rb +27 -0
- data/lib/pangea/resources/cloudflare_workers_script_subdomain/types.rb +11 -0
- data/lib/pangea/resources/cloudflare_workflow/resource.rb +27 -0
- data/lib/pangea/resources/cloudflare_workflow/types.rb +11 -0
- data/lib/pangea/resources/cloudflare_zero_trust_access_application/block_builders.rb +116 -0
- data/lib/pangea/resources/cloudflare_zero_trust_access_application/resource.rb +161 -0
- data/lib/pangea/resources/cloudflare_zero_trust_access_application/types/attributes.rb +102 -0
- data/lib/pangea/resources/cloudflare_zero_trust_access_application/types/cors_headers.rb +37 -0
- data/lib/pangea/resources/cloudflare_zero_trust_access_application/types/destination.rb +37 -0
- data/lib/pangea/resources/cloudflare_zero_trust_access_application/types/enums.rb +31 -0
- data/lib/pangea/resources/cloudflare_zero_trust_access_application/types/footer_link.rb +31 -0
- data/lib/pangea/resources/cloudflare_zero_trust_access_application/types/landing_page_design.rb +34 -0
- data/lib/pangea/resources/cloudflare_zero_trust_access_application/types/saas_app.rb +44 -0
- data/lib/pangea/resources/cloudflare_zero_trust_access_application/types/scim_config.rb +35 -0
- data/lib/pangea/resources/cloudflare_zero_trust_access_application/types.rb +26 -0
- data/lib/pangea/resources/cloudflare_zero_trust_access_custom_page/resource.rb +26 -0
- data/lib/pangea/resources/cloudflare_zero_trust_access_custom_page/types.rb +10 -0
- data/lib/pangea/resources/cloudflare_zero_trust_access_group/resource.rb +31 -0
- data/lib/pangea/resources/cloudflare_zero_trust_access_group/types.rb +15 -0
- data/lib/pangea/resources/cloudflare_zero_trust_access_identity_provider/resource.rb +31 -0
- data/lib/pangea/resources/cloudflare_zero_trust_access_identity_provider/types.rb +15 -0
- data/lib/pangea/resources/cloudflare_zero_trust_access_infrastructure_target/resource.rb +26 -0
- data/lib/pangea/resources/cloudflare_zero_trust_access_infrastructure_target/types.rb +10 -0
- data/lib/pangea/resources/cloudflare_zero_trust_access_key_configuration/resource.rb +26 -0
- data/lib/pangea/resources/cloudflare_zero_trust_access_key_configuration/types.rb +10 -0
- data/lib/pangea/resources/cloudflare_zero_trust_access_mtls_certificate/resource.rb +26 -0
- data/lib/pangea/resources/cloudflare_zero_trust_access_mtls_certificate/types.rb +10 -0
- data/lib/pangea/resources/cloudflare_zero_trust_access_mtls_hostname_settings/resource.rb +26 -0
- data/lib/pangea/resources/cloudflare_zero_trust_access_mtls_hostname_settings/types.rb +10 -0
- data/lib/pangea/resources/cloudflare_zero_trust_access_policy/resource.rb +39 -0
- data/lib/pangea/resources/cloudflare_zero_trust_access_policy/types.rb +23 -0
- data/lib/pangea/resources/cloudflare_zero_trust_access_service_token/resource.rb +26 -0
- data/lib/pangea/resources/cloudflare_zero_trust_access_service_token/types.rb +10 -0
- data/lib/pangea/resources/cloudflare_zero_trust_access_short_lived_certificate/resource.rb +26 -0
- data/lib/pangea/resources/cloudflare_zero_trust_access_short_lived_certificate/types.rb +10 -0
- data/lib/pangea/resources/cloudflare_zero_trust_access_tag/resource.rb +26 -0
- data/lib/pangea/resources/cloudflare_zero_trust_access_tag/types.rb +10 -0
- data/lib/pangea/resources/cloudflare_zero_trust_device_custom_profile/resource.rb +26 -0
- data/lib/pangea/resources/cloudflare_zero_trust_device_custom_profile/types.rb +10 -0
- data/lib/pangea/resources/cloudflare_zero_trust_device_custom_profile_local_domain_fallback/resource.rb +26 -0
- data/lib/pangea/resources/cloudflare_zero_trust_device_custom_profile_local_domain_fallback/types.rb +10 -0
- data/lib/pangea/resources/cloudflare_zero_trust_device_default_profile/resource.rb +26 -0
- data/lib/pangea/resources/cloudflare_zero_trust_device_default_profile/types.rb +10 -0
- data/lib/pangea/resources/cloudflare_zero_trust_device_default_profile_certificates/resource.rb +26 -0
- data/lib/pangea/resources/cloudflare_zero_trust_device_default_profile_certificates/types.rb +10 -0
- data/lib/pangea/resources/cloudflare_zero_trust_device_default_profile_local_domain_fallback/resource.rb +26 -0
- data/lib/pangea/resources/cloudflare_zero_trust_device_default_profile_local_domain_fallback/types.rb +10 -0
- data/lib/pangea/resources/cloudflare_zero_trust_device_managed_networks/resource.rb +26 -0
- data/lib/pangea/resources/cloudflare_zero_trust_device_managed_networks/types.rb +10 -0
- data/lib/pangea/resources/cloudflare_zero_trust_device_posture_integration/resource.rb +26 -0
- data/lib/pangea/resources/cloudflare_zero_trust_device_posture_integration/types.rb +10 -0
- data/lib/pangea/resources/cloudflare_zero_trust_device_posture_rule/resource.rb +26 -0
- data/lib/pangea/resources/cloudflare_zero_trust_device_posture_rule/types.rb +10 -0
- data/lib/pangea/resources/cloudflare_zero_trust_device_settings/resource.rb +26 -0
- data/lib/pangea/resources/cloudflare_zero_trust_device_settings/types.rb +10 -0
- data/lib/pangea/resources/cloudflare_zero_trust_dex_test/resource.rb +26 -0
- data/lib/pangea/resources/cloudflare_zero_trust_dex_test/types.rb +10 -0
- data/lib/pangea/resources/cloudflare_zero_trust_dlp_custom_entry/resource.rb +26 -0
- data/lib/pangea/resources/cloudflare_zero_trust_dlp_custom_entry/types.rb +10 -0
- data/lib/pangea/resources/cloudflare_zero_trust_dlp_custom_profile/resource.rb +26 -0
- data/lib/pangea/resources/cloudflare_zero_trust_dlp_custom_profile/types.rb +10 -0
- data/lib/pangea/resources/cloudflare_zero_trust_dlp_dataset/resource.rb +26 -0
- data/lib/pangea/resources/cloudflare_zero_trust_dlp_dataset/types.rb +10 -0
- data/lib/pangea/resources/cloudflare_zero_trust_dlp_entry/resource.rb +26 -0
- data/lib/pangea/resources/cloudflare_zero_trust_dlp_entry/types.rb +10 -0
- data/lib/pangea/resources/cloudflare_zero_trust_dlp_integration_entry/resource.rb +26 -0
- data/lib/pangea/resources/cloudflare_zero_trust_dlp_integration_entry/types.rb +10 -0
- data/lib/pangea/resources/cloudflare_zero_trust_dlp_predefined_entry/resource.rb +26 -0
- data/lib/pangea/resources/cloudflare_zero_trust_dlp_predefined_entry/types.rb +10 -0
- data/lib/pangea/resources/cloudflare_zero_trust_dlp_predefined_profile/resource.rb +26 -0
- data/lib/pangea/resources/cloudflare_zero_trust_dlp_predefined_profile/types.rb +10 -0
- data/lib/pangea/resources/cloudflare_zero_trust_dns_location/resource.rb +26 -0
- data/lib/pangea/resources/cloudflare_zero_trust_dns_location/types.rb +10 -0
- data/lib/pangea/resources/cloudflare_zero_trust_gateway_certificate/resource.rb +26 -0
- data/lib/pangea/resources/cloudflare_zero_trust_gateway_certificate/types.rb +10 -0
- data/lib/pangea/resources/cloudflare_zero_trust_gateway_logging/resource.rb +26 -0
- data/lib/pangea/resources/cloudflare_zero_trust_gateway_logging/types.rb +10 -0
- data/lib/pangea/resources/cloudflare_zero_trust_gateway_policy/resource.rb +34 -0
- data/lib/pangea/resources/cloudflare_zero_trust_gateway_policy/types.rb +18 -0
- data/lib/pangea/resources/cloudflare_zero_trust_gateway_proxy_endpoint/resource.rb +26 -0
- data/lib/pangea/resources/cloudflare_zero_trust_gateway_proxy_endpoint/types.rb +10 -0
- data/lib/pangea/resources/cloudflare_zero_trust_gateway_settings/resource.rb +26 -0
- data/lib/pangea/resources/cloudflare_zero_trust_gateway_settings/types.rb +10 -0
- data/lib/pangea/resources/cloudflare_zero_trust_list/resource.rb +26 -0
- data/lib/pangea/resources/cloudflare_zero_trust_list/types.rb +10 -0
- data/lib/pangea/resources/cloudflare_zero_trust_network_hostname_route/resource.rb +26 -0
- data/lib/pangea/resources/cloudflare_zero_trust_network_hostname_route/types.rb +10 -0
- data/lib/pangea/resources/cloudflare_zero_trust_organization/resource.rb +26 -0
- data/lib/pangea/resources/cloudflare_zero_trust_organization/types.rb +10 -0
- data/lib/pangea/resources/cloudflare_zero_trust_risk_behavior/resource.rb +26 -0
- data/lib/pangea/resources/cloudflare_zero_trust_risk_behavior/types.rb +10 -0
- data/lib/pangea/resources/cloudflare_zero_trust_risk_scoring_integration/resource.rb +26 -0
- data/lib/pangea/resources/cloudflare_zero_trust_risk_scoring_integration/types.rb +10 -0
- data/lib/pangea/resources/cloudflare_zero_trust_tunnel_cloudflared/resource.rb +33 -0
- data/lib/pangea/resources/cloudflare_zero_trust_tunnel_cloudflared/types.rb +13 -0
- data/lib/pangea/resources/cloudflare_zero_trust_tunnel_cloudflared_config/resource.rb +28 -0
- data/lib/pangea/resources/cloudflare_zero_trust_tunnel_cloudflared_config/types.rb +12 -0
- data/lib/pangea/resources/cloudflare_zero_trust_tunnel_cloudflared_route/resource.rb +30 -0
- data/lib/pangea/resources/cloudflare_zero_trust_tunnel_cloudflared_route/types.rb +14 -0
- data/lib/pangea/resources/cloudflare_zero_trust_tunnel_cloudflared_virtual_network/resource.rb +26 -0
- data/lib/pangea/resources/cloudflare_zero_trust_tunnel_cloudflared_virtual_network/types.rb +10 -0
- data/lib/pangea/resources/cloudflare_zero_trust_tunnel_warp_connector/resource.rb +26 -0
- data/lib/pangea/resources/cloudflare_zero_trust_tunnel_warp_connector/types.rb +10 -0
- data/lib/pangea/resources/cloudflare_zone/resource.rb +71 -0
- data/lib/pangea/resources/cloudflare_zone/types.rb +62 -0
- data/lib/pangea/resources/cloudflare_zone_cache_reserve/resource.rb +27 -0
- data/lib/pangea/resources/cloudflare_zone_cache_reserve/types.rb +11 -0
- data/lib/pangea/resources/cloudflare_zone_cache_variants/resource.rb +27 -0
- data/lib/pangea/resources/cloudflare_zone_cache_variants/types.rb +11 -0
- data/lib/pangea/resources/cloudflare_zone_dns_settings/resource.rb +27 -0
- data/lib/pangea/resources/cloudflare_zone_dns_settings/types.rb +11 -0
- data/lib/pangea/resources/cloudflare_zone_dnssec/resource.rb +96 -0
- data/lib/pangea/resources/cloudflare_zone_dnssec/types.rb +81 -0
- data/lib/pangea/resources/cloudflare_zone_hold/resource.rb +26 -0
- data/lib/pangea/resources/cloudflare_zone_hold/types.rb +10 -0
- data/lib/pangea/resources/cloudflare_zone_lockdown/resource.rb +27 -0
- data/lib/pangea/resources/cloudflare_zone_lockdown/types.rb +11 -0
- data/lib/pangea/resources/cloudflare_zone_settings_override/resource.rb +80 -0
- data/lib/pangea/resources/cloudflare_zone_settings_override/types.rb +64 -0
- data/lib/pangea/resources/cloudflare_zone_subscription/resource.rb +26 -0
- data/lib/pangea/resources/cloudflare_zone_subscription/types.rb +10 -0
- data/lib/pangea/resources/composition/auto_scaling_web_tier.rb +179 -0
- data/lib/pangea/resources/composition/composite_auto_scaling_reference.rb +63 -0
- data/lib/pangea/resources/composition/composite_vpc_reference.rb +73 -0
- data/lib/pangea/resources/composition/composite_web_server_reference.rb +46 -0
- data/lib/pangea/resources/composition/helpers.rb +75 -0
- data/lib/pangea/resources/composition/vpc_with_subnets.rb +143 -0
- data/lib/pangea/resources/composition/web_server.rb +72 -0
- data/lib/pangea/resources/composition.rb +14 -510
- data/lib/pangea/resources/event_driven_example/dynamodb_tables.rb +103 -0
- data/lib/pangea/resources/event_driven_example/eventbridge_buses.rb +68 -0
- data/lib/pangea/resources/event_driven_example/eventbridge_rules.rb +94 -0
- data/lib/pangea/resources/event_driven_example/eventbridge_targets.rb +123 -0
- data/lib/pangea/resources/event_driven_example.rb +48 -254
- data/lib/pangea/resources/hcloud_certificate/resource.rb +50 -0
- data/lib/pangea/resources/hcloud_certificate/types.rb +26 -0
- data/lib/pangea/resources/hcloud_firewall/resource.rb +57 -0
- data/lib/pangea/resources/hcloud_firewall/types.rb +25 -0
- data/lib/pangea/resources/hcloud_firewall_attachment/resource.rb +40 -0
- data/lib/pangea/resources/hcloud_firewall_attachment/types.rb +22 -0
- data/lib/pangea/resources/hcloud_floating_ip/resource.rb +52 -0
- data/lib/pangea/resources/hcloud_floating_ip/types.rb +28 -0
- data/lib/pangea/resources/hcloud_floating_ip_assignment/resource.rb +40 -0
- data/lib/pangea/resources/hcloud_floating_ip_assignment/types.rb +22 -0
- data/lib/pangea/resources/hcloud_load_balancer/resource.rb +57 -0
- data/lib/pangea/resources/hcloud_load_balancer/types.rb +28 -0
- data/lib/pangea/resources/hcloud_load_balancer_network/resource.rb +43 -0
- data/lib/pangea/resources/hcloud_load_balancer_network/types.rb +26 -0
- data/lib/pangea/resources/hcloud_load_balancer_service/resource.rb +70 -0
- data/lib/pangea/resources/hcloud_load_balancer_service/types.rb +29 -0
- data/lib/pangea/resources/hcloud_load_balancer_target/resource.rb +45 -0
- data/lib/pangea/resources/hcloud_load_balancer_target/types.rb +28 -0
- data/lib/pangea/resources/hcloud_managed_certificate/resource.rb +49 -0
- data/lib/pangea/resources/hcloud_managed_certificate/types.rb +25 -0
- data/lib/pangea/resources/hcloud_network/resource.rb +48 -0
- data/lib/pangea/resources/hcloud_network/types.rb +25 -0
- data/lib/pangea/resources/hcloud_network_route/resource.rb +42 -0
- data/lib/pangea/resources/hcloud_network_route/types.rb +23 -0
- data/lib/pangea/resources/hcloud_network_subnet/resource.rb +44 -0
- data/lib/pangea/resources/hcloud_network_subnet/types.rb +27 -0
- data/lib/pangea/resources/hcloud_placement_group/resource.rb +48 -0
- data/lib/pangea/resources/hcloud_placement_group/types.rb +25 -0
- data/lib/pangea/resources/hcloud_primary_ip/resource.rb +52 -0
- data/lib/pangea/resources/hcloud_primary_ip/types.rb +29 -0
- data/lib/pangea/resources/hcloud_rdns/resource.rb +42 -0
- data/lib/pangea/resources/hcloud_rdns/types.rb +23 -0
- data/lib/pangea/resources/hcloud_server/resource.rb +91 -0
- data/lib/pangea/resources/hcloud_server/types.rb +58 -0
- data/lib/pangea/resources/hcloud_server_network/resource.rb +43 -0
- data/lib/pangea/resources/hcloud_server_network/types.rb +26 -0
- data/lib/pangea/resources/hcloud_snapshot/resource.rb +41 -0
- data/lib/pangea/resources/hcloud_snapshot/types.rb +25 -0
- data/lib/pangea/resources/hcloud_ssh_key/resource.rb +73 -0
- data/lib/pangea/resources/hcloud_ssh_key/types.rb +38 -0
- data/lib/pangea/resources/hcloud_uploaded_certificate/resource.rb +44 -0
- data/lib/pangea/resources/hcloud_uploaded_certificate/types.rb +26 -0
- data/lib/pangea/resources/hcloud_volume/resource.rb +53 -0
- data/lib/pangea/resources/hcloud_volume/types.rb +28 -0
- data/lib/pangea/resources/hcloud_volume_attachment/resource.rb +41 -0
- data/lib/pangea/resources/hcloud_volume_attachment/types.rb +25 -0
- data/lib/pangea/resources/hcloud_zone/resource.rb +40 -0
- data/lib/pangea/resources/hcloud_zone/types.rb +24 -0
- data/lib/pangea/resources/hcloud_zone_rrset/resource.rb +44 -0
- data/lib/pangea/resources/hcloud_zone_rrset/types.rb +27 -0
- data/lib/pangea/resources/network_helpers.rb +75 -0
- data/lib/pangea/resources/reference/instance_computed_attributes.rb +78 -0
- data/lib/pangea/resources/reference/subnet_computed_attributes.rb +60 -0
- data/lib/pangea/resources/reference/vpc_computed_attributes.rb +89 -0
- data/lib/pangea/resources/reference.rb +43 -206
- data/lib/pangea/resources/types/aws/compute.rb +103 -0
- data/lib/pangea/resources/types/aws/core.rb +132 -0
- data/lib/pangea/resources/types/aws/database.rb +37 -0
- data/lib/pangea/resources/types/aws/iot.rb +181 -0
- data/lib/pangea/resources/types/aws/iot_analytics.rb +57 -0
- data/lib/pangea/resources/types/aws/load_balancer.rb +99 -0
- data/lib/pangea/resources/types/aws/monitoring.rb +52 -0
- data/lib/pangea/resources/types/aws/networking.rb +74 -0
- data/lib/pangea/resources/types/aws/security.rb +138 -0
- data/lib/pangea/resources/types/aws/storage.rb +60 -0
- data/lib/pangea/resources/types/cloudflare/core.rb +130 -0
- data/lib/pangea/resources/types/cloudflare/load_balancing.rb +104 -0
- data/lib/pangea/resources/types/cloudflare/security.rb +107 -0
- data/lib/pangea/resources/types/cloudflare/workers.rb +60 -0
- data/lib/pangea/resources/types/core.rb +38 -0
- data/lib/pangea/resources/types/hetzner/core.rb +136 -0
- data/lib/pangea/resources/types/index.rb +38 -0
- data/lib/pangea/resources/types.rb +2 -1216
- data/lib/pangea/resources/validators/shared/aws_validators.rb +66 -0
- data/lib/pangea/resources/validators/shared/format_validators.rb +79 -0
- data/lib/pangea/resources/validators/shared/network_validators.rb +106 -0
- data/lib/pangea/resources/validators/shared_validators.rb +49 -0
- data/lib/pangea/utilities/ip_discovery.rb +109 -0
- data/lib/pangea/utilities.rb +1 -0
- data/lib/pangea/validation/base_validator.rb +104 -0
- data/lib/pangea/validation/common_validation_rules.rb +92 -0
- data/lib/pangea/validation/resource_validator.rb +36 -0
- data/lib/pangea/validation/validator_manager.rb +200 -0
- data/lib/pangea/validation/validators/aws_compute_validators.rb +66 -0
- data/lib/pangea/validation/validators/aws_database_validators.rb +100 -0
- data/lib/pangea/validation/validators/aws_network_validators.rb +135 -0
- data/lib/pangea/validation.rb +2 -0
- data/lib/pangea/version.rb +1 -1
- data/lib/pangea.rb +8 -4
- data/pangea.gemspec +4 -2
- data/pkgs/products/pangea/deploy/configmap.yaml +67 -0
- data/pkgs/products/pangea/deploy/crds/infrastructuretemplates.yaml +395 -0
- data/pkgs/products/pangea/deploy/crds/pangeanamespaces.yaml +286 -0
- data/pkgs/products/pangea/deploy/kustomization.yaml +54 -0
- data/pkgs/products/pangea/deploy/namespace.yaml +6 -0
- data/pkgs/products/pangea/deploy/operator-deployment.yaml +138 -0
- data/pkgs/products/pangea/deploy/operator-service.yaml +23 -0
- data/pkgs/products/pangea/deploy/rbac/role.yaml +106 -0
- data/pkgs/products/pangea/deploy/rbac/rolebinding.yaml +15 -0
- data/pkgs/products/pangea/deploy/rbac/serviceaccount.yaml +7 -0
- data/pkgs/products/pangea/deploy/web-deployment.yaml +64 -0
- data/pkgs/products/pangea/deploy/web-service.yaml +19 -0
- data/synthesizer-tests.yaml +72 -0
- metadata +1509 -309
- data/CLAUDE.md +0 -626
- data/OPEN_SOURCE_READINESS.md +0 -170
- data/audit_results/vpc_resources_audit.json +0 -219
- data/examples/basic-web-app/pangea.yaml +0 -36
- data/examples/cicd-pipeline/pangea.yaml +0 -35
- data/examples/data-processing/pangea.yaml +0 -57
- data/examples/disaster-recovery/pangea.yaml +0 -62
- data/examples/global-multi-region/pangea.yaml +0 -61
- data/examples/microservices-platform/pangea.yaml +0 -35
- data/examples/ml-platform/pangea.yaml +0 -58
- data/examples/multi-environment/pangea.yaml +0 -71
- data/examples/multi-tier-architecture/pangea.yaml +0 -49
- data/examples/security-focused/pangea.yaml +0 -60
- data/lib/pangea/architectures/CLAUDE.md +0 -425
- data/lib/pangea/components/CLAUDE.md +0 -350
- data/lib/pangea/components/application_load_balancer/CLAUDE.md +0 -224
- data/lib/pangea/components/carbon_aware_compute/CLAUDE.md +0 -295
- data/lib/pangea/components/green_data_lifecycle/CLAUDE.md +0 -353
- data/lib/pangea/components/public_private_subnets/CLAUDE.md +0 -547
- data/lib/pangea/components/secure_vpc/CLAUDE.md +0 -366
- data/lib/pangea/components/spot_instance_carbon_optimizer/CLAUDE.md +0 -469
- data/lib/pangea/components/sustainable_ml_training/CLAUDE.md +0 -653
- data/lib/pangea/components/web_security_group/CLAUDE.md +0 -690
- data/lib/pangea/components/web_tier_subnets/CLAUDE.md +0 -572
- data/lib/pangea/resources/CLAUDE.md +0 -607
- data/lib/pangea/resources/DATABASE_SERVICES_CLAUDE.md +0 -577
- data/lib/pangea/resources/aws/audit_manager/CLAUDE.md +0 -778
- data/lib/pangea/resources/aws/batch/CLAUDE.md +0 -965
- data/lib/pangea/resources/aws/cloudformation/CLAUDE.md +0 -98
- data/lib/pangea/resources/aws/detective/CLAUDE.md +0 -668
- data/lib/pangea/resources/aws/extended_resources_CLAUDE.md +0 -470
- data/lib/pangea/resources/aws/media_services_CLAUDE.md +0 -494
- data/lib/pangea/resources/aws/opensearch.disabled/CLAUDE.md +0 -480
- data/lib/pangea/resources/aws/security_lake/CLAUDE.md +0 -932
- data/lib/pangea/resources/aws_acm_certificate/CLAUDE.md +0 -290
- data/lib/pangea/resources/aws_acm_certificate_validation/CLAUDE.md +0 -437
- data/lib/pangea/resources/aws_ami/CLAUDE.md +0 -253
- data/lib/pangea/resources/aws_api_gateway_deployment/CLAUDE.md +0 -270
- data/lib/pangea/resources/aws_api_gateway_integration/CLAUDE.md +0 -304
- data/lib/pangea/resources/aws_api_gateway_method/CLAUDE.md +0 -235
- data/lib/pangea/resources/aws_api_gateway_resource/CLAUDE.md +0 -215
- data/lib/pangea/resources/aws_api_gateway_rest_api/CLAUDE.md +0 -152
- data/lib/pangea/resources/aws_api_gateway_stage/CLAUDE.md +0 -308
- data/lib/pangea/resources/aws_appstream_fleet/CLAUDE.md +0 -468
- data/lib/pangea/resources/aws_appsync_datasource/CLAUDE.md +0 -479
- data/lib/pangea/resources/aws_appsync_graphql_api/CLAUDE.md +0 -325
- data/lib/pangea/resources/aws_appsync_resolver/CLAUDE.md +0 -459
- data/lib/pangea/resources/aws_athena_database/CLAUDE.md +0 -276
- data/lib/pangea/resources/aws_athena_named_query/CLAUDE.md +0 -385
- data/lib/pangea/resources/aws_athena_workgroup/CLAUDE.md +0 -315
- data/lib/pangea/resources/aws_autoscaling_attachment/CLAUDE.md +0 -226
- data/lib/pangea/resources/aws_autoscaling_group/CLAUDE.md +0 -263
- data/lib/pangea/resources/aws_autoscaling_lifecycle_hook/CLAUDE.md +0 -357
- data/lib/pangea/resources/aws_autoscaling_notification/CLAUDE.md +0 -405
- data/lib/pangea/resources/aws_autoscaling_policy/CLAUDE.md +0 -278
- data/lib/pangea/resources/aws_autoscaling_schedule/CLAUDE.md +0 -219
- data/lib/pangea/resources/aws_autoscaling_tag/CLAUDE.md +0 -443
- data/lib/pangea/resources/aws_batch_compute_environment/CLAUDE.md +0 -571
- data/lib/pangea/resources/aws_batch_job_definition/CLAUDE.md +0 -714
- data/lib/pangea/resources/aws_batch_job_queue/CLAUDE.md +0 -585
- data/lib/pangea/resources/aws_braket_device/CLAUDE.md +0 -331
- data/lib/pangea/resources/aws_braket_quantum_task/CLAUDE.md +0 -188
- data/lib/pangea/resources/aws_budgets_budget/CLAUDE.md +0 -304
- data/lib/pangea/resources/aws_budgets_budget_action/CLAUDE.md +0 -357
- data/lib/pangea/resources/aws_cloudformation_stack/CLAUDE.md +0 -244
- data/lib/pangea/resources/aws_cloudformation_stack_set/CLAUDE.md +0 -309
- data/lib/pangea/resources/aws_cloudfront_distribution/CLAUDE.md +0 -62
- data/lib/pangea/resources/aws_cloudwatch_composite_alarm/CLAUDE.md +0 -288
- data/lib/pangea/resources/aws_cloudwatch_dashboard/CLAUDE.md +0 -342
- data/lib/pangea/resources/aws_cloudwatch_event_rule/CLAUDE.md +0 -568
- data/lib/pangea/resources/aws_cloudwatch_event_target/CLAUDE.md +0 -625
- data/lib/pangea/resources/aws_cloudwatch_log_destination/CLAUDE.md +0 -388
- data/lib/pangea/resources/aws_cloudwatch_log_destination_policy/CLAUDE.md +0 -479
- data/lib/pangea/resources/aws_cloudwatch_log_group/CLAUDE.md +0 -175
- data/lib/pangea/resources/aws_cloudwatch_log_metric_filter/CLAUDE.md +0 -502
- data/lib/pangea/resources/aws_cloudwatch_log_stream/CLAUDE.md +0 -260
- data/lib/pangea/resources/aws_cloudwatch_log_subscription_filter/CLAUDE.md +0 -473
- data/lib/pangea/resources/aws_cloudwatch_metric_alarm/CLAUDE.md +0 -317
- data/lib/pangea/resources/aws_codeartifact_domain/CLAUDE.md +0 -54
- data/lib/pangea/resources/aws_codeartifact_repository/CLAUDE.md +0 -55
- data/lib/pangea/resources/aws_codebuild_project/CLAUDE.md +0 -304
- data/lib/pangea/resources/aws_codecommit_repository/CLAUDE.md +0 -150
- data/lib/pangea/resources/aws_codedeploy_application/CLAUDE.md +0 -312
- data/lib/pangea/resources/aws_codedeploy_deployment_config/CLAUDE.md +0 -354
- data/lib/pangea/resources/aws_codedeploy_deployment_group/CLAUDE.md +0 -342
- data/lib/pangea/resources/aws_codepipeline/CLAUDE.md +0 -592
- data/lib/pangea/resources/aws_codepipeline_webhook/CLAUDE.md +0 -449
- data/lib/pangea/resources/aws_codestar_connection/CLAUDE.md +0 -55
- data/lib/pangea/resources/aws_cognito_identity_pool/CLAUDE.md +0 -712
- data/lib/pangea/resources/aws_cognito_user_pool/CLAUDE.md +0 -431
- data/lib/pangea/resources/aws_cognito_user_pool_client/CLAUDE.md +0 -542
- data/lib/pangea/resources/aws_cognito_user_pool_domain/CLAUDE.md +0 -524
- data/lib/pangea/resources/aws_config_config_rule/CLAUDE.md +0 -381
- data/lib/pangea/resources/aws_config_configuration_recorder/CLAUDE.md +0 -247
- data/lib/pangea/resources/aws_config_delivery_channel/CLAUDE.md +0 -290
- data/lib/pangea/resources/aws_customer_gateway/CLAUDE.md +0 -458
- data/lib/pangea/resources/aws_db_instance/CLAUDE.md +0 -407
- data/lib/pangea/resources/aws_db_parameter_group/CLAUDE.md +0 -285
- data/lib/pangea/resources/aws_db_subnet_group/CLAUDE.md +0 -189
- data/lib/pangea/resources/aws_device_farm_project/CLAUDE.md +0 -299
- data/lib/pangea/resources/aws_docdb_certificate/CLAUDE.md +0 -96
- data/lib/pangea/resources/aws_docdb_cluster/CLAUDE.md +0 -96
- data/lib/pangea/resources/aws_docdb_cluster_endpoint/CLAUDE.md +0 -96
- data/lib/pangea/resources/aws_docdb_cluster_instance/CLAUDE.md +0 -96
- data/lib/pangea/resources/aws_docdb_cluster_parameter_group/CLAUDE.md +0 -96
- data/lib/pangea/resources/aws_docdb_cluster_snapshot/CLAUDE.md +0 -96
- data/lib/pangea/resources/aws_docdb_event_subscription/CLAUDE.md +0 -96
- data/lib/pangea/resources/aws_docdb_global_cluster/CLAUDE.md +0 -96
- data/lib/pangea/resources/aws_docdb_subnet_group/CLAUDE.md +0 -96
- data/lib/pangea/resources/aws_dynamodb_global_table/CLAUDE.md +0 -184
- data/lib/pangea/resources/aws_dynamodb_table/CLAUDE.md +0 -130
- data/lib/pangea/resources/aws_ebs_volume/CLAUDE.md +0 -275
- data/lib/pangea/resources/aws_ec2_transit_gateway/CLAUDE.md +0 -220
- data/lib/pangea/resources/aws_ec2_transit_gateway_route/CLAUDE.md +0 -458
- data/lib/pangea/resources/aws_ec2_transit_gateway_route_table/CLAUDE.md +0 -384
- data/lib/pangea/resources/aws_ec2_transit_gateway_route_table_association/CLAUDE.md +0 -409
- data/lib/pangea/resources/aws_ec2_transit_gateway_route_table_propagation/CLAUDE.md +0 -433
- data/lib/pangea/resources/aws_ec2_transit_gateway_vpc_attachment/CLAUDE.md +0 -326
- data/lib/pangea/resources/aws_ecr_lifecycle_policy/CLAUDE.md +0 -56
- data/lib/pangea/resources/aws_ecr_replication_configuration/CLAUDE.md +0 -55
- data/lib/pangea/resources/aws_ecr_repository/CLAUDE.md +0 -54
- data/lib/pangea/resources/aws_ecr_repository_policy/CLAUDE.md +0 -55
- data/lib/pangea/resources/aws_ecs_cluster/CLAUDE.md +0 -218
- data/lib/pangea/resources/aws_ecs_cluster_capacity_providers/CLAUDE.md +0 -191
- data/lib/pangea/resources/aws_ecs_service/CLAUDE.md +0 -256
- data/lib/pangea/resources/aws_ecs_task_definition/CLAUDE.md +0 -281
- data/lib/pangea/resources/aws_ecs_task_definition/types_old.rb +0 -439
- data/lib/pangea/resources/aws_efs_access_point/CLAUDE.md +0 -504
- data/lib/pangea/resources/aws_efs_file_system/CLAUDE.md +0 -279
- data/lib/pangea/resources/aws_efs_mount_target/CLAUDE.md +0 -361
- data/lib/pangea/resources/aws_eip/CLAUDE.md +0 -325
- data/lib/pangea/resources/aws_eip_association/CLAUDE.md +0 -96
- data/lib/pangea/resources/aws_eks_addon/CLAUDE.md +0 -271
- data/lib/pangea/resources/aws_eks_cluster/CLAUDE.md +0 -198
- data/lib/pangea/resources/aws_eks_fargate_profile/CLAUDE.md +0 -266
- data/lib/pangea/resources/aws_eks_node_group/CLAUDE.md +0 -258
- data/lib/pangea/resources/aws_elasticache_cluster/CLAUDE.md +0 -240
- data/lib/pangea/resources/aws_elasticache_parameter_group/CLAUDE.md +0 -334
- data/lib/pangea/resources/aws_elasticache_subnet_group/CLAUDE.md +0 -286
- data/lib/pangea/resources/aws_emr_cluster/CLAUDE.md +0 -660
- data/lib/pangea/resources/aws_emr_instance_group/CLAUDE.md +0 -586
- data/lib/pangea/resources/aws_emr_step/CLAUDE.md +0 -560
- data/lib/pangea/resources/aws_eventbridge_bus/CLAUDE.md +0 -208
- data/lib/pangea/resources/aws_eventbridge_rule/CLAUDE.md +0 -232
- data/lib/pangea/resources/aws_eventbridge_target/CLAUDE.md +0 -260
- data/lib/pangea/resources/aws_extended_resources_CLAUDE.md +0 -395
- data/lib/pangea/resources/aws_fsx_lustre_filesystem/CLAUDE.md +0 -383
- data/lib/pangea/resources/aws_gamelift_alias/CLAUDE.md +0 -261
- data/lib/pangea/resources/aws_gamelift_build/CLAUDE.md +0 -233
- data/lib/pangea/resources/aws_gamelift_fleet/CLAUDE.md +0 -191
- data/lib/pangea/resources/aws_gamelift_game_session_queue/CLAUDE.md +0 -282
- data/lib/pangea/resources/aws_gamelift_matchmaking_configuration/CLAUDE.md +0 -288
- data/lib/pangea/resources/aws_glue_catalog_database/CLAUDE.md +0 -161
- data/lib/pangea/resources/aws_glue_catalog_table/CLAUDE.md +0 -387
- data/lib/pangea/resources/aws_glue_job/CLAUDE.md +0 -398
- data/lib/pangea/resources/aws_glue_trigger/CLAUDE.md +0 -454
- data/lib/pangea/resources/aws_iam_group/CLAUDE.md +0 -351
- data/lib/pangea/resources/aws_iam_policy/CLAUDE.md +0 -278
- data/lib/pangea/resources/aws_iam_role/CLAUDE.md +0 -419
- data/lib/pangea/resources/aws_iam_role_policy_attachment/CLAUDE.md +0 -331
- data/lib/pangea/resources/aws_iam_user/CLAUDE.md +0 -312
- data/lib/pangea/resources/aws_instance/CLAUDE.md +0 -396
- data/lib/pangea/resources/aws_internet_gateway/CLAUDE.md +0 -157
- data/lib/pangea/resources/aws_iot_analytics_channel/CLAUDE.md +0 -3
- data/lib/pangea/resources/aws_iot_analytics_datastore/CLAUDE.md +0 -3
- data/lib/pangea/resources/aws_iot_certificate/CLAUDE.md +0 -361
- data/lib/pangea/resources/aws_iot_device_defender_security_profile/CLAUDE.md +0 -3
- data/lib/pangea/resources/aws_iot_policy/CLAUDE.md +0 -27
- data/lib/pangea/resources/aws_iot_security_profile/CLAUDE.md +0 -3
- data/lib/pangea/resources/aws_iot_thing/CLAUDE.md +0 -397
- data/lib/pangea/resources/aws_iot_thing_type/CLAUDE.md +0 -526
- data/lib/pangea/resources/aws_iot_topic_rule/CLAUDE.md +0 -11
- data/lib/pangea/resources/aws_iot_topic_rule_destination/CLAUDE.md +0 -5
- data/lib/pangea/resources/aws_key_pair/CLAUDE.md +0 -357
- data/lib/pangea/resources/aws_kinesis_analytics_application/CLAUDE.md +0 -630
- data/lib/pangea/resources/aws_kinesis_firehose_delivery_stream/CLAUDE.md +0 -532
- data/lib/pangea/resources/aws_kinesis_stream/CLAUDE.md +0 -255
- data/lib/pangea/resources/aws_kinesis_video_stream/CLAUDE.md +0 -595
- data/lib/pangea/resources/aws_lambda_event_source_mapping/CLAUDE.md +0 -316
- data/lib/pangea/resources/aws_lambda_function/CLAUDE.md +0 -255
- data/lib/pangea/resources/aws_lambda_layer_version/CLAUDE.md +0 -322
- data/lib/pangea/resources/aws_lambda_permission/CLAUDE.md +0 -276
- data/lib/pangea/resources/aws_launch_template/CLAUDE.md +0 -269
- data/lib/pangea/resources/aws_lb/CLAUDE.md +0 -411
- data/lib/pangea/resources/aws_lb_listener/CLAUDE.md +0 -310
- data/lib/pangea/resources/aws_lb_listener_certificate/CLAUDE.md +0 -463
- data/lib/pangea/resources/aws_lb_listener_rule/CLAUDE.md +0 -502
- data/lib/pangea/resources/aws_lb_target_group/CLAUDE.md +0 -271
- data/lib/pangea/resources/aws_lb_target_group_attachment/CLAUDE.md +0 -560
- data/lib/pangea/resources/aws_licensemanager_association/CLAUDE.md +0 -96
- data/lib/pangea/resources/aws_licensemanager_grant/CLAUDE.md +0 -96
- data/lib/pangea/resources/aws_licensemanager_grant_accepter/CLAUDE.md +0 -96
- data/lib/pangea/resources/aws_licensemanager_license_configuration/CLAUDE.md +0 -96
- data/lib/pangea/resources/aws_licensemanager_license_grant_accepter/CLAUDE.md +0 -96
- data/lib/pangea/resources/aws_licensemanager_report_generator/CLAUDE.md +0 -96
- data/lib/pangea/resources/aws_licensemanager_token/CLAUDE.md +0 -96
- data/lib/pangea/resources/aws_managedblockchain_member/CLAUDE.md +0 -478
- data/lib/pangea/resources/aws_managedblockchain_network/CLAUDE.md +0 -487
- data/lib/pangea/resources/aws_managedblockchain_node/CLAUDE.md +0 -505
- data/lib/pangea/resources/aws_media_live_channel/CLAUDE.md +0 -881
- data/lib/pangea/resources/aws_media_live_input/CLAUDE.md +0 -729
- data/lib/pangea/resources/aws_media_package_channel/CLAUDE.md +0 -698
- data/lib/pangea/resources/aws_memorydb_acl/CLAUDE.md +0 -96
- data/lib/pangea/resources/aws_memorydb_cluster/CLAUDE.md +0 -96
- data/lib/pangea/resources/aws_memorydb_cluster_endpoint/CLAUDE.md +0 -96
- data/lib/pangea/resources/aws_memorydb_multi_region_cluster/CLAUDE.md +0 -96
- data/lib/pangea/resources/aws_memorydb_parameter_group/CLAUDE.md +0 -96
- data/lib/pangea/resources/aws_memorydb_snapshot/CLAUDE.md +0 -96
- data/lib/pangea/resources/aws_memorydb_subnet_group/CLAUDE.md +0 -96
- data/lib/pangea/resources/aws_memorydb_user/CLAUDE.md +0 -96
- data/lib/pangea/resources/aws_mobile_analytics_app/CLAUDE.md +0 -262
- data/lib/pangea/resources/aws_nat_gateway/CLAUDE.md +0 -209
- data/lib/pangea/resources/aws_neptune_cluster/CLAUDE.md +0 -96
- data/lib/pangea/resources/aws_neptune_cluster_endpoint/CLAUDE.md +0 -96
- data/lib/pangea/resources/aws_neptune_cluster_instance/CLAUDE.md +0 -96
- data/lib/pangea/resources/aws_neptune_cluster_parameter_group/CLAUDE.md +0 -96
- data/lib/pangea/resources/aws_neptune_cluster_snapshot/CLAUDE.md +0 -96
- data/lib/pangea/resources/aws_neptune_event_subscription/CLAUDE.md +0 -96
- data/lib/pangea/resources/aws_neptune_parameter_group/CLAUDE.md +0 -96
- data/lib/pangea/resources/aws_neptune_subnet_group/CLAUDE.md +0 -96
- data/lib/pangea/resources/aws_network_acl/CLAUDE.md +0 -96
- data/lib/pangea/resources/aws_network_acl_rule/CLAUDE.md +0 -297
- data/lib/pangea/resources/aws_network_interface/CLAUDE.md +0 -310
- data/lib/pangea/resources/aws_pinpoint_app/CLAUDE.md +0 -363
- data/lib/pangea/resources/aws_qldb_ledger/CLAUDE.md +0 -734
- data/lib/pangea/resources/aws_qldb_stream/CLAUDE.md +0 -845
- data/lib/pangea/resources/aws_ram_invitation_accepter/CLAUDE.md +0 -96
- data/lib/pangea/resources/aws_ram_managed_permission/CLAUDE.md +0 -96
- data/lib/pangea/resources/aws_ram_permission/CLAUDE.md +0 -96
- data/lib/pangea/resources/aws_ram_permission_association/CLAUDE.md +0 -96
- data/lib/pangea/resources/aws_ram_principal_association/CLAUDE.md +0 -96
- data/lib/pangea/resources/aws_ram_resource_association/CLAUDE.md +0 -96
- data/lib/pangea/resources/aws_ram_resource_share/CLAUDE.md +0 -96
- data/lib/pangea/resources/aws_ram_resource_share_accepter/CLAUDE.md +0 -96
- data/lib/pangea/resources/aws_ram_resource_share_invitation/CLAUDE.md +0 -96
- data/lib/pangea/resources/aws_ram_sharing_with_organization/CLAUDE.md +0 -96
- data/lib/pangea/resources/aws_rds_cluster/CLAUDE.md +0 -361
- data/lib/pangea/resources/aws_rds_cluster_endpoint/CLAUDE.md +0 -279
- data/lib/pangea/resources/aws_rds_cluster_instance/CLAUDE.md +0 -378
- data/lib/pangea/resources/aws_rds_cluster_parameter_group/CLAUDE.md +0 -344
- data/lib/pangea/resources/aws_rds_global_cluster/CLAUDE.md +0 -362
- data/lib/pangea/resources/aws_redshift_cluster/CLAUDE.md +0 -358
- data/lib/pangea/resources/aws_redshift_parameter_group/CLAUDE.md +0 -352
- data/lib/pangea/resources/aws_redshift_snapshot_schedule/CLAUDE.md +0 -395
- data/lib/pangea/resources/aws_redshift_subnet_group/CLAUDE.md +0 -274
- data/lib/pangea/resources/aws_route/CLAUDE.md +0 -96
- data/lib/pangea/resources/aws_route53_health_check/CLAUDE.md +0 -408
- data/lib/pangea/resources/aws_route53_record/CLAUDE.md +0 -414
- data/lib/pangea/resources/aws_route53_zone/CLAUDE.md +0 -363
- data/lib/pangea/resources/aws_route_table/CLAUDE.md +0 -224
- data/lib/pangea/resources/aws_route_table_association/CLAUDE.md +0 -401
- data/lib/pangea/resources/aws_s3_access_point/CLAUDE.md +0 -211
- data/lib/pangea/resources/aws_s3_bucket/CLAUDE.md +0 -140
- data/lib/pangea/resources/aws_s3_bucket_cors_configuration/CLAUDE.md +0 -262
- data/lib/pangea/resources/aws_s3_bucket_encryption/CLAUDE.md +0 -465
- data/lib/pangea/resources/aws_s3_bucket_inventory/CLAUDE.md +0 -430
- data/lib/pangea/resources/aws_s3_bucket_lifecycle_configuration/CLAUDE.md +0 -221
- data/lib/pangea/resources/aws_s3_bucket_notification/CLAUDE.md +0 -358
- data/lib/pangea/resources/aws_s3_bucket_object_lock_configuration/CLAUDE.md +0 -561
- data/lib/pangea/resources/aws_s3_bucket_policy/CLAUDE.md +0 -234
- data/lib/pangea/resources/aws_s3_bucket_public_access_block/CLAUDE.md +0 -528
- data/lib/pangea/resources/aws_s3_bucket_replication_configuration/CLAUDE.md +0 -628
- data/lib/pangea/resources/aws_s3_bucket_versioning/CLAUDE.md +0 -340
- data/lib/pangea/resources/aws_s3_bucket_website_configuration/CLAUDE.md +0 -355
- data/lib/pangea/resources/aws_s3_object/CLAUDE.md +0 -535
- data/lib/pangea/resources/aws_sagemaker_domain/CLAUDE.md +0 -253
- data/lib/pangea/resources/aws_secretsmanager_secret/CLAUDE.md +0 -528
- data/lib/pangea/resources/aws_sfn_activity/CLAUDE.md +0 -571
- data/lib/pangea/resources/aws_sfn_state_machine/CLAUDE.md +0 -464
- data/lib/pangea/resources/aws_sns_subscription/CLAUDE.md +0 -289
- data/lib/pangea/resources/aws_sns_topic/CLAUDE.md +0 -249
- data/lib/pangea/resources/aws_sqs_queue/CLAUDE.md +0 -190
- data/lib/pangea/resources/aws_sqs_queue_policy/CLAUDE.md +0 -227
- data/lib/pangea/resources/aws_ssm_document/CLAUDE.md +0 -410
- data/lib/pangea/resources/aws_ssm_maintenance_window/CLAUDE.md +0 -412
- data/lib/pangea/resources/aws_ssm_parameter/CLAUDE.md +0 -355
- data/lib/pangea/resources/aws_ssm_patch_baseline/CLAUDE.md +0 -509
- data/lib/pangea/resources/aws_subnet/CLAUDE.md +0 -301
- data/lib/pangea/resources/aws_timestream_access_policy/CLAUDE.md +0 -96
- data/lib/pangea/resources/aws_timestream_batch_load_task/CLAUDE.md +0 -96
- data/lib/pangea/resources/aws_timestream_database/CLAUDE.md +0 -96
- data/lib/pangea/resources/aws_timestream_influx_db_instance/CLAUDE.md +0 -96
- data/lib/pangea/resources/aws_timestream_scheduled_query/CLAUDE.md +0 -96
- data/lib/pangea/resources/aws_timestream_table/CLAUDE.md +0 -96
- data/lib/pangea/resources/aws_timestream_table_retention_properties/CLAUDE.md +0 -96
- data/lib/pangea/resources/aws_volume_attachment/CLAUDE.md +0 -326
- data/lib/pangea/resources/aws_vpc/CLAUDE.md +0 -184
- data/lib/pangea/resources/aws_vpc_endpoint/CLAUDE.md +0 -483
- data/lib/pangea/resources/aws_vpc_endpoint_service/CLAUDE.md +0 -313
- data/lib/pangea/resources/aws_vpc_peering_connection/CLAUDE.md +0 -361
- data/lib/pangea/resources/aws_vpc_peering_connection_accepter/CLAUDE.md +0 -248
- data/lib/pangea/resources/aws_vpn_connection/CLAUDE.md +0 -420
- data/lib/pangea/resources/aws_vpn_gateway/CLAUDE.md +0 -411
- data/lib/pangea/resources/aws_wafv2_web_acl/CLAUDE.md +0 -788
- data/lib/pangea/resources/aws_workspaces_bundle/CLAUDE.md +0 -412
- data/lib/pangea/resources/aws_workspaces_directory/CLAUDE.md +0 -365
- data/lib/pangea/resources/aws_workspaces_ip_group/CLAUDE.md +0 -421
- data/lib/pangea/resources/aws_workspaces_workspace/CLAUDE.md +0 -322
- data/pangea_test.yml +0 -19
- data/shell.nix +0 -13
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
# frozen_string_literal: true
|
|
2
|
+
|
|
2
3
|
# Copyright 2025 The Pangea Authors
|
|
3
4
|
#
|
|
4
5
|
# Licensed under the Apache License, Version 2.0 (the "License");
|
|
@@ -13,141 +14,126 @@
|
|
|
13
14
|
# See the License for the specific language governing permissions and
|
|
14
15
|
# limitations under the License.
|
|
15
16
|
|
|
16
|
-
|
|
17
17
|
require 'pangea/components/base'
|
|
18
18
|
require 'pangea/components/zero_trust_network/types'
|
|
19
|
+
require_relative 'policies'
|
|
20
|
+
require_relative 'audit'
|
|
21
|
+
require_relative 'networking'
|
|
22
|
+
require_relative 'segments'
|
|
23
|
+
require_relative 'endpoints'
|
|
24
|
+
require_relative 'security_automation'
|
|
25
|
+
require_relative 'monitoring'
|
|
26
|
+
require_relative 'threat_detection'
|
|
27
|
+
require_relative 'compliance'
|
|
19
28
|
|
|
20
29
|
module Pangea
|
|
21
30
|
module Components
|
|
22
31
|
module ZeroTrustNetwork
|
|
32
|
+
include Policies
|
|
33
|
+
include Audit
|
|
34
|
+
include Networking
|
|
35
|
+
include Segments
|
|
36
|
+
include Endpoints
|
|
37
|
+
include SecurityAutomation
|
|
38
|
+
include Monitoring
|
|
39
|
+
include ThreatDetection
|
|
40
|
+
include Compliance
|
|
41
|
+
|
|
23
42
|
# Zero Trust Network Architecture Component
|
|
24
|
-
# Implements identity-based access control with continuous verification
|
|
25
43
|
def zero_trust_network(name, attributes = {})
|
|
26
|
-
# Validate attributes
|
|
27
44
|
attrs = Attributes.new(attributes)
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
45
|
+
resources = initialize_resources
|
|
46
|
+
|
|
47
|
+
create_trust_provider(name, attrs, resources)
|
|
48
|
+
create_verified_access_instance(name, attrs, resources)
|
|
49
|
+
create_access_logging(name, attrs, resources)
|
|
50
|
+
create_network_segments(name, attrs, resources)
|
|
51
|
+
create_verified_access_group(name, attrs, resources)
|
|
52
|
+
create_endpoints(name, attrs, resources)
|
|
53
|
+
create_vpc_endpoints(name, attrs, resources)
|
|
54
|
+
create_flow_logs(name, attrs, resources) if attrs.monitoring_config[:enable_flow_logs]
|
|
55
|
+
create_security_automation(name, attrs, resources)
|
|
56
|
+
create_monitoring_alarms(name, attrs, resources)
|
|
57
|
+
create_threat_detection(name, attrs, resources) if threat_detection_enabled?(attrs)
|
|
58
|
+
|
|
59
|
+
create_component_reference('zero_trust_network', name, attrs.to_h, resources, build_outputs(name, attrs, resources))
|
|
60
|
+
end
|
|
61
|
+
|
|
62
|
+
private
|
|
63
|
+
|
|
64
|
+
def initialize_resources
|
|
65
|
+
{
|
|
66
|
+
trust_provider: nil, verified_access_instance: nil, verified_access_groups: {},
|
|
67
|
+
verified_access_endpoints: {}, security_groups: {}, network_acls: {},
|
|
68
|
+
vpc_endpoints: {}, flow_logs: {}, cloudwatch_logs: {}, s3_buckets: {},
|
|
69
|
+
lambda_functions: {}, event_rules: {}, alarms: {}
|
|
44
70
|
}
|
|
45
|
-
|
|
46
|
-
|
|
71
|
+
end
|
|
72
|
+
|
|
73
|
+
def create_trust_provider(name, attrs, resources)
|
|
47
74
|
trust_provider_name = component_resource_name(name, :trust_provider)
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
75
|
+
resources[:trust_provider] = attrs.trust_provider_type == 'user' ?
|
|
76
|
+
create_user_trust_provider(trust_provider_name, attrs) :
|
|
77
|
+
create_device_trust_provider(trust_provider_name, attrs)
|
|
78
|
+
end
|
|
79
|
+
|
|
80
|
+
def create_user_trust_provider(trust_provider_name, attrs)
|
|
81
|
+
aws_verifiedaccess_trust_provider(trust_provider_name, {
|
|
82
|
+
trust_provider_type: attrs.trust_provider_type,
|
|
83
|
+
user_trust_provider_type: attrs.identity_provider[:type],
|
|
84
|
+
oidc_options: attrs.identity_provider[:type] == 'oidc' ? oidc_options(attrs) : nil,
|
|
85
|
+
tags: component_tags('zero_trust_network', trust_provider_name, attrs.tags)
|
|
86
|
+
})
|
|
87
|
+
end
|
|
88
|
+
|
|
89
|
+
def create_device_trust_provider(trust_provider_name, attrs)
|
|
90
|
+
aws_verifiedaccess_trust_provider(trust_provider_name, {
|
|
91
|
+
trust_provider_type: attrs.trust_provider_type,
|
|
92
|
+
device_trust_provider_type: 'jamf',
|
|
93
|
+
tags: component_tags('zero_trust_network', trust_provider_name, attrs.tags)
|
|
94
|
+
})
|
|
95
|
+
end
|
|
96
|
+
|
|
97
|
+
def oidc_options(attrs)
|
|
98
|
+
ip = attrs.identity_provider
|
|
99
|
+
{ issuer: ip[:issuer], authorization_endpoint: ip[:authorization_endpoint],
|
|
100
|
+
token_endpoint: ip[:token_endpoint], user_info_endpoint: ip[:user_info_endpoint],
|
|
101
|
+
client_id: ip[:client_id], client_secret: ip[:client_secret], scope: ip[:scope] }
|
|
102
|
+
end
|
|
103
|
+
|
|
104
|
+
def create_verified_access_instance(name, attrs, resources)
|
|
73
105
|
instance_name = component_resource_name(name, :verified_access)
|
|
74
106
|
resources[:verified_access_instance] = aws_verifiedaccess_instance(instance_name, {
|
|
75
107
|
description: "Zero Trust Network for #{name}",
|
|
76
108
|
trust_provider_ids: [resources[:trust_provider].id],
|
|
77
109
|
tags: component_tags('zero_trust_network', name, attrs.tags)
|
|
78
110
|
})
|
|
79
|
-
|
|
80
|
-
|
|
111
|
+
end
|
|
112
|
+
|
|
113
|
+
def create_access_logging(name, attrs, resources)
|
|
81
114
|
log_group_name = component_resource_name(name, :access_logs)
|
|
82
115
|
resources[:cloudwatch_logs][:access] = aws_cloudwatch_log_group(log_group_name, {
|
|
83
116
|
name: "/aws/verified-access/#{name}",
|
|
84
117
|
retention_in_days: attrs.monitoring_config[:log_retention_days],
|
|
85
118
|
tags: component_tags('zero_trust_network', name, attrs.tags)
|
|
86
119
|
})
|
|
87
|
-
|
|
88
|
-
|
|
120
|
+
|
|
121
|
+
instance_name = component_resource_name(name, :verified_access)
|
|
89
122
|
aws_verifiedaccess_instance_logging_configuration(:"#{instance_name}_logging", {
|
|
90
123
|
verified_access_instance_id: resources[:verified_access_instance].id,
|
|
91
|
-
access_logs:
|
|
92
|
-
cloudwatch_logs: {
|
|
93
|
-
enabled: true,
|
|
94
|
-
log_group: resources[:cloudwatch_logs][:access].name
|
|
95
|
-
},
|
|
96
|
-
s3: attrs.audit_config[:audit_log_destination] == 's3' || attrs.audit_config[:audit_log_destination] == 'both' ? {
|
|
97
|
-
enabled: true,
|
|
98
|
-
bucket_name: create_audit_bucket(name, attrs, resources)
|
|
99
|
-
} : nil
|
|
100
|
-
}
|
|
124
|
+
access_logs: build_access_logs_config(name, attrs, resources)
|
|
101
125
|
})
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
description: segment[:description] || "Zero Trust segment: #{segment[:name]}",
|
|
109
|
-
vpc_id: attrs.vpc_ref,
|
|
110
|
-
tags: component_tags('zero_trust_network', name, attrs.tags.merge(
|
|
111
|
-
Segment: segment[:name]
|
|
112
|
-
))
|
|
113
|
-
})
|
|
114
|
-
|
|
115
|
-
# Add ingress rules for verified access
|
|
116
|
-
aws_vpc_security_group_ingress_rule(:"#{sg_name}_va_ingress", {
|
|
117
|
-
security_group_id: resources[:security_groups][segment[:name]].id,
|
|
118
|
-
description: "Allow verified access",
|
|
119
|
-
from_port: 443,
|
|
120
|
-
to_port: 443,
|
|
121
|
-
ip_protocol: 'tcp',
|
|
122
|
-
cidr_ipv4: '0.0.0.0/0'
|
|
123
|
-
})
|
|
124
|
-
|
|
125
|
-
# Create NACLs if specified
|
|
126
|
-
if segment[:nacl_rules] && !segment[:nacl_rules].empty?
|
|
127
|
-
nacl_name = component_resource_name(name, :nacl, segment[:name])
|
|
128
|
-
resources[:network_acls][segment[:name]] = aws_network_acl(nacl_name, {
|
|
129
|
-
vpc_id: attrs.vpc_ref,
|
|
130
|
-
tags: component_tags('zero_trust_network', name, attrs.tags.merge(
|
|
131
|
-
Segment: segment[:name]
|
|
132
|
-
))
|
|
133
|
-
})
|
|
134
|
-
|
|
135
|
-
# Add NACL rules
|
|
136
|
-
segment[:nacl_rules].each_with_index do |rule, index|
|
|
137
|
-
aws_network_acl_rule(:"#{nacl_name}_rule_#{index}", {
|
|
138
|
-
network_acl_id: resources[:network_acls][segment[:name]].id,
|
|
139
|
-
rule_number: rule[:rule_number] || (index + 1) * 100,
|
|
140
|
-
protocol: rule[:protocol] || 'tcp',
|
|
141
|
-
rule_action: rule[:action] || 'allow',
|
|
142
|
-
cidr_block: rule[:cidr_block],
|
|
143
|
-
from_port: rule[:from_port],
|
|
144
|
-
to_port: rule[:to_port]
|
|
145
|
-
})
|
|
146
|
-
end
|
|
147
|
-
end
|
|
126
|
+
end
|
|
127
|
+
|
|
128
|
+
def build_access_logs_config(name, attrs, resources)
|
|
129
|
+
config = { cloudwatch_logs: { enabled: true, log_group: resources[:cloudwatch_logs][:access].name } }
|
|
130
|
+
if %w[s3 both].include?(attrs.audit_config[:audit_log_destination])
|
|
131
|
+
config[:s3] = { enabled: true, bucket_name: create_audit_bucket(name, attrs, resources) }
|
|
148
132
|
end
|
|
149
|
-
|
|
150
|
-
|
|
133
|
+
config
|
|
134
|
+
end
|
|
135
|
+
|
|
136
|
+
def create_verified_access_group(name, attrs, resources)
|
|
151
137
|
group_name = component_resource_name(name, :group)
|
|
152
138
|
resources[:verified_access_groups][:main] = aws_verifiedaccess_group(group_name, {
|
|
153
139
|
verified_access_instance_id: resources[:verified_access_instance].id,
|
|
@@ -155,520 +141,34 @@ module Pangea
|
|
|
155
141
|
policy_document: generate_default_policy(attrs),
|
|
156
142
|
tags: component_tags('zero_trust_network', name, attrs.tags)
|
|
157
143
|
})
|
|
158
|
-
|
|
159
|
-
|
|
160
|
-
|
|
161
|
-
|
|
162
|
-
|
|
163
|
-
|
|
164
|
-
|
|
165
|
-
|
|
166
|
-
resources[:verified_access_endpoints][endpoint[:name]] = aws_verifiedaccess_endpoint(endpoint_name, {
|
|
167
|
-
verified_access_group_id: resources[:verified_access_groups][:main].id,
|
|
168
|
-
description: "Endpoint: #{endpoint[:name]}",
|
|
169
|
-
endpoint_type: endpoint[:type],
|
|
170
|
-
attachment_type: 'vpc',
|
|
171
|
-
domain_certificate_arn: endpoint[:domain_name] ? create_certificate(endpoint[:domain_name], name, attrs, resources) : nil,
|
|
172
|
-
endpoint_domain_prefix: endpoint[:domain_name] ? endpoint[:name] : nil,
|
|
173
|
-
security_group_ids: [resources[:security_groups].values.first.id],
|
|
174
|
-
policy_document: policy_document,
|
|
175
|
-
network_interface_options: endpoint[:type] == 'network' ? {
|
|
176
|
-
port: endpoint[:port],
|
|
177
|
-
protocol: endpoint[:protocol]
|
|
178
|
-
} : nil,
|
|
179
|
-
tags: component_tags('zero_trust_network', name, attrs.tags.merge(
|
|
180
|
-
EndpointName: endpoint[:name]
|
|
181
|
-
))
|
|
182
|
-
})
|
|
183
|
-
end
|
|
184
|
-
|
|
185
|
-
# Create VPC endpoints for AWS services
|
|
186
|
-
create_vpc_endpoints(name, attrs, resources)
|
|
187
|
-
|
|
188
|
-
# Enable flow logs if configured
|
|
189
|
-
if attrs.monitoring_config[:enable_flow_logs]
|
|
190
|
-
create_flow_logs(name, attrs, resources)
|
|
191
|
-
end
|
|
192
|
-
|
|
193
|
-
# Create Lambda functions for advanced security features
|
|
194
|
-
create_security_automation(name, attrs, resources)
|
|
195
|
-
|
|
196
|
-
# Create CloudWatch alarms
|
|
197
|
-
create_monitoring_alarms(name, attrs, resources)
|
|
198
|
-
|
|
199
|
-
# Create threat detection resources
|
|
200
|
-
if attrs.threat_protection[:enable_ids] || attrs.threat_protection[:enable_ips]
|
|
201
|
-
create_threat_detection(name, attrs, resources)
|
|
202
|
-
end
|
|
203
|
-
|
|
204
|
-
# Component outputs
|
|
205
|
-
outputs = {
|
|
144
|
+
end
|
|
145
|
+
|
|
146
|
+
def threat_detection_enabled?(attrs)
|
|
147
|
+
attrs.threat_protection[:enable_ids] || attrs.threat_protection[:enable_ips]
|
|
148
|
+
end
|
|
149
|
+
|
|
150
|
+
def build_outputs(_name, attrs, resources)
|
|
151
|
+
{
|
|
206
152
|
verified_access_instance_id: resources[:verified_access_instance].id,
|
|
207
153
|
verified_access_instance_arn: resources[:verified_access_instance].arn,
|
|
208
154
|
trust_provider_id: resources[:trust_provider].id,
|
|
209
155
|
verified_access_group_id: resources[:verified_access_groups][:main].id,
|
|
210
|
-
endpoints: resources[:verified_access_endpoints].transform_values
|
|
211
|
-
security_groups: resources[:security_groups].transform_values
|
|
156
|
+
endpoints: resources[:verified_access_endpoints].transform_values(&:id),
|
|
157
|
+
security_groups: resources[:security_groups].transform_values(&:id),
|
|
212
158
|
compliance_status: generate_compliance_status(attrs),
|
|
213
159
|
security_score: calculate_security_score(attrs, resources)
|
|
214
160
|
}
|
|
215
|
-
|
|
216
|
-
# Create component reference
|
|
217
|
-
create_component_reference(
|
|
218
|
-
'zero_trust_network',
|
|
219
|
-
name,
|
|
220
|
-
attrs.to_h,
|
|
221
|
-
resources,
|
|
222
|
-
outputs
|
|
223
|
-
)
|
|
224
|
-
end
|
|
225
|
-
|
|
226
|
-
private
|
|
227
|
-
|
|
228
|
-
def generate_default_policy(attrs)
|
|
229
|
-
policy = {
|
|
230
|
-
version: "2012-10-17",
|
|
231
|
-
statement: [
|
|
232
|
-
{
|
|
233
|
-
effect: "Allow",
|
|
234
|
-
principal: {
|
|
235
|
-
federated: attrs.identity_provider[:identity_provider_arn] || "arn:aws:iam::#{aws_account_id}:saml-provider/#{attrs.identity_provider[:issuer]}"
|
|
236
|
-
},
|
|
237
|
-
action: "sts:AssumeRoleWithWebIdentity",
|
|
238
|
-
condition: {}
|
|
239
|
-
}
|
|
240
|
-
]
|
|
241
|
-
}
|
|
242
|
-
|
|
243
|
-
# Add MFA requirement if enabled
|
|
244
|
-
if attrs.verification_settings[:require_mfa]
|
|
245
|
-
policy[:statement][0][:condition]["Bool"] = {
|
|
246
|
-
"aws:MultiFactorAuthPresent" => "true"
|
|
247
|
-
}
|
|
248
|
-
end
|
|
249
|
-
|
|
250
|
-
# Add session duration
|
|
251
|
-
policy[:statement][0][:condition]["NumericLessThanEquals"] = {
|
|
252
|
-
"aws:TokenIssueTime" => attrs.verification_settings[:session_duration]
|
|
253
|
-
}
|
|
254
|
-
|
|
255
|
-
JSON.pretty_generate(policy)
|
|
256
161
|
end
|
|
257
|
-
|
|
258
|
-
def generate_endpoint_policy(endpoint, attrs)
|
|
259
|
-
policy = {
|
|
260
|
-
version: "2012-10-17",
|
|
261
|
-
statement: [
|
|
262
|
-
{
|
|
263
|
-
effect: "Allow",
|
|
264
|
-
action: ["verified-access:*"],
|
|
265
|
-
resource: "*",
|
|
266
|
-
condition: {
|
|
267
|
-
"StringEquals" => {
|
|
268
|
-
"verified-access:endpoint-type" => endpoint[:type]
|
|
269
|
-
}
|
|
270
|
-
}
|
|
271
|
-
}
|
|
272
|
-
]
|
|
273
|
-
}
|
|
274
|
-
|
|
275
|
-
JSON.pretty_generate(policy)
|
|
276
|
-
end
|
|
277
|
-
|
|
278
|
-
def create_audit_bucket(name, attrs, resources)
|
|
279
|
-
bucket_name = component_resource_name(name, :audit_bucket)
|
|
280
|
-
resources[:s3_buckets][:audit] = aws_s3_bucket(bucket_name, {
|
|
281
|
-
bucket: "zt-audit-#{name}-#{aws_region}",
|
|
282
|
-
tags: component_tags('zero_trust_network', name, attrs.tags)
|
|
283
|
-
})
|
|
284
|
-
|
|
285
|
-
# Enable versioning
|
|
286
|
-
aws_s3_bucket_versioning(:"#{bucket_name}_versioning", {
|
|
287
|
-
bucket: resources[:s3_buckets][:audit].id,
|
|
288
|
-
versioning_configuration: {
|
|
289
|
-
status: "Enabled"
|
|
290
|
-
}
|
|
291
|
-
})
|
|
292
|
-
|
|
293
|
-
# Enable encryption
|
|
294
|
-
aws_s3_bucket_server_side_encryption_configuration(:"#{bucket_name}_encryption", {
|
|
295
|
-
bucket: resources[:s3_buckets][:audit].id,
|
|
296
|
-
rule: {
|
|
297
|
-
apply_server_side_encryption_by_default: {
|
|
298
|
-
sse_algorithm: "aws:kms"
|
|
299
|
-
}
|
|
300
|
-
}
|
|
301
|
-
})
|
|
302
|
-
|
|
303
|
-
# Block public access
|
|
304
|
-
aws_s3_bucket_public_access_block(:"#{bucket_name}_pab", {
|
|
305
|
-
bucket: resources[:s3_buckets][:audit].id,
|
|
306
|
-
block_public_acls: true,
|
|
307
|
-
block_public_policy: true,
|
|
308
|
-
ignore_public_acls: true,
|
|
309
|
-
restrict_public_buckets: true
|
|
310
|
-
})
|
|
311
|
-
|
|
312
|
-
resources[:s3_buckets][:audit].id
|
|
313
|
-
end
|
|
314
|
-
|
|
315
|
-
def create_certificate(domain_name, name, attrs, resources)
|
|
316
|
-
# This would typically request or import a certificate
|
|
317
|
-
# For now, return a placeholder
|
|
318
|
-
"arn:aws:acm:#{aws_region}:#{aws_account_id}:certificate/placeholder"
|
|
319
|
-
end
|
|
320
|
-
|
|
321
|
-
def create_vpc_endpoints(name, attrs, resources)
|
|
322
|
-
# Create VPC endpoints for AWS services
|
|
323
|
-
services = ['s3', 'ec2', 'ssm', 'logs']
|
|
324
|
-
|
|
325
|
-
services.each do |service|
|
|
326
|
-
endpoint_name = component_resource_name(name, :vpc_endpoint, service)
|
|
327
|
-
resources[:vpc_endpoints][service] = aws_vpc_endpoint(endpoint_name, {
|
|
328
|
-
vpc_id: attrs.vpc_ref,
|
|
329
|
-
service_name: "com.amazonaws.#{aws_region}.#{service}",
|
|
330
|
-
vpc_endpoint_type: service == 's3' ? 'Gateway' : 'Interface',
|
|
331
|
-
security_group_ids: service != 's3' ? [resources[:security_groups].values.first.id] : nil,
|
|
332
|
-
subnet_ids: service != 's3' ? attrs.subnet_refs : nil,
|
|
333
|
-
tags: component_tags('zero_trust_network', name, attrs.tags.merge(
|
|
334
|
-
Service: service
|
|
335
|
-
))
|
|
336
|
-
})
|
|
337
|
-
end
|
|
338
|
-
end
|
|
339
|
-
|
|
340
|
-
def create_flow_logs(name, attrs, resources)
|
|
341
|
-
# Create flow log group
|
|
342
|
-
flow_log_group_name = component_resource_name(name, :flow_logs)
|
|
343
|
-
resources[:cloudwatch_logs][:flow] = aws_cloudwatch_log_group(flow_log_group_name, {
|
|
344
|
-
name: "/aws/vpc/flowlogs/#{name}",
|
|
345
|
-
retention_in_days: attrs.monitoring_config[:log_retention_days],
|
|
346
|
-
tags: component_tags('zero_trust_network', name, attrs.tags)
|
|
347
|
-
})
|
|
348
|
-
|
|
349
|
-
# Create flow log
|
|
350
|
-
resources[:flow_logs][:vpc] = aws_flow_log(:"#{name}_vpc_flow_log", {
|
|
351
|
-
log_destination_type: 'cloud-watch-logs',
|
|
352
|
-
log_destination: resources[:cloudwatch_logs][:flow].arn,
|
|
353
|
-
traffic_type: 'ALL',
|
|
354
|
-
vpc_id: attrs.vpc_ref,
|
|
355
|
-
tags: component_tags('zero_trust_network', name, attrs.tags)
|
|
356
|
-
})
|
|
357
|
-
end
|
|
358
|
-
|
|
359
|
-
def create_security_automation(name, attrs, resources)
|
|
360
|
-
return unless attrs.advanced_options[:enable_security_automation]
|
|
361
|
-
|
|
362
|
-
# Create Lambda for policy evaluation
|
|
363
|
-
lambda_name = component_resource_name(name, :policy_evaluator)
|
|
364
|
-
resources[:lambda_functions][:policy_evaluator] = aws_lambda_function(lambda_name, {
|
|
365
|
-
function_name: "zt-policy-evaluator-#{name}",
|
|
366
|
-
runtime: 'python3.9',
|
|
367
|
-
handler: 'index.lambda_handler',
|
|
368
|
-
role: create_lambda_role(name, attrs, resources),
|
|
369
|
-
code: {
|
|
370
|
-
zip_file: generate_policy_evaluator_code()
|
|
371
|
-
},
|
|
372
|
-
environment: {
|
|
373
|
-
variables: {
|
|
374
|
-
VERIFIED_ACCESS_INSTANCE_ID: resources[:verified_access_instance].id,
|
|
375
|
-
COMPLIANCE_FRAMEWORKS: attrs.compliance_frameworks.join(',')
|
|
376
|
-
}
|
|
377
|
-
},
|
|
378
|
-
tags: component_tags('zero_trust_network', name, attrs.tags)
|
|
379
|
-
})
|
|
380
|
-
|
|
381
|
-
# Create EventBridge rule for continuous verification
|
|
382
|
-
rule_name = component_resource_name(name, :verification_rule)
|
|
383
|
-
resources[:event_rules][:verification] = aws_cloudwatch_event_rule(rule_name, {
|
|
384
|
-
name: "zt-verification-#{name}",
|
|
385
|
-
description: "Continuous verification for zero trust network",
|
|
386
|
-
schedule_expression: "rate(#{attrs.verification_settings[:continuous_verification_interval] / 60} minutes)",
|
|
387
|
-
tags: component_tags('zero_trust_network', name, attrs.tags)
|
|
388
|
-
})
|
|
389
|
-
|
|
390
|
-
# Add Lambda as target
|
|
391
|
-
aws_cloudwatch_event_target(:"#{rule_name}_target", {
|
|
392
|
-
rule: resources[:event_rules][:verification].name,
|
|
393
|
-
arn: resources[:lambda_functions][:policy_evaluator].arn,
|
|
394
|
-
target_id: "PolicyEvaluator"
|
|
395
|
-
})
|
|
396
|
-
end
|
|
397
|
-
|
|
398
|
-
def create_lambda_role(name, attrs, resources)
|
|
399
|
-
role_name = component_resource_name(name, :lambda_role)
|
|
400
|
-
role = aws_iam_role(role_name, {
|
|
401
|
-
name: "zt-lambda-role-#{name}",
|
|
402
|
-
assume_role_policy: JSON.pretty_generate({
|
|
403
|
-
Version: "2012-10-17",
|
|
404
|
-
Statement: [{
|
|
405
|
-
Action: "sts:AssumeRole",
|
|
406
|
-
Effect: "Allow",
|
|
407
|
-
Principal: {
|
|
408
|
-
Service: "lambda.amazonaws.com"
|
|
409
|
-
}
|
|
410
|
-
}]
|
|
411
|
-
}),
|
|
412
|
-
tags: component_tags('zero_trust_network', name, attrs.tags)
|
|
413
|
-
})
|
|
414
|
-
|
|
415
|
-
# Attach policies
|
|
416
|
-
aws_iam_role_policy_attachment(:"#{role_name}_basic", {
|
|
417
|
-
role: role.name,
|
|
418
|
-
policy_arn: "arn:aws:iam::aws:policy/service-role/AWSLambdaBasicExecutionRole"
|
|
419
|
-
})
|
|
420
|
-
|
|
421
|
-
aws_iam_role_policy_attachment(:"#{role_name}_vpc", {
|
|
422
|
-
role: role.name,
|
|
423
|
-
policy_arn: "arn:aws:iam::aws:policy/service-role/AWSLambdaVPCAccessExecutionRole"
|
|
424
|
-
})
|
|
425
|
-
|
|
426
|
-
role.arn
|
|
427
|
-
end
|
|
428
|
-
|
|
429
|
-
def generate_policy_evaluator_code
|
|
430
|
-
<<~PYTHON
|
|
431
|
-
import json
|
|
432
|
-
import boto3
|
|
433
|
-
import os
|
|
434
|
-
from datetime import datetime
|
|
435
|
-
|
|
436
|
-
def lambda_handler(event, context):
|
|
437
|
-
instance_id = os.environ['VERIFIED_ACCESS_INSTANCE_ID']
|
|
438
|
-
frameworks = os.environ['COMPLIANCE_FRAMEWORKS'].split(',')
|
|
439
|
-
|
|
440
|
-
# Evaluate compliance
|
|
441
|
-
compliance_results = evaluate_compliance(instance_id, frameworks)
|
|
442
|
-
|
|
443
|
-
# Check for policy violations
|
|
444
|
-
violations = check_policy_violations(instance_id)
|
|
445
|
-
|
|
446
|
-
# Generate security score
|
|
447
|
-
security_score = calculate_security_score(compliance_results, violations)
|
|
448
|
-
|
|
449
|
-
return {
|
|
450
|
-
'statusCode': 200,
|
|
451
|
-
'body': json.dumps({
|
|
452
|
-
'timestamp': datetime.utcnow().isoformat(),
|
|
453
|
-
'compliance': compliance_results,
|
|
454
|
-
'violations': violations,
|
|
455
|
-
'security_score': security_score
|
|
456
|
-
})
|
|
457
|
-
}
|
|
458
|
-
|
|
459
|
-
def evaluate_compliance(instance_id, frameworks):
|
|
460
|
-
# Implement compliance evaluation logic
|
|
461
|
-
return {framework: 'compliant' for framework in frameworks}
|
|
462
|
-
|
|
463
|
-
def check_policy_violations(instance_id):
|
|
464
|
-
# Implement policy violation detection
|
|
465
|
-
return []
|
|
466
|
-
|
|
467
|
-
def calculate_security_score(compliance, violations):
|
|
468
|
-
# Calculate security score based on compliance and violations
|
|
469
|
-
base_score = 100
|
|
470
|
-
violation_penalty = len(violations) * 5
|
|
471
|
-
return max(0, base_score - violation_penalty)
|
|
472
|
-
PYTHON
|
|
473
|
-
end
|
|
474
|
-
|
|
475
|
-
def create_monitoring_alarms(name, attrs, resources)
|
|
476
|
-
return unless attrs.monitoring_config[:create_alarms]
|
|
477
|
-
|
|
478
|
-
# Access denied alarm
|
|
479
|
-
alarm_name = component_resource_name(name, :access_denied_alarm)
|
|
480
|
-
resources[:alarms][:access_denied] = aws_cloudwatch_metric_alarm(alarm_name, {
|
|
481
|
-
alarm_name: "zt-access-denied-#{name}",
|
|
482
|
-
alarm_description: "Alert on excessive access denials",
|
|
483
|
-
metric_name: "AccessDenied",
|
|
484
|
-
namespace: "AWS/VerifiedAccess",
|
|
485
|
-
statistic: "Sum",
|
|
486
|
-
period: 300,
|
|
487
|
-
evaluation_periods: 2,
|
|
488
|
-
threshold: attrs.verification_settings[:max_failed_attempts],
|
|
489
|
-
comparison_operator: "GreaterThanThreshold",
|
|
490
|
-
dimensions: {
|
|
491
|
-
VerifiedAccessInstanceId: resources[:verified_access_instance].id
|
|
492
|
-
},
|
|
493
|
-
tags: component_tags('zero_trust_network', name, attrs.tags)
|
|
494
|
-
})
|
|
495
|
-
|
|
496
|
-
# Policy violation alarm
|
|
497
|
-
if attrs.monitoring_config[:alert_on_policy_violations]
|
|
498
|
-
violation_alarm_name = component_resource_name(name, :policy_violation_alarm)
|
|
499
|
-
resources[:alarms][:policy_violation] = aws_cloudwatch_metric_alarm(violation_alarm_name, {
|
|
500
|
-
alarm_name: "zt-policy-violation-#{name}",
|
|
501
|
-
alarm_description: "Alert on policy violations",
|
|
502
|
-
metric_name: "PolicyViolations",
|
|
503
|
-
namespace: "Custom/ZeroTrust",
|
|
504
|
-
statistic: "Sum",
|
|
505
|
-
period: 300,
|
|
506
|
-
evaluation_periods: 1,
|
|
507
|
-
threshold: 1,
|
|
508
|
-
comparison_operator: "GreaterThanOrEqualToThreshold",
|
|
509
|
-
tags: component_tags('zero_trust_network', name, attrs.tags)
|
|
510
|
-
})
|
|
511
|
-
end
|
|
512
|
-
|
|
513
|
-
# Suspicious activity alarm
|
|
514
|
-
if attrs.monitoring_config[:alert_on_suspicious_activity]
|
|
515
|
-
suspicious_alarm_name = component_resource_name(name, :suspicious_activity_alarm)
|
|
516
|
-
resources[:alarms][:suspicious_activity] = aws_cloudwatch_metric_alarm(suspicious_alarm_name, {
|
|
517
|
-
alarm_name: "zt-suspicious-activity-#{name}",
|
|
518
|
-
alarm_description: "Alert on suspicious activity patterns",
|
|
519
|
-
metric_name: "SuspiciousActivity",
|
|
520
|
-
namespace: "Custom/ZeroTrust",
|
|
521
|
-
statistic: "Sum",
|
|
522
|
-
period: 300,
|
|
523
|
-
evaluation_periods: 1,
|
|
524
|
-
threshold: 1,
|
|
525
|
-
comparison_operator: "GreaterThanOrEqualToThreshold",
|
|
526
|
-
tags: component_tags('zero_trust_network', name, attrs.tags)
|
|
527
|
-
})
|
|
528
|
-
end
|
|
529
|
-
end
|
|
530
|
-
|
|
531
|
-
def create_threat_detection(name, attrs, resources)
|
|
532
|
-
# Create GuardDuty detector if IDS is enabled
|
|
533
|
-
if attrs.threat_protection[:enable_ids]
|
|
534
|
-
detector_name = component_resource_name(name, :guardduty)
|
|
535
|
-
resources[:guardduty] = aws_guardduty_detector(detector_name, {
|
|
536
|
-
enable: true,
|
|
537
|
-
finding_publishing_frequency: "FIFTEEN_MINUTES",
|
|
538
|
-
tags: component_tags('zero_trust_network', name, attrs.tags)
|
|
539
|
-
})
|
|
540
|
-
end
|
|
541
|
-
|
|
542
|
-
# Create WAF if enabled
|
|
543
|
-
if attrs.threat_protection[:enable_waf]
|
|
544
|
-
waf_name = component_resource_name(name, :waf)
|
|
545
|
-
resources[:waf] = aws_wafv2_web_acl(waf_name, {
|
|
546
|
-
name: "zt-waf-#{name}",
|
|
547
|
-
scope: "REGIONAL",
|
|
548
|
-
default_action: {
|
|
549
|
-
allow: {}
|
|
550
|
-
},
|
|
551
|
-
rules: generate_waf_rules(attrs),
|
|
552
|
-
visibility_config: {
|
|
553
|
-
cloudwatch_metrics_enabled: true,
|
|
554
|
-
metric_name: "zt-waf-#{name}",
|
|
555
|
-
sampled_requests_enabled: true
|
|
556
|
-
},
|
|
557
|
-
tags: component_tags('zero_trust_network', name, attrs.tags)
|
|
558
|
-
})
|
|
559
|
-
end
|
|
560
|
-
end
|
|
561
|
-
|
|
562
|
-
def generate_waf_rules(attrs)
|
|
563
|
-
rules = []
|
|
564
|
-
|
|
565
|
-
# Add managed rule groups
|
|
566
|
-
rules << {
|
|
567
|
-
name: "AWSManagedRulesCommonRuleSet",
|
|
568
|
-
priority: 1,
|
|
569
|
-
override_action: {
|
|
570
|
-
none: {}
|
|
571
|
-
},
|
|
572
|
-
statement: {
|
|
573
|
-
managed_rule_group_statement: {
|
|
574
|
-
vendor_name: "AWS",
|
|
575
|
-
name: "AWSManagedRulesCommonRuleSet"
|
|
576
|
-
}
|
|
577
|
-
},
|
|
578
|
-
visibility_config: {
|
|
579
|
-
cloudwatch_metrics_enabled: true,
|
|
580
|
-
metric_name: "CommonRuleSetMetric",
|
|
581
|
-
sampled_requests_enabled: true
|
|
582
|
-
}
|
|
583
|
-
}
|
|
584
|
-
|
|
585
|
-
# Add rate limiting rule
|
|
586
|
-
rules << {
|
|
587
|
-
name: "RateLimitRule",
|
|
588
|
-
priority: 2,
|
|
589
|
-
action: {
|
|
590
|
-
block: {}
|
|
591
|
-
},
|
|
592
|
-
statement: {
|
|
593
|
-
rate_based_statement: {
|
|
594
|
-
limit: 2000,
|
|
595
|
-
aggregate_key_type: "IP"
|
|
596
|
-
}
|
|
597
|
-
},
|
|
598
|
-
visibility_config: {
|
|
599
|
-
cloudwatch_metrics_enabled: true,
|
|
600
|
-
metric_name: "RateLimitMetric",
|
|
601
|
-
sampled_requests_enabled: true
|
|
602
|
-
}
|
|
603
|
-
}
|
|
604
|
-
|
|
605
|
-
rules
|
|
606
|
-
end
|
|
607
|
-
|
|
608
|
-
def generate_compliance_status(attrs)
|
|
609
|
-
status = {}
|
|
610
|
-
|
|
611
|
-
attrs.compliance_frameworks.each do |framework|
|
|
612
|
-
status[framework] = {
|
|
613
|
-
compliant: true,
|
|
614
|
-
last_assessment: Time.now.iso8601,
|
|
615
|
-
controls_passed: compliance_controls_for_framework(framework).count,
|
|
616
|
-
controls_total: compliance_controls_for_framework(framework).count
|
|
617
|
-
}
|
|
618
|
-
end
|
|
619
|
-
|
|
620
|
-
status
|
|
621
|
-
end
|
|
622
|
-
|
|
623
|
-
def compliance_controls_for_framework(framework)
|
|
624
|
-
case framework
|
|
625
|
-
when 'soc2'
|
|
626
|
-
['CC1.1', 'CC1.2', 'CC1.3', 'CC2.1', 'CC3.1', 'CC4.1', 'CC5.1', 'CC6.1', 'CC7.1', 'CC8.1', 'CC9.1']
|
|
627
|
-
when 'iso27001'
|
|
628
|
-
['A.5.1', 'A.6.1', 'A.7.1', 'A.8.1', 'A.9.1', 'A.10.1', 'A.11.1', 'A.12.1', 'A.13.1', 'A.14.1']
|
|
629
|
-
when 'nist'
|
|
630
|
-
['AC-1', 'AC-2', 'AC-3', 'AU-1', 'AU-2', 'CA-1', 'CA-2', 'CM-1', 'CP-1', 'IA-1', 'IR-1', 'MA-1']
|
|
631
|
-
when 'pci-dss'
|
|
632
|
-
['1.1', '1.2', '2.1', '2.2', '3.1', '3.2', '4.1', '5.1', '6.1', '7.1', '8.1', '9.1', '10.1', '11.1', '12.1']
|
|
633
|
-
when 'hipaa'
|
|
634
|
-
['164.308', '164.310', '164.312', '164.314', '164.316']
|
|
635
|
-
when 'fedramp'
|
|
636
|
-
['AC-1', 'AC-2', 'AU-1', 'CA-1', 'CM-1', 'CP-1', 'IA-1', 'IR-1', 'MA-1', 'MP-1', 'PE-1', 'PL-1', 'PS-1', 'RA-1', 'SA-1', 'SC-1', 'SI-1']
|
|
637
|
-
else
|
|
638
|
-
[]
|
|
639
|
-
end
|
|
640
|
-
end
|
|
641
|
-
|
|
642
|
-
def calculate_security_score(attrs, resources)
|
|
643
|
-
score = 100
|
|
644
|
-
|
|
645
|
-
# Deduct points for missing features
|
|
646
|
-
score -= 5 unless attrs.verification_settings[:require_mfa]
|
|
647
|
-
score -= 5 unless attrs.monitoring_config[:enable_anomaly_detection]
|
|
648
|
-
score -= 5 unless attrs.threat_protection[:enable_ids]
|
|
649
|
-
score -= 5 unless attrs.threat_protection[:enable_ips]
|
|
650
|
-
score -= 5 unless attrs.advanced_options[:enable_microsegmentation]
|
|
651
|
-
score -= 10 unless attrs.audit_config[:enable_tamper_protection]
|
|
652
|
-
|
|
653
|
-
# Add points for advanced features
|
|
654
|
-
score += 5 if attrs.advanced_options[:enable_security_automation]
|
|
655
|
-
score += 5 if attrs.threat_protection[:automated_response]
|
|
656
|
-
score += 5 if attrs.advanced_options[:enable_privileged_access_management]
|
|
657
|
-
|
|
658
|
-
[score, 100].min
|
|
659
|
-
end
|
|
660
|
-
|
|
162
|
+
|
|
661
163
|
def aws_region
|
|
662
|
-
# This would be dynamically determined
|
|
663
164
|
'us-east-1'
|
|
664
165
|
end
|
|
665
|
-
|
|
166
|
+
|
|
666
167
|
def aws_account_id
|
|
667
|
-
# This would be dynamically determined
|
|
668
168
|
'123456789012'
|
|
669
169
|
end
|
|
670
|
-
|
|
170
|
+
|
|
671
171
|
include Base
|
|
672
172
|
end
|
|
673
173
|
end
|
|
674
|
-
end
|
|
174
|
+
end
|