~ubuntu-branches/ubuntu/utopic/moonshot-gss-eap/utopic-backports

« back to all changes in this revision

Viewing changes to mech_eap/inquire_mech_for_saslname.c

  • Committer: Package Import Robot
  • Author(s): Sam Hartman
  • Date: 2014-09-16 08:38:39 UTC
  • Revision ID: package-import@ubuntu.com-20140916083839-ipqco3thb1wcwvs0
Tags: upstream-0.9.2
ImportĀ upstreamĀ versionĀ 0.9.2

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
/*
 
2
 * Copyright (c) 2011, JANET(UK)
 
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 JANET(UK) 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 THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
 
21
 * AND 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 THE COPYRIGHT HOLDER 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
/*
 
34
 * Map mechanism OID to a SASL mechanism name.
 
35
 */
 
36
 
 
37
#include "gssapiP_eap.h"
 
38
 
 
39
OM_uint32 GSSAPI_CALLCONV
 
40
gss_inquire_saslname_for_mech(OM_uint32 *minor,
 
41
                              const gss_OID mech,
 
42
                              gss_buffer_t sasl_mech_name,
 
43
                              gss_buffer_t mech_name,
 
44
                              gss_buffer_t mech_description)
 
45
{
 
46
    OM_uint32 major;
 
47
    gss_buffer_t name;
 
48
    krb5_enctype etype = ENCTYPE_NULL;
 
49
 
 
50
    /* Dynamically construct mechanism name from Kerberos string enctype */
 
51
    major = gssEapOidToEnctype(minor, mech, &etype);
 
52
    if (GSS_ERROR(major))
 
53
        return major;
 
54
 
 
55
    if (mech_name != GSS_C_NO_BUFFER) {
 
56
        krb5_context krbContext;
 
57
 
 
58
        GSSEAP_KRB_INIT(&krbContext);
 
59
 
 
60
        *minor = krbEnctypeToString(krbContext, etype, "eap-", mech_name);
 
61
        if (*minor != 0)
 
62
            return GSS_S_FAILURE;
 
63
    }
 
64
 
 
65
    if (mech_description != GSS_C_NO_BUFFER) {
 
66
        major = makeStringBuffer(minor,
 
67
                                 "Extensible Authentication Protocol GSS-API Mechanism",
 
68
                                 mech_description);
 
69
        if (GSS_ERROR(major))
 
70
            return major;
 
71
    }
 
72
 
 
73
    if (sasl_mech_name != GSS_C_NO_BUFFER) {
 
74
        name = gssEapOidToSaslName(mech);
 
75
        if (name == GSS_C_NO_BUFFER) {
 
76
            major = GSS_S_BAD_MECH;
 
77
            *minor = GSSEAP_WRONG_MECH;
 
78
        } else {
 
79
            major = duplicateBuffer(minor, name, sasl_mech_name);
 
80
        }
 
81
    }
 
82
 
 
83
    return major;
 
84
}