fix-docker-latest.sh 1.4 KB

123456789101112131415161718192021222324252627282930313233343536373839
  1. #!/bin/bash
  2. IMAGE="1.7.0"
  3. if [ $# -eq 0 ]
  4. then
  5. echo "Please Specify the release tag (i.e. 1.7.0)"
  6. exit 1
  7. fi
  8. while [[ $# -gt 0 ]]
  9. do
  10. key="$1"
  11. case $key in
  12. --release-tag)
  13. shift
  14. IMAGE=$1
  15. ;;
  16. *)
  17. echo "Usage: fix-docker-latest.sh --release-tag <TAG>"
  18. exit 1
  19. esac
  20. shift
  21. done
  22. ASSUME_ROLE_CREDENTIALS=$(aws sts assume-role --role-arn arn:aws:iam::"$(aws sts get-caller-identity | jq -r .Account)":role/InvokeDockerTagLatest --role-session-name push_latest)
  23. AWS_ACCESS_KEY_ID=$(echo "$ASSUME_ROLE_CREDENTIALS" | jq -r .Credentials.AccessKeyId)
  24. AWS_SECRET_ACCESS_KEY=$(echo "$ASSUME_ROLE_CREDENTIALS" | jq -r .Credentials.SecretAccessKey)
  25. AWS_SESSION_TOKEN=$(echo "$ASSUME_ROLE_CREDENTIALS" | jq -r .Credentials.SessionToken)
  26. echo -e "Invoking this lambda!\nView logs at https://us-west-2.console.aws.amazon.com/cloudwatch/home?region=us-west-2#logsV2:log-groups"
  27. AWS_ACCESS_KEY_ID=$AWS_ACCESS_KEY_ID AWS_SECRET_ACCESS_KEY=$AWS_SECRET_ACCESS_KEY AWS_SESSION_TOKEN=$AWS_SESSION_TOKEN AWS_SECURITY_TOKEN='' aws \
  28. lambda invoke --function-name DockerTagLatest \
  29. --cli-binary-format raw-in-base64-out \
  30. --cli-read-timeout 600 \
  31. --payload "{\"source_tag\" : \"$IMAGE\", \"destination_tag\" : \"latest\"}" /dev/stdout
  32. echo -e "Please check logs before rerunning!!!!\n\nAt the time of writing, Autoscaler Images are not built.\nSo retagging errors for those images are expected!"