check-docker-pin.sh 1.2 KB

12345678910111213141516171819202122
  1. #!/usr/bin/env bash
  2. # This script is checks to that all our Docker images are pinned to a specific SHA256 hash
  3. #
  4. # References as to why...
  5. # - https://nickjanetakis.com/blog/docker-tip-18-please-pin-your-docker-image-versions
  6. # - https://snyk.io/blog/10-docker-image-security-best-practices/ (Specifically: USE FIXED TAGS FOR IMMUTABILITY)
  7. #
  8. # Explaination of regex ignore choices
  9. # - We ignore sha256 because it suggests that the image dep is pinned
  10. # - We ignore scratch because it's literally the docker base image
  11. # - We ignore solana AS (builder|ci_tests) because it's a relative reference to another FROM call
  12. # - We ignore cosmwasm_artifacts AS artifacts because it's a local reference only, is built in tilt
  13. # - We ignore base AS (ignite-go-build|ignite-vue-build) because the base image is already pinned in wormchain/Dockerfile.proto
  14. #
  15. git ls-files | grep "Dockerfile*" | xargs grep -s "FROM" | egrep -v 'sha256|scratch|solana|aptos|sui|base|cosmwasm_artifacts AS (application|base|builder|ci_tests|tests|artifacts|ignite-go-build|ignite-vue-build)'
  16. if [ $? -eq 0 ]; then
  17. echo "[!] Unpinned docker files" >&2
  18. exit 1
  19. else
  20. echo "[+] No unpinned docker files"
  21. fi