| # Copyright 2020 The Go Authors. All rights reserved. |
| # Use of this source code is governed by a BSD-style |
| # license that can be found in the LICENSE file. |
| |
| # This Docker image builds goboringcrypto_linux_amd64.syso according to the |
| # Security Policy. To use it, build the image, run it, and then extract |
| # /boring/godriver/goboringcrypto_linux_amd64.syso. |
| # |
| # $ podman build -t goboring:140sp3678 . |
| # $ podman run -it --name goboring-140sp3678 goboring:140sp3678 |
| # $ podman cp goboring-140sp3678:/boring/godriver/goboringcrypto_linux_amd64.syso syso |
| # $ sha256sum syso/goboringcrypto_linux_amd64.syso # compare to docker output |
| # |
| # The podman commands may need to run under sudo to work around a subuid/subgid bug. |
| |
| FROM ubuntu:focal |
| |
| RUN mkdir /boring |
| WORKDIR /boring |
| |
| # Following 140sp3678.pdf [0] page 19, install clang 7.0.1, Go 1.12.7, and |
| # Ninja 1.9.0, then download and verify BoringSSL. |
| # |
| # [0]: https://csrc.nist.gov/CSRC/media/projects/cryptographic-module-validation-program/documents/security-policies/140sp3678.pdf |
| |
| RUN apt-get update && \ |
| apt-get install --no-install-recommends -y cmake xz-utils wget unzip ca-certificates clang-7 |
| RUN wget https://github.com/ninja-build/ninja/releases/download/v1.9.0/ninja-linux.zip && \ |
| unzip ninja-linux.zip && \ |
| rm ninja-linux.zip && \ |
| mv ninja /usr/local/bin/ |
| RUN wget https://golang.org/dl/go1.12.7.linux-amd64.tar.gz && \ |
| tar -C /usr/local -xzf go1.12.7.linux-amd64.tar.gz && \ |
| rm go1.12.7.linux-amd64.tar.gz && \ |
| ln -s /usr/local/go/bin/go /usr/local/bin/ |
| |
| RUN wget https://commondatastorage.googleapis.com/chromium-boringssl-fips/boringssl-ae223d6138807a13006342edfeef32e813246b39.tar.xz |
| RUN [ "$(sha256sum boringssl-ae223d6138807a13006342edfeef32e813246b39.tar.xz | awk '{print $1}')" = \ |
| 3b5fdf23274d4179c2077b5e8fa625d9debd7a390aac1d165b7e47234f648bb8 ] |
| |
| ADD goboringcrypto.h /boring/godriver/goboringcrypto.h |
| ADD build.sh /boring/build.sh |
| |
| ENTRYPOINT ["/boring/build.sh"] |