Line data Source code
1 : /* 2 : * Copyright (c) 2004, PADL Software Pty Ltd. 3 : * All rights reserved. 4 : * 5 : * Redistribution and use in source and binary forms, with or without 6 : * modification, are permitted provided that the following conditions 7 : * are met: 8 : * 9 : * 1. Redistributions of source code must retain the above copyright 10 : * notice, this list of conditions and the following disclaimer. 11 : * 12 : * 2. Redistributions in binary form must reproduce the above copyright 13 : * notice, this list of conditions and the following disclaimer in the 14 : * documentation and/or other materials provided with the distribution. 15 : * 16 : * 3. Neither the name of PADL Software nor the names of its contributors 17 : * may be used to endorse or promote products derived from this software 18 : * without specific prior written permission. 19 : * 20 : * THIS SOFTWARE IS PROVIDED BY PADL SOFTWARE AND CONTRIBUTORS ``AS IS'' AND 21 : * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 22 : * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 23 : * ARE DISCLAIMED. IN NO EVENT SHALL PADL SOFTWARE OR CONTRIBUTORS BE LIABLE 24 : * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 25 : * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 26 : * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 27 : * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 28 : * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 29 : * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 30 : * SUCH DAMAGE. 31 : */ 32 : 33 : #include "mech_locl.h" 34 : 35 : GSSAPI_LIB_FUNCTION OM_uint32 GSSAPI_LIB_CALL 36 0 : gss_inquire_cred_by_oid (OM_uint32 *minor_status, 37 : gss_const_cred_id_t cred_handle, 38 : const gss_OID desired_object, 39 : gss_buffer_set_t *data_set) 40 : { 41 0 : struct _gss_cred *cred = (struct _gss_cred *) cred_handle; 42 0 : OM_uint32 status = GSS_S_COMPLETE; 43 0 : struct _gss_mechanism_cred *mc; 44 0 : gssapi_mech_interface m; 45 0 : gss_buffer_set_t set = GSS_C_NO_BUFFER_SET; 46 : 47 0 : *minor_status = 0; 48 0 : *data_set = GSS_C_NO_BUFFER_SET; 49 : 50 0 : if (cred == NULL) 51 0 : return GSS_S_NO_CRED; 52 : 53 0 : status = GSS_S_FAILURE; 54 : 55 0 : HEIM_TAILQ_FOREACH(mc, &cred->gc_mc, gmc_link) { 56 0 : gss_buffer_set_t rset = GSS_C_NO_BUFFER_SET; 57 0 : size_t i; 58 : 59 0 : m = mc->gmc_mech; 60 0 : if (m == NULL) { 61 0 : _gss_secure_release_buffer_set(minor_status, &set); 62 0 : *minor_status = 0; 63 0 : return GSS_S_BAD_MECH; 64 : } 65 : 66 0 : if (m->gm_inquire_cred_by_oid == NULL) 67 0 : continue; 68 : 69 0 : status = m->gm_inquire_cred_by_oid(minor_status, 70 0 : mc->gmc_cred, desired_object, &rset); 71 0 : if (status != GSS_S_COMPLETE) { 72 0 : _gss_mg_error(m, *minor_status); 73 0 : continue; 74 : } 75 : 76 0 : for (i = 0; rset != NULL && i < rset->count; i++) { 77 0 : status = gss_add_buffer_set_member(minor_status, 78 0 : &rset->elements[i], &set); 79 0 : if (status != GSS_S_COMPLETE) 80 0 : break; 81 : } 82 0 : _gss_secure_release_buffer_set(minor_status, &rset); 83 : } 84 0 : if (set == GSS_C_NO_BUFFER_SET && status == GSS_S_COMPLETE) 85 0 : status = GSS_S_FAILURE; 86 0 : *data_set = set; 87 0 : *minor_status = 0; 88 0 : return status; 89 : } 90 :