DOC HOME SITE MAP MAN PAGES GNU INFO SEARCH PRINT BOOK
 

krb5_ret_address(3)





NAME

     krb5_storage, krb5_storage_emem, krb5_storage_from_data,
     krb5_storage_from_fd, krb5_storage_from_mem, krb5_storage_set_flags,
     krb5_storage_clear_flags, krb5_storage_is_flags,
     krb5_storage_set_byteorder, krb5_storage_get_byteorder,
     krb5_storage_set_eof_code, krb5_storage_seek, krb5_storage_read,
     krb5_storage_write, krb5_storage_free, krb5_storage_to_data,
     krb5_store_int32, krb5_ret_int32, krb5_store_uint32, krb5_ret_uint32,
     krb5_store_int16, krb5_ret_int16, krb5_store_uint16, krb5_ret_uint16,
     krb5_store_int8, krb5_ret_int8, krb5_store_uint8, krb5_ret_uint8,
     krb5_store_data, krb5_ret_data, krb5_store_string, krb5_ret_string,
     krb5_store_stringnl, krb5_ret_stringnl, krb5_store_stringz,
     krb5_ret_stringz, krb5_store_principal, krb5_ret_principal,
     krb5_store_keyblock, krb5_ret_keyblock, krb5_store_times, krb5_ret_times,
     krb5_store_address, krb5_ret_address, krb5_store_addrs, krb5_ret_addrs,
     krb5_store_authdata, krb5_ret_authdata, krb5_store_creds, krb5_ret_creds
     -- operates on the Kerberos datatype krb5_storage


LIBRARY

     Kerberos 5 Library (libkrb5, -lkrb5)


SYNOPSIS

     #include <krb5.h>

     struct krb5_storage;

     krb5_storage *
     krb5_storage_from_fd(int fd);

     krb5_storage *
     krb5_storage_emem(void);

     krb5_storage *
     krb5_storage_from_mem(void *buf, size_t len);

     krb5_storage *
     krb5_storage_from_data(krb5_data *data);

     void
     krb5_storage_set_flags(krb5_storage *sp, krb5_flags flags);

     void
     krb5_storage_clear_flags(krb5_storage *sp, krb5_flags flags);

     krb5_boolean
     krb5_storage_is_flags(krb5_storage *sp, krb5_flags flags);

     void
     krb5_storage_set_byteorder(krb5_storage *sp, krb5_flags byteorder);

     krb5_flags
     krb5_storage_get_byteorder(krb5_storage *sp, krb5_flags byteorder);

     void
     krb5_storage_set_eof_code(krb5_storage *sp, int code);

     off_t
     krb5_storage_seek(krb5_storage *sp, off_t offset, int whence);

     krb5_ssize_t
     krb5_storage_read(krb5_storage *sp, void *buf, size_t len);

     krb5_ssize_t
     krb5_storage_write(krb5_storage *sp, const void *buf, size_t len);

     krb5_error_code
     krb5_storage_free(krb5_storage *sp);

     krb5_error_code
     krb5_storage_to_data(krb5_storage *sp, krb5_data *data);

     krb5_error_code
     krb5_store_int32(krb5_storage *sp, int32_t value);

     krb5_error_code
     krb5_ret_int32(krb5_storage *sp, int32_t *value);

     krb5_error_code
     krb5_ret_uint32(krb5_storage *sp, uint32_t *value);

     krb5_error_code
     krb5_store_uint32(krb5_storage *sp, uint32_t value);

     krb5_error_code
     krb5_store_int16(krb5_storage *sp, int16_t value);

     krb5_error_code
     krb5_ret_int16(krb5_storage *sp, int16_t *value);

     krb5_error_code
     krb5_store_uint16(krb5_storage *sp, uint16_t value);

     krb5_error_code
     krb5_ret_uint16(krb5_storage *sp, u_int16_t *value);

     krb5_error_code
     krb5_store_int8(krb5_storage *sp, int8_t value);

     krb5_error_code
     krb5_ret_int8(krb5_storage *sp, int8_t *value);

     krb5_error_code
     krb5_store_uint8(krb5_storage *sp, u_int8_t value);

     krb5_error_code
     krb5_ret_uint8(krb5_storage *sp, u_int8_t *value);

     krb5_error_code
     krb5_store_data(krb5_storage *sp, krb5_data data);

     krb5_error_code
     krb5_ret_data(krb5_storage *sp, krb5_data *data);

     krb5_error_code
     krb5_store_string(krb5_storage *sp, const char *s);

     krb5_error_code
     krb5_ret_string(krb5_storage *sp, char **string);

     krb5_error_code
     krb5_store_stringnl(krb5_storage *sp, const char *s);

     krb5_error_code
     krb5_ret_stringnl(krb5_storage *sp, char **string);

     krb5_error_code
     krb5_store_stringz(krb5_storage *sp, const char *s);

     krb5_error_code
     krb5_ret_stringz(krb5_storage *sp, char **string);

     krb5_error_code
     krb5_store_principal(krb5_storage *sp, krb5_const_principal p);

     krb5_error_code
     krb5_ret_principal(krb5_storage *sp, krb5_principal *princ);

     krb5_error_code
     krb5_store_keyblock(krb5_storage *sp, krb5_keyblock p);

     krb5_error_code
     krb5_ret_keyblock(krb5_storage *sp, krb5_keyblock *p);

     krb5_error_code
     krb5_store_times(krb5_storage *sp, krb5_times times);

     krb5_error_code
     krb5_ret_times(krb5_storage *sp, krb5_times *times);

     krb5_error_code
     krb5_store_address(krb5_storage *sp, krb5_address p);

     krb5_error_code
     krb5_ret_address(krb5_storage *sp, krb5_address *adr);

     krb5_error_code
     krb5_store_addrs(krb5_storage *sp, krb5_addresses p);

     krb5_error_code
     krb5_ret_addrs(krb5_storage *sp, krb5_addresses *adr);

     krb5_error_code
     krb5_store_authdata(krb5_storage *sp, krb5_authdata auth);

     krb5_error_code
     krb5_ret_authdata(krb5_storage *sp, krb5_authdata *auth);

     krb5_error_code
     krb5_store_creds(krb5_storage *sp, krb5_creds *creds);

     krb5_error_code
     krb5_ret_creds(krb5_storage *sp, krb5_creds *creds);


DESCRIPTION

     The krb5_storage structure holds a storage element that is used for data
     manipulation.  The structure contains no public accessible elements.

     krb5_storage_emem() create a memory based krb5 storage unit that dynam-
     icly resized to the ammount of data stored in.  The storage never returns
     errors, on memory allocation errors exit(3) will be called.

     krb5_storage_from_data() create a krb5 storage unit that will read is
     data from a krb5_data.  There is no copy made of the data, so the caller
     must not free data until the storage is freed.

     krb5_storage_from_fd() create a krb5 storage unit that will read is data
     from a file descriptor.  The descriptor must be seekable if
     krb5_storage_seek() is used.  Caller must not free the file descriptor
     before the storage is freed.

     krb5_storage_from_mem() create a krb5 storage unit that will read is data
     from a memory region.  There is no copy made of the data, so the caller
     must not free data until the storage is freed.

     krb5_storage_set_flags() and krb5_storage_clear_flags() modifies the
     behavior of the storage functions.  krb5_storage_is_flags() tests if the
     flags are set on the krb5_storage.  Valid flags to set, is and clear is
     are:

           KRB5_STORAGE_PRINCIPAL_WRONG_NUM_COMPONENTS
                       Stores the number of principal componets one too many
                       when storing principal namees, used for compatibility
                       with version 1 of file keytabs and version 1 of file
                       credential caches.
           KRB5_STORAGE_PRINCIPAL_NO_NAME_TYPE
                       Doesn't store the name type in when storing a principal
                       name, used for compatibility with version 1 of file
                       keytabs and version 1 of file credential caches.
           KRB5_STORAGE_KEYBLOCK_KEYTYPE_TWICE
                       Stores the keyblock type twice storing a keyblock, used
                       for compatibility version 3 of file credential caches.
           KRB5_STORAGE_BYTEORDER_MASK
                       bitmask that can be used to and out what type of byte
                       order order is used.
           KRB5_STORAGE_BYTEORDER_BE
                       Store integers in in big endian byte order, this is the
                       default mode.
           KRB5_STORAGE_BYTEORDER_LE
                       Store integers in in little endian byte order.
           KRB5_STORAGE_BYTEORDER_HOST
                       Stores the integers in host byte order, used for com-
                       patibility with version 1 of file keytabs and version 1
                       and 2 of file credential caches.
           KRB5_STORAGE_CREDS_FLAGS_WRONG_BITORDER
                       Store the credential flags in a krb5_creds in the
                       reverse bit order.

     krb5_storage_set_byteorder() and krb5_storage_get_byteorder() modifies
     the byte order used in the storage for integers.  The flags used is same
     as above.  The valid flags are KRB5_STORAGE_BYTEORDER_BE,
     KRB5_STORAGE_BYTEORDER_LE and KRB5_STORAGE_BYTEORDER_HOST.

     krb5_storage_set_eof_code() sets the error code that will be returned on
     end of file condition to code.

     krb5_storage_seek() seeks offset bytes in the storage sp.  The whence
     argument is one of
           SEEK_SET  offset is from begining of storage.
           SEEK_CUR  offset is relative from current offset.
           SEEK_END  offset is from end of storage.

     krb5_storage_read() reads len (or less bytes in case of end of file) into
     buf from the current offset in the storage sp.

     krb5_storage_write() writes len or (less bytes in case of end of file)
     from buf from the current offset in the storage sp.

     krb5_storage_free() frees the storage sp.

     krb5_storage_to_data() converts the data in storage sp into a krb5_data
     structure.  data must be freed with krb5_data_free() by the caller when
     done with the data.

     All krb5_store and krb5_ret functions move the current offset forward
     when the functions returns.

     krb5_store_int32(), krb5_ret_int32(), krb5_store_uint32(),
     krb5_ret_uint32(), krb5_store_int16(), krb5_ret_int16(),
     krb5_store_uint16(), krb5_ret_uint16(), krb5_store_int8(),
     krb5_ret_int8() krb5_store_uint8(), and krb5_ret_uint8() stores and reads
     an integer from sp in the byte order specified by the flags set on the
     sp.

     krb5_store_data() and krb5_ret_data() store and reads a krb5_data.  The
     length of the data is stored with krb5_store_int32().

     krb5_store_string() and krb5_ret_string() store and reads a string by
     storing the length of the string with krb5_store_int32() followed by the
     string itself.

     krb5_store_stringnl() and krb5_ret_stringnl() store and reads a string by
     storing string followed by a '0.

     krb5_store_stringz() and krb5_ret_stringz() store and reads a string by
     storing string followed by a NUL.

     krb5_store_principal() and krb5_ret_principal() store and reads a princi-
     pal.

     krb5_store_keyblock() and krb5_ret_keyblock() store and reads a
     krb5_keyblock.

     krb5_store_times() krb5_ret_times() store and reads krb5_times structure
     .

     krb5_store_address() and krb5_ret_address() store and reads a
     krb5_address.

     krb5_store_addrs() and krb5_ret_addrs() store and reads a krb5_addresses.

     krb5_store_authdata() and krb5_ret_authdata() store and reads a
     krb5_authdata.

     krb5_store_creds() and krb5_ret_creds() store and reads a krb5_creds.


SEE ALSO

     krb5(3), krb5_data(3), kerberos(8)

HEIMDAL                          Aug 18, 2006                          HEIMDAL

Man(1) output converted with man2html