| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950 |
- 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-sslkeylog enable-fips enable-demos enable-h3demo enable-hqinterop disable-docs --prefix=/usr --openssldir=/etc/pki/tls && \
- make -j 4 && make install && cp test/quic-openssl-docker/hq-interop/quic-hq-interop /usr/local/bin && \
- cp test/quic-openssl-docker/hq-interop/quic-hq-interop-server /usr/local/bin && \
- cp demos/http3/ossl-nghttp3-demo-server /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" ]
|