Mercurial > prosody-wiki
annotate mod_client_certs.wiki @ 337:da79793316ff
Since this only works starting with 0.9 remove autoloaded modules from modules_enabled.
author | florob@babelmonkeys.de |
---|---|
date | Sat, 06 Apr 2013 16:00:30 +0000 |
parents | 118f44d63e25 |
children |
rev | line source |
---|---|
283
bc0b13c53b57
Created wiki page through web user interface.
thijsalkemade@gmail.com
parents:
diff
changeset
|
1 #summary Client-side certificate management for Prosody |
bc0b13c53b57
Created wiki page through web user interface.
thijsalkemade@gmail.com
parents:
diff
changeset
|
2 #labels Stage-Alpha |
bc0b13c53b57
Created wiki page through web user interface.
thijsalkemade@gmail.com
parents:
diff
changeset
|
3 |
bc0b13c53b57
Created wiki page through web user interface.
thijsalkemade@gmail.com
parents:
diff
changeset
|
4 = Introduction = |
bc0b13c53b57
Created wiki page through web user interface.
thijsalkemade@gmail.com
parents:
diff
changeset
|
5 [http://xmpp.org/extensions/xep-0257.html XEP-0257] specifies a protocol for clients to store and manage client side certificates. When a client presents a stored client side certificate during the TLS handshake, it can log in without supplying a password (using SASL EXTERNAL). This makes it possible to have multiple devices accessing an account, without any of them needing to know the password, and makes it easier to revoke access for a single device. |
bc0b13c53b57
Created wiki page through web user interface.
thijsalkemade@gmail.com
parents:
diff
changeset
|
6 |
bc0b13c53b57
Created wiki page through web user interface.
thijsalkemade@gmail.com
parents:
diff
changeset
|
7 |
bc0b13c53b57
Created wiki page through web user interface.
thijsalkemade@gmail.com
parents:
diff
changeset
|
8 = Details = |
bc0b13c53b57
Created wiki page through web user interface.
thijsalkemade@gmail.com
parents:
diff
changeset
|
9 |
bc0b13c53b57
Created wiki page through web user interface.
thijsalkemade@gmail.com
parents:
diff
changeset
|
10 Each user can add their own certificates. These do not need to be signed by a trusted CA, yet they do need to be valid at the time of logging in and they should include an subjectAltName with otherName "id-on-xmppAddr" with the JID of the user. |
bc0b13c53b57
Created wiki page through web user interface.
thijsalkemade@gmail.com
parents:
diff
changeset
|
11 |
287
1a00ae04a358
Added an example of how to generate your client side certificate with a id-on-xmppAddr field, thanks to Zash for the cnf file.
thijsalkemade@gmail.com
parents:
283
diff
changeset
|
12 == Generating your certificate == |
1a00ae04a358
Added an example of how to generate your client side certificate with a id-on-xmppAddr field, thanks to Zash for the cnf file.
thijsalkemade@gmail.com
parents:
283
diff
changeset
|
13 |
1a00ae04a358
Added an example of how to generate your client side certificate with a id-on-xmppAddr field, thanks to Zash for the cnf file.
thijsalkemade@gmail.com
parents:
283
diff
changeset
|
14 # To generate your own certificate with a "id-on-xmppAddr" attribute using the command line {{{openssl}}} tool, first create a file called {{{client.cnf}}} with contents: |
1a00ae04a358
Added an example of how to generate your client side certificate with a id-on-xmppAddr field, thanks to Zash for the cnf file.
thijsalkemade@gmail.com
parents:
283
diff
changeset
|
15 {{{ |
1a00ae04a358
Added an example of how to generate your client side certificate with a id-on-xmppAddr field, thanks to Zash for the cnf file.
thijsalkemade@gmail.com
parents:
283
diff
changeset
|
16 [req] |
1a00ae04a358
Added an example of how to generate your client side certificate with a id-on-xmppAddr field, thanks to Zash for the cnf file.
thijsalkemade@gmail.com
parents:
283
diff
changeset
|
17 prompt = no |
1a00ae04a358
Added an example of how to generate your client side certificate with a id-on-xmppAddr field, thanks to Zash for the cnf file.
thijsalkemade@gmail.com
parents:
283
diff
changeset
|
18 x509_extensions = v3_extensions |
1a00ae04a358
Added an example of how to generate your client side certificate with a id-on-xmppAddr field, thanks to Zash for the cnf file.
thijsalkemade@gmail.com
parents:
283
diff
changeset
|
19 req_extensions = v3_extensions |
1a00ae04a358
Added an example of how to generate your client side certificate with a id-on-xmppAddr field, thanks to Zash for the cnf file.
thijsalkemade@gmail.com
parents:
283
diff
changeset
|
20 distinguished_name = distinguished_name |
1a00ae04a358
Added an example of how to generate your client side certificate with a id-on-xmppAddr field, thanks to Zash for the cnf file.
thijsalkemade@gmail.com
parents:
283
diff
changeset
|
21 |
1a00ae04a358
Added an example of how to generate your client side certificate with a id-on-xmppAddr field, thanks to Zash for the cnf file.
thijsalkemade@gmail.com
parents:
283
diff
changeset
|
22 [v3_extensions] |
1a00ae04a358
Added an example of how to generate your client side certificate with a id-on-xmppAddr field, thanks to Zash for the cnf file.
thijsalkemade@gmail.com
parents:
283
diff
changeset
|
23 extendedKeyUsage = clientAuth |
1a00ae04a358
Added an example of how to generate your client side certificate with a id-on-xmppAddr field, thanks to Zash for the cnf file.
thijsalkemade@gmail.com
parents:
283
diff
changeset
|
24 keyUsage = digitalSignature,keyEncipherment |
1a00ae04a358
Added an example of how to generate your client side certificate with a id-on-xmppAddr field, thanks to Zash for the cnf file.
thijsalkemade@gmail.com
parents:
283
diff
changeset
|
25 basicConstraints = CA:FALSE |
1a00ae04a358
Added an example of how to generate your client side certificate with a id-on-xmppAddr field, thanks to Zash for the cnf file.
thijsalkemade@gmail.com
parents:
283
diff
changeset
|
26 subjectAltName = @subject_alternative_name |
1a00ae04a358
Added an example of how to generate your client side certificate with a id-on-xmppAddr field, thanks to Zash for the cnf file.
thijsalkemade@gmail.com
parents:
283
diff
changeset
|
27 |
1a00ae04a358
Added an example of how to generate your client side certificate with a id-on-xmppAddr field, thanks to Zash for the cnf file.
thijsalkemade@gmail.com
parents:
283
diff
changeset
|
28 [subject_alternative_name] |
1a00ae04a358
Added an example of how to generate your client side certificate with a id-on-xmppAddr field, thanks to Zash for the cnf file.
thijsalkemade@gmail.com
parents:
283
diff
changeset
|
29 otherName.0 = 1.3.6.1.5.5.7.8.5;FORMAT:UTF8,UTF8:hamlet@shakespeare.lit |
1a00ae04a358
Added an example of how to generate your client side certificate with a id-on-xmppAddr field, thanks to Zash for the cnf file.
thijsalkemade@gmail.com
parents:
283
diff
changeset
|
30 |
1a00ae04a358
Added an example of how to generate your client side certificate with a id-on-xmppAddr field, thanks to Zash for the cnf file.
thijsalkemade@gmail.com
parents:
283
diff
changeset
|
31 [distinguished_name] |
1a00ae04a358
Added an example of how to generate your client side certificate with a id-on-xmppAddr field, thanks to Zash for the cnf file.
thijsalkemade@gmail.com
parents:
283
diff
changeset
|
32 commonName = Your Name |
1a00ae04a358
Added an example of how to generate your client side certificate with a id-on-xmppAddr field, thanks to Zash for the cnf file.
thijsalkemade@gmail.com
parents:
283
diff
changeset
|
33 emailAddress = hamlet@shakespeare.lit |
1a00ae04a358
Added an example of how to generate your client side certificate with a id-on-xmppAddr field, thanks to Zash for the cnf file.
thijsalkemade@gmail.com
parents:
283
diff
changeset
|
34 }}} |
1a00ae04a358
Added an example of how to generate your client side certificate with a id-on-xmppAddr field, thanks to Zash for the cnf file.
thijsalkemade@gmail.com
parents:
283
diff
changeset
|
35 # Replace the values for {{{otherName.0}}} and {{{commonName}}} and {{{emailAddress}}} with your own values. The JID in {{{otherName.0}}} can either be a full JID or a bare JID, in the former case, the client can only use the resource specified in the resource. There are many other fields you can add, however, for SASL EXTERNAL, they will have no meaning. You can add more JIDs as {{{otherName.1}}}, {{{otherName.2}}}, etc. |
1a00ae04a358
Added an example of how to generate your client side certificate with a id-on-xmppAddr field, thanks to Zash for the cnf file.
thijsalkemade@gmail.com
parents:
283
diff
changeset
|
36 # Create a private key (as an example, a 4096 bits RSA key): |
1a00ae04a358
Added an example of how to generate your client side certificate with a id-on-xmppAddr field, thanks to Zash for the cnf file.
thijsalkemade@gmail.com
parents:
283
diff
changeset
|
37 {{{ |
1a00ae04a358
Added an example of how to generate your client side certificate with a id-on-xmppAddr field, thanks to Zash for the cnf file.
thijsalkemade@gmail.com
parents:
283
diff
changeset
|
38 openssl genrsa -out client.key 4096 |
1a00ae04a358
Added an example of how to generate your client side certificate with a id-on-xmppAddr field, thanks to Zash for the cnf file.
thijsalkemade@gmail.com
parents:
283
diff
changeset
|
39 }}} |
1a00ae04a358
Added an example of how to generate your client side certificate with a id-on-xmppAddr field, thanks to Zash for the cnf file.
thijsalkemade@gmail.com
parents:
283
diff
changeset
|
40 # Create the certificate request: |
1a00ae04a358
Added an example of how to generate your client side certificate with a id-on-xmppAddr field, thanks to Zash for the cnf file.
thijsalkemade@gmail.com
parents:
283
diff
changeset
|
41 {{{ |
1a00ae04a358
Added an example of how to generate your client side certificate with a id-on-xmppAddr field, thanks to Zash for the cnf file.
thijsalkemade@gmail.com
parents:
283
diff
changeset
|
42 openssl req -key client.key -new -out client.req -config client.cnf -extensions v3_extensions |
1a00ae04a358
Added an example of how to generate your client side certificate with a id-on-xmppAddr field, thanks to Zash for the cnf file.
thijsalkemade@gmail.com
parents:
283
diff
changeset
|
43 }}} |
1a00ae04a358
Added an example of how to generate your client side certificate with a id-on-xmppAddr field, thanks to Zash for the cnf file.
thijsalkemade@gmail.com
parents:
283
diff
changeset
|
44 # Sign it yourself: |
1a00ae04a358
Added an example of how to generate your client side certificate with a id-on-xmppAddr field, thanks to Zash for the cnf file.
thijsalkemade@gmail.com
parents:
283
diff
changeset
|
45 {{{ |
1a00ae04a358
Added an example of how to generate your client side certificate with a id-on-xmppAddr field, thanks to Zash for the cnf file.
thijsalkemade@gmail.com
parents:
283
diff
changeset
|
46 openssl x509 -req -days 365 -in client.req -signkey client.key -out client.crt -extfile client.cnf -extensions v3_extensions |
1a00ae04a358
Added an example of how to generate your client side certificate with a id-on-xmppAddr field, thanks to Zash for the cnf file.
thijsalkemade@gmail.com
parents:
283
diff
changeset
|
47 }}} |
1a00ae04a358
Added an example of how to generate your client side certificate with a id-on-xmppAddr field, thanks to Zash for the cnf file.
thijsalkemade@gmail.com
parents:
283
diff
changeset
|
48 The 365 means the certificate will be valid for a year starting now. |
1a00ae04a358
Added an example of how to generate your client side certificate with a id-on-xmppAddr field, thanks to Zash for the cnf file.
thijsalkemade@gmail.com
parents:
283
diff
changeset
|
49 |
288
118f44d63e25
Explained what these steps actually generated.
thijsalkemade@gmail.com
parents:
287
diff
changeset
|
50 The {{{client.key}}} *must* be kept secret, and is only needed by clients connecting using this certificate. The {{{client.crt}}} file contains the certificate that should be sent to the server using XEP-0257, and is also needed by clients connecting to the server. The {{{client.req}}} file is not needed anymore. |
118f44d63e25
Explained what these steps actually generated.
thijsalkemade@gmail.com
parents:
287
diff
changeset
|
51 |
283
bc0b13c53b57
Created wiki page through web user interface.
thijsalkemade@gmail.com
parents:
diff
changeset
|
52 = Configuration = |
bc0b13c53b57
Created wiki page through web user interface.
thijsalkemade@gmail.com
parents:
diff
changeset
|
53 |
bc0b13c53b57
Created wiki page through web user interface.
thijsalkemade@gmail.com
parents:
diff
changeset
|
54 (None yet) |
bc0b13c53b57
Created wiki page through web user interface.
thijsalkemade@gmail.com
parents:
diff
changeset
|
55 |
bc0b13c53b57
Created wiki page through web user interface.
thijsalkemade@gmail.com
parents:
diff
changeset
|
56 = Compatibility = |
bc0b13c53b57
Created wiki page through web user interface.
thijsalkemade@gmail.com
parents:
diff
changeset
|
57 |
bc0b13c53b57
Created wiki page through web user interface.
thijsalkemade@gmail.com
parents:
diff
changeset
|
58 ||0.9||Works|| |
bc0b13c53b57
Created wiki page through web user interface.
thijsalkemade@gmail.com
parents:
diff
changeset
|
59 ||0.8||Untested. Probably doesn't.|| |
bc0b13c53b57
Created wiki page through web user interface.
thijsalkemade@gmail.com
parents:
diff
changeset
|
60 |
bc0b13c53b57
Created wiki page through web user interface.
thijsalkemade@gmail.com
parents:
diff
changeset
|
61 = Clients = |
bc0b13c53b57
Created wiki page through web user interface.
thijsalkemade@gmail.com
parents:
diff
changeset
|
62 |
bc0b13c53b57
Created wiki page through web user interface.
thijsalkemade@gmail.com
parents:
diff
changeset
|
63 (None?) |
bc0b13c53b57
Created wiki page through web user interface.
thijsalkemade@gmail.com
parents:
diff
changeset
|
64 |
bc0b13c53b57
Created wiki page through web user interface.
thijsalkemade@gmail.com
parents:
diff
changeset
|
65 = TODO = |
bc0b13c53b57
Created wiki page through web user interface.
thijsalkemade@gmail.com
parents:
diff
changeset
|
66 Possible options to add to the configuration: |
bc0b13c53b57
Created wiki page through web user interface.
thijsalkemade@gmail.com
parents:
diff
changeset
|
67 * Require certificates to be signed by a trusted CA. |
bc0b13c53b57
Created wiki page through web user interface.
thijsalkemade@gmail.com
parents:
diff
changeset
|
68 * Do not require a id-on-xmppAddr |
bc0b13c53b57
Created wiki page through web user interface.
thijsalkemade@gmail.com
parents:
diff
changeset
|
69 * Remove expired certs after a certain time |
bc0b13c53b57
Created wiki page through web user interface.
thijsalkemade@gmail.com
parents:
diff
changeset
|
70 * Limit the number of certificates per user |