From e00c96df9942723ff867f12c4db3ae4ffbe51ccf Mon Sep 17 00:00:00 2001 From: Anton-Latukha Date: Thu, 18 May 2017 16:51:50 +0300 Subject: [PATCH] systemd service with user switch. rm previous systemd unit service cmake now placing new file 'qbittorrent-nox@.service.in' systemd service now "Type=simple" --- configure | 4 ++-- configure.ac | 2 +- dist/unix/CMakeLists.txt | 4 ++-- dist/unix/systemd/qbittorrent-nox.service.in | 11 ----------- dist/unix/systemd/qbittorrent-nox@.service.in | 14 ++++++++++++++ unixconf.pri | 2 +- 6 files changed, 20 insertions(+), 17 deletions(-) delete mode 100644 dist/unix/systemd/qbittorrent-nox.service.in create mode 100644 dist/unix/systemd/qbittorrent-nox@.service.in diff --git a/configure b/configure index 685aa7cff..8b25e3f1a 100755 --- a/configure +++ b/configure @@ -6689,7 +6689,7 @@ $as_echo "$as_me: WARNING: unrecognized options: $ac_unrecognized_opts" >&2;} fi if test "x$enable_systemd" = "xyes"; then : - ac_config_files="$ac_config_files dist/unix/systemd/qbittorrent-nox.service" + ac_config_files="$ac_config_files dist/unix/systemd/qbittorrent-nox@.service" cat >confcache <<\_ACEOF # This file is a shell script that caches the results of configure @@ -7443,7 +7443,7 @@ do case $ac_config_target in "depfiles") CONFIG_COMMANDS="$CONFIG_COMMANDS depfiles" ;; "conf.pri") CONFIG_FILES="$CONFIG_FILES conf.pri" ;; - "dist/unix/systemd/qbittorrent-nox.service") CONFIG_FILES="$CONFIG_FILES dist/unix/systemd/qbittorrent-nox.service" ;; + "dist/unix/systemd/qbittorrent-nox@.service") CONFIG_FILES="$CONFIG_FILES dist/unix/systemd/qbittorrent-nox@.service" ;; *) as_fn_error $? "invalid argument: \`$ac_config_target'" "$LINENO" 5;; esac diff --git a/configure.ac b/configure.ac index 342d9550f..872dfe3ff 100644 --- a/configure.ac +++ b/configure.ac @@ -218,7 +218,7 @@ AC_SUBST(QBT_REMOVE_DEFINES) AC_OUTPUT(conf.pri) AS_IF([test "x$enable_systemd" = "xyes"], - [AC_OUTPUT(dist/unix/systemd/qbittorrent-nox.service)]) + [AC_OUTPUT(dist/unix/systemd/qbittorrent-nox@.service)]) diff --git a/dist/unix/CMakeLists.txt b/dist/unix/CMakeLists.txt index f625cbc20..8d4be6399 100644 --- a/dist/unix/CMakeLists.txt +++ b/dist/unix/CMakeLists.txt @@ -2,8 +2,8 @@ if (SYSTEMD) find_package(Systemd) if (SYSTEMD_FOUND) set(EXPAND_BINDIR ${CMAKE_INSTALL_FULL_BINDIR}) - configure_file(systemd/qbittorrent-nox.service.in ${CMAKE_CURRENT_BINARY_DIR}/qbittorrent-nox.service @ONLY) - install(FILES ${CMAKE_CURRENT_BINARY_DIR}/qbittorrent-nox.service + configure_file(systemd/qbittorrent-nox@.service.in ${CMAKE_CURRENT_BINARY_DIR}/qbittorrent-nox@.service @ONLY) + install(FILES ${CMAKE_CURRENT_BINARY_DIR}/qbittorrent-nox@.service DESTINATION ${SYSTEMD_SERVICES_INSTALL_DIR} COMPONENT data) endif(SYSTEMD_FOUND) diff --git a/dist/unix/systemd/qbittorrent-nox.service.in b/dist/unix/systemd/qbittorrent-nox.service.in deleted file mode 100644 index b395917c3..000000000 --- a/dist/unix/systemd/qbittorrent-nox.service.in +++ /dev/null @@ -1,11 +0,0 @@ -[Unit] -Description=qBittorrent Daemon Service -After=network.target - -[Service] -Type=forking -User=1000 -ExecStart=@EXPAND_BINDIR@/qbittorrent-nox -d - -[Install] -WantedBy=multi-user.target diff --git a/dist/unix/systemd/qbittorrent-nox@.service.in b/dist/unix/systemd/qbittorrent-nox@.service.in new file mode 100644 index 000000000..59396a844 --- /dev/null +++ b/dist/unix/systemd/qbittorrent-nox@.service.in @@ -0,0 +1,14 @@ +[Unit] +Description=qBittorrenti-nox service for user %I + +Documentation=man:qbittorrent-nox(1) +After=network.target + +[Service] +Type=simple +PrivateTmp=false +User=%i +ExecStart=@EXPAND_BINDIR@/qbittorrent-nox + +[Install] +WantedBy=multi-user.target diff --git a/unixconf.pri b/unixconf.pri index 5ae018eac..a93a7a9d3 100644 --- a/unixconf.pri +++ b/unixconf.pri @@ -29,7 +29,7 @@ DIST_PATH = ../dist/unix # Systemd Service file nogui:systemd { - systemdService.files = $$DIST_PATH/systemd/qbittorrent-nox.service + systemdService.files = $$DIST_PATH/systemd/qbittorrent-nox@.service systemdService.path = $$PREFIX/lib/systemd/system/ INSTALLS += systemdService }