NAME
Perlbug::Email - Email interface to perlbug database.
DESCRIPTION
Email interface to perlbug database.
SYNOPSIS
use Perlbug::Email;
use Mail::Internet;
my $o_mail = Mail::Internet->new(*STDIN);
my $o_perlbug = Perlbug::Email->new($o_mail);
my $call = $o_perlbug->switch;
my $result = $o_perlbug->$call($o_mail);
print $result; # =1 (hopefully :-)
METHODS
- new
-
Create new Perlbug::Email object:
my $pb = Perlbug::Email->new($o_mail); # Mail::Internet
- _original_mail
-
Maintain original
- original
-
Returns original field/s from header
- mailing
-
Switch mailing on/off, also sets email->mailer to 'test' if off
- splice
-
Returns the original mail spliced up into useful bits, set from parse_mail or switch, or given as arg.
my ($o_hdr, $header, $body) = $self->splice; # or splice($o_mail);
- parse_mail
-
Given a mail (Mail::Internet) object, parses it into command hash, also checks the header for X-Perlbug loop and the address of the sender via check_user.
my $h_commands = $pb->parse_mail($mail);
- from
-
Sort out the wheat from the chaff, use the first valid ck822 address:
my $from = $self->from($replyto, $from, @alternatives);
- check_header
-
Checks (incoming) email header against our X-Perlbug flags, also slurps up the Message-Id for future reference.
my $i_ok = $o_perlbug->check_header($o_hdr); # or undef
- check_user
-
Checks the address given (From usually) against the tm_users table, sets user or admin access priviliges via the switches mechanism accordingly.
Returns admin name
my $admin = $pb->check_user($mail->('From')); # -> user_id || blank
- return_info
-
Takes data ($a_stuff), which may be a ref to the result array, and mails it to the From or Reply-To address, Cc:-ing it to any address given by the
-e
flag.my $i_ok = $pb->return_info($o_mail, $a_stuff);
- _mail
-
Get and set the incoming mail object (Mail::Internet)
Returned (used) via splice()
- doh
-
Wraps help message
- doH
-
Returns more detailed help.
- get_header
-
Get new perlbug Mail::Header, filled with appropriate values, based on given header.
my $o_hdr = $o_email->get_header(); # completely clean my $o_hdr = $o_email->get_header($o_old_header); # plain (coerced as from us) my $o_hdr = $o_email->get_header($o_old_header, 'remap'); # maintain headers (nearly transparent)
- default
-
Operates on given tag, from bugdb@perl.org: we're sending this out from here.
Affects Message-Id(new), From(bugdb), Reply-To(maintainer) lines
Keeps Subject|To|Cc for later modification?
Filters anything else
my @lines = $self->default($tag, @lines);
- remap
-
Operating on a given tag, remaps (To|Cc) -> forwarding address, removes duplicates.
Attempt to remain moderately invisible by maintaining all other original headers.
my @lines = $self->remap($tag, @lines);
- send_mail
-
Send a mail with protection.
my $ok = $email->send_mail($o_hdr, $body);
- tester
-
If test mail, turn header to maintainer and return header data for insertion
- defense
-
Set mail defaults for _all_ mail emanating from here, calls clean_header(), trim_to().
my $o_hdr = $self->defense($o_hdr);
- clean_header
-
Clean header of non-compliant 822 address lines using Mail::Address::parse()
my $o_hdr = $o_mail->clean_header($o_hdr);
- trim_to
-
Takes the header and returns it without any dodgy to, or cc addresses (or undef):
my $o_hdr = $o_obj->trim_to($o_hdr);
- get_forward
-
Operating on a single (or blank) address, returns a list of forwarding addresses.
my $to = $perlbug->get_forward('perlbug@perl.org'); # perl5-porters@perl.org my $to = $perlbug->get_forward('perl-win32-porters@perl.org'); # perl-win32-porters@perl.org my $to = $perlbug->get_forward(); # perl5-porters@perl.org my @to = $perlbug->get_forward(); # perl5-porters@perl.org perl-win32-porters@perl.org etc...
- switch
-
Returns appropriate method name to call to handle this mail.
This enables you to bypass the suggested method with your own call (be it on your own head :-):
my $call = $pb->switch(Mail::Internet->new(\$STDIN);
- do_new
-
Deal with a new bug
- scan
-
Scan for perl relevant data putting found or default switches in $h_data. Looking for both category=docs and '\brunning\s*under\ssome\s*perl' style markers.
my $h_data = $o_mail->scan($body); my $res = $o_mail->bug_set($tid, $h_data);
- do_reply
-
Deal with a reply to an existing bug - no acknowledgement
- header2admin
-
Given a Mail::Header object attempts to return a valid create admin command
my $data = $o_email->header2admin($o_hdr);
- doe
-
Email address to 'Cc:' to
-e me.too@some.where.org
- dov
-
Volunteer proposed bug modifications
propose_close_<bugid>@bugs.perl.org my $i_ok = $o_obj->dov('tid close patch');
- doV
-
Volunteer a new administrator
register_MYUSERID@bugs.perl.org
- doa
-
admin a bug
close_<bugid>_patch_macos@bugs.perl.org
- doP
-
Recieve a patch
patch_<version>*_<changeid>*_<bugid>*@bugs.perl.org
- doT
-
Recieve a test
test_<bugid>@bugs.perl.org
- doN
-
Recieve a note
note_<bugid>*@bugs.perl.org
- dow
-
Forward (weiterleiten) mail onto all active administrators
admin(s)@bugs.perl.org my $i_ok = $o_obj->dow($body);
- do_quiet
-
Drop out quietly, no entry in database, silent dump into black hole.
- do_bounce
-
Deal with a bounced mail
- assign_bugs
-
Assign to this admin, so many, of these unclaimed bugs.
N.B. the claimed bugs are shifted off the end of the referenced array!
$ok = $pb->assign_bugs($admin, 5, \@unclaimed);
- check_mail
-
Check headers against various given parameters, attempts to read all required lines/data.
# call # Scope Regex my $o_new = $o_mail->process_header($o_hdr, $context); # Mail::Send object (ready to go) my @should = $o_hdr->get('X-Perlbug-Match'); # Subject: \-h\s\-o my @shouldnt = $o_hdr->get('X-Perlbug-Match-Non'); # To: \s*perlbug\@perl\.com my @failures = $o_hdr->get('X-Perlbug-Match-Bad'); # To: \s*perlbug\@perl\.org ($i_ok, $feedback) = $o_bugmail->check_mail($o_new, $body, \@should, \@shouldnt, \@shouldfail); warn "Mail header check failure: ($feedback)\n" unless $i_ok == 1;
- doD
-
Mail me a copy of the latest database dump
- scan_header
-
Scan a typical *@bugs.perl.org header
my ($cmd, $body) = $o_mail->scan_header($o_hdr, $body);
To: line can be any of:
close_<bugid>_@bugs.perl.org = bug admin request register@bugs.perl.org = admin registration request admins@bugs.perl.org = admin mail forward
Subject: line may look like:
-h -o -H -d2 -l -A close 20000721.002 lib -r patch -e some@one.net
- admin_of_bug
-
Checks given bugid and administrator against tm_claimants, tm_bugs::sourceaddr, tm_cc.
Now you can admin a bug if you're on the source address, or the Cc: list.
- administration_failure
-
Deal with a failed administration attempt
my $i_ok = $self->administration_failure($tid, $user, $commands);
- in_master_list
-
Checks given address against ok-to-be-administrator email address list
my $i_ok = $o_obj->in_master_list($address);
AUTHOR
Richard Foley perlbug@rfi.net 1999 2000