Home | History | Annotate | Download | only in gssapi
      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