version 1.8.2.1, 2006/02/03 03:01:56 |
version 1.8.2.2, 2006/10/06 03:19:32 |
|
|
/* $OpenBSD$ */ |
/* $OpenBSD$ */ |
|
|
/* |
/* |
* Copyright (c) 2001-2003 Simon Wilkinson. All rights reserved. |
* Copyright (c) 2001-2003 Simon Wilkinson. All rights reserved. |
|
|
* THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. |
* THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. |
*/ |
*/ |
|
|
#include "includes.h" |
#include <sys/types.h> |
|
|
#ifdef GSSAPI |
#ifdef GSSAPI |
|
|
#include "bufaux.h" |
#include <string.h> |
|
|
|
#include "xmalloc.h" |
|
#include "buffer.h" |
|
#include "key.h" |
|
#include "hostfile.h" |
#include "auth.h" |
#include "auth.h" |
#include "log.h" |
#include "log.h" |
#include "channels.h" |
#include "channels.h" |
#include "session.h" |
#include "session.h" |
#include "servconf.h" |
#include "misc.h" |
#include "xmalloc.h" |
|
#include "getput.h" |
|
|
|
#include "ssh-gss.h" |
#include "ssh-gss.h" |
|
|
|
|
&supported_mechs[i]->oid, oidset); |
&supported_mechs[i]->oid, oidset); |
i++; |
i++; |
} |
} |
|
|
|
gss_release_oid_set(&min_status, &supported); |
} |
} |
|
|
|
|
|
|
* second without. |
* second without. |
*/ |
*/ |
|
|
oidl = GET_16BIT(tok+2); /* length including next two bytes */ |
oidl = get_u16(tok+2); /* length including next two bytes */ |
oidl = oidl-2; /* turn it into the _real_ length of the variable OID */ |
oidl = oidl-2; /* turn it into the _real_ length of the variable OID */ |
|
|
/* |
/* |
|
|
if (ename->length < offset+4) |
if (ename->length < offset+4) |
return GSS_S_FAILURE; |
return GSS_S_FAILURE; |
|
|
name->length = GET_32BIT(tok+offset); |
name->length = get_u32(tok+offset); |
offset += 4; |
offset += 4; |
|
|
if (ename->length < offset+name->length) |
if (ename->length < offset+name->length) |
return GSS_S_FAILURE; |
return GSS_S_FAILURE; |
|
|
name->value = xmalloc(name->length+1); |
name->value = xmalloc(name->length+1); |
memcpy(name->value, tok+offset,name->length); |
memcpy(name->value, tok+offset, name->length); |
((char *)name->value)[name->length] = 0; |
((char *)name->value)[name->length] = 0; |
|
|
return GSS_S_COMPLETE; |
return GSS_S_COMPLETE; |
|
|
{ |
{ |
if (gssapi_client.store.filename != NULL) { |
if (gssapi_client.store.filename != NULL) { |
/* Unlink probably isn't sufficient */ |
/* Unlink probably isn't sufficient */ |
debug("removing gssapi cred file\"%s\"", gssapi_client.store.filename); |
debug("removing gssapi cred file\"%s\"", |
|
gssapi_client.store.filename); |
unlink(gssapi_client.store.filename); |
unlink(gssapi_client.store.filename); |
} |
} |
} |
} |