← Documentation Index

NAME

Mailmunge::Response - encapsulates response to send back to Milter.

ABSTRACT

Mailmunge::Response holds all of the information needed to reply to an SMTP connection request or SMTP command such as HELO, MAIL From: and RCPT To:

SYNOPSIS

use Mailmunge::Response;

sub filter_sender {
    my ($self, $ctx) = @_;
    # Everything's OK
    return Mailmunge::Response->new(status => 'CONTINUE');

    # Reject
    return Mailmunge::Response->new(status => 'REJECT',
                                    message => $ctx->sender . ' is unwelcome');

CLASS METHODS

Mailmunge::Response->new($key1 => $val1 [, $key2 => $val2...])

Creates a new Mailmunge::Response object. Arguments are a series of key => val pairs. Possible keys are:

status

The status to return. This is one of the following strings:

CONTINUE

Accept the SMTP command with a 2xx status code

TEMPFAIL

Tempfail the SMTP command with a 4xx status code

REJECT

Reject the SMTP command with a 5xx status code

DISCARD

Accept the SMTP command, but discard the message rather than delivering it

ACCEPT_AND_NO_MORE_FILTERING

Accept the SMTP command, and do no further filtering of the message.

code

A 3-digit SMTP reply code. If not supplied, an appropriate code is picked based on the value of status.

dsn

A 3-numbered SMTP DSN of the form "X.Y.Z". If not supplied, an appropriate DSN is picked based on the value of status.

message

A text message to include in the SMTP reply. If not supplied, an appropriate message is picked based on the value of status

delay

A delay in seconds; if non-zero, mailmunge will pause for this many seconds before replying to the MTA. This parameter should be used with caution; if used at all, the delay should be at most a few seconds.

Mailmunge::Response->CONTINUE(...)

Equivalent to Mailmunge::Response->new(status => 'CONTINUE', ...)

Mailmunge::Response->ACCEPT_AND_NO_MORE_FILTERING(...)

Equivalent to Mailmunge::Response->new(status => 'ACCEPT_AND_NO_MORE_FILTERING', ...)

Mailmunge::Response->DISCARD(...)

Equivalent to Mailmunge::Response->new(status => 'DISCARD', ...)

Mailmunge::Response->TEMPFAIL(...)

Equivalent to Mailmunge::Response->new(status => 'TEMPFAIL', ...)

Mailmunge::Response->REJECT(...)

Equivalent to Mailmunge::Response->new(status => 'REJECT', ...)

INSTANCE METHODS

code([$val])

Returns the code value. If an argument is supplied, the code is set to that value.

dsn([$val])

Returns the dsn value. If an argument is supplied, the dsn is set to that value.

delay([$val])

Returns the delay value. If an argument is supplied, the delay is set to that value.

message([$val])

Returns the message value. If an argument is supplied, the message is set to that value.

status([$val])

Returns the status value. If an argument is supplied, the status is set to that value. If you supply an invalid status, then this method croaks.

fix_code_dsn()

Fix up the code and dsn members so they make sense for the given status. For example, if status is TEMPFAIL, then code must be 4xx and dsn must be 4.m.n.

is_tempfail()

Returns true if status is TEMPFAIL; false otherwise.

is_discard()

Returns true if status is DISCARD; false otherwise.

is_reject()

Returns true if status is REJECT; false otherwise.

is_success()

Returns true if status is CONTINUE or ACCEPT_AND_NO_MORE_FILTERING; false otherwise.

is_success_or_discard()

Returns true if status is CONTINUE, DISCARD or ACCEPT_AND_NO_MORE_FILTERING; false otherwise.

AUTHOR

Dianne Skoll <dianne@skollsoft.com>

LICENSE

This code is licensed under the terms of the GNU General Public License, version 2.

SEE ALSO

Mailmunge::Filter, Mailmunge::Context, mailmunge, mailmunge-multiplexor

Copyright © 2025 Skoll Software Consulting