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 *db;
|
||||||
hdb_entry ent;
|
hdb_entry ent;
|
||||||
krb5_error_code ret;
|
krb5_error_code ret;
|
||||||
|
krb5_principal ent_principal;
|
||||||
|
|
||||||
memset(&ent, 0, sizeof(ent));
|
memset(&ent, 0, sizeof(ent));
|
||||||
if((ret = hdb_open(context, &db, database, O_RDWR, 0600))) {
|
if((ret = hdb_open(context, &db, database, O_RDWR, 0600))) {
|
||||||
krb5_warn(context, ret, "hdb_open");
|
krb5_warn(context, ret, "hdb_open");
|
||||||
return;
|
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);
|
ret = db->fetch(context, db, &ent);
|
||||||
|
|
||||||
@@ -61,7 +63,8 @@ doit(const char *principal)
|
|||||||
break;
|
break;
|
||||||
case 0:
|
case 0:
|
||||||
krb5_warnx(context, "Principal exists");
|
krb5_warnx(context, "Principal exists");
|
||||||
return;
|
krb5_free_principal (context, ent_principal);
|
||||||
|
goto cleanup;
|
||||||
default:
|
default:
|
||||||
krb5_err(context, 1, ret, "dbget");
|
krb5_err(context, 1, ret, "dbget");
|
||||||
}
|
}
|
||||||
@@ -74,6 +77,7 @@ doit(const char *principal)
|
|||||||
if(ret)
|
if(ret)
|
||||||
krb5_err(context, 1, ret, "db->store");
|
krb5_err(context, 1, ret, "db->store");
|
||||||
|
|
||||||
|
cleanup:
|
||||||
db->close(context, db);
|
db->close(context, db);
|
||||||
hdb_free_entry(context, &ent);
|
hdb_free_entry(context, &ent);
|
||||||
}
|
}
|
||||||
|
@@ -48,6 +48,7 @@ ext_keytab(int argc, char **argv)
|
|||||||
int ret;
|
int ret;
|
||||||
krb5_keytab kid;
|
krb5_keytab kid;
|
||||||
krb5_keytab_entry key_entry;
|
krb5_keytab_entry key_entry;
|
||||||
|
krb5_principal principal;
|
||||||
|
|
||||||
if(argc < 2 || argc > 3){
|
if(argc < 2 || argc > 3){
|
||||||
krb5_warnx(context, "Usage: ext_keytab principal [file]");
|
krb5_warnx(context, "Usage: ext_keytab principal [file]");
|
||||||
@@ -60,11 +61,12 @@ ext_keytab(int argc, char **argv)
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
ret = krb5_parse_name (context, argv[1], &ent.principal);
|
ret = krb5_parse_name (context, argv[1], &principal);
|
||||||
if (ret) {
|
if (ret) {
|
||||||
krb5_warn(context, ret, "krb5_parse_name");
|
krb5_warn(context, ret, "krb5_parse_name");
|
||||||
goto cleanup1;
|
goto cleanup1;
|
||||||
}
|
}
|
||||||
|
ent.principal = principal;
|
||||||
|
|
||||||
ret = db->fetch(context, db, &ent);
|
ret = db->fetch(context, db, &ent);
|
||||||
if (ret) {
|
if (ret) {
|
||||||
@@ -73,7 +75,10 @@ ext_keytab(int argc, char **argv)
|
|||||||
goto cleanup1;
|
goto cleanup1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
key_entry.principal = principal;
|
||||||
|
#if 0
|
||||||
krb5_copy_principal (context, ent.principal, &key_entry.principal);
|
krb5_copy_principal (context, ent.principal, &key_entry.principal);
|
||||||
|
#endif
|
||||||
key_entry.vno = ent.kvno;
|
key_entry.vno = ent.kvno;
|
||||||
/* XXX XXX XXX XXX */
|
/* XXX XXX XXX XXX */
|
||||||
key_entry.keyblock.keytype = ent.keys.val[0].key.keytype;
|
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;
|
int ret;
|
||||||
hdb_entry ent;
|
hdb_entry ent;
|
||||||
int i;
|
int i;
|
||||||
|
krb5_principal principal;
|
||||||
|
|
||||||
if(argc != 2) {
|
if(argc != 2) {
|
||||||
krb5_warnx(context, "Usage: get_entry principal");
|
krb5_warnx(context, "Usage: get_entry principal");
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
krb5_parse_name(context, argv[1], &ent.principal);
|
|
||||||
|
|
||||||
if((ret = hdb_open(context, &db, database, O_RDONLY, 0600))) {
|
if((ret = hdb_open(context, &db, database, O_RDONLY, 0600))) {
|
||||||
krb5_warn(context, ret, "hdb_open");
|
krb5_warn(context, ret, "hdb_open");
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
krb5_parse_name(context, argv[1], &principal);
|
||||||
|
|
||||||
|
memset (&ent, 0, sizeof(ent));
|
||||||
|
|
||||||
|
ent.principal = principal;
|
||||||
|
|
||||||
ret = db->fetch(context, db, &ent);
|
ret = db->fetch(context, db, &ent);
|
||||||
|
|
||||||
switch(ret){
|
switch(ret){
|
||||||
@@ -70,6 +75,8 @@ get_entry(int argc, char **argv)
|
|||||||
char buf[128];
|
char buf[128];
|
||||||
char *name;
|
char *name;
|
||||||
|
|
||||||
|
krb5_free_principal(context, principal);
|
||||||
|
|
||||||
krb5_unparse_name(context, ent.principal, &name);
|
krb5_unparse_name(context, ent.principal, &name);
|
||||||
printf("Principal: %s\n", name);
|
printf("Principal: %s\n", name);
|
||||||
free(name);
|
free(name);
|
||||||
@@ -126,7 +133,7 @@ get_entry(int argc, char **argv)
|
|||||||
krb5_warn(context, ret, "db->fetch");
|
krb5_warn(context, ret, "db->fetch");
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
memset(&ent, 0, sizeof(ent));
|
hdb_free_entry (context, &ent);
|
||||||
db->close(context, db);
|
db->close(context, db);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
@@ -45,7 +45,10 @@ doit2(HDB *db, hdb_entry *ent)
|
|||||||
{
|
{
|
||||||
char buf[1024];
|
char buf[1024];
|
||||||
int ret;
|
int ret;
|
||||||
|
krb5_principal hata;
|
||||||
|
|
||||||
|
hata = ent->principal;
|
||||||
|
|
||||||
ret = db->fetch(context, db, ent);
|
ret = db->fetch(context, db, ent);
|
||||||
|
|
||||||
switch(ret){
|
switch(ret){
|
||||||
@@ -53,6 +56,7 @@ doit2(HDB *db, hdb_entry *ent)
|
|||||||
krb5_warnx(context, "Entry not found in database");
|
krb5_warnx(context, "Entry not found in database");
|
||||||
return;
|
return;
|
||||||
case 0:
|
case 0:
|
||||||
|
krb5_free_principal (context, hata);
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
krb5_err(context, 1, ret, "dbget");
|
krb5_err(context, 1, ret, "dbget");
|
||||||
@@ -81,6 +85,8 @@ doit(const char *principal)
|
|||||||
HDB *db;
|
HDB *db;
|
||||||
hdb_entry ent;
|
hdb_entry ent;
|
||||||
krb5_error_code ret;
|
krb5_error_code ret;
|
||||||
|
|
||||||
|
|
||||||
memset(&ent, 0, sizeof(ent));
|
memset(&ent, 0, sizeof(ent));
|
||||||
if((ret = hdb_open(context, &db, database, O_RDWR, 0600))){
|
if((ret = hdb_open(context, &db, database, O_RDWR, 0600))){
|
||||||
krb5_warn(context, ret, "hdb_open");
|
krb5_warn(context, ret, "hdb_open");
|
||||||
|
Reference in New Issue
Block a user