ハンズオン(簡易版): S3基礎 通知

1.5. スクリプトファイルの作成 (handson-cli-s3-upload.sh)

目的

スクリプトファイル"handson-cli-s3-upload.sh"を作成します。

パラメータの指定

作業に必要なパラメータを変数に格納をします。

1. プロファイル名

利用するプロファイル名(IAMユーザ名)を指定します。

変数の設定:

IAM_USER_NAME='handson-cli-s3-MaintUser'

2. AWS認証ファイル

AWS認証ファイル名を指定します。

変数の設定:

DIR_CREDENTIAL="${HOME}/environment/credentials-handson-cli-s3-MaintUser"

変数の設定:

FILE_USER_CREDENTIAL="${DIR_CREDENTIAL}/${IAM_USER_NAME}.ini" \
  && echo ${FILE_USER_CREDENTIAL}

結果(例):

${HOME}/environment/credentials-handson-cli-s3-MaintUser/handson-cli-s3-MaintUser.ini

3. S3バケット名

S3バケット名を指定します。

変数の設定:

S3_BUCKET_PREFIX='handson-cli-s3-notification'

コマンド:

AWS_ID=$( \
  aws sts get-caller-identity \
    --query 'Account' \
    --output text \
) \
  && echo ${AWS_ID}

結果(例):

XXXXXXXXXXXX

変数の設定:

S3_BUCKET_NAME="${S3_BUCKET_PREFIX}-${AWS_ID}" \
  && echo ${S3_BUCKET_NAME}

結果(例):

handson-cli-s3-notification-XXXXXXXXXXXX

4. スクリプトファイル用ディレクトリ

スクリプトファイル用ディレクトリを指定します。

変数の設定:

DIR_SCRIPT="${HOME}/environment/conf-handson-cli-s3"

ディレクトリが存在することを確認します。

コマンド:

ls -d ${HOME}/environment/conf-handson-cli-s3

結果(例:存在する場合):

${HOME}/environment/conf-handson-cli-s3

存在しない場合は作成します。

コマンド:

mkdir -p ${HOME}/environment/conf-handson-cli-s3

5. スクリプトファイル名

スクリプトファイル名を指定します。

変数の設定:

FILE_SCRIPT="${DIR_SCRIPT}/handson-cli-s3-upload.sh" \
  && echo ${FILE_SCRIPT}

結果(例):

${HOME}/environment/conf-handson-cli-s3/handson-cli-s3-upload.sh

各変数に正しいパラメータ値が格納されていることを確認します。

変数の確認:

cat << END

  # 1. IAM_USER_NAME:"handson-cli-s3-MaintUser"
       IAM_USER_NAME="${IAM_USER_NAME}"
  # 2. FILE_USER_CREDENTIAL:"${HOME}/environment/credentials-handson-cli-s3-MaintUser/handson-cli-s3-MaintUser.ini"
       FILE_USER_CREDENTIAL="${FILE_USER_CREDENTIAL}"
  # 3. S3_BUCKET_NAME:"handson-cli-s3-notification-XXXXXXXXXXXX"
       S3_BUCKET_NAME="${S3_BUCKET_NAME}"
  # 4. DIR_SCRIPT:"${HOME}/environment/conf-handson-cli-s3"
       DIR_SCRIPT="${DIR_SCRIPT}"
  # 5. FILE_SCRIPT:"${HOME}/environment/conf-handson-cli-s3/handson-cli-s3-upload.sh"
       FILE_SCRIPT="${FILE_SCRIPT}"

END

手順

スクリプトファイルを作成します。

変数の確認:

cat << END

  # IAM_USER_NAME:"handson-cli-s3-MaintUser"
    IAM_USER_NAME="${IAM_USER_NAME}"
  # FILE_USER_CREDENTIAL:"${HOME}/environment/credentials-handson-cli-s3-MaintUser/handson-cli-s3-MaintUser.ini"
    FILE_USER_CREDENTIAL="${FILE_USER_CREDENTIAL}"
  # S3_BUCKET_NAME:"handson-cli-s3-notification-XXXXXXXXXXXX"
    S3_BUCKET_NAME="${S3_BUCKET_NAME}"
  # DIR_SCRIPT:"${HOME}/environment/conf-handson-cli-s3"
    DIR_SCRIPT="${DIR_SCRIPT}"
  # FILE_SCRIPT:"${HOME}/environment/conf-handson-cli-s3/handson-cli-s3-upload.sh"
    FILE_SCRIPT="${FILE_SCRIPT}"

END

コマンド:

cat << EOF > ${FILE_SCRIPT}
#!/bin/sh

set -eu

if [ ! "\$2" ]; then
  echo "Usage: \$0 target_file destination_key"
  exit 1
fi

readonly FILE_TARGET="\$1"
readonly S3_OBJECT_DESTINATION="\$2"
readonly S3_BUCKET_NAME='${S3_BUCKET_NAME}'

export AWS_SHARED_CREDENTIALS_FILE='${FILE_USER_CREDENTIAL}'
export AWS_DEFAULT_PROFILE='${IAM_USER_NAME}'

if [ ! -e "\${FILE_TARGET}" ]; then
  echo "ERROR: \${FILE_TARGET}: No such file."
  exit 1
fi

aws s3 cp \${FILE_TARGET} s3://\${S3_BUCKET_NAME}/\${S3_OBJECT_DESTINATION}

exit \$?
EOF

cat  ${FILE_SCRIPT}

結果(例):

#!/bin/sh

set -eu

if [ ! "$2" ]; then
  echo "Usage: $0 target_file destination_key"
  exit 1
fi

readonly FILE_TARGET="$1"
readonly S3_OBJECT_DESTINATION="$2"
readonly S3_BUCKET_NAME='handson-cli-s3-notification-XXXXXXXXXXXX'

export AWS_SHARED_CREDENTIALS_FILE='${HOME}/environment/credentials-handson-cli-s3-MaintUser/handson-cli-s3-MaintUser.ini'
export AWS_DEFAULT_PROFILE='handson-cli-s3-MaintUser'

if [ ! -e "${FILE_TARGET}" ]; then
  echo "ERROR: ${FILE_TARGET}: No such file."
  exit 1
fi

aws s3 cp ${FILE_TARGET} s3://${S3_BUCKET_NAME}/${S3_OBJECT_DESTINATION}

exit $?

コマンド:

chmod u+x ${FILE_SCRIPT}

結果(例):

(出力なし)

完了確認

「スクリプトファイル"handson-cli-s3-upload.sh"が存在する。」ことを確認します。

コマンド:

ls ${FILE_SCRIPT}

結果(例):

${HOME}/environment/conf-handson-cli-s3/handson-cli-s3-upload.sh