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