File: SSLLookup.pm

package info (click to toggle)
libapache-ssllookup-perl 2.00-04-4
  • links: PTS, VCS
  • area: main
  • in suites: bookworm, sid, trixie
  • size: 212 kB
  • sloc: perl: 209; ansic: 10; makefile: 9; sh: 5
file content (122 lines) | stat: -rwxr-xr-x 2,853 bytes parent folder | download | duplicates (4)
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
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
package Apache::SSLLookup;

use 5.008001;

use strict;

use DynaLoader ();

our @ISA = qw(DynaLoader);
our $VERSION = '2.00_04';

__PACKAGE__->bootstrap($VERSION);

1;

__END__

=head1 NAME

Apache::SSLLookup - hooks for various mod_ssl functions

=head1 SYNOPSIS

in httpd.conf:

  # pre-loading via PerlModule or startup.pl is REQUIRED!!!
  PerlModule Apache::SSLLookup

in any handler:

  sub handler {
    my $r = Apache::SSLLookup->new(shift);

    my $request_is_over_ssl = $r->is_https;

    my $value = $r->lookup_var('SSL_CLIENT_VERIFY');

    ...
  }

=head1 DESCRIPTION

Apache::SSLLookup is a glue layer between Perl handlers
and the mod_ssl public API.  under normal circumstances, you would
use C<$rE<gt>subprocess_env()> to glean information about mod_ssl.
for example,

  my $request_is_over_ssl = $r->subprocess_env('HTTPS');

however, this is only possible after mod_ssl runs its fixups -
that is, Perl handlers can only accurately check the
C<subprocess_env> table for mod_ssl information in the
PerlResponsePhase or later.

this module allows you to query mod_ssl directly via its public
C API at any point in the request cycle.  but without using C,
of course.

=head1 METHODS

there are only three methods you need to be concerned with.

=over 4

=item new()

to use this class you create an C<Apache::SSLLookup> object.
C<Apache::SSLLookup> is a subclass of C<Apache::RequestRec>
so you can simply call C<new()> and get on with your business.

  my $r = Apache::SSLLookup->new($r);

=item is_https()

returns true if mod_ssl considers the request to be under SSL.

  my $request_is_over_ssl = $r->is_https;

you can call this function any time during the request, specifically
before mod_ssl populates C<subprocess_env('HTTPS')> in the fixup
phase.

you must be using Apache 2.0.51 or greater for this method to
accurately reflect the SSL status of the request.

=item lookup_var()

returns the value of various mod_ssl environment variables.

  my $value = $r->lookup_var('SSL_CLIENT_VERIFY');

you can call this function any time during the request, specifically
before mod_ssl populates C<subprocess_env()> in the fixup phase.

=back

=head1 NOTES

this module is for Apache 2.0 exclusively.  it will not work with
Apache 1.3.

you MUST MUST MUST preload this module with PerlModule or from
a startup.pl.  what if you don't?  the short answer is that this
module will do nothing for you.  the long answer is that unless
you preload the module it will not be able to glean the optional
function definitions from mod_ssl.  I'm still trying to figure
out why not...

=head1 AUTHOR

Geoffrey Young E<lt>geoff@modperlcookbook.orgE<gt>

=head1 COPYRIGHT

Copyright (c) 2004, Geoffrey Young

All rights reserved.

This module is free software.  It may be used, redistributed
and/or modified under the same terms as Perl itself.

=cut