NAME Mail::Milter::Authentication - A Perl Mail Authentication Milter VERSION version 3.20241024 SYNOPSIS Subclass of Net::Server::PreFork for bringing up the main server process for authentication_milter. This class handles the server aspects of Authentication Milter. For individual Protocol handling please see the Mail::Milter::Authentication::Protocol::* classes For request handling please see Mail::Milter::Authentication::Handler Please see Net::Server docs for more detail of the server code. Please see the output of 'authentication_milter --help' for usage help. DESCRIPTION A Perl Implementation of email authentication standards rolled up into a single easy to use milter. METHODS preload_modules( $from, $matching ) Preload (pre-fork) lazy loading modules. Takes a Package Name and a Base module, and loads all modules which match. write_to_log_hook() Hook which runs to write logs idle_loop_hook() Hook which runs in the parent periodically. pre_loop_hook() Hook which runs in the parent before looping. run_n_children_hook() Hook which runs in parent before it forks children. child_init_hook() Hook which runs after forking, sets up per process items. child_finish_hook() Hook which runs when the child is about to finish. pre_server_close_hook() Hook which runs before the server closes. dequeue() Call the dequeue handlers get_client_proto() Get the protocol of the connecting client. get_client_port() Get the port of the connecting client. get_client_host() Get the host of the connecting client. get_client_path() Get the path of the connecting client. get_client_details() Get the details of the connecting client. process_request() Hook which runs for each request, passes control to metrics handler or process_main as appropriate. process_main() Method which runs for each request, sets up per request items and processes the request. send_exception_email() Send an email to the administrator with details of a problem. fatal($error) Log a fatal error and die in child fatal_global($error) Log a fatal error and die in child and parent setup_handlers() Setup the Handler objects. load_handler( $name ) Load the $name Handler module setup_handler( $name ) Setup the $name Handler object destroy_handler( $name ) Remove the $name Handler register_callback( $name, $callback ) Register the specified callback sort_all_callbacks() Sort the callbacks into the order in which they must be called sort_callbacks( $callback ) Sort the callbacks for the $callback callback into the right order destroy_objects() Remove references to all objects get_queue_id() Return the queue ID (for logging) if possible. enable_extra_debugging() Turn on extra debugging mode, will cause child to exit on close. extra_debugging( $line ) Cause $line to be written to log if extra debugging mode is enabled. logerror( $line ) Log to the error log. loginfo( $line ) Log to the info log. logdebug( $line ) Log to the debug log. FUNCTIONS get_installed_handlers() Return an array ref of installed handler modules. send_panic_email() Send an email to the administrator with details of a problem. Called from the parent process if the server exits. get_valid_pid($pid_file) Given a pid file, check for a valid process ID and return if valid. find_process() Search the process table for an authentication_milter parent process control($command) Run a daemon command. Command can be one of start/restart/stop/status. start($hashref) Start the server. This method does not return. $hashref = { 'pid_file' => 'The pid file to use', # 'daemon' => 1/0, # Daemonize process? } AUTHOR Marc Bradshaw <marc@marcbradshaw.net> COPYRIGHT AND LICENSE This software is copyright (c) 2020 by Marc Bradshaw. This is free software; you can redistribute it and/or modify it under the same terms as the Perl 5 programming language system itself.