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