new file
git-svn-id: svn://svn.h5l.se/heimdal/trunk/heimdal@1292 ec53bebd-3082-4978-b11e-865c3cabbd6b
This commit is contained in:
27
lib/krb5/checksum.c
Normal file
27
lib/krb5/checksum.c
Normal file
@@ -0,0 +1,27 @@
|
||||
#include <krb5_locl.h>
|
||||
#include <krb5_error.h>
|
||||
#include "md4.h"
|
||||
|
||||
krb5_error_code
|
||||
krb5_create_checksum (krb5_context context,
|
||||
krb5_cksumtype type,
|
||||
void *ptr,
|
||||
size_t len,
|
||||
Checksum *result)
|
||||
{
|
||||
struct md4 m;
|
||||
|
||||
if (type != CKSUMTYPE_RSA_MD4)
|
||||
abort ();
|
||||
|
||||
result->cksumtype = CKSUMTYPE_RSA_MD4;
|
||||
result->checksum.length = 16;
|
||||
result->checksum.data = malloc(16);
|
||||
if (result->checksum.data == NULL)
|
||||
return ENOMEM;
|
||||
|
||||
md4_init(&m);
|
||||
md4_update(&m, ptr, len);
|
||||
md4_finito (&m, result->checksum.data);
|
||||
return 0;
|
||||
}
|
54
lib/krb5/mk_safe.c
Normal file
54
lib/krb5/mk_safe.c
Normal file
@@ -0,0 +1,54 @@
|
||||
#include <krb5_locl.h>
|
||||
#include <krb5_error.h>
|
||||
#include "md4.h"
|
||||
|
||||
krb5_error_code
|
||||
krb5_mk_safe(krb5_context context,
|
||||
krb5_auth_context auth_context,
|
||||
const krb5_data *userdata,
|
||||
krb5_data *outbuf,
|
||||
/*krb5_replay_data*/ void *outdata)
|
||||
{
|
||||
krb5_error_code r;
|
||||
KRB_SAFE s;
|
||||
struct timeval tv;
|
||||
unsigned usec;
|
||||
krb5_addresses addr;
|
||||
Checksum c;
|
||||
u_char buf[1024];
|
||||
int len;
|
||||
|
||||
r = krb5_create_checksum (context,
|
||||
CKSUMTYPE_RSA_MD4,
|
||||
userdata->data,
|
||||
userdata->length,
|
||||
&c);
|
||||
if (r)
|
||||
return r;
|
||||
|
||||
r = krb5_get_all_client_addrs (&addr);
|
||||
if (r)
|
||||
return r;
|
||||
|
||||
s.pvno = 5;
|
||||
s.msg_type = krb_safe;
|
||||
s.safe_body.user_data = *userdata;
|
||||
gettimeofday (&tv, NULL);
|
||||
usec = tv.tv_usec;
|
||||
s.safe_body.timestamp = &tv.tv_sec;
|
||||
s.safe_body.usec = &usec;
|
||||
s.safe_body.seq_number = NULL;
|
||||
s.safe_body.s_address.addr_type = addr.addrs[0].type;
|
||||
s.safe_body.s_address.address = addr.addrs[0].address;
|
||||
s.safe_body.r_address = NULL;
|
||||
|
||||
len = encode_KRB_SAFE (buf + sizeof(buf) - 1, sizeof(buf), &s);
|
||||
if (len < 0)
|
||||
return ASN1_PARSE_ERROR;
|
||||
outbuf->length = len;
|
||||
outbuf->data = malloc (len);
|
||||
if (outbuf->data == NULL)
|
||||
return ENOMEM;
|
||||
memcpy (outbuf->data, buf + sizeof(buf) - len, len);
|
||||
return 0;
|
||||
}
|
Reference in New Issue
Block a user