Merge to one program.

git-svn-id: svn://svn.h5l.se/heimdal/trunk/heimdal@1812 ec53bebd-3082-4978-b11e-865c3cabbd6b
This commit is contained in:
Johan Danielsson
1997-06-01 21:14:56 +00:00
parent 2b0977609b
commit 7d955a6940
12 changed files with 679 additions and 104 deletions

View File

@@ -2,32 +2,73 @@
RCSID("$Id$");
int main(int argc, char **argv)
char *
time2str(time_t t)
{
static char s[32];
struct tm *tm;
tm = gmtime(&t);
strftime(s, sizeof(s), "%Y%m%d%H%M%S", tm);
return s;
}
char *
key2str(krb5_keyblock *key)
{
static char *s;
unsigned char *p;
int i;
if(s)
free(s);
s = malloc(key->contents.length/2+10);
sprintf(s, "%d:", key->keytype);
p = (unsigned char*)key->contents.data;
for(i = 0; i < key->contents.length; i++)
sprintf(s + strlen(s), "%02x", p[i]);
return s;
}
void
dump(int argc, char **argv)
{
HDB *db;
hdb_entry ent;
krb5_context context;
int err;
int i;
FILE *f;
char *p;
if(argc < 2)
f = stdout;
else
f = fopen(argv[1], "w");
krb5_init_context(&context);
err = hdb_open(context, &db, argv[1], O_RDONLY, 0600);
err = hdb_open(context, &db, database, O_RDONLY, 0600);
if(err){
fprintf(stderr, "%s\n", krb5_get_err_text(context, err));
exit(1);
warnx("hdb_open: %s", krb5_get_err_text(context, err));
if(f != stdout)
fclose(f);
return;
}
err = db->firstkey(context, db, &ent);
while(err == 0){
char *p;
krb5_unparse_name(context, ent.principal, &p);
printf("%s ", p);
for(i = 0; i < ent.keyblock.contents.length; i++)
printf("%02x", (int)((unsigned char*)ent.keyblock.contents.data)[i]);
printf(" ");
printf("%d %d %d\n", ent.kvno, ent.max_life, ent.max_renew);
fprintf(f, "%s ", p);
free(p);
fprintf(f, "%d:%s", ent.kvno, key2str(&ent.keyblock));
fprintf(f, " %d %d %s",
ent.max_life,
ent.max_renew,
time2str(ent.last_change));
krb5_unparse_name(context, ent.changed_by, &p);
fprintf(f, " %s %s %d\n",
p,
time2str(ent.expires),
ent.u.flags);
free(p);
err = db->nextkey(context, db, &ent);
}
if(f != stdout)
fclose(f);
}