package Net::Server::Mail::ESMTP::AUTH; use 5.006; use strict; use base qw(Net::Server::Mail::ESMTP::Extension); use MIME::Base64; use vars qw( $VERSION ); $VERSION = '0.1'; =pod Net::Server::Mail::ESMTP::AUTH - An extension to provide support for SMTP Authentification with Net::Server::Mail::ESMTP module =head1 SYNOPSIS use Net::Server::Mail::ESMTP; my @local_domains = qw(example.com example.org); my $server = new IO::Socket::INET Listen => 1, LocalPort => 25; my $conn; while($conn = $server->accept) { my $esmtp = new Net::Server::Mail::ESMTP socket => $conn; # activate AUTH extension $esmtp->register('Net::Server::Mail::ESMTP::AUTH'); # adding AUTH handler $esmtp->set_callback(AUTH => \&validate_auth); $esmtp->process; } sub validate_auth { my ($session, $username, $password) = @_; if ($username eq 'ROBERT' and $password eq 'TOTO04') { # AUTH SUCCESFULL return 1; } else { # AUTH FAILED return 0; } } =head1 FEATURES * AUTH LOGIN method support * AUTH PLAIN method support =head1 DESCRIPTION "Net::Server::Mail::ESMTP::AUTH" is an extension to provide ESMTP Authentification support to Net::Server::Mail::ESMTP module. Actually only AUTH LOGIN and AUTH PLAIN methods are supported. AUTH callback is called with login and password who was given by user's mail client, AUTH callback should return 1 when authentification mechanism was succesfull otherwise 0. =cut our $verb = 'AUTH'; sub init { my ($self, $parent) = @_; $self->{AUTH} = (); return $self; } sub verb { return ( [ 'AUTH' => \&process, ],); } sub keyword { return 'AUTH LOGIN PLAIN'; } sub reply { return ( [ 'AUTH', ]); } sub process_authlogin_username { my ($self, $operation) = @_; $self->{AUTH}->{username} = decode_base64($operation); $self->{AUTH}->{password} = ''; $self->reply(334, "UGFzc3dvcmQ6"); $self->next_input_to(\&process_authlogin_password); return 1; } sub process_authlogin_password { my ($self, $operation) = @_; $self->{AUTH}->{password} = decode_base64($operation); exec_auth_callback($self); return 1; } sub exec_auth_callback { my ($self) = @_; my $authok=0; my $ref = $self->{callback}->{AUTH}; if (ref $ref eq 'ARRAY' && ref $ref->[0] eq 'CODE') { my $code = $ref->[0]; $authok = &$code($self, $self->{AUTH}->{username}, $self->{AUTH}->{password}); } if ($authok) { $self->reply(235, "Authentification successful."); } else { $self->reply(535, "Authentification failed."); } } sub process { my ($self, $data) = @_; my ($operation, $param) = $data=~/^(.+?)\s(.*)$/ ? ($1, $2) : ($data, ''); $self->{AUTH}->{type} = $operation; map { $self->{AUTH}->{$_} = '' } ('username', 'password', 'challenge', 'ticket', ); if ($operation eq '*') { $self->reply(501, "Authentification aborted."); return (); } elsif ($operation eq 'PLAIN') { $param=decode_base64($param); my @plaindata = split /\0/, $param; unless (@plaindata > 2) { $self->reply(535, "Authentification failed."); return (); } else { $self->{AUTH}->{username} = $plaindata[@plaindata-2]; $self->{AUTH}->{password} = $plaindata[@plaindata-1]; exec_auth_callback($self); return (); } } elsif ($operation eq 'LOGIN') { $param=decode_base64($param); warn " ==> LOGIN ==> $param\n"; $self->reply(334, "VXNlcm5hbWU6"); $self->next_input_to(\&process_authlogin_username); return (); } else { $self->reply(504, "Unrecognized authentification type."); } return (); } =pod =head1 SEE ALSO Please, see L and L for more documentations. =head1 AUTHOR Sylvain Cresto Etost@softhome.netE =head1 BUGS Please send bug-reports to tost@softhome.net. =head1 LICENCE This library is free software; you can redistribute it and/or modify it under the terms of the GNU Lesser General Public License as published by the Free Software Foundation; either version 2.1 of the License, or (at your option) any later version. This library is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License for more details. You should have received a copy of the GNU Lesser General Public License along with this library; if not, write to the Free Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA =head1 COPYRIGHT Copyright (C) 2004 - Sylvain Cresto =cut 1;