Compare commits
17 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
|
2e68ad7323
|
|||
|
792465dab2
|
|||
|
7f06ffe6d7
|
|||
|
9dc6aa8d04
|
|||
|
163a642f5a
|
|||
|
2cc5945e1d
|
|||
|
8adbb87fc3
|
|||
|
399544dc50
|
|||
|
822c3941fd
|
|||
|
210fb30059
|
|||
|
ebe75427af
|
|||
|
d0fe37033c
|
|||
|
8cdacba0d6
|
|||
|
597a02a5ed
|
|||
|
290730f413
|
|||
|
a4e896158d
|
|||
|
e68d675f4b
|
+1
-1
@@ -1,3 +1,3 @@
|
|||||||
NAVIDROME_MUSIC_FOLDER="/opt/navidrome/music"
|
NAVIDROME_MUSIC_FOLDER="/opt/navidrome/music"
|
||||||
BIND_ADDRESS="192.168.2.24"
|
BIND_ADDRESS="0.0.0.0"
|
||||||
BIND_PORT="5001"
|
BIND_PORT="5001"
|
||||||
@@ -3,3 +3,5 @@ setup.sh
|
|||||||
navidrome-upload.service
|
navidrome-upload.service
|
||||||
.idea/
|
.idea/
|
||||||
.env
|
.env
|
||||||
|
/README.md
|
||||||
|
__pycache__/
|
||||||
@@ -9,7 +9,7 @@ Group=navidrome-uploader
|
|||||||
WorkingDirectory=/opt/navidrome-uploader
|
WorkingDirectory=/opt/navidrome-uploader
|
||||||
Environment="PATH=/opt/navidrome-uploader/venv/bin"
|
Environment="PATH=/opt/navidrome-uploader/venv/bin"
|
||||||
EnvironmentFile=/etc/default/navidrome-uploader/.env
|
EnvironmentFile=/etc/default/navidrome-uploader/.env
|
||||||
ExecStart=/opt/navidrome-uploader/venv/bin/gunicorn -c gunicorn.conf.py main:app
|
ExecStart=/opt/navidrome-uploader/venv/bin/gunicorn --no-control-socket -c gunicorn.conf.py main:app
|
||||||
Restart=on-failure
|
Restart=on-failure
|
||||||
RestartSec=30
|
RestartSec=30
|
||||||
|
|
||||||
@@ -20,7 +20,7 @@ AmbientCapabilities=
|
|||||||
ProtectSystem=strict
|
ProtectSystem=strict
|
||||||
ProtectHome=yes
|
ProtectHome=yes
|
||||||
PrivateTmp=yes
|
PrivateTmp=yes
|
||||||
ReadWritePaths=/opt/navidrome-uploader
|
ReadWritePaths=/opt/navidrome-uploader /opt/navidrome/music
|
||||||
InaccessiblePaths=/boot /mnt /media
|
InaccessiblePaths=/boot /mnt /media
|
||||||
|
|
||||||
PrivateDevices=yes
|
PrivateDevices=yes
|
||||||
|
|||||||
Vendored
+18
@@ -0,0 +1,18 @@
|
|||||||
|
navidrome-uploader (0.1.0-2) unstable; urgency=high
|
||||||
|
|
||||||
|
* Run pip install stage as navidrome-uploader user instead of root
|
||||||
|
|
||||||
|
-- Arian Nasr <arian@2ari.ca> Tue, 14 Apr 2026 12:11:00 -0400
|
||||||
|
|
||||||
|
navidrome-uploader (0.1.0-1) unstable; urgency=medium
|
||||||
|
|
||||||
|
* Disable gunicorn control socket in systemd service unit
|
||||||
|
|
||||||
|
-- Arian Nasr <arian@2ari.ca> Thu, 09 Apr 2026 01:58:00 -0400
|
||||||
|
|
||||||
|
navidrome-uploader (0.1.0) unstable; urgency=medium
|
||||||
|
|
||||||
|
* Add Debian packaging with systemd service integration and venv setup.
|
||||||
|
|
||||||
|
-- Arian Nasr <arian@2ari.ca> Tue, 07 Apr 2026 12:00:00 +0000
|
||||||
|
|
||||||
Vendored
+12
@@ -0,0 +1,12 @@
|
|||||||
|
Source: navidrome-uploader
|
||||||
|
Section: web
|
||||||
|
Priority: optional
|
||||||
|
Maintainer: Arian Nasr <arian@2ari.ca>
|
||||||
|
Build-Depends: debhelper-compat (= 13)
|
||||||
|
Standards-Version: 4.7.0
|
||||||
|
Rules-Requires-Root: no
|
||||||
|
|
||||||
|
Package: navidrome-uploader
|
||||||
|
Architecture: all
|
||||||
|
Depends: ${misc:Depends}, adduser, python3, python3-venv
|
||||||
|
Description: Navidrome Web Upload Utility
|
||||||
Vendored
+7
@@ -0,0 +1,7 @@
|
|||||||
|
opt/navidrome-uploader
|
||||||
|
opt/navidrome-uploader/templates
|
||||||
|
opt/navidrome-uploader/static
|
||||||
|
opt/navidrome-uploader/static/css
|
||||||
|
opt/navidrome-uploader/static/js
|
||||||
|
etc/default/navidrome-uploader
|
||||||
|
|
||||||
Vendored
+9
@@ -0,0 +1,9 @@
|
|||||||
|
main.py opt/navidrome-uploader/
|
||||||
|
gunicorn.conf.py opt/navidrome-uploader/
|
||||||
|
requirements.txt opt/navidrome-uploader/
|
||||||
|
.env.example opt/navidrome-uploader/
|
||||||
|
templates/* opt/navidrome-uploader/templates/
|
||||||
|
static/css/* opt/navidrome-uploader/static/css/
|
||||||
|
static/js/* opt/navidrome-uploader/static/js/
|
||||||
|
contrib/navidrome-uploader.service lib/systemd/system/
|
||||||
|
|
||||||
Vendored
+26
@@ -0,0 +1,26 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
set -e
|
||||||
|
|
||||||
|
APP_DIR="/opt/navidrome-uploader"
|
||||||
|
VENV_DIR="${APP_DIR}/venv"
|
||||||
|
APP_USER="navidrome-uploader"
|
||||||
|
|
||||||
|
case "$1" in
|
||||||
|
configure)
|
||||||
|
chown -R "$APP_USER:$APP_USER" "$APP_DIR"
|
||||||
|
|
||||||
|
runuser -u "$APP_USER" -- python3 -m venv "$VENV_DIR"
|
||||||
|
runuser -u "$APP_USER" -- "$VENV_DIR/bin/pip" install --no-cache-dir --upgrade pip
|
||||||
|
runuser -u "$APP_USER" -- "$VENV_DIR/bin/pip" install --no-cache-dir -r "$APP_DIR/requirements.txt"
|
||||||
|
|
||||||
|
if command -v systemctl >/dev/null 2>&1; then
|
||||||
|
systemctl daemon-reload || true
|
||||||
|
systemctl enable navidrome-uploader.service || true
|
||||||
|
systemctl restart navidrome-uploader.service || true
|
||||||
|
fi
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
|
||||||
|
exit 0
|
||||||
|
|
||||||
|
|
||||||
Vendored
+14
@@ -0,0 +1,14 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
set -e
|
||||||
|
|
||||||
|
if command -v systemctl > /dev/null 2>&1; then
|
||||||
|
systemctl daemon-reload || true
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ "$1" = "purge" ]; then
|
||||||
|
rm -rf /etc/default/navidrome-uploader
|
||||||
|
rm -rf /opt/navidrome-uploader/venv
|
||||||
|
fi
|
||||||
|
|
||||||
|
exit 0
|
||||||
|
|
||||||
Vendored
+10
@@ -0,0 +1,10 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
set -e
|
||||||
|
|
||||||
|
if ! getent passwd navidrome-uploader > /dev/null 2>&1; then
|
||||||
|
printf "Creating navidrome-uploader user\n"
|
||||||
|
useradd --system --shell /usr/sbin/nologin --user-group navidrome-uploader
|
||||||
|
fi
|
||||||
|
|
||||||
|
exit 0
|
||||||
|
|
||||||
Vendored
+14
@@ -0,0 +1,14 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
set -e
|
||||||
|
|
||||||
|
case "$1" in
|
||||||
|
remove|deconfigure)
|
||||||
|
if command -v systemctl > /dev/null 2>&1; then
|
||||||
|
systemctl stop navidrome-uploader.service || true
|
||||||
|
systemctl disable navidrome-uploader.service || true
|
||||||
|
fi
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
|
||||||
|
exit 0
|
||||||
|
|
||||||
Vendored
+10
@@ -0,0 +1,10 @@
|
|||||||
|
#!/usr/bin/make -f
|
||||||
|
|
||||||
|
%:
|
||||||
|
dh $@
|
||||||
|
|
||||||
|
override_dh_install:
|
||||||
|
dh_install
|
||||||
|
install -d debian/navidrome-uploader/etc/default/navidrome-uploader
|
||||||
|
install -m 0640 .env.example debian/navidrome-uploader/etc/default/navidrome-uploader/.env
|
||||||
|
|
||||||
Vendored
+2
@@ -0,0 +1,2 @@
|
|||||||
|
3.0 (native)
|
||||||
|
|
||||||
@@ -0,0 +1,9 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
set -eu
|
||||||
|
|
||||||
|
SCRIPT_DIR="$(CDPATH= cd -- "$(dirname -- "$0")" && pwd)"
|
||||||
|
PROJECT_ROOT="$(CDPATH= cd -- "${SCRIPT_DIR}/.." && pwd)"
|
||||||
|
|
||||||
|
cd "${PROJECT_ROOT}"
|
||||||
|
dpkg-buildpackage -us -uc -b
|
||||||
|
|
||||||
Reference in New Issue
Block a user