freebsd-ports/irc/sirc/files/dsirc-ipv6
Doug Barton 80826c19a2 Seriously modernize this port, my first contribution to FreeBSD
from almost 11 years ago!

Add IPv6 support as well as fixing the dsirc script for modern Perl
courtesy of the NetBSD port. Also add a stripped down version of that
patch which will let dsirc work with modern Perl even without IPv6.

Use OPTIONS to handle IPv6 and SOCKS support.

Also include the addon scripts from the author's site as an OPTION.

Take advantage of PORTDOCS support, and fix the plist as a side effect.

If the user chooses to add SOCKS support print a pkg-message to tell
them how to set it up, and make the README.socks PORTDOC conditional.

Fix the shebang line in dsirc to respect PREFIX.

Change the default IRC server to irc.efnet.org using sed on dsirc
instead of trying to handle it in the sirc script. The effect is
the same, and the user can still override this trivially in their
~/.sircrc.pl file.

Patch ssfe.c to include string.h so that it compiles without errors.

Bump PORTREVISION to signify the significant nature of the update.
2009-03-06 09:06:13 +00:00

107 lines
3.6 KiB
Text

--- dsirc.orig 1998-03-10 04:55:50.000000000 -0800
+++ dsirc 2009-03-05 00:34:19.000000000 -0800
@@ -52,6 +52,7 @@
}
if ($] >= 5 && (eval "use Socket;", $@ eq '')) {
+ use Socket6;
} elsif (-f "$libdir/sircsock.ph") {
do "$libdir/sircsock.ph";
} elsif (-f $ENV{'HOME'}."/sircsock.ph") {
@@ -95,6 +96,7 @@
$restrict=$opt_R;
$set{"LOCALHOST"}=$opt_H || $ENV{"SIRCHOST"} || $ENV{"IRCHOST"} ||
$ENV{"LOCALHOST"} || "";
+$use_ipv6=0; # enabled when the given server gets resolved by gethostbyname2
if ($set{"LOCALHOST"}) {
$bindaddr=&resolve($set{"LOCALHOST"});
@@ -148,7 +150,16 @@
} elsif ($_[0] =~ /^(\d+)\.(\d+)\.(\d+)\.(\d+)$/) {
return pack("c4", $1, $2, $3, $4);
} else {
- return (gethostbyname($_[0]))[4];
+ local $rc;
+
+ $rc = (gethostbyname2($_[0], AF_INET6))[4];
+
+ if ($rc) {
+ $use_ipv6 = 1;
+ return $rc;
+ } else {
+ return (gethostbyname($_[0]))[4];
+ }
}
}
@@ -162,19 +173,31 @@
local($fh, $host, $port)=@_;
local($adr, $otherend)=&resolve($host);
&tell("*\cbE\cb* Hostname `$host' not found"), return 0 unless $adr;
- $otherend=pack("S n a4 x8", &AF_INET, $port, $adr);
- &print("*\cbE\cb* Out of file descriptors"), return 0
- unless socket($fh, &PF_INET, &SOCK_STREAM, 0);
- if ($set{"LOCALHOST"}) {
- bind($fh, pack("S n a4 x8", &AF_INET, 0, $bindaddr)) ||
- &tell("*\cbE\cb* Warning: can't bind to sirc host ".$set{'LOCALHOST'});
+ if ($use_ipv6) {
+ $otherend=pack_sockaddr_in6($port, $adr);
+ &print("*\cbE\cb* Out of file descriptors"), return 0
+ unless socket($fh, &PF_INET6, &SOCK_STREAM, 0);
+ } else {
+ $otherend=pack_sockaddr_in($port, $adr);
+ &print("*\cbE\cb* Out of file descriptors"), return 0
+ unless socket($fh, &PF_INET, &SOCK_STREAM, 0);
+ }
+ if (! $use_ipv6) {
+ if ($set{"LOCALHOST"}) {
+ bind($fh, pack("S n a4 x8", &AF_INET, 0, $bindaddr)) ||
+ &tell("*\cbE\cb* Warning: can't bind to sirc host ".$set{'LOCALHOST'});
+ }
}
$trysock=$fh;
$SIG{'QUIT'}='sigquit';
&print("*\cbE\cb* Can't connect to host: $!"), close $fh,
$SIG{'QUIT'}='IGNORE', return 0 unless connect($fh, $otherend);
$SIG{'QUIT'}='IGNORE';
- $bindaddr=(unpack("S n a4", getsockname($fh)))[2] if !$bindaddr;
+ if ($use_ipv6) {
+ $bindaddr=(unpack_sockaddr_in6(getsockname($fh)))[2] if !$bindaddr;
+ } else {
+ $bindaddr=(unpack_sockaddr_in(getsockname($fh)))[2] if !$bindaddr;
+ }
select($fh); $|=1; select(STDOUT);
return 1;
}
@@ -183,15 +206,26 @@
$_[0]=&newfh;
local($fh, $port)=@_;
local($thisend);
- $bindaddr=pack("x4", 0) unless $bindaddr;
- $thisend=pack("S n a4 x8", &AF_INET, $port+0, $bindaddr);
- &tell("*\cbE\cb* Out of file descriptors"), return 0
- unless socket($fh, &PF_INET, &SOCK_STREAM, 0);
+ if ($use_ipv6) {
+ $bindaddr=pack_sockaddr_in6(0, 0) unless $bindaddr;
+ $thisend=pack_sockaddr_in6($port+0, $bindaddr);
+ &tell("*\cbE\cb* Out of file descriptors"), return 0
+ unless socket($fh, &PF_INET6, &SOCK_STREAM, 0);
+ } else {
+ $bindaddr=pack_sockaddr_in(0, 0) unless $bindaddr;
+ $thisend=pack_sockaddr_in($port+0, $bindaddr);
+ &tell("*\cbE\cb* Out of file descriptors"), return 0
+ unless socket($fh, &PF_INET, &SOCK_STREAM, 0);
+ }
&tell("*\cbE\cb* Can't bind local socket!"), close $fh, return 0
unless bind($fh, $thisend);
&tell("*\cbE\cb* Can't listen to socket!"), close $fh, return
unless listen($fh, 5);
- return (unpack("S n", getsockname($fh)))[1];
+ if ($use_ipv6) {
+ return (unpack_sockaddr_in6(getsockname($fh)))[1];
+ } else {
+ return (unpack_sockaddr_in(getsockname($fh)))[1];
+ }
}
sub accept {