mirror of
https://github.com/openssl/openssl.git
synced 2025-01-12 13:36:28 +08:00
3951741224
1) Limit clone depth to allow faster fetches 2) Supply OPENSSL_URL and OPENSSL_BRANCH args to allow for branch testing Reviewed-by: Sasa Nedvedicky <sashan@openssl.org> Reviewed-by: Viktor Dukhovni <viktor@openssl.org> Reviewed-by: Tomas Mraz <tomas@openssl.org> (Merged from https://github.com/openssl/openssl/pull/25426)
49 lines
1.6 KiB
Docker
49 lines
1.6 KiB
Docker
FROM martenseemann/quic-network-simulator-endpoint:latest
|
|
|
|
# Make sure curl picks up the new openssl
|
|
ENV PKG_CONFIG_LIBDIR=/usr/lib64/pkgconfig:/usr/lib/pkgconfig:/usr/lib/x86_64-linux-gnu/pkgconfig/:$PKG_CONFIG_LIBDIR
|
|
# Set the environment variable LD_LIBRARY_PATH to ensure we get the right libraries
|
|
ENV LD_LIBRARY_PATH=/usr/lib64:/usr/lib:/usr/lib/x86_64-linux-gnu:$LD_LIBRARY_PATH
|
|
# The branch of openssl to clone
|
|
ARG OPENSSL_URL=https://github.com/openssl/openssl.git
|
|
ARG OPENSSL_BRANCH=master
|
|
|
|
# Install needed tools
|
|
RUN apt-get update && apt-get install -y \
|
|
git make gcc perl cmake build-essential \
|
|
autoconf libtool pkg-config libpsl-dev
|
|
|
|
WORKDIR /
|
|
|
|
# build nghttp3
|
|
RUN git clone --depth 1 https://github.com/ngtcp2/nghttp3.git && \
|
|
cd nghttp3 && \
|
|
git submodule update --init && \
|
|
autoreconf -i && \
|
|
./configure --prefix=/usr && \
|
|
make -j 4 check && \
|
|
make install && \
|
|
rm -rf /nghttp3
|
|
|
|
# download and build openssl
|
|
RUN git clone --depth 1 -b $OPENSSL_BRANCH $OPENSSL_URL && \
|
|
cd openssl && \
|
|
./Configure enable-fips enable-demos disable-docs --prefix=/usr --openssldir=/etc/pki/tls && \
|
|
make -j 4 && make install && cp demos/guide/quic-hq-interop /usr/local/bin && \
|
|
rm -rf /openssl
|
|
|
|
# Build curl
|
|
RUN git clone --depth 1 https://github.com/curl/curl.git && \
|
|
cd curl && \
|
|
autoreconf -fi && ./configure --with-openssl-quic --with-openssl --with-nghttp3 --prefix=/usr && \
|
|
make -j 4 && \
|
|
make install && \
|
|
rm -rf /curl
|
|
|
|
# copy run script and run it
|
|
COPY run_endpoint.sh .
|
|
RUN chmod +x run_endpoint.sh
|
|
RUN apt-get clean
|
|
ENTRYPOINT [ "./run_endpoint.sh" ]
|
|
|