aboutsummaryrefslogtreecommitdiffstats
path: root/audio/esound
diff options
context:
space:
mode:
authorgreen <green@FreeBSD.org>2000-06-30 12:21:53 +0800
committergreen <green@FreeBSD.org>2000-06-30 12:21:53 +0800
commit2afdb8123e2f2adba06081cad035880ae961874e (patch)
treed5382aeeba28b1d98ea0ade38ad131b2ecce6d6c /audio/esound
parent6d49f05ed508b3e892f02311e1bd89ca79882783 (diff)
downloadfreebsd-ports-gnome-2afdb8123e2f2adba06081cad035880ae961874e.tar.gz
freebsd-ports-gnome-2afdb8123e2f2adba06081cad035880ae961874e.tar.zst
freebsd-ports-gnome-2afdb8123e2f2adba06081cad035880ae961874e.zip
Fix EsounD daemon and library insecurities noted on BugTraq.
Instead of an 0777 chock-full-o-races /tmp/.esd/, use a 0755 ~/.esd/. Also, the ~/.esd/socket of course needs only be 0644. Two macros had to be backed up by functions which returned a static buffer. These macros, ESD_UNIX_SOCKET_DIR and ESD_UNIX_SOCKET_NAME, both return constant strings as the new functions esd_unix_socket_dir() and esd_unix_socket_name(), so the static buffers are not particularly evil. The fix has been tested (without needing recompilation) by the most important EsounD-related apps, esd and XMMS, and works perfectly in both cases. It will be submitted to the EsounD maintainer to be fixed in the source distribution ASAP. Approved by: Security Officer Kris Noticed by: Stan Bubrouski <satan@FASTDIAL.NET>
Diffstat (limited to 'audio/esound')
-rw-r--r--audio/esound/files/patch-ab18
-rw-r--r--audio/esound/files/patch-ac32
-rw-r--r--audio/esound/files/patch-ad46
-rw-r--r--audio/esound/files/patch-ae11
4 files changed, 107 insertions, 0 deletions
diff --git a/audio/esound/files/patch-ab b/audio/esound/files/patch-ab
new file mode 100644
index 000000000000..e9adf4705bbf
--- /dev/null
+++ b/audio/esound/files/patch-ab
@@ -0,0 +1,18 @@
+--- esd.h.orig Thu Jun 29 23:12:53 2000
++++ esd.h Thu Jun 29 23:12:41 2000
+@@ -7,8 +7,15 @@
+ #endif
+
+ /* path and name of the default EsounD domain socket */
++#if 0
+ #define ESD_UNIX_SOCKET_DIR "/tmp/.esd"
+ #define ESD_UNIX_SOCKET_NAME ESD_UNIX_SOCKET_DIR ## "/" ## "socket"
++#else
++char *esd_unix_socket_dir(void);
++char *esd_unix_socket_name(void);
++#define ESD_UNIX_SOCKET_DIR esd_unix_socket_dir()
++#define ESD_UNIX_SOCKET_NAME esd_unix_socket_name()
++#endif
+
+ /* length of the audio buffer size */
+ #define ESD_BUF_SIZE (4 * 1024)
diff --git a/audio/esound/files/patch-ac b/audio/esound/files/patch-ac
new file mode 100644
index 000000000000..f493138a02a1
--- /dev/null
+++ b/audio/esound/files/patch-ac
@@ -0,0 +1,32 @@
+--- esd.c.orig Tue Apr 4 11:20:08 2000
++++ esd.c Thu Jun 29 23:34:18 2000
+@@ -219,12 +219,12 @@
+ {
+ mkdir(ESD_UNIX_SOCKET_DIR,
+ S_IRUSR|S_IWUSR|S_IXUSR|
+- S_IRGRP|S_IWGRP|S_IXGRP|
+- S_IROTH|S_IWOTH|S_IXOTH);
++ S_IRGRP|S_IXGRP|
++ S_IROTH|S_IXOTH);
+ chmod(ESD_UNIX_SOCKET_DIR,
+ S_IRUSR|S_IWUSR|S_IXUSR|
+- S_IRGRP|S_IWGRP|S_IXGRP|
+- S_IROTH|S_IWOTH|S_IXOTH);
++ S_IRGRP|S_IXGRP|
++ S_IROTH|S_IXOTH);
+ }
+ if (access(ESD_UNIX_SOCKET_NAME, R_OK | W_OK) == -1)
+ {
+@@ -317,9 +317,9 @@
+ /* let anyone access esd's socket - but we have authentication so they */
+ /* wont get far if they dont have the auth key */
+ chmod(ESD_UNIX_SOCKET_NAME,
+- S_IRUSR|S_IWUSR|S_IXUSR|
+- S_IRGRP|S_IWGRP|S_IXGRP|
+- S_IROTH|S_IWOTH|S_IXOTH);
++ S_IRUSR|S_IWUSR|
++ S_IRGRP|
++ S_IROTH);
+ }
+ if (listen(socket_listen,16)<0)
+ {
diff --git a/audio/esound/files/patch-ad b/audio/esound/files/patch-ad
new file mode 100644
index 000000000000..9d85c98df16a
--- /dev/null
+++ b/audio/esound/files/patch-ad
@@ -0,0 +1,46 @@
+--- esdlib.c.orig Thu Jun 29 23:31:04 2000
++++ esdlib.c Thu Jun 29 23:31:21 2000
+@@ -19,6 +19,8 @@
+ #include <arpa/inet.h>
+ #include <errno.h>
+ #include <sys/wait.h>
++#include <pwd.h>
++#include <limits.h>
+
+ #include <sys/un.h>
+
+@@ -1421,4 +1423,34 @@
+ */
+
+ return close( esd );
++}
++
++char *
++esd_unix_socket_dir(void) {
++ static char *sockdir = NULL, sockdirbuf[PATH_MAX];
++ struct passwd *pw;
++
++ if (sockdir != NULL)
++ return (sockdir);
++ pw = getpwuid(getuid());
++ if (pw == NULL || pw->pw_dir == NULL) {
++ fprintf(stderr, "esd: could not find home directory\n");
++ exit(1);
++ }
++ snprintf(sockdirbuf, sizeof(sockdirbuf), "%s/.esd", pw->pw_dir);
++ endpwent();
++ sockdir = sockdirbuf;
++ return (sockdir);
++}
++
++char *
++esd_unix_socket_name(void) {
++ static char *sockname = NULL, socknamebuf[PATH_MAX];
++
++ if (sockname != NULL)
++ return (sockname);
++ snprintf(socknamebuf, sizeof(socknamebuf), "%s/socket",
++ esd_unix_socket_dir());
++ sockname = socknamebuf;
++ return (sockname);
+ }
diff --git a/audio/esound/files/patch-ae b/audio/esound/files/patch-ae
new file mode 100644
index 000000000000..891f45cad290
--- /dev/null
+++ b/audio/esound/files/patch-ae
@@ -0,0 +1,11 @@
+--- ltmain.sh.orig Thu Jun 29 23:41:49 2000
++++ ltmain.sh Thu Jun 29 23:45:36 2000
+@@ -3227,7 +3227,7 @@
+ outputname=
+ if test "$fast_install" = no && test -n "$relink_command"; then
+ if test "$finalize" = yes; then
+- outputname="/tmp/$$-$file"
++ outputname=$(mktemp "${TMPDIR:-/tmp}/$file.XXXXXX") || exit $?
+ # Replace the output file specification.
+ relink_command=`$echo "X$relink_command" | $Xsed -e 's%@OUTPUT@%'"$outputname"'%g'`
+