Lightmediascanner becomes systemd user service 09/4409/4
authorTadao Tanikawa <tanikawa.tadao@jp.panasonic.com>
Wed, 9 Dec 2015 04:34:28 +0000 (13:34 +0900)
committerGerrit Code Review <gerrit@172.30.200.200>
Fri, 11 Dec 2015 12:13:50 +0000 (12:13 +0000)
Now lightmediascanner becomes systemd user service because
it needs D-Bus session bus provided by D-Bus Daemon which
is managed by systemd (as user service).

Change-Id: I38aa8a60394dbf078b3dd3a42e60514816f96969
Signed-off-by: Tadao Tanikawa <tanikawa.tadao@jp.panasonic.com>
meta-agl/recipes-multimedia/lightmediascanner/files/lightmediascanner.service
meta-agl/recipes-multimedia/lightmediascanner/lightmediascanner_%.bbappend

index 00bbf8d..a13e2e6 100644 (file)
@@ -2,9 +2,10 @@
 Description=Lightmediascanner (LMS)
 
 [Service]
-Environment=DBUS_SESSION_BUS_ADDRESS=unix:path=/run/user/%U/dbus/user_bus_socket
-User=root
-ExecStart=/usr/bin/dbus-launch --auto-syntax /usr/bin/lightmediascannerd --startup-scan --directory=/usr/share/media
+Type=dbus
+BusName=org.lightmediascanner
+ExecStart=/usr/bin/lightmediascannerd --startup-scan --directory=/usr/share/media
 
 [Install]
-WantedBy=multi-user.target
+WantedBy=default.target
+Alias=dbus-org.lightmediascanner.service
index d2b790e..f9c269d 100644 (file)
@@ -7,13 +7,19 @@ SRC_URI += "file://lightmediascanner.service"
 
 inherit systemd
 
-SYSTEMD_PACKAGES = "${PN}"
-SYSTEMD_SERVICE_${PN} = ""
-SYSTEMD_SERVICE_${PN} += "lightmediascanner.service"
-
 do_install_append() {
        # Install LMS systemd service
        if ${@bb.utils.contains('DISTRO_FEATURES', 'systemd', 'true', 'false', d)}; then
-              install -p -D ${WORKDIR}/lightmediascanner.service ${D}${systemd_unitdir}/system/lightmediascanner.service
+              install -p -D ${WORKDIR}/lightmediascanner.service ${D}${systemd_user_unitdir}/lightmediascanner.service
+
+              # Execute these manually on behalf of systemctl script (from systemd-systemctl-native.bb)
+              # because it does not support systemd's user mode.
+              mkdir -p ${D}/etc/systemd/user/default.target.wants/
+              ln -sf ${systemd_user_unitdir}/lightmediascanner.service ${D}/etc/systemd/user/dbus-org.lightmediascanner.service
+              ln -sf ${systemd_user_unitdir}/lightmediascanner.service ${D}/etc/systemd/user/default.target.wants/lightmediascanner.service
        fi
 }
+
+FILES_${PN} += " \
+    ${@bb.utils.contains('DISTRO_FEATURES', 'systemd', '${systemd_user_unitdir}/lightmediascanner.service', '', d)} \
+    "