summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorRajiv Aaron Manglani <rajiv@gentoo.org>2003-12-10 08:31:13 +0000
committerRajiv Aaron Manglani <rajiv@gentoo.org>2003-12-10 08:31:13 +0000
commitfbeec037c6201c68043601cfdfe53066bead50fd (patch)
tree27791e7327288f9d9d85b7babcf9fbe885602525 /net-ftp
parentno fd.4 manpage (diff)
downloadgentoo-2-fbeec037c6201c68043601cfdfe53066bead50fd.tar.gz
gentoo-2-fbeec037c6201c68043601cfdfe53066bead50fd.tar.bz2
gentoo-2-fbeec037c6201c68043601cfdfe53066bead50fd.zip
removed old patch files.
Diffstat (limited to 'net-ftp')
-rw-r--r--net-ftp/vsftpd/ChangeLog6
-rw-r--r--net-ftp/vsftpd/Manifest5
-rw-r--r--net-ftp/vsftpd/files/vsftpd-1.1.2-gentoo.diff159
-rw-r--r--net-ftp/vsftpd/files/vsftpd-1.1.3-gentoo.diff173
-rw-r--r--net-ftp/vsftpd/files/vsftpd-1.1.3-ipv6.patch1191
5 files changed, 5 insertions, 1529 deletions
diff --git a/net-ftp/vsftpd/ChangeLog b/net-ftp/vsftpd/ChangeLog
index 3eea53b7938a..14ba3d8ab5d5 100644
--- a/net-ftp/vsftpd/ChangeLog
+++ b/net-ftp/vsftpd/ChangeLog
@@ -1,9 +1,11 @@
# ChangeLog for net-ftp/vsftpd
# Copyright 2002-2003 Gentoo Technologies, Inc.; Distributed under the GPL v2
-# $Header: /var/cvsroot/gentoo-x86/net-ftp/vsftpd/ChangeLog,v 1.20 2003/12/10 08:21:36 rajiv Exp $
+# $Header: /var/cvsroot/gentoo-x86/net-ftp/vsftpd/ChangeLog,v 1.21 2003/12/10 08:31:09 rajiv Exp $
10 Dec 2003; Rajiv Aaron Manglani <rajiv@gentoo.org> vsftpd-1.1.2.ebuild,
- vsftpd-1.1.3-r1.ebuild, vsftpd-1.1.3.ebuild, vsftpd-1.2.0.ebuild:
+ vsftpd-1.1.3-r1.ebuild, vsftpd-1.1.3.ebuild, vsftpd-1.2.0.ebuild,
+ files/vsftpd-1.1.2-gentoo.diff, files/vsftpd-1.1.3-gentoo.diff,
+ files/vsftpd-1.1.3-ipv6.patch:
removed old ebuild files.
10 Dec 2003; Rajiv Aaron Manglani <rajiv@gentoo.org> files/vsftpd.init.d:
diff --git a/net-ftp/vsftpd/Manifest b/net-ftp/vsftpd/Manifest
index 62bb7c8a2efc..a69c30bef67f 100644
--- a/net-ftp/vsftpd/Manifest
+++ b/net-ftp/vsftpd/Manifest
@@ -1,9 +1,8 @@
MD5 191a04cdbe5134583744b69e7548cb61 vsftpd-1.2.0-r1.ebuild 2235
MD5 3f5cf714b4de6ff10f590a7239803cc2 vsftpd-1.0.1-r1.ebuild 1341
-MD5 527fc70b681e5b44803e6c8e0e6a09cd ChangeLog 2498
+MD5 826239f8987e96d54a1d701d070e38ec ChangeLog 2597
MD5 d161cb0e313c1619fc61077d5b0c8821 metadata.xml 251
MD5 26ff667accf732a00069c479e03cb17d files/ftpusers 363
-MD5 76cc239220e45f7acc48338d183a370e files/vsftpd-1.1.2-gentoo.diff 5695
MD5 3734a4e9aaa1cc7775943c0c97bedd4b files/digest-vsftpd-1.0.1-r1 63
MD5 767d44cc19f7afc4085da8fd837193e4 files/digest-vsftpd-1.2.0-r1 64
MD5 2ef7d85b3290f9d192f9d20045b61052 files/vsftpd.xinetd.ipv6 484
@@ -11,8 +10,6 @@ MD5 12157a137e6633887fad5c7a8e1e1ae3 files/vsftpd-1.2.0-gentoo.diff.bz2 2078
MD5 1a93d49d1cd737194ab7c38ecd62f8ab files/vsftpd.conf.d 295
MD5 9920815c556713474a590d46aa9889e1 files/vsftpd.conf 3768
MD5 dab305a7002358f4f298c8e1fe59f3bf files/vsftpd.init.d 980
-MD5 c5f7799cb5bacb00ea2920976353f3b6 files/vsftpd-1.1.3-gentoo.diff 6302
MD5 1fbe76ee9788335150f3c31b6c649e29 files/vsftpd.xinetd 466
MD5 b602cee3b9a0967cfa02e3e398c0d641 files/vsftpd-1.0.1-gentoo.diff 5204
MD5 5cd84e770cb3dd070b0048f8933edc4e files/vsftpd.pam 479
-MD5 5cdf504bf481bd877ec0aca8ee92a0c6 files/vsftpd-1.1.3-ipv6.patch 41561
diff --git a/net-ftp/vsftpd/files/vsftpd-1.1.2-gentoo.diff b/net-ftp/vsftpd/files/vsftpd-1.1.2-gentoo.diff
deleted file mode 100644
index 4f6663e08a7f..000000000000
--- a/net-ftp/vsftpd/files/vsftpd-1.1.2-gentoo.diff
+++ /dev/null
@@ -1,159 +0,0 @@
-diff -uNr vsftpd-1.1.2.orig/defs.h vsftpd-1.1.2/defs.h
---- vsftpd-1.1.2.orig/defs.h Tue Jul 9 18:51:57 2002
-+++ vsftpd-1.1.2/defs.h Sat Oct 19 01:57:41 2002
-@@ -1,7 +1,7 @@
- #ifndef VSF_DEFS_H
- #define VSF_DEFS_H
-
--#define VSFTP_DEFAULT_CONFIG "/etc/vsftpd.conf"
-+#define VSFTP_DEFAULT_CONFIG "/etc/vsftpd/vsftpd.conf"
-
- #define VSFTP_COMMAND_FD 0
-
-diff -uNr vsftpd-1.1.2.orig/tunables.c vsftpd-1.1.2/tunables.c
---- vsftpd-1.1.2.orig/tunables.c Fri Oct 11 20:03:13 2002
-+++ vsftpd-1.1.2/tunables.c Sat Oct 19 02:05:54 2002
-@@ -63,19 +63,19 @@
- unsigned int tunable_file_open_mode = 0666;
- unsigned int tunable_max_per_ip = 0;
-
--const char* tunable_secure_chroot_dir = "/usr/share/empty";
-+const char* tunable_secure_chroot_dir = "/usr/share/vsftpd/empty";
- const char* tunable_ftp_username = "ftp";
- const char* tunable_chown_username = "root";
--const char* tunable_xferlog_file = "/var/log/vsftpd.log";
-+const char* tunable_xferlog_file = "/var/log/vsftpd/vsftpd.log";
- const char* tunable_message_file = ".message";
- /* XXX -> "secure"? */
- const char* tunable_nopriv_user = "nobody";
- const char* tunable_ftpd_banner = 0;
--const char* tunable_banned_email_file = "/etc/vsftpd.banned_emails";
--const char* tunable_chroot_list_file = "/etc/vsftpd.chroot_list";
--const char* tunable_pam_service_name = "ftp";
-+const char* tunable_banned_email_file = "/etc/vsftpd/vsftpd.banned_emails";
-+const char* tunable_chroot_list_file = "/etc/vsftpd/vsftpd.chroot_list";
-+const char* tunable_pam_service_name = "vsftpd";
- const char* tunable_guest_username = "ftp";
--const char* tunable_userlist_file = "/etc/vsftpd.user_list";
-+const char* tunable_userlist_file = "/etc/vsftpd/vsftpd.user_list";
- const char* tunable_anon_root = 0;
- const char* tunable_local_root = 0;
- const char* tunable_banner_file = 0;
-diff -uNr vsftpd-1.1.2.orig/vsftpd.8 vsftpd-1.1.2/vsftpd.8
---- vsftpd-1.1.2.orig/vsftpd.8 Sun Mar 11 20:14:07 2001
-+++ vsftpd-1.1.2/vsftpd.8 Sat Oct 19 02:06:32 2002
-@@ -20,7 +20,7 @@
- An optional
- .Op configuration file
- may be given on the command line. The default configuration file is
--.Pa /etc/vsftpd.conf .
-+.Pa /etc/vsftpd/vsftpd.conf .
- .Sh SEE ALSO
- .Xr vsftpd.conf 5
-
-diff -uNr vsftpd-1.1.2.orig/vsftpd.conf.5 vsftpd-1.1.2/vsftpd.conf.5
---- vsftpd-1.1.2.orig/vsftpd.conf.5 Sun Oct 13 20:56:28 2002
-+++ vsftpd-1.1.2/vsftpd.conf.5 Sat Oct 19 02:14:37 2002
-@@ -4,7 +4,7 @@
- .SH DESCRIPTION
- vsftpd.conf may be used to control various aspects of vsftpd's behaviour. By
- default, vsftpd looks for this file at the location
--.BR /etc/vsftpd.conf .
-+.BR /etc/vsftpd/vsftpd.conf .
- However, you may override this by specifying a command line argument to
- vsftpd. The command line argument is the pathname of the configuration file
- for vsftpd. This behaviour is useful because you may wish to use an advanced
-@@ -115,7 +115,7 @@
- different if chroot_local_user is set to YES. In this case, the list becomes
- a list of users which are NOT to be placed in a chroot() jail.
- By default, the file containing this list is
--/etc/vsftpd.chroot_list, but you may override this with the
-+/etc/vsftpd/vsftpd.chroot_list, but you may override this with the
- .BR chroot_list_file
- setting.
-
-@@ -143,7 +143,7 @@
- .B deny_email_enable
- If activated, you may provide a list of anonymous password e-mail responses
- which cause login to be denied. By default, the file containing this list is
--/etc/vsftpd.banned_emails, but you may override this with the
-+/etc/vsftpd/vsftpd.banned_emails, but you may override this with the
- .BR banned_email_file
- setting.
-
-@@ -301,7 +301,7 @@
- .TP
- .B xferlog_enable
- If enabled, a log file will be maintained detailling uploads and downloads.
--By default, this file will be placed at /var/log/vsftpd.log, but this location
-+By default, this file will be placed at /var/log/vsftpd/vsftpd.log, but this location
- may be overridden using the configuration setting
- .BR xferlog_file .
-
-@@ -433,7 +433,7 @@
- .BR deny_email_enable
- is enabled.
-
--Default: /etc/vsftpd.banned_emails
-+Default: /etc/vsftpd/vsftpd.banned_emails
- .TP
- .B banner_file
- This option is the name of a file containing text to display when someone
-@@ -461,7 +461,7 @@
- .BR chroot_local_user
- is disabled.
-
--Default: /etc/vsftpd.chroot_list
-+Default: /etc/vsftpd/vsftpd.chroot_list
- .TP
- .B guest_username
- See the boolean setting
-@@ -515,7 +515,7 @@
- .B pam_service_name
- This string is the name of the PAM service vsftpd will use.
-
--Default: ftp
-+Default: vsftpd
- .TP
- .B pasv_address
- Use this option to override the IP address that vsftpd will advertise in
-@@ -528,7 +528,7 @@
- directory should not be writable by the ftp user. This directory is used
- as a secure chroot() jail at times vsftpd does not require filesystem access.
-
--Default: /usr/share/empty
-+Default: /usr/share/vsftpd/empty
- .TP
- .B user_config_dir
- This powerful option allows the override of any config option specified in
-@@ -536,10 +536,10 @@
- with an example. If you set
- .BR user_config_dir
- to be
--.BR /etc/vsftpd_user_conf
-+.BR /etc/vsftpd/vsftpd_user_conf
- and then log on as the user "chris", then vsftpd will apply the settings in
- the file
--.BR /etc/vsftpd_user_conf/chris
-+.BR /etc/vsftpd/vsftpd_user_conf/chris
- for the duration of the session. The format of this file is as detailed in
- this manual page!
-
-@@ -550,7 +550,7 @@
- .BR userlist_enable
- option is active.
-
--Default: /etc/vsftpd.user_list
-+Default: /etc/vsftpd/vsftpd.user_list
- .TP
- .B xferlog_file
- This option is the name of the file to which we write the transfer log. The
-@@ -558,7 +558,7 @@
- .BR xferlog_enable
- is set.
-
--Default: /var/log/vsftpd.log
-+Default: /var/log/vsftpd/vsftpd.log
-
- .SH AUTHOR
- chris@scary.beasts.org
diff --git a/net-ftp/vsftpd/files/vsftpd-1.1.3-gentoo.diff b/net-ftp/vsftpd/files/vsftpd-1.1.3-gentoo.diff
deleted file mode 100644
index 6f1fa7337932..000000000000
--- a/net-ftp/vsftpd/files/vsftpd-1.1.3-gentoo.diff
+++ /dev/null
@@ -1,173 +0,0 @@
-diff -uNr vsftpd-1.1.3.orig/defs.h vsftpd-1.1.3/defs.h
---- vsftpd-1.1.3.orig/defs.h 2002-07-09 18:51:57.000000000 -0400
-+++ vsftpd-1.1.3/defs.h 2003-02-15 11:19:48.000000000 -0500
-@@ -1,7 +1,7 @@
- #ifndef VSF_DEFS_H
- #define VSF_DEFS_H
-
--#define VSFTP_DEFAULT_CONFIG "/etc/vsftpd.conf"
-+#define VSFTP_DEFAULT_CONFIG "/etc/vsftpd/vsftpd.conf"
-
- #define VSFTP_COMMAND_FD 0
-
-diff -uNr vsftpd-1.1.3.orig/sysdeputil.c vsftpd-1.1.3/sysdeputil.c
---- vsftpd-1.1.3.orig/sysdeputil.c 2002-10-29 20:06:41.000000000 -0500
-+++ vsftpd-1.1.3/sysdeputil.c 2003-02-15 11:21:17.000000000 -0500
-@@ -39,7 +39,9 @@
- #undef VSF_SYSDEP_HAVE_HPUX_SETPROCTITLE
- #undef VSF_SYSDEP_HAVE_MAP_ANON
- #undef VSF_SYSDEP_NEED_OLD_FD_PASSING
--#define VSF_SYSDEP_HAVE_PAM
-+#ifdef USE_PAM
-+ #define VSF_SYSDEP_HAVE_PAM
-+#endif
- #define VSF_SYSDEP_HAVE_SHADOW
- #define VSF_SYSDEP_HAVE_USERSHELL
- #define VSF_SYSDEP_HAVE_LIBCAP
-diff -uNr vsftpd-1.1.3.orig/tunables.c vsftpd-1.1.3/tunables.c
---- vsftpd-1.1.3.orig/tunables.c 2002-10-24 18:46:21.000000000 -0400
-+++ vsftpd-1.1.3/tunables.c 2003-02-15 11:19:48.000000000 -0500
-@@ -65,19 +65,19 @@
- unsigned int tunable_file_open_mode = 0666;
- unsigned int tunable_max_per_ip = 0;
-
--const char* tunable_secure_chroot_dir = "/usr/share/empty";
-+const char* tunable_secure_chroot_dir = "/usr/share/vsftpd/empty";
- const char* tunable_ftp_username = "ftp";
- const char* tunable_chown_username = "root";
--const char* tunable_xferlog_file = "/var/log/vsftpd.log";
-+const char* tunable_xferlog_file = "/var/log/vsftpd/vsftpd.log";
- const char* tunable_message_file = ".message";
- /* XXX -> "secure"? */
- const char* tunable_nopriv_user = "nobody";
- const char* tunable_ftpd_banner = 0;
--const char* tunable_banned_email_file = "/etc/vsftpd.banned_emails";
--const char* tunable_chroot_list_file = "/etc/vsftpd.chroot_list";
--const char* tunable_pam_service_name = "ftp";
-+const char* tunable_banned_email_file = "/etc/vsftpd/vsftpd.banned_emails";
-+const char* tunable_chroot_list_file = "/etc/vsftpd/vsftpd.chroot_list";
-+const char* tunable_pam_service_name = "vsftpd";
- const char* tunable_guest_username = "ftp";
--const char* tunable_userlist_file = "/etc/vsftpd.user_list";
-+const char* tunable_userlist_file = "/etc/vsftpd/vsftpd.user_list";
- const char* tunable_anon_root = 0;
- const char* tunable_local_root = 0;
- const char* tunable_banner_file = 0;
-diff -uNr vsftpd-1.1.3.orig/vsftpd.8 vsftpd-1.1.3/vsftpd.8
---- vsftpd-1.1.3.orig/vsftpd.8 2001-03-11 20:14:07.000000000 -0500
-+++ vsftpd-1.1.3/vsftpd.8 2003-02-15 11:19:48.000000000 -0500
-@@ -20,7 +20,7 @@
- An optional
- .Op configuration file
- may be given on the command line. The default configuration file is
--.Pa /etc/vsftpd.conf .
-+.Pa /etc/vsftpd/vsftpd.conf .
- .Sh SEE ALSO
- .Xr vsftpd.conf 5
-
-diff -uNr vsftpd-1.1.3.orig/vsftpd.conf.5 vsftpd-1.1.3/vsftpd.conf.5
---- vsftpd-1.1.3.orig/vsftpd.conf.5 2002-11-09 10:41:11.000000000 -0500
-+++ vsftpd-1.1.3/vsftpd.conf.5 2003-02-15 11:19:48.000000000 -0500
-@@ -4,7 +4,7 @@
- .SH DESCRIPTION
- vsftpd.conf may be used to control various aspects of vsftpd's behaviour. By
- default, vsftpd looks for this file at the location
--.BR /etc/vsftpd.conf .
-+.BR /etc/vsftpd/vsftpd.conf .
- However, you may override this by specifying a command line argument to
- vsftpd. The command line argument is the pathname of the configuration file
- for vsftpd. This behaviour is useful because you may wish to use an advanced
-@@ -115,7 +115,7 @@
- different if chroot_local_user is set to YES. In this case, the list becomes
- a list of users which are NOT to be placed in a chroot() jail.
- By default, the file containing this list is
--/etc/vsftpd.chroot_list, but you may override this with the
-+/etc/vsftpd/vsftpd.chroot_list, but you may override this with the
- .BR chroot_list_file
- setting.
-
-@@ -143,7 +143,7 @@
- .B deny_email_enable
- If activated, you may provide a list of anonymous password e-mail responses
- which cause login to be denied. By default, the file containing this list is
--/etc/vsftpd.banned_emails, but you may override this with the
-+/etc/vsftpd/vsftpd.banned_emails, but you may override this with the
- .BR banned_email_file
- setting.
-
-@@ -316,7 +316,7 @@
- .TP
- .B xferlog_enable
- If enabled, a log file will be maintained detailling uploads and downloads.
--By default, this file will be placed at /var/log/vsftpd.log, but this location
-+By default, this file will be placed at /var/log/vsftpd/vsftpd.log, but this location
- may be overridden using the configuration setting
- .BR xferlog_file .
-
-@@ -448,7 +448,7 @@
- .BR deny_email_enable
- is enabled.
-
--Default: /etc/vsftpd.banned_emails
-+Default: /etc/vsftpd/vsftpd.banned_emails
- .TP
- .B banner_file
- This option is the name of a file containing text to display when someone
-@@ -476,7 +476,7 @@
- .BR chroot_local_user
- is disabled.
-
--Default: /etc/vsftpd.chroot_list
-+Default: /etc/vsftpd/vsftpd.chroot_list
- .TP
- .B guest_username
- See the boolean setting
-@@ -530,7 +530,7 @@
- .B pam_service_name
- This string is the name of the PAM service vsftpd will use.
-
--Default: ftp
-+Default: vsftpd
- .TP
- .B pasv_address
- Use this option to override the IP address that vsftpd will advertise in
-@@ -543,7 +543,7 @@
- directory should not be writable by the ftp user. This directory is used
- as a secure chroot() jail at times vsftpd does not require filesystem access.
-
--Default: /usr/share/empty
-+Default: /usr/share/vsftpd/empty
- .TP
- .B user_config_dir
- This powerful option allows the override of any config option specified in
-@@ -551,10 +551,10 @@
- with an example. If you set
- .BR user_config_dir
- to be
--.BR /etc/vsftpd_user_conf
-+.BR /etc/vsftpd/vsftpd_user_conf
- and then log on as the user "chris", then vsftpd will apply the settings in
- the file
--.BR /etc/vsftpd_user_conf/chris
-+.BR /etc/vsftpd/vsftpd_user_conf/chris
- for the duration of the session. The format of this file is as detailed in
- this manual page!
-
-@@ -565,7 +565,7 @@
- .BR userlist_enable
- option is active.
-
--Default: /etc/vsftpd.user_list
-+Default: /etc/vsftpd/vsftpd.user_list
- .TP
- .B xferlog_file
- This option is the name of the file to which we write the transfer log. The
-@@ -573,7 +573,7 @@
- .BR xferlog_enable
- is set.
-
--Default: /var/log/vsftpd.log
-+Default: /var/log/vsftpd/vsftpd.log
-
- .SH AUTHOR
- chris@scary.beasts.org
diff --git a/net-ftp/vsftpd/files/vsftpd-1.1.3-ipv6.patch b/net-ftp/vsftpd/files/vsftpd-1.1.3-ipv6.patch
deleted file mode 100644
index 3ea9c64eaa16..000000000000
--- a/net-ftp/vsftpd/files/vsftpd-1.1.3-ipv6.patch
+++ /dev/null
@@ -1,1191 +0,0 @@
-diff -u -d -r vsftpd-1.1.3.orig/Changelog vsftpd-1.1.3/Changelog
---- vsftpd-1.1.3.orig/Changelog Sat Nov 9 18:17:39 2002
-+++ vsftpd-1.1.3/Changelog Mon Nov 11 21:18:27 2002
-@@ -637,3 +637,4 @@
- At this point: 1.1.3 package released
- -------------------------------------
-
-+- IPv6, EPRT and EPSV (RFC 2428) support by Cougar <cougar@random.ee>
-diff -u -d -r vsftpd-1.1.3.orig/ftpcodes.h vsftpd-1.1.3/ftpcodes.h
---- vsftpd-1.1.3.orig/ftpcodes.h Tue Oct 22 02:11:42 2002
-+++ vsftpd-1.1.3/ftpcodes.h Mon Nov 11 21:18:27 2002
-@@ -17,6 +17,7 @@
- #define FTP_TRANSFEROK 226
- #define FTP_ABOROK 226
- #define FTP_PASVOK 227
-+#define FTP_EPSVOK 229
- #define FTP_LOGINOK 230
- #define FTP_CWDOK 250
- #define FTP_RMDIROK 250
-@@ -42,6 +43,7 @@
- #define FTP_BADHELP 502
- #define FTP_NEEDUSER 503
- #define FTP_NEEDRNFR 503
-+#define FTP_NOPROTOSUPPORT 522
- #define FTP_LOGINERR 530
- #define FTP_FILEFAIL 550
- #define FTP_NOPERM 550
-diff -u -d -r vsftpd-1.1.3.orig/ftpdataio.c vsftpd-1.1.3/ftpdataio.c
---- vsftpd-1.1.3.orig/ftpdataio.c Thu Jul 4 00:09:29 2002
-+++ vsftpd-1.1.3/ftpdataio.c Mon Nov 11 21:18:27 2002
-@@ -9,6 +9,10 @@
- * includes sends and receives, files and directories.
- */
-
-+#include <sys/types.h>
-+#include <sys/socket.h>
-+#include <arpa/inet.h>
-+
- #include "ftpdataio.h"
- #include "session.h"
- #include "ftpcmdio.h"
-@@ -72,8 +76,9 @@
- vsf_ftpdataio_get_pasv_fd(struct vsf_session* p_sess)
- {
- static struct vsf_sysutil_sockaddr* s_p_accept_addr = 0;
-- struct vsf_sysutil_ipv4addr cmd_conn_addr;
-- struct vsf_sysutil_ipv4addr remote_addr;
-+ struct vsf_sysutil_ipaddr cmd_conn_addr;
-+ struct vsf_sysutil_ipaddr remote_addr;
-+ unsigned int socklen = 0;
- int remote_fd = vsf_sysutil_accept_timeout(p_sess->pasv_listen_fd,
- &s_p_accept_addr,
- tunable_accept_timeout);
-@@ -87,12 +92,25 @@
- * Reject the connection if it wasn't from the same IP as the
- * control connection.
- */
-- cmd_conn_addr = vsf_sysutil_sockaddr_get_ipaddr(p_sess->p_remote_addr);
-- remote_addr = vsf_sysutil_sockaddr_get_ipaddr(s_p_accept_addr);
-+ vsf_sysutil_sockaddr_get_ipaddr(&cmd_conn_addr, p_sess->p_remote_addr);
-+ vsf_sysutil_sockaddr_get_ipaddr(&remote_addr, s_p_accept_addr);
- if (!tunable_pasv_promiscuous)
- {
-- if (vsf_sysutil_memcmp(cmd_conn_addr.data, remote_addr.data,
-- sizeof(cmd_conn_addr)) != 0)
-+ switch (cmd_conn_addr.family) {
-+ case AF_INET:
-+ {
-+ socklen = sizeof(struct in_addr);
-+ break;
-+ }
-+ case AF_INET6:
-+ {
-+ socklen = sizeof(struct in6_addr);
-+ break;
-+ }
-+ }
-+ if ((cmd_conn_addr.family != remote_addr.family) ||
-+ (!socklen) ||
-+ (vsf_sysutil_memcmp(&cmd_conn_addr.data, &remote_addr.data, socklen) != 0))
- {
- vsf_cmdio_write(p_sess, FTP_BADSENDCONN, "Security: Bad IP connecting.");
- vsf_sysutil_close(remote_fd);
-@@ -107,7 +125,7 @@
- vsf_ftpdataio_get_port_fd(struct vsf_session* p_sess)
- {
- int retval;
-- int remote_fd;
-+ int remote_fd = -1;
- if (tunable_connect_from_port_20)
- {
- if (tunable_one_process_model)
-@@ -121,7 +139,22 @@
- }
- else
- {
-- remote_fd = vsf_sysutil_get_ipv4_sock();
-+ switch (((struct sockaddr*)p_sess->p_remote_addr)->sa_family) {
-+ case AF_INET:
-+ {
-+ remote_fd = vsf_sysutil_get_ipv4_sock();
-+ break;
-+ }
-+ case AF_INET6:
-+ {
-+ remote_fd = vsf_sysutil_get_ipv6_sock();
-+ break;
-+ }
-+ default:
-+ {
-+ die("unknown protocol family");
-+ }
-+ }
- }
- retval = vsf_sysutil_connect_timeout(remote_fd, p_sess->p_port_sockaddr,
- tunable_connect_timeout);
-diff -u -d -r vsftpd-1.1.3.orig/main.c vsftpd-1.1.3/main.c
---- vsftpd-1.1.3.orig/main.c Fri Oct 25 20:46:20 2002
-+++ vsftpd-1.1.3/main.c Mon Nov 11 21:18:27 2002
-@@ -121,7 +121,7 @@
- */
- vsf_log_init(&the_session);
- str_alloc_text(&the_session.remote_ip_str,
-- vsf_sysutil_inet_ntoa(the_session.p_remote_addr));
-+ vsf_sysutil_inet_ntop(the_session.p_remote_addr));
- /* Set up options on the command socket */
- vsf_cmdio_sock_setup();
- if (tunable_setproctitle_enable)
-diff -u -d -r vsftpd-1.1.3.orig/postlogin.c vsftpd-1.1.3/postlogin.c
---- vsftpd-1.1.3.orig/postlogin.c Sun Sep 22 23:35:27 2002
-+++ vsftpd-1.1.3/postlogin.c Mon Nov 11 21:18:27 2002
-@@ -5,6 +5,10 @@
- * postlogin.c
- */
-
-+#include <sys/types.h>
-+#include <sys/socket.h>
-+#include <arpa/inet.h>
-+
- #include "postlogin.h"
- #include "session.h"
- #include "oneprocess.h"
-@@ -26,11 +30,13 @@
- static void handle_pwd(struct vsf_session* p_sess);
- static void handle_cwd(struct vsf_session* p_sess);
- static void handle_pasv(struct vsf_session* p_sess);
-+static void handle_epsv(struct vsf_session* p_sess);
- static void handle_retr(struct vsf_session* p_sess);
- static void handle_cdup(struct vsf_session* p_sess);
- static void handle_list(struct vsf_session* p_sess);
- static void handle_type(struct vsf_session* p_sess);
- static void handle_port(struct vsf_session* p_sess);
-+static void handle_eprt(struct vsf_session* p_sess);
- static void handle_stor(struct vsf_session* p_sess);
- static void handle_mkd(struct vsf_session* p_sess);
- static void handle_rmd(struct vsf_session* p_sess);
-@@ -128,6 +134,11 @@
- {
- handle_pasv(p_sess);
- }
-+ else if (tunable_pasv_enable &&
-+ str_equal_text(&p_sess->ftp_cmd_str, "EPSV"))
-+ {
-+ handle_epsv(p_sess);
-+ }
- else if (str_equal_text(&p_sess->ftp_cmd_str, "RETR"))
- {
- handle_retr(p_sess);
-@@ -157,6 +168,11 @@
- {
- handle_port(p_sess);
- }
-+ else if (tunable_port_enable &&
-+ str_equal_text(&p_sess->ftp_cmd_str, "EPRT"))
-+ {
-+ handle_eprt(p_sess);
-+ }
- else if (tunable_write_enable &&
- (tunable_anon_upload_enable || !p_sess->is_anonymous) &&
- str_equal_text(&p_sess->ftp_cmd_str, "STOR"))
-@@ -344,9 +360,14 @@
- {
- static struct mystr s_pasv_res_str;
- static struct vsf_sysutil_sockaddr* s_p_sockaddr;
-- struct vsf_sysutil_ipv4port listen_port;
-- struct vsf_sysutil_ipv4addr listen_ipaddr;
-+ struct vsf_sysutil_ipaddr the_addr;
-+ struct vsf_sysutil_ipport listen_port;
-+ struct vsf_sysutil_ipaddr listen_ipaddr;
- int bind_retries = 10;
-+ if (((struct sockaddr*)p_sess->p_remote_addr)->sa_family != AF_INET) {
-+ vsf_cmdio_write(p_sess, FTP_BADCMD, "PASV command not allowed for IPv6 sessions, use EPSV instead.");
-+ return;
-+ }
- pasv_cleanup(p_sess);
- port_cleanup(p_sess);
- p_sess->pasv_listen_fd = vsf_sysutil_get_ipv4_sock();
-@@ -375,10 +396,10 @@
- the_port = (unsigned short) scaled_port;
- vsf_sysutil_sockaddr_alloc_ipv4(&s_p_sockaddr);
- vsf_sysutil_sockaddr_set_port(s_p_sockaddr,
-- vsf_sysutil_ipv4port_from_int(the_port));
-+ vsf_sysutil_ipport_from_int(the_port));
- /* Bind to same address we got the incoming connect on */
-- vsf_sysutil_sockaddr_set_ipaddr(s_p_sockaddr,
-- vsf_sysutil_sockaddr_get_ipaddr(p_sess->p_local_addr));
-+ vsf_sysutil_sockaddr_get_ipaddr(&the_addr, p_sess->p_local_addr);
-+ vsf_sysutil_sockaddr_set_ipaddr(s_p_sockaddr, &the_addr);
- retval = vsf_sysutil_bind(p_sess->pasv_listen_fd, s_p_sockaddr);
- if (!vsf_sysutil_retval_is_error(retval))
- {
-@@ -408,17 +429,17 @@
- else
- {
- /* Use address of bound socket for passive address */
-- listen_ipaddr = vsf_sysutil_sockaddr_get_ipaddr(s_p_sockaddr);
-+ vsf_sysutil_sockaddr_get_ipaddr(&listen_ipaddr, s_p_sockaddr);
- }
- listen_port = vsf_sysutil_sockaddr_get_port(s_p_sockaddr);
- str_alloc_text(&s_pasv_res_str, "Entering Passive Mode (");
-- str_append_ulong(&s_pasv_res_str, listen_ipaddr.data[0]);
-+ str_append_ulong(&s_pasv_res_str, listen_ipaddr.data.ipv4[0]);
- str_append_text(&s_pasv_res_str, ",");
-- str_append_ulong(&s_pasv_res_str, listen_ipaddr.data[1]);
-+ str_append_ulong(&s_pasv_res_str, listen_ipaddr.data.ipv4[1]);
- str_append_text(&s_pasv_res_str, ",");
-- str_append_ulong(&s_pasv_res_str, listen_ipaddr.data[2]);
-+ str_append_ulong(&s_pasv_res_str, listen_ipaddr.data.ipv4[2]);
- str_append_text(&s_pasv_res_str, ",");
-- str_append_ulong(&s_pasv_res_str, listen_ipaddr.data[3]);
-+ str_append_ulong(&s_pasv_res_str, listen_ipaddr.data.ipv4[3]);
- str_append_text(&s_pasv_res_str, ",");
- str_append_ulong(&s_pasv_res_str, listen_port.data[0]);
- str_append_text(&s_pasv_res_str, ",");
-@@ -428,6 +449,103 @@
- }
-
- static void
-+handle_epsv(struct vsf_session* p_sess)
-+{
-+ static struct mystr s_pasv_res_str;
-+ static struct vsf_sysutil_sockaddr* s_p_sockaddr;
-+ struct vsf_sysutil_ipaddr the_addr;
-+ struct vsf_sysutil_ipport listen_port;
-+ struct vsf_sysutil_ipaddr listen_ipaddr;
-+ int bind_retries = 10;
-+ pasv_cleanup(p_sess);
-+ port_cleanup(p_sess);
-+ switch (((struct sockaddr*)p_sess->p_remote_addr)->sa_family) {
-+ case AF_INET:
-+ {
-+ p_sess->pasv_listen_fd = vsf_sysutil_get_ipv4_sock();
-+ break;
-+ }
-+ case AF_INET6:
-+ {
-+ p_sess->pasv_listen_fd = vsf_sysutil_get_ipv6_sock();
-+ break;
-+ }
-+ default:
-+ {
-+ die("unknown address family");
-+ }
-+ }
-+ while (--bind_retries)
-+ {
-+ int retval;
-+ unsigned short the_port;
-+ double scaled_port;
-+ /* IPPORT_RESERVED */
-+ unsigned short min_port = 1024;
-+ unsigned short max_port = 65535;
-+ if (tunable_pasv_min_port > min_port && tunable_pasv_min_port < max_port)
-+ {
-+ min_port = tunable_pasv_min_port;
-+ }
-+ if (tunable_pasv_max_port > min_port && tunable_pasv_max_port < max_port)
-+ {
-+ max_port = tunable_pasv_max_port;
-+ }
-+ the_port = vsf_sysutil_get_random_byte();
-+ the_port <<= 8;
-+ the_port |= vsf_sysutil_get_random_byte();
-+ scaled_port = (double) min_port;
-+ scaled_port += ((double) the_port / (double) 65535) *
-+ ((double) max_port - min_port);
-+ the_port = (unsigned short) scaled_port;
-+ switch (((struct sockaddr*)p_sess->p_remote_addr)->sa_family) {
-+ case AF_INET:
-+ {
-+ vsf_sysutil_sockaddr_alloc_ipv4(&s_p_sockaddr);
-+ break;
-+ }
-+ case AF_INET6:
-+ {
-+ vsf_sysutil_sockaddr_alloc_ipv6(&s_p_sockaddr);
-+ break;
-+ }
-+ default:
-+ {
-+ die("unknown address family");
-+ }
-+ }
-+ vsf_sysutil_sockaddr_set_port(s_p_sockaddr,
-+ vsf_sysutil_ipport_from_int(the_port));
-+ /* Bind to same address we got the incoming connect on */
-+ vsf_sysutil_sockaddr_get_ipaddr(&the_addr, p_sess->p_local_addr);
-+ vsf_sysutil_sockaddr_set_ipaddr(s_p_sockaddr, &the_addr);
-+ retval = vsf_sysutil_bind(p_sess->pasv_listen_fd, s_p_sockaddr);
-+ if (!vsf_sysutil_retval_is_error(retval))
-+ {
-+ break;
-+ }
-+ if (vsf_sysutil_get_error() == kVSFSysUtilErrADDRINUSE)
-+ {
-+ continue;
-+ }
-+ die("vsf_sysutil_bind");
-+ }
-+ if (!bind_retries)
-+ {
-+ die("vsf_sysutil_bind");
-+ }
-+ vsf_sysutil_listen(p_sess->pasv_listen_fd, 1);
-+ /* Get the address of the bound socket, for the port */
-+ vsf_sysutil_getsockname(p_sess->pasv_listen_fd, &s_p_sockaddr);
-+ vsf_sysutil_sockaddr_get_ipaddr(&listen_ipaddr, s_p_sockaddr);
-+ listen_port = vsf_sysutil_sockaddr_get_port(s_p_sockaddr);
-+ str_alloc_text(&s_pasv_res_str, "Entering Extended Passive Mode (|||");
-+ str_append_ulong(&s_pasv_res_str, htons(*(unsigned short *)listen_port.data));
-+ str_append_text(&s_pasv_res_str, "|)");
-+ vsf_cmdio_write_str(p_sess, FTP_EPSVOK, &s_pasv_res_str);
-+}
-+
-+static void
- handle_retr(struct vsf_session* p_sess)
- {
- static struct mystr s_mark_str;
-@@ -661,12 +779,16 @@
- handle_port(struct vsf_session* p_sess)
- {
- static struct mystr s_tmp_str;
-- struct vsf_sysutil_ipv4addr the_addr;
-- struct vsf_sysutil_ipv4port the_port;
-+ struct vsf_sysutil_ipaddr the_addr;
-+ struct vsf_sysutil_ipport the_port;
- unsigned char vals[6];
- int i;
-- struct vsf_sysutil_ipv4addr remote_addr =
-- vsf_sysutil_sockaddr_get_ipaddr(p_sess->p_remote_addr);
-+ struct vsf_sysutil_ipaddr remote_addr;
-+ if (((struct sockaddr*)p_sess->p_remote_addr)->sa_family != AF_INET) {
-+ vsf_cmdio_write(p_sess, FTP_BADCMD, "PORT command not allowed for IPv6 sessions, use EPRT instead.");
-+ return;
-+ }
-+ vsf_sysutil_sockaddr_get_ipaddr(&remote_addr, p_sess->p_remote_addr);
- pasv_cleanup(p_sess);
- port_cleanup(p_sess);
- str_copy(&s_tmp_str, &p_sess->ftp_arg_str);
-@@ -696,7 +818,8 @@
- */
- str_copy(&s_tmp_str, &s_rhs_comma_str);
- }
-- vsf_sysutil_memcpy(the_addr.data, vals, sizeof(the_addr.data));
-+ the_addr.family = AF_INET;
-+ vsf_sysutil_memcpy(the_addr.data.ipv4, vals, sizeof(the_addr.data.ipv4));
- vsf_sysutil_memcpy(the_port.data, &vals[4], sizeof(the_port.data));
- /* SECURITY:
- * 1) Reject requests not connecting to the control socket IP
-@@ -704,8 +827,8 @@
- */
- if (!tunable_port_promiscuous)
- {
-- if (vsf_sysutil_memcmp(the_addr.data, remote_addr.data,
-- sizeof(the_addr.data)) != 0 ||
-+ if (vsf_sysutil_memcmp(the_addr.data.ipv4, remote_addr.data.ipv4,
-+ sizeof(the_addr.data.ipv4)) != 0 ||
- vsf_sysutil_is_port_reserved(the_port))
- {
- vsf_cmdio_write(p_sess, FTP_BADCMD, "Illegal PORT command.");
-@@ -715,9 +838,82 @@
- }
- vsf_sysutil_sockaddr_alloc_ipv4(&p_sess->p_port_sockaddr);
- vsf_sysutil_sockaddr_set_port(p_sess->p_port_sockaddr, the_port);
-- vsf_sysutil_sockaddr_set_ipaddr(p_sess->p_port_sockaddr, the_addr);
-+ vsf_sysutil_sockaddr_set_ipaddr(p_sess->p_port_sockaddr, &the_addr);
- vsf_cmdio_write(p_sess, FTP_PORTOK,
- "PORT command successful. Consider using PASV.");
-+}
-+
-+static void
-+handle_eprt(struct vsf_session* p_sess)
-+{
-+ static struct mystr s_tmp_str;
-+ static struct mystr s_rhs_delim_str;
-+ struct vsf_sysutil_ipaddr the_addr;
-+ struct vsf_sysutil_ipport the_port;
-+ unsigned short i;
-+ struct vsf_sysutil_ipaddr remote_addr;
-+ char delim;
-+ int net_prt;
-+ unsigned int addrlen = 0;
-+
-+ vsf_sysutil_sockaddr_get_ipaddr(&remote_addr, p_sess->p_remote_addr);
-+ pasv_cleanup(p_sess);
-+ port_cleanup(p_sess);
-+ str_copy(&s_tmp_str, &p_sess->ftp_arg_str);
-+ delim = str_get_char_at(&s_tmp_str, 0);
-+ str_split_char(&s_tmp_str, &s_rhs_delim_str, delim);
-+ str_copy(&s_tmp_str, &s_rhs_delim_str);
-+ str_split_char(&s_tmp_str, &s_rhs_delim_str, delim);
-+ net_prt = str_atoi(&s_tmp_str);
-+ str_copy(&s_tmp_str, &s_rhs_delim_str);
-+ str_split_char(&s_tmp_str, &s_rhs_delim_str, delim);
-+ switch (net_prt) {
-+ case 1:
-+ {
-+ struct sockaddr_in sin4;
-+ inet_pton(AF_INET, str_getbuf(&s_tmp_str), &sin4.sin_addr);
-+ vsf_sysutil_memcpy(the_addr.data.ipv4, &sin4.sin_addr, sizeof(the_addr.data.ipv4));
-+ the_addr.family = AF_INET;
-+ addrlen = sizeof(struct in_addr);
-+ vsf_sysutil_sockaddr_alloc_ipv4(&p_sess->p_port_sockaddr);
-+ break;
-+ }
-+ case 2:
-+ {
-+ struct sockaddr_in6 sin6;
-+ inet_pton(AF_INET6, str_getbuf(&s_tmp_str), &sin6.sin6_addr);
-+ vsf_sysutil_memcpy(the_addr.data.ipv6, &sin6.sin6_addr, sizeof(the_addr.data.ipv6));
-+ the_addr.family = AF_INET6;
-+ addrlen = sizeof(struct in6_addr);
-+ vsf_sysutil_sockaddr_alloc_ipv6(&p_sess->p_port_sockaddr);
-+ break;
-+ }
-+ default:
-+ {
-+ vsf_cmdio_write(p_sess, FTP_NOPROTOSUPPORT, "Illegal EPRT command - unknown network protocol. Only AF_INET and AF_INET6 supported");
-+ return;
-+ }
-+ }
-+ str_copy(&s_tmp_str, &s_rhs_delim_str);
-+ str_split_char(&s_tmp_str, &s_rhs_delim_str, delim);
-+ i = htons(str_atoi(&s_tmp_str));
-+ vsf_sysutil_memcpy(the_port.data, &i, sizeof(the_port.data));
-+ /* SECURITY:
-+ * 1) Reject requests not connecting to the control socket IP
-+ * 2) Reject connects to privileged ports
-+ */
-+ if ((the_addr.family != remote_addr.family) ||
-+ (vsf_sysutil_memcmp(&the_addr.data, &remote_addr.data, addrlen) != 0 ||
-+ vsf_sysutil_is_port_reserved(the_port)))
-+ {
-+ vsf_cmdio_write(p_sess, FTP_BADCMD, "Illegal EPRT command.");
-+ port_cleanup(p_sess);
-+ return;
-+ }
-+ vsf_sysutil_sockaddr_set_port(p_sess->p_port_sockaddr, the_port);
-+ vsf_sysutil_sockaddr_set_ipaddr(p_sess->p_port_sockaddr, &the_addr);
-+ vsf_cmdio_write(p_sess, FTP_PORTOK,
-+ "EPRT command successful. Consider using EPSV.");
- }
-
- static void
-diff -u -d -r vsftpd-1.1.3.orig/privops.c vsftpd-1.1.3/privops.c
---- vsftpd-1.1.3.orig/privops.c Fri Sep 21 19:17:10 2001
-+++ vsftpd-1.1.3/privops.c Mon Nov 11 21:18:27 2002
-@@ -9,6 +9,10 @@
- * Look for suitable paranoia in this file.
- */
-
-+#include <sys/types.h>
-+#include <sys/socket.h>
-+#include <arpa/inet.h>
-+
- #include "privops.h"
- #include "session.h"
- #include "sysdeputil.h"
-@@ -35,15 +39,35 @@
- vsf_privop_get_ftp_port_sock(struct vsf_session* p_sess)
- {
- static struct vsf_sysutil_sockaddr* p_sockaddr;
-- struct vsf_sysutil_ipv4port the_port;
-+ struct vsf_sysutil_ipaddr the_addr;
-+ struct vsf_sysutil_ipport the_port;
- int retval;
-- int s = vsf_sysutil_get_ipv4_sock();
-- vsf_sysutil_activate_reuseaddr(s);
-- vsf_sysutil_sockaddr_alloc_ipv4(&p_sockaddr);
-- the_port = vsf_sysutil_ipv4port_from_int(tunable_ftp_data_port);
-+ int s = -1;
-+
-+ switch (((struct sockaddr*)p_sess->p_remote_addr)->sa_family) {
-+ case AF_INET:
-+ {
-+ s = vsf_sysutil_get_ipv4_sock();
-+ vsf_sysutil_activate_reuseaddr(s);
-+ vsf_sysutil_sockaddr_alloc_ipv4(&p_sockaddr);
-+ break;
-+ }
-+ case AF_INET6:
-+ {
-+ s = vsf_sysutil_get_ipv6_sock();
-+ vsf_sysutil_activate_reuseaddr(s);
-+ vsf_sysutil_sockaddr_alloc_ipv6(&p_sockaddr);
-+ break;
-+ }
-+ default:
-+ {
-+ die("unknown address family");
-+ }
-+ }
-+ the_port = vsf_sysutil_ipport_from_int(tunable_ftp_data_port);
- vsf_sysutil_sockaddr_set_port(p_sockaddr, the_port);
-- vsf_sysutil_sockaddr_set_ipaddr(p_sockaddr,
-- vsf_sysutil_sockaddr_get_ipaddr(p_sess->p_local_addr));
-+ vsf_sysutil_sockaddr_get_ipaddr(&the_addr, p_sess->p_local_addr);
-+ vsf_sysutil_sockaddr_set_ipaddr(p_sockaddr, &the_addr);
- retval = vsf_sysutil_bind(s, p_sockaddr);
- if (retval != 0)
- {
-diff -u -d -r vsftpd-1.1.3.orig/standalone.c vsftpd-1.1.3/standalone.c
---- vsftpd-1.1.3.orig/standalone.c Fri Oct 25 20:28:17 2002
-+++ vsftpd-1.1.3/standalone.c Mon Nov 11 21:18:27 2002
-@@ -7,6 +7,8 @@
- * Code to listen on the network and launch children servants.
- */
-
-+#include <sys/socket.h>
-+
- #include "standalone.h"
-
- #include "parseconf.h"
-@@ -27,8 +29,8 @@
- static void do_reload(void);
- static void prepare_child(int sockfd);
- static unsigned int handle_ip_count(
-- struct vsf_sysutil_ipv4addr* p_accept_addr);
--static void drop_ip_count(struct vsf_sysutil_ipv4addr* p_ip);
-+ struct vsf_sysutil_ipaddr* p_accept_addr);
-+static void drop_ip_count(struct vsf_sysutil_ipaddr* p_ip);
-
- static unsigned int hash_ip(unsigned int buckets, void* p_key);
- static unsigned int hash_pid(unsigned int buckets, void* p_key);
-@@ -37,13 +39,13 @@
- vsf_standalone_main(void)
- {
- struct vsf_sysutil_sockaddr* p_sockaddr = 0;
-- struct vsf_sysutil_ipv4addr listen_ipaddr;
-- int listen_sock = vsf_sysutil_get_ipv4_sock();
-+ struct vsf_sysutil_ipaddr listen_ipaddr;
-+ int listen_sock = -1;
- int retval;
-- s_p_ip_count_hash = hash_alloc(256, sizeof(struct vsf_sysutil_ipv4addr),
-+ s_p_ip_count_hash = hash_alloc(256, sizeof(struct vsf_sysutil_ipaddr),
- sizeof(unsigned int), hash_ip);
- s_p_pid_ip_hash = hash_alloc(256, sizeof(int),
-- sizeof(struct vsf_sysutil_ipv4addr), hash_pid);
-+ sizeof(struct vsf_sysutil_ipaddr), hash_pid);
- if (tunable_setproctitle_enable)
- {
- vsf_sysutil_setproctitle("LISTENER");
-@@ -51,16 +53,33 @@
- vsf_sysutil_install_sighandler(kVSFSysUtilSigCHLD, handle_sigchld, 0);
- vsf_sysutil_install_async_sighandler(kVSFSysUtilSigHUP, handle_sighup);
-
-- vsf_sysutil_activate_reuseaddr(listen_sock);
-- vsf_sysutil_sockaddr_alloc_ipv4(&p_sockaddr);
-- vsf_sysutil_sockaddr_set_port(
-- p_sockaddr, vsf_sysutil_ipv4port_from_int(tunable_listen_port));
-- if (!tunable_listen_address ||
-- vsf_sysutil_inet_aton(tunable_listen_address, &listen_ipaddr) == 0)
-+ if (tunable_listen_address)
- {
-+ if (vsf_sysutil_inet_aton(tunable_listen_address, &listen_ipaddr))
-+ {
-+ listen_sock = vsf_sysutil_get_ipv4_sock();
-+ vsf_sysutil_sockaddr_alloc_ipv4(&p_sockaddr);
-+ }
-+ else if (vsf_sysutil_inet_pton(tunable_listen_address, &listen_ipaddr))
-+ {
-+ listen_sock = vsf_sysutil_get_ipv6_sock();
-+ vsf_sysutil_sockaddr_alloc_ipv6(&p_sockaddr);
-+ }
-+ else
-+ {
-+ die("illegal listen address");
-+ }
-+ }
-+ else
-+ {
-+ listen_sock = vsf_sysutil_get_ipv6_sock();
- listen_ipaddr = vsf_sysutil_sockaddr_get_any();
-+ vsf_sysutil_sockaddr_alloc_ipv6(&p_sockaddr);
- }
-- vsf_sysutil_sockaddr_set_ipaddr(p_sockaddr, listen_ipaddr);
-+ vsf_sysutil_activate_reuseaddr(listen_sock);
-+ vsf_sysutil_sockaddr_set_port(
-+ p_sockaddr, vsf_sysutil_ipport_from_int(tunable_listen_port));
-+ vsf_sysutil_sockaddr_set_ipaddr(p_sockaddr, &listen_ipaddr);
- retval = vsf_sysutil_bind(listen_sock, p_sockaddr);
-
- vsf_sysutil_free(p_sockaddr);
-@@ -76,7 +95,7 @@
- struct vsf_client_launch child_info;
- static struct vsf_sysutil_sockaddr* p_accept_addr;
- int new_child;
-- struct vsf_sysutil_ipv4addr ip_addr;
-+ struct vsf_sysutil_ipaddr ip_addr;
- /* NOTE - wake up every 10 seconds to make sure we notice child exit
- * in a timely manner (the sync signal framework race)
- */
-@@ -91,7 +110,7 @@
- {
- continue;
- }
-- ip_addr = vsf_sysutil_sockaddr_get_ipaddr(p_accept_addr);
-+ vsf_sysutil_sockaddr_get_ipaddr(&ip_addr, p_accept_addr);
- ++s_children;
- child_info.num_children = s_children;
- child_info.num_this_ip = handle_ip_count(&ip_addr);
-@@ -139,7 +158,7 @@
- }
-
- static void
--drop_ip_count(struct vsf_sysutil_ipv4addr* p_ip)
-+drop_ip_count(struct vsf_sysutil_ipaddr* p_ip)
- {
- unsigned int count;
- unsigned int* p_count =
-@@ -171,11 +190,11 @@
- reap_one = (unsigned int)vsf_sysutil_wait_reap_one();
- if (reap_one)
- {
-- struct vsf_sysutil_ipv4addr* p_ip;
-+ struct vsf_sysutil_ipaddr* p_ip;
- /* Account total number of instances */
- --s_children;
- /* Account per-IP limit */
-- p_ip = (struct vsf_sysutil_ipv4addr*)
-+ p_ip = (struct vsf_sysutil_ipaddr*)
- hash_lookup_entry(s_p_pid_ip_hash, (void*)&reap_one);
- drop_ip_count(p_ip);
- hash_free_entry(s_p_pid_ip_hash, (void*)&reap_one);
-@@ -203,11 +222,30 @@
- static unsigned int
- hash_ip(unsigned int buckets, void* p_key)
- {
-- struct vsf_sysutil_ipv4addr* p_addr = (struct vsf_sysutil_ipv4addr*)p_key;
-- unsigned int val = p_addr->data[0] << 24;
-- val |= p_addr->data[1] << 16;
-- val |= p_addr->data[2] << 8;
-- val |= p_addr->data[3];
-+ struct vsf_sysutil_ipaddr* p_addr = (struct vsf_sysutil_ipaddr*)p_key;
-+ unsigned int val = 0;
-+ switch (p_addr->family) {
-+ case AF_INET:
-+ {
-+ val = p_addr->data.ipv4[0] << 24;
-+ val |= p_addr->data.ipv4[1] << 16;
-+ val |= p_addr->data.ipv4[2] << 8;
-+ val |= p_addr->data.ipv4[3];
-+ break;
-+ }
-+ case AF_INET6:
-+ {
-+ val = (p_addr->data.ipv6[0] ^ p_addr->data.ipv6[4] ^ p_addr->data.ipv6[8] ^ p_addr->data.ipv6[12]) << 24;
-+ val |= (p_addr->data.ipv6[1] ^ p_addr->data.ipv6[5] ^ p_addr->data.ipv6[9] ^ p_addr->data.ipv6[13]) << 16;
-+ val |= (p_addr->data.ipv6[2] ^ p_addr->data.ipv6[6] ^ p_addr->data.ipv6[10] ^ p_addr->data.ipv6[14]) << 8;
-+ val |= (p_addr->data.ipv6[3] ^ p_addr->data.ipv6[7] ^ p_addr->data.ipv6[11] ^ p_addr->data.ipv6[15]);
-+ break;
-+ }
-+ default:
-+ {
-+ die("unknown protocol family");
-+ }
-+ }
- return val % buckets;
- }
-
-@@ -219,7 +257,7 @@
- }
-
- static unsigned int
--handle_ip_count(struct vsf_sysutil_ipv4addr* p_accept_addr)
-+handle_ip_count(struct vsf_sysutil_ipaddr* p_accept_addr)
- {
- unsigned int* p_count =
- (unsigned int*)hash_lookup_entry(s_p_ip_count_hash, (void*)p_accept_addr);
-diff -u -d -r vsftpd-1.1.3.orig/sysutil.c vsftpd-1.1.3/sysutil.c
---- vsftpd-1.1.3.orig/sysutil.c Fri Oct 25 20:32:52 2002
-+++ vsftpd-1.1.3/sysutil.c Mon Nov 11 21:18:27 2002
-@@ -1425,6 +1425,17 @@
- return retval;
- }
-
-+int
-+vsf_sysutil_get_ipv6_sock(void)
-+{
-+ int retval = socket(PF_INET6, SOCK_STREAM, IPPROTO_TCP);
-+ if (retval < 0)
-+ {
-+ die("socket");
-+ }
-+ return retval;
-+}
-+
- struct vsf_sysutil_socketpair_retval
- vsf_sysutil_unix_dgram_socketpair(void)
- {
-@@ -1444,7 +1455,23 @@
- vsf_sysutil_bind(int fd, const struct vsf_sysutil_sockaddr* p_sockptr)
- {
- struct sockaddr* p_sockaddr = (struct sockaddr*) p_sockptr;
-- return bind(fd, p_sockaddr, sizeof(struct sockaddr_in));
-+ switch (p_sockaddr->sa_family) {
-+ case AF_INET:
-+ {
-+ return bind(fd, p_sockaddr, sizeof(struct sockaddr_in));
-+ break;
-+ }
-+ case AF_INET6:
-+ {
-+ return bind(fd, p_sockaddr, sizeof(struct sockaddr_in6));
-+ break;
-+ }
-+ default:
-+ {
-+ die("unknown address family");
-+ }
-+ }
-+ return -1;
- }
-
- void
-@@ -1461,7 +1488,7 @@
- vsf_sysutil_accept_timeout(int fd, struct vsf_sysutil_sockaddr** p_sockptr,
- unsigned int wait_seconds)
- {
-- struct sockaddr_in remote_addr;
-+ struct sockaddr_in6 remote_addr;
- int retval;
- fd_set accept_fdset;
- struct timeval timeout;
-@@ -1498,14 +1525,26 @@
- {
- return -1;
- }
-- if (remote_addr.sin_family != AF_INET)
-- {
-- die("can only support ipv4 currently");
-- }
- if (p_sockptr)
- {
-- *p_sockptr = vsf_sysutil_malloc(sizeof(remote_addr));
-- vsf_sysutil_memcpy(*p_sockptr, &remote_addr, sizeof(remote_addr));
-+ switch (remote_addr.sin6_family) {
-+ case AF_INET:
-+ {
-+ *p_sockptr = vsf_sysutil_malloc(sizeof(struct sockaddr_in));
-+ vsf_sysutil_memcpy(*p_sockptr, &remote_addr, sizeof(struct sockaddr_in));
-+ break;
-+ }
-+ case AF_INET6:
-+ {
-+ *p_sockptr = vsf_sysutil_malloc(sizeof(struct sockaddr_in6));
-+ vsf_sysutil_memcpy(*p_sockptr, &remote_addr, sizeof(struct sockaddr_in6));
-+ break;
-+ }
-+ default:
-+ {
-+ die("can only support ipv4 and ipv6 currently");
-+ }
-+ }
- }
- return retval;
- }
-@@ -1514,14 +1553,31 @@
- vsf_sysutil_connect_timeout(int fd, const struct vsf_sysutil_sockaddr* p_addr,
- unsigned int wait_seconds)
- {
-- const struct sockaddr_in* p_sockaddr = (const struct sockaddr_in*) p_addr;
-- unsigned int addrlen = sizeof(*p_sockaddr);
- int retval;
- if (wait_seconds > 0)
- {
- vsf_sysutil_activate_noblock(fd);
- }
-- retval = connect(fd, (const struct sockaddr*)p_sockaddr, addrlen);
-+ switch (((const struct sockaddr*)p_addr)->sa_family) {
-+ case AF_INET:
-+ {
-+ const struct sockaddr_in* p_sockaddr = (const struct sockaddr_in*) p_addr;
-+ unsigned int addrlen = sizeof(struct sockaddr_in);
-+ retval = connect(fd, (const struct sockaddr*)p_sockaddr, addrlen);
-+ break;
-+ }
-+ case AF_INET6:
-+ {
-+ const struct sockaddr_in6* p_sockaddr = (const struct sockaddr_in6*) p_addr;
-+ unsigned int addrlen = sizeof(struct sockaddr_in6);
-+ retval = connect(fd, (const struct sockaddr*)p_sockaddr, addrlen);
-+ break;
-+ }
-+ default:
-+ {
-+ die("unknown address family");
-+ }
-+ }
- if (retval < 0 && errno == EINPROGRESS)
- {
- fd_set connect_fdset;
-@@ -1561,7 +1617,7 @@
- void
- vsf_sysutil_getsockname(int fd, struct vsf_sysutil_sockaddr** p_sockptr)
- {
-- struct sockaddr_in the_addr;
-+ struct sockaddr_in6 the_addr;
- int retval;
- unsigned int socklen = sizeof(the_addr);
- vsf_sysutil_sockaddr_clear(p_sockptr);
-@@ -1570,18 +1626,44 @@
- {
- die("getsockname");
- }
-- if (the_addr.sin_family != AF_INET)
-- {
-- die("can only support ipv4 currently");
-+ switch (the_addr.sin6_family) {
-+ case AF_INET:
-+ {
-+ struct sockaddr_in *the_ipv4addr = (struct sockaddr_in*) &the_addr;
-+ *p_sockptr = vsf_sysutil_malloc(sizeof(struct sockaddr_in));
-+ vsf_sysutil_memcpy(*p_sockptr, the_ipv4addr, sizeof(struct sockaddr_in));
-+ break;
-+ }
-+ case AF_INET6:
-+ {
-+ struct sockaddr_in6 *the_ipv6addr = (struct sockaddr_in6*) &the_addr;
-+ if (IN6_IS_ADDR_V4MAPPED(&the_ipv6addr->sin6_addr))
-+ {
-+ struct sockaddr_in the_ipv4addr;
-+ the_ipv4addr.sin_family = AF_INET;
-+ vsf_sysutil_memcpy(&the_ipv4addr.sin_port, &the_ipv6addr->sin6_port, sizeof(the_ipv4addr.sin_port));
-+ vsf_sysutil_memcpy(&the_ipv4addr.sin_addr, &the_ipv6addr->sin6_addr.in6_u.u6_addr16[6], sizeof(the_ipv4addr.sin_addr));
-+ *p_sockptr = vsf_sysutil_malloc(sizeof(struct sockaddr_in));
-+ vsf_sysutil_memcpy(*p_sockptr, &the_ipv4addr, sizeof(struct sockaddr_in));
-+ }
-+ else
-+ {
-+ *p_sockptr = vsf_sysutil_malloc(sizeof(struct sockaddr_in6));
-+ vsf_sysutil_memcpy(*p_sockptr, the_ipv6addr, sizeof(struct sockaddr_in6));
-+ }
-+ break;
-+ }
-+ default:
-+ {
-+ die("can only support ipv4 and ipv6 currently");
-+ }
- }
-- *p_sockptr = vsf_sysutil_malloc(sizeof(the_addr));
-- vsf_sysutil_memcpy(*p_sockptr, &the_addr, sizeof(the_addr));
- }
-
- void
- vsf_sysutil_getpeername(int fd, struct vsf_sysutil_sockaddr** p_sockptr)
- {
-- struct sockaddr_in the_addr;
-+ struct sockaddr_in6 the_addr;
- int retval;
- unsigned int socklen = sizeof(the_addr);
- vsf_sysutil_sockaddr_clear(p_sockptr);
-@@ -1590,12 +1672,38 @@
- {
- die("getpeername");
- }
-- if (the_addr.sin_family != AF_INET)
-- {
-- die("can only support ipv4 currently");
-+ switch (the_addr.sin6_family) {
-+ case AF_INET:
-+ {
-+ struct sockaddr_in *the_ipv4addr = (struct sockaddr_in*) &the_addr;
-+ *p_sockptr = vsf_sysutil_malloc(sizeof(struct sockaddr_in));
-+ vsf_sysutil_memcpy(*p_sockptr, the_ipv4addr, sizeof(struct sockaddr_in));
-+ break;
-+ }
-+ case AF_INET6:
-+ {
-+ struct sockaddr_in6 *the_ipv6addr = (struct sockaddr_in6*) &the_addr;
-+ if (IN6_IS_ADDR_V4MAPPED(&the_ipv6addr->sin6_addr))
-+ {
-+ struct sockaddr_in the_ipv4addr;
-+ the_ipv4addr.sin_family = AF_INET;
-+ vsf_sysutil_memcpy(&the_ipv4addr.sin_port, &the_ipv6addr->sin6_port, sizeof(the_ipv4addr.sin_port));
-+ vsf_sysutil_memcpy(&the_ipv4addr.sin_addr, &the_ipv6addr->sin6_addr.in6_u.u6_addr16[6], sizeof(the_ipv4addr.sin_addr));
-+ *p_sockptr = vsf_sysutil_malloc(sizeof(struct sockaddr_in));
-+ vsf_sysutil_memcpy(*p_sockptr, &the_ipv4addr, sizeof(struct sockaddr_in));
-+ }
-+ else
-+ {
-+ *p_sockptr = vsf_sysutil_malloc(sizeof(struct sockaddr_in6));
-+ vsf_sysutil_memcpy(*p_sockptr, the_ipv6addr, sizeof(struct sockaddr_in6));
-+ }
-+ break;
-+ }
-+ default:
-+ {
-+ die("can only support ipv4 and ipv6 currently");
-+ }
- }
-- *p_sockptr = vsf_sysutil_malloc(sizeof(the_addr));
-- vsf_sysutil_memcpy(*p_sockptr, &the_addr, sizeof(the_addr));
- }
-
- void
-@@ -1630,45 +1738,112 @@
- }
-
- void
-+vsf_sysutil_sockaddr_alloc_ipv6(struct vsf_sysutil_sockaddr** p_sockptr)
-+{
-+ struct sockaddr_in6 new_addr;
-+ vsf_sysutil_sockaddr_clear(p_sockptr);
-+ *p_sockptr = vsf_sysutil_malloc(sizeof(new_addr));
-+ vsf_sysutil_memclr(&new_addr, sizeof(new_addr));
-+ new_addr.sin6_family = AF_INET6;
-+ vsf_sysutil_memcpy(*p_sockptr, &new_addr, sizeof(new_addr));
-+}
-+
-+void
- vsf_sysutil_sockaddr_set_ipaddr(struct vsf_sysutil_sockaddr* p_sockptr,
-- struct vsf_sysutil_ipv4addr the_addr)
-+ struct vsf_sysutil_ipaddr* the_addr)
- {
-- struct sockaddr_in* p_sockaddr = (struct sockaddr_in*) p_sockptr;
-- vsf_sysutil_memcpy(&p_sockaddr->sin_addr.s_addr, the_addr.data,
-+ switch (the_addr->family) {
-+ case AF_INET:
-+ {
-+ struct sockaddr_in* p_sockaddr = (struct sockaddr_in*) p_sockptr;
-+ p_sockaddr->sin_family = the_addr->family;
-+ vsf_sysutil_memcpy(&p_sockaddr->sin_addr.s_addr, &the_addr->data.ipv4,
- sizeof(p_sockaddr->sin_addr.s_addr));
-+ break;
-+ }
-+ case AF_INET6:
-+ {
-+ struct sockaddr_in6* p_sockaddr = (struct sockaddr_in6*) p_sockptr;
-+ p_sockaddr->sin6_family = the_addr->family;
-+ vsf_sysutil_memcpy(&p_sockaddr->sin6_addr, &the_addr->data.ipv6,
-+ sizeof(p_sockaddr->sin6_addr));
-+ break;
-+ }
-+ default:
-+ {
-+ die("unknown address family");
-+ }
-+ }
-+ return;
- }
-
--struct vsf_sysutil_ipv4addr
--vsf_sysutil_sockaddr_get_ipaddr(const struct vsf_sysutil_sockaddr* p_sockptr)
-+void
-+vsf_sysutil_sockaddr_get_ipaddr(struct vsf_sysutil_ipaddr *d_sockptr, const struct vsf_sysutil_sockaddr* p_sockptr)
- {
-- struct vsf_sysutil_ipv4addr retval;
-- const struct sockaddr_in* p_sockaddr = (const struct sockaddr_in*) p_sockptr;
-- vsf_sysutil_memcpy(retval.data, &p_sockaddr->sin_addr.s_addr,
-- sizeof(retval.data));
-- return retval;
-+ const struct sockaddr* p_sockaddr = (const struct sockaddr*) p_sockptr;
-+ switch (p_sockaddr->sa_family) {
-+ case AF_INET:
-+ {
-+ const struct sockaddr_in* p_sockaddr4 = (const struct sockaddr_in*) p_sockptr;
-+ d_sockptr->family = p_sockaddr4->sin_family;
-+ vsf_sysutil_memcpy(&d_sockptr->data, &p_sockaddr4->sin_addr,
-+ sizeof(p_sockaddr4->sin_addr));
-+ break;
-+ }
-+ case AF_INET6:
-+ {
-+ const struct sockaddr_in6* p_sockaddr6 = (const struct sockaddr_in6*) p_sockptr;
-+ d_sockptr->family = p_sockaddr6->sin6_family;
-+ vsf_sysutil_memcpy(&d_sockptr->data, &p_sockaddr6->sin6_addr,
-+ sizeof(p_sockaddr6->sin6_addr));
-+ break;
-+ }
-+ default:
-+ {
-+ die("unknown address family");
-+ }
-+ }
-+ return;
- }
-
--struct vsf_sysutil_ipv4addr
-+struct vsf_sysutil_ipaddr
- vsf_sysutil_sockaddr_get_any(void)
- {
-- struct vsf_sysutil_ipv4addr retval;
-+ struct vsf_sysutil_ipaddr retval;
- vsf_sysutil_memclr(&retval, sizeof(retval));
-+ retval.family = AF_INET6;
- return retval;
- }
-
--struct vsf_sysutil_ipv4port
-+struct vsf_sysutil_ipport
- vsf_sysutil_sockaddr_get_port(const struct vsf_sysutil_sockaddr* p_sockptr)
- {
-- struct vsf_sysutil_ipv4port retval;
-- const struct sockaddr_in* p_sockaddr = (const struct sockaddr_in*) p_sockptr;
-- vsf_sysutil_memcpy(retval.data, &p_sockaddr->sin_port, sizeof(retval.data));
-+ struct vsf_sysutil_ipport retval;
-+ switch (((const struct sockaddr*)p_sockptr)->sa_family) {
-+ case AF_INET:
-+ {
-+ const struct sockaddr_in* p_sockaddr = (const struct sockaddr_in*) p_sockptr;
-+ vsf_sysutil_memcpy(retval.data, &p_sockaddr->sin_port, sizeof(retval.data));
-+ break;
-+ }
-+ case AF_INET6:
-+ {
-+ const struct sockaddr_in6* p_sockaddr = (const struct sockaddr_in6*) p_sockptr;
-+ vsf_sysutil_memcpy(retval.data, &p_sockaddr->sin6_port, sizeof(retval.data));
-+ break;
-+ }
-+ default:
-+ {
-+ die("unknown address family");
-+ }
-+ }
- return retval;
- }
-
--struct vsf_sysutil_ipv4port
--vsf_sysutil_ipv4port_from_int(unsigned int port)
-+struct vsf_sysutil_ipport
-+vsf_sysutil_ipport_from_int(unsigned int port)
- {
-- struct vsf_sysutil_ipv4port retval;
-+ struct vsf_sysutil_ipport retval;
- unsigned short netorder_port = htons(port);
- vsf_sysutil_memcpy(retval.data, &netorder_port, sizeof(retval.data));
- return retval;
-@@ -1676,7 +1851,7 @@
-
- void
- vsf_sysutil_sockaddr_set_port(struct vsf_sysutil_sockaddr* p_sockptr,
-- struct vsf_sysutil_ipv4port the_port)
-+ struct vsf_sysutil_ipport the_port)
- {
- struct sockaddr_in* p_sockaddrin = (struct sockaddr_in*) p_sockptr;
- vsf_sysutil_memcpy(&p_sockaddrin->sin_port, the_port.data,
-@@ -1684,7 +1859,7 @@
- }
-
- int
--vsf_sysutil_is_port_reserved(const struct vsf_sysutil_ipv4port the_port)
-+vsf_sysutil_is_port_reserved(const struct vsf_sysutil_ipport the_port)
- {
- unsigned short netorder_port;
- vsf_sysutil_memcpy(&netorder_port, the_port.data, sizeof(netorder_port));
-@@ -1696,19 +1871,54 @@
- }
-
- const char*
--vsf_sysutil_inet_ntoa(const struct vsf_sysutil_sockaddr* p_sockptr)
-+vsf_sysutil_inet_ntop(const struct vsf_sysutil_sockaddr* p_sockptr)
- {
-- const struct sockaddr_in* p_sockaddr = (const struct sockaddr_in*) p_sockptr;
-- return inet_ntoa(p_sockaddr->sin_addr);
-+ switch (((struct sockaddr*)p_sockptr)->sa_family) {
-+ case AF_INET:
-+ {
-+ const struct sockaddr_in* p_sockaddr = (const struct sockaddr_in*) p_sockptr;
-+ return inet_ntoa(p_sockaddr->sin_addr);
-+ break;
-+ }
-+ case AF_INET6:
-+ {
-+ static char buf[INET6_ADDRSTRLEN];
-+ const struct sockaddr_in6* p_sockaddr = (const struct sockaddr_in6*) p_sockptr;
-+ return inet_ntop(AF_INET6, &p_sockaddr->sin6_addr, buf, INET6_ADDRSTRLEN);
-+ break;
-+ }
-+ default:
-+ {
-+ die("unknown address family");
-+ }
-+ }
-+ return 0;
- }
-
- int
--vsf_sysutil_inet_aton(const char* p_text, struct vsf_sysutil_ipv4addr* p_addr)
-+vsf_sysutil_inet_aton(const char* p_text, struct vsf_sysutil_ipaddr* p_addr)
- {
- struct in_addr sin_addr;
- if (inet_aton(p_text, &sin_addr))
- {
-- vsf_sysutil_memcpy(p_addr, &sin_addr.s_addr, sizeof(*p_addr));
-+ vsf_sysutil_memcpy(&p_addr->data, &sin_addr.s_addr, sizeof(*p_addr));
-+ p_addr->family = AF_INET;
-+ return 1;
-+ }
-+ else
-+ {
-+ return 0;
-+ }
-+}
-+
-+int
-+vsf_sysutil_inet_pton(const char* p_text, struct vsf_sysutil_ipaddr* p_addr)
-+{
-+ struct in6_addr sin_addr;
-+ if (inet_pton(AF_INET6, p_text, &sin_addr))
-+ {
-+ vsf_sysutil_memcpy(&p_addr->data, &sin_addr, sizeof(*p_addr));
-+ p_addr->family = AF_INET6;
- return 1;
- }
- else
-diff -u -d -r vsftpd-1.1.3.orig/sysutil.h vsftpd-1.1.3/sysutil.h
---- vsftpd-1.1.3.orig/sysutil.h Fri Oct 25 20:32:29 2002
-+++ vsftpd-1.1.3/sysutil.h Mon Nov 11 21:18:27 2002
-@@ -193,11 +193,15 @@
-
- /* Socket handling */
- struct vsf_sysutil_sockaddr;
--struct vsf_sysutil_ipv4addr
-+struct vsf_sysutil_ipaddr
- {
-- unsigned char data[4];
-+ unsigned short int family;
-+ union {
-+ unsigned char ipv4[4];
-+ unsigned char ipv6[16];
-+ } data;
- };
--struct vsf_sysutil_ipv4port
-+struct vsf_sysutil_ipport
- {
- unsigned char data[2];
- };
-@@ -208,18 +212,20 @@
- };
- void vsf_sysutil_sockaddr_clear(struct vsf_sysutil_sockaddr** p_sockptr);
- void vsf_sysutil_sockaddr_alloc_ipv4(struct vsf_sysutil_sockaddr** p_sockptr);
-+void vsf_sysutil_sockaddr_alloc_ipv6(struct vsf_sysutil_sockaddr** p_sockptr);
- void vsf_sysutil_sockaddr_set_ipaddr(struct vsf_sysutil_sockaddr* p_sockptr,
-- struct vsf_sysutil_ipv4addr the_addr);
--struct vsf_sysutil_ipv4addr vsf_sysutil_sockaddr_get_ipaddr(
-+ struct vsf_sysutil_ipaddr* the_addr);
-+void vsf_sysutil_sockaddr_get_ipaddr(struct vsf_sysutil_ipaddr *d_sockptr,
- const struct vsf_sysutil_sockaddr* p_sockptr);
--struct vsf_sysutil_ipv4addr vsf_sysutil_sockaddr_get_any(void);
--struct vsf_sysutil_ipv4port vsf_sysutil_ipv4port_from_int(unsigned int port);
-+struct vsf_sysutil_ipaddr vsf_sysutil_sockaddr_get_any(void);
-+struct vsf_sysutil_ipport vsf_sysutil_ipport_from_int(unsigned int port);
- void vsf_sysutil_sockaddr_set_port(struct vsf_sysutil_sockaddr* p_sockptr,
-- struct vsf_sysutil_ipv4port the_port);
--struct vsf_sysutil_ipv4port vsf_sysutil_sockaddr_get_port(
-+ struct vsf_sysutil_ipport the_port);
-+struct vsf_sysutil_ipport vsf_sysutil_sockaddr_get_port(
- const struct vsf_sysutil_sockaddr* p_sockptr);
--int vsf_sysutil_is_port_reserved(const struct vsf_sysutil_ipv4port);
-+int vsf_sysutil_is_port_reserved(const struct vsf_sysutil_ipport);
- int vsf_sysutil_get_ipv4_sock(void);
-+int vsf_sysutil_get_ipv6_sock(void);
- struct vsf_sysutil_socketpair_retval
- vsf_sysutil_unix_dgram_socketpair(void);
- int vsf_sysutil_bind(int fd, const struct vsf_sysutil_sockaddr* p_sockptr);
-@@ -246,10 +252,12 @@
- void vsf_sysutil_shutdown_failok(int fd);
- int vsf_sysutil_recv_peek(const int fd, void* p_buf, unsigned int len);
-
--const char* vsf_sysutil_inet_ntoa(
-+const char* vsf_sysutil_inet_ntop(
- const struct vsf_sysutil_sockaddr* p_sockptr);
- int vsf_sysutil_inet_aton(
-- const char* p_text, struct vsf_sysutil_ipv4addr* p_addr);
-+ const char* p_text, struct vsf_sysutil_ipaddr* p_addr);
-+int vsf_sysutil_inet_pton(
-+ const char* p_text, struct vsf_sysutil_ipaddr* p_addr);
-
- /* User database queries etc. */
- struct vsf_sysutil_user;