From dcc6ab043781dc70a4d295743be7dbbe417d3f59 Mon Sep 17 00:00:00 2001 From: "CanbiZ (MickLesk)" <47820557+MickLesk@users.noreply.github.com> Date: Wed, 21 Jan 2026 17:34:59 +0100 Subject: [PATCH] refactor(papra): persist data in /opt/papra_data - Move db, documents, ingestion to /opt/papra_data (survives CLEAN_INSTALL) - Use absolute paths in .env - Preserve AUTH_SECRET across updates (stored in .auth_secret file) --- install/papra-install.sh | 24 +++++++++++++++--------- 1 file changed, 15 insertions(+), 9 deletions(-) diff --git a/install/papra-install.sh b/install/papra-install.sh index 99413e4e1..dc2b38a3a 100644 --- a/install/papra-install.sh +++ b/install/papra-install.sh @@ -36,27 +36,33 @@ $STD pnpm --filter "@papra/app-server..." run build msg_ok "Set up Papra" msg_info "Configuring Papra" -AUTH_SECRET=$(openssl rand -hex 32) +DATA_DIR="/opt/papra_data" -# Create data directories in server folder (where WorkingDirectory points) -mkdir -p /opt/papra/apps/papra-server/app-data/db -mkdir -p /opt/papra/apps/papra-server/app-data/documents -mkdir -p /opt/papra/apps/papra-server/ingestion +# Create persistent data directories (survive updates/CLEAN_INSTALL) +mkdir -p "${DATA_DIR}/db" +mkdir -p "${DATA_DIR}/documents" +mkdir -p "${DATA_DIR}/ingestion" # Link client build to server public dir ln -sf /opt/papra/apps/papra-client/dist /opt/papra/apps/papra-server/public +# Generate secret only on first install, preserve on updates +if [[ ! -f "${DATA_DIR}/.auth_secret" ]]; then + openssl rand -hex 32 > "${DATA_DIR}/.auth_secret" +fi +AUTH_SECRET=$(cat "${DATA_DIR}/.auth_secret") + cat >/opt/papra/apps/papra-server/.env <