ViewVC Help
View File | Revision Log | Show Annotations | Download File
/cvs/deliantra/server/ext/tcp.ext
(Generate patch)

Comparing deliantra/server/ext/tcp.ext (file contents):
Revision 1.14 by root, Sun Jan 31 03:46:20 2010 UTC vs.
Revision 1.19 by root, Fri Jan 21 19:45:08 2011 UTC

1#! perl # MANDATORY 1#! perl # mandatory
2 2
3# this listens for new tcp connections and hands them over to the server core 3# this listens for new tcp connections and hands them over to the server core
4# wether this being an extension introduces or reduces stability problems 4# whether this being an extension introduces or reduces stability problems
5# is unknown as of today. 5# is unknown as of today.
6 6
7use Socket; 7use Socket;
8use AnyEvent::Socket; 8use AnyEvent::Socket;
9 9
10our $BIND = $cf::CFG{bind_addresses} || [[undef, 13327]]; 10our $BIND = $cf::CFG{bind_addresses} || [[undef, 13327]];
11our @LISTENERS;
11 12
12for (@$BIND) { 13for (@$BIND) {
13 my ($host, $port) = @$_; 14 my ($host, $port) = @$_;
14 warn "listening on ", (format_hostport $host, $port), "\n"; 15 cf::info "listening on ", (format_hostport $host, $port), "\n";
15 16
16 tcp_server $host, $port, sub { 17 push @LISTENERS, tcp_server $host, $port, sub {
17 my ($fh, $host, $port) = @_ 18 my ($fh, $host, $port) = @_
18 or return; 19 or return;
19 20
21 my $lhost = AnyEvent::Socket::format_address
22 +(AnyEvent::Socket::unpack_sockaddr getsockname $fh)[1];
23
20 warn "new connection from ", (format_hostport $host, $port), "\n"; 24 cf::info "new connection from ", (format_hostport $host, $port), "\n"
25 if $lhost ne $host; # do not log connections from the host, e.g. for watchdogs
21 26
22 cf::client::create fileno $fh, $host; 27 cf::client::create fileno $fh, $host;
23 }; 28 };
24} 29}
25 30

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines