AWSTemplateFormatVersion: "2010-09-09" Description: > This CloudFormation template creates a role assumed by CloudFormation during CRUDL operations to mutate resources on behalf of the customer. Resources: ExecutionRole: Type: AWS::IAM::Role Properties: MaxSessionDuration: 8400 AssumeRolePolicyDocument: Version: '2012-10-17' Statement: - Effect: Allow Principal: Service: resources.cloudformation.amazonaws.com Action: sts:AssumeRole Condition: StringEquals: aws:SourceAccount: Ref: AWS::AccountId StringLike: aws:SourceArn: Fn::Sub: arn:${AWS::Partition}:cloudformation:${AWS::Region}:${AWS::AccountId}:type/resource/AWS-ResilienceHub-App/* Path: "/" Policies: - PolicyName: ResourceTypePolicy PolicyDocument: Version: '2012-10-17' Statement: - Effect: Allow Action: - "apigateway:GET" - "autoscaling:DescribeAutoScalingGroups" - "cloudformation:DescribeStacks" - "cloudformation:ListStackResources" - "dynamodb:Describe*" - "ec2:Describe*" - "ecs:DescribeServices" - "eks:DescribeCluster" - "elasticfilesystem:DescribeFileSystems" - "elasticloadbalancing:DescribeLoadBalancers" - "lambda:GetFunction" - "rds:Describe*" - "resiliencehub:*" - "resiliencehub:DeleteApp" - "resiliencehub:DescribeApp" - "resiliencehub:DescribeAppVersionTemplate" - "resiliencehub:ListAppVersionResourceMappings" - "resiliencehub:ListApps" - "resiliencehub:ListTagsForResource" - "resiliencehub:UntagResource" - "route53:List*" - "s3:GetBucketLocation" - "s3:GetObject" - "s3:ListAllMyBuckets" - "sns:GetTopicAttributes" - "sqs:GetQueueAttributes" Resource: "*" Outputs: ExecutionRoleArn: Value: Fn::GetAtt: ExecutionRole.Arn