Added support for (x)inetd.
git-svn-id: https://svn.perl.org/qpsmtpd/branches/0.3x@681 958fd67b-6ff1-0310-b445-bb7760255be9
This commit is contained in:
parent
5fea527ba4
commit
d2c79e9736
@ -1,6 +1,7 @@
|
|||||||
package Qpsmtpd::TcpServer;
|
package Qpsmtpd::TcpServer;
|
||||||
use Qpsmtpd::SMTP;
|
use Qpsmtpd::SMTP;
|
||||||
use Qpsmtpd::Constants;
|
use Qpsmtpd::Constants;
|
||||||
|
use Socket;
|
||||||
|
|
||||||
@ISA = qw(Qpsmtpd::SMTP);
|
@ISA = qw(Qpsmtpd::SMTP);
|
||||||
use strict;
|
use strict;
|
||||||
@ -12,12 +13,25 @@ my $first_0;
|
|||||||
sub start_connection {
|
sub start_connection {
|
||||||
my $self = shift;
|
my $self = shift;
|
||||||
|
|
||||||
die "Qpsmtpd::TcpServer must be started by tcpserver\n"
|
my ($remote_host, $remote_info, $remote_ip);
|
||||||
unless $ENV{TCPREMOTEIP};
|
|
||||||
|
|
||||||
my $remote_host = $ENV{TCPREMOTEHOST} || ( $ENV{TCPREMOTEIP} ? "[$ENV{TCPREMOTEIP}]" : "[noip!]");
|
if ($ENV{TCPREMOTEIP}) {
|
||||||
my $remote_info = $ENV{TCPREMOTEINFO} ? "$ENV{TCPREMOTEINFO}\@$remote_host" : $remote_host;
|
# started from tcpserver (or some other superserver which
|
||||||
my $remote_ip = $ENV{TCPREMOTEIP};
|
# exports the TCPREMOTE* variables.
|
||||||
|
$remote_ip = $ENV{TCPREMOTEIP};
|
||||||
|
$remote_host = $ENV{TCPREMOTEHOST} || "[$remote_ip]";
|
||||||
|
$remote_info = $ENV{TCPREMOTEINFO} ? "$ENV{TCPREMOTEINFO}\@$remote_host" : $remote_host;
|
||||||
|
} else {
|
||||||
|
# Started from inetd or similar.
|
||||||
|
# get info on the remote host from the socket.
|
||||||
|
# ignore ident/tap/...
|
||||||
|
my $hersockaddr = getpeername(STDIN)
|
||||||
|
or die "getpeername failed: $0 must be called from tcpserver, (x)inetd or a similar program which passes a socket to stdin";
|
||||||
|
my ($port, $iaddr) = sockaddr_in($hersockaddr);
|
||||||
|
$remote_ip = inet_ntoa($iaddr);
|
||||||
|
$remote_host = gethostbyaddr($iaddr, AF_INET) || "[$remote_ip]";
|
||||||
|
$remote_info = $remote_host;
|
||||||
|
}
|
||||||
$self->log(LOGNOTICE, "Connection from $remote_info [$remote_ip]");
|
$self->log(LOGNOTICE, "Connection from $remote_info [$remote_ip]");
|
||||||
|
|
||||||
# if the local dns resolver doesn't filter it out we might get
|
# if the local dns resolver doesn't filter it out we might get
|
||||||
|
Loading…
Reference in New Issue
Block a user