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