#ifndef __krb5_private_h__
#define __krb5_private_h__
#include <stdarg.h>
#if !defined(__GNUC__) && !defined(__attribute__)
#define __attribute__(x)
#endif
#ifndef KRB5_DEPRECATED_FUNCTION
#if defined(__GNUC__) && ((__GNUC__ > 3) || ((__GNUC__ == 3) && (__GNUC_MINOR__ >= 1 )))
#define KRB5_DEPRECATED_FUNCTION(X) __attribute__((__deprecated__))
#else
#define KRB5_DEPRECATED_FUNCTION(X)
#endif
#endif
void
_heim_krb5_ipc_client_clear_target (void);
void
_heim_krb5_ipc_client_set_target_uid (uid_t );
void
_krb5_DES3_random_to_key (
krb5_context ,
krb5_keyblock *,
const void *,
size_t );
krb5_error_code
_krb5_HMAC_MD5_checksum (
krb5_context ,
struct _krb5_key_data *,
const void *,
size_t ,
unsigned ,
Checksum *);
krb5_error_code
_krb5_SP_HMAC_SHA1_checksum (
krb5_context ,
struct _krb5_key_data *,
const void *,
size_t ,
unsigned ,
Checksum *);
KRB5_LIB_FUNCTION krb5_error_code KRB5_LIB_CALL
_krb5_build_authenticator (
krb5_context ,
krb5_auth_context ,
krb5_enctype ,
krb5_creds *,
Checksum *,
krb5_data *,
krb5_key_usage );
krb5_error_code
_krb5_cc_allocate (
krb5_context ,
const krb5_cc_ops *,
krb5_ccache *);
KRB5_LIB_FUNCTION krb5_error_code KRB5_LIB_CALL
_krb5_config_copy (
krb5_context ,
krb5_config_section *,
krb5_config_section **);
KRB5_LIB_FUNCTION const void * KRB5_LIB_CALL
_krb5_config_get (
krb5_context ,
const krb5_config_section *,
int ,
...);
krb5_config_section *
_krb5_config_get_entry (
krb5_config_section **,
const char *,
int );
KRB5_LIB_FUNCTION const void * KRB5_LIB_CALL
_krb5_config_get_next (
krb5_context ,
const krb5_config_section *,
const krb5_config_binding **,
int ,
...);
const void *
_krb5_config_vget (
krb5_context ,
const krb5_config_section *,
int ,
va_list );
KRB5_LIB_FUNCTION const void * KRB5_LIB_CALL
_krb5_config_vget_next (
krb5_context ,
const krb5_config_section *,
const krb5_config_binding **,
int ,
va_list );
KRB5_LIB_FUNCTION krb5_error_code KRB5_LIB_CALL
_krb5_copy_send_to_kdc_func (
krb5_context ,
krb5_context );
void
_krb5_crc_init_table (void);
uint32_t
_krb5_crc_update (
const char *,
size_t ,
uint32_t );
void
_krb5_debug_backtrace (krb5_context );
krb5_error_code
_krb5_derive_key (
krb5_context ,
struct _krb5_encryption_type *,
struct _krb5_key_data *,
const void *,
size_t );
krb5_error_code
_krb5_des_checksum(krb5_context context,
CCDigestAlg alg,
struct _krb5_key_data *key,
const void *data,
size_t len,
Checksum *cksum);
krb5_error_code
_krb5_des_verify(krb5_context context,
CCDigestAlg alg,
struct _krb5_key_data *key,
const void *data,
size_t len,
Checksum *C);
krb5_error_code
_krb5_dh_group_ok (
krb5_context ,
unsigned long ,
heim_integer *,
heim_integer *,
heim_integer *,
struct krb5_dh_moduli **,
char **);
krb5_error_code
_krb5_einval (
krb5_context ,
const char *,
unsigned long );
krb5_error_code
_krb5_erase_file (
krb5_context ,
const char *);
void
_krb5_evp_cleanup (
krb5_context ,
struct _krb5_key_data *);
krb5_error_code
_krb5_evp_encrypt (
krb5_context ,
struct _krb5_key_data *,
void *,
size_t ,
krb5_boolean ,
int ,
void *);
krb5_error_code
_krb5_evp_encrypt_cts (
krb5_context ,
struct _krb5_key_data *,
void *,
size_t ,
krb5_boolean ,
int ,
void *);
void
_krb5_evp_schedule (
krb5_context ,
struct _krb5_key_type *,
struct _krb5_key_data *);
krb5_error_code
_krb5_expand_default_cc_name (
krb5_context ,
const char *,
char **);
KRB5_LIB_FUNCTION krb5_error_code KRB5_LIB_CALL
_krb5_expand_path_tokens (
krb5_context ,
const char *,
char **);
int
_krb5_extract_ticket(krb5_context context,
krb5_kdc_rep *rep,
krb5_creds *creds,
krb5_keyblock *key,
krb5_const_pointer keyseed,
krb5_key_usage key_usage,
krb5_addresses *addrs,
unsigned nonce,
unsigned flags,
krb5_data *request,
krb5_decrypt_proc decrypt_proc,
krb5_const_pointer decryptarg);
struct _krb5_checksum_type *
_krb5_find_checksum (krb5_cksumtype );
struct _krb5_encryption_type *
_krb5_find_enctype (krb5_enctype );
void
_krb5_free_key_data (
krb5_context ,
struct _krb5_key_data *,
struct _krb5_encryption_type *);
void
_krb5_free_krbhst_info (krb5_krbhst_info *);
void
_krb5_free_moduli (struct krb5_dh_moduli **);
krb5_error_code
_krb5_get_cred_kdc_any (
krb5_context ,
krb5_kdc_flags ,
krb5_ccache ,
krb5_creds *,
krb5_principal ,
Ticket *,
krb5_creds **,
krb5_creds ***);
char *
_krb5_get_default_cc_name_from_registry (void);
char *
_krb5_get_default_config_config_files_from_registry (void);
krb5_error_code
_krb5_get_default_principal_local (
krb5_context ,
krb5_principal *);
KRB5_LIB_FUNCTION krb5_error_code KRB5_LIB_CALL
_krb5_get_host_realm_int (
krb5_context ,
const char *,
krb5_boolean ,
krb5_realm **);
KRB5_LIB_FUNCTION void KRB5_LIB_CALL
_krb5_get_init_creds_opt_free_pkinit (krb5_get_init_creds_opt *);
KRB5_LIB_FUNCTION krb5_ssize_t KRB5_LIB_CALL
_krb5_get_int (
void *,
unsigned long *,
size_t );
krb5_error_code
_krb5_get_krbtgt (
krb5_context ,
krb5_ccache ,
krb5_realm ,
krb5_creds **);
krb5_boolean KRB5_LIB_FUNCTION
_krb5_have_debug (
krb5_context ,
int );
krb5_boolean
_krb5_homedir_access (krb5_context );
KRB5_LIB_FUNCTION krb5_error_code KRB5_LIB_CALL
_krb5_init_etype (
krb5_context ,
krb5_pdu ,
unsigned *,
krb5_enctype **,
const krb5_enctype *);
krb5_error_code
_krb5_internal_hmac (
krb5_context ,
struct _krb5_checksum_type *,
const void *,
size_t ,
unsigned ,
struct _krb5_key_data *,
Checksum *);
KRB5_LIB_FUNCTION krb5_error_code KRB5_LIB_CALL
_krb5_kcm_get_initial_ticket(krb5_context context,
krb5_ccache id,
krb5_principal client,
krb5_principal server,
const char *password);
KRB5_LIB_FUNCTION krb5_error_code KRB5_LIB_CALL
_krb5_kcm_get_ticket (
krb5_context ,
krb5_ccache ,
krb5_kdc_flags ,
krb5_enctype ,
krb5_principal );
KRB5_LIB_FUNCTION krb5_boolean KRB5_LIB_CALL
_krb5_kcm_is_running (krb5_context );
KRB5_LIB_FUNCTION krb5_error_code KRB5_LIB_CALL
_krb5_kcm_noop (
krb5_context ,
krb5_ccache );
krb5_error_code KRB5_CALLCONV
_krb5_kdc_retry (
krb5_context ,
krb5_sendto_ctx ,
void *,
const krb5_data *,
int *);
krb5_error_code
_krb5_krbhost_info_move (
krb5_context ,
krb5_krbhst_info *,
krb5_krbhst_info **);
const char *
_krb5_krbhst_get_realm (krb5_krbhst_handle );
krb5_error_code
_krb5_kt_principal_not_found (
krb5_context ,
krb5_error_code ,
krb5_keytab ,
krb5_const_principal ,
krb5_enctype ,
int );
krb5_error_code
_krb5_load_ccache_plugins (krb5_context );
krb5_error_code
_krb5_mk_req_internal (
krb5_context ,
krb5_auth_context *,
const krb5_flags ,
krb5_data *,
krb5_creds *,
krb5_data *,
krb5_key_usage ,
krb5_key_usage );
KRB5_LIB_FUNCTION krb5_error_code KRB5_LIB_CALL
_krb5_n_fold (
const void *,
size_t ,
void *,
size_t );
krb5_error_code
_krb5_pac_sign (
krb5_context ,
krb5_pac ,
time_t ,
krb5_principal ,
const krb5_keyblock *,
const krb5_keyblock *,
krb5_data *);
krb5_error_code
_krb5_parse_moduli (
krb5_context ,
const char *,
struct krb5_dh_moduli ***);
krb5_error_code
_krb5_parse_moduli_line (
krb5_context ,
const char *,
int ,
char *,
struct krb5_dh_moduli **);
KRB5_LIB_FUNCTION void KRB5_LIB_CALL
_krb5_pk_cert_free (struct krb5_pk_cert *);
krb5_error_code
_krb5_pk_find_cert(krb5_context context, int mme, struct hx509_certs_data *certs,
struct hx509_query_data *q, struct hx509_cert_data **cert);
krb5_error_code KRB5_LIB_FUNCTION
_krb5_pk_match_cert(krb5_context context,
krb5_principal principal,
struct hx509_cert_data *cert,
int match_realm);
krb5_error_code
_krb5_pk_kdf (
krb5_context ,
const struct AlgorithmIdentifier *,
const void *,
size_t ,
krb5_const_principal ,
krb5_const_principal ,
krb5_enctype ,
const krb5_data *,
const krb5_data *,
const Ticket *,
krb5_keyblock *);
KRB5_LIB_FUNCTION krb5_error_code KRB5_LIB_CALL
_krb5_pk_load_id (
krb5_context ,
struct krb5_pk_identity **,
const char *,
const char *,
char * const *,
char * const *,
krb5_prompter_fct ,
void *,
char *);
KRB5_LIB_FUNCTION krb5_error_code KRB5_LIB_CALL
_krb5_pk_mk_ContentInfo (
krb5_context ,
const krb5_data *,
const heim_oid *,
struct ContentInfo *);
KRB5_LIB_FUNCTION krb5_error_code KRB5_LIB_CALL
_krb5_pk_mk_padata (
krb5_context ,
void *,
int ,
int ,
const KDC_REQ_BODY *,
unsigned ,
METHOD_DATA *);
krb5_error_code
_krb5_pk_octetstring2key (
krb5_context ,
krb5_enctype ,
const void *,
size_t ,
const heim_octet_string *,
const heim_octet_string *,
krb5_keyblock *);
krb5_error_code
_krb5_plugin_find (
krb5_context ,
enum krb5_plugin_type ,
const char *,
struct krb5_plugin **);
void
_krb5_plugin_free (struct krb5_plugin *);
struct krb5_plugin *
_krb5_plugin_get_next (struct krb5_plugin *);
void *
_krb5_plugin_get_symbol (struct krb5_plugin *);
KRB5_LIB_FUNCTION krb5_error_code KRB5_LIB_CALL
_krb5_principal2principalname (
PrincipalName *,
const krb5_principal );
KRB5_LIB_FUNCTION krb5_boolean KRB5_LIB_CALL
_krb5_principal_compare_PrincipalName (
krb5_context ,
krb5_const_principal ,
PrincipalName *);
KRB5_LIB_FUNCTION krb5_error_code KRB5_LIB_CALL
_krb5_principalname2krb5_principal (
krb5_context ,
krb5_principal *,
const PrincipalName ,
const Realm );
KRB5_LIB_FUNCTION krb5_ssize_t KRB5_LIB_CALL
_krb5_put_int (
void *,
unsigned long ,
size_t );
KRB5_LIB_FUNCTION krb5_error_code KRB5_LIB_CALL
_krb5_s4u2self_to_checksumdata (
krb5_context ,
const PA_S4U2Self *,
krb5_data *);
int
_krb5_send_and_recv_tcp (
krb5_socket_t ,
time_t ,
const krb5_data *,
krb5_data *);
void
_krb5_unload_plugins (
krb5_context ,
const char *);
krb5_error_code
_krb5_usage2arcfour (
krb5_context ,
unsigned *);
int
_krb5_xlock (
krb5_context ,
int ,
krb5_boolean ,
const char *);
void
_krb5_xor (
unsigned char *,
const unsigned char *);
int
_krb5_xunlock (
krb5_context ,
int );
void KRB5_LIB_FUNCTION
_krb5_debugx(krb5_context context,
int level,
const char *fmt,
...)
__attribute__((format (printf, 3, 4)));
void KRB5_LIB_FUNCTION
_krb5_debug(krb5_context context,
int level,
krb5_error_code ret,
const char *fmt,
...)
__attribute__((format (printf, 4, 5)));
KRB5_LIB_FUNCTION void KRB5_LIB_CALL
_krb5_sendto_ctx_set_prexmit(krb5_sendto_ctx ctx,
krb5_sendto_prexmit prexmit,
void *data);
krb5_error_code
_krb5_array_to_realms(krb5_context context, heim_array_t array, krb5_realm **realms);
krb5_error_code KRB5_LIB_FUNCTION
_krb5_init_creds_set_pku2u(krb5_context context,
krb5_init_creds_context ctx,
krb5_data *data);
krb5_error_code
_krb5_pk_set_user_id(krb5_context context,
struct krb5_pk_init_ctx_data *ctx,
struct hx509_cert_data *cert);
void
_krb5_pk_copy_error(krb5_context context, int hxret, const char *fmt, ...)
HEIMDAL_PRINTF_ATTRIBUTE((printf, 3, 4));
krb5_error_code
_krb5_kcm_ntlm_challenge(krb5_context context, int op __attribute((__unused__)),
uint8_t chal[8]);
KRB5_LIB_FUNCTION krb5_error_code KRB5_LIB_CALL
_krb5_pk_rd_pa_reply(krb5_context context,
const char *realm,
struct krb5_pk_init_ctx_data *ctx,
krb5_enctype etype,
const krb5_krbhst_info *hi,
unsigned nonce,
const krb5_data *req_buffer,
PA_DATA *pa,
krb5_keyblock **key);
KRB5_LIB_FUNCTION krb5_error_code KRB5_LIB_CALL
_krb5_get_init_creds_opt_set_pkinit_user_cert(krb5_context context,
krb5_get_init_creds_opt *opt,
krb5_principal principal,
const char *user_id,
const char *x509_anchors,
char * const * pool,
char * const * pki_revoke,
int flags,
krb5_prompter_fct prompter,
void *prompter_data,
char *password);
KRB5_LIB_FUNCTION krb5_error_code KRB5_LIB_CALL
_krb5_pk_enterprise_cert(krb5_context context,
const char *user_id,
krb5_const_realm realm,
krb5_principal *principal,
struct hx509_cert_data **res);
krb5_error_code
_krb5_fast_cf2(krb5_context context,
krb5_keyblock *key1,
const char *pepper1,
krb5_keyblock *key2,
const char *pepper2,
krb5_keyblock *armorkey,
krb5_crypto *armor_crypto);
krb5_error_code
_krb5_fast_armor_key(krb5_context context,
krb5_keyblock *subkey,
krb5_keyblock *sessionkey,
krb5_keyblock *armorkey,
krb5_crypto *armor_crypto);
KRB5_LIB_FUNCTION const char * KRB5_LIB_CALL
_krb5_kcm_get_status(int status);
#undef KRB5_DEPRECATED_FUNCTION
#define KRB5_DEPRECATED_FUNCTION(X)
#endif