about summary refs log tree commit diff
path: root/lib/jitterbug/Emailer.pm
blob: ab9bedb1b4468881ccd2817ab684074fa6dcba96 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
package jitterbug::Emailer;

use strict;
use warnings;
use Email::Stuff;
use JSON;

sub new {
    my $self = bless {} => shift;
    my ($conf,$task,$tap_output) = @_;
    # smelly
    $self->{'conf'} = $conf;
    $self->{'task'} = $task;
    $self->{'tap_output'} = $tap_output;

    return $self;
}

sub run {
    my $self       = shift;
    my $task       = $self->{'task'};
    my $buildconf  = $self->{'conf'}->{'jitterbug'}{'build_process'};
    my $project    = $task->project->name;
    my $tap_output = $self->{'tap_output'};
    my $sha1       = $task->commit->sha256;
    my $shortsha1  = substr($sha1, 0, 8);
    my $desc       = JSON::decode_json( $task->commit->content );
    my $email      = $desc->{'author'}{'email'};
    my $message    = $desc->{'message'};
    my $header     = $buildconf->{'on_failure_header'};
    my $footer     = $buildconf->{'on_failure_footer'};

    my $body = <<BODY;
$header

Commit Message:
$message

TAP Output:
$tap_output

$footer
BODY
    # Expand placeholders in our on_failure header and footer
    $body =~ s/%%PROJECT%%/$project/g;
    $body =~ s/%%SHA1%%/$sha1/g;

    my $stuff = Email::Stuff->from($buildconf->{'on_failure_from_email'})
                # bug in Email::Stuff brakes chaining if $email is empty
                ->to($email || " ")
                ->cc($buildconf->{'on_failure_cc_email'})
                ->text_body($body)
                ->subject(
                    $buildconf->{'on_failure_subject_prefix'} . "$project @ $shortsha1 $message"
                  );
                # Should we attach a build log for convenience?
                # ->attach(io('dead_bunbun_faked.gif')->all,
                #    filename => 'dead_bunbun_proof.gif')
    $self->{'last_email_sent'} = $stuff;

    $stuff->send;

    return $self;
}

1;