X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=lib%2FCatalyst%2FEngine%2FHTTP.pm;h=37ed3a95d1e4eaf7863f1a494c4c22e278792adf;hb=1cf1c56a0c68611a361dbb8c797891baf6d0974f;hp=779378cbb6099e11713ea1fdf570bddec9203367;hpb=c825a86ca867b6b804aa8636728c3d3702ac9f04;p=catagits%2FCatalyst-Runtime.git diff --git a/lib/Catalyst/Engine/HTTP.pm b/lib/Catalyst/Engine/HTTP.pm index 779378c..37ed3a9 100644 --- a/lib/Catalyst/Engine/HTTP.pm +++ b/lib/Catalyst/Engine/HTTP.pm @@ -109,25 +109,27 @@ sub run { my ( $self, $class, $port, $host, $options ) = @_; $options ||= {}; - + our $GOT_HUP; local $GOT_HUP = 0; - + local $SIG{HUP} = sub { $GOT_HUP = 1; }; local $SIG{CHLD} = 'IGNORE'; + my $allowed = $options->{allowed} || { '127.0.0.1' => '255.255.255.255' }; + # Handle requests # Setup socket $host = $host ? inet_aton($host) : INADDR_ANY; socket( HTTPDaemon, PF_INET, SOCK_STREAM, getprotobyname('tcp') ) - || die "Couldn't assign TCP socket: $!"; + || die "Couldn't assign TCP socket: $!"; setsockopt( HTTPDaemon, SOL_SOCKET, SO_REUSEADDR, pack( "l", 1 ) ) - || die "Couldn't set TCP socket options: $!"; + || die "Couldn't set TCP socket options: $!"; bind( HTTPDaemon, sockaddr_in( $port, $host ) ) - || die "Couldn't bind socket to $port on $host: $!"; + || die "Couldn't bind socket to $port on $host: $!"; listen( HTTPDaemon, SOMAXCONN ) - || die "Couldn't listen to socket on $port on $host: $!"; + || die "Couldn't listen to socket on $port on $host: $!"; my $url = 'http://'; if ( $host eq INADDR_ANY ) { require Sys::Hostname; @@ -213,9 +215,22 @@ sub run { } } } + unless ( uc($method) eq 'KILL' ) { - # Pass flow control to Catalyst - $class->handle_request; + # Pass flow control to Catalyst + $class->handle_request; + } + else { + my $ipaddr = _inet_addr($peeraddr); + my $ready = 0; + while ( my ( $ip, $mask ) = each %$allowed and not $ready ) { + $ready = ( $ipaddr & _inet_addr($mask) ) == _inet_addr($ip); + } + if ($ready) { + $GOT_HUP = 1; + last; + } + } exit if defined $pid; } continue { @@ -226,7 +241,7 @@ sub run { if ($GOT_HUP) { $SIG{CHLD} = 'DEFAULT'; wait; - exec $^X . ' "' . $0 . '" ' . join(' ', @{$options->{argv}}); + exec $^X . ' "' . $0 . '" ' . join( ' ', @{ $options->{argv} } ); } } @@ -245,6 +260,8 @@ sub _get_line { return $line; } +sub _inet_addr { unpack "N*", inet_aton( $_[0] ) } + =back =head1 SEE ALSO