* SUCH DAMAGE.
*/
+/*
+ * Utility routines for credential handles.
+ */
+
#include "gssapiP_eap.h"
OM_uint32
if (GSS_ERROR(major))
goto cleanup;
+ switch (credUsage) {
+ case GSS_C_BOTH:
+ cred->flags |= CRED_FLAG_INITIATE | CRED_FLAG_ACCEPT;
+ break;
+ case GSS_C_INITIATE:
+ cred->flags |= CRED_FLAG_INITIATE;
+ break;
+ case GSS_C_ACCEPT:
+ cred->flags |= CRED_FLAG_ACCEPT;
+ break;
+ default:
+ major = GSS_S_FAILURE;
+ *minor = GSSEAP_BAD_USAGE;
+ goto cleanup;
+ break;
+ }
+
if (desiredName != GSS_C_NO_NAME) {
GSSEAP_MUTEX_LOCK(&desiredName->mutex);
/* default host-based service is host@localhost */
if (gethostname(&serviceName[5], MAXHOSTNAMELEN) != 0) {
- *minor = GSSEAP_NO_HOSTNAME;
major = GSS_S_FAILURE;
+ *minor = GSSEAP_NO_HOSTNAME;
goto cleanup;
}
goto cleanup;
cred->flags |= CRED_FLAG_PASSWORD;
- } else if (credUsage == GSS_C_INITIATE) {
+ } else if (cred->flags & CRED_FLAG_INITIATE) {
/*
* OK, here we need to ask the supplicant if we have creds or it
* will acquire them, so GS2 can know whether to prompt for a
goto cleanup;
}
- switch (credUsage) {
- case GSS_C_BOTH:
- cred->flags |= CRED_FLAG_INITIATE | CRED_FLAG_ACCEPT;
- break;
- case GSS_C_INITIATE:
- cred->flags |= CRED_FLAG_INITIATE;
- break;
- case GSS_C_ACCEPT:
- cred->flags |= CRED_FLAG_ACCEPT;
- break;
- default:
- *minor = GSSEAP_BAD_USAGE;
- major = GSS_S_FAILURE;
- goto cleanup;
- break;
- }
-
major = gssEapValidateMechs(minor, desiredMechs);
if (GSS_ERROR(major))
goto cleanup;
*timeRec = GSS_C_INDEFINITE;
*pCred = cred;
+
major = GSS_S_COMPLETE;
+ *minor = 0;
cleanup:
if (GSS_ERROR(major))