do it the right way

git-svn-id: svn://svn.h5l.se/heimdal/trunk/heimdal@2104 ec53bebd-3082-4978-b11e-865c3cabbd6b
This commit is contained in:
Assar Westerlund
1997-07-09 04:57:05 +00:00
parent 15082921fe
commit c60d70fe6d
2 changed files with 16 additions and 24 deletions

View File

@@ -14,13 +14,9 @@ krb5_mk_priv(krb5_context context,
EncKrbPrivPart part; EncKrbPrivPart part;
struct timeval tv; struct timeval tv;
unsigned usec; unsigned usec;
krb5_addresses addr;
u_char buf[1024]; u_char buf[1024];
size_t len; size_t len;
unsigned tmp_seq;
r = krb5_get_all_client_addrs (&addr);
if (r)
return r;
part.user_data = *userdata; part.user_data = *userdata;
gettimeofday (&tv, NULL); gettimeofday (&tv, NULL);
@@ -28,16 +24,16 @@ krb5_mk_priv(krb5_context context,
part.timestamp = &tv.tv_sec; part.timestamp = &tv.tv_sec;
part.usec = &usec; part.usec = &usec;
if (auth_context->flags & KRB5_AUTH_CONTEXT_DO_SEQUENCE) { if (auth_context->flags & KRB5_AUTH_CONTEXT_DO_SEQUENCE) {
part.seq_number = malloc(sizeof(*part.seq_number)); tmp_seq = ++auth_context->local_seqnumber;
*(part.seq_number) = ++auth_context->local_seqnumber; part.seq_number = &tmp_seq;
} else } else {
part.seq_number = NULL; part.seq_number = NULL;
part.s_address.addr_type = addr.val[0].addr_type; }
part.s_address.address = addr.val[0].address;
part.r_address = NULL; part.s_address = auth_context->local_address;
part.r_address = auth_context->remote_address;
r = encode_EncKrbPrivPart (buf + sizeof(buf) - 1, sizeof(buf), &part, &len); r = encode_EncKrbPrivPart (buf + sizeof(buf) - 1, sizeof(buf), &part, &len);
free (part.seq_number);
if (r) if (r)
return r; return r;

View File

@@ -13,22 +13,18 @@ krb5_mk_safe(krb5_context context,
KRB_SAFE s; KRB_SAFE s;
struct timeval tv; struct timeval tv;
unsigned usec; unsigned usec;
krb5_addresses addr;
u_char buf[1024]; u_char buf[1024];
size_t len; size_t len;
unsigned tmp_seq;
r = krb5_create_checksum (context, r = krb5_create_checksum (context,
CKSUMTYPE_RSA_MD4, auth_context->cksumtype,
userdata->data, userdata->data,
userdata->length, userdata->length,
&s.cksum); &s.cksum);
if (r) if (r)
return r; return r;
r = krb5_get_all_client_addrs (&addr);
if (r)
return r;
s.pvno = 5; s.pvno = 5;
s.msg_type = krb_safe; s.msg_type = krb_safe;
s.safe_body.user_data = *userdata; s.safe_body.user_data = *userdata;
@@ -37,15 +33,15 @@ krb5_mk_safe(krb5_context context,
s.safe_body.timestamp = &tv.tv_sec; s.safe_body.timestamp = &tv.tv_sec;
s.safe_body.usec = &usec; s.safe_body.usec = &usec;
if (auth_context->flags & KRB5_AUTH_CONTEXT_DO_SEQUENCE) { if (auth_context->flags & KRB5_AUTH_CONTEXT_DO_SEQUENCE) {
s.safe_body.seq_number = malloc(sizeof(*s.safe_body.seq_number)); tmp_seq = ++auth_context->local_seqnumber;
*(s.safe_body.seq_number) = ++auth_context->local_seqnumber; s.safe_body.seq_number = &tmp_seq;
} else } else
s.safe_body.seq_number = NULL; s.safe_body.seq_number = NULL;
s.safe_body.s_address = addr.val[0];
s.safe_body.r_address = NULL; s.safe_body.s_address = auth_context->local_address;
s.safe_body.r_address = auth_context->remote_address;
r = encode_KRB_SAFE (buf + sizeof(buf) - 1, sizeof(buf), &s, &len); r = encode_KRB_SAFE (buf + sizeof(buf) - 1, sizeof(buf), &s, &len);
free(s.safe_body.seq_number);
if (r) if (r)
return r; return r;
outbuf->length = len; outbuf->length = len;