xref: /freebsd/crypto/openssl/test/quic-openssl-docker/Dockerfile (revision e7be843b4a162e68651d3911f0357ed464915629)
1*e7be843bSPierre ProncheryFROM martenseemann/quic-network-simulator-endpoint:latest
2*e7be843bSPierre Pronchery
3*e7be843bSPierre Pronchery# Make sure curl picks up the new openssl
4*e7be843bSPierre ProncheryENV PKG_CONFIG_LIBDIR=/usr/lib64/pkgconfig:/usr/lib/pkgconfig:/usr/lib/x86_64-linux-gnu/pkgconfig/:$PKG_CONFIG_LIBDIR
5*e7be843bSPierre Pronchery# Set the environment variable LD_LIBRARY_PATH to ensure we get the right libraries
6*e7be843bSPierre ProncheryENV LD_LIBRARY_PATH=/usr/lib64:/usr/lib:/usr/lib/x86_64-linux-gnu:$LD_LIBRARY_PATH
7*e7be843bSPierre Pronchery# The branch of openssl to clone
8*e7be843bSPierre ProncheryARG OPENSSL_URL=https://github.com/openssl/openssl.git
9*e7be843bSPierre ProncheryARG OPENSSL_BRANCH=master
10*e7be843bSPierre Pronchery
11*e7be843bSPierre Pronchery# Install needed tools
12*e7be843bSPierre ProncheryRUN apt-get update && apt-get install -y \
13*e7be843bSPierre Pronchery    git make gcc perl cmake build-essential \
14*e7be843bSPierre Pronchery    autoconf libtool pkg-config libpsl-dev
15*e7be843bSPierre Pronchery
16*e7be843bSPierre ProncheryWORKDIR /
17*e7be843bSPierre Pronchery
18*e7be843bSPierre Pronchery# build nghttp3
19*e7be843bSPierre ProncheryRUN git clone --depth 1 https://github.com/ngtcp2/nghttp3.git && \
20*e7be843bSPierre Pronchery    cd nghttp3 && \
21*e7be843bSPierre Pronchery    git submodule update --init && \
22*e7be843bSPierre Pronchery    autoreconf -i && \
23*e7be843bSPierre Pronchery    ./configure --prefix=/usr && \
24*e7be843bSPierre Pronchery    make -j 4 check && \
25*e7be843bSPierre Pronchery    make install && \
26*e7be843bSPierre Pronchery    rm -rf /nghttp3
27*e7be843bSPierre Pronchery
28*e7be843bSPierre Pronchery# download and build openssl
29*e7be843bSPierre ProncheryRUN git clone --depth 1 -b $OPENSSL_BRANCH $OPENSSL_URL && \
30*e7be843bSPierre Pronchery    cd openssl && \
31*e7be843bSPierre Pronchery    ./Configure enable-sslkeylog enable-fips enable-demos enable-h3demo enable-hqinterop disable-docs --prefix=/usr --openssldir=/etc/pki/tls && \
32*e7be843bSPierre Pronchery    make -j 4 && make install && cp test/quic-openssl-docker/hq-interop/quic-hq-interop /usr/local/bin && \
33*e7be843bSPierre Pronchery    cp test/quic-openssl-docker/hq-interop/quic-hq-interop-server /usr/local/bin && \
34*e7be843bSPierre Pronchery    cp demos/http3/ossl-nghttp3-demo-server /usr/local/bin && \
35*e7be843bSPierre Pronchery    rm -rf /openssl
36*e7be843bSPierre Pronchery
37*e7be843bSPierre Pronchery# Build curl
38*e7be843bSPierre ProncheryRUN git clone --depth 1 https://github.com/curl/curl.git && \
39*e7be843bSPierre Pronchery    cd curl && \
40*e7be843bSPierre Pronchery    autoreconf -fi && ./configure --with-openssl-quic --with-openssl --with-nghttp3 --prefix=/usr && \
41*e7be843bSPierre Pronchery    make -j 4 && \
42*e7be843bSPierre Pronchery    make install && \
43*e7be843bSPierre Pronchery    rm -rf /curl
44*e7be843bSPierre Pronchery
45*e7be843bSPierre Pronchery# copy run script and run it
46*e7be843bSPierre ProncheryCOPY run_endpoint.sh .
47*e7be843bSPierre ProncheryRUN chmod +x run_endpoint.sh
48*e7be843bSPierre ProncheryRUN apt-get clean
49*e7be843bSPierre ProncheryENTRYPOINT [ "./run_endpoint.sh" ]
50*e7be843bSPierre Pronchery
51