Tony Y | 14a2400 | 2018-06-05 14:00:41 -0700 | [diff] [blame] | 1 | FROM ubuntu:18.04 |
Julien Hachenberger | ccdf669 | 2018-10-23 16:49:04 +0200 | [diff] [blame] | 2 | RUN apt-get update && apt-get install -y \ |
Tony Y | 14a2400 | 2018-06-05 14:00:41 -0700 | [diff] [blame] | 3 | autoconf \ |
John Andersen | 6c601f0 | 2017-06-29 15:23:27 -0700 | [diff] [blame] | 4 | autoconf-archive \ |
Tony Y | 14a2400 | 2018-06-05 14:00:41 -0700 | [diff] [blame] | 5 | automake \ |
John Andersen | 6c601f0 | 2017-06-29 15:23:27 -0700 | [diff] [blame] | 6 | build-essential \ |
Julien Hachenberger | ef68d65 | 2018-11-23 08:58:45 +0100 | [diff] [blame^] | 7 | doxygen \ |
Tony Y | 14a2400 | 2018-06-05 14:00:41 -0700 | [diff] [blame] | 8 | g++ \ |
| 9 | gcc \ |
John Andersen | 6c601f0 | 2017-06-29 15:23:27 -0700 | [diff] [blame] | 10 | git \ |
Julien Hachenberger | b8cbdb5 | 2018-11-22 14:31:33 +0100 | [diff] [blame] | 11 | gnulib \ |
John Andersen | 6c601f0 | 2017-06-29 15:23:27 -0700 | [diff] [blame] | 12 | libssl-dev \ |
John Andersen | 6c601f0 | 2017-06-29 15:23:27 -0700 | [diff] [blame] | 13 | libtool \ |
Tony Y | 14a2400 | 2018-06-05 14:00:41 -0700 | [diff] [blame] | 14 | m4 \ |
| 15 | net-tools \ |
Bastian | df94457 | 2018-11-13 17:36:16 +0100 | [diff] [blame] | 16 | pkg-config \ |
| 17 | wget |
John Andersen | 6c601f0 | 2017-06-29 15:23:27 -0700 | [diff] [blame] | 18 | |
Tony Y | 14a2400 | 2018-06-05 14:00:41 -0700 | [diff] [blame] | 19 | # OpenSSL |
| 20 | ARG openssl_name=openssl-1.1.0h |
| 21 | WORKDIR /tmp |
Julien Hachenberger | dc0a867 | 2018-10-23 17:03:57 +0200 | [diff] [blame] | 22 | RUN wget --quiet --show-progress --progress=dot:giga https://www.openssl.org/source/$openssl_name.tar.gz \ |
| 23 | && tar xvf $openssl_name.tar.gz \ |
| 24 | && rm /tmp/$openssl_name.tar.gz |
Tony Y | 14a2400 | 2018-06-05 14:00:41 -0700 | [diff] [blame] | 25 | WORKDIR $openssl_name |
Julien Hachenberger | 300b7d6 | 2018-10-23 17:13:35 +0200 | [diff] [blame] | 26 | RUN ./config --prefix=/usr/local/openssl --openssldir=/usr/local/openssl \ |
| 27 | && make -j$(nproc) \ |
| 28 | && make install \ |
| 29 | && openssl version |
John Andersen | 6c601f0 | 2017-06-29 15:23:27 -0700 | [diff] [blame] | 30 | |
Tony Y | 14a2400 | 2018-06-05 14:00:41 -0700 | [diff] [blame] | 31 | # IBM's Software TPM 2.0 |
| 32 | ARG ibmtpm_name=ibmtpm1119 |
| 33 | WORKDIR /tmp |
Julien Hachenberger | dc0a867 | 2018-10-23 17:03:57 +0200 | [diff] [blame] | 34 | RUN wget --quiet --show-progress --progress=dot:giga "https://downloads.sourceforge.net/project/ibmswtpm2/$ibmtpm_name.tar.gz" \ |
| 35 | && sha256sum $ibmtpm_name.tar.gz | grep ^b9eef79904e276aeaed2a6b9e4021442ef4d7dfae4adde2473bef1a6a4cd10fb \ |
| 36 | && mkdir -p $ibmtpm_name \ |
| 37 | && tar xvf $ibmtpm_name.tar.gz -C $ibmtpm_name \ |
| 38 | && rm $ibmtpm_name.tar.gz |
Tony Y | 14a2400 | 2018-06-05 14:00:41 -0700 | [diff] [blame] | 39 | WORKDIR $ibmtpm_name/src |
Julien Hachenberger | 300b7d6 | 2018-10-23 17:13:35 +0200 | [diff] [blame] | 40 | RUN CFLAGS="-I/usr/local/openssl/include" make -j$(nproc) \ |
| 41 | && cp tpm_server /usr/local/bin |
John Andersen | 80efcb4 | 2017-07-18 15:01:51 -0700 | [diff] [blame] | 42 | |
Tony Y | 14a2400 | 2018-06-05 14:00:41 -0700 | [diff] [blame] | 43 | RUN apt-get install -y \ |
| 44 | libcmocka0 \ |
| 45 | libcmocka-dev \ |
| 46 | libgcrypt20-dev \ |
| 47 | libtool \ |
| 48 | liburiparser-dev \ |
| 49 | uthash-dev |
John Andersen | e459189 | 2017-07-19 10:13:30 -0700 | [diff] [blame] | 50 | |
Tony Y | 14a2400 | 2018-06-05 14:00:41 -0700 | [diff] [blame] | 51 | # TPM2-TSS |
| 52 | COPY . /tmp/tpm2-tss/ |
| 53 | WORKDIR /tmp/tpm2-tss |
Julien Hachenberger | b8cbdb5 | 2018-11-22 14:31:33 +0100 | [diff] [blame] | 54 | RUN ./bootstrap -I /usr/share/gnulib/m4 \ |
Julien Hachenberger | 300b7d6 | 2018-10-23 17:13:35 +0200 | [diff] [blame] | 55 | && ./configure --enable-unit \ |
| 56 | && make -j$(nproc) check \ |
| 57 | && make install \ |
| 58 | && ldconfig |
Tony Y | 14a2400 | 2018-06-05 14:00:41 -0700 | [diff] [blame] | 59 | ENV LD_LIBRARY_PATH /usr/local/lib |
| 60 | RUN cat test-suite.log |
| 61 | |