Net::Server::POP3 - The Server Side of the POP3 Protocol for email
  use Net::Server::POP3;
  my $server = Net::Server::POP3->new(
    severopts    => \%options,
    authenticate => \&auth,
    list         => \&list,
    retrieve     => \&retrieve,
    delete       => \&delete,
    size         => \&size,
    welcome      => "Welcome to my mail server.",
  );
  $server->startserver();
This is alpha code. That means it needs work and doesn't yet implement everything it should. Don't use it unless you don't mind fixing up the parts that you find need fixing up. Lots of parts still need fixing. You have been warned.
The code as it stands now works, for some definition of ``works''. With the included simpletest.pl script I have successfully served test messages that I have retrieved with Mozilla Mail/News. However, much work remains to be done.
It is strongly recommended to run with Taint checking enabled.
Stub documentation for this module was created by ExtUtils::ModuleMaker. It looks like the author of the extension was negligent enough to leave the stub at least partly unedited.
This module is designed to be the server/daemon itself and so to handle all of the communication to/from the client(s). The actual details of obtaining, storing, and keeping track of messages are left to other modules or to the user's own code. (See the sample script simpletest.pl for an example.)
The main method is startserver(), which starts the server.  The
following named arguments may be passed either to new() or to
startserver().  All callbacks should be passed as coderefs.
If you pass an argument to new() and then pass an argument of
the same name to startserver(), the one passed to startserver()
overrides the one passed to new().  stopserver() has not been
implemented yet and so neither has restartserver().
The serveropts hashref is optional. You only need to supply it if you have optional arguments to pass through to Net::Server.
The connect callback is optional; you only need to supply it if you have setup to do when a client connects.
The disconnect callback is optional; you only need to supply it if you have cleanup to do when a client disconnects.
The authenticate callback is technically optional, but you need to supply it if you want any users to be able to log in using the USER and PASS commands.
The apop callback is only needed if you want to supply APOP authentication.
This is not implemented yet, but I plan to implement it.
The list callback is required.
The retrieve callback is required.
This callback is technically optional, but you'll need to supply one if you want to know when to remove messages from the user's maildrop.
If the delay may vary per user, logindelay should be a callback routine. If the callback is passed no arguments, it is being asked for the maximum delay for all users; if it is passed an argument, this will be a valid, authenticated username and the callback should return the delay for that particular user. Either way, the return value should be a number of seconds. Again, this does NOT enforce the delay; it only causes it to be announced in the capabilities list. (Some clients may not even ask for the capabilities list, if they do not implement POP3 Extensions (RFC 2449).)
The default is not to announce any particular delay.
This does NOT actually delete anything; it just announces the timeframe to the client. Clients that do not support POP3 Extensions will not get this announcement. 'NEVER' means the server will never expire messages; 0 means that expiration is immanent and the client should not count on leaving messages on the server. 0 should be announced for example if the mere act of retrieving a message may cause it to expire shortly afterward.
If the message expiration time may vary by user, expiretime should be a callback routine. If the callback is passed no arguments, it is being asked for the minimum expiration time for all users, which it should return (as a whole number of days; 0 is acceptable); if it is passed an argument, this will be a valid, authenticated username and the callback should return the expiration time for this particular user, either as a whole number of days or the string 'NEVER'.
The default is not to announce an expiration time.
Some things are just plain not implemented yet. The UIDL implementation uses the message-id as the unique id, rather than calculating a hash as suggested by RFC 1939. In practice, this seems to be what my ISP's mail server does (it calls itself InterMail), which has worked with every client I've thrown at it, so it should be mostly okay, but it's not strictly up to spec I think and may be changed in a later version. There may be other bugs as well; this is very alpha stuff. Significant changes may be made to the code interface before release quality is reached, so if you use this module now you may have to change your code when you upgrade. Caveat user.
Use the source, Luke. You can also contact the author with questions, but I cannot guarantee that I will be able to answer all of them in a satisfactory fashion. The code is supplied on an as-is basis with no warranty.
        Jonadab the Unsightly One (Nathan Eady)
        jonadab@bright.net
        http://www.bright.net/~jonadab/
This program is free software licensed under the terms of...
        The BSD License
The full text of the license can be found in the LICENSE file included with this module.
perl(1) Net::Server http://search.cpan.org/search?query=Net::Server Mail::POP3Client http://search.cpan.org/search?query=Mail::POP3Client The simpletest.pl script included in the scripts directory in this distribution.
Net::Server Mail::POP3Client simpletest.pl
 Usage     : How to use this function/method
 Purpose   : What it does
 Returns   : What it returns
 Argument  : What it wants to know
 Throws    : Exceptions and other anomolies
 Comments  : This is a sample subroutine header.
           : It is polite to include more pod and fewer comments.
See Also :