You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

63 lines
2.8 KiB

  1. FROM debian:9
  2. # Configuration version history
  3. # v1.0 - Initial version by Etienne Champetier
  4. # v1.0.1 - Run as non-root, add unzip, xz-utils
  5. # v1.0.2 - Add bzr
  6. # v1.0.3 - Verify usign signatures
  7. # v1.0.4 - Add support for Python3
  8. # v1.0.5 - Add 19.07 public keys, verify keys
  9. RUN apt update && apt install -y \
  10. build-essential \
  11. bzr \
  12. curl \
  13. jq \
  14. gawk \
  15. gettext \
  16. git \
  17. libncurses5-dev \
  18. libssl-dev \
  19. python \
  20. python3 \
  21. signify-openbsd \
  22. subversion \
  23. time \
  24. unzip \
  25. wget \
  26. xz-utils \
  27. zlib1g-dev \
  28. && rm -rf /var/lib/apt/lists/*
  29. RUN useradd -c "OpenWrt Builder" -m -d /home/build -s /bin/bash build
  30. USER build
  31. ENV HOME /home/build
  32. # OpenWrt Build System (PGP key for unattended snapshot builds)
  33. RUN curl 'https://git.openwrt.org/?p=keyring.git;a=blob_plain;f=gpg/626471F1.asc' | gpg --import \
  34. && gpg --fingerprint --with-colons '<pgpsign-snapshots@openwrt.org>' | grep '^fpr:::::::::54CC74307A2C6DC9CE618269CD84BCED626471F1:$' \
  35. && echo '54CC74307A2C6DC9CE618269CD84BCED626471F1:6:' | gpg --import-ownertrust
  36. # OpenWrt Build System (PGP key for 17.01 "Reboot" release builds)
  37. RUN curl 'https://git.openwrt.org/?p=keyring.git;a=blob_plain;f=gpg/D52BBB6B.asc' | gpg --import \
  38. && gpg --fingerprint --with-colons '<pgpsign-17.01@openwrt.org>' | grep '^fpr:::::::::B09BE781AE8A0CD4702FDCD3833C6010D52BBB6B:$' \
  39. && echo 'B09BE781AE8A0CD4702FDCD3833C6010D52BBB6B:6:' | gpg --import-ownertrust
  40. # OpenWrt Release Builder (18.06 Signing Key)
  41. RUN curl 'https://git.openwrt.org/?p=keyring.git;a=blob_plain;f=gpg/17E1CE16.asc' | gpg --import \
  42. && gpg --fingerprint --with-colons '<openwrt-devel@lists.openwrt.org>' | grep '^fpr:::::::::6768C55E79B032D77A28DA5F0F20257417E1CE16:$' \
  43. && echo '6768C55E79B032D77A28DA5F0F20257417E1CE16:6:' | gpg --import-ownertrust
  44. # OpenWrt Build System (PGP key for 19.07 release builds)
  45. RUN curl 'https://git.openwrt.org/?p=keyring.git;a=blob_plain;f=gpg/2074BE7A.asc' | gpg --import \
  46. && gpg --fingerprint --with-colons '<pgpsign-19.07@openwrt.org>' | grep '^fpr:::::::::D9C6901F45C9B86858687DFF28A39BC32074BE7A:$' \
  47. && echo 'D9C6901F45C9B86858687DFF28A39BC32074BE7A:6:' | gpg --import-ownertrust
  48. # untrusted comment: Public usign key for unattended snapshot builds
  49. RUN curl 'https://git.openwrt.org/?p=keyring.git;a=blob_plain;f=usign/b5043e70f9a75cde' --create-dirs -o /home/build/usign/b5043e70f9a75cde \
  50. && echo 'd7ac10f9ed1b38033855f3d27c9327d558444fca804c685b17d9dcfb0648228f */home/build/usign/b5043e70f9a75cde' | sha256sum --check
  51. # untrusted comment: Public usign key for 19.07 release builds
  52. RUN curl 'https://git.openwrt.org/?p=keyring.git;a=blob_plain;f=usign/f94b9dd6febac963' --create-dirs -o /home/build/usign/f94b9dd6febac963 \
  53. && echo 'b1d09457cfbc36fccfe18382d65c54a2ade3e7fd3902da490a53aa517b512755 */home/build/usign/f94b9dd6febac963' | sha256sum --check