Sha256: 5fe82cb32c334aefaddd0817ba8450d05524b6c4fd01e55f87846128259a0957

Contents?: true

Size: 1.16 KB

Versions: 4

Compression:

Stored size: 1.16 KB

Contents

module Jets::Resource::Iam
  module BaseRoleDefinition
    attr_reader :policy_definitions, :managed_policy_definitions

    def definition
      logical_id = role_logical_id

      # Do not assign pretty role_name because long controller names might hit the 64-char
      # limit. Also, IAM roles are global, so assigning role names prevents cross region deploys.
      definition = {
        logical_id => {
          type: "AWS::IAM::Role",
          properties: {
            path: "/",
            assume_role_policy_document: {
              version: "2012-10-17",
              statement: [{
                effect: "Allow",
                principal: {service: ["lambda.amazonaws.com"]},
                action: ["sts:AssumeRole"]}
              ]
            }
          }
        }
      }

      unless managed_policy_arns.empty?
        definition[logical_id][:properties][:managed_policy_arns] = managed_policy_arns
      end

      definition
    end

    def policy_document
      PolicyDocument.new(@policy_definitions.flatten.uniq).policy_document
    end

    def managed_policy_arns
      ManagedPolicy.new(@managed_policy_definitions.flatten.uniq).arns
    end
  end
end

Version data entries

4 entries across 4 versions & 1 rubygems

Version Path
jets-4.0.3 lib/jets/resource/iam/base_role_definition.rb
jets-4.0.2 lib/jets/resource/iam/base_role_definition.rb
jets-4.0.1 lib/jets/resource/iam/base_role_definition.rb
jets-4.0.0 lib/jets/resource/iam/base_role_definition.rb