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 | |
7 | use Socket; |
7 | use Socket; |
8 | use AnyEvent::Socket; |
8 | use AnyEvent::Socket; |
9 | |
9 | |
10 | our $BIND = $cf::CFG{bind_addresses} || [[undef, 13327]]; |
10 | CONF BIND_ADDRESSES = [[undef, 13327]]; |
|
|
11 | |
11 | our @LISTENERS; |
12 | our @LISTENERS; |
12 | |
13 | |
13 | for (@$BIND) { |
14 | for (@$BIND_ADDRESSES) { |
14 | my ($host, $port) = @$_; |
15 | my ($host, $port) = @$_; |
15 | cf::info "listening on ", (format_hostport $host, $port), "\n"; |
16 | cf::info "listening on ", (format_hostport $host, $port), "\n"; |
16 | |
17 | |
17 | push @LISTENERS, tcp_server $host, $port, sub { |
18 | push @LISTENERS, tcp_server $host, $port, sub { |
18 | my ($fh, $host, $port) = @_ |
19 | my ($fh, $host, $port) = @_ |
19 | or return; |
20 | or return; |
20 | |
21 | |
|
|
22 | my $lhost = AnyEvent::Socket::format_address |
|
|
23 | +(AnyEvent::Socket::unpack_sockaddr getsockname $fh)[1]; |
|
|
24 | |
21 | cf::info "new connection from ", (format_hostport $host, $port), "\n"; |
25 | cf::info "new connection from ", (format_hostport $host, $port), "\n" |
|
|
26 | if $lhost ne $host; # do not log connections from the host, e.g. for watchdogs |
22 | |
27 | |
23 | cf::client::create fileno $fh, $host; |
28 | cf::client::create fileno $fh, $host; |
24 | }; |
29 | }; |
25 | } |
30 | } |
26 | |
31 | |