1Authen::ModAuthPubTkt(3U)ser Contributed Perl DocumentatiAounthen::ModAuthPubTkt(3)
2
3
4
6 Authen::ModAuthPubTkt - Generate Tickets (Signed HTTP Cookies) for
7 mod_auth_pubtkt protected websites.
8
10 version 0.1.1
11
13 On the command-line, generate the public + private keys: (More details
14 available at <https://neon1.net/mod_auth_pubtkt/install.html>)
15
16 $ openssl genrsa -out key.priv.pem 1024
17 $ openssl rsa -in key.priv.pem -out key.pub.pem -pubout
18
19 Then in your perl script (which is probably the your custom login
20 website), use the following code to issue tickets:
21
22 use Authen::ModAuthPubTkt;
23
24 my $ticket = pubtkt_generate(
25 privatekey => "key.priv.pem",
26 keytype => "rsa",
27 clientip => undef, # or a valid IP address
28 userid => "102", # or any ID that makes sense to your application, e.g. email
29 validuntil => time() + 86400, # valid for one day
30 graceperiod=> 3600, # grace period of an hour
31 tokens => undef, # comma separated string of tokens.
32 userdata => undef # any application specific data to pass.
33 );
34
35 ## $ticket string will look something like:
36 ## "uid=102;validuntil=1337899939;graceperiod=1337896339;tokens=;udata=;sig=h5qR" \
37 ## "yZZDl8PfW8wNxPYkcOMlAxtWuEyU5bNAwEFT9lztN3I7V13SaGOHl+U6wB+aMkvvLQiaAfD2xF/Hl" \
38 ## "+QmLDEvpywp98+5nRS+GeihXTvEMRaA4YVyxb4NnZujCZgX8IBhP6XBlw3s7180jxE9I8DoDV8bDV" \
39 ## "k/2em7yMEzLns="
40
41 To verify a ticket, use the following code:
42
43 my $ok = pubtkt_verify (
44 publickey => "key.pub.pem",
45 keytype => "rsa",
46 ticket => $ticket
47 );
48 die "Ticket verification failed.\n" if not $ok;
49
50 To extract items from a ticket, use the following code:
51
52 my %items = pubtkt_parse($ticket);
53
54 ## %items will be something like:
55 ## {
56 ## 'uid' => 102,
57 ## 'validuntil' => 1337899939,
58 ## 'graceperiod => 1337896339,
59 ## 'tokens' => "",
60 ## 'udata' => "",
61 ## 'sig' => 'h5qRyZZDl8PfW8wNxPYkcOMlAxtWuEyU5bNAwEFT9lztN3 (....)'
62 ## }
63
64 Also, a command-line utility ("mod_auth_pubtkt.pl") will be installed,
65 and can be used to generate/verify keys:
66
67 $ mod_auth_pubtkt.pl --generate --private-key key.priv.pem --rsa
68 $ mod_auth_pubtkt.pl --verify --public-key key.pub.pem --rsa
69 $ mod_autH_pubtkt.pl --help
70
72 This module generates and verify a mod_auth_pubtkt-compatible ticket
73 string, which should be used as a cookie with the rest of the
74 mod_auth_pubtkt ( <https://neon1.net/mod_auth_pubtkt/> ) system.
75
76 Common scenario:
77
78 1. On the login server side, write perl code to authenticate users
79 (using Apache's authenetication, LDAP, DB, etc.).
80 2. Once the user is authenticated, call "pubtkt_generate" to generate a
81 ticket, and send it back to the user as a cookie.
82 3. Redirect the user back to the server he/she came from.
83
85 A working (but minimal) perl login example is available at
86 <https://github.com/manuelkasper/mod_auth_pubtkt/blob/master/perl-login/minimal_cgi/login.pl>
87
89 pubtkt_generate
90 Generates a signed ticket.
91
92 If successful, returns a signed ticket string (to be sent back to the
93 user as a cookie).
94
95 On any failure (bad key, failure to run "openssl", etc.) returns
96 "undef".
97
98 Accepts a hash of parameters:
99
100 privatekey
101 String containing the private key filename (full path). The key can
102 be either DSA or RSA key (see keytype).
103
104 keytype
105 either "rsa" or "dsa" - depending on how you created the
106 private/public key files.
107
108 userid
109 String containing the user ID. No specific format is enforced: can
110 by a number, a string, an email address, etc. It will be encoded as
111 "uid=XXXX" in the signed ticket.
112
113 validuntil
114 Numeric value, containing the validity period, in seconds since
115 epoch (use time() function).
116
117 graceperiod
118 Optional. Numeric value. If given, will be added to the signed
119 ticket string.
120
121 clientip
122 Optional. A string with an IP address. If given. will be added to
123 the signed ticket string.
124
125 token
126 Optional. Any textual string. If given. will be added to the signed
127 ticket string.
128
129 userdata
130 Optional. Any textual string. If given. will be added to the signed
131 ticket string.
132
133 pubtkt_verify
134 Verifies a signed ticket string.
135
136 If successful (i.e. the ticket's signature is valid), returns TRUE
137 (=1).
138
139 On any failure (bad key, failure to run "openssl", etc.) returns
140 "undef".
141
142 NOTE: This function checks ONLY THE SIGNATURE, based on the public key
143 file. It is the caller's resposibility to check the expiration date.
144 That is: The function will return TRUE if the ticket is properly
145 signed, but possibly expired.
146
147 Accepts a hash of parameters:
148
149 publickey
150 String containing the public key filename (full path). The key can
151 be either DSA or RSA key (see keytype).
152
153 keytype
154 either "rsa" or "dsa" - depending on how you created the
155 private/public key files.
156
157 ticket
158 The string of the ticket (such as returned by "pubtkt_generate").
159
160 pubtkt_parse($ticket)
161 Utility function to parse a ticket string into a Perl hash.
162
163 NOTE: No validation is performed. The given ticket might be expired, or
164 even forged.
165
167 openssl must be installed (and available on the $PATH).
168
169 IPC::Run3 is required to run the openssl executables.
170
172 Probably many.
173
175 Use Perl's Crypt::OpenSSL::RSA and Crypt::OpenSSL::DSA instead of the
176 running "openssl" executable.
177
178 Don't assume "openssl" binary is on the $PATH.
179
180 Refactor into OO interface.
181
183 Copyright (C) 2012,2022 A. Gordon ( assafgordon at gmail dot com ).
184 All rights reserved. This module is free software; you can redistribute
185 it and/or modify it under the same terms as Perl itself.
186
188 A. Gordon, heavily based on the PHP code from mod_auth_pubtkt.
189
191 ModAuthPubTkt main website: <https://neon1.net/mod_auth_pubtkt/>
192
193 ModAuthPubTkt github repository:
194 <https://github.com/manuelkasper/mod_auth_pubtkt>
195
196 This module's github repository:
197 <https://github.com/agordon/Authen-ModAuthPubTkt>
198
199 Examples in the "./eg" directory:
200
201 generate_rsa_keys.sh
202 Generates a pair of RSA key files.
203
204 generate_dsa_keys.sh
205 Generates a pair of DSA key files.
206
207 mod_auth_pubtkt.pl
208 A command-line utility to generate/verify tickets.
209
210
211
212perl v5.36.0 2023-01-20 Authen::ModAuthPubTkt(3)