Revert "Fix for OpenSSH interoperability"
authorLuke Howard <lukeh@padl.com>
Wed, 16 Mar 2011 04:19:09 +0000 (15:19 +1100)
committerLuke Howard <lukeh@padl.com>
Wed, 16 Mar 2011 04:19:09 +0000 (15:19 +1100)
This reverts commit 3dcac77927965ec56eb76d865b44a8b2bee4594b.

accept_sec_context.c
gssapiP_eap.h
import_name.c
init_sec_context.c
util.h
util_cred.c
util_name.c
util_reauth.c

index 9ef0fc9..5829ed9 100644 (file)
@@ -82,7 +82,6 @@ acceptReadyEap(OM_uint32 *minor, gss_ctx_id_t ctx, gss_cred_id_t cred)
     major = gssEapImportName(minor, &nameBuf,
                              (ctx->gssFlags & GSS_C_ANON_FLAG) ?
                                 GSS_C_NT_ANONYMOUS : GSS_C_NT_USER_NAME,
-                             ctx->mechanismUsed,
                              &ctx->initiatorName);
     if (GSS_ERROR(major))
         return major;
@@ -273,7 +272,7 @@ importInitiatorIdentity(OM_uint32 *minor,
     gssEapReleaseName(&tmpMinor, &ctx->initiatorName);
 
     return gssEapImportName(minor, &nameBuf, GSS_C_NT_USER_NAME,
-                            ctx->mechanismUsed, &ctx->initiatorName);
+                            &ctx->initiatorName);
 }
 
 /*
index 0f12811..10cd176 100644 (file)
@@ -105,7 +105,6 @@ struct gss_name_struct
 {
     GSSEAP_MUTEX mutex; /* mutex protects attrCtx */
     OM_uint32 flags;
-    gss_OID mechanismUsed; /* this is immutable */
     krb5_principal krbPrincipal; /* this is immutable */
     struct gss_eap_attr_ctx *attrCtx;
 };
index 87f0830..d20d75c 100644 (file)
@@ -43,5 +43,5 @@ gss_import_name(OM_uint32 *minor,
                 gss_name_t *output_name)
 {
     return gssEapImportName(minor, import_name_buffer,
-                            input_name_type, GSS_C_NO_OID, output_name);
+                            input_name_type, output_name);
 }
index c42fa88..1f445bc 100644 (file)
@@ -543,9 +543,7 @@ eapGssSmInitAcceptorName(OM_uint32 *minor,
                ctx->acceptorName == GSS_C_NO_NAME) {
         /* Accept target name hint from acceptor */
         major = gssEapImportName(minor, inputToken,
-                                 GSS_C_NT_USER_NAME,
-                                 ctx->mechanismUsed,
-                                 &ctx->acceptorName);
+                                 GSS_C_NT_USER_NAME, &ctx->acceptorName);
         if (GSS_ERROR(major))
             return major;
     }
diff --git a/util.h b/util.h
index 8756c95..ddf95a9 100644 (file)
--- a/util.h
+++ b/util.h
@@ -467,7 +467,6 @@ OM_uint32 gssEapExportNameInternal(OM_uint32 *minor,
 OM_uint32 gssEapImportName(OM_uint32 *minor,
                            const gss_buffer_t input_name_buffer,
                            gss_OID input_name_type,
-                           gss_OID input_mech_type,
                            gss_name_t *output_name);
 OM_uint32 gssEapImportNameInternal(OM_uint32 *minor,
                                    const gss_buffer_t input_name_buffer,
index a2a01ba..64b9284 100644 (file)
@@ -184,13 +184,7 @@ gssEapAcquireCred(OM_uint32 *minor,
         }
 
         if (nameBuf.length != 0) {
-            gss_OID mech = GSS_C_NO_OID;
-
-            if (cred->mechanisms != GSS_C_NO_OID_SET &&
-                cred->mechanisms->count == 1)
-                mech = &cred->mechanisms->elements[0];
-
-            major = gssEapImportName(minor, &nameBuf, nameType, mech, &cred->name);
+            major = gssEapImportName(minor, &nameBuf, nameType, &cred->name);
             if (GSS_ERROR(major))
                 goto cleanup;
         }
index dad8fb9..70d23e2 100644 (file)
@@ -111,7 +111,6 @@ gssEapReleaseName(OM_uint32 *minor, gss_name_t *pName)
 
     GSSEAP_KRB_INIT(&krbContext);
     krb5_free_principal(krbContext, name->krbPrincipal);
-    gssEapReleaseOid(&tmpMinor, &name->mechanismUsed);
 
     gssEapReleaseAttrContext(&tmpMinor, name);
 
@@ -283,10 +282,7 @@ gssEapImportNameInternal(OM_uint32 *minor,
     remain = nameBuffer->length;
 
     if (flags & EXPORT_NAME_FLAG_OID) {
-        gss_OID_desc mech;
-
-        /* TOK_ID || MECH_OID_LEN || MECH_OID */
-        if (remain < 6)
+        if (remain < 6 + GSS_EAP_MECHANISM->length)
             return GSS_S_BAD_NAME;
 
         if (flags & EXPORT_NAME_FLAG_COMPOSITE)
@@ -301,34 +297,18 @@ gssEapImportNameInternal(OM_uint32 *minor,
 
         /* MECH_OID_LEN */
         len = load_uint16_be(p);
-        if (len < 2)
+        if (len != 2 + GSS_EAP_MECHANISM->length)
             return GSS_S_BAD_NAME;
         UPDATE_REMAIN(2);
 
         /* MECH_OID */
         if (p[0] != 0x06)
             return GSS_S_BAD_NAME;
-
-        mech.length = p[1];
-        mech.elements = &p[2];
-
-        CHECK_REMAIN(mech.length);
-
-        if (!gssEapIsMechanismOid(&mech)) {
-            major = GSS_S_BAD_NAME;
-            *minor = GSSEAP_WRONG_MECH;
-            goto cleanup;
-        }
-
-        if (oidEqual(&mech, GSS_EAP_MECHANISM)) {
-            name->mechanismUsed = GSS_C_NO_OID;
-        } else if (!gssEapInternalizeOid(&mech, &name->mechanismUsed)) {
-            major = duplicateOid(minor, &mech, &name->mechanismUsed);
-            if (GSS_ERROR(major))
-                goto cleanup;
-        }
-
-        UPDATE_REMAIN(2 + mech.length);
+        if (p[1] != GSS_EAP_MECHANISM->length)
+            return GSS_S_BAD_MECH;
+        if (memcmp(&p[2], GSS_EAP_MECHANISM->elements, GSS_EAP_MECHANISM->length))
+            return GSS_S_BAD_MECH;
+        UPDATE_REMAIN(2 + GSS_EAP_MECHANISM->length);
     }
 
     /* NAME_LEN */
@@ -399,8 +379,7 @@ OM_uint32
 gssEapImportName(OM_uint32 *minor,
                  const gss_buffer_t nameBuffer,
                  gss_OID nameType,
-                 gss_OID mechType,
-                 gss_name_t *pName)
+                 gss_name_t *name)
 {
     struct gss_eap_name_import_provider nameTypes[] = {
         { GSS_C_NT_USER_NAME,               importUserName              },
@@ -414,36 +393,18 @@ gssEapImportName(OM_uint32 *minor,
 #endif
     };
     size_t i;
-    OM_uint32 major = GSS_S_BAD_NAMETYPE;
-    OM_uint32 tmpMinor;
-    gss_name_t name = GSS_C_NO_NAME;
+
+    *name = GSS_C_NO_NAME;
 
     if (nameType == GSS_C_NO_OID)
         nameType = nameTypes[0].oid;
 
     for (i = 0; i < sizeof(nameTypes) / sizeof(nameTypes[0]); i++) {
-        if (oidEqual(nameTypes[i].oid, nameType)) {
-            major = nameTypes[i].import(minor, nameBuffer, &name);
-            break;
-        }
+        if (oidEqual(nameTypes[i].oid, nameType))
+            return nameTypes[i].import(minor, nameBuffer, name);
     }
 
-    if (major == GSS_S_COMPLETE &&
-        mechType != GSS_C_NO_OID) {
-        assert(gssEapIsConcreteMechanismOid(mechType));
-        assert(name->mechanismUsed == GSS_C_NO_OID);
-
-        if (!gssEapInternalizeOid(mechType, &name->mechanismUsed)) {
-            major = duplicateOid(minor, mechType, &name->mechanismUsed);
-        }
-    }
-
-    if (GSS_ERROR(major))
-        gssEapReleaseName(&tmpMinor, &name);
-    else
-        *pName = name;
-
-    return major;
+    return GSS_S_BAD_NAMETYPE;
 }
 
 OM_uint32
@@ -467,16 +428,10 @@ gssEapExportNameInternal(OM_uint32 *minor,
     size_t krbNameLen, exportedNameLen;
     unsigned char *p;
     gss_buffer_desc attrs = GSS_C_EMPTY_BUFFER;
-    gss_OID mech;
 
     exportedName->length = 0;
     exportedName->value = NULL;
 
-    if (name->mechanismUsed != GSS_C_NO_OID)
-        mech = name->mechanismUsed;
-    else
-        mech = GSS_EAP_MECHANISM;
-
     GSSEAP_KRB_INIT(&krbContext);
 
     *minor = krb5_unparse_name(krbContext, name->krbPrincipal, &krbName);
@@ -488,7 +443,7 @@ gssEapExportNameInternal(OM_uint32 *minor,
 
     exportedNameLen = 0;
     if (flags & EXPORT_NAME_FLAG_OID) {
-        exportedNameLen += 6 + mech->length;
+        exportedNameLen += 6 + GSS_EAP_MECHANISM->length;
     }
     exportedNameLen += 4 + krbNameLen;
     if (flags & EXPORT_NAME_FLAG_COMPOSITE) {
@@ -515,14 +470,14 @@ gssEapExportNameInternal(OM_uint32 *minor,
                         : TOK_TYPE_EXPORT_NAME,
                         p);
         p += 2;
-        store_uint16_be(mech->length + 2, p);
+        store_uint16_be(GSS_EAP_MECHANISM->length + 2, p);
         p += 2;
 
         /* MECH_OID */
         *p++ = 0x06;
-        *p++ = mech->length & 0xff;
-        memcpy(p, mech->elements, mech->length);
-        p += mech->length;
+        *p++ = GSS_EAP_MECHANISM->length & 0xff;
+        memcpy(p, GSS_EAP_MECHANISM->elements, GSS_EAP_MECHANISM->length);
+        p += GSS_EAP_MECHANISM->length;
     }
 
     /* NAME_LEN */
@@ -573,22 +528,6 @@ gssEapDuplicateName(OM_uint32 *minor,
         return major;
     }
 
-    if (input_name->mechanismUsed == GSS_C_NO_OID) {
-        name->mechanismUsed = GSS_C_NO_OID;
-    } else if (gssEapIsConcreteMechanismOid(input_name->mechanismUsed)) {
-        if (!gssEapInternalizeOid(input_name->mechanismUsed,
-                                  &name->mechanismUsed)) {
-            major = duplicateOid(minor, input_name->mechanismUsed,
-                                 &name->mechanismUsed);
-            if (GSS_ERROR(major))
-                goto cleanup;
-        }
-    } else {
-        major = GSS_S_BAD_MECH;
-        *minor = GSSEAP_WRONG_MECH;
-        goto cleanup;
-    }
-
     name->flags = input_name->flags;
 
     *minor = krb5_copy_principal(krbContext, input_name->krbPrincipal,
index 22f089f..f1112ca 100644 (file)
@@ -735,7 +735,7 @@ gssEapGlueToMechName(OM_uint32 *minor,
         goto cleanup;
 
     major = gssEapImportName(minor, &nameBuf, GSS_C_NT_USER_NAME,
-                             ctx->mechanismUsed, pMechName);
+                             pMechName);
     if (GSS_ERROR(major))
         goto cleanup;