summaryrefslogtreecommitdiffstats
path: root/debian/perl-framework/t/htdocs/modules/cgi/ocsp.pl.PL
blob: efdbe8b965fdd20159007b137bc668f98de370f1 (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
use File::Temp qw/:POSIX/;

my $caroot = $ENV{SSL_CA_ROOT};

if (! -d $caroot) {
    print <<EOT
Status: 500 Internal Server Error
Content-Type: text/plain

Cannot find CA root at "$ENV{SSL_CA_ROOT}"
EOT
    ;
    print STDERR "SSL_CA_ROOT env var not set or can't find CA root.\n";
    exit(1);
}

chdir($caroot);

my $filein = tmpnam();
my $fileout = tmpnam();

# Enable slurp mode (read all lines at once)
local $/;

# Copy STDIN to $filein, which will be used as input for openssl
open(IN, '>', "$filein") or die "Could not open file '$filein' for write: $!";
binmode IN;
print IN <STDIN>;
close(IN);

my $cmd = 'openssl ocsp -CA certs/ca.crt'.
    ' -index index.txt'.
    ' -rsigner certs/server.crt'.
    ' -rkey keys/server.pem'.
    ' -reqin ' . $filein .
    ' -respout ' . $fileout;
system($cmd);

# Check system result
my $err = '';
if ($? == -1) {
    my $err = "failed to execute '$cmd': $!\n";
}
elsif ($? & 127) {
    my $err = sprintf("child '$cmd' died with signal %d, %s coredump\n",
        ($? & 127),  ($? & 128) ? 'with' : 'without');
}
else {
    my $rc = $? >> 8;
    my $err = "child '$cmd' exited with value $rc\n" if $rc;
}

unlink($filein);

if ($err ne '') {
    print <<EOT
Status: 500 Internal Server Error
Content-Type: text/plain

$err
EOT
    ;
    print STDERR $err;
    exit(1);
}

print <<EOT
Content-Type: application/ocsp-response

EOT
;

# Copy openssl result from $fileout to STDOUT
open(OUT, '<', "$fileout") or die "Could not open file '$fileout' for read: $!";
binmode OUT;
print <OUT>;
close(OUT);
unlink($fileout);