class Terraforming::Resource::IAMRolePolicy

Public Class Methods

new(client) click to toggle source
# File lib/terraforming/resource/iam_role_policy.rb, line 14
def initialize(client)
  @client = client
end
tf(client: Aws::IAM::Client.new) click to toggle source
# File lib/terraforming/resource/iam_role_policy.rb, line 6
def self.tf(client: Aws::IAM::Client.new)
  self.new(client).tf
end
tfstate(client: Aws::IAM::Client.new) click to toggle source
# File lib/terraforming/resource/iam_role_policy.rb, line 10
def self.tfstate(client: Aws::IAM::Client.new)
  self.new(client).tfstate
end

Public Instance Methods

tf() click to toggle source
# File lib/terraforming/resource/iam_role_policy.rb, line 18
def tf
  apply_template(@client, "tf/iam_role_policy")
end
tfstate() click to toggle source
# File lib/terraforming/resource/iam_role_policy.rb, line 22
def tfstate
  iam_role_policies.inject({}) do |resources, policy|
    attributes = {
      "id" => iam_role_policy_id_of(policy),
      "name" => policy.policy_name,
      "policy" => prettify_policy(policy.policy_document, breakline: true, unescape: true),
      "role" => policy.role_name,
    }
    resources["aws_iam_role_policy.#{unique_name(policy)}"] = {
      "type" => "aws_iam_role_policy",
      "primary" => {
        "id" => iam_role_policy_id_of(policy),
        "attributes" => attributes
      }
    }

    resources
  end
end

Private Instance Methods

iam_role_policies() click to toggle source
# File lib/terraforming/resource/iam_role_policy.rb, line 64
def iam_role_policies
  iam_roles.map do |role|
    iam_role_policy_names_in(role).map { |policy_name| iam_role_policy_of(role, policy_name) }
  end.flatten
end
iam_role_policy_id_of(policy) click to toggle source
# File lib/terraforming/resource/iam_role_policy.rb, line 48
def iam_role_policy_id_of(policy)
  "#{policy.role_name}:#{policy.policy_name}"
end
iam_role_policy_names_in(role) click to toggle source
# File lib/terraforming/resource/iam_role_policy.rb, line 56
def iam_role_policy_names_in(role)
  @client.list_role_policies(role_name: role.role_name).policy_names
end
iam_role_policy_of(role, policy_name) click to toggle source
# File lib/terraforming/resource/iam_role_policy.rb, line 60
def iam_role_policy_of(role, policy_name)
  @client.get_role_policy(role_name: role.role_name, policy_name: policy_name)
end
iam_roles() click to toggle source
# File lib/terraforming/resource/iam_role_policy.rb, line 52
def iam_roles
  @client.list_roles.map(&:roles).flatten
end
unique_name(policy) click to toggle source
# File lib/terraforming/resource/iam_role_policy.rb, line 44
def unique_name(policy)
  "#{normalize_module_name(policy.role_name)}_#{normalize_module_name(policy.policy_name)}"
end