GNU bug report logs - #63082
mpd defaul configuration does not work ('No database' error)

Previous Next

Package: guix;

Reported by: Maxim Cournoyer <maxim.cournoyer <at> gmail.com>

Date: Wed, 26 Apr 2023 02:59:02 UTC

Severity: normal

Done: Maxim Cournoyer <maxim.cournoyer <at> gmail.com>

Bug is archived. No further changes may be made.

Full log


View this message in rfc822 format

From: Maxim Cournoyer <maxim.cournoyer <at> gmail.com>
To: 63082 <at> debbugs.gnu.org
Cc: Maxim Cournoyer <maxim.cournoyer <at> gmail.com>
Subject: bug#63082: [PATCH 11/17] services: mpd: Warn when the MPD user is not in the "audio" group.
Date: Fri, 28 Apr 2023 10:27:04 -0400
Relates to <https://issues.guix.gnu.org>.

* gnu/services/audio.scm (%mpd-user) [group]: Add comment.
(mpd-user-sanitizer): Warn if the MPD user is not in the audio group.
---
 gnu/services/audio.scm | 16 +++++++++++++---
 1 file changed, 13 insertions(+), 3 deletions(-)

diff --git a/gnu/services/audio.scm b/gnu/services/audio.scm
index 550ccc542c..9579432ea3 100644
--- a/gnu/services/audio.scm
+++ b/gnu/services/audio.scm
@@ -30,6 +30,7 @@ (define-module (gnu services audio)
   #:use-module (gnu services configuration)
   #:use-module (gnu services shepherd)
   #:use-module (gnu services admin)
+  #:use-module (gnu system accounts)
   #:use-module (gnu system shadow)
   #:use-module (gnu packages admin)
   #:use-module (gnu packages mpd)
@@ -172,6 +173,8 @@ (define-maybe boolean (prefix mpd-))
 (define %mpd-user
   (user-account
    (name "mpd")
+   ;; Being in the audio group ensures that PulseAudio can access sound
+   ;; devices.
    (group "audio")
    (system? #t)
    (comment "Music Player Daemon (MPD) user")
@@ -208,10 +211,17 @@ (define (mpd-serialize-port field-name value)
 
 (define-maybe port (prefix mpd-))
 
-;;; Procedures for unsupported value types, to be removed.
-
+;;; Sanitizer procedures.
 (define (mpd-user-sanitizer value)
-  (cond ((user-account? value) value)
+  (cond ((user-account? value)
+         (match-record value <user-account>
+           (group supplementary-groups)
+           (unless (or (string=? "audio" group)
+                       (member "audio" supplementary-groups))
+             ;; Being in the "audio" group is necessary for access to the
+             ;; sound devices.
+             (warning (G_ "mpd user not member of \"audio\" group~%"))))
+         value)
         ((string? value)
          (warning (G_ "string value for 'user' is deprecated, use \
 user-account instead~%"))
-- 
2.39.2





This bug report was last modified 1 year and 358 days ago.

Previous Next


GNU bug tracking system
Copyright (C) 1999 Darren O. Benham, 1997,2003 nCipher Corporation Ltd, 1994-97 Ian Jackson.