packages icon



 Heimdal GSS-API functions(3)   Version 1.5.2   Heimdal GSS-API functions(3)
 HeimdalGSS-APIlibrary                                 HeimdalGSS-APIlibrary

                                 11 Jan 2012



 NAME
      Heimdal GSS-API functions -

    Functions
      GSSAPI_LIB_FUNCTION OM_uint32 GSSAPI_LIB_CALL gss_add_oid_set_member
          (OM_uint32 *minor_status, const gss_OID member_oid, gss_OID_set
          *oid_set)
      GSSAPI_LIB_FUNCTION OM_uint32 GSSAPI_LIB_CALL gss_wrap_iov (OM_uint32
          *minor_status, gss_ctx_id_t context_handle, int conf_req_flag,
          gss_qop_t qop_req, int *conf_state, gss_iov_buffer_desc *iov, int
          iov_count)
      GSSAPI_LIB_FUNCTION OM_uint32 GSSAPI_LIB_CALL gss_unwrap_iov
          (OM_uint32 *minor_status, gss_ctx_id_t context_handle, int
          *conf_state, gss_qop_t *qop_state, gss_iov_buffer_desc *iov, int
          iov_count)
      GSSAPI_LIB_FUNCTION OM_uint32 GSSAPI_LIB_CALL gss_wrap_iov_length
          (OM_uint32 *minor_status, gss_ctx_id_t context_handle, int
          conf_req_flag, gss_qop_t qop_req, int *conf_state,
          gss_iov_buffer_desc *iov, int iov_count)
      GSSAPI_LIB_FUNCTION OM_uint32 GSSAPI_LIB_CALL gss_release_iov_buffer
          (OM_uint32 *minor_status, gss_iov_buffer_desc *iov, int iov_count)
      GSSAPI_LIB_FUNCTION OM_uint32 GSSAPI_LIB_CALL gss_canonicalize_name
          (OM_uint32 *minor_status, const gss_name_t input_name, const
          gss_OID mech_type, gss_name_t *output_name)
      GSSAPI_LIB_FUNCTION OM_uint32 GSSAPI_LIB_CALL gss_import_name
          (OM_uint32 *minor_status, const gss_buffer_t input_name_buffer,
          const gss_OID input_name_type, gss_name_t *output_name)
      GSSAPI_LIB_FUNCTION OM_uint32 GSSAPI_LIB_CALL gss_init_sec_context
          (OM_uint32 *minor_status, const gss_cred_id_t
          initiator_cred_handle, gss_ctx_id_t *context_handle, const
          gss_name_t target_name, const gss_OID input_mech_type, OM_uint32
          req_flags, OM_uint32 time_req, const gss_channel_bindings_t
          input_chan_bindings, const gss_buffer_t input_token, gss_OID
          *actual_mech_type, gss_buffer_t output_token, OM_uint32
          *ret_flags, OM_uint32 *time_rec)
      GSSAPI_LIB_FUNCTION OM_uint32 GSSAPI_LIB_CALL
          gss_inquire_saslname_for_mech (OM_uint32 *minor_status, const
          gss_OID desired_mech, gss_buffer_t sasl_mech_name, gss_buffer_t
          mech_name, gss_buffer_t mech_description)
      GSSAPI_LIB_FUNCTION OM_uint32 GSSAPI_LIB_CALL
          gss_inquire_attrs_for_mech (OM_uint32 *minor_status, gss_const_OID
          mech, gss_OID_set *mech_attr, gss_OID_set *known_mech_attrs)
      GSSAPI_LIB_FUNCTION int GSSAPI_LIB_CALL gss_oid_equal (gss_const_OID
          a, gss_const_OID b)
      GSSAPI_LIB_FUNCTION OM_uint32 GSSAPI_LIB_CALL gss_release_cred
          (OM_uint32 *minor_status, gss_cred_id_t *cred_handle)
      GSSAPI_LIB_FUNCTION OM_uint32 GSSAPI_LIB_CALL gss_release_name
          (OM_uint32 *minor_status, gss_name_t *input_name)
      GSSAPI_LIB_FUNCTION OM_uint32 GSSAPI_LIB_CALL gss_wrap (OM_uint32



                                    - 1 -     Formatted:  September 17, 2024






 Heimdal GSS-API functions(3)   Version 1.5.2   Heimdal GSS-API functions(3)
 HeimdalGSS-APIlibrary                                 HeimdalGSS-APIlibrary

                                 11 Jan 2012



          *minor_status, const gss_ctx_id_t context_handle, int
          conf_req_flag, gss_qop_t qop_req, const gss_buffer_t
          input_message_buffer, int *conf_state, gss_buffer_t
          output_message_buffer)

    Variables
      gss_OID_desc GSSAPI_LIB_FUNCTION __gss_c_attr_stream_sizes_oid_desc

 Detailed Description
 Function Documentation
    GSSAPI_LIB_FUNCTION OM_uint32 GSSAPI_LIB_CALL gss_add_oid_set_member
      (OM_uint32 * minor_status, const gss_OID member_oid, gss_OID_set *
      oid_set)
      Add a oid to the oid set, function does not make a copy of the oid, so
      the pointer to member_oid needs to be stable for the whole time
      oid_set is used.

      If there is a duplicate member of the oid, the new member is not added
      to to the set.

      Parameters:
          minor_status minor status code.
          member_oid member to add to the oid set
          oid_set oid set to add the member too

      Returns:
          a gss_error code, see gss_display_status() about printing the
          error code.

    GSSAPI_LIB_FUNCTION OM_uint32 GSSAPI_LIB_CALL gss_canonicalize_name
      (OM_uint32 * minor_status, const gss_name_t input_name, const gss_OID
      mech_type, gss_name_t * output_name)
      gss_canonicalize_name takes a Internal Name (IN) and converts in into
      a mechanism specific Mechanism Name (MN).

      The input name may multiple name, or generic name types.

      If the input_name if of the GSS_C_NT_USER_NAME, and the Kerberos
      mechanism is specified, the resulting MN type is a
      GSS_KRB5_NT_PRINCIPAL_NAME.

      For more information about internalVSmechname.

      Parameters:
          minor_status minor status code.
          input_name name to covert, unchanged by gss_canonicalize_name().
          mech_type the type to convert Name too.
          output_name the resulting type, release with gss_release_name(),
          independent of input_name.



                                    - 2 -     Formatted:  September 17, 2024






 Heimdal GSS-API functions(3)   Version 1.5.2   Heimdal GSS-API functions(3)
 HeimdalGSS-APIlibrary                                 HeimdalGSS-APIlibrary

                                 11 Jan 2012



      Returns:
          a gss_error code, see gss_display_status() about printing the
          error code.

    GSSAPI_LIB_FUNCTION OM_uint32 GSSAPI_LIB_CALL gss_import_name (OM_uint32
      * minor_status, const gss_buffer_t input_name_buffer, const gss_OID
      input_name_type, gss_name_t * output_name)
      Import a name internal or mechanism name

      Type of name and their format:

      + GSS_C_NO_OID

      + GSS_C_NT_USER_NAME

      + GSS_C_NT_HOSTBASED_SERVICE

      + GSS_C_NT_EXPORT_NAME

      + GSS_C_NT_ANONYMOUS

      + GSS_KRB5_NT_PRINCIPAL_NAME

      For more information about internalVSmechname.

      Parameters:
          minor_status minor status code
          input_name_buffer import name buffer
          input_name_type type of the import name buffer
          output_name the resulting type, release with gss_release_name(),
          independent of input_name

      Returns:
          a gss_error code, see gss_display_status() about printing the
          error code.

    GSSAPI_LIB_FUNCTION OM_uint32 GSSAPI_LIB_CALL gss_init_sec_context
      (OM_uint32 * minor_status, const gss_cred_id_t initiator_cred_handle,
      gss_ctx_id_t * context_handle, const gss_name_t target_name, const
      gss_OID input_mech_type, OM_uint32 req_flags, OM_uint32 time_req,
      const gss_channel_bindings_t input_chan_bindings, const gss_buffer_t
      input_token, gss_OID * actual_mech_type, gss_buffer_t output_token,
      OM_uint32 * ret_flags, OM_uint32 * time_rec)
      As the initiator build a context with an acceptor.

      Returns in the major

      + GSS_S_COMPLETE - if the context if build




                                    - 3 -     Formatted:  September 17, 2024






 Heimdal GSS-API functions(3)   Version 1.5.2   Heimdal GSS-API functions(3)
 HeimdalGSS-APIlibrary                                 HeimdalGSS-APIlibrary

                                 11 Jan 2012



      + GSS_S_CONTINUE_NEEDED - if the caller needs to continue another
        round of gss_i nit_sec_context

      + error code - any other error code

      Parameters:
          minor_status minor status code.
          initiator_cred_handle the credential to use when building the
          context, if GSS_C_NO_CREDENTIAL is passed, the default credential
          for the mechanism will be used.
          context_handle a pointer to a context handle, will be returned as
          long as there is not an error.
          target_name the target name of acceptor, created using
          gss_import_name(). The name is can be of any name types the
          mechanism supports, check supported name types with
          gss_inquire_names_for_mech().
          input_mech_type mechanism type to use, if GSS_C_NO_OID is used,
          Kerberos (GSS_KRB5_MECHANISM) will be tried. Other available
          mechanism are listed in the GSS-API mechanisms section.
          req_flags flags using when building the context, see Context
          creation flags
          time_req time requested this context should be valid in seconds,
          common used value is GSS_C_INDEFINITE
          input_chan_bindings Channel bindings used, if not exepected
          otherwise, used GSS_C_NO_CHANNEL_BINDINGS
          input_token input token sent from the acceptor, for the initial
          packet the buffer of { NULL, 0 } should be used.
          actual_mech_type the actual mech used, MUST NOT be freed since it
          pointing to static memory.
          output_token if there is an output token, regardless of complete,
          continue_needed, or error it should be sent to the acceptor
          ret_flags return what flags was negotitated, caller should check
          if they are accetable. For example, if GSS_C_MUTUAL_FLAG was
          negotiated with the acceptor or not.
          time_rec amount of time this context is valid for

      Returns:
          a gss_error code, see gss_display_status() about printing the
          error code.

    GSSAPI_LIB_FUNCTION OM_uint32 GSSAPI_LIB_CALL gss_inquire_attrs_for_mech
      (OM_uint32 * minor_status, gss_const_OID mech, gss_OID_set *
      mech_attr, gss_OID_set * known_mech_attrs)
      List support attributes for a mech and/or all mechanisms.

      Parameters:
          minor_status minor status code
          mech given together with mech_attr will return the list of
          attributes for mechanism, can optionally be GSS_C_NO_OID.



                                    - 4 -     Formatted:  September 17, 2024






 Heimdal GSS-API functions(3)   Version 1.5.2   Heimdal GSS-API functions(3)
 HeimdalGSS-APIlibrary                                 HeimdalGSS-APIlibrary

                                 11 Jan 2012



          mech_attr see mech parameter, can optionally be NULL, release with
          gss_release_oid_set().
          known_mech_attrs all attributes for mechanisms supported, release
          with gss_release_oid_set().

    GSSAPI_LIB_FUNCTION OM_uint32 GSSAPI_LIB_CALL
      gss_inquire_saslname_for_mech (OM_uint32 * minor_status, const gss_OID
      desired_mech, gss_buffer_t sasl_mech_name, gss_buffer_t mech_name,
      gss_buffer_t mech_description)
      Returns different protocol names and description of the mechanism.

      Parameters:
          minor_status minor status code
          desired_mech mech list query
          sasl_mech_name SASL GS2 protocol name
          mech_name gssapi protocol name
          mech_description description of gssapi mech

      Returns:
          returns GSS_S_COMPLETE or a error code.

    GSSAPI_LIB_FUNCTION int GSSAPI_LIB_CALL gss_oid_equal (gss_const_OID a,
      gss_const_OID b)
      Compare two GSS-API OIDs with each other.

      GSS_C_NO_OID matches nothing, not even it-self.

      Parameters:
          a first oid to compare
          b second oid to compare

      Returns:
          non-zero when both oid are the same OID, zero when they are not
          the same.

    GSSAPI_LIB_FUNCTION OM_uint32 GSSAPI_LIB_CALL gss_release_cred
      (OM_uint32 * minor_status, gss_cred_id_t * cred_handle)
      Release a credentials

      Its ok to release the GSS_C_NO_CREDENTIAL/NULL credential, it will
      return a GSS_S_COMPLETE error code. On return cred_handle is set ot
      GSS_C_NO_CREDENTIAL.

      Example:

       gss_cred_id_t cred = GSS_C_NO_CREDENTIAL;
       major = gss_release_cred(&minor, &cred);

      Parameters:



                                    - 5 -     Formatted:  September 17, 2024






 Heimdal GSS-API functions(3)   Version 1.5.2   Heimdal GSS-API functions(3)
 HeimdalGSS-APIlibrary                                 HeimdalGSS-APIlibrary

                                 11 Jan 2012



          minor_status minor status return code, mech specific
          cred_handle a pointer to the credential too release

      Returns:
          an gssapi error code

    GSSAPI_LIB_FUNCTION OM_uint32 GSSAPI_LIB_CALL gss_release_iov_buffer
      (OM_uint32 * minor_status, gss_iov_buffer_desc * iov, int iov_count)

      Free all buffer allocated by gss_wrap_iov() or gss_unwrap_iov() by
      looking at the GSS_IOV_BUFFER_FLAG_ALLOCATED flag.

    GSSAPI_LIB_FUNCTION OM_uint32 GSSAPI_LIB_CALL gss_release_name
      (OM_uint32 * minor_status, gss_name_t * input_name)
      Free a name

      import_name can point to NULL or be NULL, or a pointer to a gss_name_t
      structure. If it was a pointer to gss_name_t, the pointer will be set
      to NULL on success and failure.

      Parameters:
          minor_status minor status code
          input_name name to free

      Returns:
          a gss_error code, see gss_display_status() about printing the
          error code.

    GSSAPI_LIB_FUNCTION OM_uint32 GSSAPI_LIB_CALL gss_unwrap_iov (OM_uint32
      * minor_status, gss_ctx_id_t context_handle, int * conf_state,
      gss_qop_t * qop_state, gss_iov_buffer_desc * iov, int iov_count)
      Decrypt or verifies the signature on the data.

    GSSAPI_LIB_FUNCTION OM_uint32 GSSAPI_LIB_CALL gss_wrap (OM_uint32 *
      minor_status, const gss_ctx_id_t context_handle, int conf_req_flag,
      gss_qop_t qop_req, const gss_buffer_t input_message_buffer, int *
      conf_state, gss_buffer_t output_message_buffer)
      Wrap a message using either confidentiality (encryption + signature)
      or sealing (signature).

      Parameters:
          minor_status minor status code.
          context_handle context handle.
          conf_req_flag if non zero, confidentiality is requestd.
          qop_req type of protection needed, in most cases it
          GSS_C_QOP_DEFAULT should be passed in.
          input_message_buffer messages to wrap
          conf_state returns non zero if confidentiality was honoured.
          output_message_buffer the resulting buffer, release with



                                    - 6 -     Formatted:  September 17, 2024






 Heimdal GSS-API functions(3)   Version 1.5.2   Heimdal GSS-API functions(3)
 HeimdalGSS-APIlibrary                                 HeimdalGSS-APIlibrary

                                 11 Jan 2012



          gss_release_buffer().

    GSSAPI_LIB_FUNCTION OM_uint32 GSSAPI_LIB_CALL gss_wrap_iov (OM_uint32 *
      minor_status, gss_ctx_id_t context_handle, int conf_req_flag,
      gss_qop_t qop_req, int * conf_state, gss_iov_buffer_desc * iov, int
      iov_count)
      Encrypts or sign the data.

      This is a more complicated version of gss_wrap(), it allows the caller
      to use AEAD data (signed header/trailer) and allow greater controll
      over where the encrypted data is placed.

      The maximum packet size is gss_context_stream_sizes.max_msg_size.

      The caller needs provide the folloing buffers when using in
      conf_req_flag=1 mode:

      + HEADER (of size gss_context_stream_sizes.header) { DATA or SIGN_ONLY
        } (optional, zero or more) PADDING (of size
        gss_context_stream_sizes.blocksize, if zero padding is zero, can be
        omitted) TRAILER (of size gss_context_stream_sizes.trailer)

      + on DCE-RPC mode, the caller can skip PADDING and TRAILER if the DATA
        elements is padded to a block bountry and header is of at least size
        gss_context_stream_sizes.header + gss_context_stream_sizes.trailer.

      HEADER, PADDING, TRAILER will be shrunken to the size required to
      transmit any of them too large.

      To generate gss_wrap() compatible packets, use: HEADER | DATA |
      PADDING | TRAILER

      When used in conf_req_flag=0,

      + HEADER (of size gss_context_stream_sizes.header) { DATA or SIGN_ONLY
        } (optional, zero or more) PADDING (of size
        gss_context_stream_sizes.blocksize, if zero padding is zero, can be
        omitted) TRAILER (of size gss_context_stream_sizes.trailer)

      The input sizes of HEADER, PADDING and TRAILER can be fetched using
      gss_wrap_iov_length() or gss_context_query_attributes().

    GSSAPI_LIB_FUNCTION OM_uint32 GSSAPI_LIB_CALL gss_wrap_iov_length
      (OM_uint32 * minor_status, gss_ctx_id_t context_handle, int
      conf_req_flag, gss_qop_t qop_req, int * conf_state,
      gss_iov_buffer_desc * iov, int iov_count)
      Update the length fields in iov buffer for the types:

      + GSS_IOV_BUFFER_TYPE_HEADER



                                    - 7 -     Formatted:  September 17, 2024






 Heimdal GSS-API functions(3)   Version 1.5.2   Heimdal GSS-API functions(3)
 HeimdalGSS-APIlibrary                                 HeimdalGSS-APIlibrary

                                 11 Jan 2012



      + GSS_IOV_BUFFER_TYPE_PADDING

      + GSS_IOV_BUFFER_TYPE_TRAILER

      Consider using gss_context_query_attributes() to fetch the data
      instead.

 Variable Documentation
    gss_OID_desc GSSAPI_LIB_FUNCTION __gss_c_attr_stream_sizes_oid_desc
      Initial value:

          {10, rk_UNCONST('
      .fi
      Query the context for parameters.

      SSPI equivalent if this function is QueryContextAttributes.

      + GSS_C_ATTR_STREAM_SIZES data is a gss_context_stream_sizes.































                                    - 8 -     Formatted:  September 17, 2024