From e20b9c512280f64a00d728d99daed4b01186efcf Mon Sep 17 00:00:00 2001 From: Bernhard B Date: Sun, 14 Feb 2021 20:55:41 +0100 Subject: [PATCH] updated Dockerfile * changed signal-cli to version 0.8.0 * use architecture specific signal-client --- Dockerfile | 37 ++++++++++++++++++++++++++++++++----- 1 file changed, 32 insertions(+), 5 deletions(-) diff --git a/Dockerfile b/Dockerfile index e636722..544ccf3 100644 --- a/Dockerfile +++ b/Dockerfile @@ -1,5 +1,6 @@ -ARG SIGNAL_CLI_VERSION=0.7.4 +ARG SIGNAL_CLI_VERSION=0.8.0 ARG ZKGROUP_VERSION=0.7.0 +ARG LIBSIGNAL_CLIENT_VERSION=0.2.3 ARG SWAG_VERSION=1.6.7 ARG GRAALVM_JAVA_VERSION=11 @@ -9,14 +10,15 @@ FROM golang:1.14-buster AS buildcontainer ARG SIGNAL_CLI_VERSION ARG ZKGROUP_VERSION +ARG LIBSIGNAL_CLIENT_VERSION ARG SWAG_VERSION ARG GRAALVM_JAVA_VERSION ARG GRAALVM_VERSION COPY ext/libraries/zkgroup/v${ZKGROUP_VERSION} /tmp/zkgroup-libraries +COPY ext/libraries/libsignal-client/v${LIBSIGNAL_CLIENT_VERSION} /tmp/libsignal-client-libraries -RUN ls -la /tmp/zkgroup-libraries/x86-64 - +# use architecture specific libzkgroup.so RUN arch="$(uname -m)"; \ case "$arch" in \ aarch64) cp /tmp/zkgroup-libraries/arm64/libzkgroup.so /tmp/libzkgroup.so ;; \ @@ -24,6 +26,14 @@ RUN arch="$(uname -m)"; \ x86_64) cp /tmp/zkgroup-libraries/x86-64/libzkgroup.so /tmp/libzkgroup.so ;; \ esac; +# use architecture specific libsignal_jni.so +RUN arch="$(uname -m)"; \ + case "$arch" in \ + aarch64) cp /tmp/libsignal-client-libraries/arm64/libsignal_jni.so /tmp/libsignal_jni.so ;; \ + armv7l) cp /tmp/libsignal-client-libraries/armv7/libsignal_jni.so /tmp/libsignal_jni.so ;; \ + x86_64) cp /tmp/libsignal-client-libraries/x86-64/libsignal_jni.so /tmp/libsignal_jni.so ;; \ + esac; + RUN apt-get update \ && apt-get install -y --no-install-recommends wget default-jre software-properties-common git locales zip file \ && rm -rf /var/lib/apt/lists/* @@ -52,6 +62,8 @@ RUN cd /tmp/ \ && ./gradlew installDist \ && ./gradlew distTar +# replace zkgroup + RUN ls /tmp/signal-cli-${SIGNAL_CLI_VERSION}/build/install/signal-cli/lib/zkgroup-java-${ZKGROUP_VERSION}.jar || (echo "\n\nzkgroup jar file with version ${ZKGROUP_VERSION} not found. Maybe the version needs to be bumped in the signal-cli-rest-api Dockerfile?\n\n" && echo "Available version: \n" && ls /tmp/signal-cli-${SIGNAL_CLI_VERSION}/build/install/signal-cli/lib/zkgroup-java-* && echo "\n\n" && exit 1) RUN cd /tmp/ \ @@ -66,6 +78,20 @@ RUN cd /tmp/signal-cli-${SIGNAL_CLI_VERSION}/build/distributions/ \ && tar --delete -vPf /tmp/signal-cli-${SIGNAL_CLI_VERSION}/build/distributions/signal-cli-${SIGNAL_CLI_VERSION}.tar signal-cli-${SIGNAL_CLI_VERSION}/lib/zkgroup-java-${ZKGROUP_VERSION}.jar \ && tar --owner='' --group='' -rvPf /tmp/signal-cli-${SIGNAL_CLI_VERSION}/build/distributions/signal-cli-${SIGNAL_CLI_VERSION}.tar signal-cli-${SIGNAL_CLI_VERSION}/lib/zkgroup-java-${ZKGROUP_VERSION}.jar +# replace libsignal-client + +RUN ls /tmp/signal-cli-${SIGNAL_CLI_VERSION}/build/install/signal-cli/lib/signal-client-java-${LIBSIGNAL_CLIENT_VERSION}.jar || (echo "\n\nsignal-client jar file with version ${LIBSIGNAL_CLIENT_VERSION} not found. Maybe the version needs to be bumped in the signal-cli-rest-api Dockerfile?\n\n" && echo "Available version: \n" && ls /tmp/signal-cli-${SIGNAL_CLI_VERSION}/build/install/signal-cli/lib/signal-client-java-* && echo "\n\n" && exit 1) + +RUN cd /tmp/signal-cli-${SIGNAL_CLI_VERSION}/build/distributions/ \ + && mkdir -p signal-cli-${SIGNAL_CLI_VERSION}/lib/ \ + && cp /tmp/signal-cli-${SIGNAL_CLI_VERSION}/build/install/signal-cli/lib/signal-client-java-${LIBSIGNAL_CLIENT_VERSION}.jar signal-cli-${SIGNAL_CLI_VERSION}/lib/ \ + # update zip + && zip -u /tmp/signal-cli-${SIGNAL_CLI_VERSION}/build/distributions/signal-cli-${SIGNAL_CLI_VERSION}.zip signal-cli-${SIGNAL_CLI_VERSION}/lib/signal-client-java-${LIBSIGNAL_CLIENT_VERSION}.jar \ + # update tar + && tar --delete -vPf /tmp/signal-cli-${SIGNAL_CLI_VERSION}/build/distributions/signal-cli-${SIGNAL_CLI_VERSION}.tar signal-cli-${SIGNAL_CLI_VERSION}/lib/signal-client-java-${LIBSIGNAL_CLIENT_VERSION}.jar \ + && tar --owner='' --group='' -rvPf /tmp/signal-cli-${SIGNAL_CLI_VERSION}/build/distributions/signal-cli-${SIGNAL_CLI_VERSION}.tar signal-cli-${SIGNAL_CLI_VERSION}/lib/signal-client-java-${LIBSIGNAL_CLIENT_VERSION}.jar + + COPY src/api /tmp/signal-cli-rest-api-src/api COPY src/main.go /tmp/signal-cli-rest-api-src/ COPY src/go.mod /tmp/signal-cli-rest-api-src/ @@ -90,8 +116,9 @@ RUN cd /tmp/ \ ENV GRAALVM_HOME=/tmp/graalvm-ce-java${GRAALVM_JAVA_VERSION}-${GRAALVM_VERSION} -RUN cd /tmp/signal-cli-${SIGNAL_CLI_VERSION} \ - && ./gradlew assembleNativeImage +# TODO +#RUN cd /tmp/signal-cli-${SIGNAL_CLI_VERSION} \ +# && ./gradlew assembleNativeImage # Start a fresh container for release container FROM adoptopenjdk:11-jre-hotspot-bionic