keyhole logo

Functions
Heimdal Kerberos 5 address functions

Functions

KRB5_LIB_FUNCTION krb5_error_code KRB5_LIB_CALL krb5_sockaddr2address (krb5_context context, const struct sockaddr *sa, krb5_address *addr)
 
KRB5_LIB_FUNCTION krb5_error_code KRB5_LIB_CALL krb5_sockaddr2port (krb5_context context, const struct sockaddr *sa, int16_t *port)
 
KRB5_LIB_FUNCTION krb5_error_code KRB5_LIB_CALL krb5_addr2sockaddr (krb5_context context, const krb5_address *addr, struct sockaddr *sa, krb5_socklen_t *sa_size, int port)
 
KRB5_LIB_FUNCTION size_t KRB5_LIB_CALL krb5_max_sockaddr_size (void)
 
KRB5_LIB_FUNCTION krb5_boolean KRB5_LIB_CALL krb5_sockaddr_uninteresting (const struct sockaddr *sa)
 
KRB5_LIB_FUNCTION krb5_error_code KRB5_LIB_CALL krb5_h_addr2sockaddr (krb5_context context, int af, const char *addr, struct sockaddr *sa, krb5_socklen_t *sa_size, int port)
 
KRB5_LIB_FUNCTION krb5_error_code KRB5_LIB_CALL krb5_h_addr2addr (krb5_context context, int af, const char *haddr, krb5_address *addr)
 
KRB5_LIB_FUNCTION krb5_error_code KRB5_LIB_CALL krb5_anyaddr (krb5_context context, int af, struct sockaddr *sa, krb5_socklen_t *sa_size, int port)
 
KRB5_LIB_FUNCTION krb5_error_code KRB5_LIB_CALL krb5_print_address (const krb5_address *addr, char *str, size_t len, size_t *ret_len)
 
KRB5_LIB_FUNCTION krb5_error_code KRB5_LIB_CALL krb5_parse_address (krb5_context context, const char *string, krb5_addresses *addresses)
 
KRB5_LIB_FUNCTION int KRB5_LIB_CALL krb5_address_order (krb5_context context, const krb5_address *addr1, const krb5_address *addr2)
 
KRB5_LIB_FUNCTION krb5_boolean KRB5_LIB_CALL krb5_address_compare (krb5_context context, const krb5_address *addr1, const krb5_address *addr2)
 
KRB5_LIB_FUNCTION krb5_boolean KRB5_LIB_CALL krb5_address_search (krb5_context context, const krb5_address *addr, const krb5_addresses *addrlist)
 
KRB5_LIB_FUNCTION krb5_error_code KRB5_LIB_CALL krb5_free_address (krb5_context context, krb5_address *address)
 
KRB5_LIB_FUNCTION krb5_error_code KRB5_LIB_CALL krb5_free_addresses (krb5_context context, krb5_addresses *addresses)
 
KRB5_LIB_FUNCTION krb5_error_code KRB5_LIB_CALL krb5_copy_address (krb5_context context, const krb5_address *inaddr, krb5_address *outaddr)
 
KRB5_LIB_FUNCTION krb5_error_code KRB5_LIB_CALL krb5_copy_addresses (krb5_context context, const krb5_addresses *inaddr, krb5_addresses *outaddr)
 
KRB5_LIB_FUNCTION krb5_error_code KRB5_LIB_CALL krb5_append_addresses (krb5_context context, krb5_addresses *dest, const krb5_addresses *source)
 
KRB5_LIB_FUNCTION krb5_error_code KRB5_LIB_CALL krb5_make_addrport (krb5_context context, krb5_address **res, const krb5_address *addr, int16_t port)
 
KRB5_LIB_FUNCTION krb5_error_code KRB5_LIB_CALL krb5_address_prefixlen_boundary (krb5_context context, const krb5_address *inaddr, unsigned long prefixlen, krb5_address *low, krb5_address *high)
 

Detailed Description

Function Documentation

◆ krb5_addr2sockaddr()

KRB5_LIB_FUNCTION krb5_error_code KRB5_LIB_CALL krb5_addr2sockaddr ( krb5_context  context,
const krb5_address *  addr,
struct sockaddr *  sa,
krb5_socklen_t *  sa_size,
int  port 
)

krb5_addr2sockaddr sets the "struct sockaddr sockaddr" from addr and port. The argument sa_size should initially contain the size of the sa and after the call, it will contain the actual length of the address. In case of the sa is too small to fit the whole address, the up to *sa_size will be stored, and then *sa_size will be set to the required length.

Parameters
contexta Keberos context
addrthe address to copy the from
sathe struct sockaddr that will be filled in
sa_sizepointer to length of sa, and after the call, it will contain the actual length of the address.
portset port in sa.
Returns
Return an error code or 0. Will return KRB5_PROG_ATYPE_NOSUPP in case address type is not supported.

◆ krb5_address_compare()

KRB5_LIB_FUNCTION krb5_boolean KRB5_LIB_CALL krb5_address_compare ( krb5_context  context,
const krb5_address *  addr1,
const krb5_address *  addr2 
)

krb5_address_compare compares the addresses addr1 and addr2. Returns TRUE if the two addresses are the same.

Parameters
contexta Keberos context
addr1address to compare
addr2address to compare
Returns
Return an TRUE is the address are the same FALSE if not

◆ krb5_address_order()

KRB5_LIB_FUNCTION int KRB5_LIB_CALL krb5_address_order ( krb5_context  context,
const krb5_address *  addr1,
const krb5_address *  addr2 
)

krb5_address_order compares the addresses addr1 and addr2 so that it can be used for sorting addresses. If the addresses are the same address krb5_address_order will return 0. Behavies like memcmp(2).

Parameters
contexta Keberos context
addr1krb5_address to compare
addr2krb5_address to compare
Returns
< 0 if address addr1 in "less" then addr2. 0 if addr1 and addr2 is the same address, > 0 if addr2 is "less" then addr1.

◆ krb5_address_prefixlen_boundary()

KRB5_LIB_FUNCTION krb5_error_code KRB5_LIB_CALL krb5_address_prefixlen_boundary ( krb5_context  context,
const krb5_address *  inaddr,
unsigned long  prefixlen,
krb5_address *  low,
krb5_address *  high 
)

Calculate the boundary addresses of ‘inaddr’/‘prefixlen’ and store them in ‘low’ and ‘high’.

Parameters
contexta Keberos context
inaddraddress in prefixlen that the bondery searched
prefixlenwidth of boundery
lowlowest address
highhighest address
Returns
Return an error code or 0.

◆ krb5_address_search()

KRB5_LIB_FUNCTION krb5_boolean KRB5_LIB_CALL krb5_address_search ( krb5_context  context,
const krb5_address *  addr,
const krb5_addresses *  addrlist 
)

krb5_address_search checks if the address addr is a member of the address set list addrlist .

Parameters
contexta Keberos context.
addraddress to search for.
addrlistlist of addresses to look in for addr.
Returns
Return an error code or 0.

◆ krb5_anyaddr()

KRB5_LIB_FUNCTION krb5_error_code KRB5_LIB_CALL krb5_anyaddr ( krb5_context  context,
int  af,
struct sockaddr *  sa,
krb5_socklen_t *  sa_size,
int  port 
)

krb5_anyaddr fills in a "struct sockaddr sa" that can be used to bind(2) to. The argument sa_size should initially contain the size of the sa, and after the call, it will contain the actual length of the address.

Parameters
contexta Keberos context
afaddress family
sasockaddr
sa_sizelenght of sa.
portfor to fill into sa.
Returns
Return an error code or 0.

◆ krb5_append_addresses()

KRB5_LIB_FUNCTION krb5_error_code KRB5_LIB_CALL krb5_append_addresses ( krb5_context  context,
krb5_addresses *  dest,
const krb5_addresses *  source 
)

krb5_append_addresses adds the set of addresses in source to dest. While copying the addresses, duplicates are also sorted out.

Parameters
contexta Keberos context
destdestination of copy operation
sourceadresses that are going to be added to dest
Returns
Return an error code or 0.

◆ krb5_copy_address()

KRB5_LIB_FUNCTION krb5_error_code KRB5_LIB_CALL krb5_copy_address ( krb5_context  context,
const krb5_address *  inaddr,
krb5_address *  outaddr 
)

krb5_copy_address copies the content of address inaddr to outaddr.

Parameters
contexta Keberos context
inaddrpointer to source address
outaddrpointer to destination address
Returns
Return an error code or 0.

◆ krb5_copy_addresses()

KRB5_LIB_FUNCTION krb5_error_code KRB5_LIB_CALL krb5_copy_addresses ( krb5_context  context,
const krb5_addresses *  inaddr,
krb5_addresses *  outaddr 
)

krb5_copy_addresses copies the content of addresses inaddr to outaddr.

Parameters
contexta Keberos context
inaddrpointer to source addresses
outaddrpointer to destination addresses
Returns
Return an error code or 0.

◆ krb5_free_address()

KRB5_LIB_FUNCTION krb5_error_code KRB5_LIB_CALL krb5_free_address ( krb5_context  context,
krb5_address *  address 
)

krb5_free_address frees the data stored in the address that is alloced with any of the krb5_address functions.

Parameters
contexta Keberos context
addressaddresss to be freed.
Returns
Return an error code or 0.

◆ krb5_free_addresses()

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

krb5_free_addresses frees the data stored in the address that is alloced with any of the krb5_address functions.

Parameters
contexta Keberos context
addressesaddressses to be freed.
Returns
Return an error code or 0.

◆ krb5_h_addr2addr()

KRB5_LIB_FUNCTION krb5_error_code KRB5_LIB_CALL krb5_h_addr2addr ( krb5_context  context,
int  af,
const char *  haddr,
krb5_address *  addr 
)

krb5_h_addr2addr works like krb5_h_addr2sockaddr with the exception that it operates on a krb5_address instead of a struct sockaddr.

Parameters
contexta Keberos context
afaddress family
haddrhost address from struct hostent.
addrreturned krb5_address.
Returns
Return an error code or 0.

◆ krb5_h_addr2sockaddr()

KRB5_LIB_FUNCTION krb5_error_code KRB5_LIB_CALL krb5_h_addr2sockaddr ( krb5_context  context,
int  af,
const char *  addr,
struct sockaddr *  sa,
krb5_socklen_t *  sa_size,
int  port 
)

krb5_h_addr2sockaddr initializes a "struct sockaddr sa" from af and the "struct hostent" (see gethostbyname(3) ) h_addr_list component. The argument sa_size should initially contain the size of the sa, and after the call, it will contain the actual length of the address.

Parameters
contexta Keberos context
afaddresses
addraddress
sareturned struct sockaddr
sa_sizesize of sa
portport to set in sa.
Returns
Return an error code or 0.

◆ krb5_make_addrport()

KRB5_LIB_FUNCTION krb5_error_code KRB5_LIB_CALL krb5_make_addrport ( krb5_context  context,
krb5_address **  res,
const krb5_address *  addr,
int16_t  port 
)

Create an address of type KRB5_ADDRESS_ADDRPORT from (addr, port)

Parameters
contexta Keberos context
resbuilt address from addr/port
addraddress to use
portport to use
Returns
Return an error code or 0.

◆ krb5_max_sockaddr_size()

KRB5_LIB_FUNCTION size_t KRB5_LIB_CALL krb5_max_sockaddr_size ( void  )

krb5_max_sockaddr_size returns the max size of the .Li struct sockaddr that the Kerberos library will return.

Returns
Return an size_t of the maximum struct sockaddr.

◆ krb5_parse_address()

KRB5_LIB_FUNCTION krb5_error_code KRB5_LIB_CALL krb5_parse_address ( krb5_context  context,
const char *  string,
krb5_addresses *  addresses 
)

krb5_parse_address returns the resolved hostname in string to the krb5_addresses addresses .

Parameters
contexta Keberos context
string
addresses
Returns
Return an error code or 0.

◆ krb5_print_address()

KRB5_LIB_FUNCTION krb5_error_code KRB5_LIB_CALL krb5_print_address ( const krb5_address *  addr,
char *  str,
size_t  len,
size_t *  ret_len 
)

krb5_print_address prints the address in addr to the string string that have the length len. If ret_len is not NULL, it will be filled with the length of the string if size were unlimited (not including the final NUL) .

Parameters
addraddress to be printed
strpointer string to print the address into
lenlength that will fit into area pointed to by "str".
ret_lenreturn length the str.
Returns
Return an error code or 0.

◆ krb5_sockaddr2address()

KRB5_LIB_FUNCTION krb5_error_code KRB5_LIB_CALL krb5_sockaddr2address ( krb5_context  context,
const struct sockaddr *  sa,
krb5_address *  addr 
)

krb5_sockaddr2address stores a address a "struct sockaddr" sa in the krb5_address addr.

Parameters
contexta Keberos context
saa struct sockaddr to extract the address from
addran Kerberos 5 address to store the address in.
Returns
Return an error code or 0.

◆ krb5_sockaddr2port()

KRB5_LIB_FUNCTION krb5_error_code KRB5_LIB_CALL krb5_sockaddr2port ( krb5_context  context,
const struct sockaddr *  sa,
int16_t *  port 
)

krb5_sockaddr2port extracts a port (if possible) from a "struct sockaddr.

Parameters
contexta Keberos context
saa struct sockaddr to extract the port from
porta pointer to an int16_t store the port in.
Returns
Return an error code or 0. Will return KRB5_PROG_ATYPE_NOSUPP in case address type is not supported.

◆ krb5_sockaddr_uninteresting()

KRB5_LIB_FUNCTION krb5_boolean KRB5_LIB_CALL krb5_sockaddr_uninteresting ( const struct sockaddr *  sa)

krb5_sockaddr_uninteresting returns TRUE for all .Fa sa that the kerberos library thinks are uninteresting. One example are link local addresses.

Parameters
sapointer to struct sockaddr that might be interesting.
Returns
Return a non zero for uninteresting addresses.

Generated on Tue Nov 15 2022 14:04:26 for Heimdal Kerberos 5 library by doxygen 1.9.1