Blame src/include/k5-int-pkinit.h

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 */