|
Packit |
fd8b60 |
/* -*- mode: c; c-basic-offset: 4; indent-tabs-mode: nil -*- */
|
|
Packit |
fd8b60 |
/*
|
|
Packit |
fd8b60 |
* COPYRIGHT (C) 2006
|
|
Packit |
fd8b60 |
* THE REGENTS OF THE UNIVERSITY OF MICHIGAN
|
|
Packit |
fd8b60 |
* ALL RIGHTS RESERVED
|
|
Packit |
fd8b60 |
*
|
|
Packit |
fd8b60 |
* Permission is granted to use, copy, create derivative works
|
|
Packit |
fd8b60 |
* and redistribute this software and such derivative works
|
|
Packit |
fd8b60 |
* for any purpose, so long as the name of The University of
|
|
Packit |
fd8b60 |
* Michigan is not used in any advertising or publicity
|
|
Packit |
fd8b60 |
* pertaining to the use of distribution of this software
|
|
Packit |
fd8b60 |
* without specific, written prior authorization. If the
|
|
Packit |
fd8b60 |
* above copyright notice or any other identification of the
|
|
Packit |
fd8b60 |
* University of Michigan is included in any copy of any
|
|
Packit |
fd8b60 |
* portion of this software, then the disclaimer below must
|
|
Packit |
fd8b60 |
* also be included.
|
|
Packit |
fd8b60 |
*
|
|
Packit |
fd8b60 |
* THIS SOFTWARE IS PROVIDED AS IS, WITHOUT REPRESENTATION
|
|
Packit |
fd8b60 |
* FROM THE UNIVERSITY OF MICHIGAN AS TO ITS FITNESS FOR ANY
|
|
Packit |
fd8b60 |
* PURPOSE, AND WITHOUT WARRANTY BY THE UNIVERSITY OF
|
|
Packit |
fd8b60 |
* MICHIGAN OF ANY KIND, EITHER EXPRESS OR IMPLIED, INCLUDING
|
|
Packit |
fd8b60 |
* WITHOUT LIMITATION THE IMPLIED WARRANTIES OF
|
|
Packit |
fd8b60 |
* MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. THE
|
|
Packit |
fd8b60 |
* REGENTS OF THE UNIVERSITY OF MICHIGAN SHALL NOT BE LIABLE
|
|
Packit |
fd8b60 |
* FOR ANY DAMAGES, INCLUDING SPECIAL, INDIRECT, INCIDENTAL, OR
|
|
Packit |
fd8b60 |
* CONSEQUENTIAL DAMAGES, WITH RESPECT TO ANY CLAIM ARISING
|
|
Packit |
fd8b60 |
* OUT OF OR IN CONNECTION WITH THE USE OF THE SOFTWARE, EVEN
|
|
Packit |
fd8b60 |
* IF IT HAS BEEN OR IS HEREAFTER ADVISED OF THE POSSIBILITY OF
|
|
Packit |
fd8b60 |
* SUCH DAMAGES.
|
|
Packit |
fd8b60 |
*/
|
|
Packit |
fd8b60 |
|
|
Packit |
fd8b60 |
#ifndef _KRB5_INT_PKINIT_H
|
|
Packit |
fd8b60 |
#define _KRB5_INT_PKINIT_H
|
|
Packit |
fd8b60 |
|
|
Packit |
fd8b60 |
/*
|
|
Packit |
fd8b60 |
* pkinit structures
|
|
Packit |
fd8b60 |
*/
|
|
Packit |
fd8b60 |
|
|
Packit |
fd8b60 |
/* PKAuthenticator */
|
|
Packit |
fd8b60 |
typedef struct _krb5_pk_authenticator {
|
|
Packit |
fd8b60 |
krb5_int32 cusec; /* (0..999999) */
|
|
Packit |
fd8b60 |
krb5_timestamp ctime;
|
|
Packit |
fd8b60 |
krb5_int32 nonce; /* (0..4294967295) */
|
|
Packit |
fd8b60 |
krb5_checksum paChecksum;
|
|
Packit |
fd8b60 |
krb5_data *freshnessToken;
|
|
Packit |
fd8b60 |
} krb5_pk_authenticator;
|
|
Packit |
fd8b60 |
|
|
Packit |
fd8b60 |
/* AlgorithmIdentifier */
|
|
Packit |
fd8b60 |
typedef struct _krb5_algorithm_identifier {
|
|
Packit |
fd8b60 |
krb5_data algorithm; /* OID */
|
|
Packit |
fd8b60 |
krb5_data parameters; /* Optional */
|
|
Packit |
fd8b60 |
} krb5_algorithm_identifier;
|
|
Packit |
fd8b60 |
|
|
Packit |
fd8b60 |
/* SubjectPublicKeyInfo */
|
|
Packit |
fd8b60 |
typedef struct _krb5_subject_pk_info {
|
|
Packit |
fd8b60 |
krb5_algorithm_identifier algorithm;
|
|
Packit |
fd8b60 |
krb5_data subjectPublicKey; /* BIT STRING */
|
|
Packit |
fd8b60 |
} krb5_subject_pk_info;
|
|
Packit |
fd8b60 |
|
|
Packit |
fd8b60 |
/** AuthPack from RFC 4556*/
|
|
Packit |
fd8b60 |
typedef struct _krb5_auth_pack {
|
|
Packit |
fd8b60 |
krb5_pk_authenticator pkAuthenticator;
|
|
Packit |
fd8b60 |
krb5_subject_pk_info *clientPublicValue; /* Optional */
|
|
Packit |
fd8b60 |
krb5_algorithm_identifier **supportedCMSTypes; /* Optional */
|
|
Packit |
fd8b60 |
krb5_data clientDHNonce; /* Optional */
|
|
Packit |
fd8b60 |
krb5_data **supportedKDFs; /* OIDs of KDFs; OPTIONAL */
|
|
Packit |
fd8b60 |
} krb5_auth_pack;
|
|
Packit |
fd8b60 |
|
|
Packit |
fd8b60 |
/* ExternalPrincipalIdentifier */
|
|
Packit |
fd8b60 |
typedef struct _krb5_external_principal_identifier {
|
|
Packit |
fd8b60 |
krb5_data subjectName; /* Optional */
|
|
Packit |
fd8b60 |
krb5_data issuerAndSerialNumber; /* Optional */
|
|
Packit |
fd8b60 |
krb5_data subjectKeyIdentifier; /* Optional */
|
|
Packit |
fd8b60 |
} krb5_external_principal_identifier;
|
|
Packit |
fd8b60 |
|
|
Packit |
fd8b60 |
/* PA-PK-AS-REQ (rfc4556 -- PA TYPE 16) */
|
|
Packit |
fd8b60 |
typedef struct _krb5_pa_pk_as_req {
|
|
Packit |
fd8b60 |
krb5_data signedAuthPack;
|
|
Packit |
fd8b60 |
krb5_external_principal_identifier **trustedCertifiers; /* Optional array */
|
|
Packit |
fd8b60 |
krb5_data kdcPkId; /* Optional */
|
|
Packit |
fd8b60 |
} krb5_pa_pk_as_req;
|
|
Packit |
fd8b60 |
|
|
Packit |
fd8b60 |
/** Pkinit DHRepInfo */
|
|
Packit |
fd8b60 |
typedef struct _krb5_dh_rep_info {
|
|
Packit |
fd8b60 |
krb5_data dhSignedData;
|
|
Packit |
fd8b60 |
krb5_data serverDHNonce; /* Optional */
|
|
Packit |
fd8b60 |
krb5_data *kdfID; /* OID of selected KDF OPTIONAL */
|
|
Packit |
fd8b60 |
} krb5_dh_rep_info;
|
|
Packit |
fd8b60 |
|
|
Packit |
fd8b60 |
/* KDCDHKeyInfo */
|
|
Packit |
fd8b60 |
typedef struct _krb5_kdc_dh_key_info {
|
|
Packit |
fd8b60 |
krb5_data subjectPublicKey; /* BIT STRING */
|
|
Packit |
fd8b60 |
krb5_int32 nonce; /* (0..4294967295) */
|
|
Packit |
fd8b60 |
krb5_timestamp dhKeyExpiration; /* Optional */
|
|
Packit |
fd8b60 |
} krb5_kdc_dh_key_info;
|
|
Packit |
fd8b60 |
|
|
Packit |
fd8b60 |
/* ReplyKeyPack */
|
|
Packit |
fd8b60 |
typedef struct _krb5_reply_key_pack {
|
|
Packit |
fd8b60 |
krb5_keyblock replyKey;
|
|
Packit |
fd8b60 |
krb5_checksum asChecksum;
|
|
Packit |
fd8b60 |
} krb5_reply_key_pack;
|
|
Packit |
fd8b60 |
|
|
Packit |
fd8b60 |
/* PA-PK-AS-REP (rfc4556 -- PA TYPE 17) */
|
|
Packit |
fd8b60 |
typedef struct _krb5_pa_pk_as_rep {
|
|
Packit |
fd8b60 |
enum krb5_pa_pk_as_rep_selection {
|
|
Packit |
fd8b60 |
choice_pa_pk_as_rep_UNKNOWN = -1,
|
|
Packit |
fd8b60 |
choice_pa_pk_as_rep_dhInfo = 0,
|
|
Packit |
fd8b60 |
choice_pa_pk_as_rep_encKeyPack = 1
|
|
Packit |
fd8b60 |
} choice;
|
|
Packit |
fd8b60 |
union krb5_pa_pk_as_rep_choices {
|
|
Packit |
fd8b60 |
krb5_dh_rep_info dh_Info;
|
|
Packit |
fd8b60 |
krb5_data encKeyPack;
|
|
Packit |
fd8b60 |
} u;
|
|
Packit |
fd8b60 |
} krb5_pa_pk_as_rep;
|
|
Packit |
fd8b60 |
|
|
Packit |
fd8b60 |
/* SP80056A OtherInfo, for pkinit algorithm agility */
|
|
Packit |
fd8b60 |
typedef struct _krb5_sp80056a_other_info {
|
|
Packit |
fd8b60 |
krb5_algorithm_identifier algorithm_identifier;
|
|
Packit |
fd8b60 |
krb5_principal party_u_info;
|
|
Packit |
fd8b60 |
krb5_principal party_v_info;
|
|
Packit |
fd8b60 |
krb5_data supp_pub_info;
|
|
Packit |
fd8b60 |
} krb5_sp80056a_other_info;
|
|
Packit |
fd8b60 |
|
|
Packit |
fd8b60 |
/* PkinitSuppPubInfo, for pkinit algorithm agility */
|
|
Packit |
fd8b60 |
typedef struct _krb5_pkinit_supp_pub_info {
|
|
Packit |
fd8b60 |
krb5_enctype enctype;
|
|
Packit |
fd8b60 |
krb5_data as_req;
|
|
Packit |
fd8b60 |
krb5_data pk_as_rep;
|
|
Packit |
fd8b60 |
} krb5_pkinit_supp_pub_info;
|
|
Packit |
fd8b60 |
|
|
Packit |
fd8b60 |
/*
|
|
Packit |
fd8b60 |
* Begin "asn1.h"
|
|
Packit |
fd8b60 |
*/
|
|
Packit |
fd8b60 |
|
|
Packit |
fd8b60 |
/*************************************************************************
|
|
Packit |
fd8b60 |
* Prototypes for pkinit asn.1 encode routines
|
|
Packit |
fd8b60 |
*************************************************************************/
|
|
Packit |
fd8b60 |
|
|
Packit |
fd8b60 |
krb5_error_code
|
|
Packit |
fd8b60 |
encode_krb5_pa_pk_as_req(const krb5_pa_pk_as_req *rep, krb5_data **code);
|
|
Packit |
fd8b60 |
|
|
Packit |
fd8b60 |
krb5_error_code
|
|
Packit |
fd8b60 |
encode_krb5_pa_pk_as_rep(const krb5_pa_pk_as_rep *rep, krb5_data **code);
|
|
Packit |
fd8b60 |
|
|
Packit |
fd8b60 |
krb5_error_code
|
|
Packit |
fd8b60 |
encode_krb5_auth_pack(const krb5_auth_pack *rep, krb5_data **code);
|
|
Packit |
fd8b60 |
|
|
Packit |
fd8b60 |
krb5_error_code
|
|
Packit |
fd8b60 |
encode_krb5_kdc_dh_key_info(const krb5_kdc_dh_key_info *rep, krb5_data **code);
|
|
Packit |
fd8b60 |
|
|
Packit |
fd8b60 |
krb5_error_code
|
|
Packit |
fd8b60 |
encode_krb5_reply_key_pack(const krb5_reply_key_pack *, krb5_data **code);
|
|
Packit |
fd8b60 |
|
|
Packit |
fd8b60 |
krb5_error_code
|
|
Packit |
fd8b60 |
encode_krb5_td_trusted_certifiers(krb5_external_principal_identifier *const *,
|
|
Packit |
fd8b60 |
krb5_data **code);
|
|
Packit |
fd8b60 |
|
|
Packit |
fd8b60 |
krb5_error_code
|
|
Packit |
fd8b60 |
encode_krb5_td_dh_parameters(krb5_algorithm_identifier *const *,
|
|
Packit |
fd8b60 |
krb5_data **code);
|
|
Packit |
fd8b60 |
|
|
Packit |
fd8b60 |
krb5_error_code
|
|
Packit |
fd8b60 |
encode_krb5_sp80056a_other_info(const krb5_sp80056a_other_info *,
|
|
Packit |
fd8b60 |
krb5_data **);
|
|
Packit |
fd8b60 |
|
|
Packit |
fd8b60 |
krb5_error_code
|
|
Packit |
fd8b60 |
encode_krb5_pkinit_supp_pub_info(const krb5_pkinit_supp_pub_info *,
|
|
Packit |
fd8b60 |
krb5_data **);
|
|
Packit |
fd8b60 |
|
|
Packit |
fd8b60 |
/*************************************************************************
|
|
Packit |
fd8b60 |
* Prototypes for pkinit asn.1 decode routines
|
|
Packit |
fd8b60 |
*************************************************************************/
|
|
Packit |
fd8b60 |
|
|
Packit |
fd8b60 |
krb5_error_code
|
|
Packit |
fd8b60 |
decode_krb5_pa_pk_as_req(const krb5_data *, krb5_pa_pk_as_req **);
|
|
Packit |
fd8b60 |
|
|
Packit |
fd8b60 |
krb5_error_code
|
|
Packit |
fd8b60 |
decode_krb5_pa_pk_as_rep(const krb5_data *, krb5_pa_pk_as_rep **);
|
|
Packit |
fd8b60 |
|
|
Packit |
fd8b60 |
krb5_error_code
|
|
Packit |
fd8b60 |
decode_krb5_auth_pack(const krb5_data *, krb5_auth_pack **);
|
|
Packit |
fd8b60 |
|
|
Packit |
fd8b60 |
krb5_error_code
|
|
Packit |
fd8b60 |
decode_krb5_kdc_dh_key_info(const krb5_data *, krb5_kdc_dh_key_info **);
|
|
Packit |
fd8b60 |
|
|
Packit |
fd8b60 |
krb5_error_code
|
|
Packit |
fd8b60 |
decode_krb5_principal_name(const krb5_data *, krb5_principal_data **);
|
|
Packit |
fd8b60 |
|
|
Packit |
fd8b60 |
krb5_error_code
|
|
Packit |
fd8b60 |
decode_krb5_reply_key_pack(const krb5_data *, krb5_reply_key_pack **);
|
|
Packit |
fd8b60 |
|
|
Packit |
fd8b60 |
krb5_error_code
|
|
Packit |
fd8b60 |
decode_krb5_td_trusted_certifiers(const krb5_data *,
|
|
Packit |
fd8b60 |
krb5_external_principal_identifier ***);
|
|
Packit |
fd8b60 |
|
|
Packit |
fd8b60 |
krb5_error_code
|
|
Packit |
fd8b60 |
decode_krb5_td_dh_parameters(const krb5_data *, krb5_algorithm_identifier ***);
|
|
Packit |
fd8b60 |
|
|
Packit |
fd8b60 |
krb5_error_code
|
|
Packit |
fd8b60 |
encode_krb5_enc_data(const krb5_enc_data *, krb5_data **);
|
|
Packit |
fd8b60 |
|
|
Packit |
fd8b60 |
krb5_error_code
|
|
Packit |
fd8b60 |
encode_krb5_encryption_key(const krb5_keyblock *rep, krb5_data **code);
|
|
Packit |
fd8b60 |
|
|
Packit |
fd8b60 |
krb5_error_code
|
|
Packit |
fd8b60 |
krb5_encrypt_helper(krb5_context context, const krb5_keyblock *key,
|
|
Packit |
fd8b60 |
krb5_keyusage keyusage, const krb5_data *plain,
|
|
Packit |
fd8b60 |
krb5_enc_data *cipher);
|
|
Packit |
fd8b60 |
|
|
Packit |
fd8b60 |
#endif /* _KRB5_INT_PKINIT_H */
|