leak less memory
git-svn-id: svn://svn.h5l.se/heimdal/trunk/heimdal@3213 ec53bebd-3082-4978-b11e-865c3cabbd6b
This commit is contained in:
@@ -46,13 +46,15 @@ doit(const char *principal)
|
||||
HDB *db;
|
||||
hdb_entry ent;
|
||||
krb5_error_code ret;
|
||||
krb5_principal ent_principal;
|
||||
|
||||
memset(&ent, 0, sizeof(ent));
|
||||
if((ret = hdb_open(context, &db, database, O_RDWR, 0600))) {
|
||||
krb5_warn(context, ret, "hdb_open");
|
||||
return;
|
||||
}
|
||||
krb5_parse_name(context, principal, &ent.principal);
|
||||
krb5_parse_name(context, principal, &ent_principal);
|
||||
ent.principal = ent_principal;
|
||||
|
||||
ret = db->fetch(context, db, &ent);
|
||||
|
||||
@@ -61,7 +63,8 @@ doit(const char *principal)
|
||||
break;
|
||||
case 0:
|
||||
krb5_warnx(context, "Principal exists");
|
||||
return;
|
||||
krb5_free_principal (context, ent_principal);
|
||||
goto cleanup;
|
||||
default:
|
||||
krb5_err(context, 1, ret, "dbget");
|
||||
}
|
||||
@@ -74,6 +77,7 @@ doit(const char *principal)
|
||||
if(ret)
|
||||
krb5_err(context, 1, ret, "db->store");
|
||||
|
||||
cleanup:
|
||||
db->close(context, db);
|
||||
hdb_free_entry(context, &ent);
|
||||
}
|
||||
|
@@ -48,6 +48,7 @@ ext_keytab(int argc, char **argv)
|
||||
int ret;
|
||||
krb5_keytab kid;
|
||||
krb5_keytab_entry key_entry;
|
||||
krb5_principal principal;
|
||||
|
||||
if(argc < 2 || argc > 3){
|
||||
krb5_warnx(context, "Usage: ext_keytab principal [file]");
|
||||
@@ -60,11 +61,12 @@ ext_keytab(int argc, char **argv)
|
||||
return 0;
|
||||
}
|
||||
|
||||
ret = krb5_parse_name (context, argv[1], &ent.principal);
|
||||
ret = krb5_parse_name (context, argv[1], &principal);
|
||||
if (ret) {
|
||||
krb5_warn(context, ret, "krb5_parse_name");
|
||||
goto cleanup1;
|
||||
}
|
||||
ent.principal = principal;
|
||||
|
||||
ret = db->fetch(context, db, &ent);
|
||||
if (ret) {
|
||||
@@ -73,7 +75,10 @@ ext_keytab(int argc, char **argv)
|
||||
goto cleanup1;
|
||||
}
|
||||
|
||||
key_entry.principal = principal;
|
||||
#if 0
|
||||
krb5_copy_principal (context, ent.principal, &key_entry.principal);
|
||||
#endif
|
||||
key_entry.vno = ent.kvno;
|
||||
/* XXX XXX XXX XXX */
|
||||
key_entry.keyblock.keytype = ent.keys.val[0].key.keytype;
|
||||
|
13
admin/get.c
13
admin/get.c
@@ -47,19 +47,24 @@ get_entry(int argc, char **argv)
|
||||
int ret;
|
||||
hdb_entry ent;
|
||||
int i;
|
||||
krb5_principal principal;
|
||||
|
||||
if(argc != 2) {
|
||||
krb5_warnx(context, "Usage: get_entry principal");
|
||||
return 0;
|
||||
}
|
||||
|
||||
krb5_parse_name(context, argv[1], &ent.principal);
|
||||
|
||||
if((ret = hdb_open(context, &db, database, O_RDONLY, 0600))) {
|
||||
krb5_warn(context, ret, "hdb_open");
|
||||
return 0;
|
||||
}
|
||||
|
||||
krb5_parse_name(context, argv[1], &principal);
|
||||
|
||||
memset (&ent, 0, sizeof(ent));
|
||||
|
||||
ent.principal = principal;
|
||||
|
||||
ret = db->fetch(context, db, &ent);
|
||||
|
||||
switch(ret){
|
||||
@@ -70,6 +75,8 @@ get_entry(int argc, char **argv)
|
||||
char buf[128];
|
||||
char *name;
|
||||
|
||||
krb5_free_principal(context, principal);
|
||||
|
||||
krb5_unparse_name(context, ent.principal, &name);
|
||||
printf("Principal: %s\n", name);
|
||||
free(name);
|
||||
@@ -126,7 +133,7 @@ get_entry(int argc, char **argv)
|
||||
krb5_warn(context, ret, "db->fetch");
|
||||
break;
|
||||
}
|
||||
memset(&ent, 0, sizeof(ent));
|
||||
hdb_free_entry (context, &ent);
|
||||
db->close(context, db);
|
||||
return 0;
|
||||
}
|
||||
|
@@ -45,6 +45,9 @@ doit2(HDB *db, hdb_entry *ent)
|
||||
{
|
||||
char buf[1024];
|
||||
int ret;
|
||||
krb5_principal hata;
|
||||
|
||||
hata = ent->principal;
|
||||
|
||||
ret = db->fetch(context, db, ent);
|
||||
|
||||
@@ -53,6 +56,7 @@ doit2(HDB *db, hdb_entry *ent)
|
||||
krb5_warnx(context, "Entry not found in database");
|
||||
return;
|
||||
case 0:
|
||||
krb5_free_principal (context, hata);
|
||||
break;
|
||||
default:
|
||||
krb5_err(context, 1, ret, "dbget");
|
||||
@@ -81,6 +85,8 @@ doit(const char *principal)
|
||||
HDB *db;
|
||||
hdb_entry ent;
|
||||
krb5_error_code ret;
|
||||
|
||||
|
||||
memset(&ent, 0, sizeof(ent));
|
||||
if((ret = hdb_open(context, &db, database, O_RDWR, 0600))){
|
||||
krb5_warn(context, ret, "hdb_open");
|
||||
|
Reference in New Issue
Block a user