⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 gssapi.h

📁 samba最新软件
💻 H
📖 第 1 页 / 共 2 页
字号:
/* * Copyright (c) 1997 - 2007 Kungliga Tekniska H鰃skolan * (Royal Institute of Technology, Stockholm, Sweden).  * All rights reserved.  * * Redistribution and use in source and binary forms, with or without  * modification, are permitted provided that the following conditions  * are met:  * * 1. Redistributions of source code must retain the above copyright  *    notice, this list of conditions and the following disclaimer.  * * 2. Redistributions in binary form must reproduce the above copyright  *    notice, this list of conditions and the following disclaimer in the  *    documentation and/or other materials provided with the distribution.  * * 3. Neither the name of the Institute nor the names of its contributors  *    may be used to endorse or promote products derived from this software  *    without specific prior written permission.  * * THIS SOFTWARE IS PROVIDED BY THE INSTITUTE AND CONTRIBUTORS ``AS IS'' AND  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE  * ARE DISCLAIMED.  IN NO EVENT SHALL THE INSTITUTE OR CONTRIBUTORS BE LIABLE  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF  * SUCH DAMAGE.  *//* $Id: gssapi.h 21004 2007-06-08 01:53:10Z lha $ */#ifndef GSSAPI_GSSAPI_H_#define GSSAPI_GSSAPI_H_/* * First, include stddef.h to get size_t defined. */#include <stddef.h>#include <krb5-types.h>/* * Now define the three implementation-dependent types. */typedef uint32_t OM_uint32;typedef uint64_t OM_uint64;typedef uint32_t gss_uint32;struct gss_name_t_desc_struct;typedef struct gss_name_t_desc_struct *gss_name_t;struct gss_ctx_id_t_desc_struct;typedef struct gss_ctx_id_t_desc_struct *gss_ctx_id_t;typedef struct gss_OID_desc_struct {      OM_uint32 length;      void      *elements;} gss_OID_desc, *gss_OID;typedef struct gss_OID_set_desc_struct  {      size_t     count;      gss_OID    elements;} gss_OID_set_desc, *gss_OID_set;typedef int gss_cred_usage_t;struct gss_cred_id_t_desc_struct;typedef struct gss_cred_id_t_desc_struct *gss_cred_id_t;typedef struct gss_buffer_desc_struct {      size_t length;      void *value;} gss_buffer_desc, *gss_buffer_t;typedef struct gss_channel_bindings_struct {      OM_uint32 initiator_addrtype;      gss_buffer_desc initiator_address;      OM_uint32 acceptor_addrtype;      gss_buffer_desc acceptor_address;      gss_buffer_desc application_data;} *gss_channel_bindings_t;/* GGF extension data types */typedef struct gss_buffer_set_desc_struct {      size_t count;      gss_buffer_desc *elements;} gss_buffer_set_desc, *gss_buffer_set_t;/* * For now, define a QOP-type as an OM_uint32 */typedef OM_uint32 gss_qop_t;/* * Flag bits for context-level services. */#define GSS_C_DELEG_FLAG 1#define GSS_C_MUTUAL_FLAG 2#define GSS_C_REPLAY_FLAG 4#define GSS_C_SEQUENCE_FLAG 8#define GSS_C_CONF_FLAG 16#define GSS_C_INTEG_FLAG 32#define GSS_C_ANON_FLAG 64#define GSS_C_PROT_READY_FLAG 128#define GSS_C_TRANS_FLAG 256#define GSS_C_DCE_STYLE 4096#define GSS_C_IDENTIFY_FLAG 8192#define GSS_C_EXTENDED_ERROR_FLAG 16384/* * Credential usage options */#define GSS_C_BOTH 0#define GSS_C_INITIATE 1#define GSS_C_ACCEPT 2/* * Status code types for gss_display_status */#define GSS_C_GSS_CODE 1#define GSS_C_MECH_CODE 2/* * The constant definitions for channel-bindings address families */#define GSS_C_AF_UNSPEC     0#define GSS_C_AF_LOCAL      1#define GSS_C_AF_INET       2#define GSS_C_AF_IMPLINK    3#define GSS_C_AF_PUP        4#define GSS_C_AF_CHAOS      5#define GSS_C_AF_NS         6#define GSS_C_AF_NBS        7#define GSS_C_AF_ECMA       8#define GSS_C_AF_DATAKIT    9#define GSS_C_AF_CCITT      10#define GSS_C_AF_SNA        11#define GSS_C_AF_DECnet     12#define GSS_C_AF_DLI        13#define GSS_C_AF_LAT        14#define GSS_C_AF_HYLINK     15#define GSS_C_AF_APPLETALK  16#define GSS_C_AF_BSC        17#define GSS_C_AF_DSS        18#define GSS_C_AF_OSI        19#define GSS_C_AF_X25        21#define GSS_C_AF_INET6	    24#define GSS_C_AF_NULLADDR   255/* * Various Null values */#define GSS_C_NO_NAME ((gss_name_t) 0)#define GSS_C_NO_BUFFER ((gss_buffer_t) 0)#define GSS_C_NO_BUFFER_SET ((gss_buffer_set_t) 0)#define GSS_C_NO_OID ((gss_OID) 0)#define GSS_C_NO_OID_SET ((gss_OID_set) 0)#define GSS_C_NO_CONTEXT ((gss_ctx_id_t) 0)#define GSS_C_NO_CREDENTIAL ((gss_cred_id_t) 0)#define GSS_C_NO_CHANNEL_BINDINGS ((gss_channel_bindings_t) 0)#define GSS_C_EMPTY_BUFFER {0, NULL}/* * Some alternate names for a couple of the above * values.  These are defined for V1 compatibility. */#define GSS_C_NULL_OID GSS_C_NO_OID#define GSS_C_NULL_OID_SET GSS_C_NO_OID_SET/* * Define the default Quality of Protection for per-message * services.  Note that an implementation that offers multiple * levels of QOP may define GSS_C_QOP_DEFAULT to be either zero * (as done here) to mean "default protection", or to a specific * explicit QOP value.  However, a value of 0 should always be * interpreted by a GSSAPI implementation as a request for the * default protection level. */#define GSS_C_QOP_DEFAULT 0#define GSS_KRB5_CONF_C_QOP_DES		0x0100#define GSS_KRB5_CONF_C_QOP_DES3_KD	0x0200/* * Expiration time of 2^32-1 seconds means infinite lifetime for a * credential or security context */#define GSS_C_INDEFINITE 0xfffffffful#ifdef __cplusplusextern "C" {#endif/* * The implementation must reserve static storage for a * gss_OID_desc object containing the value * {10, (void *)"\x2a\x86\x48\x86\xf7\x12" *              "\x01\x02\x01\x01"}, * corresponding to an object-identifier value of * {iso(1) member-body(2) United States(840) mit(113554) *  infosys(1) gssapi(2) generic(1) user_name(1)}.  The constant * GSS_C_NT_USER_NAME should be initialized to point * to that gss_OID_desc. */extern gss_OID GSS_C_NT_USER_NAME;/* * The implementation must reserve static storage for a * gss_OID_desc object containing the value * {10, (void *)"\x2a\x86\x48\x86\xf7\x12" *              "\x01\x02\x01\x02"}, * corresponding to an object-identifier value of * {iso(1) member-body(2) United States(840) mit(113554) *  infosys(1) gssapi(2) generic(1) machine_uid_name(2)}. * The constant GSS_C_NT_MACHINE_UID_NAME should be * initialized to point to that gss_OID_desc. */extern gss_OID GSS_C_NT_MACHINE_UID_NAME;/* * The implementation must reserve static storage for a * gss_OID_desc object containing the value * {10, (void *)"\x2a\x86\x48\x86\xf7\x12" *              "\x01\x02\x01\x03"}, * corresponding to an object-identifier value of * {iso(1) member-body(2) United States(840) mit(113554) *  infosys(1) gssapi(2) generic(1) string_uid_name(3)}. * The constant GSS_C_NT_STRING_UID_NAME should be * initialized to point to that gss_OID_desc. */extern gss_OID GSS_C_NT_STRING_UID_NAME;/* * The implementation must reserve static storage for a * gss_OID_desc object containing the value * {6, (void *)"\x2b\x06\x01\x05\x06\x02"}, * corresponding to an object-identifier value of * {iso(1) org(3) dod(6) internet(1) security(5) * nametypes(6) gss-host-based-services(2)).  The constant * GSS_C_NT_HOSTBASED_SERVICE_X should be initialized to point * to that gss_OID_desc.  This is a deprecated OID value, and * implementations wishing to support hostbased-service names * should instead use the GSS_C_NT_HOSTBASED_SERVICE OID, * defined below, to identify such names; * GSS_C_NT_HOSTBASED_SERVICE_X should be accepted a synonym * for GSS_C_NT_HOSTBASED_SERVICE when presented as an input * parameter, but should not be emitted by GSS-API * implementations */extern gss_OID GSS_C_NT_HOSTBASED_SERVICE_X;/* * The implementation must reserve static storage for a * gss_OID_desc object containing the value * {10, (void *)"\x2a\x86\x48\x86\xf7\x12" *              "\x01\x02\x01\x04"}, corresponding to an * object-identifier value of {iso(1) member-body(2) * Unites States(840) mit(113554) infosys(1) gssapi(2) * generic(1) service_name(4)}.  The constant * GSS_C_NT_HOSTBASED_SERVICE should be initialized * to point to that gss_OID_desc. */extern gss_OID GSS_C_NT_HOSTBASED_SERVICE;/* * The implementation must reserve static storage for a * gss_OID_desc object containing the value * {6, (void *)"\x2b\x06\01\x05\x06\x03"}, * corresponding to an object identifier value of * {1(iso), 3(org), 6(dod), 1(internet), 5(security), * 6(nametypes), 3(gss-anonymous-name)}.  The constant * and GSS_C_NT_ANONYMOUS should be initialized to point * to that gss_OID_desc. */extern gss_OID GSS_C_NT_ANONYMOUS;/* * The implementation must reserve static storage for a * gss_OID_desc object containing the value * {6, (void *)"\x2b\x06\x01\x05\x06\x04"}, * corresponding to an object-identifier value of * {1(iso), 3(org), 6(dod), 1(internet), 5(security), * 6(nametypes), 4(gss-api-exported-name)}.  The constant * GSS_C_NT_EXPORT_NAME should be initialized to point * to that gss_OID_desc. */extern gss_OID GSS_C_NT_EXPORT_NAME;/* * Digest mechanism */extern gss_OID GSS_SASL_DIGEST_MD5_MECHANISM;/* * NTLM mechanism */extern gss_OID GSS_NTLM_MECHANISM;/* Major status codes */#define GSS_S_COMPLETE 0/* * Some "helper" definitions to make the status code macros obvious. */#define GSS_C_CALLING_ERROR_OFFSET 24#define GSS_C_ROUTINE_ERROR_OFFSET 16#define GSS_C_SUPPLEMENTARY_OFFSET 0#define GSS_C_CALLING_ERROR_MASK 0377ul#define GSS_C_ROUTINE_ERROR_MASK 0377ul#define GSS_C_SUPPLEMENTARY_MASK 0177777ul/* * The macros that test status codes for error conditions. * Note that the GSS_ERROR() macro has changed slightly from * the V1 GSSAPI so that it now evaluates its argument * only once. */#define GSS_CALLING_ERROR(x) \  (x & (GSS_C_CALLING_ERROR_MASK << GSS_C_CALLING_ERROR_OFFSET))#define GSS_ROUTINE_ERROR(x) \  (x & (GSS_C_ROUTINE_ERROR_MASK << GSS_C_ROUTINE_ERROR_OFFSET))#define GSS_SUPPLEMENTARY_INFO(x) \  (x & (GSS_C_SUPPLEMENTARY_MASK << GSS_C_SUPPLEMENTARY_OFFSET))#define GSS_ERROR(x) \  (x & ((GSS_C_CALLING_ERROR_MASK << GSS_C_CALLING_ERROR_OFFSET) | \        (GSS_C_ROUTINE_ERROR_MASK << GSS_C_ROUTINE_ERROR_OFFSET)))/* * Now the actual status code definitions *//* * Calling errors: */#define GSS_S_CALL_INACCESSIBLE_READ \                             (1ul << GSS_C_CALLING_ERROR_OFFSET)#define GSS_S_CALL_INACCESSIBLE_WRITE \                             (2ul << GSS_C_CALLING_ERROR_OFFSET)#define GSS_S_CALL_BAD_STRUCTURE \                             (3ul << GSS_C_CALLING_ERROR_OFFSET)/* * Routine errors: */#define GSS_S_BAD_MECH (1ul << GSS_C_ROUTINE_ERROR_OFFSET)#define GSS_S_BAD_NAME (2ul << GSS_C_ROUTINE_ERROR_OFFSET)#define GSS_S_BAD_NAMETYPE (3ul << GSS_C_ROUTINE_ERROR_OFFSET)#define GSS_S_BAD_BINDINGS (4ul << GSS_C_ROUTINE_ERROR_OFFSET)#define GSS_S_BAD_STATUS (5ul << GSS_C_ROUTINE_ERROR_OFFSET)#define GSS_S_BAD_SIG (6ul << GSS_C_ROUTINE_ERROR_OFFSET)#define GSS_S_BAD_MIC GSS_S_BAD_SIG#define GSS_S_NO_CRED (7ul << GSS_C_ROUTINE_ERROR_OFFSET)#define GSS_S_NO_CONTEXT (8ul << GSS_C_ROUTINE_ERROR_OFFSET)#define GSS_S_DEFECTIVE_TOKEN (9ul << GSS_C_ROUTINE_ERROR_OFFSET)#define GSS_S_DEFECTIVE_CREDENTIAL (10ul << GSS_C_ROUTINE_ERROR_OFFSET)#define GSS_S_CREDENTIALS_EXPIRED (11ul << GSS_C_ROUTINE_ERROR_OFFSET)#define GSS_S_CONTEXT_EXPIRED (12ul << GSS_C_ROUTINE_ERROR_OFFSET)#define GSS_S_FAILURE (13ul << GSS_C_ROUTINE_ERROR_OFFSET)#define GSS_S_BAD_QOP (14ul << GSS_C_ROUTINE_ERROR_OFFSET)#define GSS_S_UNAUTHORIZED (15ul << GSS_C_ROUTINE_ERROR_OFFSET)#define GSS_S_UNAVAILABLE (16ul << GSS_C_ROUTINE_ERROR_OFFSET)#define GSS_S_DUPLICATE_ELEMENT (17ul << GSS_C_ROUTINE_ERROR_OFFSET)#define GSS_S_NAME_NOT_MN (18ul << GSS_C_ROUTINE_ERROR_OFFSET)/* * Supplementary info bits: */#define GSS_S_CONTINUE_NEEDED (1ul << (GSS_C_SUPPLEMENTARY_OFFSET + 0))#define GSS_S_DUPLICATE_TOKEN (1ul << (GSS_C_SUPPLEMENTARY_OFFSET + 1))#define GSS_S_OLD_TOKEN (1ul << (GSS_C_SUPPLEMENTARY_OFFSET + 2))#define GSS_S_UNSEQ_TOKEN (1ul << (GSS_C_SUPPLEMENTARY_OFFSET + 3))#define GSS_S_GAP_TOKEN (1ul << (GSS_C_SUPPLEMENTARY_OFFSET + 4))/* * Finally, function prototypes for the GSS-API routines. */OM_uint32 gss_acquire_cred           (OM_uint32 * /*minor_status*/,            const gss_name_t /*desired_name*/,            OM_uint32 /*time_req*/,            const gss_OID_set /*desired_mechs*/,            gss_cred_usage_t /*cred_usage*/,            gss_cred_id_t * /*output_cred_handle*/,            gss_OID_set * /*actual_mechs*/,            OM_uint32 * /*time_rec*/           );OM_uint32 gss_release_cred           (OM_uint32 * /*minor_status*/,            gss_cred_id_t * /*cred_handle*/           );

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -