003 File Manager
Current Path:
/usr/src/crypto/heimdal/lib/gssapi/mech
usr
/
src
/
crypto
/
heimdal
/
lib
/
gssapi
/
mech
/
📁
..
📄
compat.h
(4.07 KB)
📄
context.c
(3.66 KB)
📄
context.h
(1.66 KB)
📄
cred.h
(2.24 KB)
📄
doxygen.c
(4.18 KB)
📄
gss_accept_sec_context.c
(8.26 KB)
📄
gss_acquire_cred.c
(4.57 KB)
📄
gss_acquire_cred_ext.c
(5.34 KB)
📄
gss_acquire_cred_with_password.c
(3.69 KB)
📄
gss_add_cred.c
(5.45 KB)
📄
gss_add_cred_with_password.c
(4.7 KB)
📄
gss_add_oid_set_member.c
(2.89 KB)
📄
gss_aeap.c
(5.54 KB)
📄
gss_authorize_localname.c
(5.97 KB)
📄
gss_buffer_set.c
(3.48 KB)
📄
gss_canonicalize_name.c
(3.66 KB)
📄
gss_compare_name.c
(2.68 KB)
📄
gss_context_time.c
(1.76 KB)
📄
gss_create_empty_oid_set.c
(1.82 KB)
📄
gss_cred.c
(5.37 KB)
📄
gss_decapsulate_token.c
(2.49 KB)
📄
gss_delete_name_attribute.c
(2.47 KB)
📄
gss_delete_sec_context.c
(2.07 KB)
📄
gss_display_name.c
(2.8 KB)
📄
gss_display_name_ext.c
(2.58 KB)
📄
gss_display_status.c
(6.7 KB)
📄
gss_duplicate_name.c
(3.14 KB)
📄
gss_duplicate_oid.c
(2.37 KB)
📄
gss_encapsulate_token.c
(2.39 KB)
📄
gss_export_name.c
(2.04 KB)
📄
gss_export_name_composite.c
(2.53 KB)
📄
gss_export_sec_context.c
(2.82 KB)
📄
gss_get_mic.c
(1.96 KB)
📄
gss_get_name_attribute.c
(3.04 KB)
📄
gss_import_name.c
(6.92 KB)
📄
gss_import_sec_context.c
(2.68 KB)
📄
gss_indicate_mechs.c
(2.28 KB)
📄
gss_init_sec_context.c
(6.55 KB)
📄
gss_inquire_context.c
(3.14 KB)
📄
gss_inquire_cred.c
(5.18 KB)
📄
gss_inquire_cred_by_mech.c
(2.94 KB)
📄
gss_inquire_cred_by_oid.c
(2.83 KB)
📄
gss_inquire_mechs_for_name.c
(2.68 KB)
📄
gss_inquire_name.c
(2.89 KB)
📄
gss_inquire_names_for_mech.c
(2.55 KB)
📄
gss_inquire_sec_context_by_oid.c
(2.5 KB)
📄
gss_krb5.c
(21.41 KB)
📄
gss_mech_switch.c
(10.37 KB)
📄
gss_mo.c
(17.84 KB)
📄
gss_names.c
(3.09 KB)
📄
gss_oid.c
(14.92 KB)
📄
gss_oid_equal.c
(2.2 KB)
📄
gss_oid_to_str.c
(2.97 KB)
📄
gss_pname_to_uid.c
(5.65 KB)
📄
gss_process_context_token.c
(1.81 KB)
📄
gss_pseudo_random.c
(2.43 KB)
📄
gss_release_buffer.c
(1.67 KB)
📄
gss_release_cred.c
(2.51 KB)
📄
gss_release_name.c
(2.54 KB)
📄
gss_release_oid.c
(2.01 KB)
📄
gss_release_oid_set.c
(1.71 KB)
📄
gss_seal.c
(1.82 KB)
📄
gss_set_cred_option.c
(3.37 KB)
📄
gss_set_name_attribute.c
(2.61 KB)
📄
gss_set_sec_context_option.c
(2.36 KB)
📄
gss_sign.c
(1.71 KB)
📄
gss_store_cred.c
(3.12 KB)
📄
gss_test_oid_set_member.c
(1.77 KB)
📄
gss_unseal.c
(1.8 KB)
📄
gss_unwrap.c
(1.91 KB)
📄
gss_utils.c
(2.39 KB)
📄
gss_verify.c
(1.75 KB)
📄
gss_verify_mic.c
(1.98 KB)
📄
gss_wrap.c
(2.68 KB)
📄
gss_wrap_size_limit.c
(2 KB)
📄
gssapi.asn1
(199 B)
📄
mech.5
(3.19 KB)
📄
mech.cat5
(2.34 KB)
📄
mech_locl.h
(2.36 KB)
📄
mech_switch.h
(1.79 KB)
📄
mechqueue.h
(3.41 KB)
📄
name.h
(2.05 KB)
📄
utils.h
(1.62 KB)
Editing: gss_import_name.c
/*- * Copyright (c) 2005 Doug Rabson * 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. * * THIS SOFTWARE IS PROVIDED BY THE AUTHOR 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 AUTHOR 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. * * $FreeBSD: src/lib/libgssapi/gss_import_name.c,v 1.1 2005/12/29 14:40:20 dfr Exp $ */ #include "mech_locl.h" static OM_uint32 _gss_import_export_name(OM_uint32 *minor_status, const gss_buffer_t input_name_buffer, gss_name_t *output_name) { OM_uint32 major_status; unsigned char *p = input_name_buffer->value; size_t len = input_name_buffer->length; size_t t; gss_OID_desc mech_oid; gssapi_mech_interface m; struct _gss_name *name; gss_name_t new_canonical_name; int composite = 0; *minor_status = 0; *output_name = 0; /* * Make sure that TOK_ID is {4, 1}. */ if (len < 2) return (GSS_S_BAD_NAME); if (p[0] != 4) return (GSS_S_BAD_NAME); switch (p[1]) { case 1: /* non-composite name */ break; case 2: /* composite name */ composite = 1; break; default: return (GSS_S_BAD_NAME); } p += 2; len -= 2; /* * Get the mech length and the name length and sanity * check the size of of the buffer. */ if (len < 2) return (GSS_S_BAD_NAME); t = (p[0] << 8) + p[1]; p += 2; len -= 2; /* * Check the DER encoded OID to make sure it agrees with the * length we just decoded. */ if (p[0] != 6) /* 6=OID */ return (GSS_S_BAD_NAME); p++; len--; t--; if (p[0] & 0x80) { int digits = p[0]; p++; len--; t--; mech_oid.length = 0; while (digits--) { mech_oid.length = (mech_oid.length << 8) | p[0]; p++; len--; t--; } } else { mech_oid.length = p[0]; p++; len--; t--; } if (mech_oid.length != t) return (GSS_S_BAD_NAME); mech_oid.elements = p; if (len < t + 4) return (GSS_S_BAD_NAME); p += t; len -= t; t = (p[0] << 24) | (p[1] << 16) | (p[2] << 8) | p[3]; p += 4; len -= 4; if (!composite && len != t) return (GSS_S_BAD_NAME); m = __gss_get_mechanism(&mech_oid); if (!m) return (GSS_S_BAD_MECH); /* * Ask the mechanism to import the name. */ major_status = m->gm_import_name(minor_status, input_name_buffer, GSS_C_NT_EXPORT_NAME, &new_canonical_name); if (major_status != GSS_S_COMPLETE) { _gss_mg_error(m, major_status, *minor_status); return major_status; } /* * Now we make a new name and mark it as an MN. */ name = _gss_make_name(m, new_canonical_name); if (!name) { m->gm_release_name(minor_status, &new_canonical_name); return (GSS_S_FAILURE); } *output_name = (gss_name_t) name; *minor_status = 0; return (GSS_S_COMPLETE); } /** * Import a name internal or mechanism name * * Type of name and their format: * - GSS_C_NO_OID * - GSS_C_NT_USER_NAME * - GSS_C_NT_HOSTBASED_SERVICE * - GSS_C_NT_EXPORT_NAME * - GSS_C_NT_ANONYMOUS * - GSS_KRB5_NT_PRINCIPAL_NAME * * For more information about @ref internalVSmechname. * * @param minor_status minor status code * @param input_name_buffer import name buffer * @param input_name_type type of the import name buffer * @param output_name the resulting type, release with * gss_release_name(), independent of input_name * * @returns a gss_error code, see gss_display_status() about printing * the error code. * * @ingroup gssapi */ GSSAPI_LIB_FUNCTION OM_uint32 GSSAPI_LIB_CALL gss_import_name(OM_uint32 *minor_status, const gss_buffer_t input_name_buffer, const gss_OID input_name_type, gss_name_t *output_name) { struct _gss_mechanism_name *mn; gss_OID name_type = input_name_type; OM_uint32 major_status, ms; struct _gss_name *name; struct _gss_mech_switch *m; gss_name_t rname; *output_name = GSS_C_NO_NAME; if (input_name_buffer->length == 0) { *minor_status = 0; return (GSS_S_BAD_NAME); } _gss_load_mech(); /* * Use GSS_NT_USER_NAME as default name type. */ if (name_type == GSS_C_NO_OID) name_type = GSS_C_NT_USER_NAME; /* * If this is an exported name, we need to parse it to find * the mechanism and then import it as an MN. See RFC 2743 * section 3.2 for a description of the format. */ if (gss_oid_equal(name_type, GSS_C_NT_EXPORT_NAME)) { return _gss_import_export_name(minor_status, input_name_buffer, output_name); } *minor_status = 0; name = calloc(1, sizeof(struct _gss_name)); if (!name) { *minor_status = ENOMEM; return (GSS_S_FAILURE); } HEIM_SLIST_INIT(&name->gn_mn); major_status = _gss_copy_oid(minor_status, name_type, &name->gn_type); if (major_status) { free(name); return (GSS_S_FAILURE); } major_status = _gss_copy_buffer(minor_status, input_name_buffer, &name->gn_value); if (major_status) goto out; /* * Walk over the mechs and import the name into a mech name * for those supported this nametype. */ HEIM_SLIST_FOREACH(m, &_gss_mechs, gm_link) { int present = 0; major_status = gss_test_oid_set_member(minor_status, name_type, m->gm_name_types, &present); if (major_status || present == 0) continue; mn = malloc(sizeof(struct _gss_mechanism_name)); if (!mn) { *minor_status = ENOMEM; major_status = GSS_S_FAILURE; goto out; } major_status = (*m->gm_mech.gm_import_name)(minor_status, &name->gn_value, (name->gn_type.elements ? &name->gn_type : GSS_C_NO_OID), &mn->gmn_name); if (major_status != GSS_S_COMPLETE) { _gss_mg_error(&m->gm_mech, major_status, *minor_status); free(mn); goto out; } mn->gmn_mech = &m->gm_mech; mn->gmn_mech_oid = &m->gm_mech_oid; HEIM_SLIST_INSERT_HEAD(&name->gn_mn, mn, gmn_link); } /* * If we can't find a mn for the name, bail out already here. */ mn = HEIM_SLIST_FIRST(&name->gn_mn); if (!mn) { *minor_status = 0; major_status = GSS_S_NAME_NOT_MN; goto out; } *output_name = (gss_name_t) name; return (GSS_S_COMPLETE); out: rname = (gss_name_t)name; gss_release_name(&ms, &rname); return major_status; }
Upload File
Create Folder