2002-07-06 09:18:48 +02:00
|
|
|
package Qpsmtpd::Plugin;
|
|
|
|
use strict;
|
|
|
|
|
|
|
|
sub new {
|
|
|
|
my $proto = shift;
|
|
|
|
my $class = ref($proto) || $proto;
|
2002-07-08 04:30:11 +02:00
|
|
|
my %args = @_;
|
|
|
|
bless ({ _qp => $args{qpsmtpd} }, $class);
|
2002-07-06 09:18:48 +02:00
|
|
|
}
|
|
|
|
|
2002-07-08 04:30:11 +02:00
|
|
|
sub register_hook {
|
|
|
|
my ($plugin, $hook, $method) = @_;
|
|
|
|
# I can't quite decide if it's better to parse this code ref or if
|
|
|
|
# we should pass the plugin object and method name ... hmn.
|
2003-11-02 12:13:08 +01:00
|
|
|
$plugin->qp->_register_hook($hook, { code => sub { local $plugin->{_qp} = shift; $plugin->$method(@_) },
|
2002-09-24 12:56:35 +02:00
|
|
|
name => $plugin->plugin_name
|
|
|
|
}
|
|
|
|
);
|
2003-11-02 12:13:08 +01:00
|
|
|
delete $plugin->{_qp};
|
2002-07-08 04:30:11 +02:00
|
|
|
}
|
2002-07-06 09:18:48 +02:00
|
|
|
|
2002-07-08 04:30:11 +02:00
|
|
|
sub qp {
|
|
|
|
shift->{_qp};
|
|
|
|
}
|
2002-07-06 09:18:48 +02:00
|
|
|
|
2002-07-08 04:30:11 +02:00
|
|
|
sub log {
|
2002-09-08 12:00:02 +02:00
|
|
|
my $self = shift;
|
|
|
|
$self->qp->log(shift, $self->plugin_name . " plugin: " . shift, @_);
|
2002-07-06 09:18:48 +02:00
|
|
|
}
|
|
|
|
|
2002-07-08 04:30:11 +02:00
|
|
|
sub transaction {
|
|
|
|
# not sure if this will work in a non-forking or a threaded daemon
|
|
|
|
shift->qp->transaction;
|
|
|
|
}
|
2002-07-06 09:18:48 +02:00
|
|
|
|
|
|
|
1;
|