* SUCH DAMAGE.
*/
+/*
+ * Utility routines for credential handles.
+ */
+
#include "gssapiP_eap.h"
OM_uint32
GSSEAP_MUTEX_UNLOCK(&desiredName->mutex);
} else {
- if (cred->flags & CRED_FLAG_INITIATE) {
- gss_buffer_desc buf;
+ gss_buffer_desc nameBuf = GSS_C_EMPTY_BUFFER;
+ gss_OID nameType = GSS_C_NO_OID;
+
+ if (cred->flags & CRED_FLAG_ACCEPT) {
+ char serviceName[5 + MAXHOSTNAMELEN] = "host@";
+
+ /* default host-based service is host@localhost */
+ if (gethostname(&serviceName[5], MAXHOSTNAMELEN) != 0) {
+ major = GSS_S_FAILURE;
+ *minor = GSSEAP_NO_HOSTNAME;
+ goto cleanup;
+ }
+
+ nameBuf.value = serviceName;
+ nameBuf.length = strlen((char *)nameBuf.value);
- buf.value = getlogin(); /* XXX */
- buf.length = strlen((char *)buf.value);
+ nameType = GSS_C_NT_HOSTBASED_SERVICE;
+ } else if (cred->flags & CRED_FLAG_INITIATE) {
+ nameBuf.value = getlogin(); /* XXX */
+ nameBuf.length = strlen((char *)nameBuf.value);
- major = gssEapImportName(minor, &buf,
- GSS_C_NT_USER_NAME, &cred->name);
+ nameType = GSS_C_NT_USER_NAME;
+ }
+
+ if (nameBuf.length != 0) {
+ major = gssEapImportName(minor, &nameBuf, nameType, &cred->name);
if (GSS_ERROR(major))
goto cleanup;
}
cred->flags |= CRED_FLAG_ACCEPT;
break;
default:
- *minor = GSSEAP_BAD_USAGE;
major = GSS_S_FAILURE;
+ *minor = GSSEAP_BAD_USAGE;
goto cleanup;
break;
}
*timeRec = GSS_C_INDEFINITE;
*pCred = cred;
+
major = GSS_S_COMPLETE;
+ *minor = 0;
cleanup:
if (GSS_ERROR(major))