Skip site navigation (1)Skip section navigation (2)
Date:      Thu,  9 Apr 2009 11:31:20 +0530 (IST)
From:      Ashish SHUKLA <wahjava@gmail.com>
To:        FreeBSD-gnats-submit@FreeBSD.org
Subject:   ports/133533: [PATCH] Add a static user/group for audio/musicpd port
Message-ID:  <20090409060120.4CF221E23C@chateau.d.lf>
Resent-Message-ID: <200904090610.n396A50f000304@freefall.freebsd.org>

next in thread | raw e-mail | index | archive | help

>Number:         133533
>Category:       ports
>Synopsis:       [PATCH] Add a static user/group for audio/musicpd port
>Confidential:   no
>Severity:       non-critical
>Priority:       low
>Responsible:    freebsd-ports-bugs
>State:          open
>Quarter:        
>Keywords:       
>Date-Required:
>Class:          sw-bug
>Submitter-Id:   current-users
>Arrival-Date:   Thu Apr 09 06:10:05 UTC 2009
>Closed-Date:
>Last-Modified:
>Originator:     Ashish SHUKLA
>Release:        FreeBSD 8.0-CURRENT amd64
>Organization:
N/A
>Environment:
System: FreeBSD chateau.d.lf 8.0-CURRENT FreeBSD 8.0-CURRENT #2: Wed Apr 8 09:26:34 IST 2009 root@chateau.d.lf:/usr/obj/usr/src/sys/CHATEAU amd64


>Description:
The audio/musicpd port isn't installing any user/group for running mpd, like other
distributions do. This attached diff adds a static user/group for the audio/musicpd
port.

The UID 137 and GID 137 needs to be reserved for this port. The diff for
${PORTSDIR}/UIDs and ${PORTSDIR}/GIDs is also attached in the same diff.
>How-To-Repeat:
>Fix:
diff -urN /usr/ports/audio/musicpd/Makefile musicpd/Makefile
--- /usr/ports/audio/musicpd/Makefile	2009-03-18 22:15:43.000000000 +0530
+++ musicpd/Makefile	2009-04-09 08:55:41.000000000 +0530
@@ -7,6 +7,7 @@
 
 PORTNAME=	musicpd
 PORTVERSION=	0.14.2
+PORTREVISION=	1
 CATEGORIES=	audio ipv6
 MASTER_SITES=	SF
 DISTNAME=	mpd-${PORTVERSION}
@@ -51,6 +52,24 @@
 		LAME		"Support for MP3 Icecast Streams"	off \
 		SAMPLERATE	"Support sample rate conversion"	off
 
+MPDUSER?=	mpd
+MPDGROUP?=	mpd
+MPDDIR?=	${PREFIX}/var/mpd
+
+MPDUID=	137
+MPDGID=	${MPDUID}
+
+PLIST_SUB=	MPDUSER=${MPDUSER} \
+		MPDGROUP=${MPDGROUP}
+
+SUB_LIST+=	MPDUSER=${MPDUSER} \
+		MPDGROUP=${MPDGROUP} \
+		MPDDIR=${MPDDIR} \
+		MPDUID=${MPDUID} \
+		MPDGID=${MPDGID}
+
+SUB_FILES+=	pkg-install pkg-deinstall
+
 .include <bsd.port.pre.mk>
 
 .if defined(WITHOUT_FLAC)
@@ -151,13 +170,20 @@
 LIB_DEPENDS+=	samplerate.1:${PORTSDIR}/audio/libsamplerate
 .endif
 
-.if defined(NOPORTDOCS)
 post-patch:
+	@${REINPLACE_CMD} -e "s/%%MPDDIR%%/${MPDDIR:C/\//\\\//g}/g" -e "s/%%MPDUSER%%/${MPDUSER}/g" \
+		${WRKSRC}/doc/mpdconf.example
+.if defined(NOPORTDOCS)
 	@${REINPLACE_CMD} -e '/^install-data-am:/ s|install-docDATA||' \
 		${WRKSRC}/Makefile.in ${WRKSRC}/doc/Makefile.in
 .endif
 
+pre-install:
+	@PKG_PREFIX=${PREFIX} ${SH} ${PKGINSTALL} ${PKGNAME} PRE-INSTALL
+
 post-install:
+	@${MKDIR} ${MPDDIR}
+	@${CHOWN} -R ${MPDUSER}:${MPDGROUP} ${MPDDIR}
 	@${ECHO_MSG}
 	@${CAT} ${PKGMESSAGE}
 	@${ECHO_MSG}
diff -urN /usr/ports/audio/musicpd/files/patch-doc_mpdconf.example musicpd/files/patch-doc_mpdconf.example
--- /usr/ports/audio/musicpd/files/patch-doc_mpdconf.example	1970-01-01 05:30:00.000000000 +0530
+++ musicpd/files/patch-doc_mpdconf.example	2009-04-09 08:32:02.000000000 +0530
@@ -0,0 +1,72 @@
+
+$FreeBSD$
+
+--- doc/mpdconf.example.orig
++++ doc/mpdconf.example
+@@ -6,27 +6,27 @@
+ # This setting controls the top directory which MPD will search to discover the
+ # available audio files and add them to the daemon's online database.
+ #
+-music_directory			"~/music"
++music_directory			"%%MPDDIR%%/music"
+ #
+ # This setting sets the MPD internal playlist directory. The purpose of this
+ # directory is storage for playlists created by MPD. The server will use 
+ # playlist files not created by the server but only if they are in the MPD
+ # format.
+ #
+-playlist_directory		"~/.mpd/playlists"
++playlist_directory		"%%MPDDIR%%/playlists"
+ #
+ # This setting sets the location of the MPD database. This file is used to
+ # load the database at server start up and store the database while the 
+ # server is not up.
+ #
+-db_file				"~/.mpd/database"
++db_file				"%%MPDDIR%%/database"
+ # 
+ # These settings are the locations for the daemon log files for the daemon.
+ # These logs are great for troubleshooting, depending on your log_level
+ # settings.
+ #
+-log_file			"~/.mpd/log"
+-error_file			"~/.mpd/error-log"
++log_file			"%%MPDDIR%%/log"
++error_file			"%%MPDDIR%%/error-log"
+ ###############################################################################
+ 
+ 
+@@ -36,13 +36,13 @@
+ # for use of mpd --kill and some init scripts. This setting is disabled by
+ # default.
+ #
+-#pid_file			"~/.mpd/pid"
++pid_file			"%%MPDDIR%%/pid"
+ #
+ # This setting sets the location of the file which contains information about
+ # most variables to get MPD back into the same general shape it was in before
+ # it was brought down. This setting is disabled by default.
+ #
+-#state_file			"~/.mpd/state"
++state_file			"%%MPDDIR%%/state"
+ #
+ ###############################################################################
+ 
+@@ -55,7 +55,7 @@
+ # unprivileged user. This setting is disabled by default, and the server will
+ # run as root.
+ #
+-#user				"nobody"
++user				"%%MPDUSER%%"
+ #
+ # This setting sets the address for the daemon to listen on. Careful attention
+ # should be paid if this is assigned to anything other then the default, any.
+@@ -65,7 +65,7 @@
+ #bind_to_address		"any"
+ #
+ # And for Unix Socket
+-#bind_to_address		"~/.mpd/socket"
++#bind_to_address		"%%MPDDIR%%/socket"
+ #
+ # This setting is the port that is desired for the daemon to get assigned to.
+ #
diff -urN /usr/ports/audio/musicpd/files/pkg-deinstall.in musicpd/files/pkg-deinstall.in
--- /usr/ports/audio/musicpd/files/pkg-deinstall.in	1970-01-01 05:30:00.000000000 +0530
+++ musicpd/files/pkg-deinstall.in	2009-04-09 08:17:51.000000000 +0530
@@ -0,0 +1,17 @@
+#!/bin/sh -
+#
+# $FreeBSD$
+#
+
+MPDUSER=%%MPDUSER%%
+MPDGROUP=%%MPDGROUP%%
+
+if [ "$2" = "POST-DEINSTALL" ]; then
+  if /usr/sbin/pw group show "${MPDGROUP}" 2>&1 >/dev/null; then
+    echo "You should manually remove the \"${MPDGROUP}\" group."
+  fi
+
+  if /usr/sbin/pw user show "${MPDUSER}" 2>&1 >/dev/null; then
+    echo "You should manually remove the \"${MPDUSER}\" user."
+  fi
+fi
diff -urN /usr/ports/audio/musicpd/files/pkg-install.in musicpd/files/pkg-install.in
--- /usr/ports/audio/musicpd/files/pkg-install.in	1970-01-01 05:30:00.000000000 +0530
+++ musicpd/files/pkg-install.in	2009-04-09 08:58:44.000000000 +0530
@@ -0,0 +1,76 @@
+#!/bin/sh -
+#
+# $FreeBSD$
+#
+
+MPDDIR=%%MPDDIR%%
+MPDUSER=%%MPDUSER%%
+MPDGROUP=%%MPDGROUP%%
+MPDUID=%%MPDUID%%
+MPDGID=%%MPDGID%%
+
+ask() {
+  local question default answer
+
+  question=$1
+  default=$2
+  if [ -z "${PACKAGE_BUILDING}" ]; then
+    read -p "${question} [${default}]? " answer
+  fi
+  if [ "x${answer}" = "x" ]; then
+    answer=${default}
+  fi
+  echo ${answer}
+}
+
+yesno() {
+  local default question answer
+
+  question=$1
+  default=$2
+  while :; do
+    answer=$(ask "${question}" "${default}")
+    case "${answer}" in
+      [Yy][Ee][Ss]|[Yy])
+        return 0
+        ;;
+      [Nn][Oo]|[Nn])
+        return 1
+        ;;
+    esac
+    echo "Please answer yes or no."
+   done
+}
+
+if [ "$2" = "PRE-INSTALL" ]; then
+  if /usr/sbin/pw group show "${MPDGROUP}" 2>&1 >/dev/null; then
+    echo "You already have a \"${MPDGROUP}\" group, so I will use it."
+  else
+    echo "You need a \"${MPDGROUP}\" group."
+    if yesno "Would you like me to create it" "YES"; then
+      /usr/sbin/pw groupadd "${MPDGROUP}" -g "${MPDGID}" -h - || \
+        /usr/sbin/pw groupadd "${MPDGROUP}" -h - || exit
+      echo "Done."
+    else
+      echo "Please create the \"${MPDGROUP}\" group manually and try again."
+      exit 1
+    fi
+  fi
+
+  if /usr/sbin/pw user show "${MPDUSER}" 2>&1 >/dev/null; then
+    echo "You already have a \"${MPDUSER}\" user, so I will use it."
+  else
+    echo "You need a \"${MPDUSER}\" user."
+    if yesno "Would you like me to create it" "YES"; then
+      /usr/sbin/pw useradd "${MPDUSER}" -u "${MPDUID}" -g "${MPDGROUP}" -h - -d "${MPDDIR}" \
+        -s /sbin/nologin -c "MusicPD pseudo-user" || \
+        /usr/sbin/pw useradd "${MPDUSER}" -g "${MPDGROUP}" -h - -d "${MPDDIR}" \
+        -s /sbin/nologin -c "MusicPD pseudo-user" || exit
+    else
+      echo "Please create the \"${MPDUSER}\" user manually and try again."
+      exit 1
+    fi
+  fi
+  [ -d ${MPDDIR} ] || mkdir ${MPDDIR};
+  chown -R ${MPDUSER}:${MPDGROUP} ${MPDDIR}
+fi
diff -urN /usr/ports/audio/musicpd/files/pkg-message.in musicpd/files/pkg-message.in
--- /usr/ports/audio/musicpd/files/pkg-message.in	2008-12-06 02:41:46.000000000 +0530
+++ musicpd/files/pkg-message.in	2009-04-09 08:45:58.000000000 +0530
@@ -17,6 +17,9 @@
 
 or reboot.
 
+The example configuration of MPD server requires music files to
+be stored at %%MPDDIR%%/music .
+
 NOTE: The musicpd server is pretty useless without a client.
       You might want to install one of the following ports too:
       mpc, ncmpc, glurp, gmpc, kmp, or phpmp.
diff -urN /usr/ports/audio/musicpd/pkg-plist musicpd/pkg-plist
--- /usr/ports/audio/musicpd/pkg-plist	2009-01-28 11:00:46.000000000 +0530
+++ musicpd/pkg-plist	2009-04-09 08:51:00.000000000 +0530
@@ -6,5 +6,8 @@
 %%PORTDOCS%%%%DOCSDIR%%/TODO
 %%PORTDOCS%%%%DOCSDIR%%/NEWS
 %%PORTDOCS%%%%DOCSDIR%%/UPGRADING
+%%PORTDOCS%%%%DOCSDIR%%/protocol.html
 %%PORTDOCS%%@dirrm %%DOCSDIR%%
 %%PORTDOCS%%@unexec %D/%%DOCSDIR%% 2>/dev/null || true
+@dirrmtry var/mpd
+@dirrmtry var
--- /usr/ports/UIDs	2009-04-07 17:19:11.000000000 +0530
+++ UIDs	2009-04-09 11:20:33.000000000 +0530
@@ -76,6 +76,7 @@
 undernet:*:134:134::0:0:Undernet ircu Daemon:/nonexistant:/usr/sbin/nologin
 rabbitmq:*:135:135::0:0:RabbitMQ:/var/db/rabbitmq:/usr/sbin/nologin
 dhcpd:*:136:136::0:0:ISC DHCP daemon:/nonexistent:/usr/sbin/nologin
+mpd:*:137:137:MusicPD pseudo-user:/var/tmp/musicpd/var/mpd:/sbin/nologin
 cricket:*:141:80::0:0:Cricket Monitoring User:/usr/local/cricket:/usr/sbin/nologin
 dovecot:*:143:143::0:0:Dovecot User:/var/empty:/usr/sbin/nologin
 rbldns:*:153:153::0:0:rbldnsd pseudo-user:/nonexistent:/usr/sbin/nologin
--- /usr/ports/GIDs	2009-04-07 17:19:11.000000000 +0530
+++ GIDs	2009-04-09 11:20:43.000000000 +0530
@@ -68,6 +68,7 @@
 undernet:*:134:
 rabbitmq:*:135:
 dhcpd:*:136:
+mpd:*:137
 dovecot:*:143:
 rbldns:*:153:
 sfs:*:171:

>Release-Note:
>Audit-Trail:
>Unformatted:



Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?20090409060120.4CF221E23C>