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:
parent
dcc6ab0437
commit
bff65fa631
@ -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
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user