aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorume <ume@FreeBSD.org>2002-08-16 00:10:56 +0800
committerume <ume@FreeBSD.org>2002-08-16 00:10:56 +0800
commit16bd96bf7bdc55b53184ccdacb00738060a1ebb1 (patch)
tree46e8b00e642b89ced2f07bcd1d908b8e647f69ea
parenta742bfc7a31d68d8c81b7c12a44e9e69b88e43c7 (diff)
downloadfreebsd-ports-gnome-16bd96bf7bdc55b53184ccdacb00738060a1ebb1.tar.gz
freebsd-ports-gnome-16bd96bf7bdc55b53184ccdacb00738060a1ebb1.tar.zst
freebsd-ports-gnome-16bd96bf7bdc55b53184ccdacb00738060a1ebb1.zip
It seems getpeername() returns with no error but doesn't fill struct
sockaddr correctly against PF_UNIX socket under 5-CURRENT. Because of this behavior, PF_UNIX socket was always checked by libwrap. This work around prevents PF_UNIX socket from checking by libwrap to always allow LMTP.
-rw-r--r--mail/cyrus-imapd2/files/patch-df8
-rw-r--r--mail/cyrus-imapd22/files/patch-df8
-rw-r--r--mail/cyrus-imapd23/files/patch-df8
-rw-r--r--mail/cyrus-imapd24/files/patch-df8
4 files changed, 20 insertions, 12 deletions
diff --git a/mail/cyrus-imapd2/files/patch-df b/mail/cyrus-imapd2/files/patch-df
index 1b092230a8f3..e95e795d2092 100644
--- a/mail/cyrus-imapd2/files/patch-df
+++ b/mail/cyrus-imapd2/files/patch-df
@@ -1,10 +1,12 @@
Index: master/service.c
diff -u master/service.c.orig master/service.c
---- master/service.c.orig Mon Dec 17 18:08:07 2001
-+++ master/service.c Mon Dec 17 18:08:38 2001
-@@ -101,7 +101,11 @@
+--- master/service.c.orig Thu Aug 15 06:02:41 2002
++++ master/service.c Fri Aug 16 00:28:31 2002
+@@ -103,8 +103,13 @@
+ socklen_t len = sizeof(sin);
/* is this a connection from the local host? */
++ memset(&sin, 0, len);
if (getpeername(fd, (struct sockaddr *) &sin, &len) == 0) {
- if (((struct sockaddr *)&sin)->sa_family == AF_UNIX) {
+ switch (((struct sockaddr *)&sin)->sa_family) {
diff --git a/mail/cyrus-imapd22/files/patch-df b/mail/cyrus-imapd22/files/patch-df
index 1b092230a8f3..e95e795d2092 100644
--- a/mail/cyrus-imapd22/files/patch-df
+++ b/mail/cyrus-imapd22/files/patch-df
@@ -1,10 +1,12 @@
Index: master/service.c
diff -u master/service.c.orig master/service.c
---- master/service.c.orig Mon Dec 17 18:08:07 2001
-+++ master/service.c Mon Dec 17 18:08:38 2001
-@@ -101,7 +101,11 @@
+--- master/service.c.orig Thu Aug 15 06:02:41 2002
++++ master/service.c Fri Aug 16 00:28:31 2002
+@@ -103,8 +103,13 @@
+ socklen_t len = sizeof(sin);
/* is this a connection from the local host? */
++ memset(&sin, 0, len);
if (getpeername(fd, (struct sockaddr *) &sin, &len) == 0) {
- if (((struct sockaddr *)&sin)->sa_family == AF_UNIX) {
+ switch (((struct sockaddr *)&sin)->sa_family) {
diff --git a/mail/cyrus-imapd23/files/patch-df b/mail/cyrus-imapd23/files/patch-df
index 1b092230a8f3..e95e795d2092 100644
--- a/mail/cyrus-imapd23/files/patch-df
+++ b/mail/cyrus-imapd23/files/patch-df
@@ -1,10 +1,12 @@
Index: master/service.c
diff -u master/service.c.orig master/service.c
---- master/service.c.orig Mon Dec 17 18:08:07 2001
-+++ master/service.c Mon Dec 17 18:08:38 2001
-@@ -101,7 +101,11 @@
+--- master/service.c.orig Thu Aug 15 06:02:41 2002
++++ master/service.c Fri Aug 16 00:28:31 2002
+@@ -103,8 +103,13 @@
+ socklen_t len = sizeof(sin);
/* is this a connection from the local host? */
++ memset(&sin, 0, len);
if (getpeername(fd, (struct sockaddr *) &sin, &len) == 0) {
- if (((struct sockaddr *)&sin)->sa_family == AF_UNIX) {
+ switch (((struct sockaddr *)&sin)->sa_family) {
diff --git a/mail/cyrus-imapd24/files/patch-df b/mail/cyrus-imapd24/files/patch-df
index 1b092230a8f3..e95e795d2092 100644
--- a/mail/cyrus-imapd24/files/patch-df
+++ b/mail/cyrus-imapd24/files/patch-df
@@ -1,10 +1,12 @@
Index: master/service.c
diff -u master/service.c.orig master/service.c
---- master/service.c.orig Mon Dec 17 18:08:07 2001
-+++ master/service.c Mon Dec 17 18:08:38 2001
-@@ -101,7 +101,11 @@
+--- master/service.c.orig Thu Aug 15 06:02:41 2002
++++ master/service.c Fri Aug 16 00:28:31 2002
+@@ -103,8 +103,13 @@
+ socklen_t len = sizeof(sin);
/* is this a connection from the local host? */
++ memset(&sin, 0, len);
if (getpeername(fd, (struct sockaddr *) &sin, &len) == 0) {
- if (((struct sockaddr *)&sin)->sa_family == AF_UNIX) {
+ switch (((struct sockaddr *)&sin)->sa_family) {