CACreateCert: support --request and --utf8
[ezcert.git] / Examples.html
blobf6168e7576e49bfda6abd93ce29780fb59f2dc88
1 <!DOCTYPE html>
2 <!--
3 CACreateCert Examples Page
4 Copyright (C) 2013 Kyle J. McKay (mackyle a_t g_ma_il d_o_t _co_m)
5 All rights reserved
7 This file is free software: you can redistribute it and/or modify
8 it under the terms of the GNU Affero General Public License as published by
9 the Free Software Foundation, either version 3 of the License, or
10 (at your option) any later version.
12 This file is distributed in the hope that it will be useful,
13 but WITHOUT ANY WARRANTY; without even the implied warranty of
14 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15 GNU Affero General Public License for more details.
17 You should have received a copy of the GNU Affero General Public License
18 along with this file. If not, see <http://www.gnu.org/licenses/>.
19 -->
20 <html xmlns="http://www.w3.org/1999/xhtml">
21 <head>
22 <meta charset='ISO-8859-1' />
23 <meta http-equiv="Content-Type" content="text/html; charset=ISO-8859-1" />
24 <title>CACreateCert Examples</title>
25 <style type="text/css">
27 body {
28 margin-top: 1.0em;
29 /* background-color: #f8f8f8; */
30 background-color: white;
31 font-family: Times, "Times New Roman", serif;
32 color: black;
34 #container {
35 margin: 0 auto;
36 background-color: white;
37 max-width: 90ex;
38 position: relative;
40 @media screen {
41 .last { margin-bottom: -1em; }
42 .aftermargin {
43 position: absolute;
44 height: 100%;
45 width: 1px;
48 h1 { font-size: 3.0em; color: black; margin-bottom: 0.1em; }
49 h1 .small { font-size: 0.4em; }
50 h1 a { text-decoration: none; }
51 h2 { font-size: 1.5em; color: black; }
52 h3 { color: black; }
53 p.note:before, p.important:before, h1, h2, h3, th, .cert { font-family: Helvetica, Arial, FreeSans, sans-serif; font-weight: normal; }
54 a { color: black; }
55 .description { font-size: 1.2em; margin-bottom: 2em; margin-top: 2em; font-style: italic; }
56 pre { font-family: Menlo, Monaco, Consolas, Courier, "Courier New", monospace; }
57 pre { font-size: 75%;}
58 pre { padding: 0.5em 1ex; border: thin dotted silver; }
59 hr { border: 0; width: 80%; border-bottom: thin solid silver; }
60 p { text-align: justify; }
61 p.left { text-align: left; }
62 .inset { margin-left: 1ex; margin-right: 1ex; }
63 .indent { margin-left: 3ex; margin-right: 3ex; }
64 p.note:before { content: "Note: "; /* font-style: italic; */ }
65 p.note { display:block; border: thin dashed silver; padding: 0.5ex 0.5ex 0.5ex 6.5ex; text-indent: -6ex; }
66 p.important:before { content: "Important: "; }
67 .nobreak { white-space: nowrap; }
68 .left { text-align: left; }
69 .center { text-align: center; }
71 :link, :visited {
72 text-decoration: none !important;
73 border-bottom: 1px dotted !important;
75 :link:hover, :visited:hover {
76 border-bottom: 1px solid !important;
78 @media print {
79 :link, :visited {
80 border-bottom: 0 !important;
81 color: inherit !important;
85 </style>
86 </head>
87 <body><div id="container">
89 <h1 class="center">CACreateCert Examples</h1>
91 <h2>Foreword</h2>
92 <p>The examples here may be a bit weak on comments. They are intended to show how to create a reasonable certificate chain using the <tt>CACreateCert</tt> tool. For more details on the options available use <tt>CACreateCert -h</tt> to see the full utility documentation.</p>
94 <h2>The Desired Certificate Chain</h2>
95 <p>The examples below show how to use <tt>CACreateCert</tt> to create a certificate chain that looks like this:</p>
96 <img src="" />
97 <p>The idea is that the root certificate is only used to sign other, in-house certificates for each class of certificate. In this example, the root certificate will sign both the server authority and client authority certificates (if email certificates were to issued, there&#x2019;d also be an email authority certificate and if code signing certificates were to be issued there&#x2019;d also be a code signing authority certificate and so on for any other certificate classes, but in the interest of keeping the example simpler those have been omitted).</p>
99 <p>These three certificates (root, server authority and client authority) along with their private keys would be kept in-house by the certificate authority.</p>
101 <p>When a new https server certificate is needed for an external entity, the in-house server authority signs and issues it, but only the external entity would have the private key for it. Similarly when a new client authority certificate (that can sign client certificates) is needed for an external entity, the in-house client authority signs and issues it.</p>
103 <p>The examples below will keep all of the created private keys and certificates together but in reality things will not work that way.</p>
105 <h2>The Examples</h2>
107 <p>The example code below assumes that <tt>CACreateCert</tt> is in the <tt>PATH</tt> and that all private keys and certificates are to be created in the current directory unless otherwise specified. All command-line commands shown assume a POSIX shell.</p>
109 <p>The OpenSSL command suite is required for these examples and should be available as the <tt>openssl</tt> command in the <tt>PATH</tt>.</p>
111 <h3>Create the Root Authority</h3>
113 <pre>
114 # Create a 2048 bit private RSA key
115 openssl genrsa -f4 2048 > root_key.pem
116 CACreateCert --root --key root_key.pem "Acme Certificate Co." > root_crt.pem
117 </pre>
118 <p class="note">The <tt>-f4</tt> option to <tt>genrsa</tt> selects the public exponent of 65537 (instead of 3) and should be the default with most versions of OpenSSL.</p>
120 <p>The file <tt>root_key.pem</tt> now contains the new 2048-bit RSA root private key and the file <tt>root_crt.pem</tt> now contains the new root certificate.</p>
122 <h3>Create the Server Authority</h3>
124 <pre>
125 # Create a 2048 bit private RSA key
126 openssl genrsa -f4 2048 > serverauth_key.pem
127 openssl rsa -in serverauth_key.pem -pubout |
128 CACreateCert --subca --cert root_crt.pem --key root_key.pem \
129 "Acme Server Authority" > serverauth_crt.pem
130 </pre>
132 <p>The file <tt>serverauth_key.pem</tt> now contains the new 2048-bit RSA server authority private key and the file <tt>serverauth_crt.pem</tt> now contains the new server authority certificate.</p>
134 <h3>Create the Client Authority</h3>
136 <pre>
137 # Create a 2048 bit private RSA key
138 openssl genrsa -f4 2048 > clientauth_key.pem
139 openssl rsa -in clientauth_key.pem -pubout |
140 CACreateCert --subca --cert root_crt.pem --key root_key.pem \
141 "Acme Client Authority" > clientauth_crt.pem
142 </pre>
144 <p>The file <tt>clientauth_key.pem</tt> now contains the new 2048-bit RSA client authority private key and the file <tt>clientauth_crt.pem</tt> now contains the new client authority certificate.</p>
146 <h3 id="site1">Create Site 1 Keys &amp; Certificates</h3>
148 <p>Normally the private keys created here for Site 1 would remain with Site 1 and not be shared with anyone else, but for this example they are just kept together with all the other keys. Only the public key portion of the private keys need be communicated to the authority for signing purposes.</p>
150 <pre>
151 openssl genrsa -f4 2048 > site1server_key.pem
152 openssl genrsa -f4 2048 > site1client_key.pem
153 openssl rsa -in site1server_key.pem -pubout |
154 CACreateCert --server --cert serverauth_crt.pem --key serverauth_key.pem \
155 "site1.example.com" > site1server_crt.pem
156 openssl rsa -in site1client_key.pem -pubout |
157 CACreateCert --subca --cert clientauth_crt.pem --key clientauth_key.pem \
158 "Site 1 Client Authority" > site1client_crt.pem
159 </pre>
161 <p class="note">It&#x2019;s important that the canonical domain name be given when creating <tt>--server</tt> certificates. It&#x2019;s the <tt>"site1.example.com"</tt> part of the above command.</p>
163 <p>Now the files <tt>site1server_key.pem</tt> and <tt>site1server_crt.pem</tt> contain the private key and certificate for the https server for domain <tt>site1.example.com</tt>. Similarly the files <tt>site1client_key.pem</tt> and <tt>site1client_crt.pem</tt> now contain the private key and client certificate authority for Site 1.</p>
165 <p class="note">There&#x2019;s nothing to prevent the <tt>site1client_crt.pem</tt> from signing certificate types other than client certificates. However, since client certificates need not be signed by a root certificate that the client trusts, <tt>site1client_crt.pem</tt> could just as easily have been made a <tt>--root</tt> certificate (instead of a <tt>--subca</tt>) so that a client that trusts <tt>root_crt.pem</tt> does not automatically trust anything signed by <tt>site1client_crt.pem</tt>.</p>
167 <h3>Create other Site Keys &amp; Certificates</h3>
169 <p>The same procedure used for Site 1 can be duplicated to make the keys and certificates for additional sites.</p>
171 <h3>Deploying a Site 1 Server</h3>
173 <p>For this example, assuming an Apache web server will be used, here&#x2019;s the procedure needed to properly configure the certificates.</p>
175 <h4>Create the Server Intermediate Chain</h4>
177 <p>All the certificates leading from the server&#x2019;s certificate up to and including the root certificate need to be collected into a file in order from the certificate that signed the server&#x2019;s certificate on up the chain to the root.</p>
179 <pre>
180 cat serverauth_crt.pem root_crt.pem > site1chain_crt.pem
181 </pre>
183 <p>The file <tt>site1chain_crt.pem</tt> now contains the certificates for the part of the certificate chain above Site 1&#x2019;s server certificate.</p>
185 <h4 id="apache">Adjust the Server Configuration</h4>
187 <p>The apache server certificate configuration directives that are needed look like this:</p>
189 <pre>
190 # A ServerName or ServerAlias directive matching the
191 # canonical DNS name embedded in site1server_crt.pem
192 # will generally also be required.
194 # For the server's https authentication
195 SSLCertificateChainFile site1chain_crt.pem
196 SSLCertificateFile site1server_crt.pem
197 SSLCertificateKeyFile site1server_key.pem
200 # Client certificate authentication is activated with
201 # the SSLVerifyClient directive and the results
202 # transfered to the REMOTE_USER variable with
203 # the SSLOptions +FakeBasicAuth and the
204 # Require valid-user directives.
206 # For the server to do client authentication
207 SSLCACertificateFile root_crt.pem
208 SSLCADNRequestFile site1client_crt.pem
209 </pre>
210 <p class="note">If the <tt>site1client_crt.pem</tt> certificate was created with <tt>--root</tt> instead of <tt>--subca</tt> then the <tt>SSLCACertificateFile</tt> directive should also specify <tt>site1client_crt.pem</tt> instead of <tt>root_crt.pem</tt>.</p>
212 <h3 id="client">Creating Client Authentication Certificates</h3>
214 <p>These examples assume the Site 1 certificates shown <a href="#site1">above</a> have been created in the current directory.</p>
216 <h4>Create the Client Intermediate Chain</h4>
218 <p>Much like for the server&#x2019;s certificate, the chain of intermediate certificates leading from the to-be-generated client certificates up to the client authentication root certificate need to be collected. In this case the root certificate may be omitted since the server is guaranteed to already have it for any successful client authentication.</p>
220 <p>To generate the Site 1 client chain that will be needed to generate Site 1 client authentication user certificates do the following:</p>
222 <pre>
223 cat site1client_crt.pem clientauth_crt.pem > site1usuffix_crt.pem
224 </pre>
226 <p>Now the <tt>site1suffix_crt.pem</tt> file contains the certificates that need to be appended to any generated Site 1 client authentication user certificates.</p>
228 <p class="note">If the <tt>site1client_crt.pem</tt> certificate was created with <tt>--root</tt> instead of <tt>--subca</tt> then the correct <tt>site1usuffix_crt.pem</tt> file contents are simply the empty file (use <tt class="nobreak">: > site1usuffix_crt.pem</tt> to create it).</p>
230 <h4>Acquire a User RSA Public Key</h4>
232 <p>The <tt>CACreateCert</tt> utility can create client authentication certificates from RSA public keys. There are several common ways to acquire an RSA public key:</p>
234 <ol>
235 <li>From an RSA private key
236 <p>The Site 1 RSA public key in X509 format can be generated from the Site 1 RSA private key like so:</p>
237 <pre>openssl rsa -in site1server_key.pem -pubout</pre></li>
239 <li>From an OpenSSH RSA public key
240 <p><tt>CACreateCert</tt> can read an OpenSSH protocol 2 public RSA key file directly. For example, if OpenSSH has created a private key in <tt>~/.ssh/id_rsa</tt> then it has also created the corresponding public key in <tt>~/.ssh/id_rsa.pub</tt> which can be read directly by <tt>CACreateCert</tt>.</p>
242 <p>An OpenSSH public key can also be created from the Site 1 RSA private key like so:</p>
243 <pre>
244 # OpenSSH is very picky about private key permissions
245 chmod go-rwx site1server_key.pem
246 ssh-keygen -y -f site1server_key.pem
247 </pre></li>
249 <li>From a new OpenSSH RSA key
250 <p>The <tt>ssh-keygen -t rsa</tt> command can be used to generate an RSA private key and the <tt class="nobreak">ssh-keygen -y -f</tt> public key at the same time.</p></li>
252 </ol>
254 <h4 id="user">Generate the User Client Certificate</h4>
256 <p>The following example assumes an RSA public key for Pat (in either X509 public key format or OpenSSH public key format) is located in the file <tt>id_rsa_pat.pub</tt> (perhaps copied from <tt>~pat/.ssh/id_rsa.pub</tt>).</p>
258 <p class="note">For you folks following along at home that want to generate an <tt>id_rsa_pat.pub</tt> file in order to continue trying out these instructions, execute the command:<br /><tt class="nobreak indent">ssh-keygen -t rsa -b 2048 -N '' -q -f id_rsa_pat</tt><br />to create the <tt>id_rsa_pat.pub</tt> file.</p>
260 <p>A client authentication certificate for use with the Site 1 server may be generated from the <tt>id_rsa_pat.pub</tt> file like so:</p>
261 <pre>
262 cat id_rsa_pat.pub |
263 CACreateCert --client --cert site1client_crt.pem --key site1client_key.pem \
264 "pat" > site1patbare_crt.pem
265 </pre>
267 <p>The bare certificate is not usable by itself however (unless the <tt>site1client_crt.pem</tt> certificate was created with <tt>--root</tt> instead of <tt>--subca</tt>). To make a usable client authentication certificate file append the previously generated suffix like so:</p>
269 <pre>
270 cat site1patbare_crt.pem site1usuffix_crt.pem > site1patuser_crt.pem
271 </pre>
273 <p>Note that at no point is the <tt>id_rsa_pat</tt> private key needed to create the user&#x2019;s client authentication certificate. The generated <tt>site1patuser_crt.pem</tt> certificate can be used together with the <tt>id_rsa_pat</tt> private key file to authenticate to the Site 1 server as the user <tt>"pat"</tt>.</p>
275 <p class="note">Assuming the server is configured correctly (see <a href="#apache">above</a>), the name provided to <tt>CACreateCert --client</tt> will end up in the <tt>REMOTE_USER</tt> variable (in this case <tt>pat</tt>) but it will be prefixed by <tt>/UID=</tt> so when <tt>site1patuser_crt.pem</tt> is used to successfully authenticate, the server will (assuming it&#x2019;s been configured correctly) set <tt>REMOTE_USER</tt> to <tt>/UID=pat</tt> when executing any scripts. Any scripts inspecting <tt>REMOTE_USER</tt> must be written to accommodate the <tt>/UID=</tt> prefix.</p>
277 <h3>Using Client Authentication with Git</h3>
279 <p>Presuming that a server has been configured for user authentication using client certificates (see <a href="#apache">above</a>), as the means to authenticate users for push privileges using the git smart http protocol, then the following git commands would configure git to authenticate as the <tt>"pat"</tt> user:</p>
281 <pre>
282 git config http.sslCAInfo root_crt.pem
283 git config http.sslCert site1patuser_crt.pem
284 git config http.sslKey id_rsa_pat
285 </pre>
287 <p>If the Site 1 server allows the user <tt>pat</tt> to push, then this git configuration shows how to authenticate as <tt>pat</tt> using the <tt>site1patuser_crt.pem</tt> client authentication user certificate in order to push.</p>
289 <p class="last">Note the <tt>site1patuser_crt.pem</tt> file (which has had the intermediate certificates suffix added) is used and <em>not</em> the bare file (<tt>site1patbare_crt.pem</tt>) which would fail to authenticate.</p>
291 </div><span class="aftermargin"></span></body>
292 </html>