処理の実行
CloudFormationテンプレート共通部分を作成します。
変数の確認:
cat << END
# FILE_CLOUDFORMATION_TEMPLATE:"${HOME}/environment/conf-handson-cli-cfn-iam-ManagedPolicy/handson-cli-cfn-iam-ManagedPolicy.template"
FILE_CLOUDFORMATION_TEMPLATE="${FILE_CLOUDFORMATION_TEMPLATE}"
# CLOUDFORMATION_TEMPLATE_DESCRIPTION:"Template for handson-cli-cfn-iam-ManagedPolicy."
CLOUDFORMATION_TEMPLATE_DESCRIPTION="${CLOUDFORMATION_TEMPLATE_DESCRIPTION}"
END
コマンド:
cat << EOF > ${FILE_CLOUDFORMATION_TEMPLATE}
AWSTemplateFormatVersion: 2010-09-09
Description:
${CLOUDFORMATION_TEMPLATE_DESCRIPTION}
EOF
cat ${FILE_CLOUDFORMATION_TEMPLATE}
結果(例):
AWSTemplateFormatVersion: 2010-09-09
Description:
Template for handson-cli-cfn-iam-ManagedPolicy.
CloudFormationテンプレートにリソース部分を追加します。
コマンド:
echo 'Resources:' >> ${FILE_CLOUDFORMATION_TEMPLATE}
for i in $( ls ${DIR_CLOUDFORMATION_RESOURCE}/*.txt ); do \
cat $i | sed '/^$/d' >> ${FILE_CLOUDFORMATION_TEMPLATE}; \
echo '' >> ${FILE_CLOUDFORMATION_TEMPLATE} \
; done
cat ${FILE_CLOUDFORMATION_TEMPLATE}
結果(例):
AWSTemplateFormatVersion: 2010-09-09
Description:
Template for handson-cli-cfn-iam-managedpolicy.
Resources:
Policy0Named:
Type: AWS::IAM::ManagedPolicy
Properties:
Description: Policy for handson-cli-cfn-iam-managedpolicy.
ManagedPolicyName: handson-cli-cfn-iam-managedpolicy-policy
Path: /handson-cli/
PolicyDocument:
Statement:
- Effect: "Allow"
Action: "iam:ListUsers"
Resource: "*"
Version: "2012-10-17"
Policy0StackName:
Type: AWS::IAM::ManagedPolicy
Properties:
Description: Policy for handson-cli-cfn-iam-managedpolicy.
ManagedPolicyName: !Ref AWS::StackName
Path: /handson-cli/
PolicyDocument:
Statement:
- Effect: "Allow"
Action: "iam:ListUsers"
Resource: "*"
Version: "2012-10-17"
Policy0:
Type: AWS::IAM::ManagedPolicy
Properties:
Description: "Policy for handson-cli-cfn-iam-managedpolicy."
Path: "/handson-cli/"
PolicyDocument:
Statement:
- Effect: "Allow"
Action: "iam:ListUsers"
Resource: "*"
Version: "2012-10-17"
完了確認
本手順の主処理は、以下の完了条件を満たしたときに成功したものとします。
完了条件1: CloudFormationテンプレート"handson-cli-cfn-iam-ManagedPolicy"が存在する。
「CloudFormationテンプレート"handson-cli-cfn-iam-ManagedPolicy"が存在する。」ことを確認します。
コマンド:
ls ${FILE_CLOUDFORMATION_TEMPLATE}
結果(例):
${HOME}/environment/conf-handson-cli-cfn-iam-ManagedPolicy/handson-cli-cfn-iam-ManagedPolicy.template
完了条件2: CloudFormationテンプレート"handson-cli-cfn-iam-ManagedPolicy"がYAMLフォーマットとして正常である。
「CloudFormationテンプレート"handson-cli-cfn-iam-ManagedPolicy"がYAMLフォーマットとして正常である。」ことを確認します。
コマンド:
yamllint ${FILE_CLOUDFORMATION_TEMPLATE}
結果(例):