|
|
|
|
@ -20,7 +20,8 @@ $STD apt-get install -y \
|
|
|
|
|
unzip \
|
|
|
|
|
build-essential \
|
|
|
|
|
libyaml-dev \
|
|
|
|
|
python3-dev
|
|
|
|
|
python3-dev \
|
|
|
|
|
git
|
|
|
|
|
msg_ok "Installed Dependencies"
|
|
|
|
|
|
|
|
|
|
msg_info "Installing Python"
|
|
|
|
|
@ -38,13 +39,13 @@ NODE_VERSION="20" install_node_and_modules
|
|
|
|
|
msg_ok "Installed Node.js"
|
|
|
|
|
|
|
|
|
|
msg_info "Setup ${APPLICATION}"
|
|
|
|
|
RELEASE=$(curl -fsSL https://api.github.com/repos/Dictionarry-Hub/profilarr/releases/latest | grep "tag_name" | cut -d'"' -f4)
|
|
|
|
|
RELEASE=$(curl -fsSL https://api.github.com/repos/BiluliB/profilarr/releases/latest | grep "tag_name" | cut -d'"' -f4)
|
|
|
|
|
if [[ -z "$RELEASE" ]]; then
|
|
|
|
|
msg_error "Failed to fetch latest release version"
|
|
|
|
|
exit 1
|
|
|
|
|
fi
|
|
|
|
|
temp_file=$(mktemp)
|
|
|
|
|
$STD curl -fsSL -o "$temp_file" "https://github.com/Dictionarry-Hub/profilarr/archive/refs/tags/${RELEASE}.zip"
|
|
|
|
|
$STD curl -fsSL -o "$temp_file" "https://github.com/BiluliB/profilarr/archive/refs/tags/${RELEASE}.zip"
|
|
|
|
|
$STD unzip -q "$temp_file" -d /tmp
|
|
|
|
|
$STD mkdir -p /opt/${APPLICATION}
|
|
|
|
|
$STD mkdir -p /opt/${APPLICATION}_config
|
|
|
|
|
@ -91,21 +92,140 @@ cat <<EOF >/etc/systemd/system/${APPLICATION}.service
|
|
|
|
|
[Unit]
|
|
|
|
|
Description=Profilarr Profile Manager
|
|
|
|
|
After=network.target
|
|
|
|
|
|
|
|
|
|
[Service]
|
|
|
|
|
Type=simple
|
|
|
|
|
User=root
|
|
|
|
|
WorkingDirectory=/opt/${APPLICATION}/backend
|
|
|
|
|
Environment=PATH=/opt/${APPLICATION}/venv/bin
|
|
|
|
|
Environment=PATH=/opt/${APPLICATION}/venv/bin:/usr/local/bin:/usr/bin:/bin
|
|
|
|
|
Environment=CONFIG_PATH=/opt/${APPLICATION}_config
|
|
|
|
|
ExecStart=/opt/${APPLICATION}/venv/bin/gunicorn --bind 0.0.0.0:6868 --workers 2 --timeout 120 app.main:create_app()
|
|
|
|
|
Environment=PYTHONPATH=/opt/${APPLICATION}/backend
|
|
|
|
|
Environment=GIT_PYTHON_REFRESH=quiet
|
|
|
|
|
ExecStart=/opt/${APPLICATION}/venv/bin/python -m gunicorn --bind 0.0.0.0:6868 --workers 2 --timeout 120 --pythonpath /opt/${APPLICATION}/backend "app.main:create_app()"
|
|
|
|
|
Restart=always
|
|
|
|
|
RestartSec=10
|
|
|
|
|
StandardOutput=journal
|
|
|
|
|
StandardError=journal
|
|
|
|
|
|
|
|
|
|
[Install]
|
|
|
|
|
WantedBy=multi-user.target
|
|
|
|
|
EOF
|
|
|
|
|
|
|
|
|
|
$STD systemctl daemon-reload
|
|
|
|
|
systemctl enable -q --now ${APPLICATION}
|
|
|
|
|
|
|
|
|
|
# Test the application manually first
|
|
|
|
|
msg_info "Testing Application"
|
|
|
|
|
cd /opt/${APPLICATION}/backend
|
|
|
|
|
|
|
|
|
|
# Check if the main module exists and is importable
|
|
|
|
|
if ! /opt/${APPLICATION}/venv/bin/python -c "
|
|
|
|
|
import sys
|
|
|
|
|
import os
|
|
|
|
|
sys.path.insert(0, '/opt/${APPLICATION}/backend')
|
|
|
|
|
os.environ['GIT_PYTHON_REFRESH'] = 'quiet'
|
|
|
|
|
try:
|
|
|
|
|
import app.main
|
|
|
|
|
print('✓ app.main imported successfully')
|
|
|
|
|
except ImportError as e:
|
|
|
|
|
print(f'✗ Import error: {e}')
|
|
|
|
|
sys.exit(1)
|
|
|
|
|
except Exception as e:
|
|
|
|
|
print(f'✗ Other error: {e}')
|
|
|
|
|
sys.exit(1)
|
|
|
|
|
"; then
|
|
|
|
|
msg_error "Application import test failed"
|
|
|
|
|
|
|
|
|
|
# Try alternative approaches
|
|
|
|
|
msg_info "Trying alternative startup methods"
|
|
|
|
|
|
|
|
|
|
# Check if there's a direct run.py or main.py
|
|
|
|
|
if [[ -f "/opt/${APPLICATION}/backend/run.py" ]]; then
|
|
|
|
|
cat <<EOF >/etc/systemd/system/${APPLICATION}.service
|
|
|
|
|
[Unit]
|
|
|
|
|
Description=Profilarr Profile Manager
|
|
|
|
|
After=network.target
|
|
|
|
|
|
|
|
|
|
[Service]
|
|
|
|
|
Type=simple
|
|
|
|
|
User=root
|
|
|
|
|
WorkingDirectory=/opt/${APPLICATION}/backend
|
|
|
|
|
Environment=PATH=/opt/${APPLICATION}/venv/bin:/usr/local/bin:/usr/bin:/bin
|
|
|
|
|
Environment=CONFIG_PATH=/opt/${APPLICATION}_config
|
|
|
|
|
Environment=GIT_PYTHON_REFRESH=quiet
|
|
|
|
|
ExecStart=/opt/${APPLICATION}/venv/bin/python run.py
|
|
|
|
|
Restart=always
|
|
|
|
|
RestartSec=10
|
|
|
|
|
StandardOutput=journal
|
|
|
|
|
StandardError=journal
|
|
|
|
|
|
|
|
|
|
[Install]
|
|
|
|
|
WantedBy=multi-user.target
|
|
|
|
|
EOF
|
|
|
|
|
elif [[ -f "/opt/${APPLICATION}/backend/main.py" ]]; then
|
|
|
|
|
cat <<EOF >/etc/systemd/system/${APPLICATION}.service
|
|
|
|
|
[Unit]
|
|
|
|
|
Description=Profilarr Profile Manager
|
|
|
|
|
After=network.target
|
|
|
|
|
|
|
|
|
|
[Service]
|
|
|
|
|
Type=simple
|
|
|
|
|
User=root
|
|
|
|
|
WorkingDirectory=/opt/${APPLICATION}/backend
|
|
|
|
|
Environment=PATH=/opt/${APPLICATION}/venv/bin:/usr/local/bin:/usr/bin:/bin
|
|
|
|
|
Environment=CONFIG_PATH=/opt/${APPLICATION}_config
|
|
|
|
|
Environment=GIT_PYTHON_REFRESH=quiet
|
|
|
|
|
ExecStart=/opt/${APPLICATION}/venv/bin/python main.py
|
|
|
|
|
Restart=always
|
|
|
|
|
RestartSec=10
|
|
|
|
|
StandardOutput=journal
|
|
|
|
|
StandardError=journal
|
|
|
|
|
|
|
|
|
|
[Install]
|
|
|
|
|
WantedBy=multi-user.target
|
|
|
|
|
EOF
|
|
|
|
|
else
|
|
|
|
|
# Fallback to Flask development server
|
|
|
|
|
cat <<EOF >/etc/systemd/system/${APPLICATION}.service
|
|
|
|
|
[Unit]
|
|
|
|
|
Description=Profilarr Profile Manager
|
|
|
|
|
After=network.target
|
|
|
|
|
|
|
|
|
|
[Service]
|
|
|
|
|
Type=simple
|
|
|
|
|
User=root
|
|
|
|
|
WorkingDirectory=/opt/${APPLICATION}/backend
|
|
|
|
|
Environment=PATH=/opt/${APPLICATION}/venv/bin:/usr/local/bin:/usr/bin:/bin
|
|
|
|
|
Environment=CONFIG_PATH=/opt/${APPLICATION}_config
|
|
|
|
|
Environment=GIT_PYTHON_REFRESH=quiet
|
|
|
|
|
Environment=FLASK_APP=app.main:create_app
|
|
|
|
|
Environment=FLASK_RUN_HOST=0.0.0.0
|
|
|
|
|
Environment=FLASK_RUN_PORT=6868
|
|
|
|
|
ExecStart=/opt/${APPLICATION}/venv/bin/python -m flask run
|
|
|
|
|
Restart=always
|
|
|
|
|
RestartSec=10
|
|
|
|
|
StandardOutput=journal
|
|
|
|
|
StandardError=journal
|
|
|
|
|
|
|
|
|
|
[Install]
|
|
|
|
|
WantedBy=multi-user.target
|
|
|
|
|
EOF
|
|
|
|
|
fi
|
|
|
|
|
|
|
|
|
|
$STD systemctl daemon-reload
|
|
|
|
|
fi
|
|
|
|
|
|
|
|
|
|
systemctl enable ${APPLICATION}
|
|
|
|
|
systemctl start ${APPLICATION}
|
|
|
|
|
|
|
|
|
|
# Wait and check status
|
|
|
|
|
sleep 5
|
|
|
|
|
if systemctl is-active --quiet ${APPLICATION}; then
|
|
|
|
|
msg_ok "Service started successfully"
|
|
|
|
|
else
|
|
|
|
|
msg_error "Service failed to start. Checking logs..."
|
|
|
|
|
journalctl -u ${APPLICATION} --no-pager -n 20
|
|
|
|
|
exit 1
|
|
|
|
|
fi
|
|
|
|
|
msg_ok "Created Service"
|
|
|
|
|
|
|
|
|
|
motd_ssh
|
|
|
|
|
|