refactor(papra): cleanup install script community-style

- Remove unnecessary vars and comments
- Use apt-get instead of apt
- Get pnpm version from package.json
- Use NODE_MODULE for pnpm setup
- Simplify service (node direct, no corepack)
- Compact .env format
This commit is contained in:
CanbiZ (MickLesk) 2026-01-21 17:36:12 +01:00
parent dcc6ab0437
commit bff65fa631

View File

@ -14,98 +14,64 @@ network_check
update_os update_os
msg_info "Installing Dependencies" msg_info "Installing Dependencies"
$STD apt install -y \ $STD apt-get install -y \
build-essential \ build-essential \
tesseract-ocr \ tesseract-ocr \
tesseract-ocr-all tesseract-ocr-all
msg_ok "Installed Dependencies" msg_ok "Installed Dependencies"
NODE_VERSION="24" setup_nodejs
RELEASE=$(curl -fsSL https://api.github.com/repos/papra-hq/papra/releases | grep -oP '"tag_name":\s*"\K@papra/docker@[^"]+' | head -n1) RELEASE=$(curl -fsSL https://api.github.com/repos/papra-hq/papra/releases | grep -oP '"tag_name":\s*"\K@papra/docker@[^"]+' | head -n1)
fetch_and_deploy_gh_release "papra" "papra-hq/papra" "tarball" "${RELEASE}" "/opt/papra" fetch_and_deploy_gh_release "papra" "papra-hq/papra" "tarball" "${RELEASE}" "/opt/papra"
msg_info "Setup Papra" pnpm_version=$(grep -Po '"pnpm":\s*"\K[^"]+' /opt/papra/package.json)
NODE_VERSION="24" NODE_MODULE="pnpm@$pnpm_version" setup_nodejs
msg_info "Installing Papra (Patience)"
cd /opt/papra cd /opt/papra
export COREPACK_ENABLE_NETWORK=1
$STD corepack enable
$STD corepack prepare pnpm@10.19.0 --activate
$STD pnpm install --frozen-lockfile $STD pnpm install --frozen-lockfile
$STD pnpm --filter "@papra/app-client..." run build $STD pnpm --filter "@papra/app-client..." run build
$STD pnpm --filter "@papra/app-server..." run build $STD pnpm --filter "@papra/app-server..." run build
msg_ok "Set up Papra" ln -sf /opt/papra/apps/papra-client/dist /opt/papra/apps/papra-server/public
msg_ok "Installed Papra"
msg_info "Configuring Papra" msg_info "Configuring Papra"
DATA_DIR="/opt/papra_data" mkdir -p /opt/papra_data/{db,documents,ingestion}
[[ ! -f /opt/papra_data/.secret ]] && openssl rand -hex 32 >/opt/papra_data/.secret
# Create persistent data directories (survive updates/CLEAN_INSTALL) cat <<EOF >/opt/papra/apps/papra-server/.env
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 <<EOF
NODE_ENV=production NODE_ENV=production
SERVER_SERVE_PUBLIC_DIR=true SERVER_SERVE_PUBLIC_DIR=true
PORT=1221 PORT=1221
DATABASE_URL=file:/opt/papra_data/db/db.sqlite
# Database Configuration DOCUMENT_STORAGE_FILESYSTEM_ROOT=/opt/papra_data/documents
DATABASE_URL=file:${DATA_DIR}/db/db.sqlite PAPRA_CONFIG_DIR=/opt/papra_data
AUTH_SECRET=$(cat /opt/papra_data/.secret)
# Storage Configuration BETTER_AUTH_SECRET=$(cat /opt/papra_data/.secret)
DOCUMENT_STORAGE_FILESYSTEM_ROOT=${DATA_DIR}/documents
PAPRA_CONFIG_DIR=${DATA_DIR}
# Authentication
AUTH_SECRET=${AUTH_SECRET}
BETTER_AUTH_SECRET=${AUTH_SECRET}
BETTER_AUTH_TELEMETRY=0 BETTER_AUTH_TELEMETRY=0
# Application Configuration
CLIENT_BASE_URL=http://${LOCAL_IP}:1221 CLIENT_BASE_URL=http://${LOCAL_IP}:1221
# Email Configuration (dry-run mode)
EMAILS_DRY_RUN=true EMAILS_DRY_RUN=true
INGESTION_FOLDER_ROOT=/opt/papra_data/ingestion
# Ingestion Folder
INGESTION_FOLDER_ROOT=${DATA_DIR}/ingestion
EOF EOF
chown -R root:root /opt/papra
msg_ok "Configured Papra" msg_ok "Configured Papra"
msg_info "Creating Papra Service" msg_info "Creating Service"
cat >/etc/systemd/system/papra.service <<EOF cat <<EOF >/etc/systemd/system/papra.service
[Unit] [Unit]
Description=Papra Document Management Description=Papra Document Management
After=network.target After=network.target
[Service] [Service]
Type=simple Type=simple
User=root
WorkingDirectory=/opt/papra/apps/papra-server WorkingDirectory=/opt/papra/apps/papra-server
EnvironmentFile=/opt/papra/apps/papra-server/.env EnvironmentFile=/opt/papra/apps/papra-server/.env
Environment=PATH=/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin ExecStartPre=/usr/bin/pnpm run migrate:up
ExecStartPre=/usr/bin/corepack pnpm --silent run migrate:up ExecStart=/usr/bin/node dist/index.js
ExecStart=/usr/bin/corepack pnpm --silent run start
Restart=on-failure
RestartSec=10
[Install] [Install]
WantedBy=multi-user.target WantedBy=multi-user.target
EOF EOF
systemctl enable -q --now papra systemctl enable -q --now papra
echo "${RELEASE}" >/opt/papra_version.txt echo "${RELEASE}" >/opt/papra_version.txt
msg_ok "Created and Started Papra Service" msg_ok "Created Service"
motd_ssh motd_ssh
customize customize