#ifndef __krb5_private_h__
#define __krb5_private_h__
#include <stdarg.h>
#if !defined(__GNUC__) && !defined(__attribute__)
#define __attribute__(x)
#endif
void
_heim_krb5_ipc_client_clear_target (void);
void
_heim_krb5_ipc_client_set_target_uid (uid_t );
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_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_LIB_FUNCTION
_krb5_debugx (
krb5_context ,
int ,
const char *,
...)
__attribute__((format (printf, 3, 4)));
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_erase_file (
krb5_context ,
const char *);
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 ,
krb5_kdc_rep *,
krb5_creds *,
krb5_keyblock *,
krb5_const_pointer ,
krb5_key_usage ,
krb5_addresses *,
unsigned ,
unsigned ,
krb5_decrypt_proc ,
krb5_const_pointer );
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 ***);
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_error_code KRB5_LIB_FUNCTION
_krb5_get_init_creds_opt_set_pkinit_user_cert (
krb5_context ,
krb5_get_init_creds_opt *,
struct hx509_cert_data *);
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_error_code KRB5_LIB_FUNCTION
_krb5_init_creds_set_pku2u (
krb5_context ,
krb5_init_creds_context ,
krb5_data *);
krb5_error_code
_krb5_kcm_get_initial_ticket (
krb5_context ,
krb5_ccache ,
krb5_principal ,
krb5_principal ,
const char *);
krb5_error_code
_krb5_kcm_get_ticket (
krb5_context ,
krb5_ccache ,
krb5_kdc_flags ,
krb5_enctype ,
krb5_principal );
krb5_boolean
_krb5_kcm_is_running (krb5_context );
krb5_error_code
_krb5_kcm_noop (
krb5_context ,
krb5_ccache );
krb5_error_code
_krb5_kdc_retry (
krb5_context ,
krb5_sendto_ctx ,
void *,
const krb5_data *,
int *);
KRB5_LIB_FUNCTION krb5_error_code KRB5_LIB_CALL
_krb5_krb_cr_err_reply (
krb5_context ,
const char *,
const char *,
const char *,
uint32_t ,
uint32_t ,
const char *,
krb5_data *);
KRB5_LIB_FUNCTION krb5_error_code KRB5_LIB_CALL
_krb5_krb_create_auth_reply (
krb5_context ,
const char *,
const char *,
const char *,
int32_t ,
int ,
uint32_t ,
unsigned char ,
const krb5_data *,
krb5_data *);
KRB5_LIB_FUNCTION krb5_error_code KRB5_LIB_CALL
_krb5_krb_create_ciph (
krb5_context ,
const krb5_keyblock *,
const char *,
const char *,
const char *,
uint32_t ,
unsigned char ,
const krb5_data *,
uint32_t ,
const krb5_keyblock *,
krb5_data *);
KRB5_LIB_FUNCTION krb5_error_code KRB5_LIB_CALL
_krb5_krb_create_ticket (
krb5_context ,
unsigned char ,
const char *,
const char *,
const char *,
int32_t ,
const krb5_keyblock *,
int16_t ,
int32_t ,
const char *,
const char *,
const krb5_keyblock *,
krb5_data *);
KRB5_LIB_FUNCTION krb5_error_code KRB5_LIB_CALL
_krb5_krb_decomp_ticket (
krb5_context ,
const krb5_data *,
const krb5_keyblock *,
const char *,
char **,
char **,
struct _krb5_krb_auth_data *);
KRB5_LIB_FUNCTION krb5_error_code KRB5_LIB_CALL
_krb5_krb_dest_tkt (
krb5_context ,
const char *);
KRB5_LIB_FUNCTION void KRB5_LIB_CALL
_krb5_krb_free_auth_data (
krb5_context ,
struct _krb5_krb_auth_data *);
KRB5_LIB_FUNCTION time_t KRB5_LIB_CALL
_krb5_krb_life_to_time (
int ,
int );
KRB5_LIB_FUNCTION krb5_error_code KRB5_LIB_CALL
_krb5_krb_rd_req (
krb5_context ,
krb5_data *,
const char *,
const char *,
const char *,
int32_t ,
const krb5_keyblock *,
struct _krb5_krb_auth_data *);
KRB5_LIB_FUNCTION krb5_error_code KRB5_LIB_CALL
_krb5_krb_tf_setup (
krb5_context ,
struct credentials *,
const char *,
int );
KRB5_LIB_FUNCTION int KRB5_LIB_CALL
_krb5_krb_time_to_life (
time_t ,
time_t );
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_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 **);
void
_krb5_pk_copy_error (
krb5_context ,
int ,
const char *,
...) HEIMDAL_PRINTF_ATTRIBUTE((printf, 3, 4));
KRB5_LIB_FUNCTION krb5_error_code KRB5_LIB_CALL
_krb5_pk_enterprise_cert (
krb5_context ,
const char *,
krb5_const_realm ,
krb5_principal *,
struct hx509_cert_data **);
struct hx509_query_data
;
krb5_error_code
_krb5_pk_find_cert (
krb5_context ,
int ,
struct hx509_certs_data *,
struct hx509_query_data *,
struct hx509_cert_data **);
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_error_code KRB5_LIB_FUNCTION
_krb5_pk_match_cert (
krb5_context ,
krb5_principal ,
struct hx509_cert_data *,
int );
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_LIB_FUNCTION krb5_error_code KRB5_LIB_CALL
_krb5_pk_rd_pa_reply (
krb5_context ,
const char *,
struct krb5_pk_init_ctx_data *,
krb5_enctype ,
const krb5_krbhst_info *,
unsigned ,
const krb5_data *,
PA_DATA *,
krb5_keyblock **);
krb5_error_code
_krb5_pk_set_user_id (
krb5_context ,
struct krb5_pk_init_ctx_data *,
struct hx509_cert_data *);
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 *);
int
_krb5_xlock (
krb5_context ,
int ,
krb5_boolean ,
const char *);
int
_krb5_xunlock (
krb5_context ,
int );
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_plugin_run_f(krb5_context, const char *, const char *, int, int, void *,
krb5_error_code (*)(krb5_context, const void *,
void *, void *));
void _krb5_load_plugins(krb5_context, const char *, const char **);
void _krb5_unload_plugins(krb5_context, const char *);
krb5_error_code
_krb5_des_checksum(krb5_context context,
CCDigestAlg alg,
struct key_data *key,
const void *data,
size_t len,
Checksum *cksum);
krb5_error_code
_krb5_des_verify(krb5_context context,
CCDigestAlg alg,
struct key_data *key,
const void *data,
size_t len,
Checksum *C);
struct encryption_type *
_krb5_find_enctype(krb5_enctype type);
krb5_error_code
_krb5_internal_hmac(krb5_context context,
struct checksum_type *cm,
const void *data,
size_t len,
unsigned usage,
struct key_data *keyblock,
Checksum *result);
struct checksum_type *
_krb5_find_checksum(krb5_cksumtype type);
krb5_error_code
_krb5_SP_HMAC_SHA1_checksum(krb5_context context,
struct key_data *key,
const void *data,
size_t len,
unsigned usage,
Checksum *result);
krb5_error_code
_krb5_derive_key(krb5_context context,
struct encryption_type *et,
struct key_data *key,
const void *constant,
size_t len);
void
_krb5_free_key_data(krb5_context context, struct key_data *key,
struct encryption_type *et);
void
_krb5_evp_schedule(krb5_context context,
struct key_type *kt,
struct key_data *kd);
void
_krb5_evp_cleanup(krb5_context context, struct key_data *kd);
krb5_error_code
_krb5_evp_encrypt_cts(krb5_context context,
struct key_data *key,
void *data,
size_t len,
krb5_boolean encryptp,
int usage,
void *ivec);
krb5_error_code
_krb5_usage2arcfour(krb5_context context, unsigned *usage);
void
_krb5_xor (unsigned char *p, const unsigned char *b);
krb5_error_code
_krb5_evp_encrypt(krb5_context context,
struct key_data *key,
void *data,
size_t len,
krb5_boolean encryptp,
int usage,
void *ivec);
void
_krb5_DES3_random_to_key(krb5_context context,
krb5_keyblock *key,
const void *data,
size_t size);
krb5_error_code
_krb5_array_to_realms(krb5_context context, heim_array_t array, krb5_realm **realms);
void KRB5_LIB_FUNCTION
_krb5_debug(krb5_context context,
int level,
krb5_error_code ret,
const char *fmt,
...)
__attribute__((format (printf, 4, 5)));
#endif