summaryrefslogtreecommitdiffstats
path: root/sentry.pl
blob: b5b9c3f312f38e642cb015592faa4219b216600d (plain)
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
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
#!/usr/bin/perl -w

# This Source Code Form is subject to the terms of the Mozilla Public
# License, v. 2.0. If a copy of the MPL was not distributed with this
# file, You can obtain one at http://mozilla.org/MPL/2.0/.
#
# This Source Code Form is "Incompatible With Secondary Licenses", as
# defined by the Mozilla Public License, v. 2.0.

#
# report errors to sentry
# expects a filename with a Data::Dumper serialised parameters
# called by Bugzilla::Sentry
#

use strict;
use warnings;

use FindBin qw($Bin);
use lib $Bin;
use lib "$Bin/lib";

use Bugzilla;
use Bugzilla::Constants;
use Bugzilla::RNG qw(irand);
use Fcntl qw(:flock);
use File::Slurp;
use HTTP::Request::Common;
use JSON ();
use LWP::UserAgent;
use POSIX qw(setsid nice);
use Safe;
use URI;

Bugzilla->usage_mode(USAGE_MODE_CMDLINE);
nice(19);

# detach
open(STDIN, '</dev/null');
open(STDOUT, '>/dev/null');
open(STDERR, '>/dev/null');
setsid();

# grab sentry server url
my $sentry_uri = Bugzilla->params->{sentry_uri} || '';
exit(1) unless $sentry_uri;

# read data dump
exit(1) unless my $filename = shift;
my $dump = read_file($filename);
unlink($filename);

# deserialise
my $cpt = new Safe;
$cpt->reval($dump) || exit(1);
my $data = ${$cpt->varglob('VAR1')};

# split the sentry uri
my $uri = URI->new($sentry_uri);
my ($public_key, $secret_key) = split(/:/, $uri->userinfo);
$uri->userinfo(undef);
my $project_id = $uri->path;
$project_id =~ s/^\///;
$uri->path("/api/$project_id/store/");

# build the message
my $message = JSON->new->utf8(1)->pretty(0)->allow_nonref(1)->encode($data);
my %header = (
    'X-Sentry-Auth' => sprintf(
        "Sentry sentry_version=%s, sentry_timestamp=%s, sentry_key=%s, sentry_client=%s, sentry_secret=%s",
        '2.0',
        (time),
        $public_key,
        'bugzilla/4.2',
        $secret_key,
    ),
    'Content-Type' => 'application/json'
);

# ensure we send warnings one at a time per webhead
flock(DATA, LOCK_EX);

# and post to sentry
my $request = POST $uri->canonical, %header, Content => $message;
my $response = LWP::UserAgent->new->request($request);

__DATA__
this exists so the flock() code works.
do not remove this data section.