From 893de2e916f20e41b81cc577eb769e725e5e7d06 Mon Sep 17 00:00:00 2001 From: Evgeniy Antonyuk Date: Thu, 1 Aug 2024 18:40:47 +0300 Subject: [PATCH 1/3] fix Bug 66601 - Add fixes to WOPI modulus configuration (#756) --- Dockerfile | 1 + run-document-server.sh | 2 +- 2 files changed, 2 insertions(+), 1 deletion(-) diff --git a/Dockerfile b/Dockerfile index 732bde94..f438a479 100644 --- a/Dockerfile +++ b/Dockerfile @@ -69,6 +69,7 @@ RUN echo "#!/bin/sh\nexit 0" > /usr/sbin/policy-rc.d && \ unixodbc-dev \ unzip \ xvfb \ + xxd \ zlib1g && \ if [ $(ls -l /usr/share/fonts/truetype/msttcorefonts | wc -l) -ne 61 ]; \ then echo 'msttcorefonts failed to download'; exit 1; fi && \ diff --git a/run-document-server.sh b/run-document-server.sh index ddce1bdf..e1b8f507 100644 --- a/run-document-server.sh +++ b/run-document-server.sh @@ -403,7 +403,7 @@ update_ds_settings(){ [ ! -f "${WOPI_PRIVATE_KEY}" ] && echo -n "Generating WOPI private key..." && openssl genpkey -algorithm RSA -outform PEM -out "${WOPI_PRIVATE_KEY}" >/dev/null 2>&1 && echo "Done" [ ! -f "${WOPI_PUBLIC_KEY}" ] && echo -n "Generating WOPI public key..." && openssl rsa -RSAPublicKey_out -in "${WOPI_PRIVATE_KEY}" -outform "MS PUBLICKEYBLOB" -out "${WOPI_PUBLIC_KEY}" >/dev/null 2>&1 && echo "Done" - WOPI_MODULUS=$(openssl rsa -pubin -inform "MS PUBLICKEYBLOB" -modulus -noout -in "${WOPI_PUBLIC_KEY}" | sed 's/Modulus=//') + WOPI_MODULUS=$(openssl rsa -pubin -inform "MS PUBLICKEYBLOB" -modulus -noout -in "${WOPI_PUBLIC_KEY}" | sed 's/Modulus=//' | xxd -r -p | openssl base64 -A) WOPI_EXPONENT=$(openssl rsa -pubin -inform "MS PUBLICKEYBLOB" -text -noout -in "${WOPI_PUBLIC_KEY}" | grep -oP '(?<=Exponent: )\d+') ${JSON} -I -e "if(this.wopi===undefined)this.wopi={};" From bf557756630985c93b1a8d438cd006854bf8c21d Mon Sep 17 00:00:00 2001 From: Evgeniy Antonyuk Date: Thu, 5 Sep 2024 07:57:32 +0000 Subject: [PATCH 2/3] Add an optional option to enable plugins (#1) Co-authored-by: Evgeniy Antonyuk Co-committed-by: Evgeniy Antonyuk --- README.md | 1 + run-document-server.sh | 8 ++++++++ 2 files changed, 9 insertions(+) diff --git a/README.md b/README.md index dc2d4e81..6e0418e5 100644 --- a/README.md +++ b/README.md @@ -208,6 +208,7 @@ Below is the complete list of parameters that can be set using environment varia - **METRICS_PREFIX**: Defines StatsD metrics prefix for backend services. Defaults to `ds.`. - **LETS_ENCRYPT_DOMAIN**: Defines the domain for Let's Encrypt certificate. - **LETS_ENCRYPT_MAIL**: Defines the domain administator mail address for Let's Encrypt certificate. +- **PLUGINS_ENABLED**: Defines whether to enable default plugins. Defaults to `false`. ## Installing ONLYOFFICE Document Server integrated with Community and Mail Servers diff --git a/run-document-server.sh b/run-document-server.sh index e1b8f507..b086e769 100644 --- a/run-document-server.sh +++ b/run-document-server.sh @@ -25,6 +25,7 @@ DS_LIB_DIR="${LIB_DIR}/documentserver" CONF_DIR="/etc/${COMPANY_NAME}/documentserver" SUPERVISOR_CONF_DIR="/etc/supervisor/conf.d" IS_UPGRADE="false" +PLUGINS_ENABLED=${PLUGINS_ENABLED:-false} ONLYOFFICE_DATA_CONTAINER=${ONLYOFFICE_DATA_CONTAINER:-false} ONLYOFFICE_DATA_CONTAINER_HOST=${ONLYOFFICE_DATA_CONTAINER_HOST:-localhost} @@ -766,6 +767,13 @@ fi if [ "${GENERATE_FONTS}" == "true" ]; then documentserver-generate-allfonts.sh ${ONLYOFFICE_DATA_CONTAINER} fi + +if [ "${PLUGINS_ENABLED}" = "true" ]; then + echo -n Installing plugins, please wait... + documentserver-pluginsmanager.sh -r false --update=\"${APP_DIR}/sdkjs-plugins/plugin-list-default.json\" >/dev/null + echo Done +fi + documentserver-static-gzip.sh ${ONLYOFFICE_DATA_CONTAINER} echo "${JWT_MESSAGE}" From ca1a38e4408cda46eb964c679fa3c2b7b7b524be Mon Sep 17 00:00:00 2001 From: Evgeniy Antonyuk Date: Thu, 5 Sep 2024 11:47:11 +0000 Subject: [PATCH 3/3] Disable plugin installation when building the docker image (#3) Co-authored-by: Evgeniy Antonyuk Co-committed-by: Evgeniy Antonyuk --- Dockerfile | 1 + 1 file changed, 1 insertion(+) diff --git a/Dockerfile b/Dockerfile index f438a479..50c55a7f 100644 --- a/Dockerfile +++ b/Dockerfile @@ -109,6 +109,7 @@ ARG PACKAGE_BASEURL="http://download.onlyoffice.com/install/documentserver/linux ENV COMPANY_NAME=$COMPANY_NAME \ PRODUCT_NAME=$PRODUCT_NAME \ PRODUCT_EDITION=$PRODUCT_EDITION \ + DS_PLUGIN_INSTALLATION=false \ DS_DOCKER_INSTALLATION=true RUN PACKAGE_FILE="${COMPANY_NAME}-${PRODUCT_NAME}${PRODUCT_EDITION}${PACKAGE_VERSION:+_$PACKAGE_VERSION}_${TARGETARCH:-$(dpkg --print-architecture)}.deb" && \