keyhole logo

Functions
Heimdal Kerberos 5 library

Functions

KRB5_LIB_FUNCTION krb5_error_code KRB5_LIB_CALL krb5_add_et_list (krb5_context context, void(*func)(struct et_list **))
 
KRB5_LIB_FUNCTION krb5_error_code KRB5_LIB_CALL krb5_set_password (krb5_context context, krb5_creds *creds, const char *newpw, krb5_principal targprinc, int *result_code, krb5_data *result_code_string, krb5_data *result_string)
 
KRB5_LIB_FUNCTION krb5_error_code KRB5_LIB_CALL krb5_init_context (krb5_context *context)
 
KRB5_LIB_FUNCTION krb5_error_code KRB5_LIB_CALL krb5_copy_context (krb5_context context, krb5_context *out)
 
KRB5_LIB_FUNCTION void KRB5_LIB_CALL krb5_free_context (krb5_context context)
 
KRB5_LIB_FUNCTION krb5_error_code KRB5_LIB_CALL krb5_set_config_files (krb5_context context, char **filenames)
 
KRB5_LIB_FUNCTION krb5_error_code KRB5_LIB_CALL krb5_prepend_config_files_default (const char *filelist, char ***pfilenames)
 
KRB5_LIB_FUNCTION krb5_error_code KRB5_LIB_CALL krb5_get_default_config_files (char ***pfilenames)
 
KRB5_LIB_FUNCTION void KRB5_LIB_CALL krb5_free_config_files (char **filenames)
 
KRB5_LIB_FUNCTION const krb5_enctype *KRB5_LIB_CALL krb5_kerberos_enctypes (krb5_context context)
 
KRB5_LIB_FUNCTION krb5_error_code KRB5_LIB_CALL krb5_set_default_in_tkt_etypes (krb5_context context, const krb5_enctype *etypes)
 
KRB5_LIB_FUNCTION krb5_error_code KRB5_LIB_CALL krb5_get_default_in_tkt_etypes (krb5_context context, krb5_pdu pdu_type, krb5_enctype **etypes)
 
KRB5_LIB_FUNCTION void KRB5_LIB_CALL krb5_init_ets (krb5_context context)
 
KRB5_LIB_FUNCTION void KRB5_LIB_CALL krb5_set_use_admin_kdc (krb5_context context, krb5_boolean flag)
 
KRB5_LIB_FUNCTION krb5_boolean KRB5_LIB_CALL krb5_get_use_admin_kdc (krb5_context context)
 
KRB5_LIB_FUNCTION krb5_error_code KRB5_LIB_CALL krb5_add_extra_addresses (krb5_context context, krb5_addresses *addresses)
 
KRB5_LIB_FUNCTION krb5_error_code KRB5_LIB_CALL krb5_set_extra_addresses (krb5_context context, const krb5_addresses *addresses)
 
KRB5_LIB_FUNCTION krb5_error_code KRB5_LIB_CALL krb5_get_extra_addresses (krb5_context context, krb5_addresses *addresses)
 
KRB5_LIB_FUNCTION krb5_error_code KRB5_LIB_CALL krb5_add_ignore_addresses (krb5_context context, krb5_addresses *addresses)
 
KRB5_LIB_FUNCTION krb5_error_code KRB5_LIB_CALL krb5_set_ignore_addresses (krb5_context context, const krb5_addresses *addresses)
 
KRB5_LIB_FUNCTION krb5_error_code KRB5_LIB_CALL krb5_get_ignore_addresses (krb5_context context, krb5_addresses *addresses)
 
KRB5_LIB_FUNCTION krb5_error_code KRB5_LIB_CALL krb5_set_fcache_version (krb5_context context, int version)
 
KRB5_LIB_FUNCTION krb5_error_code KRB5_LIB_CALL krb5_get_fcache_version (krb5_context context, int *version)
 
KRB5_LIB_FUNCTION krb5_boolean KRB5_LIB_CALL krb5_is_thread_safe (void)
 
KRB5_LIB_FUNCTION void KRB5_LIB_CALL krb5_set_dns_canonicalize_hostname (krb5_context context, krb5_boolean flag)
 
KRB5_LIB_FUNCTION krb5_boolean KRB5_LIB_CALL krb5_get_dns_canonicalize_hostname (krb5_context context)
 
KRB5_LIB_FUNCTION krb5_error_code KRB5_LIB_CALL krb5_get_kdc_sec_offset (krb5_context context, int32_t *sec, int32_t *usec)
 
KRB5_LIB_FUNCTION krb5_error_code KRB5_LIB_CALL krb5_set_kdc_sec_offset (krb5_context context, int32_t sec, int32_t usec)
 
KRB5_LIB_FUNCTION time_t KRB5_LIB_CALL krb5_get_max_time_skew (krb5_context context)
 
KRB5_LIB_FUNCTION void KRB5_LIB_CALL krb5_set_max_time_skew (krb5_context context, time_t t)
 
KRB5_LIB_FUNCTION krb5_boolean KRB5_LIB_CALL krb5_set_home_dir_access (krb5_context context, krb5_boolean allow)
 
KRB5_LIB_FUNCTION krb5_error_code KRB5_LIB_CALL krb5_copy_host_realm (krb5_context context, const krb5_realm *from, krb5_realm **to)
 
KRB5_LIB_FUNCTION krb5_error_code KRB5_LIB_CALL krb5_free_cred_contents (krb5_context context, krb5_creds *c)
 
KRB5_LIB_FUNCTION krb5_error_code KRB5_LIB_CALL krb5_copy_creds_contents (krb5_context context, const krb5_creds *incred, krb5_creds *c)
 
KRB5_LIB_FUNCTION krb5_error_code KRB5_LIB_CALL krb5_copy_creds (krb5_context context, const krb5_creds *incred, krb5_creds **outcred)
 
KRB5_LIB_FUNCTION krb5_error_code KRB5_LIB_CALL krb5_free_creds (krb5_context context, krb5_creds *c)
 
KRB5_LIB_FUNCTION krb5_boolean KRB5_LIB_CALL krb5_compare_creds (krb5_context context, krb5_flags whichfields, const krb5_creds *mcreds, const krb5_creds *creds)
 
KRB5_LIB_FUNCTION unsigned long KRB5_LIB_CALL krb5_creds_get_ticket_flags (krb5_creds *creds)
 
KRB5_LIB_FUNCTION void KRB5_LIB_CALL krb5_data_zero (krb5_data *p)
 
KRB5_LIB_FUNCTION void KRB5_LIB_CALL krb5_data_free (krb5_data *p)
 
KRB5_LIB_FUNCTION void KRB5_LIB_CALL krb5_free_data (krb5_context context, krb5_data *p)
 
KRB5_LIB_FUNCTION krb5_error_code KRB5_LIB_CALL krb5_data_alloc (krb5_data *p, int len)
 
KRB5_LIB_FUNCTION krb5_error_code KRB5_LIB_CALL krb5_data_realloc (krb5_data *p, int len)
 
KRB5_LIB_FUNCTION krb5_error_code KRB5_LIB_CALL krb5_data_copy (krb5_data *p, const void *data, size_t len)
 
KRB5_LIB_FUNCTION krb5_error_code KRB5_LIB_CALL krb5_copy_data (krb5_context context, const krb5_data *indata, krb5_data **outdata)
 
KRB5_LIB_FUNCTION int KRB5_LIB_CALL krb5_data_cmp (const krb5_data *data1, const krb5_data *data2)
 
KRB5_LIB_FUNCTION int KRB5_LIB_CALL krb5_data_ct_cmp (const krb5_data *data1, const krb5_data *data2)
 
KRB5_LIB_FUNCTION const char *KRB5_LIB_CALL krb5_get_err_text (krb5_context context, krb5_error_code code) KRB5_DEPRECATED_FUNCTION("Use krb5_get_error_message instead")
 
KRB5_LIB_FUNCTION krb5_error_code KRB5_LIB_CALL krb5_krbhst_get_addrinfo (krb5_context context, krb5_krbhst_info *host, struct addrinfo **ai)
 
KRB5_LIB_FUNCTION krb5_error_code KRB5_LIB_CALL krb5_free_ticket (krb5_context context, krb5_ticket *ticket)
 
KRB5_LIB_FUNCTION krb5_error_code KRB5_LIB_CALL krb5_copy_ticket (krb5_context context, const krb5_ticket *from, krb5_ticket **to)
 
KRB5_LIB_FUNCTION krb5_error_code KRB5_LIB_CALL krb5_ticket_get_client (krb5_context context, const krb5_ticket *ticket, krb5_principal *client)
 
KRB5_LIB_FUNCTION krb5_error_code KRB5_LIB_CALL krb5_ticket_get_server (krb5_context context, const krb5_ticket *ticket, krb5_principal *server)
 
KRB5_LIB_FUNCTION time_t KRB5_LIB_CALL krb5_ticket_get_endtime (krb5_context context, const krb5_ticket *ticket)
 
KRB5_LIB_FUNCTION krb5_error_code KRB5_LIB_CALL krb5_ticket_get_authorization_data_type (krb5_context context, krb5_ticket *ticket, int type, krb5_data *data)
 
KRB5_LIB_FUNCTION krb5_error_code KRB5_LIB_CALL krb5_set_real_time (krb5_context context, krb5_timestamp sec, int32_t usec)
 

Detailed Description

Function Documentation

◆ krb5_add_et_list()

KRB5_LIB_FUNCTION krb5_error_code KRB5_LIB_CALL krb5_add_et_list ( krb5_context  context,
void(*)(struct et_list **)  func 
)

Add a specified list of error messages to the et list in context. Call func (probably a comerr-generated function) with a pointer to the current et_list.

Parameters
contextA kerberos context.
funcThe generated com_err et function.
Returns
Returns 0 to indicate success. Otherwise an kerberos et error code is returned, see krb5_get_error_message().

◆ krb5_add_extra_addresses()

KRB5_LIB_FUNCTION krb5_error_code KRB5_LIB_CALL krb5_add_extra_addresses ( krb5_context  context,
krb5_addresses *  addresses 
)

Add extra address to the address list that the library will add to the client's address list when communicating with the KDC.

Parameters
contextKerberos 5 context.
addressesaddreses to add
Returns
Returns 0 to indicate success. Otherwise an kerberos et error code is returned, see krb5_get_error_message().

◆ krb5_add_ignore_addresses()

KRB5_LIB_FUNCTION krb5_error_code KRB5_LIB_CALL krb5_add_ignore_addresses ( krb5_context  context,
krb5_addresses *  addresses 
)

Add extra addresses to ignore when fetching addresses from the underlaying operating system.

Parameters
contextKerberos 5 context.
addressesaddreses to ignore
Returns
Returns 0 to indicate success. Otherwise an kerberos et error code is returned, see krb5_get_error_message().

◆ krb5_compare_creds()

KRB5_LIB_FUNCTION krb5_boolean KRB5_LIB_CALL krb5_compare_creds ( krb5_context  context,
krb5_flags  whichfields,
const krb5_creds *  mcreds,
const krb5_creds *  creds 
)

Return TRUE if `mcreds' and `creds' are equal (`whichfields' determines what equal means).

The following flags, set in whichfields affects the comparison:

  • KRB5_TC_MATCH_SRV_NAMEONLY Consider all realms equal when comparing the service principal.
  • KRB5_TC_MATCH_KEYTYPE Compare enctypes.
  • KRB5_TC_MATCH_FLAGS_EXACT Make sure that the ticket flags are identical.
  • KRB5_TC_MATCH_FLAGS Make sure that all ticket flags set in mcreds are also present in creds .
  • KRB5_TC_MATCH_TIMES_EXACT Compares the ticket times exactly.
  • KRB5_TC_MATCH_TIMES Compares only the expiration times of the creds.
  • KRB5_TC_MATCH_AUTHDATA Compares the authdata fields.
  • KRB5_TC_MATCH_2ND_TKT Compares the second tickets (used by user-to-user authentication).
  • KRB5_TC_MATCH_IS_SKEY Compares the existance of the second ticket.
Parameters
contextKerberos 5 context.
whichfieldswhich fields to compare.
mcredscred to compare with.
credscred to compare with.
Returns
return TRUE if mcred and creds are equal, FALSE if not.

◆ krb5_copy_context()

KRB5_LIB_FUNCTION krb5_error_code KRB5_LIB_CALL krb5_copy_context ( krb5_context  context,
krb5_context *  out 
)

Make a copy for the Kerberos 5 context, the new krb5_context shoud be freed with krb5_free_context().

Parameters
contextthe Kerberos context to copy
outthe copy of the Kerberos, set to NULL error.
Returns
Returns 0 to indicate success. Otherwise an kerberos et error code is returned, see krb5_get_error_message().

◆ krb5_copy_creds()

KRB5_LIB_FUNCTION krb5_error_code KRB5_LIB_CALL krb5_copy_creds ( krb5_context  context,
const krb5_creds *  incred,
krb5_creds **  outcred 
)

Copy krb5_creds.

Parameters
contextKerberos 5 context.
incredsource credential
outcreddestination credential, free with krb5_free_creds().
Returns
Returns 0 to indicate success. Otherwise an kerberos et error code is returned, see krb5_get_error_message().

◆ krb5_copy_creds_contents()

KRB5_LIB_FUNCTION krb5_error_code KRB5_LIB_CALL krb5_copy_creds_contents ( krb5_context  context,
const krb5_creds *  incred,
krb5_creds *  c 
)

Copy content of krb5_creds.

Parameters
contextKerberos 5 context.
incredsource credential
cdestination credential, free with krb5_free_cred_contents().
Returns
Returns 0 to indicate success. Otherwise an kerberos et error code is returned, see krb5_get_error_message().

◆ krb5_copy_data()

KRB5_LIB_FUNCTION krb5_error_code KRB5_LIB_CALL krb5_copy_data ( krb5_context  context,
const krb5_data *  indata,
krb5_data **  outdata 
)

Copy the data into a newly allocated krb5_data.

Parameters
contextKerberos 5 context.
indatathe krb5_data data to copy
outdatanew krb5_date to copy too. Free with krb5_free_data().
Returns
Returns 0 to indicate success. Otherwise an kerberos et error code is returned.

◆ krb5_copy_host_realm()

KRB5_LIB_FUNCTION krb5_error_code KRB5_LIB_CALL krb5_copy_host_realm ( krb5_context  context,
const krb5_realm *  from,
krb5_realm **  to 
)

Copy the list of realms from `from' to `to'.

Parameters
contextKerberos 5 context.
fromlist of realms to copy from.
tolist of realms to copy to, free list of krb5_free_host_realm().
Returns
Returns 0 to indicate success. Otherwise an kerberos et error code is returned, see krb5_get_error_message().

◆ krb5_copy_ticket()

KRB5_LIB_FUNCTION krb5_error_code KRB5_LIB_CALL krb5_copy_ticket ( krb5_context  context,
const krb5_ticket *  from,
krb5_ticket **  to 
)

Copy ticket and content

Parameters
contexta Kerberos 5 context
fromticket to copy
tonew copy of ticket, free with krb5_free_ticket()
Returns
Returns 0 to indicate success. Otherwise an kerberos et error code is returned, see krb5_get_error_message().

◆ krb5_creds_get_ticket_flags()

KRB5_LIB_FUNCTION unsigned long KRB5_LIB_CALL krb5_creds_get_ticket_flags ( krb5_creds *  creds)

Returns the ticket flags for the credentials in creds. See also krb5_ticket_get_flags().

Parameters
credscredential to get ticket flags from
Returns
ticket flags

◆ krb5_data_alloc()

KRB5_LIB_FUNCTION krb5_error_code KRB5_LIB_CALL krb5_data_alloc ( krb5_data *  p,
int  len 
)

Allocate data of and krb5_data.

Parameters
pkrb5_data to allocate.
lensize to allocate.
Returns
Returns 0 to indicate success. Otherwise an kerberos et error code is returned.

◆ krb5_data_cmp()

KRB5_LIB_FUNCTION int KRB5_LIB_CALL krb5_data_cmp ( const krb5_data *  data1,
const krb5_data *  data2 
)

Compare to data.

Parameters
data1krb5_data to compare
data2krb5_data to compare
Returns
return the same way as memcmp(), useful when sorting.

◆ krb5_data_copy()

KRB5_LIB_FUNCTION krb5_error_code KRB5_LIB_CALL krb5_data_copy ( krb5_data *  p,
const void *  data,
size_t  len 
)

Copy the data of len into the krb5_data.

Parameters
pkrb5_data to copy into.
datadata to copy..
lennew size.
Returns
Returns 0 to indicate success. Otherwise an kerberos et error code is returned.

◆ krb5_data_ct_cmp()

KRB5_LIB_FUNCTION int KRB5_LIB_CALL krb5_data_ct_cmp ( const krb5_data *  data1,
const krb5_data *  data2 
)

Compare to data not exposing timing information from the checksum data

Parameters
data1krb5_data to compare
data2krb5_data to compare
Returns
returns zero for same data, otherwise non zero.

◆ krb5_data_free()

KRB5_LIB_FUNCTION void KRB5_LIB_CALL krb5_data_free ( krb5_data *  p)

Free the content of krb5_data structure, its ok to free a zeroed structure (with memset() or krb5_data_zero()). When done, the structure will be zeroed. The same function is called krb5_free_data_contents() in MIT Kerberos.

Parameters
pkrb5_data to free.

◆ krb5_data_realloc()

KRB5_LIB_FUNCTION krb5_error_code KRB5_LIB_CALL krb5_data_realloc ( krb5_data *  p,
int  len 
)

Grow (or shrink) the content of krb5_data to a new size.

Parameters
pkrb5_data to free.
lennew size.
Returns
Returns 0 to indicate success. Otherwise an kerberos et error code is returned.

◆ krb5_data_zero()

KRB5_LIB_FUNCTION void KRB5_LIB_CALL krb5_data_zero ( krb5_data *  p)

Reset the (potentially uninitalized) krb5_data structure.

Parameters
pkrb5_data to reset.

◆ krb5_free_config_files()

KRB5_LIB_FUNCTION void KRB5_LIB_CALL krb5_free_config_files ( char **  filenames)

Free a list of configuration files.

Parameters
filenameslist, terminated with a NULL pointer, to be freed. NULL is an valid argument.
Returns
Returns 0 to indicate success. Otherwise an kerberos et error code is returned, see krb5_get_error_message().

◆ krb5_free_context()

KRB5_LIB_FUNCTION void KRB5_LIB_CALL krb5_free_context ( krb5_context  context)

Frees the krb5_context allocated by krb5_init_context().

Parameters
contextcontext to be freed.

◆ krb5_free_cred_contents()

KRB5_LIB_FUNCTION krb5_error_code KRB5_LIB_CALL krb5_free_cred_contents ( krb5_context  context,
krb5_creds *  c 
)

Free content of krb5_creds.

Parameters
contextKerberos 5 context.
ckrb5_creds to free.
Returns
Returns 0 to indicate success. Otherwise an kerberos et error code is returned, see krb5_get_error_message().

◆ krb5_free_creds()

KRB5_LIB_FUNCTION krb5_error_code KRB5_LIB_CALL krb5_free_creds ( krb5_context  context,
krb5_creds *  c 
)

Free krb5_creds.

Parameters
contextKerberos 5 context.
ckrb5_creds to free.
Returns
Returns 0 to indicate success. Otherwise an kerberos et error code is returned, see krb5_get_error_message().

◆ krb5_free_data()

KRB5_LIB_FUNCTION void KRB5_LIB_CALL krb5_free_data ( krb5_context  context,
krb5_data *  p 
)

Free krb5_data (and its content).

Parameters
contextKerberos 5 context.
pkrb5_data to free.

◆ krb5_free_ticket()

KRB5_LIB_FUNCTION krb5_error_code KRB5_LIB_CALL krb5_free_ticket ( krb5_context  context,
krb5_ticket *  ticket 
)

Free ticket and content

Parameters
contexta Kerberos 5 context
ticketticket to free
Returns
Returns 0 to indicate success. Otherwise an kerberos et error code is returned, see krb5_get_error_message().

◆ krb5_get_default_config_files()

KRB5_LIB_FUNCTION krb5_error_code KRB5_LIB_CALL krb5_get_default_config_files ( char ***  pfilenames)

Get the global configuration list.

Parameters
pfilenamesreturn array of filenames, should be freed with krb5_free_config_files().
Returns
Returns 0 to indicate success. Otherwise an kerberos et error code is returned, see krb5_get_error_message().

◆ krb5_get_default_in_tkt_etypes()

KRB5_LIB_FUNCTION krb5_error_code KRB5_LIB_CALL krb5_get_default_in_tkt_etypes ( krb5_context  context,
krb5_pdu  pdu_type,
krb5_enctype **  etypes 
)

Get the default encryption types that will be use in communcation with the KDC, clients and servers.

Parameters
contextKerberos 5 context.
pdu_typerequest type (AS, TGS or none)
etypesEncryption types, array terminated with ETYPE_NULL(0), caller should free array with krb5_xfree():
Returns
Returns 0 to indicate success. Otherwise an kerberos et error code is returned, see krb5_get_error_message().

◆ krb5_get_dns_canonicalize_hostname()

KRB5_LIB_FUNCTION krb5_boolean KRB5_LIB_CALL krb5_get_dns_canonicalize_hostname ( krb5_context  context)

Get if the library uses DNS to canonicalize hostnames.

Parameters
contextKerberos 5 context.
Returns
return non zero if the library uses DNS to canonicalize hostnames.

◆ krb5_get_err_text()

KRB5_LIB_FUNCTION const char* KRB5_LIB_CALL krb5_get_err_text ( krb5_context  context,
krb5_error_code  code 
)

Return the error string for the error code. The caller must not free the string.

This function is deprecated since its not threadsafe.

Parameters
contextKerberos 5 context.
codeKerberos error code.
Returns
the error message matching code

◆ krb5_get_extra_addresses()

KRB5_LIB_FUNCTION krb5_error_code KRB5_LIB_CALL krb5_get_extra_addresses ( krb5_context  context,
krb5_addresses *  addresses 
)

Get extra address to the address list that the library will add to the client's address list when communicating with the KDC.

Parameters
contextKerberos 5 context.
addressesaddreses to set
Returns
Returns 0 to indicate success. Otherwise an kerberos et error code is returned, see krb5_get_error_message().

◆ krb5_get_fcache_version()

KRB5_LIB_FUNCTION krb5_error_code KRB5_LIB_CALL krb5_get_fcache_version ( krb5_context  context,
int *  version 
)

Get version of fcache that the library should use.

Parameters
contextKerberos 5 context.
versionversion number.
Returns
Returns 0 to indicate success. Otherwise an kerberos et error code is returned, see krb5_get_error_message().

◆ krb5_get_ignore_addresses()

KRB5_LIB_FUNCTION krb5_error_code KRB5_LIB_CALL krb5_get_ignore_addresses ( krb5_context  context,
krb5_addresses *  addresses 
)

Get extra addresses to ignore when fetching addresses from the underlaying operating system.

Parameters
contextKerberos 5 context.
addresseslist addreses ignored
Returns
Returns 0 to indicate success. Otherwise an kerberos et error code is returned, see krb5_get_error_message().

◆ krb5_get_kdc_sec_offset()

KRB5_LIB_FUNCTION krb5_error_code KRB5_LIB_CALL krb5_get_kdc_sec_offset ( krb5_context  context,
int32_t *  sec,
int32_t *  usec 
)

Get current offset in time to the KDC.

Parameters
contextKerberos 5 context.
secseconds part of offset.
usecmicro seconds part of offset.
Returns
returns zero

◆ krb5_get_max_time_skew()

KRB5_LIB_FUNCTION time_t KRB5_LIB_CALL krb5_get_max_time_skew ( krb5_context  context)

Get max time skew allowed.

Parameters
contextKerberos 5 context.
Returns
timeskew in seconds.

◆ krb5_get_use_admin_kdc()

KRB5_LIB_FUNCTION krb5_boolean KRB5_LIB_CALL krb5_get_use_admin_kdc ( krb5_context  context)

Make the kerberos library default to the admin KDC.

Parameters
contextKerberos 5 context.
Returns
boolean flag to telling the context will use admin KDC as the default KDC.

◆ krb5_init_context()

KRB5_LIB_FUNCTION krb5_error_code KRB5_LIB_CALL krb5_init_context ( krb5_context *  context)

Initializes the context structure and reads the configuration file /etc/krb5.conf. The structure should be freed by calling krb5_free_context() when it is no longer being used.

Parameters
contextpointer to returned context
Returns
Returns 0 to indicate success. Otherwise an errno code is returned. Failure means either that something bad happened during initialization (typically ENOMEM) or that Kerberos should not be used ENXIO. If the function returns HEIM_ERR_RANDOM_OFFLINE, the random source is not available and later Kerberos calls might fail.

krb5_init_context() will get one random byte to make sure our random is alive. Assumption is that once the non blocking source allows us to pull bytes, its all seeded and allows us to pull more bytes.

Most Kerberos users calls krb5_init_context(), so this is useful point where we can do the checking.

◆ krb5_init_ets()

KRB5_LIB_FUNCTION void KRB5_LIB_CALL krb5_init_ets ( krb5_context  context)

Init the built-in ets in the Kerberos library.

Parameters
contextkerberos context to add the ets too

◆ krb5_is_thread_safe()

KRB5_LIB_FUNCTION krb5_boolean KRB5_LIB_CALL krb5_is_thread_safe ( void  )

Runtime check if the Kerberos library was complied with thread support.

Returns
TRUE if the library was compiled with thread support, FALSE if not.

◆ krb5_kerberos_enctypes()

KRB5_LIB_FUNCTION const krb5_enctype* KRB5_LIB_CALL krb5_kerberos_enctypes ( krb5_context  context)

Returns the list of Kerberos encryption types sorted in order of most preferred to least preferred encryption type. Note that some encryption types might be disabled, so you need to check with krb5_enctype_valid() before using the encryption type.

Returns
list of enctypes, terminated with ETYPE_NULL. Its a static array completed into the Kerberos library so the content doesn't need to be freed.

◆ krb5_krbhst_get_addrinfo()

KRB5_LIB_FUNCTION krb5_error_code KRB5_LIB_CALL krb5_krbhst_get_addrinfo ( krb5_context  context,
krb5_krbhst_info *  host,
struct addrinfo **  ai 
)

Return an `struct addrinfo *' for a KDC host.

Returns an the struct addrinfo in in that corresponds to the information in `host'. free:ing is handled by krb5_krbhst_free, so the returned ai must not be released.

◆ krb5_prepend_config_files_default()

KRB5_LIB_FUNCTION krb5_error_code KRB5_LIB_CALL krb5_prepend_config_files_default ( const char *  filelist,
char ***  pfilenames 
)

Prepend the filename to the global configuration list.

Parameters
filelista filename to add to the default list of filename
pfilenamesreturn array of filenames, should be freed with krb5_free_config_files().
Returns
Returns 0 to indicate success. Otherwise an kerberos et error code is returned, see krb5_get_error_message().

◆ krb5_set_config_files()

KRB5_LIB_FUNCTION krb5_error_code KRB5_LIB_CALL krb5_set_config_files ( krb5_context  context,
char **  filenames 
)

Reinit the context from a new set of filenames.

Parameters
contextcontext to add configuration too.
filenamesarray of filenames, end of list is indicated with a NULL filename.
Returns
Returns 0 to indicate success. Otherwise an kerberos et error code is returned, see krb5_get_error_message().

◆ krb5_set_default_in_tkt_etypes()

KRB5_LIB_FUNCTION krb5_error_code KRB5_LIB_CALL krb5_set_default_in_tkt_etypes ( krb5_context  context,
const krb5_enctype *  etypes 
)

Set the default encryption types that will be use in communcation with the KDC, clients and servers.

Parameters
contextKerberos 5 context.
etypesEncryption types, array terminated with ETYPE_NULL (0). A value of NULL resets the encryption types to the defaults set in the configuration file.
Returns
Returns 0 to indicate success. Otherwise an kerberos et error code is returned, see krb5_get_error_message().

◆ krb5_set_dns_canonicalize_hostname()

KRB5_LIB_FUNCTION void KRB5_LIB_CALL krb5_set_dns_canonicalize_hostname ( krb5_context  context,
krb5_boolean  flag 
)

Set if the library should use DNS to canonicalize hostnames.

Parameters
contextKerberos 5 context.
flagif its dns canonicalizion is used or not.

◆ krb5_set_extra_addresses()

KRB5_LIB_FUNCTION krb5_error_code KRB5_LIB_CALL krb5_set_extra_addresses ( krb5_context  context,
const krb5_addresses *  addresses 
)

Set extra address to the address list that the library will add to the client's address list when communicating with the KDC.

Parameters
contextKerberos 5 context.
addressesaddreses to set
Returns
Returns 0 to indicate success. Otherwise an kerberos et error code is returned, see krb5_get_error_message().

◆ krb5_set_fcache_version()

KRB5_LIB_FUNCTION krb5_error_code KRB5_LIB_CALL krb5_set_fcache_version ( krb5_context  context,
int  version 
)

Set version of fcache that the library should use.

Parameters
contextKerberos 5 context.
versionversion number.
Returns
Returns 0 to indicate success. Otherwise an kerberos et error code is returned, see krb5_get_error_message().

◆ krb5_set_home_dir_access()

KRB5_LIB_FUNCTION krb5_boolean KRB5_LIB_CALL krb5_set_home_dir_access ( krb5_context  context,
krb5_boolean  allow 
)

Enable and disable home directory access on either the global state or the krb5_context state. By calling krb5_set_home_dir_access() with context set to NULL, the global state is configured otherwise the state for the krb5_context is modified.

For home directory access to be allowed, both the global state and the krb5_context state have to be allowed.

Parameters
contexta Kerberos 5 context or NULL
allowallow if TRUE home directory
Returns
the old value

◆ krb5_set_ignore_addresses()

KRB5_LIB_FUNCTION krb5_error_code KRB5_LIB_CALL krb5_set_ignore_addresses ( krb5_context  context,
const krb5_addresses *  addresses 
)

Set extra addresses to ignore when fetching addresses from the underlaying operating system.

Parameters
contextKerberos 5 context.
addressesaddreses to ignore
Returns
Returns 0 to indicate success. Otherwise an kerberos et error code is returned, see krb5_get_error_message().

◆ krb5_set_kdc_sec_offset()

KRB5_LIB_FUNCTION krb5_error_code KRB5_LIB_CALL krb5_set_kdc_sec_offset ( krb5_context  context,
int32_t  sec,
int32_t  usec 
)

Set current offset in time to the KDC.

Parameters
contextKerberos 5 context.
secseconds part of offset.
usecmicro seconds part of offset.
Returns
returns zero

◆ krb5_set_max_time_skew()

KRB5_LIB_FUNCTION void KRB5_LIB_CALL krb5_set_max_time_skew ( krb5_context  context,
time_t  t 
)

Set max time skew allowed.

Parameters
contextKerberos 5 context.
ttimeskew in seconds.

◆ krb5_set_password()

KRB5_LIB_FUNCTION krb5_error_code KRB5_LIB_CALL krb5_set_password ( krb5_context  context,
krb5_creds *  creds,
const char *  newpw,
krb5_principal  targprinc,
int *  result_code,
krb5_data *  result_code_string,
krb5_data *  result_string 
)

Change password using creds.

Parameters
contexta Keberos context
credsThe initial kadmin/passwd for the principal or an admin principal
newpwThe new password to set
targprincif unset, the default principal is used.
result_codeResult code, KRB5_KPASSWD_SUCCESS is when password is changed.
result_code_stringbinary message from the server, contains at least the result_code.
result_stringA message from the kpasswd service or the library in human printable form. The string is NUL terminated.
Returns
On sucess and *result_code is KRB5_KPASSWD_SUCCESS, the password is changed.

@

◆ krb5_set_real_time()

KRB5_LIB_FUNCTION krb5_error_code KRB5_LIB_CALL krb5_set_real_time ( krb5_context  context,
krb5_timestamp  sec,
int32_t  usec 
)

Set the absolute time that the caller knows the kdc has so the kerberos library can calculate the relative diffrence beteen the KDC time and local system time.

Parameters
contextKeberos 5 context.
secThe applications new of "now" in seconds
usecThe applications new of "now" in micro seconds
Returns
Kerberos 5 error code, see krb5_get_error_message().

If the caller passes in a negative usec, its assumed to be unknown and the function will use the current time usec.

◆ krb5_set_use_admin_kdc()

KRB5_LIB_FUNCTION void KRB5_LIB_CALL krb5_set_use_admin_kdc ( krb5_context  context,
krb5_boolean  flag 
)

Make the kerberos library default to the admin KDC.

Parameters
contextKerberos 5 context.
flagboolean flag to select if the use the admin KDC or not.

◆ krb5_ticket_get_authorization_data_type()

KRB5_LIB_FUNCTION krb5_error_code KRB5_LIB_CALL krb5_ticket_get_authorization_data_type ( krb5_context  context,
krb5_ticket *  ticket,
int  type,
krb5_data *  data 
)

Extract the authorization data type of type from the ticket. Store the field in data. This function is to use for kerberos applications.

Parameters
contexta Kerberos 5 context
ticketKerberos ticket
typetype to fetch
datareturned data, free with krb5_data_free()

◆ krb5_ticket_get_client()

KRB5_LIB_FUNCTION krb5_error_code KRB5_LIB_CALL krb5_ticket_get_client ( krb5_context  context,
const krb5_ticket *  ticket,
krb5_principal *  client 
)

Return client principal in ticket

Parameters
contexta Kerberos 5 context
ticketticket to copy
clientclient principal, free with krb5_free_principal()
Returns
Returns 0 to indicate success. Otherwise an kerberos et error code is returned, see krb5_get_error_message().

◆ krb5_ticket_get_endtime()

KRB5_LIB_FUNCTION time_t KRB5_LIB_CALL krb5_ticket_get_endtime ( krb5_context  context,
const krb5_ticket *  ticket 
)

Return end time of ticket

Parameters
contexta Kerberos 5 context
ticketticket to copy
Returns
end time of ticket

◆ krb5_ticket_get_server()

KRB5_LIB_FUNCTION krb5_error_code KRB5_LIB_CALL krb5_ticket_get_server ( krb5_context  context,
const krb5_ticket *  ticket,
krb5_principal *  server 
)

Return server principal in ticket

Parameters
contexta Kerberos 5 context
ticketticket to copy
serverserver principal, free with krb5_free_principal()
Returns
Returns 0 to indicate success. Otherwise an kerberos et error code is returned, see krb5_get_error_message().

Generated on Fri Jun 7 2019 02:49:56 for HeimdalKerberos5library by doxygen 1.8.13