1 0 stevel /* 2 10598 Glenn * Copyright 2009 Sun Microsystems, Inc. All rights reserved. 3 0 stevel * Use is subject to license terms. 4 0 stevel */ 5 0 stevel 6 0 stevel /* 7 0 stevel * Copyright 1993 by OpenVision Technologies, Inc. 8 0 stevel * 9 0 stevel * Permission to use, copy, modify, distribute, and sell this software 10 0 stevel * and its documentation for any purpose is hereby granted without fee, 11 0 stevel * provided that the above copyright notice appears in all copies and 12 0 stevel * that both that copyright notice and this permission notice appear in 13 0 stevel * supporting documentation, and that the name of OpenVision not be used 14 0 stevel * in advertising or publicity pertaining to distribution of the software 15 0 stevel * without specific, written prior permission. OpenVision makes no 16 0 stevel * representations about the suitability of this software for any 17 0 stevel * purpose. It is provided "as is" without express or implied warranty. 18 0 stevel * 19 0 stevel * OPENVISION DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS SOFTWARE, 20 0 stevel * INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS, IN NO 21 0 stevel * EVENT SHALL OPENVISION BE LIABLE FOR ANY SPECIAL, INDIRECT OR 22 0 stevel * CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF 23 0 stevel * USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR 24 0 stevel * OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR 25 0 stevel * PERFORMANCE OF THIS SOFTWARE. 26 0 stevel */ 27 0 stevel 28 0 stevel #include <mechglueP.h> 29 0 stevel 30 0 stevel /* 31 0 stevel * See krb5/gssapi_krb5.c for a description of the algorithm for 32 0 stevel * encoding an object identifier. 33 0 stevel */ 34 0 stevel 35 0 stevel /* 36 0 stevel * The OID of user_name is(gss_nt_user_name, GSS_C_NT_USER_NAME): 37 0 stevel * iso(1) member-body(2) US(840) mit(113554) infosys(1) gssapi(2) 38 0 stevel * generic(1) user_name(1) = 1.2.840.113554.1.2.1.1 39 0 stevel * machine_uid_name(gss_nt_machine_uid_name, GSS_C_NT_MACHINE_UID_NAME): 40 0 stevel * iso(1) member-body(2) US(840) mit(113554) infosys(1) gssapi(2) 41 0 stevel * generic(1) machine_uid_name(2) = 1.2.840.113554.1.2.1.2 42 0 stevel * string_uid_name(gss_nt_string_uid_name,GSS_C_NT_STRING_UID_NAME): 43 0 stevel * iso(1) member-body(2) US(840) mit(113554) infosys(1) gssapi(2) 44 0 stevel * generic(1) string_uid_name(3) = 1.2.840.113554.1.2.1.3 45 0 stevel * service_name(gss_nt_service_name): 46 0 stevel * iso(1) member-body(2) US(840) mit(113554) infosys(1) gssapi(2) 47 0 stevel * generic(1) service_name(4) = 1.2.840.113554.1.2.1.4 48 0 stevel * hostbased_service_name(GSS_C_NT_HOSTBASED_SERVICE) 49 0 stevel * iso(1) org(3) dod(6) 1(internet) 5(security) 6(nametypes) 50 0 stevel * 2(gss-host-based-services) == 1.3.6.1.5.6.2 51 0 stevel * anonymous_name(GSS_C_NT_ANONYMOUS) 52 0 stevel * iso(1) org(3) dod(6) 1(internet) 5(security) 6(nametypes) 53 0 stevel * 3(anonymous) = 1.3.6.1.5.6.3 54 0 stevel * export_name(GSS_C_NT_EXPORT) 55 0 stevel * iso(1) org(3) dod(6) 1(internet) 5(security) 6(nametypes) 56 0 stevel * 4(export) = 1.3.6.1.5.6.4 57 0 stevel */ 58 0 stevel 59 0 stevel static const gss_OID_desc oids[] = { 60 0 stevel {10, "\052\206\110\206\367\022\001\002\001\001"}, 61 0 stevel {10, "\052\206\110\206\367\022\001\002\001\002"}, 62 0 stevel {10, "\052\206\110\206\367\022\001\002\001\003"}, 63 0 stevel {10, "\052\206\110\206\367\022\001\002\001\004"}, 64 0 stevel {6, "\053\006\001\005\006\002"}, 65 0 stevel {6, "\053\006\001\005\006\003"}, 66 0 stevel {6, "\053\006\001\005\006\004"}, 67 10598 Glenn {11, "\x2a\x86\x48\x86\xf7\x12\x01\x02\x02\x05\x05"}, 68 10598 Glenn 69 0 stevel }; 70 0 stevel 71 0 stevel const gss_OID_desc * const gss_nt_user_name = oids+0; 72 0 stevel const gss_OID_desc * const gss_nt_machine_uid_name = oids+1; 73 0 stevel const gss_OID_desc * const gss_nt_string_uid_name = oids+2; 74 0 stevel const gss_OID_desc * const gss_nt_service_name = oids+3; 75 0 stevel /* XXXXX These are needed for Kerberos */ 76 0 stevel const gss_OID_desc * const gss_nt_service_name_v2 = oids+4; 77 0 stevel const gss_OID_desc * const gss_nt_exported_name = oids+6; 78 0 stevel 79 0 stevel 80 0 stevel /* 81 0 stevel * These are added to reflect definitions in the 82 0 stevel * gss c-bindings spec. 83 0 stevel */ 84 0 stevel 85 0 stevel /* 86 0 stevel * The use of the following defines are preferred over the above defines. 87 0 stevel * This is because the following are the only ones defined 88 0 stevel * in GSS-API Specs. 89 0 stevel */ 90 0 stevel const gss_OID GSS_C_NT_USER_NAME = (gss_OID)oids+0; 91 0 stevel const gss_OID GSS_C_NT_MACHINE_UID_NAME = (gss_OID)oids+1; 92 0 stevel const gss_OID GSS_C_NT_STRING_UID_NAME = (gss_OID)oids+2; 93 0 stevel const gss_OID GSS_C_NT_HOSTBASED_SERVICE = (gss_OID)oids+4; 94 0 stevel const gss_OID GSS_C_NT_ANONYMOUS = (gss_OID)oids+5; 95 0 stevel const gss_OID GSS_C_NT_EXPORT_NAME = (gss_OID)oids+6; 96 10598 Glenn const gss_OID GSS_C_INQ_SSPI_SESSION_KEY = (gss_OID)oids+7; 97