📄 gssapi.h
字号:
/* * 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 + -