pangea 0.0.42 → 0.0.45

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (2040) hide show
  1. checksums.yaml +4 -4
  2. data/.github/ISSUE_TEMPLATE/bug_report.yml +114 -0
  3. data/.github/ISSUE_TEMPLATE/feature_request.yml +67 -0
  4. data/.github/ISSUE_TEMPLATE/question.yml +44 -0
  5. data/.github/PULL_REQUEST_TEMPLATE.md +69 -0
  6. data/.github/workflows/ci.yml +79 -0
  7. data/.github/workflows/release.yml +43 -0
  8. data/.gitignore +72 -37
  9. data/AGENT_GUIDE.md +333 -0
  10. data/CHANGELOG.md +67 -0
  11. data/CLAUDE.md +626 -0
  12. data/CONTRIBUTING.md +143 -0
  13. data/Dockerfile +20 -4
  14. data/EXAMPLES.md +376 -0
  15. data/Gemfile +6 -28
  16. data/Gemfile.lock +265 -74
  17. data/LICENSE +1 -1
  18. data/OPEN_SOURCE_READINESS.md +170 -0
  19. data/README.md +208 -40
  20. data/README_backend_configuration.md +174 -0
  21. data/Rakefile +145 -23
  22. data/SECURITY.md +90 -0
  23. data/Steepfile +33 -0
  24. data/audit_results/vpc_resources_audit.json +219 -0
  25. data/bin/pangea +4 -2
  26. data/docker-compose.test.yml +31 -0
  27. data/docs/RESOURCES.md +456 -0
  28. data/examples/advanced_global_infrastructure.rb +544 -0
  29. data/examples/advanced_ml_healthcare_infrastructure.rb +546 -0
  30. data/examples/api_gateway_complete.rb +275 -0
  31. data/examples/basic-web-app/README.md +176 -0
  32. data/examples/basic-web-app/infrastructure.rb +686 -0
  33. data/examples/basic-web-app/pangea.yaml +36 -0
  34. data/examples/cicd-pipeline/README.md +348 -0
  35. data/examples/cicd-pipeline/infrastructure.rb +1186 -0
  36. data/examples/cicd-pipeline/pangea.yaml +35 -0
  37. data/examples/cloudwatch_monitoring_example.rb +192 -0
  38. data/examples/comprehensive_database_platform.rb +575 -0
  39. data/examples/data-processing/README.md +320 -0
  40. data/examples/data-processing/infrastructure.rb +1616 -0
  41. data/examples/data-processing/pangea.yaml +57 -0
  42. data/examples/disaster-recovery/README.md +446 -0
  43. data/examples/disaster-recovery/infrastructure.rb +1518 -0
  44. data/examples/disaster-recovery/pangea.yaml +62 -0
  45. data/examples/gaming_infrastructure.rb +505 -0
  46. data/examples/global-multi-region/README.md +427 -0
  47. data/examples/global-multi-region/infrastructure.rb +1454 -0
  48. data/examples/global-multi-region/pangea.yaml +61 -0
  49. data/examples/messaging_example.rb +189 -0
  50. data/examples/microservices-platform/README.md +275 -0
  51. data/examples/microservices-platform/infrastructure.rb +1024 -0
  52. data/examples/microservices-platform/pangea.yaml +35 -0
  53. data/examples/ml-platform/README.md +456 -0
  54. data/examples/ml-platform/infrastructure.rb +1882 -0
  55. data/examples/ml-platform/pangea.yaml +58 -0
  56. data/examples/multi-environment/README.md +280 -0
  57. data/examples/multi-environment/infrastructure.rb +1266 -0
  58. data/examples/multi-environment/pangea.yaml +71 -0
  59. data/examples/multi-tier-architecture/README.md +271 -0
  60. data/examples/multi-tier-architecture/infrastructure.rb +1077 -0
  61. data/examples/multi-tier-architecture/pangea.yaml +49 -0
  62. data/examples/resource_composition_patterns.rb +303 -0
  63. data/examples/robotics_and_specialized_services.rb +310 -0
  64. data/examples/scalable_infrastructure.rb +422 -0
  65. data/examples/security-focused/README.md +368 -0
  66. data/examples/security-focused/infrastructure.rb +1684 -0
  67. data/examples/security-focused/pangea.yaml +60 -0
  68. data/examples/simple.rb +39 -0
  69. data/examples/type_safe_infrastructure.rb +214 -0
  70. data/exe/pangea +37 -0
  71. data/flake.lock +49 -16
  72. data/flake.nix +58 -13
  73. data/gemset.nix +756 -116
  74. data/guides/README.md +157 -0
  75. data/guides/advanced-patterns.md +1196 -0
  76. data/guides/cicd-integration.md +1047 -0
  77. data/guides/getting-started.md +399 -0
  78. data/guides/migration-from-terraform.md +924 -0
  79. data/guides/multi-environment-management.md +769 -0
  80. data/guides/template-isolation.md +673 -0
  81. data/guides/type-safe-infrastructure.md +695 -0
  82. data/lib/pangea/agent.rb +366 -0
  83. data/lib/pangea/architecture_registry.rb +94 -0
  84. data/lib/pangea/architectures/ARCHITECTURE_CATALOG.md +736 -0
  85. data/lib/pangea/architectures/CLAUDE.md +425 -0
  86. data/lib/pangea/architectures/COMPLETE_ARCHITECTURE_SUMMARY.md +385 -0
  87. data/lib/pangea/architectures/base.rb +545 -0
  88. data/lib/pangea/architectures/examples/web_application_examples.rb +589 -0
  89. data/lib/pangea/architectures/examples.rb +508 -0
  90. data/lib/pangea/architectures/patterns/data_processing.rb +669 -0
  91. data/lib/pangea/architectures/patterns/microservices.rb +626 -0
  92. data/lib/pangea/architectures/patterns/simple_web_application.rb +120 -0
  93. data/lib/pangea/architectures/patterns/web_application.rb +556 -0
  94. data/lib/pangea/architectures/simple_web_app/architecture.rb +70 -0
  95. data/lib/pangea/architectures/simple_web_app/types.rb +36 -0
  96. data/lib/pangea/architectures/types.rb +281 -0
  97. data/lib/pangea/architectures/web_application_architecture/README.md +375 -0
  98. data/lib/pangea/architectures/web_application_architecture/architecture.rb +511 -0
  99. data/lib/pangea/architectures/web_application_architecture/types.rb +295 -0
  100. data/lib/pangea/architectures.rb +24 -0
  101. data/lib/pangea/backends/base.rb +77 -0
  102. data/lib/pangea/backends/local.rb +159 -0
  103. data/lib/pangea/backends/s3.rb +213 -0
  104. data/lib/pangea/backends.rb +51 -0
  105. data/lib/pangea/cli/application.rb +211 -0
  106. data/lib/pangea/cli/commands/agent.rb +609 -0
  107. data/lib/pangea/cli/commands/apply.rb +240 -0
  108. data/lib/pangea/cli/commands/base_command.rb +131 -0
  109. data/lib/pangea/cli/commands/destroy.rb +131 -0
  110. data/lib/pangea/cli/commands/inspect.rb +437 -0
  111. data/lib/pangea/cli/commands/plan.rb +194 -0
  112. data/lib/pangea/cli/formatters/json_formatter.rb +195 -0
  113. data/lib/pangea/cli/ui/diff.rb +250 -0
  114. data/lib/pangea/cli/ui/logger.rb +174 -0
  115. data/lib/pangea/cli/ui/progress.rb +232 -0
  116. data/lib/pangea/cli/ui/spinner.rb +68 -0
  117. data/lib/pangea/cli/ui/table.rb +51 -0
  118. data/lib/pangea/cli/ui/visualizer.rb +409 -0
  119. data/lib/pangea/compilation/template_compiler.rb +384 -0
  120. data/lib/pangea/compilation/validator.rb +133 -0
  121. data/lib/pangea/component_registry.rb +79 -0
  122. data/lib/pangea/components/ADVANCED_COMPONENT_CATALOG.md +556 -0
  123. data/lib/pangea/components/CLAUDE.md +350 -0
  124. data/lib/pangea/components/COMPLETE_COMPONENT_SUMMARY.md +266 -0
  125. data/lib/pangea/components/COMPONENT_CATALOG.md +470 -0
  126. data/lib/pangea/components/EXTENDED_COMPONENT_CATALOG.md +558 -0
  127. data/lib/pangea/components/IMPLEMENTATION_PROGRESS.md +246 -0
  128. data/lib/pangea/components/api_gateway_microservices/README.md +384 -0
  129. data/lib/pangea/components/api_gateway_microservices/component.rb +630 -0
  130. data/lib/pangea/components/api_gateway_microservices/types.rb +248 -0
  131. data/lib/pangea/components/application_load_balancer/CLAUDE.md +224 -0
  132. data/lib/pangea/components/application_load_balancer/README.md +225 -0
  133. data/lib/pangea/components/application_load_balancer/component.rb +316 -0
  134. data/lib/pangea/components/application_load_balancer/types.rb +117 -0
  135. data/lib/pangea/components/auto_scaling_web_servers/README.md +326 -0
  136. data/lib/pangea/components/auto_scaling_web_servers/component.rb +396 -0
  137. data/lib/pangea/components/auto_scaling_web_servers/types.rb +176 -0
  138. data/lib/pangea/components/base.rb +104 -0
  139. data/lib/pangea/components/capabilities.rb +93 -0
  140. data/lib/pangea/components/carbon_aware_compute/CLAUDE.md +295 -0
  141. data/lib/pangea/components/carbon_aware_compute/README.md +194 -0
  142. data/lib/pangea/components/carbon_aware_compute/component.rb +1136 -0
  143. data/lib/pangea/components/carbon_aware_compute/types.rb +167 -0
  144. data/lib/pangea/components/disaster_recovery_pilot_light/README.md +366 -0
  145. data/lib/pangea/components/disaster_recovery_pilot_light/component.rb +1549 -0
  146. data/lib/pangea/components/disaster_recovery_pilot_light/types.rb +255 -0
  147. data/lib/pangea/components/event_driven_microservice/README.md +341 -0
  148. data/lib/pangea/components/event_driven_microservice/component.rb +665 -0
  149. data/lib/pangea/components/event_driven_microservice/types.rb +217 -0
  150. data/lib/pangea/components/examples.rb +515 -0
  151. data/lib/pangea/components/global_service_mesh/README.md +438 -0
  152. data/lib/pangea/components/global_service_mesh/component.rb +1307 -0
  153. data/lib/pangea/components/global_service_mesh/types.rb +289 -0
  154. data/lib/pangea/components/global_traffic_manager/README.md +351 -0
  155. data/lib/pangea/components/global_traffic_manager/component.rb +1144 -0
  156. data/lib/pangea/components/global_traffic_manager/types.rb +282 -0
  157. data/lib/pangea/components/green_data_lifecycle/CLAUDE.md +353 -0
  158. data/lib/pangea/components/green_data_lifecycle/README.md +270 -0
  159. data/lib/pangea/components/green_data_lifecycle/component.rb +1403 -0
  160. data/lib/pangea/components/green_data_lifecycle/types.rb +184 -0
  161. data/lib/pangea/components/microservice_deployment/README.md +321 -0
  162. data/lib/pangea/components/microservice_deployment/component.rb +440 -0
  163. data/lib/pangea/components/microservice_deployment/types.rb +236 -0
  164. data/lib/pangea/components/microservices_examples.rb +444 -0
  165. data/lib/pangea/components/multi_region_active_active/README.md +267 -0
  166. data/lib/pangea/components/multi_region_active_active/component.rb +1200 -0
  167. data/lib/pangea/components/multi_region_active_active/types.rb +248 -0
  168. data/lib/pangea/components/mysql_database/README.md +342 -0
  169. data/lib/pangea/components/mysql_database/component.rb +343 -0
  170. data/lib/pangea/components/mysql_database/types.rb +201 -0
  171. data/lib/pangea/components/public_private_subnets/CLAUDE.md +547 -0
  172. data/lib/pangea/components/public_private_subnets/README.md +293 -0
  173. data/lib/pangea/components/public_private_subnets/component.rb +386 -0
  174. data/lib/pangea/components/public_private_subnets/types.rb +152 -0
  175. data/lib/pangea/components/reference.rb +155 -0
  176. data/lib/pangea/components/secure_s3_bucket/README.md +459 -0
  177. data/lib/pangea/components/secure_s3_bucket/component.rb +442 -0
  178. data/lib/pangea/components/secure_s3_bucket/types.rb +292 -0
  179. data/lib/pangea/components/secure_vpc/CLAUDE.md +366 -0
  180. data/lib/pangea/components/secure_vpc/README.md +187 -0
  181. data/lib/pangea/components/secure_vpc/component.rb +88 -0
  182. data/lib/pangea/components/secure_vpc/types.rb +141 -0
  183. data/lib/pangea/components/service_mesh_observability/README.md +423 -0
  184. data/lib/pangea/components/service_mesh_observability/component.rb +610 -0
  185. data/lib/pangea/components/service_mesh_observability/types.rb +231 -0
  186. data/lib/pangea/components/siem_security_platform/component.rb +2877 -0
  187. data/lib/pangea/components/siem_security_platform/types.rb +220 -0
  188. data/lib/pangea/components/spot_instance_carbon_optimizer/CLAUDE.md +469 -0
  189. data/lib/pangea/components/spot_instance_carbon_optimizer/README.md +338 -0
  190. data/lib/pangea/components/spot_instance_carbon_optimizer/component.rb +1638 -0
  191. data/lib/pangea/components/spot_instance_carbon_optimizer/types.rb +213 -0
  192. data/lib/pangea/components/sustainable_ml_training/CLAUDE.md +653 -0
  193. data/lib/pangea/components/sustainable_ml_training/README.md +363 -0
  194. data/lib/pangea/components/sustainable_ml_training/component.rb +1754 -0
  195. data/lib/pangea/components/sustainable_ml_training/types.rb +234 -0
  196. data/lib/pangea/components/threat_intelligence_platform/types.rb +203 -0
  197. data/lib/pangea/components/types.rb +198 -0
  198. data/lib/pangea/components/vpc_with_subnets/component.rb +177 -0
  199. data/lib/pangea/components/vpc_with_subnets/types.rb +61 -0
  200. data/lib/pangea/components/web_security_group/CLAUDE.md +690 -0
  201. data/lib/pangea/components/web_security_group/README.md +450 -0
  202. data/lib/pangea/components/web_security_group/component.rb +217 -0
  203. data/lib/pangea/components/web_security_group/types.rb +257 -0
  204. data/lib/pangea/components/web_tier_subnets/CLAUDE.md +572 -0
  205. data/lib/pangea/components/web_tier_subnets/README.md +368 -0
  206. data/lib/pangea/components/web_tier_subnets/component.rb +205 -0
  207. data/lib/pangea/components/web_tier_subnets/types.rb +185 -0
  208. data/lib/pangea/components/zero_trust_network/component.rb +674 -0
  209. data/lib/pangea/components/zero_trust_network/types.rb +150 -0
  210. data/lib/pangea/components.rb +80 -0
  211. data/lib/pangea/configuration/types.rb +294 -0
  212. data/lib/pangea/configuration.rb +249 -0
  213. data/lib/pangea/documentation/generator.rb +139 -0
  214. data/lib/pangea/documentation/writer.rb +86 -0
  215. data/lib/pangea/entities/module_definition.rb +140 -0
  216. data/lib/pangea/entities/namespace.rb +154 -0
  217. data/lib/pangea/entities/project.rb +99 -0
  218. data/lib/pangea/entities/template.rb +121 -0
  219. data/lib/pangea/entities.rb +29 -0
  220. data/lib/pangea/errors.rb +67 -0
  221. data/lib/pangea/execution/terraform_executor.rb +271 -0
  222. data/lib/pangea/execution/workspace_manager.rb +164 -0
  223. data/lib/pangea/generators/resource_generator.rb +82 -0
  224. data/lib/pangea/generators/test_generator.rb +68 -0
  225. data/lib/pangea/quality/resource_auditor.rb +74 -0
  226. data/lib/pangea/resource_registry.rb +68 -0
  227. data/lib/pangea/resources/AWS_RESOURCE_COMPLETION_SUMMARY.md +200 -0
  228. data/lib/pangea/resources/CLAUDE.md +607 -0
  229. data/lib/pangea/resources/DATABASE_SERVICES_CLAUDE.md +577 -0
  230. data/lib/pangea/resources/EXTENDED_SERVICES_IMPLEMENTATION.md +197 -0
  231. data/lib/pangea/resources/FINAL_BATCH_IMPLEMENTATION.md +328 -0
  232. data/lib/pangea/resources/IMPLEMENTATION_SUMMARY.md +185 -0
  233. data/lib/pangea/resources/NEW_RESOURCES_SUMMARY.md +259 -0
  234. data/lib/pangea/resources/aws/MEDIA_SERVICES_IMPLEMENTATION_SUMMARY.md +219 -0
  235. data/lib/pangea/resources/aws/appconfig/configuration_version.rb +55 -0
  236. data/lib/pangea/resources/aws/appconfig/deployment_strategy.rb +104 -0
  237. data/lib/pangea/resources/aws/appconfig/extension.rb +55 -0
  238. data/lib/pangea/resources/aws/appconfig/extension_association.rb +55 -0
  239. data/lib/pangea/resources/aws/appconfig/hosted_configuration_version.rb +55 -0
  240. data/lib/pangea/resources/aws/appconfig/monitor.rb +55 -0
  241. data/lib/pangea/resources/aws/appconfig/validator.rb +55 -0
  242. data/lib/pangea/resources/aws/appconfig.rb +42 -0
  243. data/lib/pangea/resources/aws/applicationdiscoveryservice/application.rb +82 -0
  244. data/lib/pangea/resources/aws/applicationdiscoveryservice/application_resource.rb +55 -0
  245. data/lib/pangea/resources/aws/applicationdiscoveryservice/application_resource.rbs +15 -0
  246. data/lib/pangea/resources/aws/applicationdiscoveryservice.rb +30 -0
  247. data/lib/pangea/resources/aws/audit_manager/CLAUDE.md +778 -0
  248. data/lib/pangea/resources/aws/audit_manager/account_registration.rb +55 -0
  249. data/lib/pangea/resources/aws/audit_manager/assessment.rb +55 -0
  250. data/lib/pangea/resources/aws/audit_manager/assessment_control_set.rb +55 -0
  251. data/lib/pangea/resources/aws/audit_manager/assessment_delegation.rb +55 -0
  252. data/lib/pangea/resources/aws/audit_manager/assessment_report.rb +55 -0
  253. data/lib/pangea/resources/aws/audit_manager/control.rb +55 -0
  254. data/lib/pangea/resources/aws/audit_manager/evidence_folder.rb +55 -0
  255. data/lib/pangea/resources/aws/audit_manager/framework.rb +55 -0
  256. data/lib/pangea/resources/aws/audit_manager/framework_share.rb +55 -0
  257. data/lib/pangea/resources/aws/audit_manager/organization_admin_account.rb +55 -0
  258. data/lib/pangea/resources/aws/audit_manager.rb +186 -0
  259. data/lib/pangea/resources/aws/autoscaling/autoscaling_group_tag.rb +55 -0
  260. data/lib/pangea/resources/aws/autoscaling/autoscaling_lifecycle_hook.rb +55 -0
  261. data/lib/pangea/resources/aws/autoscaling/autoscaling_notification.rb +55 -0
  262. data/lib/pangea/resources/aws/autoscaling/autoscaling_policy_step_adjustment.rb +55 -0
  263. data/lib/pangea/resources/aws/autoscaling/autoscaling_policy_target_tracking_scaling_policy.rb +55 -0
  264. data/lib/pangea/resources/aws/autoscaling/autoscaling_schedule.rb +55 -0
  265. data/lib/pangea/resources/aws/autoscaling/autoscaling_traffic_source_attachment.rb +55 -0
  266. data/lib/pangea/resources/aws/autoscaling/autoscaling_warm_pool.rb +55 -0
  267. data/lib/pangea/resources/aws/autoscaling/launch_configuration.rb +55 -0
  268. data/lib/pangea/resources/aws/autoscaling/placement_group.rb +55 -0
  269. data/lib/pangea/resources/aws/autoscaling.rb +186 -0
  270. data/lib/pangea/resources/aws/base_resource.rb +92 -0
  271. data/lib/pangea/resources/aws/batch/CLAUDE.md +965 -0
  272. data/lib/pangea/resources/aws/batch/compute_environment.rb +55 -0
  273. data/lib/pangea/resources/aws/batch/job.rb +55 -0
  274. data/lib/pangea/resources/aws/batch/job_definition.rb +55 -0
  275. data/lib/pangea/resources/aws/batch/job_queue.rb +55 -0
  276. data/lib/pangea/resources/aws/batch/scheduling_policy.rb +55 -0
  277. data/lib/pangea/resources/aws/batch.rb +106 -0
  278. data/lib/pangea/resources/aws/cdk/bootstrap_version.rb +47 -0
  279. data/lib/pangea/resources/aws/cdk/bundling_docker_image.rb +46 -0
  280. data/lib/pangea/resources/aws/cdk/custom_resource_provider.rb +46 -0
  281. data/lib/pangea/resources/aws/cdk/docker_image_asset.rb +46 -0
  282. data/lib/pangea/resources/aws/cdk/file_asset.rb +46 -0
  283. data/lib/pangea/resources/aws/cdk/metadata.rb +46 -0
  284. data/lib/pangea/resources/aws/cdk/toolkit_stack_tags.rb +48 -0
  285. data/lib/pangea/resources/aws/cdk/tree_metadata.rb +46 -0
  286. data/lib/pangea/resources/aws/cdk.rb +44 -0
  287. data/lib/pangea/resources/aws/cleanrooms.rb +145 -0
  288. data/lib/pangea/resources/aws/cloudformation/CLAUDE.md +98 -0
  289. data/lib/pangea/resources/aws/cloudformation/hook_default_version.rb +48 -0
  290. data/lib/pangea/resources/aws/cloudformation/public_type_version.rb +51 -0
  291. data/lib/pangea/resources/aws/cloudformation/publisher.rb +63 -0
  292. data/lib/pangea/resources/aws/cloudformation/resource_default_version.rb +48 -0
  293. data/lib/pangea/resources/aws/cloudformation/resource_version.rb +56 -0
  294. data/lib/pangea/resources/aws/cloudformation/stack_instances.rb +161 -0
  295. data/lib/pangea/resources/aws/cloudformation/stack_set.rb +195 -0
  296. data/lib/pangea/resources/aws/cloudformation/stack_set_instance.rb +151 -0
  297. data/lib/pangea/resources/aws/cloudformation/type.rb +167 -0
  298. data/lib/pangea/resources/aws/cloudformation/type_activation.rb +91 -0
  299. data/lib/pangea/resources/aws/cloudformation/types.rb +301 -0
  300. data/lib/pangea/resources/aws/cloudformation/types.rbs +125 -0
  301. data/lib/pangea/resources/aws/cloudformation.rb +48 -0
  302. data/lib/pangea/resources/aws/code/codebuild_project_cache.rb +55 -0
  303. data/lib/pangea/resources/aws/code/codebuild_project_file_system_location.rb +55 -0
  304. data/lib/pangea/resources/aws/code/codebuild_source_credential.rb +55 -0
  305. data/lib/pangea/resources/aws/code/codebuild_webhook_filter.rb +55 -0
  306. data/lib/pangea/resources/aws/code/codecommit_approval_rule_template.rb +55 -0
  307. data/lib/pangea/resources/aws/code/codecommit_approval_rule_template_association.rb +55 -0
  308. data/lib/pangea/resources/aws/code/codedeploy_deployment_config.rb +55 -0
  309. data/lib/pangea/resources/aws/code/codedeploy_deployment_group_auto_rollback.rb +55 -0
  310. data/lib/pangea/resources/aws/code/codepipeline_custom_action_type.rb +55 -0
  311. data/lib/pangea/resources/aws/code/codepipeline_webhook.rb +55 -0
  312. data/lib/pangea/resources/aws/code/codestar_connection.rb +85 -0
  313. data/lib/pangea/resources/aws/code/codestar_notification_rule.rb +55 -0
  314. data/lib/pangea/resources/aws/code.rb +52 -0
  315. data/lib/pangea/resources/aws/comprehendmedical/jobs.rb +320 -0
  316. data/lib/pangea/resources/aws/comprehendmedical.rb +28 -0
  317. data/lib/pangea/resources/aws/config/aggregate_authorization.rb +55 -0
  318. data/lib/pangea/resources/aws/config/configuration_aggregator_organization.rb +55 -0
  319. data/lib/pangea/resources/aws/config/organization_conformance_pack.rb +103 -0
  320. data/lib/pangea/resources/aws/config/organization_custom_rule.rb +55 -0
  321. data/lib/pangea/resources/aws/config/organization_managed_rule.rb +55 -0
  322. data/lib/pangea/resources/aws/config/remediation_configuration.rb +55 -0
  323. data/lib/pangea/resources/aws/config/retention_configuration.rb +55 -0
  324. data/lib/pangea/resources/aws/config/stored_query.rb +55 -0
  325. data/lib/pangea/resources/aws/config.rb +44 -0
  326. data/lib/pangea/resources/aws/controltower/control.rb +82 -0
  327. data/lib/pangea/resources/aws/controltower/control_resource.rb +55 -0
  328. data/lib/pangea/resources/aws/controltower/control_resource.rbs +15 -0
  329. data/lib/pangea/resources/aws/controltower/enabled_control.rb +74 -0
  330. data/lib/pangea/resources/aws/controltower/enabled_control_resource.rb +55 -0
  331. data/lib/pangea/resources/aws/controltower/enabled_control_resource.rbs +15 -0
  332. data/lib/pangea/resources/aws/controltower/landing_zone.rb +126 -0
  333. data/lib/pangea/resources/aws/controltower/landing_zone_resource.rb +55 -0
  334. data/lib/pangea/resources/aws/controltower/landing_zone_resource.rbs +18 -0
  335. data/lib/pangea/resources/aws/controltower.rb +34 -0
  336. data/lib/pangea/resources/aws/data_pipeline/pipeline.rb +55 -0
  337. data/lib/pangea/resources/aws/data_pipeline/pipeline_definition.rb +55 -0
  338. data/lib/pangea/resources/aws/detective/CLAUDE.md +668 -0
  339. data/lib/pangea/resources/aws/detective/datasource_package.rb +55 -0
  340. data/lib/pangea/resources/aws/detective/finding.rb +56 -0
  341. data/lib/pangea/resources/aws/detective/graph.rb +58 -0
  342. data/lib/pangea/resources/aws/detective/indicator.rb +56 -0
  343. data/lib/pangea/resources/aws/detective/invitation_accepter.rb +54 -0
  344. data/lib/pangea/resources/aws/detective/member.rb +59 -0
  345. data/lib/pangea/resources/aws/detective/organization_admin_account.rb +54 -0
  346. data/lib/pangea/resources/aws/detective/organization_configuration.rb +54 -0
  347. data/lib/pangea/resources/aws/detective.rb +154 -0
  348. data/lib/pangea/resources/aws/ec2/ec2_ami_launch_permission.rb +55 -0
  349. data/lib/pangea/resources/aws/ec2/ec2_availability_zone_group.rb +55 -0
  350. data/lib/pangea/resources/aws/ec2/ec2_capacity_block_reservation.rb +55 -0
  351. data/lib/pangea/resources/aws/ec2/ec2_capacity_reservation.rb +55 -0
  352. data/lib/pangea/resources/aws/ec2/ec2_dedicated_host.rb +55 -0
  353. data/lib/pangea/resources/aws/ec2/ec2_fleet.rb +55 -0
  354. data/lib/pangea/resources/aws/ec2/ec2_host_resource_group_association.rb +55 -0
  355. data/lib/pangea/resources/aws/ec2/ec2_image_block_public_access.rb +55 -0
  356. data/lib/pangea/resources/aws/ec2/ec2_instance_metadata_defaults.rb +55 -0
  357. data/lib/pangea/resources/aws/ec2/ec2_serial_console_access.rb +55 -0
  358. data/lib/pangea/resources/aws/ec2/ec2_snapshot_block_public_access.rb +55 -0
  359. data/lib/pangea/resources/aws/ec2/ec2_spot_datafeed_subscription.rb +55 -0
  360. data/lib/pangea/resources/aws/ec2/ec2_spot_fleet_request.rb +55 -0
  361. data/lib/pangea/resources/aws/ec2/ec2_spot_instance_request.rb +55 -0
  362. data/lib/pangea/resources/aws/ec2/ec2_tag.rb +55 -0
  363. data/lib/pangea/resources/aws/ec2/ec2_transit_gateway_multicast_domain.rb +55 -0
  364. data/lib/pangea/resources/aws/ec2/ec2_transit_gateway_multicast_domain_association.rb +55 -0
  365. data/lib/pangea/resources/aws/ec2/ec2_transit_gateway_multicast_group_member.rb +55 -0
  366. data/lib/pangea/resources/aws/ec2.rb +314 -0
  367. data/lib/pangea/resources/aws/elasticache_extended.disabled/auth_token.rb +50 -0
  368. data/lib/pangea/resources/aws/elasticache_extended.disabled/cache_policy.rb +57 -0
  369. data/lib/pangea/resources/aws/elasticache_extended.disabled/global_replication_group.rb +121 -0
  370. data/lib/pangea/resources/aws/elasticache_extended.disabled/notification_topic.rb +50 -0
  371. data/lib/pangea/resources/aws/elasticache_extended.disabled/parameter_group_parameter.rb +52 -0
  372. data/lib/pangea/resources/aws/elasticache_extended.disabled/reserved_cache_node.rb +55 -0
  373. data/lib/pangea/resources/aws/elasticache_extended.disabled/serverless_cache.rb +178 -0
  374. data/lib/pangea/resources/aws/elasticache_extended.disabled/user_group.rb +90 -0
  375. data/lib/pangea/resources/aws/elasticache_extended.disabled/user_group_association.rb +50 -0
  376. data/lib/pangea/resources/aws/elasticache_extended.rb +46 -0
  377. data/lib/pangea/resources/aws/emrcontainers/job_run.rb +134 -0
  378. data/lib/pangea/resources/aws/emrcontainers/job_template.rb +165 -0
  379. data/lib/pangea/resources/aws/emrcontainers/managed_endpoint.rb +126 -0
  380. data/lib/pangea/resources/aws/emrcontainers/virtual_cluster.rb +99 -0
  381. data/lib/pangea/resources/aws/emrcontainers.rb +34 -0
  382. data/lib/pangea/resources/aws/extended_resources_CLAUDE.md +470 -0
  383. data/lib/pangea/resources/aws/frauddetector/detector.rb +262 -0
  384. data/lib/pangea/resources/aws/frauddetector.rb +28 -0
  385. data/lib/pangea/resources/aws/gamedev.rb +178 -0
  386. data/lib/pangea/resources/aws/gamelift.rb +244 -0
  387. data/lib/pangea/resources/aws/gamesparks.rb +246 -0
  388. data/lib/pangea/resources/aws/healthlake/fhir_datastore.rb +220 -0
  389. data/lib/pangea/resources/aws/healthlake.rb +28 -0
  390. data/lib/pangea/resources/aws/kinesisvideo/signaling_channel.rb +55 -0
  391. data/lib/pangea/resources/aws/kinesisvideo/stream.rb +55 -0
  392. data/lib/pangea/resources/aws/kinesisvideo.rb +58 -0
  393. data/lib/pangea/resources/aws/load_balancing/alb_target_group_attachment.rb +55 -0
  394. data/lib/pangea/resources/aws/load_balancing/elb_attachment.rb +55 -0
  395. data/lib/pangea/resources/aws/load_balancing/elb_service_account.rb +55 -0
  396. data/lib/pangea/resources/aws/load_balancing/lb_cookie_stickiness_policy.rb +55 -0
  397. data/lib/pangea/resources/aws/load_balancing/lb_ssl_negotiation_policy.rb +55 -0
  398. data/lib/pangea/resources/aws/load_balancing/lb_target_group_attachment.rb +55 -0
  399. data/lib/pangea/resources/aws/load_balancing/lb_trust_store.rb +55 -0
  400. data/lib/pangea/resources/aws/load_balancing/lb_trust_store_revocation.rb +55 -0
  401. data/lib/pangea/resources/aws/load_balancing/load_balancer_backend_server_policy.rb +55 -0
  402. data/lib/pangea/resources/aws/load_balancing/load_balancer_listener_policy.rb +55 -0
  403. data/lib/pangea/resources/aws/load_balancing/load_balancer_policy.rb +55 -0
  404. data/lib/pangea/resources/aws/load_balancing/proxy_protocol_policy.rb +55 -0
  405. data/lib/pangea/resources/aws/load_balancing.rb +218 -0
  406. data/lib/pangea/resources/aws/lookout/equipment.rb +227 -0
  407. data/lib/pangea/resources/aws/lookout/metrics.rb +129 -0
  408. data/lib/pangea/resources/aws/lookout.rb +30 -0
  409. data/lib/pangea/resources/aws/media_services_CLAUDE.md +494 -0
  410. data/lib/pangea/resources/aws/mediaconvert/job.rb +55 -0
  411. data/lib/pangea/resources/aws/mediaconvert/job_template.rb +55 -0
  412. data/lib/pangea/resources/aws/mediaconvert/preset.rb +55 -0
  413. data/lib/pangea/resources/aws/mediaconvert/queue.rb +55 -0
  414. data/lib/pangea/resources/aws/mediaconvert.rb +90 -0
  415. data/lib/pangea/resources/aws/medialive/channel.rb +55 -0
  416. data/lib/pangea/resources/aws/medialive/input.rb +55 -0
  417. data/lib/pangea/resources/aws/medialive/input_security_group.rb +55 -0
  418. data/lib/pangea/resources/aws/medialive/multiplex.rb +55 -0
  419. data/lib/pangea/resources/aws/medialive/multiplex_program.rb +55 -0
  420. data/lib/pangea/resources/aws/medialive.rb +106 -0
  421. data/lib/pangea/resources/aws/mediapackage/channel.rb +55 -0
  422. data/lib/pangea/resources/aws/mediapackage/origin_endpoint.rb +55 -0
  423. data/lib/pangea/resources/aws/mediapackage/packaging_configuration.rb +55 -0
  424. data/lib/pangea/resources/aws/mediapackage/packaging_group.rb +55 -0
  425. data/lib/pangea/resources/aws/mediapackage.rb +90 -0
  426. data/lib/pangea/resources/aws/migrationhub/progress_update_stream.rb +69 -0
  427. data/lib/pangea/resources/aws/migrationhub/progress_update_stream_resource.rb +55 -0
  428. data/lib/pangea/resources/aws/migrationhub/progress_update_stream_resource.rbs +14 -0
  429. data/lib/pangea/resources/aws/migrationhub.rb +30 -0
  430. data/lib/pangea/resources/aws/opensearch.disabled/CLAUDE.md +480 -0
  431. data/lib/pangea/resources/aws/opensearch.disabled/domain.rb +59 -0
  432. data/lib/pangea/resources/aws/opensearch.disabled/domain_endpoint.rb +88 -0
  433. data/lib/pangea/resources/aws/opensearch.disabled/domain_policy.rb +89 -0
  434. data/lib/pangea/resources/aws/opensearch.disabled/domain_saml_options.rb +105 -0
  435. data/lib/pangea/resources/aws/opensearch.disabled/inbound_connection.rb +75 -0
  436. data/lib/pangea/resources/aws/opensearch.disabled/outbound_connection.rb +137 -0
  437. data/lib/pangea/resources/aws/opensearch.disabled/package.rb +102 -0
  438. data/lib/pangea/resources/aws/opensearch.disabled/package_association.rb +80 -0
  439. data/lib/pangea/resources/aws/opensearch.disabled/serverless_access_policy.rb +143 -0
  440. data/lib/pangea/resources/aws/opensearch.disabled/serverless_collection.rb +109 -0
  441. data/lib/pangea/resources/aws/opensearch.disabled/serverless_security_policy.rb +118 -0
  442. data/lib/pangea/resources/aws/opensearch.disabled/vpc_endpoint.rb +86 -0
  443. data/lib/pangea/resources/aws/opensearch.rb.disabled +36 -0
  444. data/lib/pangea/resources/aws/private5g.rb +132 -0
  445. data/lib/pangea/resources/aws/robomaker.rb +175 -0
  446. data/lib/pangea/resources/aws/sagemaker/feature_group.rb +146 -0
  447. data/lib/pangea/resources/aws/sagemaker/model_package_group.rb +79 -0
  448. data/lib/pangea/resources/aws/sagemaker/pipeline.rb +152 -0
  449. data/lib/pangea/resources/aws/sagemaker.rb +32 -0
  450. data/lib/pangea/resources/aws/security_lake/CLAUDE.md +932 -0
  451. data/lib/pangea/resources/aws/security_lake/aws_log_source.rb +55 -0
  452. data/lib/pangea/resources/aws/security_lake/custom_log_source.rb +55 -0
  453. data/lib/pangea/resources/aws/security_lake/data_lake.rb +55 -0
  454. data/lib/pangea/resources/aws/security_lake/data_lake_exception_subscription.rb +55 -0
  455. data/lib/pangea/resources/aws/security_lake/organization_configuration.rb +55 -0
  456. data/lib/pangea/resources/aws/security_lake/subscriber.rb +55 -0
  457. data/lib/pangea/resources/aws/security_lake/subscriber_notification.rb +55 -0
  458. data/lib/pangea/resources/aws/security_lake.rb +138 -0
  459. data/lib/pangea/resources/aws/servicecatalog/constraint.rb +93 -0
  460. data/lib/pangea/resources/aws/servicecatalog/constraint_resource.rb +55 -0
  461. data/lib/pangea/resources/aws/servicecatalog/constraint_resource.rbs +15 -0
  462. data/lib/pangea/resources/aws/servicecatalog/portfolio.rb +69 -0
  463. data/lib/pangea/resources/aws/servicecatalog/portfolio_resource.rb +55 -0
  464. data/lib/pangea/resources/aws/servicecatalog/portfolio_resource.rbs +15 -0
  465. data/lib/pangea/resources/aws/servicecatalog/principal_portfolio_association.rb +70 -0
  466. data/lib/pangea/resources/aws/servicecatalog/principal_portfolio_association_resource.rb +55 -0
  467. data/lib/pangea/resources/aws/servicecatalog/principal_portfolio_association_resource.rbs +14 -0
  468. data/lib/pangea/resources/aws/servicecatalog/product.rb +108 -0
  469. data/lib/pangea/resources/aws/servicecatalog/product_portfolio_association.rb +70 -0
  470. data/lib/pangea/resources/aws/servicecatalog/product_portfolio_association_resource.rb +55 -0
  471. data/lib/pangea/resources/aws/servicecatalog/product_portfolio_association_resource.rbs +14 -0
  472. data/lib/pangea/resources/aws/servicecatalog/product_resource.rb +55 -0
  473. data/lib/pangea/resources/aws/servicecatalog/product_resource.rbs +16 -0
  474. data/lib/pangea/resources/aws/servicecatalog/provisioned_product.rb +96 -0
  475. data/lib/pangea/resources/aws/servicecatalog/provisioned_product_resource.rb +55 -0
  476. data/lib/pangea/resources/aws/servicecatalog/provisioned_product_resource.rbs +18 -0
  477. data/lib/pangea/resources/aws/servicecatalog/tag_option.rb +75 -0
  478. data/lib/pangea/resources/aws/servicecatalog/tag_option_resource.rb +55 -0
  479. data/lib/pangea/resources/aws/servicecatalog/tag_option_resource.rbs +15 -0
  480. data/lib/pangea/resources/aws/servicecatalog/tag_option_resource_association.rb +65 -0
  481. data/lib/pangea/resources/aws/servicecatalog/tag_option_resource_association_resource.rb +55 -0
  482. data/lib/pangea/resources/aws/servicecatalog/tag_option_resource_association_resource.rbs +14 -0
  483. data/lib/pangea/resources/aws/servicecatalog.rb +44 -0
  484. data/lib/pangea/resources/aws/sfn_extended.disabled/activity.rb +79 -0
  485. data/lib/pangea/resources/aws/sfn_extended.disabled/activity_task.rb +51 -0
  486. data/lib/pangea/resources/aws/sfn_extended.disabled/execution.rb +53 -0
  487. data/lib/pangea/resources/aws/sfn_extended.disabled/express_logging_configuration.rb +54 -0
  488. data/lib/pangea/resources/aws/sfn_extended.disabled/map_run.rb +51 -0
  489. data/lib/pangea/resources/aws/sfn_extended.disabled/state_machine_alias.rb +99 -0
  490. data/lib/pangea/resources/aws/sfn_extended.disabled/state_machine_version.rb +52 -0
  491. data/lib/pangea/resources/aws/sfn_extended.rb +40 -0
  492. data/lib/pangea/resources/aws/ssm/automation_execution.rb +55 -0
  493. data/lib/pangea/resources/aws/ssm/command_invocation.rb +55 -0
  494. data/lib/pangea/resources/aws/ssm/compliance_item.rb +55 -0
  495. data/lib/pangea/resources/aws/ssm/inventory_result_entity.rb +55 -0
  496. data/lib/pangea/resources/aws/ssm/maintenance_window_target.rb +93 -0
  497. data/lib/pangea/resources/aws/ssm/maintenance_window_target_resource.rb +55 -0
  498. data/lib/pangea/resources/aws/ssm/maintenance_window_target_resource.rbs +15 -0
  499. data/lib/pangea/resources/aws/ssm/maintenance_window_task.rb +149 -0
  500. data/lib/pangea/resources/aws/ssm/maintenance_window_task_resource.rb +55 -0
  501. data/lib/pangea/resources/aws/ssm/maintenance_window_task_resource.rbs +15 -0
  502. data/lib/pangea/resources/aws/ssm/ops_item.rb +177 -0
  503. data/lib/pangea/resources/aws/ssm/ops_metadata.rb +55 -0
  504. data/lib/pangea/resources/aws/ssm/patch_manager_patch_baseline_approval_rule.rb +55 -0
  505. data/lib/pangea/resources/aws/ssm/resource_compliance_item.rb +55 -0
  506. data/lib/pangea/resources/aws/ssm/session_manager_preferences.rb +55 -0
  507. data/lib/pangea/resources/aws/ssm/session_preferences.rb +55 -0
  508. data/lib/pangea/resources/aws/ssm.rb +52 -0
  509. data/lib/pangea/resources/aws/sumerian.rb +223 -0
  510. data/lib/pangea/resources/aws/supplychain.rb +120 -0
  511. data/lib/pangea/resources/aws/types/vpc.rb +94 -0
  512. data/lib/pangea/resources/aws/verifiedpermissions.rb +101 -0
  513. data/lib/pangea/resources/aws/vpc/default_network_acl.rb +55 -0
  514. data/lib/pangea/resources/aws/vpc/default_route_table.rb +55 -0
  515. data/lib/pangea/resources/aws/vpc/default_security_group.rb +55 -0
  516. data/lib/pangea/resources/aws/vpc/default_vpc_dhcp_options.rb +55 -0
  517. data/lib/pangea/resources/aws/vpc/vpc_dhcp_options_association.rb +55 -0
  518. data/lib/pangea/resources/aws/vpc/vpc_endpoint_connection_accepter.rb +55 -0
  519. data/lib/pangea/resources/aws/vpc/vpc_endpoint_connection_notification.rb +55 -0
  520. data/lib/pangea/resources/aws/vpc/vpc_endpoint_route_table_association.rb +55 -0
  521. data/lib/pangea/resources/aws/vpc/vpc_endpoint_service_allowed_principal.rb +55 -0
  522. data/lib/pangea/resources/aws/vpc/vpc_endpoint_subnet_association.rb +55 -0
  523. data/lib/pangea/resources/aws/vpc/vpc_network_performance_metric_subscription.rb +55 -0
  524. data/lib/pangea/resources/aws/vpc/vpc_peering_connection_accepter.rb +55 -0
  525. data/lib/pangea/resources/aws/vpc/vpc_peering_connection_options.rb +55 -0
  526. data/lib/pangea/resources/aws/vpc/vpc_security_group_egress_rule.rb +55 -0
  527. data/lib/pangea/resources/aws/vpc/vpc_security_group_ingress_rule.rb +55 -0
  528. data/lib/pangea/resources/aws/vpc.rb +266 -0
  529. data/lib/pangea/resources/aws/wellarchitected/workload.rb +103 -0
  530. data/lib/pangea/resources/aws/wellarchitected/workload_resource.rb +55 -0
  531. data/lib/pangea/resources/aws/wellarchitected/workload_resource.rbs +15 -0
  532. data/lib/pangea/resources/aws/wellarchitected.rb +30 -0
  533. data/lib/pangea/resources/aws.rb +49 -0
  534. data/lib/pangea/resources/aws_acm_certificate/CLAUDE.md +290 -0
  535. data/lib/pangea/resources/aws_acm_certificate/resource.rb +120 -0
  536. data/lib/pangea/resources/aws_acm_certificate/types.rb +153 -0
  537. data/lib/pangea/resources/aws_acm_certificate_validation/CLAUDE.md +437 -0
  538. data/lib/pangea/resources/aws_acm_certificate_validation/resource.rb +75 -0
  539. data/lib/pangea/resources/aws_acm_certificate_validation/types.rb +145 -0
  540. data/lib/pangea/resources/aws_acmpca_certificate_authority/resource.rb +129 -0
  541. data/lib/pangea/resources/aws_acmpca_certificate_authority/types.rb +343 -0
  542. data/lib/pangea/resources/aws_alb_target_group_attachment/resource.rb +67 -0
  543. data/lib/pangea/resources/aws_alb_target_group_attachment/types.rb +46 -0
  544. data/lib/pangea/resources/aws_ami/CLAUDE.md +253 -0
  545. data/lib/pangea/resources/aws_ami/resource.rb +142 -0
  546. data/lib/pangea/resources/aws_ami/types.rb +196 -0
  547. data/lib/pangea/resources/aws_api_gateway_api_key/resource.rb +86 -0
  548. data/lib/pangea/resources/aws_api_gateway_api_key/types.rb +247 -0
  549. data/lib/pangea/resources/aws_api_gateway_deployment/CLAUDE.md +270 -0
  550. data/lib/pangea/resources/aws_api_gateway_deployment/resource.rb +197 -0
  551. data/lib/pangea/resources/aws_api_gateway_deployment/types.rb +199 -0
  552. data/lib/pangea/resources/aws_api_gateway_integration/CLAUDE.md +304 -0
  553. data/lib/pangea/resources/aws_api_gateway_integration/resource.rb +172 -0
  554. data/lib/pangea/resources/aws_api_gateway_integration/types.rb +257 -0
  555. data/lib/pangea/resources/aws_api_gateway_method/CLAUDE.md +235 -0
  556. data/lib/pangea/resources/aws_api_gateway_method/resource.rb +82 -0
  557. data/lib/pangea/resources/aws_api_gateway_method/types.rb +172 -0
  558. data/lib/pangea/resources/aws_api_gateway_resource/CLAUDE.md +215 -0
  559. data/lib/pangea/resources/aws_api_gateway_resource/resource.rb +62 -0
  560. data/lib/pangea/resources/aws_api_gateway_resource/types.rb +129 -0
  561. data/lib/pangea/resources/aws_api_gateway_rest_api/CLAUDE.md +152 -0
  562. data/lib/pangea/resources/aws_api_gateway_rest_api/resource.rb +95 -0
  563. data/lib/pangea/resources/aws_api_gateway_rest_api/types.rb +161 -0
  564. data/lib/pangea/resources/aws_api_gateway_stage/CLAUDE.md +308 -0
  565. data/lib/pangea/resources/aws_api_gateway_stage/resource.rb +335 -0
  566. data/lib/pangea/resources/aws_api_gateway_stage/types.rb +226 -0
  567. data/lib/pangea/resources/aws_api_gateway_usage_plan/resource.rb +122 -0
  568. data/lib/pangea/resources/aws_api_gateway_usage_plan/types.rb +312 -0
  569. data/lib/pangea/resources/aws_api_gateway_usage_plan.rbs +60 -0
  570. data/lib/pangea/resources/aws_application_integration_README.md +453 -0
  571. data/lib/pangea/resources/aws_appstream_fleet/CLAUDE.md +468 -0
  572. data/lib/pangea/resources/aws_appstream_fleet/resource.rb +121 -0
  573. data/lib/pangea/resources/aws_appstream_fleet/types.rb +223 -0
  574. data/lib/pangea/resources/aws_appstream_image_builder/resource.rb +34 -0
  575. data/lib/pangea/resources/aws_appstream_stack/resource.rb +34 -0
  576. data/lib/pangea/resources/aws_appsync_datasource/CLAUDE.md +479 -0
  577. data/lib/pangea/resources/aws_appsync_datasource/resource.rb +152 -0
  578. data/lib/pangea/resources/aws_appsync_datasource/types.rb +176 -0
  579. data/lib/pangea/resources/aws_appsync_datasource.rbs +129 -0
  580. data/lib/pangea/resources/aws_appsync_graphql_api/CLAUDE.md +325 -0
  581. data/lib/pangea/resources/aws_appsync_graphql_api/resource.rb +166 -0
  582. data/lib/pangea/resources/aws_appsync_graphql_api/types.rb +164 -0
  583. data/lib/pangea/resources/aws_appsync_graphql_api.rbs +134 -0
  584. data/lib/pangea/resources/aws_appsync_resolver/CLAUDE.md +459 -0
  585. data/lib/pangea/resources/aws_appsync_resolver/resource.rb +118 -0
  586. data/lib/pangea/resources/aws_appsync_resolver/types.rb +134 -0
  587. data/lib/pangea/resources/aws_appsync_resolver.rbs +86 -0
  588. data/lib/pangea/resources/aws_athena_database/CLAUDE.md +276 -0
  589. data/lib/pangea/resources/aws_athena_database/resource.rb +106 -0
  590. data/lib/pangea/resources/aws_athena_database/types.rb +192 -0
  591. data/lib/pangea/resources/aws_athena_database/types.rbs +38 -0
  592. data/lib/pangea/resources/aws_athena_database.rbs +10 -0
  593. data/lib/pangea/resources/aws_athena_named_query/CLAUDE.md +385 -0
  594. data/lib/pangea/resources/aws_athena_named_query/resource.rb +77 -0
  595. data/lib/pangea/resources/aws_athena_named_query/types.rb +248 -0
  596. data/lib/pangea/resources/aws_athena_named_query/types.rbs +42 -0
  597. data/lib/pangea/resources/aws_athena_named_query.rbs +10 -0
  598. data/lib/pangea/resources/aws_athena_workgroup/CLAUDE.md +315 -0
  599. data/lib/pangea/resources/aws_athena_workgroup/resource.rb +141 -0
  600. data/lib/pangea/resources/aws_athena_workgroup/types.rb +251 -0
  601. data/lib/pangea/resources/aws_athena_workgroup/types.rbs +38 -0
  602. data/lib/pangea/resources/aws_athena_workgroup.rbs +10 -0
  603. data/lib/pangea/resources/aws_auditmanager_assessment.rbs +35 -0
  604. data/lib/pangea/resources/aws_autoscaling_attachment/CLAUDE.md +226 -0
  605. data/lib/pangea/resources/aws_autoscaling_attachment/resource.rb +81 -0
  606. data/lib/pangea/resources/aws_autoscaling_attachment/types.rb +86 -0
  607. data/lib/pangea/resources/aws_autoscaling_group/CLAUDE.md +263 -0
  608. data/lib/pangea/resources/aws_autoscaling_group/resource.rb +175 -0
  609. data/lib/pangea/resources/aws_autoscaling_group/types.rb +236 -0
  610. data/lib/pangea/resources/aws_autoscaling_group_tag/resource.rb +67 -0
  611. data/lib/pangea/resources/aws_autoscaling_group_tag/types.rb +46 -0
  612. data/lib/pangea/resources/aws_autoscaling_lifecycle_hook/CLAUDE.md +357 -0
  613. data/lib/pangea/resources/aws_autoscaling_lifecycle_hook/resource.rb +67 -0
  614. data/lib/pangea/resources/aws_autoscaling_lifecycle_hook/types.rb +46 -0
  615. data/lib/pangea/resources/aws_autoscaling_lifecycle_hook/types.rbs +42 -0
  616. data/lib/pangea/resources/aws_autoscaling_notification/CLAUDE.md +405 -0
  617. data/lib/pangea/resources/aws_autoscaling_notification/resource.rb +67 -0
  618. data/lib/pangea/resources/aws_autoscaling_notification/types.rb +46 -0
  619. data/lib/pangea/resources/aws_autoscaling_notification/types.rbs +41 -0
  620. data/lib/pangea/resources/aws_autoscaling_policy/CLAUDE.md +278 -0
  621. data/lib/pangea/resources/aws_autoscaling_policy/resource.rb +168 -0
  622. data/lib/pangea/resources/aws_autoscaling_policy/types.rb +239 -0
  623. data/lib/pangea/resources/aws_autoscaling_policy_step_adjustment/resource.rb +67 -0
  624. data/lib/pangea/resources/aws_autoscaling_policy_step_adjustment/types.rb +46 -0
  625. data/lib/pangea/resources/aws_autoscaling_policy_target_tracking_scaling_policy/resource.rb +67 -0
  626. data/lib/pangea/resources/aws_autoscaling_policy_target_tracking_scaling_policy/types.rb +46 -0
  627. data/lib/pangea/resources/aws_autoscaling_schedule/CLAUDE.md +219 -0
  628. data/lib/pangea/resources/aws_autoscaling_schedule/resource.rb +67 -0
  629. data/lib/pangea/resources/aws_autoscaling_schedule/types.rb +46 -0
  630. data/lib/pangea/resources/aws_autoscaling_schedule/types.rbs +45 -0
  631. data/lib/pangea/resources/aws_autoscaling_tag/CLAUDE.md +443 -0
  632. data/lib/pangea/resources/aws_autoscaling_tag/resource.rb +119 -0
  633. data/lib/pangea/resources/aws_autoscaling_tag/types.rb +233 -0
  634. data/lib/pangea/resources/aws_autoscaling_tag/types.rbs +60 -0
  635. data/lib/pangea/resources/aws_autoscaling_traffic_source_attachment/resource.rb +67 -0
  636. data/lib/pangea/resources/aws_autoscaling_traffic_source_attachment/types.rb +46 -0
  637. data/lib/pangea/resources/aws_autoscaling_warm_pool/resource.rb +67 -0
  638. data/lib/pangea/resources/aws_autoscaling_warm_pool/types.rb +46 -0
  639. data/lib/pangea/resources/aws_batch_compute_environment/CLAUDE.md +571 -0
  640. data/lib/pangea/resources/aws_batch_compute_environment/resource.rb +158 -0
  641. data/lib/pangea/resources/aws_batch_compute_environment/types.rb +332 -0
  642. data/lib/pangea/resources/aws_batch_compute_environment.rbs +33 -0
  643. data/lib/pangea/resources/aws_batch_job_definition/CLAUDE.md +714 -0
  644. data/lib/pangea/resources/aws_batch_job_definition/resource.rb +253 -0
  645. data/lib/pangea/resources/aws_batch_job_definition/types.rb +548 -0
  646. data/lib/pangea/resources/aws_batch_job_queue/CLAUDE.md +585 -0
  647. data/lib/pangea/resources/aws_batch_job_queue/resource.rb +72 -0
  648. data/lib/pangea/resources/aws_batch_job_queue/types.rb +371 -0
  649. data/lib/pangea/resources/aws_billing_service_account/resource.rb +56 -0
  650. data/lib/pangea/resources/aws_billing_service_account/types.rb +43 -0
  651. data/lib/pangea/resources/aws_blockchain_query/resource.rb +122 -0
  652. data/lib/pangea/resources/aws_blockchain_query/types.rb +339 -0
  653. data/lib/pangea/resources/aws_blockchain_token_balance/resource.rb +94 -0
  654. data/lib/pangea/resources/aws_blockchain_token_balance/types.rb +319 -0
  655. data/lib/pangea/resources/aws_braket_device/CLAUDE.md +331 -0
  656. data/lib/pangea/resources/aws_braket_device/resource.rb +118 -0
  657. data/lib/pangea/resources/aws_braket_device/types.rb +242 -0
  658. data/lib/pangea/resources/aws_braket_device_capabilities/resource.rb +86 -0
  659. data/lib/pangea/resources/aws_braket_device_capabilities/types.rb +251 -0
  660. data/lib/pangea/resources/aws_braket_job/resource.rb +162 -0
  661. data/lib/pangea/resources/aws_braket_job/types.rb +265 -0
  662. data/lib/pangea/resources/aws_braket_job_queue/resource.rb +111 -0
  663. data/lib/pangea/resources/aws_braket_job_queue/types.rb +246 -0
  664. data/lib/pangea/resources/aws_braket_local_simulator/resource.rb +149 -0
  665. data/lib/pangea/resources/aws_braket_local_simulator/types.rb +301 -0
  666. data/lib/pangea/resources/aws_braket_quantum_task/CLAUDE.md +188 -0
  667. data/lib/pangea/resources/aws_braket_quantum_task/resource.rb +90 -0
  668. data/lib/pangea/resources/aws_braket_quantum_task/types.rb +171 -0
  669. data/lib/pangea/resources/aws_budgets_budget/CLAUDE.md +304 -0
  670. data/lib/pangea/resources/aws_budgets_budget/resource.rb +199 -0
  671. data/lib/pangea/resources/aws_budgets_budget/types.rb +337 -0
  672. data/lib/pangea/resources/aws_budgets_budget_action/CLAUDE.md +357 -0
  673. data/lib/pangea/resources/aws_budgets_budget_action/resource.rb +201 -0
  674. data/lib/pangea/resources/aws_budgets_budget_action/types.rb +417 -0
  675. data/lib/pangea/resources/aws_ce_anomaly_detector/resource.rb +65 -0
  676. data/lib/pangea/resources/aws_ce_anomaly_detector/types.rb +72 -0
  677. data/lib/pangea/resources/aws_ce_anomaly_subscription/resource.rb +62 -0
  678. data/lib/pangea/resources/aws_ce_anomaly_subscription/types.rb +59 -0
  679. data/lib/pangea/resources/aws_ce_cost_category/resource.rb +204 -0
  680. data/lib/pangea/resources/aws_ce_cost_category/types.rb +399 -0
  681. data/lib/pangea/resources/aws_cloudformation_stack/CLAUDE.md +244 -0
  682. data/lib/pangea/resources/aws_cloudformation_stack/resource.rb +139 -0
  683. data/lib/pangea/resources/aws_cloudformation_stack/types.rb +244 -0
  684. data/lib/pangea/resources/aws_cloudformation_stack/types.rbs +46 -0
  685. data/lib/pangea/resources/aws_cloudformation_stack_set/CLAUDE.md +309 -0
  686. data/lib/pangea/resources/aws_cloudformation_stack_set/resource.rb +152 -0
  687. data/lib/pangea/resources/aws_cloudformation_stack_set/types.rb +311 -0
  688. data/lib/pangea/resources/aws_cloudformation_stack_set/types.rbs +48 -0
  689. data/lib/pangea/resources/aws_cloudfront_cache_policy/resource.rb +84 -0
  690. data/lib/pangea/resources/aws_cloudfront_cache_policy/types.rb +56 -0
  691. data/lib/pangea/resources/aws_cloudfront_distribution/CLAUDE.md +62 -0
  692. data/lib/pangea/resources/aws_cloudfront_distribution/resource.rb +251 -0
  693. data/lib/pangea/resources/aws_cloudfront_distribution/types.rb +415 -0
  694. data/lib/pangea/resources/aws_cloudfront_key_group/resource.rb +71 -0
  695. data/lib/pangea/resources/aws_cloudfront_key_group/types.rb +191 -0
  696. data/lib/pangea/resources/aws_cloudfront_origin_access_control/resource.rb +68 -0
  697. data/lib/pangea/resources/aws_cloudfront_origin_access_control/types.rb +100 -0
  698. data/lib/pangea/resources/aws_cloudfront_origin_request_policy/resource.rb +76 -0
  699. data/lib/pangea/resources/aws_cloudfront_origin_request_policy/types.rb +49 -0
  700. data/lib/pangea/resources/aws_cloudfront_public_key/resource.rb +69 -0
  701. data/lib/pangea/resources/aws_cloudfront_public_key/types.rb +177 -0
  702. data/lib/pangea/resources/aws_cloudfront_public_key.rbs +30 -0
  703. data/lib/pangea/resources/aws_cloudfront_response_headers_policy/resource.rb +175 -0
  704. data/lib/pangea/resources/aws_cloudfront_response_headers_policy/types.rb +385 -0
  705. data/lib/pangea/resources/aws_cloudtrail/resource.rb +133 -0
  706. data/lib/pangea/resources/aws_cloudtrail/types.rb +364 -0
  707. data/lib/pangea/resources/aws_cloudtrail.rbs +10 -0
  708. data/lib/pangea/resources/aws_cloudtrail_event_data_store/resource.rb +64 -0
  709. data/lib/pangea/resources/aws_cloudtrail_event_data_store/types.rb +73 -0
  710. data/lib/pangea/resources/aws_cloudtrail_event_data_store.rbs +10 -0
  711. data/lib/pangea/resources/aws_cloudwatch_anomaly_detector/resource.rb +103 -0
  712. data/lib/pangea/resources/aws_cloudwatch_composite_alarm/CLAUDE.md +288 -0
  713. data/lib/pangea/resources/aws_cloudwatch_composite_alarm/resource.rb +133 -0
  714. data/lib/pangea/resources/aws_cloudwatch_composite_alarm/types.rb +134 -0
  715. data/lib/pangea/resources/aws_cloudwatch_dashboard/CLAUDE.md +342 -0
  716. data/lib/pangea/resources/aws_cloudwatch_dashboard/resource.rb +156 -0
  717. data/lib/pangea/resources/aws_cloudwatch_dashboard/types.rb +302 -0
  718. data/lib/pangea/resources/aws_cloudwatch_event_rule/CLAUDE.md +568 -0
  719. data/lib/pangea/resources/aws_cloudwatch_event_rule/resource.rb +143 -0
  720. data/lib/pangea/resources/aws_cloudwatch_event_rule/types.rb +181 -0
  721. data/lib/pangea/resources/aws_cloudwatch_event_target/CLAUDE.md +625 -0
  722. data/lib/pangea/resources/aws_cloudwatch_event_target/resource.rb +226 -0
  723. data/lib/pangea/resources/aws_cloudwatch_event_target/types.rb +231 -0
  724. data/lib/pangea/resources/aws_cloudwatch_insight_rule/resource.rb +101 -0
  725. data/lib/pangea/resources/aws_cloudwatch_log_data_protection_policy/resource.rb +99 -0
  726. data/lib/pangea/resources/aws_cloudwatch_log_destination/CLAUDE.md +388 -0
  727. data/lib/pangea/resources/aws_cloudwatch_log_destination/resource.rb +103 -0
  728. data/lib/pangea/resources/aws_cloudwatch_log_destination/types.rb +103 -0
  729. data/lib/pangea/resources/aws_cloudwatch_log_destination_policy/CLAUDE.md +479 -0
  730. data/lib/pangea/resources/aws_cloudwatch_log_destination_policy/resource.rb +132 -0
  731. data/lib/pangea/resources/aws_cloudwatch_log_destination_policy/types.rb +130 -0
  732. data/lib/pangea/resources/aws_cloudwatch_log_group/CLAUDE.md +175 -0
  733. data/lib/pangea/resources/aws_cloudwatch_log_group/resource.rb +120 -0
  734. data/lib/pangea/resources/aws_cloudwatch_log_group/types.rb +138 -0
  735. data/lib/pangea/resources/aws_cloudwatch_log_metric_filter/CLAUDE.md +502 -0
  736. data/lib/pangea/resources/aws_cloudwatch_log_metric_filter/resource.rb +130 -0
  737. data/lib/pangea/resources/aws_cloudwatch_log_metric_filter/types.rb +139 -0
  738. data/lib/pangea/resources/aws_cloudwatch_log_resource_policy/resource.rb +82 -0
  739. data/lib/pangea/resources/aws_cloudwatch_log_stream/CLAUDE.md +260 -0
  740. data/lib/pangea/resources/aws_cloudwatch_log_stream/resource.rb +90 -0
  741. data/lib/pangea/resources/aws_cloudwatch_log_stream/types.rb +130 -0
  742. data/lib/pangea/resources/aws_cloudwatch_log_subscription_filter/CLAUDE.md +473 -0
  743. data/lib/pangea/resources/aws_cloudwatch_log_subscription_filter/resource.rb +105 -0
  744. data/lib/pangea/resources/aws_cloudwatch_log_subscription_filter/types.rb +142 -0
  745. data/lib/pangea/resources/aws_cloudwatch_metric_alarm/CLAUDE.md +317 -0
  746. data/lib/pangea/resources/aws_cloudwatch_metric_alarm/resource.rb +198 -0
  747. data/lib/pangea/resources/aws_cloudwatch_metric_alarm/types.rb +242 -0
  748. data/lib/pangea/resources/aws_cloudwatch_query_definition/resource.rb +93 -0
  749. data/lib/pangea/resources/aws_codeartifact_domain/CLAUDE.md +54 -0
  750. data/lib/pangea/resources/aws_codeartifact_domain/resource.rb +126 -0
  751. data/lib/pangea/resources/aws_codeartifact_domain/types.rb +131 -0
  752. data/lib/pangea/resources/aws_codeartifact_repository/CLAUDE.md +55 -0
  753. data/lib/pangea/resources/aws_codeartifact_repository/resource.rb +176 -0
  754. data/lib/pangea/resources/aws_codeartifact_repository/types.rb +196 -0
  755. data/lib/pangea/resources/aws_codebuild_project/CLAUDE.md +304 -0
  756. data/lib/pangea/resources/aws_codebuild_project/resource.rb +254 -0
  757. data/lib/pangea/resources/aws_codebuild_project/types.rb +288 -0
  758. data/lib/pangea/resources/aws_codebuild_project/types.rbs +140 -0
  759. data/lib/pangea/resources/aws_codebuild_project.rbs +10 -0
  760. data/lib/pangea/resources/aws_codecommit_repository/CLAUDE.md +150 -0
  761. data/lib/pangea/resources/aws_codecommit_repository/resource.rb +100 -0
  762. data/lib/pangea/resources/aws_codecommit_repository/types.rb +122 -0
  763. data/lib/pangea/resources/aws_codecommit_repository/types.rbs +55 -0
  764. data/lib/pangea/resources/aws_codecommit_repository.rbs +10 -0
  765. data/lib/pangea/resources/aws_codedeploy_application/CLAUDE.md +312 -0
  766. data/lib/pangea/resources/aws_codedeploy_application/resource.rb +81 -0
  767. data/lib/pangea/resources/aws_codedeploy_application/types.rb +98 -0
  768. data/lib/pangea/resources/aws_codedeploy_application.rbs +10 -0
  769. data/lib/pangea/resources/aws_codedeploy_deployment_config/CLAUDE.md +354 -0
  770. data/lib/pangea/resources/aws_codedeploy_deployment_config/resource.rb +97 -0
  771. data/lib/pangea/resources/aws_codedeploy_deployment_config/types.rb +143 -0
  772. data/lib/pangea/resources/aws_codedeploy_deployment_config.rbs +10 -0
  773. data/lib/pangea/resources/aws_codedeploy_deployment_group/CLAUDE.md +342 -0
  774. data/lib/pangea/resources/aws_codedeploy_deployment_group/resource.rb +224 -0
  775. data/lib/pangea/resources/aws_codedeploy_deployment_group/types.rb +249 -0
  776. data/lib/pangea/resources/aws_codedeploy_deployment_group.rbs +10 -0
  777. data/lib/pangea/resources/aws_codepipeline/CLAUDE.md +592 -0
  778. data/lib/pangea/resources/aws_codepipeline/resource.rb +126 -0
  779. data/lib/pangea/resources/aws_codepipeline/types.rb +212 -0
  780. data/lib/pangea/resources/aws_codepipeline.rbs +10 -0
  781. data/lib/pangea/resources/aws_codepipeline_webhook/CLAUDE.md +449 -0
  782. data/lib/pangea/resources/aws_codepipeline_webhook/resource.rb +94 -0
  783. data/lib/pangea/resources/aws_codepipeline_webhook/types.rb +134 -0
  784. data/lib/pangea/resources/aws_codepipeline_webhook.rbs +10 -0
  785. data/lib/pangea/resources/aws_codestar_connection/CLAUDE.md +55 -0
  786. data/lib/pangea/resources/aws_codestar_connection/resource.rb +136 -0
  787. data/lib/pangea/resources/aws_codestar_connection/types.rb +191 -0
  788. data/lib/pangea/resources/aws_cognito_identity_pool/CLAUDE.md +712 -0
  789. data/lib/pangea/resources/aws_cognito_identity_pool/resource.rb +110 -0
  790. data/lib/pangea/resources/aws_cognito_identity_pool/types.rb +343 -0
  791. data/lib/pangea/resources/aws_cognito_identity_provider/resource.rb +91 -0
  792. data/lib/pangea/resources/aws_cognito_identity_provider/types.rb +480 -0
  793. data/lib/pangea/resources/aws_cognito_user/resource.rb +81 -0
  794. data/lib/pangea/resources/aws_cognito_user/types.rb +145 -0
  795. data/lib/pangea/resources/aws_cognito_user_group/resource.rb +64 -0
  796. data/lib/pangea/resources/aws_cognito_user_group/types.rb +130 -0
  797. data/lib/pangea/resources/aws_cognito_user_pool/CLAUDE.md +431 -0
  798. data/lib/pangea/resources/aws_cognito_user_pool/resource.rb +251 -0
  799. data/lib/pangea/resources/aws_cognito_user_pool/types.rb +359 -0
  800. data/lib/pangea/resources/aws_cognito_user_pool_client/CLAUDE.md +542 -0
  801. data/lib/pangea/resources/aws_cognito_user_pool_client/resource.rb +139 -0
  802. data/lib/pangea/resources/aws_cognito_user_pool_client/types.rb +394 -0
  803. data/lib/pangea/resources/aws_cognito_user_pool_domain/CLAUDE.md +524 -0
  804. data/lib/pangea/resources/aws_cognito_user_pool_domain/resource.rb +71 -0
  805. data/lib/pangea/resources/aws_cognito_user_pool_domain/types.rb +252 -0
  806. data/lib/pangea/resources/aws_config_config_rule/CLAUDE.md +381 -0
  807. data/lib/pangea/resources/aws_config_config_rule/resource.rb +190 -0
  808. data/lib/pangea/resources/aws_config_config_rule/types.rb +231 -0
  809. data/lib/pangea/resources/aws_config_config_rule.rbs +10 -0
  810. data/lib/pangea/resources/aws_config_configuration_recorder/CLAUDE.md +247 -0
  811. data/lib/pangea/resources/aws_config_configuration_recorder/resource.rb +139 -0
  812. data/lib/pangea/resources/aws_config_configuration_recorder/types.rb +156 -0
  813. data/lib/pangea/resources/aws_config_configuration_recorder.rbs +10 -0
  814. data/lib/pangea/resources/aws_config_delivery_channel/CLAUDE.md +290 -0
  815. data/lib/pangea/resources/aws_config_delivery_channel/resource.rb +141 -0
  816. data/lib/pangea/resources/aws_config_delivery_channel/types.rb +195 -0
  817. data/lib/pangea/resources/aws_config_delivery_channel.rbs +10 -0
  818. data/lib/pangea/resources/aws_config_remediation_configuration/resource.rb +77 -0
  819. data/lib/pangea/resources/aws_config_remediation_configuration/types.rb +119 -0
  820. data/lib/pangea/resources/aws_config_remediation_configuration.rbs +10 -0
  821. data/lib/pangea/resources/aws_cur_report_definition/resource.rb +63 -0
  822. data/lib/pangea/resources/aws_cur_report_definition/types.rb +80 -0
  823. data/lib/pangea/resources/aws_customer_gateway/CLAUDE.md +458 -0
  824. data/lib/pangea/resources/aws_customer_gateway/resource.rb +93 -0
  825. data/lib/pangea/resources/aws_customer_gateway/types.rb +117 -0
  826. data/lib/pangea/resources/aws_db_cluster_snapshot/resource.rb +95 -0
  827. data/lib/pangea/resources/aws_db_cluster_snapshot/types.rb +245 -0
  828. data/lib/pangea/resources/aws_db_instance/CLAUDE.md +407 -0
  829. data/lib/pangea/resources/aws_db_instance/resource.rb +126 -0
  830. data/lib/pangea/resources/aws_db_instance/types.rb +260 -0
  831. data/lib/pangea/resources/aws_db_parameter_group/CLAUDE.md +285 -0
  832. data/lib/pangea/resources/aws_db_parameter_group/resource.rb +94 -0
  833. data/lib/pangea/resources/aws_db_parameter_group/types.rb +300 -0
  834. data/lib/pangea/resources/aws_db_snapshot/resource.rb +92 -0
  835. data/lib/pangea/resources/aws_db_snapshot/types.rb +175 -0
  836. data/lib/pangea/resources/aws_db_subnet_group/CLAUDE.md +189 -0
  837. data/lib/pangea/resources/aws_db_subnet_group/resource.rb +77 -0
  838. data/lib/pangea/resources/aws_db_subnet_group/types.rb +102 -0
  839. data/lib/pangea/resources/aws_default_network_acl/resource.rb +67 -0
  840. data/lib/pangea/resources/aws_default_network_acl/types.rb +46 -0
  841. data/lib/pangea/resources/aws_default_route_table/resource.rb +67 -0
  842. data/lib/pangea/resources/aws_default_route_table/types.rb +46 -0
  843. data/lib/pangea/resources/aws_default_security_group/resource.rb +67 -0
  844. data/lib/pangea/resources/aws_default_security_group/types.rb +46 -0
  845. data/lib/pangea/resources/aws_default_vpc_dhcp_options/resource.rb +67 -0
  846. data/lib/pangea/resources/aws_default_vpc_dhcp_options/types.rb +46 -0
  847. data/lib/pangea/resources/aws_detective_graph.rbs +29 -0
  848. data/lib/pangea/resources/aws_device_farm_project/CLAUDE.md +299 -0
  849. data/lib/pangea/resources/aws_device_farm_project/resource.rb +78 -0
  850. data/lib/pangea/resources/aws_device_farm_project/types.rb +51 -0
  851. data/lib/pangea/resources/aws_device_farm_project.rbs +33 -0
  852. data/lib/pangea/resources/aws_directory_service_directory/resource.rb +34 -0
  853. data/lib/pangea/resources/aws_docdb_certificate/CLAUDE.md +96 -0
  854. data/lib/pangea/resources/aws_docdb_certificate/resource.rb +74 -0
  855. data/lib/pangea/resources/aws_docdb_certificate/types.rb +48 -0
  856. data/lib/pangea/resources/aws_docdb_cluster/CLAUDE.md +96 -0
  857. data/lib/pangea/resources/aws_docdb_cluster/resource.rb +96 -0
  858. data/lib/pangea/resources/aws_docdb_cluster/types.rb +70 -0
  859. data/lib/pangea/resources/aws_docdb_cluster_endpoint/CLAUDE.md +96 -0
  860. data/lib/pangea/resources/aws_docdb_cluster_endpoint/resource.rb +74 -0
  861. data/lib/pangea/resources/aws_docdb_cluster_endpoint/types.rb +52 -0
  862. data/lib/pangea/resources/aws_docdb_cluster_instance/CLAUDE.md +96 -0
  863. data/lib/pangea/resources/aws_docdb_cluster_instance/resource.rb +89 -0
  864. data/lib/pangea/resources/aws_docdb_cluster_instance/types.rb +61 -0
  865. data/lib/pangea/resources/aws_docdb_cluster_parameter_group/CLAUDE.md +96 -0
  866. data/lib/pangea/resources/aws_docdb_cluster_parameter_group/resource.rb +71 -0
  867. data/lib/pangea/resources/aws_docdb_cluster_parameter_group/types.rb +51 -0
  868. data/lib/pangea/resources/aws_docdb_cluster_snapshot/CLAUDE.md +96 -0
  869. data/lib/pangea/resources/aws_docdb_cluster_snapshot/resource.rb +80 -0
  870. data/lib/pangea/resources/aws_docdb_cluster_snapshot/types.rb +49 -0
  871. data/lib/pangea/resources/aws_docdb_event_subscription/CLAUDE.md +96 -0
  872. data/lib/pangea/resources/aws_docdb_event_subscription/resource.rb +74 -0
  873. data/lib/pangea/resources/aws_docdb_event_subscription/types.rb +53 -0
  874. data/lib/pangea/resources/aws_docdb_global_cluster/CLAUDE.md +96 -0
  875. data/lib/pangea/resources/aws_docdb_global_cluster/resource.rb +76 -0
  876. data/lib/pangea/resources/aws_docdb_global_cluster/types.rb +54 -0
  877. data/lib/pangea/resources/aws_docdb_subnet_group/CLAUDE.md +96 -0
  878. data/lib/pangea/resources/aws_docdb_subnet_group/resource.rb +70 -0
  879. data/lib/pangea/resources/aws_docdb_subnet_group/types.rb +50 -0
  880. data/lib/pangea/resources/aws_drs_launch_configuration_template/resource.rb +183 -0
  881. data/lib/pangea/resources/aws_drs_replication_configuration_template/resource.rb +156 -0
  882. data/lib/pangea/resources/aws_dynamodb_global_table/CLAUDE.md +184 -0
  883. data/lib/pangea/resources/aws_dynamodb_global_table/resource.rb +134 -0
  884. data/lib/pangea/resources/aws_dynamodb_global_table/types.rb +272 -0
  885. data/lib/pangea/resources/aws_dynamodb_global_table/types.rbs +39 -0
  886. data/lib/pangea/resources/aws_dynamodb_kinesis_streaming_destination/resource.rb +70 -0
  887. data/lib/pangea/resources/aws_dynamodb_kinesis_streaming_destination/types.rb +76 -0
  888. data/lib/pangea/resources/aws_dynamodb_table/CLAUDE.md +130 -0
  889. data/lib/pangea/resources/aws_dynamodb_table/resource.rb +224 -0
  890. data/lib/pangea/resources/aws_dynamodb_table/types.rb +408 -0
  891. data/lib/pangea/resources/aws_dynamodb_table/types.rbs +55 -0
  892. data/lib/pangea/resources/aws_dynamodb_table_export/resource.rb +85 -0
  893. data/lib/pangea/resources/aws_dynamodb_table_export/types.rb +98 -0
  894. data/lib/pangea/resources/aws_ebs_volume/CLAUDE.md +275 -0
  895. data/lib/pangea/resources/aws_ebs_volume/resource.rb +114 -0
  896. data/lib/pangea/resources/aws_ebs_volume/types.rb +250 -0
  897. data/lib/pangea/resources/aws_ec2_ami_launch_permission/resource.rb +67 -0
  898. data/lib/pangea/resources/aws_ec2_ami_launch_permission/types.rb +46 -0
  899. data/lib/pangea/resources/aws_ec2_availability_zone_group/resource.rb +67 -0
  900. data/lib/pangea/resources/aws_ec2_availability_zone_group/types.rb +46 -0
  901. data/lib/pangea/resources/aws_ec2_capacity_block_reservation/resource.rb +67 -0
  902. data/lib/pangea/resources/aws_ec2_capacity_block_reservation/types.rb +46 -0
  903. data/lib/pangea/resources/aws_ec2_capacity_reservation/resource.rb +67 -0
  904. data/lib/pangea/resources/aws_ec2_capacity_reservation/types.rb +46 -0
  905. data/lib/pangea/resources/aws_ec2_dedicated_host/resource.rb +67 -0
  906. data/lib/pangea/resources/aws_ec2_dedicated_host/types.rb +46 -0
  907. data/lib/pangea/resources/aws_ec2_fleet/resource.rb +67 -0
  908. data/lib/pangea/resources/aws_ec2_fleet/types.rb +46 -0
  909. data/lib/pangea/resources/aws_ec2_host_resource_group_association/resource.rb +67 -0
  910. data/lib/pangea/resources/aws_ec2_host_resource_group_association/types.rb +46 -0
  911. data/lib/pangea/resources/aws_ec2_image_block_public_access/resource.rb +67 -0
  912. data/lib/pangea/resources/aws_ec2_image_block_public_access/types.rb +46 -0
  913. data/lib/pangea/resources/aws_ec2_instance_metadata_defaults/resource.rb +67 -0
  914. data/lib/pangea/resources/aws_ec2_instance_metadata_defaults/types.rb +46 -0
  915. data/lib/pangea/resources/aws_ec2_serial_console_access/resource.rb +67 -0
  916. data/lib/pangea/resources/aws_ec2_serial_console_access/types.rb +46 -0
  917. data/lib/pangea/resources/aws_ec2_snapshot_block_public_access/resource.rb +67 -0
  918. data/lib/pangea/resources/aws_ec2_snapshot_block_public_access/types.rb +46 -0
  919. data/lib/pangea/resources/aws_ec2_spot_datafeed_subscription/resource.rb +67 -0
  920. data/lib/pangea/resources/aws_ec2_spot_datafeed_subscription/types.rb +46 -0
  921. data/lib/pangea/resources/aws_ec2_spot_fleet_request/resource.rb +67 -0
  922. data/lib/pangea/resources/aws_ec2_spot_fleet_request/types.rb +46 -0
  923. data/lib/pangea/resources/aws_ec2_spot_instance_request/resource.rb +67 -0
  924. data/lib/pangea/resources/aws_ec2_spot_instance_request/types.rb +46 -0
  925. data/lib/pangea/resources/aws_ec2_tag/resource.rb +67 -0
  926. data/lib/pangea/resources/aws_ec2_tag/types.rb +46 -0
  927. data/lib/pangea/resources/aws_ec2_transit_gateway/CLAUDE.md +220 -0
  928. data/lib/pangea/resources/aws_ec2_transit_gateway/resource.rb +114 -0
  929. data/lib/pangea/resources/aws_ec2_transit_gateway/types.rb +124 -0
  930. data/lib/pangea/resources/aws_ec2_transit_gateway.rbs +29 -0
  931. data/lib/pangea/resources/aws_ec2_transit_gateway_multicast_domain/resource.rb +67 -0
  932. data/lib/pangea/resources/aws_ec2_transit_gateway_multicast_domain/types.rb +46 -0
  933. data/lib/pangea/resources/aws_ec2_transit_gateway_multicast_domain_association/resource.rb +67 -0
  934. data/lib/pangea/resources/aws_ec2_transit_gateway_multicast_domain_association/types.rb +46 -0
  935. data/lib/pangea/resources/aws_ec2_transit_gateway_multicast_group_member/resource.rb +67 -0
  936. data/lib/pangea/resources/aws_ec2_transit_gateway_multicast_group_member/types.rb +46 -0
  937. data/lib/pangea/resources/aws_ec2_transit_gateway_route/CLAUDE.md +458 -0
  938. data/lib/pangea/resources/aws_ec2_transit_gateway_route/resource.rb +81 -0
  939. data/lib/pangea/resources/aws_ec2_transit_gateway_route/types.rb +233 -0
  940. data/lib/pangea/resources/aws_ec2_transit_gateway_route.rbs +27 -0
  941. data/lib/pangea/resources/aws_ec2_transit_gateway_route_table/CLAUDE.md +384 -0
  942. data/lib/pangea/resources/aws_ec2_transit_gateway_route_table/resource.rb +77 -0
  943. data/lib/pangea/resources/aws_ec2_transit_gateway_route_table/types.rb +171 -0
  944. data/lib/pangea/resources/aws_ec2_transit_gateway_route_table.rbs +24 -0
  945. data/lib/pangea/resources/aws_ec2_transit_gateway_route_table_association/CLAUDE.md +409 -0
  946. data/lib/pangea/resources/aws_ec2_transit_gateway_route_table_association/resource.rb +74 -0
  947. data/lib/pangea/resources/aws_ec2_transit_gateway_route_table_association/types.rb +167 -0
  948. data/lib/pangea/resources/aws_ec2_transit_gateway_route_table_association.rbs +25 -0
  949. data/lib/pangea/resources/aws_ec2_transit_gateway_route_table_propagation/CLAUDE.md +433 -0
  950. data/lib/pangea/resources/aws_ec2_transit_gateway_route_table_propagation/resource.rb +70 -0
  951. data/lib/pangea/resources/aws_ec2_transit_gateway_route_table_propagation/types.rb +213 -0
  952. data/lib/pangea/resources/aws_ec2_transit_gateway_route_table_propagation.rbs +25 -0
  953. data/lib/pangea/resources/aws_ec2_transit_gateway_vpc_attachment/CLAUDE.md +326 -0
  954. data/lib/pangea/resources/aws_ec2_transit_gateway_vpc_attachment/resource.rb +101 -0
  955. data/lib/pangea/resources/aws_ec2_transit_gateway_vpc_attachment/types.rb +152 -0
  956. data/lib/pangea/resources/aws_ec2_transit_gateway_vpc_attachment.rbs +30 -0
  957. data/lib/pangea/resources/aws_ecr_lifecycle_policy/CLAUDE.md +56 -0
  958. data/lib/pangea/resources/aws_ecr_lifecycle_policy/resource.rb +164 -0
  959. data/lib/pangea/resources/aws_ecr_lifecycle_policy/types.rb +220 -0
  960. data/lib/pangea/resources/aws_ecr_replication_configuration/CLAUDE.md +55 -0
  961. data/lib/pangea/resources/aws_ecr_replication_configuration/resource.rb +147 -0
  962. data/lib/pangea/resources/aws_ecr_replication_configuration/types.rb +169 -0
  963. data/lib/pangea/resources/aws_ecr_repository/CLAUDE.md +54 -0
  964. data/lib/pangea/resources/aws_ecr_repository/resource.rb +143 -0
  965. data/lib/pangea/resources/aws_ecr_repository/types.rb +128 -0
  966. data/lib/pangea/resources/aws_ecr_repository_policy/CLAUDE.md +55 -0
  967. data/lib/pangea/resources/aws_ecr_repository_policy/resource.rb +133 -0
  968. data/lib/pangea/resources/aws_ecr_repository_policy/types.rb +193 -0
  969. data/lib/pangea/resources/aws_ecs_capacity_provider/resource.rb +106 -0
  970. data/lib/pangea/resources/aws_ecs_capacity_provider/types.rb +114 -0
  971. data/lib/pangea/resources/aws_ecs_cluster/CLAUDE.md +218 -0
  972. data/lib/pangea/resources/aws_ecs_cluster/resource.rb +130 -0
  973. data/lib/pangea/resources/aws_ecs_cluster/types.rb +155 -0
  974. data/lib/pangea/resources/aws_ecs_cluster_capacity_providers/CLAUDE.md +191 -0
  975. data/lib/pangea/resources/aws_ecs_cluster_capacity_providers/resource.rb +79 -0
  976. data/lib/pangea/resources/aws_ecs_cluster_capacity_providers/types.rb +171 -0
  977. data/lib/pangea/resources/aws_ecs_service/CLAUDE.md +256 -0
  978. data/lib/pangea/resources/aws_ecs_service/resource.rb +242 -0
  979. data/lib/pangea/resources/aws_ecs_service/types.rb +327 -0
  980. data/lib/pangea/resources/aws_ecs_task_definition/CLAUDE.md +281 -0
  981. data/lib/pangea/resources/aws_ecs_task_definition/resource.rb +318 -0
  982. data/lib/pangea/resources/aws_ecs_task_definition/types.rb +439 -0
  983. data/lib/pangea/resources/aws_ecs_task_definition/types_old.rb +439 -0
  984. data/lib/pangea/resources/aws_efs_access_point/CLAUDE.md +504 -0
  985. data/lib/pangea/resources/aws_efs_access_point/resource.rb +77 -0
  986. data/lib/pangea/resources/aws_efs_access_point/types.rb +185 -0
  987. data/lib/pangea/resources/aws_efs_file_system/CLAUDE.md +279 -0
  988. data/lib/pangea/resources/aws_efs_file_system/resource.rb +80 -0
  989. data/lib/pangea/resources/aws_efs_file_system/types.rb +106 -0
  990. data/lib/pangea/resources/aws_efs_mount_target/CLAUDE.md +361 -0
  991. data/lib/pangea/resources/aws_efs_mount_target/resource.rb +68 -0
  992. data/lib/pangea/resources/aws_efs_mount_target/types.rb +100 -0
  993. data/lib/pangea/resources/aws_eip/CLAUDE.md +325 -0
  994. data/lib/pangea/resources/aws_eip/resource.rb +105 -0
  995. data/lib/pangea/resources/aws_eip/types.rb +102 -0
  996. data/lib/pangea/resources/aws_eip_association/CLAUDE.md +96 -0
  997. data/lib/pangea/resources/aws_eip_association/resource.rb +77 -0
  998. data/lib/pangea/resources/aws_eip_association/types.rb +88 -0
  999. data/lib/pangea/resources/aws_eks_access_entry/resource.rb +92 -0
  1000. data/lib/pangea/resources/aws_eks_access_entry/types.rb +110 -0
  1001. data/lib/pangea/resources/aws_eks_addon/CLAUDE.md +271 -0
  1002. data/lib/pangea/resources/aws_eks_addon/resource.rb +153 -0
  1003. data/lib/pangea/resources/aws_eks_addon/types.rb +199 -0
  1004. data/lib/pangea/resources/aws_eks_cluster/CLAUDE.md +198 -0
  1005. data/lib/pangea/resources/aws_eks_cluster/resource.rb +165 -0
  1006. data/lib/pangea/resources/aws_eks_cluster/types.rb +195 -0
  1007. data/lib/pangea/resources/aws_eks_fargate_profile/CLAUDE.md +266 -0
  1008. data/lib/pangea/resources/aws_eks_fargate_profile/resource.rb +152 -0
  1009. data/lib/pangea/resources/aws_eks_fargate_profile/types.rb +145 -0
  1010. data/lib/pangea/resources/aws_eks_node_group/CLAUDE.md +258 -0
  1011. data/lib/pangea/resources/aws_eks_node_group/resource.rb +224 -0
  1012. data/lib/pangea/resources/aws_eks_node_group/types.rb +260 -0
  1013. data/lib/pangea/resources/aws_elasticache_cluster/CLAUDE.md +240 -0
  1014. data/lib/pangea/resources/aws_elasticache_cluster/resource.rb +134 -0
  1015. data/lib/pangea/resources/aws_elasticache_cluster/types.rb +286 -0
  1016. data/lib/pangea/resources/aws_elasticache_cluster/types.rbs +41 -0
  1017. data/lib/pangea/resources/aws_elasticache_parameter_group/CLAUDE.md +334 -0
  1018. data/lib/pangea/resources/aws_elasticache_parameter_group/resource.rb +94 -0
  1019. data/lib/pangea/resources/aws_elasticache_parameter_group/types.rb +295 -0
  1020. data/lib/pangea/resources/aws_elasticache_subnet_group/CLAUDE.md +286 -0
  1021. data/lib/pangea/resources/aws_elasticache_subnet_group/resource.rb +79 -0
  1022. data/lib/pangea/resources/aws_elasticache_subnet_group/types.rb +159 -0
  1023. data/lib/pangea/resources/aws_elb_attachment/resource.rb +67 -0
  1024. data/lib/pangea/resources/aws_elb_attachment/types.rb +46 -0
  1025. data/lib/pangea/resources/aws_elb_service_account/resource.rb +67 -0
  1026. data/lib/pangea/resources/aws_elb_service_account/types.rb +46 -0
  1027. data/lib/pangea/resources/aws_elemental_data_plane_channel/resource.rb +74 -0
  1028. data/lib/pangea/resources/aws_elemental_data_plane_channel/types.rb +66 -0
  1029. data/lib/pangea/resources/aws_emr_cluster/CLAUDE.md +660 -0
  1030. data/lib/pangea/resources/aws_emr_cluster/resource.rb +324 -0
  1031. data/lib/pangea/resources/aws_emr_cluster/types.rb +496 -0
  1032. data/lib/pangea/resources/aws_emr_cluster/types.rbs +67 -0
  1033. data/lib/pangea/resources/aws_emr_instance_group/CLAUDE.md +586 -0
  1034. data/lib/pangea/resources/aws_emr_instance_group/resource.rb +185 -0
  1035. data/lib/pangea/resources/aws_emr_instance_group/types.rb +420 -0
  1036. data/lib/pangea/resources/aws_emr_instance_group/types.rbs +51 -0
  1037. data/lib/pangea/resources/aws_emr_step/CLAUDE.md +560 -0
  1038. data/lib/pangea/resources/aws_emr_step/resource.rb +96 -0
  1039. data/lib/pangea/resources/aws_emr_step/types.rb +389 -0
  1040. data/lib/pangea/resources/aws_emr_step/types.rbs +46 -0
  1041. data/lib/pangea/resources/aws_eventbridge_bus/CLAUDE.md +208 -0
  1042. data/lib/pangea/resources/aws_eventbridge_bus/resource.rb +78 -0
  1043. data/lib/pangea/resources/aws_eventbridge_bus/types.rb +177 -0
  1044. data/lib/pangea/resources/aws_eventbridge_bus/types.rbs +32 -0
  1045. data/lib/pangea/resources/aws_eventbridge_rule/CLAUDE.md +232 -0
  1046. data/lib/pangea/resources/aws_eventbridge_rule/resource.rb +95 -0
  1047. data/lib/pangea/resources/aws_eventbridge_rule/types.rb +332 -0
  1048. data/lib/pangea/resources/aws_eventbridge_rule/types.rbs +41 -0
  1049. data/lib/pangea/resources/aws_eventbridge_target/CLAUDE.md +260 -0
  1050. data/lib/pangea/resources/aws_eventbridge_target/resource.rb +220 -0
  1051. data/lib/pangea/resources/aws_eventbridge_target/types.rb +483 -0
  1052. data/lib/pangea/resources/aws_eventbridge_target/types.rbs +58 -0
  1053. data/lib/pangea/resources/aws_extended_resources_CLAUDE.md +395 -0
  1054. data/lib/pangea/resources/aws_fsx_lustre_filesystem/CLAUDE.md +383 -0
  1055. data/lib/pangea/resources/aws_fsx_lustre_filesystem/resource.rb +151 -0
  1056. data/lib/pangea/resources/aws_fsx_lustre_filesystem/types.rb +218 -0
  1057. data/lib/pangea/resources/aws_gamelift_alias/CLAUDE.md +261 -0
  1058. data/lib/pangea/resources/aws_gamelift_alias/resource.rb +78 -0
  1059. data/lib/pangea/resources/aws_gamelift_alias/types.rb +84 -0
  1060. data/lib/pangea/resources/aws_gamelift_alias.rbs +44 -0
  1061. data/lib/pangea/resources/aws_gamelift_build/CLAUDE.md +233 -0
  1062. data/lib/pangea/resources/aws_gamelift_build/resource.rb +89 -0
  1063. data/lib/pangea/resources/aws_gamelift_build/types.rb +71 -0
  1064. data/lib/pangea/resources/aws_gamelift_build.rbs +45 -0
  1065. data/lib/pangea/resources/aws_gamelift_compute/resource.rb +86 -0
  1066. data/lib/pangea/resources/aws_gamelift_compute/types.rb +51 -0
  1067. data/lib/pangea/resources/aws_gamelift_fleet/CLAUDE.md +191 -0
  1068. data/lib/pangea/resources/aws_gamelift_fleet/resource.rb +118 -0
  1069. data/lib/pangea/resources/aws_gamelift_fleet/types.rb +128 -0
  1070. data/lib/pangea/resources/aws_gamelift_fleet.rbs +84 -0
  1071. data/lib/pangea/resources/aws_gamelift_game_session/resource.rb +107 -0
  1072. data/lib/pangea/resources/aws_gamelift_game_session/types.rb +62 -0
  1073. data/lib/pangea/resources/aws_gamelift_game_session_queue/CLAUDE.md +282 -0
  1074. data/lib/pangea/resources/aws_gamelift_game_session_queue/resource.rb +101 -0
  1075. data/lib/pangea/resources/aws_gamelift_game_session_queue/types.rb +87 -0
  1076. data/lib/pangea/resources/aws_gamelift_game_session_queue.rbs +57 -0
  1077. data/lib/pangea/resources/aws_gamelift_matchmaking_configuration/CLAUDE.md +288 -0
  1078. data/lib/pangea/resources/aws_gamelift_matchmaking_configuration/resource.rb +83 -0
  1079. data/lib/pangea/resources/aws_gamelift_matchmaking_configuration/types.rb +89 -0
  1080. data/lib/pangea/resources/aws_gamelift_matchmaking_configuration.rbs +52 -0
  1081. data/lib/pangea/resources/aws_gamelift_matchmaking_rule_set/resource.rb +88 -0
  1082. data/lib/pangea/resources/aws_gamelift_matchmaking_rule_set/types.rb +41 -0
  1083. data/lib/pangea/resources/aws_gamelift_player_session/resource.rb +86 -0
  1084. data/lib/pangea/resources/aws_gamelift_player_session/types.rb +48 -0
  1085. data/lib/pangea/resources/aws_gamelift_script/resource.rb +99 -0
  1086. data/lib/pangea/resources/aws_gamelift_script/types.rb +52 -0
  1087. data/lib/pangea/resources/aws_gamesparks_game/resource.rb +82 -0
  1088. data/lib/pangea/resources/aws_gamesparks_game/types.rb +44 -0
  1089. data/lib/pangea/resources/aws_glue_catalog_database/CLAUDE.md +161 -0
  1090. data/lib/pangea/resources/aws_glue_catalog_database/resource.rb +108 -0
  1091. data/lib/pangea/resources/aws_glue_catalog_database/types.rb +154 -0
  1092. data/lib/pangea/resources/aws_glue_catalog_database/types.rbs +36 -0
  1093. data/lib/pangea/resources/aws_glue_catalog_table/CLAUDE.md +387 -0
  1094. data/lib/pangea/resources/aws_glue_catalog_table/resource.rb +180 -0
  1095. data/lib/pangea/resources/aws_glue_catalog_table/types.rb +284 -0
  1096. data/lib/pangea/resources/aws_glue_catalog_table/types.rbs +44 -0
  1097. data/lib/pangea/resources/aws_glue_job/CLAUDE.md +398 -0
  1098. data/lib/pangea/resources/aws_glue_job/resource.rb +147 -0
  1099. data/lib/pangea/resources/aws_glue_job/types.rb +284 -0
  1100. data/lib/pangea/resources/aws_glue_job/types.rbs +50 -0
  1101. data/lib/pangea/resources/aws_glue_trigger/CLAUDE.md +454 -0
  1102. data/lib/pangea/resources/aws_glue_trigger/resource.rb +158 -0
  1103. data/lib/pangea/resources/aws_glue_trigger/types.rb +331 -0
  1104. data/lib/pangea/resources/aws_glue_trigger/types.rbs +53 -0
  1105. data/lib/pangea/resources/aws_ground_station.rb +371 -0
  1106. data/lib/pangea/resources/aws_guardduty_detector/resource.rb +104 -0
  1107. data/lib/pangea/resources/aws_guardduty_detector/types.rb +92 -0
  1108. data/lib/pangea/resources/aws_guardduty_detector.rbs +35 -0
  1109. data/lib/pangea/resources/aws_guardduty_member/resource.rb +72 -0
  1110. data/lib/pangea/resources/aws_guardduty_member/types.rb +59 -0
  1111. data/lib/pangea/resources/aws_guardduty_member.rbs +34 -0
  1112. data/lib/pangea/resources/aws_iam_group/CLAUDE.md +351 -0
  1113. data/lib/pangea/resources/aws_iam_group/resource.rb +78 -0
  1114. data/lib/pangea/resources/aws_iam_group/types.rb +406 -0
  1115. data/lib/pangea/resources/aws_iam_policy/CLAUDE.md +278 -0
  1116. data/lib/pangea/resources/aws_iam_policy/resource.rb +86 -0
  1117. data/lib/pangea/resources/aws_iam_policy/types.rb +358 -0
  1118. data/lib/pangea/resources/aws_iam_role/CLAUDE.md +419 -0
  1119. data/lib/pangea/resources/aws_iam_role/resource.rb +98 -0
  1120. data/lib/pangea/resources/aws_iam_role/types.rb +224 -0
  1121. data/lib/pangea/resources/aws_iam_role_policy_attachment/CLAUDE.md +331 -0
  1122. data/lib/pangea/resources/aws_iam_role_policy_attachment/resource.rb +71 -0
  1123. data/lib/pangea/resources/aws_iam_role_policy_attachment/types.rb +267 -0
  1124. data/lib/pangea/resources/aws_iam_user/CLAUDE.md +312 -0
  1125. data/lib/pangea/resources/aws_iam_user/resource.rb +85 -0
  1126. data/lib/pangea/resources/aws_iam_user/types.rb +338 -0
  1127. data/lib/pangea/resources/aws_inspector2_enabler/resource.rb +66 -0
  1128. data/lib/pangea/resources/aws_inspector2_enabler/types.rb +86 -0
  1129. data/lib/pangea/resources/aws_inspector2_enabler.rbs +33 -0
  1130. data/lib/pangea/resources/aws_instance/CLAUDE.md +396 -0
  1131. data/lib/pangea/resources/aws_instance/resource.rb +123 -0
  1132. data/lib/pangea/resources/aws_instance/types.rb +150 -0
  1133. data/lib/pangea/resources/aws_internet_gateway/CLAUDE.md +157 -0
  1134. data/lib/pangea/resources/aws_internet_gateway/resource.rb +85 -0
  1135. data/lib/pangea/resources/aws_internet_gateway/types.rb +47 -0
  1136. data/lib/pangea/resources/aws_iot_analytics_channel/CLAUDE.md +3 -0
  1137. data/lib/pangea/resources/aws_iot_analytics_channel/resource.rb +90 -0
  1138. data/lib/pangea/resources/aws_iot_analytics_channel/types.rb +58 -0
  1139. data/lib/pangea/resources/aws_iot_analytics_channel.rbs +15 -0
  1140. data/lib/pangea/resources/aws_iot_analytics_datastore/CLAUDE.md +3 -0
  1141. data/lib/pangea/resources/aws_iot_analytics_datastore/resource.rb +109 -0
  1142. data/lib/pangea/resources/aws_iot_analytics_datastore/types.rb +61 -0
  1143. data/lib/pangea/resources/aws_iot_analytics_datastore.rbs +16 -0
  1144. data/lib/pangea/resources/aws_iot_authorizer/resource.rb +97 -0
  1145. data/lib/pangea/resources/aws_iot_authorizer/types.rb +80 -0
  1146. data/lib/pangea/resources/aws_iot_billing_group/resource.rb +93 -0
  1147. data/lib/pangea/resources/aws_iot_billing_group/types.rb +77 -0
  1148. data/lib/pangea/resources/aws_iot_ca_certificate/resource.rb +127 -0
  1149. data/lib/pangea/resources/aws_iot_ca_certificate/types.rb +102 -0
  1150. data/lib/pangea/resources/aws_iot_certificate/CLAUDE.md +361 -0
  1151. data/lib/pangea/resources/aws_iot_certificate/resource.rb +93 -0
  1152. data/lib/pangea/resources/aws_iot_certificate/types.rb +238 -0
  1153. data/lib/pangea/resources/aws_iot_certificate.rbs +31 -0
  1154. data/lib/pangea/resources/aws_iot_device_defender_security_profile/CLAUDE.md +3 -0
  1155. data/lib/pangea/resources/aws_iot_device_defender_security_profile/resource.rb +77 -0
  1156. data/lib/pangea/resources/aws_iot_device_defender_security_profile/types.rb +56 -0
  1157. data/lib/pangea/resources/aws_iot_device_defender_security_profile.rbs +14 -0
  1158. data/lib/pangea/resources/aws_iot_domain_configuration/resource.rb +123 -0
  1159. data/lib/pangea/resources/aws_iot_domain_configuration/types.rb +111 -0
  1160. data/lib/pangea/resources/aws_iot_job_template/resource.rb +134 -0
  1161. data/lib/pangea/resources/aws_iot_job_template/types.rb +122 -0
  1162. data/lib/pangea/resources/aws_iot_policy/CLAUDE.md +27 -0
  1163. data/lib/pangea/resources/aws_iot_policy/resource.rb +63 -0
  1164. data/lib/pangea/resources/aws_iot_policy/types.rb +136 -0
  1165. data/lib/pangea/resources/aws_iot_policy.rbs +18 -0
  1166. data/lib/pangea/resources/aws_iot_policy_attachment/resource.rb +98 -0
  1167. data/lib/pangea/resources/aws_iot_policy_attachment/types.rb +54 -0
  1168. data/lib/pangea/resources/aws_iot_provisioning_template/resource.rb +133 -0
  1169. data/lib/pangea/resources/aws_iot_provisioning_template/types.rb +89 -0
  1170. data/lib/pangea/resources/aws_iot_role_alias/resource.rb +98 -0
  1171. data/lib/pangea/resources/aws_iot_role_alias/types.rb +66 -0
  1172. data/lib/pangea/resources/aws_iot_security_profile/CLAUDE.md +3 -0
  1173. data/lib/pangea/resources/aws_iot_security_profile/resource.rb +89 -0
  1174. data/lib/pangea/resources/aws_iot_security_profile/types.rb +53 -0
  1175. data/lib/pangea/resources/aws_iot_security_profile.rbs +14 -0
  1176. data/lib/pangea/resources/aws_iot_thing/CLAUDE.md +397 -0
  1177. data/lib/pangea/resources/aws_iot_thing/resource.rb +87 -0
  1178. data/lib/pangea/resources/aws_iot_thing/types.rb +139 -0
  1179. data/lib/pangea/resources/aws_iot_thing.rbs +27 -0
  1180. data/lib/pangea/resources/aws_iot_thing_group/resource.rb +125 -0
  1181. data/lib/pangea/resources/aws_iot_thing_group/types.rb +100 -0
  1182. data/lib/pangea/resources/aws_iot_thing_group_membership/resource.rb +78 -0
  1183. data/lib/pangea/resources/aws_iot_thing_group_membership/types.rb +57 -0
  1184. data/lib/pangea/resources/aws_iot_thing_principal_attachment/resource.rb +91 -0
  1185. data/lib/pangea/resources/aws_iot_thing_principal_attachment/types.rb +54 -0
  1186. data/lib/pangea/resources/aws_iot_thing_type/CLAUDE.md +526 -0
  1187. data/lib/pangea/resources/aws_iot_thing_type/resource.rb +100 -0
  1188. data/lib/pangea/resources/aws_iot_thing_type/types.rb +242 -0
  1189. data/lib/pangea/resources/aws_iot_thing_type.rbs +31 -0
  1190. data/lib/pangea/resources/aws_iot_topic_rule/CLAUDE.md +11 -0
  1191. data/lib/pangea/resources/aws_iot_topic_rule/resource.rb +81 -0
  1192. data/lib/pangea/resources/aws_iot_topic_rule/types.rb +53 -0
  1193. data/lib/pangea/resources/aws_iot_topic_rule.rbs +13 -0
  1194. data/lib/pangea/resources/aws_iot_topic_rule_destination/CLAUDE.md +5 -0
  1195. data/lib/pangea/resources/aws_iot_topic_rule_destination/resource.rb +66 -0
  1196. data/lib/pangea/resources/aws_iot_topic_rule_destination/types.rb +46 -0
  1197. data/lib/pangea/resources/aws_iot_topic_rule_destination.rbs +13 -0
  1198. data/lib/pangea/resources/aws_iot_wireless_destination/resource.rb +82 -0
  1199. data/lib/pangea/resources/aws_iot_wireless_destination/types.rb +65 -0
  1200. data/lib/pangea/resources/aws_iotanalytics_dataset/resource.rb +213 -0
  1201. data/lib/pangea/resources/aws_iotanalytics_dataset/types.rb +220 -0
  1202. data/lib/pangea/resources/aws_key_pair/CLAUDE.md +357 -0
  1203. data/lib/pangea/resources/aws_key_pair/resource.rb +88 -0
  1204. data/lib/pangea/resources/aws_key_pair/types.rb +175 -0
  1205. data/lib/pangea/resources/aws_kinesis_analytics_application/CLAUDE.md +630 -0
  1206. data/lib/pangea/resources/aws_kinesis_analytics_application/resource.rb +309 -0
  1207. data/lib/pangea/resources/aws_kinesis_analytics_application/types.rb +319 -0
  1208. data/lib/pangea/resources/aws_kinesis_analytics_application/types.rbs +45 -0
  1209. data/lib/pangea/resources/aws_kinesis_firehose_delivery_stream/CLAUDE.md +532 -0
  1210. data/lib/pangea/resources/aws_kinesis_firehose_delivery_stream/resource.rb +288 -0
  1211. data/lib/pangea/resources/aws_kinesis_firehose_delivery_stream/types.rb +305 -0
  1212. data/lib/pangea/resources/aws_kinesis_firehose_delivery_stream/types.rbs +44 -0
  1213. data/lib/pangea/resources/aws_kinesis_stream/CLAUDE.md +255 -0
  1214. data/lib/pangea/resources/aws_kinesis_stream/resource.rb +106 -0
  1215. data/lib/pangea/resources/aws_kinesis_stream/types.rb +160 -0
  1216. data/lib/pangea/resources/aws_kinesis_stream/types.rbs +43 -0
  1217. data/lib/pangea/resources/aws_kinesis_video_stream/CLAUDE.md +595 -0
  1218. data/lib/pangea/resources/aws_kinesis_video_stream/resource.rb +76 -0
  1219. data/lib/pangea/resources/aws_kinesis_video_stream/types.rb +229 -0
  1220. data/lib/pangea/resources/aws_kinesis_video_stream/types.rbs +48 -0
  1221. data/lib/pangea/resources/aws_kms_alias/resource.rb +68 -0
  1222. data/lib/pangea/resources/aws_kms_alias/types.rb +131 -0
  1223. data/lib/pangea/resources/aws_kms_key/resource.rb +110 -0
  1224. data/lib/pangea/resources/aws_kms_key/types.rb +119 -0
  1225. data/lib/pangea/resources/aws_lambda_event_source_mapping/CLAUDE.md +316 -0
  1226. data/lib/pangea/resources/aws_lambda_event_source_mapping/resource.rb +155 -0
  1227. data/lib/pangea/resources/aws_lambda_event_source_mapping/types.rb +201 -0
  1228. data/lib/pangea/resources/aws_lambda_function/CLAUDE.md +255 -0
  1229. data/lib/pangea/resources/aws_lambda_function/resource.rb +210 -0
  1230. data/lib/pangea/resources/aws_lambda_function/types.rb +217 -0
  1231. data/lib/pangea/resources/aws_lambda_function_url/resource.rb +89 -0
  1232. data/lib/pangea/resources/aws_lambda_function_url/types.rb +103 -0
  1233. data/lib/pangea/resources/aws_lambda_layer_version/CLAUDE.md +322 -0
  1234. data/lib/pangea/resources/aws_lambda_layer_version/resource.rb +88 -0
  1235. data/lib/pangea/resources/aws_lambda_layer_version/types.rb +159 -0
  1236. data/lib/pangea/resources/aws_lambda_permission/CLAUDE.md +276 -0
  1237. data/lib/pangea/resources/aws_lambda_permission/resource.rb +76 -0
  1238. data/lib/pangea/resources/aws_lambda_permission/types.rb +117 -0
  1239. data/lib/pangea/resources/aws_launch_configuration/resource.rb +67 -0
  1240. data/lib/pangea/resources/aws_launch_configuration/types.rb +46 -0
  1241. data/lib/pangea/resources/aws_launch_template/CLAUDE.md +269 -0
  1242. data/lib/pangea/resources/aws_launch_template/resource.rb +198 -0
  1243. data/lib/pangea/resources/aws_launch_template/types.rb +211 -0
  1244. data/lib/pangea/resources/aws_lb/CLAUDE.md +411 -0
  1245. data/lib/pangea/resources/aws_lb/resource.rb +111 -0
  1246. data/lib/pangea/resources/aws_lb/types.rb +80 -0
  1247. data/lib/pangea/resources/aws_lb_cookie_stickiness_policy/resource.rb +67 -0
  1248. data/lib/pangea/resources/aws_lb_cookie_stickiness_policy/types.rb +46 -0
  1249. data/lib/pangea/resources/aws_lb_listener/CLAUDE.md +310 -0
  1250. data/lib/pangea/resources/aws_lb_listener/resource.rb +187 -0
  1251. data/lib/pangea/resources/aws_lb_listener/types.rb +125 -0
  1252. data/lib/pangea/resources/aws_lb_listener/types.rbs +23 -0
  1253. data/lib/pangea/resources/aws_lb_listener_certificate/CLAUDE.md +463 -0
  1254. data/lib/pangea/resources/aws_lb_listener_certificate/resource.rb +56 -0
  1255. data/lib/pangea/resources/aws_lb_listener_certificate/types.rb +54 -0
  1256. data/lib/pangea/resources/aws_lb_listener_certificate/types.rbs +17 -0
  1257. data/lib/pangea/resources/aws_lb_listener_rule/CLAUDE.md +502 -0
  1258. data/lib/pangea/resources/aws_lb_listener_rule/resource.rb +210 -0
  1259. data/lib/pangea/resources/aws_lb_listener_rule/types.rb +123 -0
  1260. data/lib/pangea/resources/aws_lb_listener_rule/types.rbs +20 -0
  1261. data/lib/pangea/resources/aws_lb_ssl_negotiation_policy/resource.rb +67 -0
  1262. data/lib/pangea/resources/aws_lb_ssl_negotiation_policy/types.rb +46 -0
  1263. data/lib/pangea/resources/aws_lb_target_group/CLAUDE.md +271 -0
  1264. data/lib/pangea/resources/aws_lb_target_group/resource.rb +159 -0
  1265. data/lib/pangea/resources/aws_lb_target_group/types.rb +201 -0
  1266. data/lib/pangea/resources/aws_lb_target_group_attachment/CLAUDE.md +560 -0
  1267. data/lib/pangea/resources/aws_lb_target_group_attachment/resource.rb +67 -0
  1268. data/lib/pangea/resources/aws_lb_target_group_attachment/types.rb +46 -0
  1269. data/lib/pangea/resources/aws_lb_target_group_attachment/types.rbs +21 -0
  1270. data/lib/pangea/resources/aws_lb_trust_store/resource.rb +67 -0
  1271. data/lib/pangea/resources/aws_lb_trust_store/types.rb +46 -0
  1272. data/lib/pangea/resources/aws_lb_trust_store_revocation/resource.rb +67 -0
  1273. data/lib/pangea/resources/aws_lb_trust_store_revocation/types.rb +46 -0
  1274. data/lib/pangea/resources/aws_licensemanager_association/CLAUDE.md +96 -0
  1275. data/lib/pangea/resources/aws_licensemanager_association/resource.rb +68 -0
  1276. data/lib/pangea/resources/aws_licensemanager_association/types.rb +49 -0
  1277. data/lib/pangea/resources/aws_licensemanager_grant/CLAUDE.md +96 -0
  1278. data/lib/pangea/resources/aws_licensemanager_grant/resource.rb +74 -0
  1279. data/lib/pangea/resources/aws_licensemanager_grant/types.rb +52 -0
  1280. data/lib/pangea/resources/aws_licensemanager_grant_accepter/CLAUDE.md +96 -0
  1281. data/lib/pangea/resources/aws_licensemanager_grant_accepter/resource.rb +74 -0
  1282. data/lib/pangea/resources/aws_licensemanager_grant_accepter/types.rb +48 -0
  1283. data/lib/pangea/resources/aws_licensemanager_license_configuration/CLAUDE.md +96 -0
  1284. data/lib/pangea/resources/aws_licensemanager_license_configuration/resource.rb +74 -0
  1285. data/lib/pangea/resources/aws_licensemanager_license_configuration/types.rb +53 -0
  1286. data/lib/pangea/resources/aws_licensemanager_license_grant_accepter/CLAUDE.md +96 -0
  1287. data/lib/pangea/resources/aws_licensemanager_license_grant_accepter/resource.rb +68 -0
  1288. data/lib/pangea/resources/aws_licensemanager_license_grant_accepter/types.rb +48 -0
  1289. data/lib/pangea/resources/aws_licensemanager_report_generator/CLAUDE.md +96 -0
  1290. data/lib/pangea/resources/aws_licensemanager_report_generator/resource.rb +73 -0
  1291. data/lib/pangea/resources/aws_licensemanager_report_generator/types.rb +53 -0
  1292. data/lib/pangea/resources/aws_licensemanager_token/CLAUDE.md +96 -0
  1293. data/lib/pangea/resources/aws_licensemanager_token/resource.rb +71 -0
  1294. data/lib/pangea/resources/aws_licensemanager_token/types.rb +50 -0
  1295. data/lib/pangea/resources/aws_lightsail.rb +524 -0
  1296. data/lib/pangea/resources/aws_load_balancer_backend_server_policy/resource.rb +67 -0
  1297. data/lib/pangea/resources/aws_load_balancer_backend_server_policy/types.rb +46 -0
  1298. data/lib/pangea/resources/aws_load_balancer_listener_policy/resource.rb +67 -0
  1299. data/lib/pangea/resources/aws_load_balancer_listener_policy/types.rb +46 -0
  1300. data/lib/pangea/resources/aws_load_balancer_policy/resource.rb +67 -0
  1301. data/lib/pangea/resources/aws_load_balancer_policy/types.rb +46 -0
  1302. data/lib/pangea/resources/aws_local_zones.rb +223 -0
  1303. data/lib/pangea/resources/aws_managedblockchain_accessor/resource.rb +86 -0
  1304. data/lib/pangea/resources/aws_managedblockchain_accessor/types.rb +249 -0
  1305. data/lib/pangea/resources/aws_managedblockchain_ethereum_node/resource.rb +97 -0
  1306. data/lib/pangea/resources/aws_managedblockchain_ethereum_node/types.rb +349 -0
  1307. data/lib/pangea/resources/aws_managedblockchain_member/CLAUDE.md +478 -0
  1308. data/lib/pangea/resources/aws_managedblockchain_member/resource.rb +127 -0
  1309. data/lib/pangea/resources/aws_managedblockchain_member/types.rb +225 -0
  1310. data/lib/pangea/resources/aws_managedblockchain_network/CLAUDE.md +487 -0
  1311. data/lib/pangea/resources/aws_managedblockchain_network/resource.rb +160 -0
  1312. data/lib/pangea/resources/aws_managedblockchain_network/types.rb +262 -0
  1313. data/lib/pangea/resources/aws_managedblockchain_node/CLAUDE.md +505 -0
  1314. data/lib/pangea/resources/aws_managedblockchain_node/resource.rb +129 -0
  1315. data/lib/pangea/resources/aws_managedblockchain_node/types.rb +252 -0
  1316. data/lib/pangea/resources/aws_media_convert_queue/resource.rb +74 -0
  1317. data/lib/pangea/resources/aws_media_convert_queue/types.rb +71 -0
  1318. data/lib/pangea/resources/aws_media_live_channel/CLAUDE.md +881 -0
  1319. data/lib/pangea/resources/aws_media_live_channel/resource.rb +594 -0
  1320. data/lib/pangea/resources/aws_media_live_channel/types.rb +1002 -0
  1321. data/lib/pangea/resources/aws_media_live_input/CLAUDE.md +729 -0
  1322. data/lib/pangea/resources/aws_media_live_input/resource.rb +169 -0
  1323. data/lib/pangea/resources/aws_media_live_input/types.rb +247 -0
  1324. data/lib/pangea/resources/aws_media_package_channel/CLAUDE.md +698 -0
  1325. data/lib/pangea/resources/aws_media_package_channel/resource.rb +74 -0
  1326. data/lib/pangea/resources/aws_media_package_channel/types.rb +107 -0
  1327. data/lib/pangea/resources/aws_media_package_origin_endpoint/resource.rb +190 -0
  1328. data/lib/pangea/resources/aws_media_package_origin_endpoint/types.rb +197 -0
  1329. data/lib/pangea/resources/aws_media_store_container/resource.rb +60 -0
  1330. data/lib/pangea/resources/aws_media_store_container/types.rb +55 -0
  1331. data/lib/pangea/resources/aws_memorydb_acl/CLAUDE.md +96 -0
  1332. data/lib/pangea/resources/aws_memorydb_acl/resource.rb +70 -0
  1333. data/lib/pangea/resources/aws_memorydb_acl/types.rb +49 -0
  1334. data/lib/pangea/resources/aws_memorydb_cluster/CLAUDE.md +96 -0
  1335. data/lib/pangea/resources/aws_memorydb_cluster/resource.rb +93 -0
  1336. data/lib/pangea/resources/aws_memorydb_cluster/types.rb +69 -0
  1337. data/lib/pangea/resources/aws_memorydb_cluster_endpoint/CLAUDE.md +96 -0
  1338. data/lib/pangea/resources/aws_memorydb_cluster_endpoint/resource.rb +69 -0
  1339. data/lib/pangea/resources/aws_memorydb_cluster_endpoint/types.rb +48 -0
  1340. data/lib/pangea/resources/aws_memorydb_multi_region_cluster/CLAUDE.md +96 -0
  1341. data/lib/pangea/resources/aws_memorydb_multi_region_cluster/resource.rb +75 -0
  1342. data/lib/pangea/resources/aws_memorydb_multi_region_cluster/types.rb +53 -0
  1343. data/lib/pangea/resources/aws_memorydb_parameter_group/CLAUDE.md +96 -0
  1344. data/lib/pangea/resources/aws_memorydb_parameter_group/resource.rb +71 -0
  1345. data/lib/pangea/resources/aws_memorydb_parameter_group/types.rb +51 -0
  1346. data/lib/pangea/resources/aws_memorydb_snapshot/CLAUDE.md +96 -0
  1347. data/lib/pangea/resources/aws_memorydb_snapshot/resource.rb +73 -0
  1348. data/lib/pangea/resources/aws_memorydb_snapshot/types.rb +51 -0
  1349. data/lib/pangea/resources/aws_memorydb_subnet_group/CLAUDE.md +96 -0
  1350. data/lib/pangea/resources/aws_memorydb_subnet_group/resource.rb +71 -0
  1351. data/lib/pangea/resources/aws_memorydb_subnet_group/types.rb +50 -0
  1352. data/lib/pangea/resources/aws_memorydb_user/CLAUDE.md +96 -0
  1353. data/lib/pangea/resources/aws_memorydb_user/resource.rb +71 -0
  1354. data/lib/pangea/resources/aws_memorydb_user/types.rb +50 -0
  1355. data/lib/pangea/resources/aws_minimal.rb +302 -0
  1356. data/lib/pangea/resources/aws_mobile_analytics_app/CLAUDE.md +262 -0
  1357. data/lib/pangea/resources/aws_mobile_analytics_app/resource.rb +77 -0
  1358. data/lib/pangea/resources/aws_mobile_analytics_app/types.rb +47 -0
  1359. data/lib/pangea/resources/aws_mobile_analytics_app.rbs +30 -0
  1360. data/lib/pangea/resources/aws_mq_broker/resource.rb +157 -0
  1361. data/lib/pangea/resources/aws_mq_broker/types.rb +181 -0
  1362. data/lib/pangea/resources/aws_mq_broker.rbs +130 -0
  1363. data/lib/pangea/resources/aws_mq_configuration/resource.rb +75 -0
  1364. data/lib/pangea/resources/aws_mq_configuration/types.rb +88 -0
  1365. data/lib/pangea/resources/aws_mq_configuration.rbs +36 -0
  1366. data/lib/pangea/resources/aws_nat_gateway/CLAUDE.md +209 -0
  1367. data/lib/pangea/resources/aws_nat_gateway/resource.rb +97 -0
  1368. data/lib/pangea/resources/aws_nat_gateway/types.rb +80 -0
  1369. data/lib/pangea/resources/aws_neptune_cluster/CLAUDE.md +96 -0
  1370. data/lib/pangea/resources/aws_neptune_cluster/resource.rb +98 -0
  1371. data/lib/pangea/resources/aws_neptune_cluster/types.rb +70 -0
  1372. data/lib/pangea/resources/aws_neptune_cluster_endpoint/CLAUDE.md +96 -0
  1373. data/lib/pangea/resources/aws_neptune_cluster_endpoint/resource.rb +71 -0
  1374. data/lib/pangea/resources/aws_neptune_cluster_endpoint/types.rb +50 -0
  1375. data/lib/pangea/resources/aws_neptune_cluster_instance/CLAUDE.md +96 -0
  1376. data/lib/pangea/resources/aws_neptune_cluster_instance/resource.rb +85 -0
  1377. data/lib/pangea/resources/aws_neptune_cluster_instance/types.rb +58 -0
  1378. data/lib/pangea/resources/aws_neptune_cluster_parameter_group/CLAUDE.md +96 -0
  1379. data/lib/pangea/resources/aws_neptune_cluster_parameter_group/resource.rb +71 -0
  1380. data/lib/pangea/resources/aws_neptune_cluster_parameter_group/types.rb +51 -0
  1381. data/lib/pangea/resources/aws_neptune_cluster_snapshot/CLAUDE.md +96 -0
  1382. data/lib/pangea/resources/aws_neptune_cluster_snapshot/resource.rb +78 -0
  1383. data/lib/pangea/resources/aws_neptune_cluster_snapshot/types.rb +49 -0
  1384. data/lib/pangea/resources/aws_neptune_event_subscription/CLAUDE.md +96 -0
  1385. data/lib/pangea/resources/aws_neptune_event_subscription/resource.rb +74 -0
  1386. data/lib/pangea/resources/aws_neptune_event_subscription/types.rb +53 -0
  1387. data/lib/pangea/resources/aws_neptune_parameter_group/CLAUDE.md +96 -0
  1388. data/lib/pangea/resources/aws_neptune_parameter_group/resource.rb +71 -0
  1389. data/lib/pangea/resources/aws_neptune_parameter_group/types.rb +51 -0
  1390. data/lib/pangea/resources/aws_neptune_subnet_group/CLAUDE.md +96 -0
  1391. data/lib/pangea/resources/aws_neptune_subnet_group/resource.rb +70 -0
  1392. data/lib/pangea/resources/aws_neptune_subnet_group/types.rb +50 -0
  1393. data/lib/pangea/resources/aws_network_acl/CLAUDE.md +96 -0
  1394. data/lib/pangea/resources/aws_network_acl/resource.rb +77 -0
  1395. data/lib/pangea/resources/aws_network_acl/types.rb +147 -0
  1396. data/lib/pangea/resources/aws_network_acl_rule/CLAUDE.md +297 -0
  1397. data/lib/pangea/resources/aws_network_acl_rule/resource.rb +92 -0
  1398. data/lib/pangea/resources/aws_network_acl_rule/types.rb +158 -0
  1399. data/lib/pangea/resources/aws_network_interface/CLAUDE.md +310 -0
  1400. data/lib/pangea/resources/aws_network_interface/resource.rb +121 -0
  1401. data/lib/pangea/resources/aws_network_interface/types.rb +108 -0
  1402. data/lib/pangea/resources/aws_organizations_account/resource.rb +69 -0
  1403. data/lib/pangea/resources/aws_organizations_account/types.rb +85 -0
  1404. data/lib/pangea/resources/aws_organizations_account.rbs +10 -0
  1405. data/lib/pangea/resources/aws_organizations_delegated_administrator/resource.rb +82 -0
  1406. data/lib/pangea/resources/aws_organizations_organization/resource.rb +60 -0
  1407. data/lib/pangea/resources/aws_organizations_organization/types.rb +77 -0
  1408. data/lib/pangea/resources/aws_organizations_organization.rbs +10 -0
  1409. data/lib/pangea/resources/aws_organizations_resource_policy/resource.rb +99 -0
  1410. data/lib/pangea/resources/aws_outposts.rb +351 -0
  1411. data/lib/pangea/resources/aws_pinpoint_app/CLAUDE.md +363 -0
  1412. data/lib/pangea/resources/aws_pinpoint_app/resource.rb +84 -0
  1413. data/lib/pangea/resources/aws_pinpoint_app/types.rb +91 -0
  1414. data/lib/pangea/resources/aws_pinpoint_app.rbs +55 -0
  1415. data/lib/pangea/resources/aws_placement_group/resource.rb +67 -0
  1416. data/lib/pangea/resources/aws_placement_group/types.rb +46 -0
  1417. data/lib/pangea/resources/aws_proxy_protocol_policy/resource.rb +67 -0
  1418. data/lib/pangea/resources/aws_proxy_protocol_policy/types.rb +46 -0
  1419. data/lib/pangea/resources/aws_qldb_ledger/CLAUDE.md +734 -0
  1420. data/lib/pangea/resources/aws_qldb_ledger/resource.rb +89 -0
  1421. data/lib/pangea/resources/aws_qldb_ledger/types.rb +173 -0
  1422. data/lib/pangea/resources/aws_qldb_stream/CLAUDE.md +845 -0
  1423. data/lib/pangea/resources/aws_qldb_stream/resource.rb +101 -0
  1424. data/lib/pangea/resources/aws_qldb_stream/types.rb +222 -0
  1425. data/lib/pangea/resources/aws_ram_invitation_accepter/CLAUDE.md +96 -0
  1426. data/lib/pangea/resources/aws_ram_invitation_accepter/resource.rb +72 -0
  1427. data/lib/pangea/resources/aws_ram_invitation_accepter/types.rb +48 -0
  1428. data/lib/pangea/resources/aws_ram_managed_permission/CLAUDE.md +96 -0
  1429. data/lib/pangea/resources/aws_ram_managed_permission/resource.rb +75 -0
  1430. data/lib/pangea/resources/aws_ram_managed_permission/types.rb +49 -0
  1431. data/lib/pangea/resources/aws_ram_permission/CLAUDE.md +96 -0
  1432. data/lib/pangea/resources/aws_ram_permission/resource.rb +75 -0
  1433. data/lib/pangea/resources/aws_ram_permission/types.rb +50 -0
  1434. data/lib/pangea/resources/aws_ram_permission_association/CLAUDE.md +96 -0
  1435. data/lib/pangea/resources/aws_ram_permission_association/resource.rb +69 -0
  1436. data/lib/pangea/resources/aws_ram_permission_association/types.rb +50 -0
  1437. data/lib/pangea/resources/aws_ram_principal_association/CLAUDE.md +96 -0
  1438. data/lib/pangea/resources/aws_ram_principal_association/resource.rb +68 -0
  1439. data/lib/pangea/resources/aws_ram_principal_association/types.rb +49 -0
  1440. data/lib/pangea/resources/aws_ram_resource_association/CLAUDE.md +96 -0
  1441. data/lib/pangea/resources/aws_ram_resource_association/resource.rb +68 -0
  1442. data/lib/pangea/resources/aws_ram_resource_association/types.rb +49 -0
  1443. data/lib/pangea/resources/aws_ram_resource_share/CLAUDE.md +96 -0
  1444. data/lib/pangea/resources/aws_ram_resource_share/resource.rb +71 -0
  1445. data/lib/pangea/resources/aws_ram_resource_share/types.rb +50 -0
  1446. data/lib/pangea/resources/aws_ram_resource_share_accepter/CLAUDE.md +96 -0
  1447. data/lib/pangea/resources/aws_ram_resource_share_accepter/resource.rb +71 -0
  1448. data/lib/pangea/resources/aws_ram_resource_share_accepter/types.rb +48 -0
  1449. data/lib/pangea/resources/aws_ram_resource_share_invitation/CLAUDE.md +96 -0
  1450. data/lib/pangea/resources/aws_ram_resource_share_invitation/resource.rb +73 -0
  1451. data/lib/pangea/resources/aws_ram_resource_share_invitation/types.rb +49 -0
  1452. data/lib/pangea/resources/aws_ram_sharing_with_organization/CLAUDE.md +96 -0
  1453. data/lib/pangea/resources/aws_ram_sharing_with_organization/resource.rb +67 -0
  1454. data/lib/pangea/resources/aws_ram_sharing_with_organization/types.rb +48 -0
  1455. data/lib/pangea/resources/aws_rds_cluster/CLAUDE.md +361 -0
  1456. data/lib/pangea/resources/aws_rds_cluster/resource.rb +189 -0
  1457. data/lib/pangea/resources/aws_rds_cluster/types.rb +464 -0
  1458. data/lib/pangea/resources/aws_rds_cluster_endpoint/CLAUDE.md +279 -0
  1459. data/lib/pangea/resources/aws_rds_cluster_endpoint/resource.rb +96 -0
  1460. data/lib/pangea/resources/aws_rds_cluster_endpoint/types.rb +254 -0
  1461. data/lib/pangea/resources/aws_rds_cluster_endpoint/types.rbs +59 -0
  1462. data/lib/pangea/resources/aws_rds_cluster_instance/CLAUDE.md +378 -0
  1463. data/lib/pangea/resources/aws_rds_cluster_instance/resource.rb +143 -0
  1464. data/lib/pangea/resources/aws_rds_cluster_instance/types.rb +437 -0
  1465. data/lib/pangea/resources/aws_rds_cluster_parameter_group/CLAUDE.md +344 -0
  1466. data/lib/pangea/resources/aws_rds_cluster_parameter_group/resource.rb +96 -0
  1467. data/lib/pangea/resources/aws_rds_cluster_parameter_group/types.rb +361 -0
  1468. data/lib/pangea/resources/aws_rds_cluster_parameter_group/types.rbs +65 -0
  1469. data/lib/pangea/resources/aws_rds_global_cluster/CLAUDE.md +362 -0
  1470. data/lib/pangea/resources/aws_rds_global_cluster/resource.rb +123 -0
  1471. data/lib/pangea/resources/aws_rds_global_cluster/types.rb +425 -0
  1472. data/lib/pangea/resources/aws_rds_global_cluster/types.rbs +84 -0
  1473. data/lib/pangea/resources/aws_rds_proxy/resource.rb +113 -0
  1474. data/lib/pangea/resources/aws_rds_proxy/types.rb +410 -0
  1475. data/lib/pangea/resources/aws_rds_proxy_default_target_group/resource.rb +72 -0
  1476. data/lib/pangea/resources/aws_rds_proxy_default_target_group/types.rb +121 -0
  1477. data/lib/pangea/resources/aws_rds_proxy_target/resource.rb +74 -0
  1478. data/lib/pangea/resources/aws_rds_proxy_target/types.rb +106 -0
  1479. data/lib/pangea/resources/aws_redshift_cluster/CLAUDE.md +358 -0
  1480. data/lib/pangea/resources/aws_redshift_cluster/resource.rb +151 -0
  1481. data/lib/pangea/resources/aws_redshift_cluster/types.rb +323 -0
  1482. data/lib/pangea/resources/aws_redshift_cluster/types.rbs +65 -0
  1483. data/lib/pangea/resources/aws_redshift_cluster.rbs +10 -0
  1484. data/lib/pangea/resources/aws_redshift_parameter_group/CLAUDE.md +352 -0
  1485. data/lib/pangea/resources/aws_redshift_parameter_group/resource.rb +87 -0
  1486. data/lib/pangea/resources/aws_redshift_parameter_group/types.rb +214 -0
  1487. data/lib/pangea/resources/aws_redshift_parameter_group/types.rbs +42 -0
  1488. data/lib/pangea/resources/aws_redshift_parameter_group.rbs +10 -0
  1489. data/lib/pangea/resources/aws_redshift_snapshot_schedule/CLAUDE.md +395 -0
  1490. data/lib/pangea/resources/aws_redshift_snapshot_schedule/resource.rb +81 -0
  1491. data/lib/pangea/resources/aws_redshift_snapshot_schedule/types.rb +229 -0
  1492. data/lib/pangea/resources/aws_redshift_snapshot_schedule/types.rbs +41 -0
  1493. data/lib/pangea/resources/aws_redshift_snapshot_schedule.rbs +10 -0
  1494. data/lib/pangea/resources/aws_redshift_subnet_group/CLAUDE.md +274 -0
  1495. data/lib/pangea/resources/aws_redshift_subnet_group/resource.rb +77 -0
  1496. data/lib/pangea/resources/aws_redshift_subnet_group/types.rb +142 -0
  1497. data/lib/pangea/resources/aws_redshift_subnet_group/types.rbs +33 -0
  1498. data/lib/pangea/resources/aws_redshift_subnet_group.rbs +10 -0
  1499. data/lib/pangea/resources/aws_resource_explorer_index/resource.rb +81 -0
  1500. data/lib/pangea/resources/aws_resource_explorer_view/resource.rb +126 -0
  1501. data/lib/pangea/resources/aws_resourcegroups_group/resource.rb +167 -0
  1502. data/lib/pangea/resources/aws_resources.rb +351 -0
  1503. data/lib/pangea/resources/aws_resources_minimal.rb +32 -0
  1504. data/lib/pangea/resources/aws_route/CLAUDE.md +96 -0
  1505. data/lib/pangea/resources/aws_route/resource.rb +83 -0
  1506. data/lib/pangea/resources/aws_route/types.rb +122 -0
  1507. data/lib/pangea/resources/aws_route53_delegation_set/resource.rb +73 -0
  1508. data/lib/pangea/resources/aws_route53_delegation_set/types.rb +133 -0
  1509. data/lib/pangea/resources/aws_route53_delegation_set.rbs +28 -0
  1510. data/lib/pangea/resources/aws_route53_health_check/CLAUDE.md +408 -0
  1511. data/lib/pangea/resources/aws_route53_health_check/resource.rb +132 -0
  1512. data/lib/pangea/resources/aws_route53_health_check/types.rb +387 -0
  1513. data/lib/pangea/resources/aws_route53_query_log/resource.rb +79 -0
  1514. data/lib/pangea/resources/aws_route53_query_log/types.rb +185 -0
  1515. data/lib/pangea/resources/aws_route53_record/CLAUDE.md +414 -0
  1516. data/lib/pangea/resources/aws_route53_record/resource.rb +138 -0
  1517. data/lib/pangea/resources/aws_route53_record/types.rb +408 -0
  1518. data/lib/pangea/resources/aws_route53_zone/CLAUDE.md +363 -0
  1519. data/lib/pangea/resources/aws_route53_zone/resource.rb +99 -0
  1520. data/lib/pangea/resources/aws_route53_zone/types.rb +260 -0
  1521. data/lib/pangea/resources/aws_route_table/CLAUDE.md +224 -0
  1522. data/lib/pangea/resources/aws_route_table/resource.rb +104 -0
  1523. data/lib/pangea/resources/aws_route_table/types.rb +107 -0
  1524. data/lib/pangea/resources/aws_route_table_association/CLAUDE.md +401 -0
  1525. data/lib/pangea/resources/aws_route_table_association/resource.rb +93 -0
  1526. data/lib/pangea/resources/aws_route_table_association/types.rb +94 -0
  1527. data/lib/pangea/resources/aws_s3_access_point/CLAUDE.md +211 -0
  1528. data/lib/pangea/resources/aws_s3_access_point/resource.rb +102 -0
  1529. data/lib/pangea/resources/aws_s3_access_point/types.rb +86 -0
  1530. data/lib/pangea/resources/aws_s3_access_point_policy/resource.rb +69 -0
  1531. data/lib/pangea/resources/aws_s3_access_point_policy/types.rb +65 -0
  1532. data/lib/pangea/resources/aws_s3_bucket/CLAUDE.md +140 -0
  1533. data/lib/pangea/resources/aws_s3_bucket/resource.rb +228 -0
  1534. data/lib/pangea/resources/aws_s3_bucket/types.rb +206 -0
  1535. data/lib/pangea/resources/aws_s3_bucket_accelerate_configuration/resource.rb +70 -0
  1536. data/lib/pangea/resources/aws_s3_bucket_accelerate_configuration/types.rb +65 -0
  1537. data/lib/pangea/resources/aws_s3_bucket_analytics_configuration/resource.rb +108 -0
  1538. data/lib/pangea/resources/aws_s3_bucket_analytics_configuration/types.rb +115 -0
  1539. data/lib/pangea/resources/aws_s3_bucket_cors_configuration/CLAUDE.md +262 -0
  1540. data/lib/pangea/resources/aws_s3_bucket_cors_configuration/resource.rb +97 -0
  1541. data/lib/pangea/resources/aws_s3_bucket_cors_configuration/types.rb +167 -0
  1542. data/lib/pangea/resources/aws_s3_bucket_encryption/CLAUDE.md +465 -0
  1543. data/lib/pangea/resources/aws_s3_bucket_encryption/resource.rb +78 -0
  1544. data/lib/pangea/resources/aws_s3_bucket_encryption/types.rb +114 -0
  1545. data/lib/pangea/resources/aws_s3_bucket_inventory/CLAUDE.md +430 -0
  1546. data/lib/pangea/resources/aws_s3_bucket_inventory/resource.rb +135 -0
  1547. data/lib/pangea/resources/aws_s3_bucket_inventory/types.rb +257 -0
  1548. data/lib/pangea/resources/aws_s3_bucket_lifecycle_configuration/CLAUDE.md +221 -0
  1549. data/lib/pangea/resources/aws_s3_bucket_lifecycle_configuration/resource.rb +158 -0
  1550. data/lib/pangea/resources/aws_s3_bucket_lifecycle_configuration/types.rb +214 -0
  1551. data/lib/pangea/resources/aws_s3_bucket_notification/CLAUDE.md +358 -0
  1552. data/lib/pangea/resources/aws_s3_bucket_notification/resource.rb +122 -0
  1553. data/lib/pangea/resources/aws_s3_bucket_notification/types.rb +224 -0
  1554. data/lib/pangea/resources/aws_s3_bucket_object_lock_configuration/CLAUDE.md +561 -0
  1555. data/lib/pangea/resources/aws_s3_bucket_object_lock_configuration/resource.rb +100 -0
  1556. data/lib/pangea/resources/aws_s3_bucket_object_lock_configuration/types.rb +241 -0
  1557. data/lib/pangea/resources/aws_s3_bucket_policy/CLAUDE.md +234 -0
  1558. data/lib/pangea/resources/aws_s3_bucket_policy/resource.rb +66 -0
  1559. data/lib/pangea/resources/aws_s3_bucket_policy/types.rb +93 -0
  1560. data/lib/pangea/resources/aws_s3_bucket_public_access_block/CLAUDE.md +528 -0
  1561. data/lib/pangea/resources/aws_s3_bucket_public_access_block/resource.rb +77 -0
  1562. data/lib/pangea/resources/aws_s3_bucket_public_access_block/types.rb +92 -0
  1563. data/lib/pangea/resources/aws_s3_bucket_replication_configuration/CLAUDE.md +628 -0
  1564. data/lib/pangea/resources/aws_s3_bucket_replication_configuration/resource.rb +200 -0
  1565. data/lib/pangea/resources/aws_s3_bucket_replication_configuration/types.rb +304 -0
  1566. data/lib/pangea/resources/aws_s3_bucket_versioning/CLAUDE.md +340 -0
  1567. data/lib/pangea/resources/aws_s3_bucket_versioning/resource.rb +72 -0
  1568. data/lib/pangea/resources/aws_s3_bucket_versioning/types.rb +77 -0
  1569. data/lib/pangea/resources/aws_s3_bucket_website_configuration/CLAUDE.md +355 -0
  1570. data/lib/pangea/resources/aws_s3_bucket_website_configuration/resource.rb +123 -0
  1571. data/lib/pangea/resources/aws_s3_bucket_website_configuration/types.rb +397 -0
  1572. data/lib/pangea/resources/aws_s3_multi_region_access_point/resource.rb +105 -0
  1573. data/lib/pangea/resources/aws_s3_multi_region_access_point/types.rb +101 -0
  1574. data/lib/pangea/resources/aws_s3_object/CLAUDE.md +535 -0
  1575. data/lib/pangea/resources/aws_s3_object/resource.rb +131 -0
  1576. data/lib/pangea/resources/aws_s3_object/types.rb +215 -0
  1577. data/lib/pangea/resources/aws_s3_object_lambda_access_point/resource.rb +97 -0
  1578. data/lib/pangea/resources/aws_s3_object_lambda_access_point/types.rb +106 -0
  1579. data/lib/pangea/resources/aws_sagemaker_domain/CLAUDE.md +253 -0
  1580. data/lib/pangea/resources/aws_sagemaker_domain/resource.rb +160 -0
  1581. data/lib/pangea/resources/aws_sagemaker_domain/types.rb +306 -0
  1582. data/lib/pangea/resources/aws_sagemaker_domain.rbs +39 -0
  1583. data/lib/pangea/resources/aws_sagemaker_endpoint/resource.rb +236 -0
  1584. data/lib/pangea/resources/aws_sagemaker_endpoint/types.rb +294 -0
  1585. data/lib/pangea/resources/aws_sagemaker_endpoint_configuration/resource.rb +232 -0
  1586. data/lib/pangea/resources/aws_sagemaker_endpoint_configuration/types.rb +359 -0
  1587. data/lib/pangea/resources/aws_sagemaker_feature_group/resource.rb +64 -0
  1588. data/lib/pangea/resources/aws_sagemaker_feature_group/types.rb +150 -0
  1589. data/lib/pangea/resources/aws_sagemaker_model/resource.rb +189 -0
  1590. data/lib/pangea/resources/aws_sagemaker_model/types.rb +330 -0
  1591. data/lib/pangea/resources/aws_sagemaker_notebook_instance/resource.rb +139 -0
  1592. data/lib/pangea/resources/aws_sagemaker_notebook_instance/types.rb +321 -0
  1593. data/lib/pangea/resources/aws_sagemaker_notebook_instance.rbs +52 -0
  1594. data/lib/pangea/resources/aws_sagemaker_pipeline/resource.rb +61 -0
  1595. data/lib/pangea/resources/aws_sagemaker_pipeline/types.rb +78 -0
  1596. data/lib/pangea/resources/aws_sagemaker_processing_job/resource.rb +61 -0
  1597. data/lib/pangea/resources/aws_sagemaker_processing_job/types.rb +140 -0
  1598. data/lib/pangea/resources/aws_sagemaker_training_job/resource.rb +69 -0
  1599. data/lib/pangea/resources/aws_sagemaker_training_job/types.rb +471 -0
  1600. data/lib/pangea/resources/aws_sagemaker_user_profile/resource.rb +198 -0
  1601. data/lib/pangea/resources/aws_sagemaker_user_profile/types.rb +330 -0
  1602. data/lib/pangea/resources/aws_sagemaker_user_profile.rbs +40 -0
  1603. data/lib/pangea/resources/aws_secretsmanager_secret/CLAUDE.md +528 -0
  1604. data/lib/pangea/resources/aws_secretsmanager_secret/resource.rb +111 -0
  1605. data/lib/pangea/resources/aws_secretsmanager_secret/types.rb +198 -0
  1606. data/lib/pangea/resources/aws_secretsmanager_secret_version/resource.rb +76 -0
  1607. data/lib/pangea/resources/aws_secretsmanager_secret_version/types.rb +99 -0
  1608. data/lib/pangea/resources/aws_security_group/resource.rb +78 -0
  1609. data/lib/pangea/resources/aws_security_group/types.rb +110 -0
  1610. data/lib/pangea/resources/aws_securityhub_account/resource.rb +74 -0
  1611. data/lib/pangea/resources/aws_securityhub_account/types.rb +61 -0
  1612. data/lib/pangea/resources/aws_securityhub_account.rbs +33 -0
  1613. data/lib/pangea/resources/aws_securitylake_data_lake.rbs +29 -0
  1614. data/lib/pangea/resources/aws_ses_configuration_set/resource.rb +70 -0
  1615. data/lib/pangea/resources/aws_ses_configuration_set/types.rb +75 -0
  1616. data/lib/pangea/resources/aws_ses_configuration_set.rbs +35 -0
  1617. data/lib/pangea/resources/aws_ses_domain_identity/resource.rb +57 -0
  1618. data/lib/pangea/resources/aws_ses_domain_identity/types.rb +61 -0
  1619. data/lib/pangea/resources/aws_ses_domain_identity.rbs +24 -0
  1620. data/lib/pangea/resources/aws_ses_email_identity/resource.rb +56 -0
  1621. data/lib/pangea/resources/aws_ses_email_identity/types.rb +73 -0
  1622. data/lib/pangea/resources/aws_ses_email_identity.rbs +24 -0
  1623. data/lib/pangea/resources/aws_sfn_activity/CLAUDE.md +571 -0
  1624. data/lib/pangea/resources/aws_sfn_activity/resource.rb +61 -0
  1625. data/lib/pangea/resources/aws_sfn_activity/types.rb +124 -0
  1626. data/lib/pangea/resources/aws_sfn_state_machine/CLAUDE.md +464 -0
  1627. data/lib/pangea/resources/aws_sfn_state_machine/resource.rb +92 -0
  1628. data/lib/pangea/resources/aws_sfn_state_machine/types.rb +347 -0
  1629. data/lib/pangea/resources/aws_snow_family.rb +401 -0
  1630. data/lib/pangea/resources/aws_sns_subscription/CLAUDE.md +289 -0
  1631. data/lib/pangea/resources/aws_sns_subscription/resource.rb +99 -0
  1632. data/lib/pangea/resources/aws_sns_subscription/types.rb +218 -0
  1633. data/lib/pangea/resources/aws_sns_topic/CLAUDE.md +249 -0
  1634. data/lib/pangea/resources/aws_sns_topic/resource.rb +126 -0
  1635. data/lib/pangea/resources/aws_sns_topic/types.rb +193 -0
  1636. data/lib/pangea/resources/aws_sqs_queue/CLAUDE.md +190 -0
  1637. data/lib/pangea/resources/aws_sqs_queue/resource.rb +114 -0
  1638. data/lib/pangea/resources/aws_sqs_queue/types.rb +169 -0
  1639. data/lib/pangea/resources/aws_sqs_queue_policy/CLAUDE.md +227 -0
  1640. data/lib/pangea/resources/aws_sqs_queue_policy/resource.rb +64 -0
  1641. data/lib/pangea/resources/aws_sqs_queue_policy/types.rb +115 -0
  1642. data/lib/pangea/resources/aws_ssm_document/CLAUDE.md +410 -0
  1643. data/lib/pangea/resources/aws_ssm_document/resource.rb +144 -0
  1644. data/lib/pangea/resources/aws_ssm_document/types.rb +417 -0
  1645. data/lib/pangea/resources/aws_ssm_document/types.rbs +49 -0
  1646. data/lib/pangea/resources/aws_ssm_maintenance_window/CLAUDE.md +412 -0
  1647. data/lib/pangea/resources/aws_ssm_maintenance_window/resource.rb +120 -0
  1648. data/lib/pangea/resources/aws_ssm_maintenance_window/types.rb +374 -0
  1649. data/lib/pangea/resources/aws_ssm_maintenance_window/types.rbs +49 -0
  1650. data/lib/pangea/resources/aws_ssm_parameter/CLAUDE.md +355 -0
  1651. data/lib/pangea/resources/aws_ssm_parameter/resource.rb +116 -0
  1652. data/lib/pangea/resources/aws_ssm_parameter/types.rb +287 -0
  1653. data/lib/pangea/resources/aws_ssm_parameter/types.rbs +47 -0
  1654. data/lib/pangea/resources/aws_ssm_patch_baseline/CLAUDE.md +509 -0
  1655. data/lib/pangea/resources/aws_ssm_patch_baseline/resource.rb +149 -0
  1656. data/lib/pangea/resources/aws_ssm_patch_baseline/types.rb +440 -0
  1657. data/lib/pangea/resources/aws_ssm_patch_baseline/types.rbs +51 -0
  1658. data/lib/pangea/resources/aws_subnet/CLAUDE.md +301 -0
  1659. data/lib/pangea/resources/aws_subnet/resource.rb +78 -0
  1660. data/lib/pangea/resources/aws_subnet/types.rb +67 -0
  1661. data/lib/pangea/resources/aws_sumerian_project/resource.rb +85 -0
  1662. data/lib/pangea/resources/aws_sumerian_project/types.rb +46 -0
  1663. data/lib/pangea/resources/aws_support_app_slack_channel_configuration/resource.rb +114 -0
  1664. data/lib/pangea/resources/aws_support_app_slack_workspace_configuration/resource.rb +73 -0
  1665. data/lib/pangea/resources/aws_timestream_access_policy/CLAUDE.md +96 -0
  1666. data/lib/pangea/resources/aws_timestream_access_policy/resource.rb +69 -0
  1667. data/lib/pangea/resources/aws_timestream_access_policy/types.rb +50 -0
  1668. data/lib/pangea/resources/aws_timestream_batch_load_task/CLAUDE.md +96 -0
  1669. data/lib/pangea/resources/aws_timestream_batch_load_task/resource.rb +77 -0
  1670. data/lib/pangea/resources/aws_timestream_batch_load_task/types.rb +54 -0
  1671. data/lib/pangea/resources/aws_timestream_database/CLAUDE.md +96 -0
  1672. data/lib/pangea/resources/aws_timestream_database/resource.rb +71 -0
  1673. data/lib/pangea/resources/aws_timestream_database/types.rb +49 -0
  1674. data/lib/pangea/resources/aws_timestream_influx_db_instance/CLAUDE.md +96 -0
  1675. data/lib/pangea/resources/aws_timestream_influx_db_instance/resource.rb +85 -0
  1676. data/lib/pangea/resources/aws_timestream_influx_db_instance/types.rb +61 -0
  1677. data/lib/pangea/resources/aws_timestream_scheduled_query/CLAUDE.md +96 -0
  1678. data/lib/pangea/resources/aws_timestream_scheduled_query/resource.rb +77 -0
  1679. data/lib/pangea/resources/aws_timestream_scheduled_query/types.rb +56 -0
  1680. data/lib/pangea/resources/aws_timestream_table/CLAUDE.md +96 -0
  1681. data/lib/pangea/resources/aws_timestream_table/resource.rb +73 -0
  1682. data/lib/pangea/resources/aws_timestream_table/types.rb +52 -0
  1683. data/lib/pangea/resources/aws_timestream_table_retention_properties/CLAUDE.md +96 -0
  1684. data/lib/pangea/resources/aws_timestream_table_retention_properties/resource.rb +70 -0
  1685. data/lib/pangea/resources/aws_timestream_table_retention_properties/types.rb +51 -0
  1686. data/lib/pangea/resources/aws_volume_attachment/CLAUDE.md +326 -0
  1687. data/lib/pangea/resources/aws_volume_attachment/resource.rb +77 -0
  1688. data/lib/pangea/resources/aws_volume_attachment/types.rb +176 -0
  1689. data/lib/pangea/resources/aws_vpc/CLAUDE.md +184 -0
  1690. data/lib/pangea/resources/aws_vpc/resource.rb +80 -0
  1691. data/lib/pangea/resources/aws_vpc/types.rb +94 -0
  1692. data/lib/pangea/resources/aws_vpc_dhcp_options_association/resource.rb +67 -0
  1693. data/lib/pangea/resources/aws_vpc_dhcp_options_association/types.rb +46 -0
  1694. data/lib/pangea/resources/aws_vpc_endpoint/CLAUDE.md +483 -0
  1695. data/lib/pangea/resources/aws_vpc_endpoint/resource.rb +126 -0
  1696. data/lib/pangea/resources/aws_vpc_endpoint/types.rb +132 -0
  1697. data/lib/pangea/resources/aws_vpc_endpoint_connection_accepter/resource.rb +67 -0
  1698. data/lib/pangea/resources/aws_vpc_endpoint_connection_accepter/types.rb +46 -0
  1699. data/lib/pangea/resources/aws_vpc_endpoint_connection_notification/resource.rb +73 -0
  1700. data/lib/pangea/resources/aws_vpc_endpoint_connection_notification/types.rb +50 -0
  1701. data/lib/pangea/resources/aws_vpc_endpoint_route_table_association/resource.rb +67 -0
  1702. data/lib/pangea/resources/aws_vpc_endpoint_route_table_association/types.rb +46 -0
  1703. data/lib/pangea/resources/aws_vpc_endpoint_service/CLAUDE.md +313 -0
  1704. data/lib/pangea/resources/aws_vpc_endpoint_service/resource.rb +127 -0
  1705. data/lib/pangea/resources/aws_vpc_endpoint_service/types.rb +144 -0
  1706. data/lib/pangea/resources/aws_vpc_endpoint_service_allowed_principal/resource.rb +67 -0
  1707. data/lib/pangea/resources/aws_vpc_endpoint_service_allowed_principal/types.rb +46 -0
  1708. data/lib/pangea/resources/aws_vpc_endpoint_subnet_association/resource.rb +67 -0
  1709. data/lib/pangea/resources/aws_vpc_endpoint_subnet_association/types.rb +46 -0
  1710. data/lib/pangea/resources/aws_vpc_network_performance_metric_subscription/resource.rb +67 -0
  1711. data/lib/pangea/resources/aws_vpc_network_performance_metric_subscription/types.rb +46 -0
  1712. data/lib/pangea/resources/aws_vpc_peering_connection/CLAUDE.md +361 -0
  1713. data/lib/pangea/resources/aws_vpc_peering_connection/resource.rb +118 -0
  1714. data/lib/pangea/resources/aws_vpc_peering_connection/types.rb +115 -0
  1715. data/lib/pangea/resources/aws_vpc_peering_connection_accepter/CLAUDE.md +248 -0
  1716. data/lib/pangea/resources/aws_vpc_peering_connection_accepter/resource.rb +67 -0
  1717. data/lib/pangea/resources/aws_vpc_peering_connection_accepter/types.rb +46 -0
  1718. data/lib/pangea/resources/aws_vpc_peering_connection_options/resource.rb +67 -0
  1719. data/lib/pangea/resources/aws_vpc_peering_connection_options/types.rb +46 -0
  1720. data/lib/pangea/resources/aws_vpc_security_group_egress_rule/resource.rb +67 -0
  1721. data/lib/pangea/resources/aws_vpc_security_group_egress_rule/types.rb +46 -0
  1722. data/lib/pangea/resources/aws_vpc_security_group_ingress_rule/resource.rb +67 -0
  1723. data/lib/pangea/resources/aws_vpc_security_group_ingress_rule/types.rb +46 -0
  1724. data/lib/pangea/resources/aws_vpn_connection/CLAUDE.md +420 -0
  1725. data/lib/pangea/resources/aws_vpn_connection/resource.rb +119 -0
  1726. data/lib/pangea/resources/aws_vpn_connection/types.rb +127 -0
  1727. data/lib/pangea/resources/aws_vpn_gateway/CLAUDE.md +411 -0
  1728. data/lib/pangea/resources/aws_vpn_gateway/resource.rb +92 -0
  1729. data/lib/pangea/resources/aws_vpn_gateway/types.rb +87 -0
  1730. data/lib/pangea/resources/aws_wafv2_ip_set/resource.rb +83 -0
  1731. data/lib/pangea/resources/aws_wafv2_ip_set/types.rb +141 -0
  1732. data/lib/pangea/resources/aws_wafv2_ip_set.rbs +36 -0
  1733. data/lib/pangea/resources/aws_wafv2_regex_pattern_set/resource.rb +89 -0
  1734. data/lib/pangea/resources/aws_wafv2_regex_pattern_set/types.rb +274 -0
  1735. data/lib/pangea/resources/aws_wafv2_rule_group/resource.rb +427 -0
  1736. data/lib/pangea/resources/aws_wafv2_rule_group/types.rb +270 -0
  1737. data/lib/pangea/resources/aws_wafv2_rule_group.rbs +44 -0
  1738. data/lib/pangea/resources/aws_wafv2_web_acl/CLAUDE.md +788 -0
  1739. data/lib/pangea/resources/aws_wafv2_web_acl/resource.rb +499 -0
  1740. data/lib/pangea/resources/aws_wafv2_web_acl/types.rb +544 -0
  1741. data/lib/pangea/resources/aws_wafv2_web_acl.rbs +309 -0
  1742. data/lib/pangea/resources/aws_wavelength.rb +323 -0
  1743. data/lib/pangea/resources/aws_workspaces_bundle/CLAUDE.md +412 -0
  1744. data/lib/pangea/resources/aws_workspaces_bundle/resource.rb +100 -0
  1745. data/lib/pangea/resources/aws_workspaces_bundle/types.rb +217 -0
  1746. data/lib/pangea/resources/aws_workspaces_directory/CLAUDE.md +365 -0
  1747. data/lib/pangea/resources/aws_workspaces_directory/resource.rb +133 -0
  1748. data/lib/pangea/resources/aws_workspaces_directory/types.rb +237 -0
  1749. data/lib/pangea/resources/aws_workspaces_ip_group/CLAUDE.md +421 -0
  1750. data/lib/pangea/resources/aws_workspaces_ip_group/resource.rb +93 -0
  1751. data/lib/pangea/resources/aws_workspaces_ip_group/types.rb +149 -0
  1752. data/lib/pangea/resources/aws_workspaces_workspace/CLAUDE.md +322 -0
  1753. data/lib/pangea/resources/aws_workspaces_workspace/resource.rb +108 -0
  1754. data/lib/pangea/resources/aws_workspaces_workspace/types.rb +184 -0
  1755. data/lib/pangea/resources/aws_xray_encryption_config/resource.rb +80 -0
  1756. data/lib/pangea/resources/aws_xray_group/resource.rb +113 -0
  1757. data/lib/pangea/resources/aws_xray_sampling_rule/resource.rb +146 -0
  1758. data/lib/pangea/resources/base.rb +81 -0
  1759. data/lib/pangea/resources/composition.rb +534 -0
  1760. data/lib/pangea/resources/edge_computing_guide.md +613 -0
  1761. data/lib/pangea/resources/event_driven_example.rb +288 -0
  1762. data/lib/pangea/resources/helpers.rb +54 -0
  1763. data/lib/pangea/resources/reference.rb +280 -0
  1764. data/lib/pangea/resources/templates/resource_template.rb.erb +56 -0
  1765. data/lib/pangea/resources/types.rb +1231 -0
  1766. data/lib/pangea/resources.rb +32 -0
  1767. data/lib/pangea/types/aws_types.rb +65 -0
  1768. data/lib/pangea/types/base_types.rb +51 -0
  1769. data/lib/pangea/types/computed_types.rb +23 -0
  1770. data/lib/pangea/types/registry.rb +68 -0
  1771. data/lib/pangea/types.rb +164 -0
  1772. data/lib/pangea/ui.rb +44 -0
  1773. data/lib/pangea/utilities/analysis/README.md +11 -0
  1774. data/lib/pangea/utilities/cli/README.md +11 -0
  1775. data/lib/pangea/utilities/cli/command.rb +98 -0
  1776. data/lib/pangea/utilities/cli/commands/cost_command.rb +117 -0
  1777. data/lib/pangea/utilities/cli/commands/drift_command.rb +127 -0
  1778. data/lib/pangea/utilities/cli/commands/state_command.rb +119 -0
  1779. data/lib/pangea/utilities/cost/README.md +12 -0
  1780. data/lib/pangea/utilities/cost/calculator.rb +174 -0
  1781. data/lib/pangea/utilities/cost/resource_pricing.rb +102 -0
  1782. data/lib/pangea/utilities/cost.rb +29 -0
  1783. data/lib/pangea/utilities/drift/README.md +12 -0
  1784. data/lib/pangea/utilities/drift/detector.rb +122 -0
  1785. data/lib/pangea/utilities/drift/report.rb +100 -0
  1786. data/lib/pangea/utilities/drift.rb +29 -0
  1787. data/lib/pangea/utilities/migration/README.md +11 -0
  1788. data/lib/pangea/utilities/monitoring/README.md +11 -0
  1789. data/lib/pangea/utilities/remote_state/README.md +12 -0
  1790. data/lib/pangea/utilities/remote_state/dependency_manager.rb +99 -0
  1791. data/lib/pangea/utilities/remote_state/dsl_extensions.rb +109 -0
  1792. data/lib/pangea/utilities/remote_state/output_registry.rb +119 -0
  1793. data/lib/pangea/utilities/remote_state/reference.rb +77 -0
  1794. data/lib/pangea/utilities/remote_state.rb +28 -0
  1795. data/lib/pangea/utilities/validation/README.md +11 -0
  1796. data/lib/pangea/utilities/visualization/README.md +12 -0
  1797. data/lib/pangea/utilities/visualization/graph.rb +112 -0
  1798. data/lib/pangea/utilities/visualization/mermaid_exporter.rb +149 -0
  1799. data/lib/pangea/utilities/visualization.rb +28 -0
  1800. data/lib/pangea/utilities.rb +39 -0
  1801. data/lib/pangea/validation.rb +100 -0
  1802. data/lib/pangea/version.rb +15 -1
  1803. data/lib/pangea.rb +37 -5
  1804. data/pangea.gemspec +40 -34
  1805. data/pangea.rb +14 -0
  1806. data/pangea.yaml.example +87 -0
  1807. data/pangea.yml.example +76 -0
  1808. data/pangea_test.yml +19 -0
  1809. data/rbs_collection.yaml +37 -0
  1810. data/release.sh +32 -0
  1811. data/scripts/add_copyright_headers.rb +65 -0
  1812. data/scripts/analyze_resource_structure.rb +127 -0
  1813. data/scripts/audit_vpc_resources.rb +36 -0
  1814. data/scripts/discover_resources.rb +53 -0
  1815. data/scripts/find_untested_resources.rb +115 -0
  1816. data/scripts/generate_vpc_tests.rb +21 -0
  1817. data/scripts/prioritize_resources.rb +72 -0
  1818. data/scripts/synthesis_coverage_report.json +3723 -0
  1819. data/scripts/synthesis_coverage_report.rb +284 -0
  1820. data/scripts/synthesis_coverage_summary.rb +233 -0
  1821. data/scripts/synthesis_enhancement_tasks.json +74 -0
  1822. data/scripts/verify_implementation.rb +146 -0
  1823. data/scripts/verify_utilities.rb +185 -0
  1824. data/shell.nix +13 -0
  1825. data/sig/pangea/architectures.rbs +260 -0
  1826. data/sig/pangea/entities/namespace.rbs +37 -0
  1827. data/sig/pangea/resources/aws.rbs +254 -0
  1828. data/sig/pangea/resources/aws_acm_certificate.rbs +23 -0
  1829. data/sig/pangea/resources/aws_acm_certificate_validation.rbs +20 -0
  1830. data/sig/pangea/resources/aws_api_gateway_deployment.rbs +49 -0
  1831. data/sig/pangea/resources/aws_api_gateway_method.rbs +51 -0
  1832. data/sig/pangea/resources/aws_api_gateway_resource.rbs +33 -0
  1833. data/sig/pangea/resources/aws_api_gateway_rest_api.rbs +60 -0
  1834. data/sig/pangea/resources/aws_api_gateway_stage.rbs +89 -0
  1835. data/sig/pangea/resources/aws_appstream_fleet.rbs +58 -0
  1836. data/sig/pangea/resources/aws_batch_compute_environment.rbs +54 -0
  1837. data/sig/pangea/resources/aws_batch_job_definition.rbs +69 -0
  1838. data/sig/pangea/resources/aws_batch_job_queue.rbs +65 -0
  1839. data/sig/pangea/resources/aws_braket_device.rbs +114 -0
  1840. data/sig/pangea/resources/aws_braket_quantum_task.rbs +32 -0
  1841. data/sig/pangea/resources/aws_budgets_budget.rbs +130 -0
  1842. data/sig/pangea/resources/aws_budgets_budget_action.rbs +95 -0
  1843. data/sig/pangea/resources/aws_cloudfront_cache_policy.rbs +18 -0
  1844. data/sig/pangea/resources/aws_cloudfront_distribution.rbs +124 -0
  1845. data/sig/pangea/resources/aws_cloudfront_origin_access_control.rbs +27 -0
  1846. data/sig/pangea/resources/aws_cloudfront_origin_request_policy.rbs +17 -0
  1847. data/sig/pangea/resources/aws_cloudwatch_composite_alarm.rbs +34 -0
  1848. data/sig/pangea/resources/aws_cloudwatch_dashboard.rbs +69 -0
  1849. data/sig/pangea/resources/aws_cloudwatch_event_rule.rbs +34 -0
  1850. data/sig/pangea/resources/aws_cloudwatch_event_target.rbs +80 -0
  1851. data/sig/pangea/resources/aws_cloudwatch_log_destination.rbs +26 -0
  1852. data/sig/pangea/resources/aws_cloudwatch_log_destination_policy.rbs +27 -0
  1853. data/sig/pangea/resources/aws_cloudwatch_log_group.rbs +28 -0
  1854. data/sig/pangea/resources/aws_cloudwatch_log_metric_filter.rbs +43 -0
  1855. data/sig/pangea/resources/aws_cloudwatch_log_stream.rbs +25 -0
  1856. data/sig/pangea/resources/aws_cloudwatch_log_subscription_filter.rbs +28 -0
  1857. data/sig/pangea/resources/aws_codeartifact_domain.rbs +29 -0
  1858. data/sig/pangea/resources/aws_codeartifact_repository.rbs +46 -0
  1859. data/sig/pangea/resources/aws_codestar_connection.rbs +36 -0
  1860. data/sig/pangea/resources/aws_cognito_identity_pool.rbs +56 -0
  1861. data/sig/pangea/resources/aws_cognito_identity_provider.rbs +46 -0
  1862. data/sig/pangea/resources/aws_cognito_user.rbs +36 -0
  1863. data/sig/pangea/resources/aws_cognito_user_group.rbs +34 -0
  1864. data/sig/pangea/resources/aws_cognito_user_pool.rbs +176 -0
  1865. data/sig/pangea/resources/aws_cognito_user_pool_client.rbs +75 -0
  1866. data/sig/pangea/resources/aws_cognito_user_pool_domain.rbs +46 -0
  1867. data/sig/pangea/resources/aws_datasync_on_snow_location.rbs +12 -0
  1868. data/sig/pangea/resources/aws_datasync_on_snow_task.rbs +12 -0
  1869. data/sig/pangea/resources/aws_datasync_snow_ball_edge.rbs +12 -0
  1870. data/sig/pangea/resources/aws_db_parameter_group.rbs +81 -0
  1871. data/sig/pangea/resources/aws_db_subnet_group.rbs +42 -0
  1872. data/sig/pangea/resources/aws_ec2_carrier_gateway.rbs +12 -0
  1873. data/sig/pangea/resources/aws_ec2_local_gateway.rbs +12 -0
  1874. data/sig/pangea/resources/aws_ec2_local_gateway_route.rbs +12 -0
  1875. data/sig/pangea/resources/aws_ec2_local_gateway_route_table.rbs +12 -0
  1876. data/sig/pangea/resources/aws_ec2_local_gateway_route_table_vpc_association.rbs +12 -0
  1877. data/sig/pangea/resources/aws_ec2_local_gateway_virtual_interface_group_association.rbs +12 -0
  1878. data/sig/pangea/resources/aws_ecr_lifecycle_policy.rbs +28 -0
  1879. data/sig/pangea/resources/aws_ecr_replication_configuration.rbs +42 -0
  1880. data/sig/pangea/resources/aws_ecr_repository.rbs +36 -0
  1881. data/sig/pangea/resources/aws_ecr_repository_policy.rbs +27 -0
  1882. data/sig/pangea/resources/aws_ecs_cluster.rbs +86 -0
  1883. data/sig/pangea/resources/aws_ecs_cluster_capacity_providers.rbs +59 -0
  1884. data/sig/pangea/resources/aws_ecs_service.rbs +238 -0
  1885. data/sig/pangea/resources/aws_ecs_task_definition.rbs +334 -0
  1886. data/sig/pangea/resources/aws_efs_access_point.rbs +33 -0
  1887. data/sig/pangea/resources/aws_efs_file_system.rbs +34 -0
  1888. data/sig/pangea/resources/aws_efs_mount_target.rbs +29 -0
  1889. data/sig/pangea/resources/aws_eks_addon.rbs +50 -0
  1890. data/sig/pangea/resources/aws_eks_cluster.rbs +79 -0
  1891. data/sig/pangea/resources/aws_eks_fargate_profile.rbs +43 -0
  1892. data/sig/pangea/resources/aws_eks_node_group.rbs +106 -0
  1893. data/sig/pangea/resources/aws_elasticache_cluster.rbs +39 -0
  1894. data/sig/pangea/resources/aws_elasticache_parameter_group.rbs +18 -0
  1895. data/sig/pangea/resources/aws_elasticache_subnet_group.rbs +17 -0
  1896. data/sig/pangea/resources/aws_elemental_data_plane_channel.rbs +18 -0
  1897. data/sig/pangea/resources/aws_emrcontainers_virtual_cluster.rbs +39 -0
  1898. data/sig/pangea/resources/aws_frauddetector_detector.rbs +76 -0
  1899. data/sig/pangea/resources/aws_groundstation_antenna_downlink_config.rbs +12 -0
  1900. data/sig/pangea/resources/aws_groundstation_antenna_uplink_config.rbs +12 -0
  1901. data/sig/pangea/resources/aws_groundstation_config.rbs +12 -0
  1902. data/sig/pangea/resources/aws_groundstation_contact.rbs +12 -0
  1903. data/sig/pangea/resources/aws_groundstation_dataflow_endpoint_group.rbs +12 -0
  1904. data/sig/pangea/resources/aws_groundstation_mission_profile.rbs +12 -0
  1905. data/sig/pangea/resources/aws_groundstation_tracking_config.rbs +12 -0
  1906. data/sig/pangea/resources/aws_healthlake_fhir_datastore.rbs +80 -0
  1907. data/sig/pangea/resources/aws_iam_group.rbs +71 -0
  1908. data/sig/pangea/resources/aws_iam_policy.rbs +62 -0
  1909. data/sig/pangea/resources/aws_iam_role_policy_attachment.rbs +88 -0
  1910. data/sig/pangea/resources/aws_iam_user.rbs +56 -0
  1911. data/sig/pangea/resources/aws_kms_alias.rbs +16 -0
  1912. data/sig/pangea/resources/aws_kms_key.rbs +23 -0
  1913. data/sig/pangea/resources/aws_lambda_event_source_mapping.rbs +116 -0
  1914. data/sig/pangea/resources/aws_lambda_function.rbs +137 -0
  1915. data/sig/pangea/resources/aws_lambda_layer_version.rbs +48 -0
  1916. data/sig/pangea/resources/aws_lambda_permission.rbs +44 -0
  1917. data/sig/pangea/resources/aws_lightsail_bucket.rbs +12 -0
  1918. data/sig/pangea/resources/aws_lightsail_certificate.rbs +12 -0
  1919. data/sig/pangea/resources/aws_lightsail_database.rbs +12 -0
  1920. data/sig/pangea/resources/aws_lightsail_disk.rbs +12 -0
  1921. data/sig/pangea/resources/aws_lightsail_disk_attachment.rbs +12 -0
  1922. data/sig/pangea/resources/aws_lightsail_domain.rbs +12 -0
  1923. data/sig/pangea/resources/aws_lightsail_instance.rbs +12 -0
  1924. data/sig/pangea/resources/aws_lightsail_key_pair.rbs +12 -0
  1925. data/sig/pangea/resources/aws_lightsail_load_balancer.rbs +12 -0
  1926. data/sig/pangea/resources/aws_lightsail_load_balancer_attachment.rbs +12 -0
  1927. data/sig/pangea/resources/aws_lightsail_static_ip.rbs +12 -0
  1928. data/sig/pangea/resources/aws_lightsail_static_ip_attachment.rbs +12 -0
  1929. data/sig/pangea/resources/aws_lookoutequipment_dataset.rbs +73 -0
  1930. data/sig/pangea/resources/aws_managedblockchain_member.rbs +73 -0
  1931. data/sig/pangea/resources/aws_managedblockchain_network.rbs +102 -0
  1932. data/sig/pangea/resources/aws_managedblockchain_node.rbs +71 -0
  1933. data/sig/pangea/resources/aws_media_convert_queue.rbs +20 -0
  1934. data/sig/pangea/resources/aws_media_live_channel.rbs +67 -0
  1935. data/sig/pangea/resources/aws_media_live_input.rbs +68 -0
  1936. data/sig/pangea/resources/aws_media_package_channel.rbs +35 -0
  1937. data/sig/pangea/resources/aws_media_package_origin_endpoint.rbs +29 -0
  1938. data/sig/pangea/resources/aws_media_store_container.rbs +13 -0
  1939. data/sig/pangea/resources/aws_outposts_asset.rbs +12 -0
  1940. data/sig/pangea/resources/aws_outposts_capacity_task.rbs +12 -0
  1941. data/sig/pangea/resources/aws_outposts_connection.rbs +12 -0
  1942. data/sig/pangea/resources/aws_outposts_order.rbs +12 -0
  1943. data/sig/pangea/resources/aws_outposts_outpost.rbs +12 -0
  1944. data/sig/pangea/resources/aws_outposts_outpost_instance_type.rbs +12 -0
  1945. data/sig/pangea/resources/aws_outposts_site.rbs +12 -0
  1946. data/sig/pangea/resources/aws_outposts_supported_hardware_type.rbs +12 -0
  1947. data/sig/pangea/resources/aws_qldb_ledger.rbs +37 -0
  1948. data/sig/pangea/resources/aws_qldb_stream.rbs +53 -0
  1949. data/sig/pangea/resources/aws_rds_cluster.rbs +193 -0
  1950. data/sig/pangea/resources/aws_rds_cluster_instance.rbs +128 -0
  1951. data/sig/pangea/resources/aws_route53_health_check.rbs +34 -0
  1952. data/sig/pangea/resources/aws_route53_record.rbs +63 -0
  1953. data/sig/pangea/resources/aws_route53_zone.rbs +26 -0
  1954. data/sig/pangea/resources/aws_s3_bucket_cors_configuration.rbs +42 -0
  1955. data/sig/pangea/resources/aws_s3_bucket_inventory.rbs +78 -0
  1956. data/sig/pangea/resources/aws_s3_bucket_lifecycle_configuration.rbs +94 -0
  1957. data/sig/pangea/resources/aws_s3_bucket_notification.rbs +65 -0
  1958. data/sig/pangea/resources/aws_s3_bucket_object_lock_configuration.rbs +51 -0
  1959. data/sig/pangea/resources/aws_s3_bucket_replication_configuration.rbs +107 -0
  1960. data/sig/pangea/resources/aws_s3_bucket_website_configuration.rbs +74 -0
  1961. data/sig/pangea/resources/aws_sagemaker_feature_group.rbs +58 -0
  1962. data/sig/pangea/resources/aws_secretsmanager_secret.rbs +29 -0
  1963. data/sig/pangea/resources/aws_secretsmanager_secret_version.rbs +21 -0
  1964. data/sig/pangea/resources/aws_sfn_activity.rbs +36 -0
  1965. data/sig/pangea/resources/aws_sfn_state_machine.rbs +54 -0
  1966. data/sig/pangea/resources/aws_snowball_cluster.rbs +12 -0
  1967. data/sig/pangea/resources/aws_snowball_job.rbs +12 -0
  1968. data/sig/pangea/resources/aws_snowcone_device.rbs +12 -0
  1969. data/sig/pangea/resources/aws_snowcone_job.rbs +12 -0
  1970. data/sig/pangea/resources/aws_snowmobile_job.rbs +12 -0
  1971. data/sig/pangea/resources/aws_sns_subscription.rbs +49 -0
  1972. data/sig/pangea/resources/aws_sns_topic.rbs +78 -0
  1973. data/sig/pangea/resources/aws_sqs_queue.rbs +67 -0
  1974. data/sig/pangea/resources/aws_sqs_queue_policy.rbs +29 -0
  1975. data/sig/pangea/resources/aws_wavelength_application_deployment.rbs +12 -0
  1976. data/sig/pangea/resources/aws_wavelength_deployment.rbs +12 -0
  1977. data/sig/pangea/resources/aws_wavelength_edge_location_mapping.rbs +12 -0
  1978. data/sig/pangea/resources/aws_wavelength_network_interface.rbs +12 -0
  1979. data/sig/pangea/resources/aws_wavelength_workload.rbs +12 -0
  1980. data/sig/pangea/resources/aws_workspaces_bundle.rbs +50 -0
  1981. data/sig/pangea/resources/aws_workspaces_directory.rbs +63 -0
  1982. data/sig/pangea/resources/aws_workspaces_ip_group.rbs +41 -0
  1983. data/sig/pangea/resources/aws_workspaces_workspace.rbs +40 -0
  1984. data/sig/pangea/structures/namespace.rbs +28 -0
  1985. data/sig/pangea/structures/project.rbs +20 -0
  1986. data/sig/pangea/types.rbs +76 -0
  1987. data/sig/pangea.rbs +13 -0
  1988. data/test_infrastructure/infrastructure.rb +510 -0
  1989. data/test_infrastructure/main.tf.json +15 -0
  1990. data/test_infrastructure/multi_template_infrastructure.rb +125 -0
  1991. data/test_infrastructure/pangea.yml +35 -0
  1992. data/test_infrastructure/simple_infrastructure.rb +82 -0
  1993. data/test_infrastructure/test_multi_workspaces.rb +90 -0
  1994. data/test_infrastructure/test_template_workspaces.rb +62 -0
  1995. data/test_infrastructure/workspace_compute.tf.json +46 -0
  1996. data/test_infrastructure/workspace_local_resources.tf.json +41 -0
  1997. data/test_infrastructure/workspace_networking.tf.json +32 -0
  1998. data/test_infrastructure/workspace_storage.tf.json +34 -0
  1999. data/tools/README.md +245 -0
  2000. data/tools/analyze_terraform_docs.rb +367 -0
  2001. data/tools/batch_generate_resources.rb +304 -0
  2002. data/tools/complete_resource_data.rb +492 -0
  2003. data/tools/database_batch.yaml +62 -0
  2004. data/tools/database_resource_data.rb +454 -0
  2005. data/tools/enhance_database_batch.rb +69 -0
  2006. data/tools/enhance_remaining_batch.rb +61 -0
  2007. data/tools/generate_resource.rb +530 -0
  2008. data/tools/priority_resources.yaml +95 -0
  2009. data/tools/resource_enhancer.rb +531 -0
  2010. data/tools/simple_validation.rb +231 -0
  2011. data/tools/update_aws_loader.rb +150 -0
  2012. data/tools/validate_database_resources.rb +444 -0
  2013. metadata +2302 -122
  2014. data/example/config/README.md +0 -3
  2015. data/example/config/sample.rb +0 -20
  2016. data/lib/pangea/cli/config.rb +0 -99
  2017. data/lib/pangea/cli/constants.rb +0 -36
  2018. data/lib/pangea/cli/subcommands/config.rb +0 -218
  2019. data/lib/pangea/cli/subcommands/infra.rb +0 -284
  2020. data/lib/pangea/cli/subcommands/main.rb +0 -59
  2021. data/lib/pangea/cli/subcommands/pangea.rb +0 -18
  2022. data/lib/pangea/cli.rb +0 -1
  2023. data/lib/pangea/docker.rb +0 -104
  2024. data/lib/pangea/errors/incorrect_subcommand_error.rb +0 -2
  2025. data/lib/pangea/errors/namespace_not_found_error.rb +0 -2
  2026. data/lib/pangea/errors/no_infra_target_error.rb +0 -2
  2027. data/lib/pangea/errors/project_not_found_error.rb +0 -2
  2028. data/lib/pangea/errors/site_not_found_error.rb +0 -2
  2029. data/lib/pangea/log/init.rb +0 -2
  2030. data/lib/pangea/modules.rb +0 -134
  2031. data/lib/pangea/sandbox.rb +0 -90
  2032. data/lib/pangea/say/init.rb +0 -27
  2033. data/lib/pangea/shell/README.md +0 -1
  2034. data/lib/pangea/shell/terraform.rb +0 -21
  2035. data/lib/pangea/structures/README.md +0 -3
  2036. data/lib/pangea/structures/abstract.rb +0 -2
  2037. data/lib/pangea/structures/namespace.rb +0 -4
  2038. data/lib/pangea/structures/project.rb +0 -4
  2039. data/lib/pangea/structures/site.rb +0 -4
  2040. data/lib/pangea/synthesizer/config.rb +0 -39
@@ -0,0 +1,2877 @@
1
+ # frozen_string_literal: true
2
+ # Copyright 2025 The Pangea Authors
3
+ #
4
+ # Licensed under the Apache License, Version 2.0 (the "License");
5
+ # you may not use this file except in compliance with the License.
6
+ # You may obtain a copy of the License at
7
+ #
8
+ # http://www.apache.org/licenses/LICENSE-2.0
9
+ #
10
+ # Unless required by applicable law or agreed to in writing, software
11
+ # distributed under the License is distributed on an "AS IS" BASIS,
12
+ # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13
+ # See the License for the specific language governing permissions and
14
+ # limitations under the License.
15
+
16
+
17
+ require 'pangea/components/base'
18
+ require 'pangea/components/siem_security_platform/types'
19
+
20
+ module Pangea
21
+ module Components
22
+ module SiemSecurityPlatform
23
+ # SIEM Security Platform Component
24
+ # Implements comprehensive security information and event management
25
+ def siem_security_platform(name, attributes = {})
26
+ # Validate attributes
27
+ attrs = Attributes.new(attributes)
28
+
29
+ # Component resources
30
+ resources = {
31
+ opensearch_domain: nil,
32
+ firehose_streams: {},
33
+ lambda_functions: {},
34
+ cloudwatch_logs: {},
35
+ s3_buckets: {},
36
+ sns_topics: {},
37
+ sqs_queues: {},
38
+ event_rules: {},
39
+ step_functions: {},
40
+ iam_roles: {},
41
+ security_groups: {},
42
+ kms_keys: {},
43
+ secrets: {},
44
+ alarms: {}
45
+ }
46
+
47
+ # Create KMS key for encryption
48
+ kms_key_name = component_resource_name(name, :kms_key)
49
+ resources[:kms_keys][:main] = aws_kms_key(kms_key_name, {
50
+ description: "SIEM encryption key for #{name}",
51
+ key_policy: generate_kms_policy(name),
52
+ tags: component_tags('siem_security_platform', name, attrs.tags)
53
+ })
54
+
55
+ aws_kms_alias(:"#{kms_key_name}_alias", {
56
+ name: "alias/siem-#{name}",
57
+ target_key_id: resources[:kms_keys][:main].id
58
+ })
59
+
60
+ # Create security group for OpenSearch
61
+ sg_name = component_resource_name(name, :opensearch_sg)
62
+ resources[:security_groups][:opensearch] = aws_security_group(sg_name, {
63
+ name: "siem-opensearch-#{name}",
64
+ description: "Security group for SIEM OpenSearch domain",
65
+ vpc_id: attrs.vpc_ref,
66
+ tags: component_tags('siem_security_platform', name, attrs.tags)
67
+ })
68
+
69
+ # Allow HTTPS access
70
+ aws_vpc_security_group_ingress_rule(:"#{sg_name}_https", {
71
+ security_group_id: resources[:security_groups][:opensearch].id,
72
+ description: "Allow HTTPS for OpenSearch",
73
+ from_port: 443,
74
+ to_port: 443,
75
+ ip_protocol: 'tcp',
76
+ cidr_ipv4: '10.0.0.0/8'
77
+ })
78
+
79
+ # Create OpenSearch domain
80
+ domain_name = attrs.opensearch_config[:domain_name]
81
+ resources[:opensearch_domain] = aws_opensearch_domain(:"#{name}_opensearch", {
82
+ domain_name: domain_name,
83
+ engine_version: attrs.opensearch_config[:engine_version],
84
+
85
+ cluster_config: {
86
+ instance_type: attrs.opensearch_config[:instance_type],
87
+ instance_count: attrs.opensearch_config[:instance_count],
88
+ dedicated_master_enabled: attrs.opensearch_config[:dedicated_master_enabled],
89
+ dedicated_master_type: attrs.opensearch_config[:dedicated_master_type],
90
+ dedicated_master_count: attrs.opensearch_config[:dedicated_master_count],
91
+ zone_awareness_enabled: attrs.opensearch_config[:zone_awareness_enabled],
92
+ zone_awareness_config: attrs.opensearch_config[:zone_awareness_enabled] ? {
93
+ availability_zone_count: attrs.opensearch_config[:availability_zone_count]
94
+ } : nil
95
+ },
96
+
97
+ ebs_options: {
98
+ ebs_enabled: attrs.opensearch_config[:ebs_enabled],
99
+ volume_type: attrs.opensearch_config[:volume_type],
100
+ volume_size: attrs.opensearch_config[:volume_size],
101
+ iops: attrs.opensearch_config[:iops],
102
+ throughput: attrs.opensearch_config[:throughput]
103
+ },
104
+
105
+ vpc_options: {
106
+ subnet_ids: attrs.subnet_refs.take(attrs.opensearch_config[:availability_zone_count] || 3),
107
+ security_group_ids: [resources[:security_groups][:opensearch].id]
108
+ },
109
+
110
+ encrypt_at_rest: attrs.security_config[:enable_encryption_at_rest] ? {
111
+ enabled: true,
112
+ kms_key_id: resources[:kms_keys][:main].id
113
+ } : nil,
114
+
115
+ node_to_node_encryption: {
116
+ enabled: attrs.security_config[:enable_encryption_in_transit]
117
+ },
118
+
119
+ advanced_security_options: attrs.security_config[:enable_fine_grained_access] ? {
120
+ enabled: true,
121
+ internal_user_database_enabled: false,
122
+ master_user_options: {
123
+ master_user_arn: attrs.security_config[:master_user_arn]
124
+ }
125
+ } : nil,
126
+
127
+ log_publishing_options: {
128
+ ES_APPLICATION_LOGS: {
129
+ enabled: true,
130
+ cloudwatch_log_group_arn: create_log_group(name, 'es-application', attrs, resources)
131
+ },
132
+ SEARCH_SLOW_LOGS: attrs.security_config[:enable_slow_logs] ? {
133
+ enabled: true,
134
+ cloudwatch_log_group_arn: create_log_group(name, 'es-slow', attrs, resources)
135
+ } : nil,
136
+ AUDIT_LOGS: attrs.security_config[:enable_audit_logs] ? {
137
+ enabled: true,
138
+ cloudwatch_log_group_arn: create_log_group(name, 'es-audit', attrs, resources)
139
+ } : nil
140
+ },
141
+
142
+ tags: component_tags('siem_security_platform', name, attrs.tags)
143
+ })
144
+
145
+ # Create S3 bucket for Firehose backup
146
+ backup_bucket_name = component_resource_name(name, :backup_bucket)
147
+ resources[:s3_buckets][:backup] = create_secure_bucket(
148
+ backup_bucket_name,
149
+ "siem-backup-#{name}",
150
+ attrs,
151
+ resources
152
+ )
153
+
154
+ # Create Firehose delivery streams for each log source
155
+ attrs.log_sources.each do |source|
156
+ create_firehose_stream(name, source, attrs, resources)
157
+ end
158
+
159
+ # Create Lambda functions for data processing
160
+ create_processing_lambdas(name, attrs, resources)
161
+
162
+ # Create correlation engine
163
+ create_correlation_engine(name, attrs, resources)
164
+
165
+ # Create threat detection components
166
+ create_threat_detection(name, attrs, resources)
167
+
168
+ # Create incident response automation
169
+ create_incident_response(name, attrs, resources)
170
+
171
+ # Create monitoring and alerting
172
+ create_monitoring(name, attrs, resources)
173
+
174
+ # Create dashboards
175
+ create_dashboards(name, attrs, resources)
176
+
177
+ # Set up integrations
178
+ attrs.integrations.each do |integration|
179
+ create_integration(name, integration, attrs, resources)
180
+ end
181
+
182
+ # Component outputs
183
+ outputs = {
184
+ opensearch_domain_endpoint: resources[:opensearch_domain].endpoint,
185
+ opensearch_domain_arn: resources[:opensearch_domain].arn,
186
+ opensearch_dashboard_url: "https://#{resources[:opensearch_domain].endpoint}/_dashboards/",
187
+ firehose_streams: resources[:firehose_streams].transform_values { |stream| stream.arn },
188
+ correlation_engine_arn: resources[:step_functions][:correlation_engine]&.arn,
189
+ incident_response_arn: resources[:step_functions][:incident_response]&.arn,
190
+ security_score: calculate_siem_security_score(attrs),
191
+ compliance_status: generate_siem_compliance_status(attrs)
192
+ }
193
+
194
+ # Create component reference
195
+ create_component_reference(
196
+ 'siem_security_platform',
197
+ name,
198
+ attrs.to_h,
199
+ resources,
200
+ outputs
201
+ )
202
+ end
203
+
204
+ private
205
+
206
+ def generate_kms_policy(name)
207
+ JSON.pretty_generate({
208
+ Version: "2012-10-17",
209
+ Statement: [
210
+ {
211
+ Sid: "Enable IAM User Permissions",
212
+ Effect: "Allow",
213
+ Principal: {
214
+ AWS: "arn:aws:iam::#{aws_account_id}:root"
215
+ },
216
+ Action: "kms:*",
217
+ Resource: "*"
218
+ },
219
+ {
220
+ Sid: "Allow use of the key for SIEM services",
221
+ Effect: "Allow",
222
+ Principal: {
223
+ Service: [
224
+ "es.amazonaws.com",
225
+ "firehose.amazonaws.com",
226
+ "lambda.amazonaws.com",
227
+ "logs.amazonaws.com"
228
+ ]
229
+ },
230
+ Action: [
231
+ "kms:Decrypt",
232
+ "kms:GenerateDataKey"
233
+ ],
234
+ Resource: "*"
235
+ }
236
+ ]
237
+ })
238
+ end
239
+
240
+ def create_log_group(name, type, attrs, resources)
241
+ log_group_name = component_resource_name(name, :log_group, type)
242
+ log_group = aws_cloudwatch_log_group(log_group_name, {
243
+ name: "/aws/siem/#{name}/#{type}",
244
+ retention_in_days: attrs.incident_response[:retention_days],
245
+ kms_key_id: resources[:kms_keys][:main].arn,
246
+ tags: component_tags('siem_security_platform', name, attrs.tags)
247
+ })
248
+
249
+ resources[:cloudwatch_logs][type] = log_group
250
+ log_group.arn
251
+ end
252
+
253
+ def create_secure_bucket(bucket_name, bucket_id, attrs, resources)
254
+ bucket = aws_s3_bucket(bucket_name, {
255
+ bucket: bucket_id,
256
+ tags: component_tags('siem_security_platform', name, attrs.tags)
257
+ })
258
+
259
+ # Enable versioning
260
+ aws_s3_bucket_versioning(:"#{bucket_name}_versioning", {
261
+ bucket: bucket.id,
262
+ versioning_configuration: {
263
+ status: "Enabled"
264
+ }
265
+ })
266
+
267
+ # Enable encryption
268
+ aws_s3_bucket_server_side_encryption_configuration(:"#{bucket_name}_encryption", {
269
+ bucket: bucket.id,
270
+ rule: {
271
+ apply_server_side_encryption_by_default: {
272
+ sse_algorithm: "aws:kms",
273
+ kms_master_key_id: resources[:kms_keys][:main].id
274
+ },
275
+ bucket_key_enabled: true
276
+ }
277
+ })
278
+
279
+ # Block public access
280
+ aws_s3_bucket_public_access_block(:"#{bucket_name}_pab", {
281
+ bucket: bucket.id,
282
+ block_public_acls: true,
283
+ block_public_policy: true,
284
+ ignore_public_acls: true,
285
+ restrict_public_buckets: true
286
+ })
287
+
288
+ # Add lifecycle rules
289
+ aws_s3_bucket_lifecycle_configuration(:"#{bucket_name}_lifecycle", {
290
+ bucket: bucket.id,
291
+ rule: [
292
+ {
293
+ id: "transition-to-glacier",
294
+ status: "Enabled",
295
+ transition: [
296
+ {
297
+ days: 90,
298
+ storage_class: "GLACIER"
299
+ }
300
+ ],
301
+ expiration: {
302
+ days: attrs.compliance_config[:audit_trail_retention]
303
+ }
304
+ }
305
+ ]
306
+ })
307
+
308
+ bucket
309
+ end
310
+
311
+ def create_firehose_stream(name, source, attrs, resources)
312
+ stream_name = component_resource_name(name, :firehose, source[:name])
313
+
314
+ # Create IAM role for Firehose
315
+ role_name = component_resource_name(name, :firehose_role, source[:name])
316
+ resources[:iam_roles][:"firehose_#{source[:name]}"] = create_firehose_role(
317
+ role_name,
318
+ attrs,
319
+ resources
320
+ )
321
+
322
+ # Create processing Lambda if transformation is needed
323
+ processor_arn = nil
324
+ if attrs.firehose_config[:enable_data_transformation] || source[:transformation]
325
+ processor_arn = create_stream_processor(name, source, attrs, resources)
326
+ end
327
+
328
+ resources[:firehose_streams][source[:name]] = aws_kinesis_firehose_delivery_stream(stream_name, {
329
+ name: "siem-#{name}-#{source[:name]}",
330
+ destination: "opensearch",
331
+
332
+ opensearch_configuration: {
333
+ domain_arn: resources[:opensearch_domain].arn,
334
+ index_name: "siem-#{source[:type]}",
335
+ index_rotation_period: "OneDay",
336
+ type_name: "_doc",
337
+ role_arn: resources[:iam_roles][:"firehose_#{source[:name]}"].arn,
338
+
339
+ buffering_hints: {
340
+ interval_in_seconds: attrs.firehose_config[:buffer_interval],
341
+ size_in_mbs: attrs.firehose_config[:buffer_size]
342
+ },
343
+
344
+ cloudwatch_logging_options: {
345
+ enabled: true,
346
+ log_group_name: "/aws/kinesisfirehose/siem-#{name}",
347
+ log_stream_name: source[:name]
348
+ },
349
+
350
+ processing_configuration: processor_arn ? {
351
+ enabled: true,
352
+ processors: [{
353
+ type: "Lambda",
354
+ parameters: [{
355
+ parameter_name: "LambdaArn",
356
+ parameter_value: processor_arn
357
+ }]
358
+ }]
359
+ } : nil,
360
+
361
+ s3_configuration: {
362
+ bucket_arn: resources[:s3_buckets][:backup].arn,
363
+ prefix: "#{source[:type]}/year=!{timestamp:yyyy}/month=!{timestamp:MM}/day=!{timestamp:dd}/",
364
+ error_output_prefix: "#{attrs.firehose_config[:error_output_prefix]}#{source[:type]}/",
365
+ compression_format: attrs.firehose_config[:compression_format],
366
+ role_arn: resources[:iam_roles][:"firehose_#{source[:name]}"].arn
367
+ },
368
+
369
+ vpc_config: {
370
+ subnet_ids: attrs.subnet_refs,
371
+ security_group_ids: [resources[:security_groups][:opensearch].id],
372
+ role_arn: resources[:iam_roles][:"firehose_#{source[:name]}"].arn
373
+ }
374
+ },
375
+
376
+ tags: component_tags('siem_security_platform', name, attrs.tags.merge(
377
+ LogSource: source[:name]
378
+ ))
379
+ })
380
+
381
+ # Configure log source subscription
382
+ configure_log_source_subscription(name, source, attrs, resources)
383
+ end
384
+
385
+ def create_firehose_role(role_name, attrs, resources)
386
+ role = aws_iam_role(role_name, {
387
+ name: role_name.to_s,
388
+ assume_role_policy: JSON.pretty_generate({
389
+ Version: "2012-10-17",
390
+ Statement: [{
391
+ Action: "sts:AssumeRole",
392
+ Effect: "Allow",
393
+ Principal: {
394
+ Service: "firehose.amazonaws.com"
395
+ }
396
+ }]
397
+ }),
398
+ tags: component_tags('siem_security_platform', name, attrs.tags)
399
+ })
400
+
401
+ # Create and attach policy
402
+ policy_name = :"#{role_name}_policy"
403
+ policy = aws_iam_role_policy(policy_name, {
404
+ role: role.id,
405
+ policy: JSON.pretty_generate({
406
+ Version: "2012-10-17",
407
+ Statement: [
408
+ {
409
+ Effect: "Allow",
410
+ Action: [
411
+ "es:ESHttpPost",
412
+ "es:ESHttpPut"
413
+ ],
414
+ Resource: [
415
+ resources[:opensearch_domain].arn,
416
+ "#{resources[:opensearch_domain].arn}/*"
417
+ ]
418
+ },
419
+ {
420
+ Effect: "Allow",
421
+ Action: [
422
+ "s3:GetObject",
423
+ "s3:PutObject"
424
+ ],
425
+ Resource: "#{resources[:s3_buckets][:backup].arn}/*"
426
+ },
427
+ {
428
+ Effect: "Allow",
429
+ Action: [
430
+ "kms:Decrypt",
431
+ "kms:GenerateDataKey"
432
+ ],
433
+ Resource: resources[:kms_keys][:main].arn
434
+ },
435
+ {
436
+ Effect: "Allow",
437
+ Action: [
438
+ "logs:CreateLogGroup",
439
+ "logs:CreateLogStream",
440
+ "logs:PutLogEvents"
441
+ ],
442
+ Resource: "*"
443
+ },
444
+ {
445
+ Effect: "Allow",
446
+ Action: [
447
+ "lambda:InvokeFunction"
448
+ ],
449
+ Resource: "arn:aws:lambda:*:*:function:siem-*"
450
+ }
451
+ ]
452
+ })
453
+ })
454
+
455
+ role
456
+ end
457
+
458
+ def create_stream_processor(name, source, attrs, resources)
459
+ processor_name = component_resource_name(name, :processor, source[:name])
460
+
461
+ # Create Lambda function
462
+ lambda_function = aws_lambda_function(processor_name, {
463
+ function_name: "siem-processor-#{name}-#{source[:name]}",
464
+ runtime: "python3.11",
465
+ handler: "index.lambda_handler",
466
+ role: create_lambda_execution_role(name, "processor-#{source[:name]}", attrs, resources),
467
+ timeout: 300,
468
+ memory_size: 512,
469
+
470
+ environment: {
471
+ variables: {
472
+ LOG_SOURCE_TYPE: source[:type],
473
+ LOG_FORMAT: source[:format],
474
+ ENABLE_ENRICHMENT: source[:enrichment].to_s,
475
+ THREAT_INTEL_TABLE: resources[:dynamodb_tables]&.dig(:threat_intel)&.name || ""
476
+ }
477
+ },
478
+
479
+ code: {
480
+ zip_file: generate_processor_code(source)
481
+ },
482
+
483
+ tags: component_tags('siem_security_platform', name, attrs.tags)
484
+ })
485
+
486
+ resources[:lambda_functions][:"processor_#{source[:name]}"] = lambda_function
487
+ lambda_function.arn
488
+ end
489
+
490
+ def generate_processor_code(source)
491
+ <<~PYTHON
492
+ import json
493
+ import base64
494
+ import os
495
+ import boto3
496
+ from datetime import datetime
497
+ import re
498
+ import ipaddress
499
+
500
+ def lambda_handler(event, context):
501
+ output_records = []
502
+
503
+ for record in event['records']:
504
+ # Decode the data
505
+ payload = base64.b64decode(record['data']).decode('utf-8')
506
+
507
+ try:
508
+ # Parse based on format
509
+ parsed_data = parse_log_data(payload, os.environ['LOG_FORMAT'])
510
+
511
+ # Add metadata
512
+ parsed_data['@timestamp'] = datetime.utcnow().isoformat()
513
+ parsed_data['log_source'] = os.environ['LOG_SOURCE_TYPE']
514
+ parsed_data['processing_timestamp'] = datetime.utcnow().isoformat()
515
+
516
+ # Enrich data if enabled
517
+ if os.environ.get('ENABLE_ENRICHMENT', 'false').lower() == 'true':
518
+ parsed_data = enrich_data(parsed_data)
519
+
520
+ # Normalize fields
521
+ parsed_data = normalize_fields(parsed_data)
522
+
523
+ # Convert back to JSON
524
+ output_data = json.dumps(parsed_data) + '\\n'
525
+
526
+ output_records.append({
527
+ 'recordId': record['recordId'],
528
+ 'result': 'Ok',
529
+ 'data': base64.b64encode(output_data.encode('utf-8')).decode('utf-8')
530
+ })
531
+
532
+ except Exception as e:
533
+ # Send failed records to error output
534
+ output_records.append({
535
+ 'recordId': record['recordId'],
536
+ 'result': 'ProcessingFailed',
537
+ 'data': record['data']
538
+ })
539
+
540
+ return {'records': output_records}
541
+
542
+ def parse_log_data(data, format_type):
543
+ if format_type == 'json':
544
+ return json.loads(data)
545
+ elif format_type == 'csv':
546
+ # Implement CSV parsing
547
+ return parse_csv(data)
548
+ elif format_type == 'syslog':
549
+ # Implement syslog parsing
550
+ return parse_syslog(data)
551
+ else:
552
+ return {'raw_data': data}
553
+
554
+ def enrich_data(data):
555
+ # Add GeoIP enrichment
556
+ if 'source_ip' in data:
557
+ data['source_geo'] = lookup_geoip(data['source_ip'])
558
+
559
+ # Add threat intelligence enrichment
560
+ if 'source_ip' in data or 'domain' in data:
561
+ data['threat_intel'] = check_threat_intel(data)
562
+
563
+ # Add user context
564
+ if 'user_id' in data:
565
+ data['user_context'] = get_user_context(data['user_id'])
566
+
567
+ return data
568
+
569
+ def normalize_fields(data):
570
+ # Normalize common field names
571
+ field_mappings = {
572
+ 'src_ip': 'source_ip',
573
+ 'dst_ip': 'destination_ip',
574
+ 'src_port': 'source_port',
575
+ 'dst_port': 'destination_port',
576
+ 'username': 'user_name',
577
+ 'userid': 'user_id'
578
+ }
579
+
580
+ for old_field, new_field in field_mappings.items():
581
+ if old_field in data:
582
+ data[new_field] = data.pop(old_field)
583
+
584
+ return data
585
+
586
+ def parse_csv(data):
587
+ # Implement CSV parsing logic
588
+ return {'raw': data}
589
+
590
+ def parse_syslog(data):
591
+ # Implement syslog parsing logic
592
+ return {'raw': data}
593
+
594
+ def lookup_geoip(ip):
595
+ # Implement GeoIP lookup
596
+ return {'country': 'US', 'city': 'Unknown'}
597
+
598
+ def check_threat_intel(data):
599
+ # Implement threat intelligence lookup
600
+ return {'reputation': 'clean', 'score': 0}
601
+
602
+ def get_user_context(user_id):
603
+ # Implement user context lookup
604
+ return {'department': 'Unknown', 'risk_score': 0}
605
+ PYTHON
606
+ end
607
+
608
+ def create_lambda_execution_role(name, function_type, attrs, resources)
609
+ role_name = component_resource_name(name, :lambda_role, function_type)
610
+ role = aws_iam_role(role_name, {
611
+ name: role_name.to_s,
612
+ assume_role_policy: JSON.pretty_generate({
613
+ Version: "2012-10-17",
614
+ Statement: [{
615
+ Action: "sts:AssumeRole",
616
+ Effect: "Allow",
617
+ Principal: {
618
+ Service: "lambda.amazonaws.com"
619
+ }
620
+ }]
621
+ }),
622
+ tags: component_tags('siem_security_platform', name, attrs.tags)
623
+ })
624
+
625
+ # Attach basic execution policy
626
+ aws_iam_role_policy_attachment(:"#{role_name}_basic", {
627
+ role: role.name,
628
+ policy_arn: "arn:aws:iam::aws:policy/service-role/AWSLambdaBasicExecutionRole"
629
+ })
630
+
631
+ # Attach VPC execution policy if needed
632
+ aws_iam_role_policy_attachment(:"#{role_name}_vpc", {
633
+ role: role.name,
634
+ policy_arn: "arn:aws:iam::aws:policy/service-role/AWSLambdaVPCAccessExecutionRole"
635
+ })
636
+
637
+ # Create custom policy for SIEM operations
638
+ custom_policy = aws_iam_role_policy(:"#{role_name}_custom", {
639
+ role: role.id,
640
+ policy: JSON.pretty_generate({
641
+ Version: "2012-10-17",
642
+ Statement: [
643
+ {
644
+ Effect: "Allow",
645
+ Action: [
646
+ "es:ESHttpPost",
647
+ "es:ESHttpGet"
648
+ ],
649
+ Resource: "#{resources[:opensearch_domain].arn}/*"
650
+ },
651
+ {
652
+ Effect: "Allow",
653
+ Action: [
654
+ "dynamodb:GetItem",
655
+ "dynamodb:Query",
656
+ "dynamodb:Scan"
657
+ ],
658
+ Resource: "arn:aws:dynamodb:*:*:table/siem-*"
659
+ },
660
+ {
661
+ Effect: "Allow",
662
+ Action: [
663
+ "kms:Decrypt"
664
+ ],
665
+ Resource: resources[:kms_keys][:main].arn
666
+ },
667
+ {
668
+ Effect: "Allow",
669
+ Action: [
670
+ "sns:Publish"
671
+ ],
672
+ Resource: "arn:aws:sns:*:*:siem-*"
673
+ }
674
+ ]
675
+ })
676
+ })
677
+
678
+ resources[:iam_roles][function_type.to_sym] = role
679
+ role.arn
680
+ end
681
+
682
+ def configure_log_source_subscription(name, source, attrs, resources)
683
+ case source[:type]
684
+ when 'cloudwatch'
685
+ if source[:log_group_name]
686
+ # Create subscription filter
687
+ aws_cloudwatch_log_subscription_filter(:"#{name}_#{source[:name]}_subscription", {
688
+ name: "siem-#{name}-#{source[:name]}",
689
+ log_group_name: source[:log_group_name],
690
+ filter_pattern: "",
691
+ destination_arn: resources[:firehose_streams][source[:name]].arn,
692
+ role_arn: create_logs_role(name, source[:name], attrs, resources)
693
+ })
694
+ end
695
+ when 's3_access'
696
+ # Configure S3 bucket logging
697
+ if source[:s3_bucket]
698
+ aws_s3_bucket_logging(:"#{name}_#{source[:name]}_logging", {
699
+ bucket: source[:s3_bucket],
700
+ target_bucket: resources[:s3_buckets][:backup].id,
701
+ target_prefix: "s3-access-logs/#{source[:s3_bucket]}/"
702
+ })
703
+ end
704
+ end
705
+ end
706
+
707
+ def create_logs_role(name, source_name, attrs, resources)
708
+ role_name = component_resource_name(name, :logs_role, source_name)
709
+ role = aws_iam_role(role_name, {
710
+ name: role_name.to_s,
711
+ assume_role_policy: JSON.pretty_generate({
712
+ Version: "2012-10-17",
713
+ Statement: [{
714
+ Action: "sts:AssumeRole",
715
+ Effect: "Allow",
716
+ Principal: {
717
+ Service: "logs.amazonaws.com"
718
+ }
719
+ }]
720
+ }),
721
+ tags: component_tags('siem_security_platform', name, attrs.tags)
722
+ })
723
+
724
+ aws_iam_role_policy(:"#{role_name}_policy", {
725
+ role: role.id,
726
+ policy: JSON.pretty_generate({
727
+ Version: "2012-10-17",
728
+ Statement: [{
729
+ Effect: "Allow",
730
+ Action: [
731
+ "firehose:PutRecord",
732
+ "firehose:PutRecordBatch"
733
+ ],
734
+ Resource: resources[:firehose_streams][source_name].arn
735
+ }]
736
+ })
737
+ })
738
+
739
+ role.arn
740
+ end
741
+
742
+ def create_processing_lambdas(name, attrs, resources)
743
+ # Create Lambda for correlation engine
744
+ correlation_lambda = component_resource_name(name, :correlation_lambda)
745
+ resources[:lambda_functions][:correlation] = aws_lambda_function(correlation_lambda, {
746
+ function_name: "siem-correlation-#{name}",
747
+ runtime: "python3.11",
748
+ handler: "index.lambda_handler",
749
+ role: create_lambda_execution_role(name, "correlation", attrs, resources),
750
+ timeout: 900,
751
+ memory_size: 3008,
752
+
753
+ environment: {
754
+ variables: {
755
+ OPENSEARCH_ENDPOINT: resources[:opensearch_domain].endpoint,
756
+ CORRELATION_RULES: JSON.generate(attrs.correlation_rules),
757
+ SNS_TOPIC_ARN: create_alert_topic(name, attrs, resources)
758
+ }
759
+ },
760
+
761
+ code: {
762
+ zip_file: generate_correlation_engine_code()
763
+ },
764
+
765
+ tags: component_tags('siem_security_platform', name, attrs.tags)
766
+ })
767
+
768
+ # Create Lambda for threat detection
769
+ if attrs.threat_detection[:enable_ml_detection]
770
+ ml_lambda = component_resource_name(name, :ml_detection_lambda)
771
+ resources[:lambda_functions][:ml_detection] = aws_lambda_function(ml_lambda, {
772
+ function_name: "siem-ml-detection-#{name}",
773
+ runtime: "python3.11",
774
+ handler: "index.lambda_handler",
775
+ role: create_lambda_execution_role(name, "ml-detection", attrs, resources),
776
+ timeout: 900,
777
+ memory_size: 3008,
778
+
779
+ environment: {
780
+ variables: {
781
+ OPENSEARCH_ENDPOINT: resources[:opensearch_domain].endpoint,
782
+ ANOMALY_DETECTORS: JSON.generate(attrs.threat_detection[:anomaly_detectors]),
783
+ ENABLE_BEHAVIOR_ANALYTICS: attrs.threat_detection[:enable_behavior_analytics].to_s
784
+ }
785
+ },
786
+
787
+ code: {
788
+ zip_file: generate_ml_detection_code()
789
+ },
790
+
791
+ tags: component_tags('siem_security_platform', name, attrs.tags)
792
+ })
793
+ end
794
+ end
795
+
796
+ def generate_correlation_engine_code
797
+ <<~PYTHON
798
+ import json
799
+ import boto3
800
+ import os
801
+ from opensearchpy import OpenSearch
802
+ from datetime import datetime, timedelta
803
+ import re
804
+
805
+ def lambda_handler(event, context):
806
+ # Initialize OpenSearch client
807
+ es = OpenSearch(
808
+ hosts=[{'host': os.environ['OPENSEARCH_ENDPOINT'], 'port': 443}],
809
+ http_auth=get_auth(),
810
+ use_ssl=True,
811
+ verify_certs=True
812
+ )
813
+
814
+ # Load correlation rules
815
+ rules = json.loads(os.environ['CORRELATION_RULES'])
816
+
817
+ # Process each rule
818
+ alerts = []
819
+ for rule in rules:
820
+ if rule.get('enabled', True):
821
+ matches = evaluate_rule(es, rule)
822
+ if matches:
823
+ alert = create_alert(rule, matches)
824
+ alerts.append(alert)
825
+ send_alert(alert)
826
+
827
+ return {
828
+ 'statusCode': 200,
829
+ 'body': json.dumps({
830
+ 'processed_rules': len(rules),
831
+ 'alerts_generated': len(alerts)
832
+ })
833
+ }
834
+
835
+ def evaluate_rule(es, rule):
836
+ # Build query based on rule type
837
+ if rule['rule_type'] == 'threshold':
838
+ return evaluate_threshold_rule(es, rule)
839
+ elif rule['rule_type'] == 'pattern':
840
+ return evaluate_pattern_rule(es, rule)
841
+ elif rule['rule_type'] == 'anomaly':
842
+ return evaluate_anomaly_rule(es, rule)
843
+ elif rule['rule_type'] == 'sequence':
844
+ return evaluate_sequence_rule(es, rule)
845
+ elif rule['rule_type'] == 'statistical':
846
+ return evaluate_statistical_rule(es, rule)
847
+
848
+ return []
849
+
850
+ def evaluate_threshold_rule(es, rule):
851
+ # Implement threshold-based detection
852
+ time_window = rule.get('time_window', 300)
853
+ query = build_query_from_conditions(rule['conditions'], time_window)
854
+
855
+ response = es.search(
856
+ index='siem-*',
857
+ body=query,
858
+ size=0
859
+ )
860
+
861
+ doc_count = response['hits']['total']['value']
862
+ threshold = rule.get('threshold', 10)
863
+
864
+ if doc_count >= threshold:
865
+ return [{
866
+ 'count': doc_count,
867
+ 'threshold': threshold,
868
+ 'time_window': time_window
869
+ }]
870
+
871
+ return []
872
+
873
+ def evaluate_pattern_rule(es, rule):
874
+ # Implement pattern-based detection
875
+ query = build_pattern_query(rule['conditions'])
876
+
877
+ response = es.search(
878
+ index='siem-*',
879
+ body=query,
880
+ size=100
881
+ )
882
+
883
+ return response['hits']['hits']
884
+
885
+ def evaluate_anomaly_rule(es, rule):
886
+ # Implement anomaly detection using ML
887
+ # This would typically use OpenSearch ML features
888
+ return []
889
+
890
+ def evaluate_sequence_rule(es, rule):
891
+ # Implement sequence-based detection
892
+ # Look for specific sequences of events
893
+ return []
894
+
895
+ def evaluate_statistical_rule(es, rule):
896
+ # Implement statistical anomaly detection
897
+ # Calculate baselines and detect deviations
898
+ return []
899
+
900
+ def build_query_from_conditions(conditions, time_window):
901
+ must_clauses = []
902
+
903
+ for condition in conditions:
904
+ if 'field' in condition and 'value' in condition:
905
+ must_clauses.append({
906
+ 'match': {
907
+ condition['field']: condition['value']
908
+ }
909
+ })
910
+
911
+ return {
912
+ 'query': {
913
+ 'bool': {
914
+ 'must': must_clauses,
915
+ 'filter': {
916
+ 'range': {
917
+ '@timestamp': {
918
+ 'gte': f'now-{time_window}s'
919
+ }
920
+ }
921
+ }
922
+ }
923
+ }
924
+ }
925
+
926
+ def build_pattern_query(conditions):
927
+ # Build complex pattern queries
928
+ return build_query_from_conditions(conditions, 3600)
929
+
930
+ def create_alert(rule, matches):
931
+ return {
932
+ 'rule_name': rule['name'],
933
+ 'severity': rule['severity'],
934
+ 'description': rule['description'],
935
+ 'matches': len(matches),
936
+ 'timestamp': datetime.utcnow().isoformat(),
937
+ 'actions': rule['actions']
938
+ }
939
+
940
+ def send_alert(alert):
941
+ sns = boto3.client('sns')
942
+
943
+ message = {
944
+ 'default': json.dumps(alert),
945
+ 'email': format_email_alert(alert),
946
+ 'sms': format_sms_alert(alert)
947
+ }
948
+
949
+ sns.publish(
950
+ TopicArn=os.environ['SNS_TOPIC_ARN'],
951
+ Message=json.dumps(message),
952
+ MessageStructure='json',
953
+ Subject=f"SIEM Alert: {alert['rule_name']} - {alert['severity'].upper()}"
954
+ )
955
+
956
+ def format_email_alert(alert):
957
+ return f"""
958
+ Security Alert: {alert['rule_name']}
959
+
960
+ Severity: {alert['severity'].upper()}
961
+ Time: {alert['timestamp']}
962
+
963
+ Description: {alert['description']}
964
+
965
+ Number of matches: {alert['matches']}
966
+
967
+ Required Actions: {', '.join(alert['actions'])}
968
+ """
969
+
970
+ def format_sms_alert(alert):
971
+ return f"SIEM Alert: {alert['rule_name']} ({alert['severity']}) - {alert['matches']} matches detected"
972
+
973
+ def get_auth():
974
+ # Implement authentication for OpenSearch
975
+ # This could use IAM roles or stored credentials
976
+ return None
977
+ PYTHON
978
+ end
979
+
980
+ def generate_ml_detection_code
981
+ <<~PYTHON
982
+ import json
983
+ import boto3
984
+ import os
985
+ import numpy as np
986
+ from opensearchpy import OpenSearch
987
+ from datetime import datetime, timedelta
988
+ from sklearn.ensemble import IsolationForest
989
+ from sklearn.preprocessing import StandardScaler
990
+
991
+ def lambda_handler(event, context):
992
+ # Initialize OpenSearch client
993
+ es = OpenSearch(
994
+ hosts=[{'host': os.environ['OPENSEARCH_ENDPOINT'], 'port': 443}],
995
+ http_auth=get_auth(),
996
+ use_ssl=True,
997
+ verify_certs=True
998
+ )
999
+
1000
+ # Load anomaly detectors configuration
1001
+ detectors = json.loads(os.environ['ANOMALY_DETECTORS'])
1002
+
1003
+ results = []
1004
+ for detector in detectors:
1005
+ anomalies = run_anomaly_detection(es, detector)
1006
+ if anomalies:
1007
+ results.extend(anomalies)
1008
+
1009
+ # Run behavior analytics if enabled
1010
+ if os.environ.get('ENABLE_BEHAVIOR_ANALYTICS', 'false').lower() == 'true':
1011
+ behavior_anomalies = run_behavior_analytics(es)
1012
+ results.extend(behavior_anomalies)
1013
+
1014
+ return {
1015
+ 'statusCode': 200,
1016
+ 'body': json.dumps({
1017
+ 'anomalies_detected': len(results),
1018
+ 'results': results
1019
+ })
1020
+ }
1021
+
1022
+ def run_anomaly_detection(es, detector):
1023
+ # Fetch data for analysis
1024
+ data = fetch_detector_data(es, detector)
1025
+
1026
+ if not data:
1027
+ return []
1028
+
1029
+ # Prepare features
1030
+ features = prepare_features(data, detector)
1031
+
1032
+ # Run anomaly detection based on type
1033
+ if detector['type'] == 'statistical':
1034
+ return detect_statistical_anomalies(features, detector)
1035
+ elif detector['type'] == 'machine_learning':
1036
+ return detect_ml_anomalies(features, detector)
1037
+ elif detector['type'] == 'pattern_based':
1038
+ return detect_pattern_anomalies(data, detector)
1039
+
1040
+ return []
1041
+
1042
+ def fetch_detector_data(es, detector):
1043
+ # Fetch relevant data based on detector configuration
1044
+ baseline_period = detector.get('baseline_period', 7)
1045
+
1046
+ query = {
1047
+ 'query': {
1048
+ 'range': {
1049
+ '@timestamp': {
1050
+ 'gte': f'now-{baseline_period}d'
1051
+ }
1052
+ }
1053
+ },
1054
+ 'size': 10000,
1055
+ 'sort': [{'@timestamp': 'desc'}]
1056
+ }
1057
+
1058
+ response = es.search(index='siem-*', body=query)
1059
+ return [hit['_source'] for hit in response['hits']['hits']]
1060
+
1061
+ def prepare_features(data, detector):
1062
+ # Extract numerical features for ML analysis
1063
+ features = []
1064
+
1065
+ for record in data:
1066
+ feature_vector = []
1067
+
1068
+ # Extract relevant features based on detector config
1069
+ if 'response_time' in record:
1070
+ feature_vector.append(float(record['response_time']))
1071
+ if 'bytes_transferred' in record:
1072
+ feature_vector.append(float(record['bytes_transferred']))
1073
+ if 'error_count' in record:
1074
+ feature_vector.append(float(record['error_count']))
1075
+
1076
+ if feature_vector:
1077
+ features.append(feature_vector)
1078
+
1079
+ return np.array(features) if features else np.array([])
1080
+
1081
+ def detect_statistical_anomalies(features, detector):
1082
+ if len(features) == 0:
1083
+ return []
1084
+
1085
+ # Calculate statistics
1086
+ mean = np.mean(features, axis=0)
1087
+ std = np.std(features, axis=0)
1088
+
1089
+ # Detect outliers
1090
+ anomalies = []
1091
+ sensitivity_factor = {
1092
+ 'low': 3,
1093
+ 'medium': 2,
1094
+ 'high': 1
1095
+ }.get(detector.get('sensitivity', 'medium'), 2)
1096
+
1097
+ for i, feature in enumerate(features):
1098
+ z_scores = np.abs((feature - mean) / (std + 1e-10))
1099
+ if np.any(z_scores > sensitivity_factor):
1100
+ anomalies.append({
1101
+ 'type': 'statistical_anomaly',
1102
+ 'detector': detector['name'],
1103
+ 'index': i,
1104
+ 'z_scores': z_scores.tolist(),
1105
+ 'severity': calculate_severity(z_scores, sensitivity_factor)
1106
+ })
1107
+
1108
+ return anomalies
1109
+
1110
+ def detect_ml_anomalies(features, detector):
1111
+ if len(features) < 10:
1112
+ return []
1113
+
1114
+ # Normalize features
1115
+ scaler = StandardScaler()
1116
+ features_normalized = scaler.fit_transform(features)
1117
+
1118
+ # Train Isolation Forest
1119
+ contamination = {
1120
+ 'low': 0.01,
1121
+ 'medium': 0.05,
1122
+ 'high': 0.1
1123
+ }.get(detector.get('sensitivity', 'medium'), 0.05)
1124
+
1125
+ model = IsolationForest(
1126
+ contamination=contamination,
1127
+ random_state=42
1128
+ )
1129
+
1130
+ predictions = model.fit_predict(features_normalized)
1131
+
1132
+ # Identify anomalies
1133
+ anomalies = []
1134
+ for i, pred in enumerate(predictions):
1135
+ if pred == -1:
1136
+ anomalies.append({
1137
+ 'type': 'ml_anomaly',
1138
+ 'detector': detector['name'],
1139
+ 'index': i,
1140
+ 'anomaly_score': model.score_samples([features_normalized[i]])[0],
1141
+ 'severity': 'high' if model.score_samples([features_normalized[i]])[0] < -0.5 else 'medium'
1142
+ })
1143
+
1144
+ return anomalies
1145
+
1146
+ def detect_pattern_anomalies(data, detector):
1147
+ # Implement pattern-based anomaly detection
1148
+ # Look for unusual patterns in categorical data
1149
+ anomalies = []
1150
+
1151
+ # Example: Detect unusual user behavior patterns
1152
+ user_activities = {}
1153
+ for record in data:
1154
+ if 'user_id' in record and 'action' in record:
1155
+ user_id = record['user_id']
1156
+ if user_id not in user_activities:
1157
+ user_activities[user_id] = []
1158
+ user_activities[user_id].append(record['action'])
1159
+
1160
+ # Detect anomalous activity sequences
1161
+ for user_id, activities in user_activities.items():
1162
+ if is_anomalous_sequence(activities):
1163
+ anomalies.append({
1164
+ 'type': 'pattern_anomaly',
1165
+ 'detector': detector['name'],
1166
+ 'user_id': user_id,
1167
+ 'pattern': activities[-10:], # Last 10 activities
1168
+ 'severity': 'high'
1169
+ })
1170
+
1171
+ return anomalies
1172
+
1173
+ def run_behavior_analytics(es):
1174
+ # Implement User and Entity Behavior Analytics (UEBA)
1175
+ anomalies = []
1176
+
1177
+ # Analyze user behavior
1178
+ user_anomalies = analyze_user_behavior(es)
1179
+ anomalies.extend(user_anomalies)
1180
+
1181
+ # Analyze entity behavior
1182
+ entity_anomalies = analyze_entity_behavior(es)
1183
+ anomalies.extend(entity_anomalies)
1184
+
1185
+ return anomalies
1186
+
1187
+ def analyze_user_behavior(es):
1188
+ # Implement user behavior analysis
1189
+ # Look for unusual login times, locations, access patterns
1190
+ return []
1191
+
1192
+ def analyze_entity_behavior(es):
1193
+ # Implement entity behavior analysis
1194
+ # Look for unusual system behavior, process execution, network connections
1195
+ return []
1196
+
1197
+ def is_anomalous_sequence(activities):
1198
+ # Implement sequence anomaly detection logic
1199
+ # This is a simplified example
1200
+ suspicious_sequences = [
1201
+ ['login', 'privilege_escalation', 'data_export'],
1202
+ ['failed_login', 'failed_login', 'failed_login', 'successful_login'],
1203
+ ['access_sensitive_data', 'download_large_file', 'delete_logs']
1204
+ ]
1205
+
1206
+ for suspicious in suspicious_sequences:
1207
+ if all(activity in activities for activity in suspicious):
1208
+ return True
1209
+
1210
+ return False
1211
+
1212
+ def calculate_severity(z_scores, threshold):
1213
+ max_z = np.max(z_scores)
1214
+ if max_z > threshold * 2:
1215
+ return 'critical'
1216
+ elif max_z > threshold * 1.5:
1217
+ return 'high'
1218
+ elif max_z > threshold:
1219
+ return 'medium'
1220
+ else:
1221
+ return 'low'
1222
+
1223
+ def get_auth():
1224
+ # Implement authentication
1225
+ return None
1226
+ PYTHON
1227
+ end
1228
+
1229
+ def create_alert_topic(name, attrs, resources)
1230
+ topic_name = component_resource_name(name, :alert_topic)
1231
+ topic = aws_sns_topic(topic_name, {
1232
+ name: "siem-alerts-#{name}",
1233
+ kms_master_key_id: resources[:kms_keys][:main].id,
1234
+ tags: component_tags('siem_security_platform', name, attrs.tags)
1235
+ })
1236
+
1237
+ resources[:sns_topics][:alerts] = topic
1238
+ topic.arn
1239
+ end
1240
+
1241
+ def create_correlation_engine(name, attrs, resources)
1242
+ # Create Step Functions state machine for correlation workflow
1243
+ state_machine_name = component_resource_name(name, :correlation_engine)
1244
+
1245
+ resources[:step_functions][:correlation_engine] = aws_sfn_state_machine(state_machine_name, {
1246
+ name: "siem-correlation-engine-#{name}",
1247
+ role_arn: create_step_functions_role(name, "correlation", attrs, resources),
1248
+
1249
+ definition: JSON.pretty_generate({
1250
+ Comment: "SIEM Correlation Engine",
1251
+ StartAt: "CollectEvents",
1252
+ States: {
1253
+ CollectEvents: {
1254
+ Type: "Task",
1255
+ Resource: resources[:lambda_functions][:correlation].arn,
1256
+ Next: "EvaluateRules"
1257
+ },
1258
+ EvaluateRules: {
1259
+ Type: "Parallel",
1260
+ Branches: attrs.correlation_rules.map do |rule|
1261
+ {
1262
+ StartAt: "Evaluate#{rule[:name].gsub(/\s+/, '')}",
1263
+ States: {
1264
+ "Evaluate#{rule[:name].gsub(/\s+/, '')}" => {
1265
+ Type: "Task",
1266
+ Resource: resources[:lambda_functions][:correlation].arn,
1267
+ Parameters: {
1268
+ "rule.$" => rule.to_json,
1269
+ "events.$" => "$"
1270
+ },
1271
+ End: true
1272
+ }
1273
+ }
1274
+ }
1275
+ end,
1276
+ Next: "ProcessAlerts"
1277
+ },
1278
+ ProcessAlerts: {
1279
+ Type: "Task",
1280
+ Resource: "arn:aws:states:::lambda:invoke",
1281
+ Parameters: {
1282
+ FunctionName: resources[:lambda_functions][:correlation].arn,
1283
+ Payload: {
1284
+ "action" => "process_alerts",
1285
+ "results.$" => "$"
1286
+ }
1287
+ },
1288
+ End: true
1289
+ }
1290
+ }
1291
+ }),
1292
+
1293
+ tags: component_tags('siem_security_platform', name, attrs.tags)
1294
+ })
1295
+ end
1296
+
1297
+ def create_step_functions_role(name, purpose, attrs, resources)
1298
+ role_name = component_resource_name(name, :sfn_role, purpose)
1299
+ role = aws_iam_role(role_name, {
1300
+ name: role_name.to_s,
1301
+ assume_role_policy: JSON.pretty_generate({
1302
+ Version: "2012-10-17",
1303
+ Statement: [{
1304
+ Action: "sts:AssumeRole",
1305
+ Effect: "Allow",
1306
+ Principal: {
1307
+ Service: "states.amazonaws.com"
1308
+ }
1309
+ }]
1310
+ }),
1311
+ tags: component_tags('siem_security_platform', name, attrs.tags)
1312
+ })
1313
+
1314
+ aws_iam_role_policy(:"#{role_name}_policy", {
1315
+ role: role.id,
1316
+ policy: JSON.pretty_generate({
1317
+ Version: "2012-10-17",
1318
+ Statement: [
1319
+ {
1320
+ Effect: "Allow",
1321
+ Action: [
1322
+ "lambda:InvokeFunction"
1323
+ ],
1324
+ Resource: "arn:aws:lambda:*:*:function:siem-*"
1325
+ },
1326
+ {
1327
+ Effect: "Allow",
1328
+ Action: [
1329
+ "xray:PutTraceSegments",
1330
+ "xray:PutTelemetryRecords"
1331
+ ],
1332
+ Resource: "*"
1333
+ }
1334
+ ]
1335
+ })
1336
+ })
1337
+
1338
+ role.arn
1339
+ end
1340
+
1341
+ def create_threat_detection(name, attrs, resources)
1342
+ # Create DynamoDB table for threat intelligence
1343
+ if attrs.threat_detection[:threat_intel_feeds] && !attrs.threat_detection[:threat_intel_feeds].empty?
1344
+ table_name = component_resource_name(name, :threat_intel_table)
1345
+ resources[:dynamodb_tables] ||= {}
1346
+ resources[:dynamodb_tables][:threat_intel] = aws_dynamodb_table(table_name, {
1347
+ name: "siem-threat-intel-#{name}",
1348
+ billing_mode: "PAY_PER_REQUEST",
1349
+
1350
+ attribute: [
1351
+ {
1352
+ name: "indicator",
1353
+ type: "S"
1354
+ },
1355
+ {
1356
+ name: "indicator_type",
1357
+ type: "S"
1358
+ }
1359
+ ],
1360
+
1361
+ hash_key: "indicator",
1362
+ range_key: "indicator_type",
1363
+
1364
+ global_secondary_index: [
1365
+ {
1366
+ name: "TypeIndex",
1367
+ hash_key: "indicator_type",
1368
+ projection_type: "ALL"
1369
+ }
1370
+ ],
1371
+
1372
+ point_in_time_recovery: {
1373
+ enabled: true
1374
+ },
1375
+
1376
+ server_side_encryption: {
1377
+ enabled: true,
1378
+ kms_key_id: resources[:kms_keys][:main].id
1379
+ },
1380
+
1381
+ tags: component_tags('siem_security_platform', name, attrs.tags)
1382
+ })
1383
+
1384
+ # Create Lambda for threat intel updates
1385
+ threat_intel_lambda = component_resource_name(name, :threat_intel_updater)
1386
+ resources[:lambda_functions][:threat_intel_updater] = aws_lambda_function(threat_intel_lambda, {
1387
+ function_name: "siem-threat-intel-updater-#{name}",
1388
+ runtime: "python3.11",
1389
+ handler: "index.lambda_handler",
1390
+ role: create_lambda_execution_role(name, "threat-intel-updater", attrs, resources),
1391
+ timeout: 900,
1392
+ memory_size: 1024,
1393
+
1394
+ environment: {
1395
+ variables: {
1396
+ THREAT_INTEL_TABLE: resources[:dynamodb_tables][:threat_intel].name,
1397
+ THREAT_FEEDS: JSON.generate(attrs.threat_detection[:threat_intel_feeds])
1398
+ }
1399
+ },
1400
+
1401
+ code: {
1402
+ zip_file: generate_threat_intel_updater_code()
1403
+ },
1404
+
1405
+ tags: component_tags('siem_security_platform', name, attrs.tags)
1406
+ })
1407
+
1408
+ # Schedule threat intel updates
1409
+ attrs.threat_detection[:threat_intel_feeds].each do |feed|
1410
+ rule_name = component_resource_name(name, :threat_intel_rule, feed[:name])
1411
+ rule = aws_cloudwatch_event_rule(rule_name, {
1412
+ name: "siem-threat-intel-#{name}-#{feed[:name]}",
1413
+ description: "Update threat intelligence feed: #{feed[:name]}",
1414
+ schedule_expression: "rate(#{feed[:update_frequency] / 60} minutes)",
1415
+ tags: component_tags('siem_security_platform', name, attrs.tags)
1416
+ })
1417
+
1418
+ aws_cloudwatch_event_target(:"#{rule_name}_target", {
1419
+ rule: rule.name,
1420
+ arn: resources[:lambda_functions][:threat_intel_updater].arn,
1421
+ input: JSON.generate({ feed: feed })
1422
+ })
1423
+
1424
+ resources[:event_rules][:"threat_intel_#{feed[:name]}"] = rule
1425
+ end
1426
+ end
1427
+ end
1428
+
1429
+ def generate_threat_intel_updater_code
1430
+ <<~PYTHON
1431
+ import json
1432
+ import boto3
1433
+ import os
1434
+ import requests
1435
+ from datetime import datetime
1436
+
1437
+ dynamodb = boto3.resource('dynamodb')
1438
+
1439
+ def lambda_handler(event, context):
1440
+ table = dynamodb.Table(os.environ['THREAT_INTEL_TABLE'])
1441
+ feed = event.get('feed', {})
1442
+
1443
+ # Fetch threat intelligence data
1444
+ indicators = fetch_threat_feed(feed)
1445
+
1446
+ # Update DynamoDB table
1447
+ with table.batch_writer() as batch:
1448
+ for indicator in indicators:
1449
+ batch.put_item(Item={
1450
+ 'indicator': indicator['value'],
1451
+ 'indicator_type': indicator['type'],
1452
+ 'severity': indicator.get('severity', 'medium'),
1453
+ 'source': feed['name'],
1454
+ 'last_seen': datetime.utcnow().isoformat(),
1455
+ 'metadata': indicator.get('metadata', {})
1456
+ })
1457
+
1458
+ return {
1459
+ 'statusCode': 200,
1460
+ 'body': json.dumps({
1461
+ 'feed': feed['name'],
1462
+ 'indicators_updated': len(indicators)
1463
+ })
1464
+ }
1465
+
1466
+ def fetch_threat_feed(feed):
1467
+ indicators = []
1468
+
1469
+ if feed['type'] == 'ip_reputation':
1470
+ indicators.extend(fetch_ip_reputation(feed))
1471
+ elif feed['type'] == 'domain_reputation':
1472
+ indicators.extend(fetch_domain_reputation(feed))
1473
+ elif feed['type'] == 'file_hash':
1474
+ indicators.extend(fetch_file_hashes(feed))
1475
+ elif feed['type'] == 'indicators':
1476
+ indicators.extend(fetch_generic_indicators(feed))
1477
+
1478
+ return indicators
1479
+
1480
+ def fetch_ip_reputation(feed):
1481
+ # Implement IP reputation feed fetching
1482
+ # This is a placeholder - real implementation would fetch from actual feeds
1483
+ return [
1484
+ {'value': '192.168.1.100', 'type': 'ip', 'severity': 'high'},
1485
+ {'value': '10.0.0.50', 'type': 'ip', 'severity': 'medium'}
1486
+ ]
1487
+
1488
+ def fetch_domain_reputation(feed):
1489
+ # Implement domain reputation feed fetching
1490
+ return [
1491
+ {'value': 'malicious.com', 'type': 'domain', 'severity': 'critical'},
1492
+ {'value': 'suspicious.net', 'type': 'domain', 'severity': 'high'}
1493
+ ]
1494
+
1495
+ def fetch_file_hashes(feed):
1496
+ # Implement file hash feed fetching
1497
+ return [
1498
+ {'value': 'd41d8cd98f00b204e9800998ecf8427e', 'type': 'md5', 'severity': 'high'},
1499
+ {'value': 'e3b0c44298fc1c149afbf4c8996fb92427ae41e4649b934ca495991b7852b855', 'type': 'sha256', 'severity': 'critical'}
1500
+ ]
1501
+
1502
+ def fetch_generic_indicators(feed):
1503
+ # Implement generic indicator fetching
1504
+ if feed.get('source_url'):
1505
+ try:
1506
+ response = requests.get(feed['source_url'], timeout=30)
1507
+ if response.status_code == 200:
1508
+ # Parse response based on format
1509
+ return parse_indicators(response.text, feed)
1510
+ except Exception as e:
1511
+ print(f"Error fetching feed {feed['name']}: {str(e)}")
1512
+
1513
+ return []
1514
+
1515
+ def parse_indicators(data, feed):
1516
+ # Parse indicators from raw data
1517
+ indicators = []
1518
+
1519
+ # Simple line-based parsing example
1520
+ for line in data.split('\\n'):
1521
+ line = line.strip()
1522
+ if line and not line.startswith('#'):
1523
+ indicators.append({
1524
+ 'value': line,
1525
+ 'type': 'unknown',
1526
+ 'severity': 'medium'
1527
+ })
1528
+
1529
+ return indicators
1530
+ PYTHON
1531
+ end
1532
+
1533
+ def create_incident_response(name, attrs, resources)
1534
+ return unless attrs.incident_response[:enable_automated_response]
1535
+
1536
+ # Create Step Functions for incident response workflows
1537
+ state_machine_name = component_resource_name(name, :incident_response)
1538
+
1539
+ resources[:step_functions][:incident_response] = aws_sfn_state_machine(state_machine_name, {
1540
+ name: "siem-incident-response-#{name}",
1541
+ role_arn: create_step_functions_role(name, "incident-response", attrs, resources),
1542
+
1543
+ definition: JSON.pretty_generate({
1544
+ Comment: "SIEM Incident Response Workflow",
1545
+ StartAt: "ClassifyIncident",
1546
+ States: {
1547
+ ClassifyIncident: {
1548
+ Type: "Task",
1549
+ Resource: "arn:aws:states:::lambda:invoke",
1550
+ Parameters: {
1551
+ FunctionName: create_incident_classifier(name, attrs, resources),
1552
+ Payload: {
1553
+ "incident.$" => "$"
1554
+ }
1555
+ },
1556
+ Next: "DetermineSeverity"
1557
+ },
1558
+ DetermineSeverity: {
1559
+ Type: "Choice",
1560
+ Choices: [
1561
+ {
1562
+ Variable: "$.severity",
1563
+ StringEquals: "critical",
1564
+ Next: "CriticalResponse"
1565
+ },
1566
+ {
1567
+ Variable: "$.severity",
1568
+ StringEquals: "high",
1569
+ Next: "HighResponse"
1570
+ },
1571
+ {
1572
+ Variable: "$.severity",
1573
+ StringEquals: "medium",
1574
+ Next: "MediumResponse"
1575
+ }
1576
+ ],
1577
+ Default: "LowResponse"
1578
+ },
1579
+ CriticalResponse: {
1580
+ Type: "Parallel",
1581
+ Branches: [
1582
+ {
1583
+ StartAt: "IsolateResource",
1584
+ States: {
1585
+ IsolateResource: {
1586
+ Type: "Task",
1587
+ Resource: "arn:aws:states:::lambda:invoke",
1588
+ Parameters: {
1589
+ FunctionName: create_isolation_lambda(name, attrs, resources),
1590
+ Payload: {
1591
+ "action" => "isolate",
1592
+ "resource.$" => "$.affected_resource"
1593
+ }
1594
+ },
1595
+ End: true
1596
+ }
1597
+ }
1598
+ },
1599
+ {
1600
+ StartAt: "NotifySOC",
1601
+ States: {
1602
+ NotifySOC: {
1603
+ Type: "Task",
1604
+ Resource: "arn:aws:states:::sns:publish",
1605
+ Parameters: {
1606
+ TopicArn: resources[:sns_topics][:alerts].arn,
1607
+ Message: {
1608
+ "incident.$" => "$",
1609
+ "priority" => "CRITICAL"
1610
+ }
1611
+ },
1612
+ End: true
1613
+ }
1614
+ }
1615
+ },
1616
+ {
1617
+ StartAt: "CollectForensics",
1618
+ States: {
1619
+ CollectForensics: {
1620
+ Type: "Task",
1621
+ Resource: "arn:aws:states:::lambda:invoke",
1622
+ Parameters: {
1623
+ FunctionName: create_forensics_lambda(name, attrs, resources),
1624
+ Payload: {
1625
+ "action" => "collect",
1626
+ "incident.$" => "$"
1627
+ }
1628
+ },
1629
+ End: true
1630
+ }
1631
+ }
1632
+ }
1633
+ ],
1634
+ Next: "CreateIncidentTicket"
1635
+ },
1636
+ HighResponse: {
1637
+ Type: "Task",
1638
+ Resource: "arn:aws:states:::lambda:invoke",
1639
+ Parameters: {
1640
+ FunctionName: create_response_lambda(name, attrs, resources),
1641
+ Payload: {
1642
+ "severity" => "high",
1643
+ "incident.$" => "$"
1644
+ }
1645
+ },
1646
+ Next: "CreateIncidentTicket"
1647
+ },
1648
+ MediumResponse: {
1649
+ Type: "Task",
1650
+ Resource: "arn:aws:states:::lambda:invoke",
1651
+ Parameters: {
1652
+ FunctionName: create_response_lambda(name, attrs, resources),
1653
+ Payload: {
1654
+ "severity" => "medium",
1655
+ "incident.$" => "$"
1656
+ }
1657
+ },
1658
+ Next: "CreateIncidentTicket"
1659
+ },
1660
+ LowResponse: {
1661
+ Type: "Task",
1662
+ Resource: "arn:aws:states:::lambda:invoke",
1663
+ Parameters: {
1664
+ FunctionName: create_response_lambda(name, attrs, resources),
1665
+ Payload: {
1666
+ "severity" => "low",
1667
+ "incident.$" => "$"
1668
+ }
1669
+ },
1670
+ Next: "CreateIncidentTicket"
1671
+ },
1672
+ CreateIncidentTicket: {
1673
+ Type: "Task",
1674
+ Resource: "arn:aws:states:::lambda:invoke",
1675
+ Parameters: {
1676
+ FunctionName: create_ticketing_lambda(name, attrs, resources),
1677
+ Payload: {
1678
+ "action" => "create_ticket",
1679
+ "incident.$" => "$"
1680
+ }
1681
+ },
1682
+ End: true
1683
+ }
1684
+ }
1685
+ }),
1686
+
1687
+ tags: component_tags('siem_security_platform', name, attrs.tags)
1688
+ })
1689
+
1690
+ # Create playbook executions for configured playbooks
1691
+ attrs.incident_response[:playbooks].each do |playbook|
1692
+ create_playbook_execution(name, playbook, attrs, resources)
1693
+ end
1694
+ end
1695
+
1696
+ def create_incident_classifier(name, attrs, resources)
1697
+ lambda_name = component_resource_name(name, :incident_classifier)
1698
+ lambda = aws_lambda_function(lambda_name, {
1699
+ function_name: "siem-incident-classifier-#{name}",
1700
+ runtime: "python3.11",
1701
+ handler: "index.lambda_handler",
1702
+ role: create_lambda_execution_role(name, "incident-classifier", attrs, resources),
1703
+ timeout: 60,
1704
+
1705
+ code: {
1706
+ zip_file: <<~PYTHON
1707
+ import json
1708
+
1709
+ def lambda_handler(event, context):
1710
+ incident = event.get('incident', {})
1711
+
1712
+ # Classify incident based on rules
1713
+ severity = classify_severity(incident)
1714
+ category = classify_category(incident)
1715
+
1716
+ return {
1717
+ 'statusCode': 200,
1718
+ 'severity': severity,
1719
+ 'category': category,
1720
+ 'incident': incident
1721
+ }
1722
+
1723
+ def classify_severity(incident):
1724
+ # Implement severity classification logic
1725
+ indicators = incident.get('indicators', [])
1726
+
1727
+ if any(ind.get('severity') == 'critical' for ind in indicators):
1728
+ return 'critical'
1729
+ elif any(ind.get('severity') == 'high' for ind in indicators):
1730
+ return 'high'
1731
+ elif len(indicators) > 10:
1732
+ return 'high'
1733
+ elif len(indicators) > 5:
1734
+ return 'medium'
1735
+ else:
1736
+ return 'low'
1737
+
1738
+ def classify_category(incident):
1739
+ # Implement category classification
1740
+ event_types = incident.get('event_types', [])
1741
+
1742
+ if 'malware' in event_types:
1743
+ return 'malware'
1744
+ elif 'unauthorized_access' in event_types:
1745
+ return 'unauthorized_access'
1746
+ elif 'data_exfiltration' in event_types:
1747
+ return 'data_breach'
1748
+ else:
1749
+ return 'unknown'
1750
+ PYTHON
1751
+ },
1752
+
1753
+ tags: component_tags('siem_security_platform', name, attrs.tags)
1754
+ })
1755
+
1756
+ resources[:lambda_functions][:incident_classifier] = lambda
1757
+ lambda.arn
1758
+ end
1759
+
1760
+ def create_isolation_lambda(name, attrs, resources)
1761
+ lambda_name = component_resource_name(name, :isolation_lambda)
1762
+ lambda = aws_lambda_function(lambda_name, {
1763
+ function_name: "siem-isolation-#{name}",
1764
+ runtime: "python3.11",
1765
+ handler: "index.lambda_handler",
1766
+ role: create_isolation_role(name, attrs, resources),
1767
+ timeout: 300,
1768
+
1769
+ code: {
1770
+ zip_file: <<~PYTHON
1771
+ import json
1772
+ import boto3
1773
+
1774
+ ec2 = boto3.client('ec2')
1775
+
1776
+ def lambda_handler(event, context):
1777
+ action = event.get('action')
1778
+ resource = event.get('resource', {})
1779
+
1780
+ if action == 'isolate':
1781
+ result = isolate_resource(resource)
1782
+ elif action == 'restore':
1783
+ result = restore_resource(resource)
1784
+ else:
1785
+ result = {'error': 'Unknown action'}
1786
+
1787
+ return {
1788
+ 'statusCode': 200,
1789
+ 'body': json.dumps(result)
1790
+ }
1791
+
1792
+ def isolate_resource(resource):
1793
+ resource_type = resource.get('type')
1794
+ resource_id = resource.get('id')
1795
+
1796
+ if resource_type == 'ec2_instance':
1797
+ return isolate_ec2_instance(resource_id)
1798
+ elif resource_type == 'security_group':
1799
+ return isolate_security_group(resource_id)
1800
+ else:
1801
+ return {'error': 'Unsupported resource type'}
1802
+
1803
+ def isolate_ec2_instance(instance_id):
1804
+ # Create isolation security group
1805
+ isolation_sg = ec2.create_security_group(
1806
+ GroupName=f'isolation-{instance_id}',
1807
+ Description='Isolation security group for incident response'
1808
+ )
1809
+
1810
+ # Remove all ingress rules
1811
+ ec2.revoke_security_group_ingress(
1812
+ GroupId=isolation_sg['GroupId'],
1813
+ IpPermissions=[{
1814
+ 'IpProtocol': '-1',
1815
+ 'FromPort': -1,
1816
+ 'ToPort': -1,
1817
+ 'IpRanges': [{'CidrIp': '0.0.0.0/0'}]
1818
+ }]
1819
+ )
1820
+
1821
+ # Apply isolation security group
1822
+ ec2.modify_instance_attribute(
1823
+ InstanceId=instance_id,
1824
+ Groups=[isolation_sg['GroupId']]
1825
+ )
1826
+
1827
+ return {
1828
+ 'action': 'isolated',
1829
+ 'instance_id': instance_id,
1830
+ 'isolation_sg': isolation_sg['GroupId']
1831
+ }
1832
+
1833
+ def restore_resource(resource):
1834
+ # Implement restoration logic
1835
+ return {'action': 'restored', 'resource': resource}
1836
+
1837
+ def isolate_security_group(sg_id):
1838
+ # Implement security group isolation
1839
+ return {'action': 'isolated', 'security_group_id': sg_id}
1840
+ PYTHON
1841
+ },
1842
+
1843
+ tags: component_tags('siem_security_platform', name, attrs.tags)
1844
+ })
1845
+
1846
+ resources[:lambda_functions][:isolation] = lambda
1847
+ lambda.arn
1848
+ end
1849
+
1850
+ def create_isolation_role(name, attrs, resources)
1851
+ role_name = component_resource_name(name, :isolation_role)
1852
+ role = aws_iam_role(role_name, {
1853
+ name: role_name.to_s,
1854
+ assume_role_policy: JSON.pretty_generate({
1855
+ Version: "2012-10-17",
1856
+ Statement: [{
1857
+ Action: "sts:AssumeRole",
1858
+ Effect: "Allow",
1859
+ Principal: {
1860
+ Service: "lambda.amazonaws.com"
1861
+ }
1862
+ }]
1863
+ }),
1864
+ tags: component_tags('siem_security_platform', name, attrs.tags)
1865
+ })
1866
+
1867
+ # Attach policies
1868
+ aws_iam_role_policy_attachment(:"#{role_name}_basic", {
1869
+ role: role.name,
1870
+ policy_arn: "arn:aws:iam::aws:policy/service-role/AWSLambdaBasicExecutionRole"
1871
+ })
1872
+
1873
+ # Custom policy for isolation actions
1874
+ aws_iam_role_policy(:"#{role_name}_isolation", {
1875
+ role: role.id,
1876
+ policy: JSON.pretty_generate({
1877
+ Version: "2012-10-17",
1878
+ Statement: [
1879
+ {
1880
+ Effect: "Allow",
1881
+ Action: [
1882
+ "ec2:CreateSecurityGroup",
1883
+ "ec2:AuthorizeSecurityGroupIngress",
1884
+ "ec2:AuthorizeSecurityGroupEgress",
1885
+ "ec2:RevokeSecurityGroupIngress",
1886
+ "ec2:RevokeSecurityGroupEgress",
1887
+ "ec2:ModifyInstanceAttribute",
1888
+ "ec2:DescribeInstances",
1889
+ "ec2:DescribeSecurityGroups",
1890
+ "ec2:CreateSnapshot",
1891
+ "ec2:CreateImage"
1892
+ ],
1893
+ Resource: "*"
1894
+ }
1895
+ ]
1896
+ })
1897
+ })
1898
+
1899
+ role.arn
1900
+ end
1901
+
1902
+ def create_forensics_lambda(name, attrs, resources)
1903
+ lambda_name = component_resource_name(name, :forensics_lambda)
1904
+ lambda = aws_lambda_function(lambda_name, {
1905
+ function_name: "siem-forensics-#{name}",
1906
+ runtime: "python3.11",
1907
+ handler: "index.lambda_handler",
1908
+ role: create_forensics_role(name, attrs, resources),
1909
+ timeout: 900,
1910
+ memory_size: 3008,
1911
+
1912
+ environment: {
1913
+ variables: {
1914
+ FORENSICS_BUCKET: create_forensics_bucket(name, attrs, resources)
1915
+ }
1916
+ },
1917
+
1918
+ code: {
1919
+ zip_file: <<~PYTHON
1920
+ import json
1921
+ import boto3
1922
+ import os
1923
+ from datetime import datetime
1924
+
1925
+ ec2 = boto3.client('ec2')
1926
+ s3 = boto3.client('s3')
1927
+ ssm = boto3.client('ssm')
1928
+
1929
+ def lambda_handler(event, context):
1930
+ action = event.get('action')
1931
+ incident = event.get('incident', {})
1932
+
1933
+ if action == 'collect':
1934
+ result = collect_forensics(incident)
1935
+ else:
1936
+ result = {'error': 'Unknown action'}
1937
+
1938
+ return {
1939
+ 'statusCode': 200,
1940
+ 'body': json.dumps(result)
1941
+ }
1942
+
1943
+ def collect_forensics(incident):
1944
+ forensics_data = {
1945
+ 'incident_id': incident.get('id'),
1946
+ 'timestamp': datetime.utcnow().isoformat(),
1947
+ 'affected_resources': []
1948
+ }
1949
+
1950
+ for resource in incident.get('affected_resources', []):
1951
+ if resource['type'] == 'ec2_instance':
1952
+ forensics = collect_ec2_forensics(resource['id'])
1953
+ forensics_data['affected_resources'].append(forensics)
1954
+
1955
+ # Store forensics data
1956
+ store_forensics_data(forensics_data)
1957
+
1958
+ return forensics_data
1959
+
1960
+ def collect_ec2_forensics(instance_id):
1961
+ forensics = {
1962
+ 'instance_id': instance_id,
1963
+ 'type': 'ec2_instance',
1964
+ 'collected_at': datetime.utcnow().isoformat()
1965
+ }
1966
+
1967
+ # Create memory dump
1968
+ memory_dump = create_memory_dump(instance_id)
1969
+ if memory_dump:
1970
+ forensics['memory_dump'] = memory_dump
1971
+
1972
+ # Create disk snapshot
1973
+ snapshot = create_disk_snapshot(instance_id)
1974
+ if snapshot:
1975
+ forensics['disk_snapshot'] = snapshot
1976
+
1977
+ # Collect system information
1978
+ system_info = collect_system_info(instance_id)
1979
+ if system_info:
1980
+ forensics['system_info'] = system_info
1981
+
1982
+ # Collect network connections
1983
+ network_info = collect_network_info(instance_id)
1984
+ if network_info:
1985
+ forensics['network_info'] = network_info
1986
+
1987
+ return forensics
1988
+
1989
+ def create_memory_dump(instance_id):
1990
+ # Use SSM to run memory dump command
1991
+ try:
1992
+ response = ssm.send_command(
1993
+ InstanceIds=[instance_id],
1994
+ DocumentName='AWS-RunShellScript',
1995
+ Parameters={
1996
+ 'commands': [
1997
+ 'sudo dd if=/dev/mem of=/tmp/memory.dump',
1998
+ 'aws s3 cp /tmp/memory.dump s3://{}/forensics/{}/memory.dump'.format(
1999
+ os.environ['FORENSICS_BUCKET'],
2000
+ instance_id
2001
+ )
2002
+ ]
2003
+ }
2004
+ )
2005
+ return {
2006
+ 'command_id': response['Command']['CommandId'],
2007
+ 's3_location': 's3://{}/forensics/{}/memory.dump'.format(
2008
+ os.environ['FORENSICS_BUCKET'],
2009
+ instance_id
2010
+ )
2011
+ }
2012
+ except Exception as e:
2013
+ print(f"Error creating memory dump: {str(e)}")
2014
+ return None
2015
+
2016
+ def create_disk_snapshot(instance_id):
2017
+ try:
2018
+ # Get instance volumes
2019
+ instance = ec2.describe_instances(InstanceIds=[instance_id])
2020
+ volumes = []
2021
+
2022
+ for reservation in instance['Reservations']:
2023
+ for instance in reservation['Instances']:
2024
+ for bdm in instance.get('BlockDeviceMappings', []):
2025
+ if 'Ebs' in bdm:
2026
+ volume_id = bdm['Ebs']['VolumeId']
2027
+
2028
+ # Create snapshot
2029
+ snapshot = ec2.create_snapshot(
2030
+ VolumeId=volume_id,
2031
+ Description=f'Forensics snapshot for incident - {instance_id}'
2032
+ )
2033
+
2034
+ volumes.append({
2035
+ 'volume_id': volume_id,
2036
+ 'snapshot_id': snapshot['SnapshotId']
2037
+ })
2038
+
2039
+ return volumes
2040
+ except Exception as e:
2041
+ print(f"Error creating snapshot: {str(e)}")
2042
+ return None
2043
+
2044
+ def collect_system_info(instance_id):
2045
+ # Collect system information via SSM
2046
+ commands = [
2047
+ 'uname -a',
2048
+ 'ps aux',
2049
+ 'netstat -tulpn',
2050
+ 'last -50',
2051
+ 'w',
2052
+ 'history'
2053
+ ]
2054
+
2055
+ try:
2056
+ response = ssm.send_command(
2057
+ InstanceIds=[instance_id],
2058
+ DocumentName='AWS-RunShellScript',
2059
+ Parameters={'commands': commands}
2060
+ )
2061
+ return {'command_id': response['Command']['CommandId']}
2062
+ except Exception as e:
2063
+ print(f"Error collecting system info: {str(e)}")
2064
+ return None
2065
+
2066
+ def collect_network_info(instance_id):
2067
+ # Collect network flow information
2068
+ try:
2069
+ # Get VPC Flow Logs
2070
+ # This is simplified - real implementation would query flow logs
2071
+ return {
2072
+ 'flow_logs': 'collected',
2073
+ 'connections': 'analyzed'
2074
+ }
2075
+ except Exception as e:
2076
+ print(f"Error collecting network info: {str(e)}")
2077
+ return None
2078
+
2079
+ def store_forensics_data(data):
2080
+ # Store forensics data in S3
2081
+ key = 'forensics/{}/data.json'.format(data['incident_id'])
2082
+
2083
+ s3.put_object(
2084
+ Bucket=os.environ['FORENSICS_BUCKET'],
2085
+ Key=key,
2086
+ Body=json.dumps(data, indent=2),
2087
+ ServerSideEncryption='aws:kms'
2088
+ )
2089
+ PYTHON
2090
+ },
2091
+
2092
+ tags: component_tags('siem_security_platform', name, attrs.tags)
2093
+ })
2094
+
2095
+ resources[:lambda_functions][:forensics] = lambda
2096
+ lambda.arn
2097
+ end
2098
+
2099
+ def create_forensics_role(name, attrs, resources)
2100
+ role_name = component_resource_name(name, :forensics_role)
2101
+ role = aws_iam_role(role_name, {
2102
+ name: role_name.to_s,
2103
+ assume_role_policy: JSON.pretty_generate({
2104
+ Version: "2012-10-17",
2105
+ Statement: [{
2106
+ Action: "sts:AssumeRole",
2107
+ Effect: "Allow",
2108
+ Principal: {
2109
+ Service: "lambda.amazonaws.com"
2110
+ }
2111
+ }]
2112
+ }),
2113
+ tags: component_tags('siem_security_platform', name, attrs.tags)
2114
+ })
2115
+
2116
+ # Attach policies
2117
+ aws_iam_role_policy_attachment(:"#{role_name}_basic", {
2118
+ role: role.name,
2119
+ policy_arn: "arn:aws:iam::aws:policy/service-role/AWSLambdaBasicExecutionRole"
2120
+ })
2121
+
2122
+ # Custom policy for forensics collection
2123
+ aws_iam_role_policy(:"#{role_name}_forensics", {
2124
+ role: role.id,
2125
+ policy: JSON.pretty_generate({
2126
+ Version: "2012-10-17",
2127
+ Statement: [
2128
+ {
2129
+ Effect: "Allow",
2130
+ Action: [
2131
+ "ec2:CreateSnapshot",
2132
+ "ec2:DescribeInstances",
2133
+ "ec2:DescribeVolumes",
2134
+ "ec2:DescribeSnapshots",
2135
+ "ssm:SendCommand",
2136
+ "ssm:GetCommandInvocation",
2137
+ "s3:PutObject",
2138
+ "s3:GetObject",
2139
+ "kms:Decrypt",
2140
+ "kms:GenerateDataKey"
2141
+ ],
2142
+ Resource: "*"
2143
+ }
2144
+ ]
2145
+ })
2146
+ })
2147
+
2148
+ role.arn
2149
+ end
2150
+
2151
+ def create_forensics_bucket(name, attrs, resources)
2152
+ bucket_name = component_resource_name(name, :forensics_bucket)
2153
+ bucket = create_secure_bucket(
2154
+ bucket_name,
2155
+ "siem-forensics-#{name}",
2156
+ attrs,
2157
+ resources
2158
+ )
2159
+
2160
+ resources[:s3_buckets][:forensics] = bucket
2161
+ bucket.id
2162
+ end
2163
+
2164
+ def create_response_lambda(name, attrs, resources)
2165
+ lambda_name = component_resource_name(name, :response_lambda)
2166
+ lambda = aws_lambda_function(lambda_name, {
2167
+ function_name: "siem-response-#{name}",
2168
+ runtime: "python3.11",
2169
+ handler: "index.lambda_handler",
2170
+ role: create_lambda_execution_role(name, "response", attrs, resources),
2171
+ timeout: 300,
2172
+
2173
+ code: {
2174
+ zip_file: <<~PYTHON
2175
+ import json
2176
+
2177
+ def lambda_handler(event, context):
2178
+ severity = event.get('severity')
2179
+ incident = event.get('incident', {})
2180
+
2181
+ # Execute response based on severity
2182
+ if severity == 'high':
2183
+ response = execute_high_severity_response(incident)
2184
+ elif severity == 'medium':
2185
+ response = execute_medium_severity_response(incident)
2186
+ else:
2187
+ response = execute_low_severity_response(incident)
2188
+
2189
+ return {
2190
+ 'statusCode': 200,
2191
+ 'body': json.dumps(response)
2192
+ }
2193
+
2194
+ def execute_high_severity_response(incident):
2195
+ # Implement high severity response
2196
+ return {
2197
+ 'actions_taken': [
2198
+ 'blocked_suspicious_ips',
2199
+ 'disabled_compromised_accounts',
2200
+ 'initiated_forensics_collection'
2201
+ ]
2202
+ }
2203
+
2204
+ def execute_medium_severity_response(incident):
2205
+ # Implement medium severity response
2206
+ return {
2207
+ 'actions_taken': [
2208
+ 'increased_monitoring',
2209
+ 'notified_security_team'
2210
+ ]
2211
+ }
2212
+
2213
+ def execute_low_severity_response(incident):
2214
+ # Implement low severity response
2215
+ return {
2216
+ 'actions_taken': [
2217
+ 'logged_incident',
2218
+ 'updated_metrics'
2219
+ ]
2220
+ }
2221
+ PYTHON
2222
+ },
2223
+
2224
+ tags: component_tags('siem_security_platform', name, attrs.tags)
2225
+ })
2226
+
2227
+ resources[:lambda_functions][:response] = lambda
2228
+ lambda.arn
2229
+ end
2230
+
2231
+ def create_ticketing_lambda(name, attrs, resources)
2232
+ lambda_name = component_resource_name(name, :ticketing_lambda)
2233
+ lambda = aws_lambda_function(lambda_name, {
2234
+ function_name: "siem-ticketing-#{name}",
2235
+ runtime: "python3.11",
2236
+ handler: "index.lambda_handler",
2237
+ role: create_lambda_execution_role(name, "ticketing", attrs, resources),
2238
+ timeout: 60,
2239
+
2240
+ environment: {
2241
+ variables: {
2242
+ INTEGRATIONS: JSON.generate(attrs.integrations.select { |i| i[:type] == 'ticketing' })
2243
+ }
2244
+ },
2245
+
2246
+ code: {
2247
+ zip_file: <<~PYTHON
2248
+ import json
2249
+ import os
2250
+ import requests
2251
+ from datetime import datetime
2252
+
2253
+ def lambda_handler(event, context):
2254
+ action = event.get('action')
2255
+ incident = event.get('incident', {})
2256
+
2257
+ if action == 'create_ticket':
2258
+ ticket = create_incident_ticket(incident)
2259
+ else:
2260
+ ticket = {'error': 'Unknown action'}
2261
+
2262
+ return {
2263
+ 'statusCode': 200,
2264
+ 'body': json.dumps(ticket)
2265
+ }
2266
+
2267
+ def create_incident_ticket(incident):
2268
+ integrations = json.loads(os.environ.get('INTEGRATIONS', '[]'))
2269
+
2270
+ ticket = {
2271
+ 'title': f"Security Incident: {incident.get('name', 'Unknown')}",
2272
+ 'description': format_incident_description(incident),
2273
+ 'severity': incident.get('severity', 'medium'),
2274
+ 'created_at': datetime.utcnow().isoformat(),
2275
+ 'incident_id': incident.get('id')
2276
+ }
2277
+
2278
+ # Send to configured ticketing systems
2279
+ for integration in integrations:
2280
+ if integration.get('enabled', True):
2281
+ send_to_ticketing_system(ticket, integration)
2282
+
2283
+ return ticket
2284
+
2285
+ def format_incident_description(incident):
2286
+ description = f"""
2287
+ Incident ID: {incident.get('id')}
2288
+ Severity: {incident.get('severity', 'unknown').upper()}
2289
+ Time: {incident.get('timestamp')}
2290
+
2291
+ Description: {incident.get('description', 'No description provided')}
2292
+
2293
+ Affected Resources:
2294
+ """
2295
+
2296
+ for resource in incident.get('affected_resources', []):
2297
+ description += f"\\n- {resource.get('type')}: {resource.get('id')}"
2298
+
2299
+ description += f"\\n\\nIndicators: {len(incident.get('indicators', []))}"
2300
+ description += f"\\nActions Taken: {', '.join(incident.get('actions_taken', []))}"
2301
+
2302
+ return description
2303
+
2304
+ def send_to_ticketing_system(ticket, integration):
2305
+ # Implement integration with ticketing systems
2306
+ # This is a placeholder - real implementation would use actual APIs
2307
+ endpoint = integration.get('endpoint')
2308
+
2309
+ if endpoint:
2310
+ try:
2311
+ response = requests.post(
2312
+ endpoint,
2313
+ json=ticket,
2314
+ headers={'Authorization': f"Bearer {get_api_key(integration)}"},
2315
+ timeout=30
2316
+ )
2317
+ return response.json()
2318
+ except Exception as e:
2319
+ print(f"Error sending to ticketing system: {str(e)}")
2320
+
2321
+ return None
2322
+
2323
+ def get_api_key(integration):
2324
+ # Retrieve API key from Secrets Manager
2325
+ # This is simplified - real implementation would use boto3
2326
+ return "placeholder-api-key"
2327
+ PYTHON
2328
+ },
2329
+
2330
+ tags: component_tags('siem_security_platform', name, attrs.tags)
2331
+ })
2332
+
2333
+ resources[:lambda_functions][:ticketing] = lambda
2334
+ lambda.arn
2335
+ end
2336
+
2337
+ def create_playbook_execution(name, playbook, attrs, resources)
2338
+ # Create Lambda for playbook execution
2339
+ playbook_lambda_name = component_resource_name(name, :playbook, playbook[:name])
2340
+
2341
+ resources[:lambda_functions][:"playbook_#{playbook[:name]}"] = aws_lambda_function(playbook_lambda_name, {
2342
+ function_name: "siem-playbook-#{name}-#{playbook[:name]}",
2343
+ runtime: "python3.11",
2344
+ handler: "index.lambda_handler",
2345
+ role: create_lambda_execution_role(name, "playbook-#{playbook[:name]}", attrs, resources),
2346
+ timeout: 900,
2347
+
2348
+ environment: {
2349
+ variables: {
2350
+ PLAYBOOK_NAME: playbook[:name],
2351
+ PLAYBOOK_STEPS: JSON.generate(playbook[:steps])
2352
+ }
2353
+ },
2354
+
2355
+ code: {
2356
+ zip_file: generate_playbook_code(playbook)
2357
+ },
2358
+
2359
+ tags: component_tags('siem_security_platform', name, attrs.tags)
2360
+ })
2361
+ end
2362
+
2363
+ def generate_playbook_code(playbook)
2364
+ <<~PYTHON
2365
+ import json
2366
+ import os
2367
+ import boto3
2368
+
2369
+ def lambda_handler(event, context):
2370
+ playbook_name = os.environ['PLAYBOOK_NAME']
2371
+ steps = json.loads(os.environ['PLAYBOOK_STEPS'])
2372
+
2373
+ results = []
2374
+ for step in steps:
2375
+ result = execute_step(step, event)
2376
+ results.append(result)
2377
+
2378
+ # Stop if step fails and is marked as critical
2379
+ if not result['success'] and step.get('critical', False):
2380
+ break
2381
+
2382
+ return {
2383
+ 'statusCode': 200,
2384
+ 'body': json.dumps({
2385
+ 'playbook': playbook_name,
2386
+ 'results': results
2387
+ })
2388
+ }
2389
+
2390
+ def execute_step(step, context):
2391
+ step_type = step.get('type')
2392
+
2393
+ if step_type == 'notify':
2394
+ return notify_step(step, context)
2395
+ elif step_type == 'isolate':
2396
+ return isolate_step(step, context)
2397
+ elif step_type == 'block':
2398
+ return block_step(step, context)
2399
+ elif step_type == 'collect':
2400
+ return collect_step(step, context)
2401
+ elif step_type == 'analyze':
2402
+ return analyze_step(step, context)
2403
+ else:
2404
+ return {'success': False, 'error': 'Unknown step type'}
2405
+
2406
+ def notify_step(step, context):
2407
+ # Implement notification logic
2408
+ return {'success': True, 'action': 'notified', 'details': step}
2409
+
2410
+ def isolate_step(step, context):
2411
+ # Implement isolation logic
2412
+ return {'success': True, 'action': 'isolated', 'details': step}
2413
+
2414
+ def block_step(step, context):
2415
+ # Implement blocking logic
2416
+ return {'success': True, 'action': 'blocked', 'details': step}
2417
+
2418
+ def collect_step(step, context):
2419
+ # Implement collection logic
2420
+ return {'success': True, 'action': 'collected', 'details': step}
2421
+
2422
+ def analyze_step(step, context):
2423
+ # Implement analysis logic
2424
+ return {'success': True, 'action': 'analyzed', 'details': step}
2425
+ PYTHON
2426
+ end
2427
+
2428
+ def create_monitoring(name, attrs, resources)
2429
+ # Create CloudWatch dashboard
2430
+ dashboard_name = component_resource_name(name, :dashboard)
2431
+
2432
+ dashboard_body = {
2433
+ widgets: [
2434
+ {
2435
+ type: "metric",
2436
+ properties: {
2437
+ metrics: [
2438
+ ["AWS/ES", "ClusterUsedSpace", { stat: "Average" }],
2439
+ [".", "ClusterIndexWritesBlocked", { stat: "Sum" }],
2440
+ [".", "ClusterStatus.green", { stat: "Average" }]
2441
+ ],
2442
+ period: 300,
2443
+ stat: "Average",
2444
+ region: aws_region,
2445
+ title: "OpenSearch Cluster Health"
2446
+ }
2447
+ },
2448
+ {
2449
+ type: "metric",
2450
+ properties: {
2451
+ metrics: [
2452
+ ["AWS/Kinesis/Firehose", "IncomingRecords", { stat: "Sum" }],
2453
+ [".", "DeliveryToElasticsearch.Success", { stat: "Sum" }],
2454
+ [".", "DeliveryToElasticsearch.DataFreshness", { stat: "Average" }]
2455
+ ],
2456
+ period: 300,
2457
+ stat: "Sum",
2458
+ region: aws_region,
2459
+ title: "Data Ingestion Metrics"
2460
+ }
2461
+ }
2462
+ ]
2463
+ }
2464
+
2465
+ aws_cloudwatch_dashboard(dashboard_name, {
2466
+ dashboard_name: "siem-#{name}",
2467
+ dashboard_body: JSON.pretty_generate(dashboard_body)
2468
+ })
2469
+
2470
+ # Create alarms for critical metrics
2471
+ create_siem_alarms(name, attrs, resources)
2472
+ end
2473
+
2474
+ def create_siem_alarms(name, attrs, resources)
2475
+ # OpenSearch cluster health alarm
2476
+ cluster_health_alarm = component_resource_name(name, :cluster_health_alarm)
2477
+ resources[:alarms][:cluster_health] = aws_cloudwatch_metric_alarm(cluster_health_alarm, {
2478
+ alarm_name: "siem-cluster-health-#{name}",
2479
+ alarm_description: "Alert when OpenSearch cluster is not green",
2480
+ metric_name: "ClusterStatus.green",
2481
+ namespace: "AWS/ES",
2482
+ statistic: "Average",
2483
+ period: 300,
2484
+ evaluation_periods: 2,
2485
+ threshold: 1,
2486
+ comparison_operator: "LessThanThreshold",
2487
+ dimensions: {
2488
+ DomainName: resources[:opensearch_domain].domain_name
2489
+ },
2490
+ alarm_actions: [resources[:sns_topics][:alerts].arn],
2491
+ tags: component_tags('siem_security_platform', name, attrs.tags)
2492
+ })
2493
+
2494
+ # Data freshness alarm
2495
+ data_freshness_alarm = component_resource_name(name, :data_freshness_alarm)
2496
+ resources[:alarms][:data_freshness] = aws_cloudwatch_metric_alarm(data_freshness_alarm, {
2497
+ alarm_name: "siem-data-freshness-#{name}",
2498
+ alarm_description: "Alert when data ingestion is delayed",
2499
+ metric_name: "DeliveryToElasticsearch.DataFreshness",
2500
+ namespace: "AWS/Kinesis/Firehose",
2501
+ statistic: "Average",
2502
+ period: 300,
2503
+ evaluation_periods: 2,
2504
+ threshold: 900, # 15 minutes
2505
+ comparison_operator: "GreaterThanThreshold",
2506
+ alarm_actions: [resources[:sns_topics][:alerts].arn],
2507
+ tags: component_tags('siem_security_platform', name, attrs.tags)
2508
+ })
2509
+
2510
+ # High severity incident alarm
2511
+ if attrs.monitoring_config[:create_alarms]
2512
+ incident_alarm = component_resource_name(name, :high_severity_alarm)
2513
+ resources[:alarms][:high_severity] = aws_cloudwatch_metric_alarm(incident_alarm, {
2514
+ alarm_name: "siem-high-severity-incidents-#{name}",
2515
+ alarm_description: "Alert on high severity security incidents",
2516
+ metric_name: "HighSeverityIncidents",
2517
+ namespace: "Custom/SIEM",
2518
+ statistic: "Sum",
2519
+ period: 300,
2520
+ evaluation_periods: 1,
2521
+ threshold: 1,
2522
+ comparison_operator: "GreaterThanOrEqualToThreshold",
2523
+ alarm_actions: [resources[:sns_topics][:alerts].arn],
2524
+ tags: component_tags('siem_security_platform', name, attrs.tags)
2525
+ })
2526
+ end
2527
+ end
2528
+
2529
+ def create_dashboards(name, attrs, resources)
2530
+ # Create OpenSearch dashboards via API
2531
+ # This would typically be done after OpenSearch is deployed
2532
+ # For now, we'll create a Lambda to configure dashboards
2533
+
2534
+ dashboard_config_lambda = component_resource_name(name, :dashboard_config)
2535
+ resources[:lambda_functions][:dashboard_config] = aws_lambda_function(dashboard_config_lambda, {
2536
+ function_name: "siem-dashboard-config-#{name}",
2537
+ runtime: "python3.11",
2538
+ handler: "index.lambda_handler",
2539
+ role: create_lambda_execution_role(name, "dashboard-config", attrs, resources),
2540
+ timeout: 300,
2541
+
2542
+ environment: {
2543
+ variables: {
2544
+ OPENSEARCH_ENDPOINT: resources[:opensearch_domain].endpoint,
2545
+ DASHBOARDS: JSON.generate(attrs.dashboards)
2546
+ }
2547
+ },
2548
+
2549
+ code: {
2550
+ zip_file: generate_dashboard_config_code()
2551
+ },
2552
+
2553
+ tags: component_tags('siem_security_platform', name, attrs.tags)
2554
+ })
2555
+
2556
+ # Invoke Lambda to configure dashboards
2557
+ aws_lambda_invocation(:"#{dashboard_config_lambda}_invoke", {
2558
+ function_name: resources[:lambda_functions][:dashboard_config].function_name,
2559
+ input: JSON.generate({ action: "configure_dashboards" })
2560
+ })
2561
+ end
2562
+
2563
+ def generate_dashboard_config_code
2564
+ <<~PYTHON
2565
+ import json
2566
+ import os
2567
+ from opensearchpy import OpenSearch
2568
+
2569
+ def lambda_handler(event, context):
2570
+ es = OpenSearch(
2571
+ hosts=[{'host': os.environ['OPENSEARCH_ENDPOINT'], 'port': 443}],
2572
+ http_auth=get_auth(),
2573
+ use_ssl=True,
2574
+ verify_certs=True
2575
+ )
2576
+
2577
+ dashboards = json.loads(os.environ['DASHBOARDS'])
2578
+
2579
+ for dashboard in dashboards:
2580
+ create_dashboard(es, dashboard)
2581
+
2582
+ return {
2583
+ 'statusCode': 200,
2584
+ 'body': json.dumps({
2585
+ 'dashboards_created': len(dashboards)
2586
+ })
2587
+ }
2588
+
2589
+ def create_dashboard(es, dashboard):
2590
+ dashboard_type = dashboard['type']
2591
+
2592
+ if dashboard_type == 'security_overview':
2593
+ create_security_overview_dashboard(es, dashboard)
2594
+ elif dashboard_type == 'threat_hunting':
2595
+ create_threat_hunting_dashboard(es, dashboard)
2596
+ elif dashboard_type == 'compliance':
2597
+ create_compliance_dashboard(es, dashboard)
2598
+ elif dashboard_type == 'incident_response':
2599
+ create_incident_response_dashboard(es, dashboard)
2600
+
2601
+ def create_security_overview_dashboard(es, config):
2602
+ # Create security overview visualizations and dashboard
2603
+ visualizations = [
2604
+ create_events_timeline(es),
2605
+ create_severity_distribution(es),
2606
+ create_top_threats(es),
2607
+ create_geographic_map(es)
2608
+ ]
2609
+
2610
+ # Create dashboard with visualizations
2611
+ dashboard_body = {
2612
+ 'title': config['name'],
2613
+ 'panels': format_panels(visualizations),
2614
+ 'refresh_interval': config.get('refresh_interval', 300)
2615
+ }
2616
+
2617
+ # Save dashboard
2618
+ es.index(
2619
+ index='.kibana',
2620
+ doc_type='dashboard',
2621
+ id=f"dashboard-{config['name'].replace(' ', '-').lower()}",
2622
+ body=dashboard_body
2623
+ )
2624
+
2625
+ def create_threat_hunting_dashboard(es, config):
2626
+ # Implement threat hunting dashboard
2627
+ pass
2628
+
2629
+ def create_compliance_dashboard(es, config):
2630
+ # Implement compliance dashboard
2631
+ pass
2632
+
2633
+ def create_incident_response_dashboard(es, config):
2634
+ # Implement incident response dashboard
2635
+ pass
2636
+
2637
+ def create_events_timeline(es):
2638
+ # Create timeline visualization
2639
+ return {
2640
+ 'title': 'Security Events Timeline',
2641
+ 'type': 'line',
2642
+ 'query': {
2643
+ 'match_all': {}
2644
+ }
2645
+ }
2646
+
2647
+ def create_severity_distribution(es):
2648
+ # Create severity distribution visualization
2649
+ return {
2650
+ 'title': 'Severity Distribution',
2651
+ 'type': 'pie',
2652
+ 'query': {
2653
+ 'terms': {
2654
+ 'field': 'severity.keyword'
2655
+ }
2656
+ }
2657
+ }
2658
+
2659
+ def create_top_threats(es):
2660
+ # Create top threats visualization
2661
+ return {
2662
+ 'title': 'Top Threats',
2663
+ 'type': 'horizontal_bar',
2664
+ 'query': {
2665
+ 'terms': {
2666
+ 'field': 'threat_name.keyword',
2667
+ 'size': 10
2668
+ }
2669
+ }
2670
+ }
2671
+
2672
+ def create_geographic_map(es):
2673
+ # Create geographic threat map
2674
+ return {
2675
+ 'title': 'Threat Geographic Distribution',
2676
+ 'type': 'map',
2677
+ 'query': {
2678
+ 'exists': {
2679
+ 'field': 'source_geo.location'
2680
+ }
2681
+ }
2682
+ }
2683
+
2684
+ def format_panels(visualizations):
2685
+ # Format visualizations as dashboard panels
2686
+ panels = []
2687
+ for i, viz in enumerate(visualizations):
2688
+ panels.append({
2689
+ 'visualization': viz,
2690
+ 'gridData': {
2691
+ 'x': (i % 2) * 24,
2692
+ 'y': (i // 2) * 12,
2693
+ 'w': 24,
2694
+ 'h': 12
2695
+ }
2696
+ })
2697
+ return panels
2698
+
2699
+ def get_auth():
2700
+ # Implement authentication
2701
+ return None
2702
+ PYTHON
2703
+ end
2704
+
2705
+ def create_integration(name, integration, attrs, resources)
2706
+ # Create integration based on type
2707
+ case integration[:type]
2708
+ when 'soar'
2709
+ create_soar_integration(name, integration, attrs, resources)
2710
+ when 'threat_intel'
2711
+ create_threat_intel_integration(name, integration, attrs, resources)
2712
+ when 'notification'
2713
+ create_notification_integration(name, integration, attrs, resources)
2714
+ end
2715
+ end
2716
+
2717
+ def create_soar_integration(name, integration, attrs, resources)
2718
+ # Create Lambda for SOAR integration
2719
+ lambda_name = component_resource_name(name, :soar_integration, integration[:name])
2720
+
2721
+ resources[:lambda_functions][:"soar_#{integration[:name]}"] = aws_lambda_function(lambda_name, {
2722
+ function_name: "siem-soar-#{name}-#{integration[:name]}",
2723
+ runtime: "python3.11",
2724
+ handler: "index.lambda_handler",
2725
+ role: create_lambda_execution_role(name, "soar-#{integration[:name]}", attrs, resources),
2726
+ timeout: 300,
2727
+
2728
+ environment: {
2729
+ variables: {
2730
+ SOAR_ENDPOINT: integration[:endpoint] || "",
2731
+ SOAR_API_KEY_SECRET: integration[:api_key_secret_arn] || ""
2732
+ }
2733
+ },
2734
+
2735
+ code: {
2736
+ zip_file: <<~PYTHON
2737
+ import json
2738
+ import boto3
2739
+ import os
2740
+ import requests
2741
+
2742
+ def lambda_handler(event, context):
2743
+ # Send incident to SOAR platform
2744
+ incident = event.get('incident', {})
2745
+
2746
+ soar_payload = {
2747
+ 'name': incident.get('name'),
2748
+ 'severity': incident.get('severity'),
2749
+ 'description': incident.get('description'),
2750
+ 'artifacts': incident.get('indicators', []),
2751
+ 'actions': incident.get('recommended_actions', [])
2752
+ }
2753
+
2754
+ # Send to SOAR
2755
+ response = send_to_soar(soar_payload)
2756
+
2757
+ return {
2758
+ 'statusCode': 200,
2759
+ 'body': json.dumps(response)
2760
+ }
2761
+
2762
+ def send_to_soar(payload):
2763
+ endpoint = os.environ.get('SOAR_ENDPOINT')
2764
+ api_key = get_api_key()
2765
+
2766
+ if endpoint and api_key:
2767
+ try:
2768
+ response = requests.post(
2769
+ f"{endpoint}/api/incidents",
2770
+ json=payload,
2771
+ headers={'Authorization': f'Bearer {api_key}'},
2772
+ timeout=30
2773
+ )
2774
+ return response.json()
2775
+ except Exception as e:
2776
+ return {'error': str(e)}
2777
+
2778
+ return {'error': 'Missing configuration'}
2779
+
2780
+ def get_api_key():
2781
+ secret_arn = os.environ.get('SOAR_API_KEY_SECRET')
2782
+ if secret_arn:
2783
+ client = boto3.client('secretsmanager')
2784
+ response = client.get_secret_value(SecretId=secret_arn)
2785
+ return json.loads(response['SecretString']).get('api_key')
2786
+ return None
2787
+ PYTHON
2788
+ },
2789
+
2790
+ tags: component_tags('siem_security_platform', name, attrs.tags)
2791
+ })
2792
+ end
2793
+
2794
+ def create_threat_intel_integration(name, integration, attrs, resources)
2795
+ # Already handled in create_threat_detection
2796
+ end
2797
+
2798
+ def create_notification_integration(name, integration, attrs, resources)
2799
+ # Create SNS topic for notifications if not exists
2800
+ topic_name = component_resource_name(name, :notification, integration[:name])
2801
+ resources[:sns_topics][integration[:name].to_sym] = aws_sns_topic(topic_name, {
2802
+ name: "siem-notify-#{name}-#{integration[:name]}",
2803
+ kms_master_key_id: resources[:kms_keys][:main].id,
2804
+ tags: component_tags('siem_security_platform', name, attrs.tags)
2805
+ })
2806
+
2807
+ # Subscribe endpoint if provided
2808
+ if integration[:endpoint]
2809
+ aws_sns_topic_subscription(:"#{topic_name}_subscription", {
2810
+ topic_arn: resources[:sns_topics][integration[:name].to_sym].arn,
2811
+ protocol: integration[:endpoint].start_with?('http') ? 'https' : 'email',
2812
+ endpoint: integration[:endpoint]
2813
+ })
2814
+ end
2815
+ end
2816
+
2817
+ def calculate_siem_security_score(attrs)
2818
+ score = 100
2819
+
2820
+ # Deduct points for missing features
2821
+ score -= 5 unless attrs.threat_detection[:enable_ml_detection]
2822
+ score -= 5 unless attrs.threat_detection[:enable_behavior_analytics]
2823
+ score -= 5 unless attrs.incident_response[:enable_automated_response]
2824
+ score -= 5 unless attrs.compliance_config[:enable_compliance_reporting]
2825
+ score -= 5 unless attrs.security_config[:enable_encryption_at_rest]
2826
+ score -= 5 unless attrs.security_config[:enable_fine_grained_access]
2827
+ score -= 10 unless attrs.threat_detection[:threat_intel_feeds].any?
2828
+
2829
+ # Add points for advanced features
2830
+ score += 5 if attrs.analytics_config[:enable_ueba]
2831
+ score += 5 if attrs.incident_response[:enable_forensics_collection]
2832
+ score += 5 if attrs.scaling_config[:enable_auto_scaling]
2833
+
2834
+ [score, 100].min
2835
+ end
2836
+
2837
+ def generate_siem_compliance_status(attrs)
2838
+ status = {}
2839
+
2840
+ attrs.compliance_config[:frameworks].each do |framework|
2841
+ status[framework] = {
2842
+ compliant: true,
2843
+ last_assessment: Time.now.iso8601,
2844
+ evidence_collected: attrs.compliance_config[:evidence_collection],
2845
+ report_available: attrs.compliance_config[:enable_compliance_reporting],
2846
+ next_report: calculate_next_report_date(attrs.compliance_config[:report_schedule])
2847
+ }
2848
+ end
2849
+
2850
+ status
2851
+ end
2852
+
2853
+ def calculate_next_report_date(schedule)
2854
+ case schedule
2855
+ when 'daily'
2856
+ (Time.now + 86400).iso8601
2857
+ when 'weekly'
2858
+ (Time.now + 604800).iso8601
2859
+ when 'monthly'
2860
+ (Time.now + 2592000).iso8601
2861
+ else
2862
+ nil
2863
+ end
2864
+ end
2865
+
2866
+ def aws_region
2867
+ 'us-east-1'
2868
+ end
2869
+
2870
+ def aws_account_id
2871
+ '123456789012'
2872
+ end
2873
+
2874
+ include Base
2875
+ end
2876
+ end
2877
+ end