# frozen_string_literal: true module Awspec::Type class Rds < ResourceBase aws_resource Aws::RDS::DBInstance def resource_via_client @resource_via_client ||= find_rds(@display_name) end def id @id ||= resource_via_client.db_instance_identifier if resource_via_client end STATES = %w[ available backing-up creating deleting failed inaccessible-encryption-credentials incompatible-credentials incompatible-network incompatible-option-group incompatible-parameters incompatible-restore maintenance modifying rebooting renaming resetting-master-credentials restore-error storage-full upgrading ] STATES.each do |state| define_method "#{state.tr('-', '_')}?" do resource_via_client.db_instance_status == state end end def vpc_id resource_via_client.db_subnet_group.vpc_id end def has_security_group?(sg_id) return true if has_vpc_security_group_id?(sg_id) return true if has_vpc_security_group_name?(sg_id) return true if has_vpc_security_group_tag_name?(sg_id) return true if has_db_security_group_name?(sg_id) end def has_db_parameter_group?(name, parameter_apply_status = nil) pgs = resource_via_client.db_parameter_groups pgs.find do |pg| if parameter_apply_status.nil? pg.db_parameter_group_name == name else pg.db_parameter_group_name == name && \ pg.parameter_apply_status == parameter_apply_status end end end def has_option_group?(name, status = nil) ogs = resource_via_client.option_group_memberships ogs.find do |og| if status.nil? og.option_group_name == name else og.option_group_name == name && og.status == status end end end def has_tag?(tag_key, tag_value) arn = resource_via_client.db_instance_arn tag_set = rds_client.list_tags_for_resource({ resource_name: arn }) tag_set.tag_list.find do |tag| tag.key == tag_key && tag.value == tag_value end end private def has_vpc_security_group_id?(sg_id) sgs = resource_via_client.vpc_security_groups sgs.find do |sg| sg.vpc_security_group_id == sg_id end end def has_vpc_security_group_name?(sg_id) sgs = resource_via_client.vpc_security_groups res = ec2_client.describe_security_groups({ filters: [{ name: 'group-name', values: [sg_id] }] }) return false unless res.security_groups.count == 1 sgs.find do |sg| sg.vpc_security_group_id == res.security_groups.first.group_id end end def has_vpc_security_group_tag_name?(sg_id) sgs = resource_via_client.vpc_security_groups res = ec2_client.describe_security_groups({ filters: [{ name: 'tag:Name', values: [sg_id] }] }) return false unless res.security_groups.count == 1 sgs.find do |sg| sg.vpc_security_group_id == res.security_groups.first.group_id end end def has_db_security_group_name?(sg_id) sgs = resource_via_client.db_security_groups sgs.find do |sg| sg.db_security_group_name == sg_id end end end end