Removed
git-svn-id: svn://svn.h5l.se/heimdal/trunk/heimdal@2392 ec53bebd-3082-4978-b11e-865c3cabbd6b
This commit is contained in:
95
string2key.c
95
string2key.c
@@ -1,95 +0,0 @@
|
|||||||
#include "krb5_locl.h"
|
|
||||||
|
|
||||||
/* XXX */
|
|
||||||
|
|
||||||
#ifdef sun
|
|
||||||
#define memmove(a,b,c) bcopy(b,a,c)
|
|
||||||
#endif
|
|
||||||
|
|
||||||
static void reverse(unsigned char *p)
|
|
||||||
{
|
|
||||||
unsigned char tmp[8];
|
|
||||||
unsigned int a, b;
|
|
||||||
int i;
|
|
||||||
|
|
||||||
a = 0;
|
|
||||||
b = *(unsigned int*)p;
|
|
||||||
for(i = 0; i < 32; i++){
|
|
||||||
a >>= 1;
|
|
||||||
a |= b & 0x80000000;
|
|
||||||
b <<= 1;
|
|
||||||
}
|
|
||||||
*(unsigned int*)(tmp + 4) = a;
|
|
||||||
|
|
||||||
a = 0;
|
|
||||||
b = *(unsigned int*)(p + 4);
|
|
||||||
for(i = 0; i < 32; i++){
|
|
||||||
a >>= 1;
|
|
||||||
a |= b & 0x80000000;
|
|
||||||
b <<= 1;
|
|
||||||
}
|
|
||||||
*(unsigned int*)tmp = a;
|
|
||||||
|
|
||||||
a = 0;
|
|
||||||
b = 0;
|
|
||||||
memmove(p, tmp, 8);
|
|
||||||
memset(tmp, 0, 8);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
krb5_error_code
|
|
||||||
mit_des_string_to_key(const krb5_keytype keytype,
|
|
||||||
krb5_keyblock *keyblock,
|
|
||||||
krb5_data *data,
|
|
||||||
krb5_data *salt)
|
|
||||||
{
|
|
||||||
unsigned char *p;
|
|
||||||
unsigned char *key;
|
|
||||||
unsigned char tmp[8];
|
|
||||||
|
|
||||||
des_key_schedule sched;
|
|
||||||
|
|
||||||
int len;
|
|
||||||
int i, j;
|
|
||||||
int odd = 0;
|
|
||||||
|
|
||||||
len = data->length;
|
|
||||||
if(salt)
|
|
||||||
len += salt->length;
|
|
||||||
len = (len / 8 + 1) * 8;
|
|
||||||
p = (unsigned char*)malloc(len);
|
|
||||||
memset(p, 0, len);
|
|
||||||
memmove(p, data->data, data->length);
|
|
||||||
if(salt)
|
|
||||||
memmove(p + data->length, salt->data, salt->length);
|
|
||||||
|
|
||||||
memset(key, 0, 8);
|
|
||||||
|
|
||||||
for(i = 0; i < len; i += 8){
|
|
||||||
memmove(tmp, p + i, 8);
|
|
||||||
if(odd)
|
|
||||||
reverse(tmp);
|
|
||||||
#ifndef RFC1510
|
|
||||||
else
|
|
||||||
for(j = 0; j < 8; j++) tmp[j] <<= 1;
|
|
||||||
#endif
|
|
||||||
for(j = 0; j < 8; j++)
|
|
||||||
key[j] ^= tmp[j];
|
|
||||||
odd = !odd;
|
|
||||||
}
|
|
||||||
|
|
||||||
des_set_odd_parity(key);
|
|
||||||
des_key_sched(key, &sched);
|
|
||||||
des_cbc_cksum(key, key, 8, &sched, key);
|
|
||||||
des_set_odd_parity(key);
|
|
||||||
if(des_is_weak_key(key))
|
|
||||||
key[8] ^= 0xf0;
|
|
||||||
memset(p, 0, len);
|
|
||||||
memset(tmp, 0, 8);
|
|
||||||
free(p);
|
|
||||||
keyblock->keytype = KEYTYPE_DES;
|
|
||||||
keyblock->contents.data = key;
|
|
||||||
keyblock->contents.length = 8;
|
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
|
49
test.c
49
test.c
@@ -1,49 +0,0 @@
|
|||||||
#include <stdio.h>
|
|
||||||
#include "krb5.h"
|
|
||||||
#include "config_file.h"
|
|
||||||
|
|
||||||
int main(int argc, char **argv)
|
|
||||||
{
|
|
||||||
krb5_error_code err;
|
|
||||||
krb5_context context;
|
|
||||||
krb5_ccache ccache;
|
|
||||||
krb5_creds cred, out_cred;
|
|
||||||
#if 0
|
|
||||||
k5_cfile *cf;
|
|
||||||
char *p;
|
|
||||||
krb5_parse_config_file(&cf, "krb5.conf");
|
|
||||||
krb5_get_config_tag(cf, "realms ATHENA.MIT.EDU v4_instance_convert mit", &p);
|
|
||||||
#endif
|
|
||||||
|
|
||||||
err = krb5_init_context (&context);
|
|
||||||
if (err)
|
|
||||||
abort ();
|
|
||||||
|
|
||||||
err = krb5_cc_default (context, &ccache);
|
|
||||||
if (err)
|
|
||||||
abort ();
|
|
||||||
|
|
||||||
err = krb5_build_principal (context,
|
|
||||||
&cred.server,
|
|
||||||
strlen("x-dce.pdc.kth.se"),
|
|
||||||
"x-dce.pdc.kth.se",
|
|
||||||
"host",
|
|
||||||
"sisyphus.pdc.kth.se",
|
|
||||||
NULL);
|
|
||||||
if (err)
|
|
||||||
abort ();
|
|
||||||
cred.server->type = KRB5_NT_SRV_HST;
|
|
||||||
cred.times.endtime = time (NULL) + 4711;
|
|
||||||
|
|
||||||
err = krb5_get_credentials (context,
|
|
||||||
0,
|
|
||||||
ccache,
|
|
||||||
&cred,
|
|
||||||
&out_cred);
|
|
||||||
if (err)
|
|
||||||
abort ();
|
|
||||||
|
|
||||||
krb5_free_context ();
|
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
|
Reference in New Issue
Block a user