1 /* -*- mode: c; c-basic-offset: 4; indent-tabs-mode: nil -*- */
4 * THE REGENTS OF THE UNIVERSITY OF MICHIGAN
7 * Permission is granted to use, copy, create derivative works
8 * and redistribute this software and such derivative works
9 * for any purpose, so long as the name of The University of
10 * Michigan is not used in any advertising or publicity
11 * pertaining to the use of distribution of this software
12 * without specific, written prior authorization. If the
13 * above copyright notice or any other identification of the
14 * University of Michigan is included in any copy of any
15 * portion of this software, then the disclaimer below must
18 * THIS SOFTWARE IS PROVIDED AS IS, WITHOUT REPRESENTATION
19 * FROM THE UNIVERSITY OF MICHIGAN AS TO ITS FITNESS FOR ANY
20 * PURPOSE, AND WITHOUT WARRANTY BY THE UNIVERSITY OF
21 * MICHIGAN OF ANY KIND, EITHER EXPRESS OR IMPLIED, INCLUDING
22 * WITHOUT LIMITATION THE IMPLIED WARRANTIES OF
23 * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. THE
24 * REGENTS OF THE UNIVERSITY OF MICHIGAN SHALL NOT BE LIABLE
25 * FOR ANY DAMAGES, INCLUDING SPECIAL, INDIRECT, INCIDENTAL, OR
26 * CONSEQUENTIAL DAMAGES, WITH RESPECT TO ANY CLAIM ARISING
27 * OUT OF OR IN CONNECTION WITH THE USE OF THE SOFTWARE, EVEN
28 * IF IT HAS BEEN OR IS HEREAFTER ADVISED OF THE POSSIBILITY OF
32 #ifndef _KRB5_INT_PKINIT_H
33 #define _KRB5_INT_PKINIT_H
40 typedef struct _krb5_pk_authenticator {
41 krb5_int32 cusec; /* (0..999999) */
43 krb5_int32 nonce; /* (0..4294967295) */
44 krb5_checksum paChecksum;
45 } krb5_pk_authenticator;
47 /* PKAuthenticator draft9 */
48 typedef struct _krb5_pk_authenticator_draft9 {
49 krb5_principal kdcName;
50 krb5_int32 cusec; /* (0..999999) */
52 krb5_int32 nonce; /* (0..4294967295) */
53 } krb5_pk_authenticator_draft9;
55 /* AlgorithmIdentifier */
56 typedef struct _krb5_algorithm_identifier {
57 krb5_data algorithm; /* OID */
58 krb5_data parameters; /* Optional */
59 } krb5_algorithm_identifier;
61 /* SubjectPublicKeyInfo */
62 typedef struct _krb5_subject_pk_info {
63 krb5_algorithm_identifier algorithm;
64 krb5_data subjectPublicKey; /* BIT STRING */
65 } krb5_subject_pk_info;
67 /** AuthPack from RFC 4556*/
68 typedef struct _krb5_auth_pack {
69 krb5_pk_authenticator pkAuthenticator;
70 krb5_subject_pk_info *clientPublicValue; /* Optional */
71 krb5_algorithm_identifier **supportedCMSTypes; /* Optional */
72 krb5_data clientDHNonce; /* Optional */
73 krb5_data **supportedKDFs; /* OIDs of KDFs; OPTIONAL */
77 typedef struct _krb5_auth_pack_draft9 {
78 krb5_pk_authenticator_draft9 pkAuthenticator;
79 krb5_subject_pk_info *clientPublicValue; /* Optional */
80 } krb5_auth_pack_draft9;
82 /* ExternalPrincipalIdentifier */
83 typedef struct _krb5_external_principal_identifier {
84 krb5_data subjectName; /* Optional */
85 krb5_data issuerAndSerialNumber; /* Optional */
86 krb5_data subjectKeyIdentifier; /* Optional */
87 } krb5_external_principal_identifier;
90 typedef struct _krb5_trusted_ca {
91 enum krb5_trusted_ca_selection {
92 choice_trusted_cas_UNKNOWN = -1,
93 choice_trusted_cas_principalName = 0,
94 choice_trusted_cas_caName = 1,
95 choice_trusted_cas_issuerAndSerial = 2
97 union krb5_trusted_ca_choices {
98 krb5_principal principalName;
99 krb5_data caName; /* fully-qualified X.500 "Name" as defined by X.509 (der-encoded) */
100 krb5_data issuerAndSerial; /* Optional -- IssuerAndSerialNumber (der-encoded) */
104 /* PA-PK-AS-REQ (Draft 9 -- PA TYPE 14) */
105 typedef struct _krb5_pa_pk_as_req_draft9 {
106 krb5_data signedAuthPack;
107 krb5_trusted_ca **trustedCertifiers; /* Optional array */
108 krb5_data kdcCert; /* Optional */
109 krb5_data encryptionCert;
110 } krb5_pa_pk_as_req_draft9;
112 /* PA-PK-AS-REQ (rfc4556 -- PA TYPE 16) */
113 typedef struct _krb5_pa_pk_as_req {
114 krb5_data signedAuthPack;
115 krb5_external_principal_identifier **trustedCertifiers; /* Optional array */
116 krb5_data kdcPkId; /* Optional */
119 /** Pkinit DHRepInfo */
120 typedef struct _krb5_dh_rep_info {
121 krb5_data dhSignedData;
122 krb5_data serverDHNonce; /* Optional */
123 krb5_data *kdfID; /* OID of selected KDF OPTIONAL */
127 typedef struct _krb5_kdc_dh_key_info {
128 krb5_data subjectPublicKey; /* BIT STRING */
129 krb5_int32 nonce; /* (0..4294967295) */
130 krb5_timestamp dhKeyExpiration; /* Optional */
131 } krb5_kdc_dh_key_info;
133 /* KDCDHKeyInfo draft9*/
134 typedef struct _krb5_kdc_dh_key_info_draft9 {
135 krb5_data subjectPublicKey; /* BIT STRING */
136 krb5_int32 nonce; /* (0..4294967295) */
137 } krb5_kdc_dh_key_info_draft9;
140 typedef struct _krb5_reply_key_pack {
141 krb5_keyblock replyKey;
142 krb5_checksum asChecksum;
143 } krb5_reply_key_pack;
146 typedef struct _krb5_reply_key_pack_draft9 {
147 krb5_keyblock replyKey;
149 } krb5_reply_key_pack_draft9;
151 /* PA-PK-AS-REP (Draft 9 -- PA TYPE 15) */
152 typedef struct _krb5_pa_pk_as_rep_draft9 {
153 enum krb5_pa_pk_as_rep_draft9_selection {
154 choice_pa_pk_as_rep_draft9_UNKNOWN = -1,
155 choice_pa_pk_as_rep_draft9_dhSignedData = 0,
156 choice_pa_pk_as_rep_draft9_encKeyPack = 1
158 union krb5_pa_pk_as_rep_draft9_choices {
159 krb5_data dhSignedData;
160 krb5_data encKeyPack;
162 } krb5_pa_pk_as_rep_draft9;
164 /* PA-PK-AS-REP (rfc4556 -- PA TYPE 17) */
165 typedef struct _krb5_pa_pk_as_rep {
166 enum krb5_pa_pk_as_rep_selection {
167 choice_pa_pk_as_rep_UNKNOWN = -1,
168 choice_pa_pk_as_rep_dhInfo = 0,
169 choice_pa_pk_as_rep_encKeyPack = 1
171 union krb5_pa_pk_as_rep_choices {
172 krb5_dh_rep_info dh_Info;
173 krb5_data encKeyPack;
177 /* SP80056A OtherInfo, for pkinit algorithm agility */
178 typedef struct _krb5_sp80056a_other_info {
179 krb5_algorithm_identifier algorithm_identifier;
180 krb5_principal party_u_info;
181 krb5_principal party_v_info;
182 krb5_data supp_pub_info;
183 } krb5_sp80056a_other_info;
185 /* PkinitSuppPubInfo, for pkinit algorithm agility */
186 typedef struct _krb5_pkinit_supp_pub_info {
187 krb5_enctype enctype;
190 } krb5_pkinit_supp_pub_info;
196 /*************************************************************************
197 * Prototypes for pkinit asn.1 encode routines
198 *************************************************************************/
201 encode_krb5_pa_pk_as_req(const krb5_pa_pk_as_req *rep, krb5_data **code);
204 encode_krb5_pa_pk_as_req_draft9(const krb5_pa_pk_as_req_draft9 *rep,
208 encode_krb5_pa_pk_as_rep(const krb5_pa_pk_as_rep *rep, krb5_data **code);
211 encode_krb5_pa_pk_as_rep_draft9(const krb5_pa_pk_as_rep_draft9 *rep,
215 encode_krb5_auth_pack(const krb5_auth_pack *rep, krb5_data **code);
218 encode_krb5_auth_pack_draft9(const krb5_auth_pack_draft9 *rep,
222 encode_krb5_kdc_dh_key_info(const krb5_kdc_dh_key_info *rep, krb5_data **code);
225 encode_krb5_reply_key_pack(const krb5_reply_key_pack *, krb5_data **code);
228 encode_krb5_reply_key_pack_draft9(const krb5_reply_key_pack_draft9 *,
232 encode_krb5_td_trusted_certifiers(krb5_external_principal_identifier *const *,
236 encode_krb5_td_dh_parameters(krb5_algorithm_identifier *const *,
240 encode_krb5_sp80056a_other_info(const krb5_sp80056a_other_info *,
244 encode_krb5_pkinit_supp_pub_info(const krb5_pkinit_supp_pub_info *,
247 /*************************************************************************
248 * Prototypes for pkinit asn.1 decode routines
249 *************************************************************************/
252 decode_krb5_pa_pk_as_req(const krb5_data *, krb5_pa_pk_as_req **);
255 decode_krb5_pa_pk_as_req_draft9(const krb5_data *,
256 krb5_pa_pk_as_req_draft9 **);
259 decode_krb5_pa_pk_as_rep(const krb5_data *, krb5_pa_pk_as_rep **);
262 decode_krb5_pa_pk_as_rep_draft9(const krb5_data *,
263 krb5_pa_pk_as_rep_draft9 **);
266 decode_krb5_auth_pack(const krb5_data *, krb5_auth_pack **);
269 decode_krb5_auth_pack_draft9(const krb5_data *, krb5_auth_pack_draft9 **);
272 decode_krb5_kdc_dh_key_info(const krb5_data *, krb5_kdc_dh_key_info **);
275 decode_krb5_principal_name(const krb5_data *, krb5_principal_data **);
278 decode_krb5_reply_key_pack(const krb5_data *, krb5_reply_key_pack **);
281 decode_krb5_reply_key_pack_draft9(const krb5_data *,
282 krb5_reply_key_pack_draft9 **);
285 decode_krb5_td_trusted_certifiers(const krb5_data *,
286 krb5_external_principal_identifier ***);
289 decode_krb5_td_dh_parameters(const krb5_data *, krb5_algorithm_identifier ***);
292 encode_krb5_enc_data(const krb5_enc_data *, krb5_data **);
295 encode_krb5_encryption_key(const krb5_keyblock *rep, krb5_data **code);
298 krb5_encrypt_helper(krb5_context context, const krb5_keyblock *key,
299 krb5_keyusage keyusage, const krb5_data *plain,
300 krb5_enc_data *cipher);
302 #endif /* _KRB5_INT_PKINIT_H */