leak less memory

git-svn-id: svn://svn.h5l.se/heimdal/trunk/heimdal@3213 ec53bebd-3082-4978-b11e-865c3cabbd6b
This commit is contained in:
Assar Westerlund
1997-08-28 01:25:40 +00:00
parent 953e6c5192
commit db5b678e09
4 changed files with 28 additions and 6 deletions

View File

@@ -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);
}

View File

@@ -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;

View File

@@ -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;
}

View File

@@ -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");