dtan4/terraforming

View on GitHub
lib/terraforming/resource/db_security_group.rb

Summary

Maintainability
A
0 mins
Test Coverage
module Terraforming
  module Resource
    class DBSecurityGroup
      include Terraforming::Util

      def self.tf(client: Aws::RDS::Client.new)
        self.new(client).tf
      end

      def self.tfstate(client: Aws::RDS::Client.new)
        self.new(client).tfstate
      end

      def initialize(client)
        @client = client
      end

      def tf
        apply_template(@client, "tf/db_security_group")
      end

      def tfstate
        db_security_groups.inject({}) do |resources, security_group|
          attributes = {
            "db_subnet_group_name" => security_group.db_security_group_name,
            "id" => security_group.db_security_group_name,
            "ingress.#" => ingresses_of(security_group).length.to_s,
            "name" => security_group.db_security_group_name,
          }
          resources["aws_db_security_group.#{module_name_of(security_group)}"] = {
            "type" => "aws_db_security_group",
            "primary" => {
              "id" => security_group.db_security_group_name,
              "attributes" => attributes
            }
          }

          resources
        end
      end

      private

      def ingresses_of(security_group)
        security_group.ec2_security_groups + security_group.ip_ranges
      end

      def db_security_groups
        @client.describe_db_security_groups.map(&:db_security_groups).flatten.select { |sg| !ingresses_of(sg).empty? }
      end

      def module_name_of(security_group)
        normalize_module_name(security_group.db_security_group_name)
      end
    end
  end
end