added passwd and change_random_key

git-svn-id: svn://svn.h5l.se/heimdal/trunk/heimdal@3639 ec53bebd-3082-4978-b11e-865c3cabbd6b
This commit is contained in:
Assar Westerlund
1997-10-19 23:14:50 +00:00
parent dee1cd050e
commit 20ed54f90c

View File

@@ -41,7 +41,7 @@
RCSID("$Id$"); RCSID("$Id$");
static void static void
doit2(HDB *db, hdb_entry *ent) doit2(HDB *db, hdb_entry *ent, int changepw, int (*func)(hdb_entry *))
{ {
char buf[1024]; char buf[1024];
int ret; int ret;
@@ -62,16 +62,21 @@ doit2(HDB *db, hdb_entry *ent)
krb5_err(context, 1, ret, "dbget"); krb5_err(context, 1, ret, "dbget");
} }
edit_entry (ent); if(changepw == 0) {
for(;;) { edit_entry (ent);
fprintf(stderr, "Change password? (y/n) "); for(;;) {
fgets(buf, sizeof(buf), stdin); fprintf(stderr, "Change password? (y/n) ");
if(buf[0] == 'n' || buf[0] == 'y' || buf[0] == 'N' || buf[0] == 'Y') fgets(buf, sizeof(buf), stdin);
break; if(buf[0] == 'n' || buf[0] == 'y' || buf[0] == 'N' || buf[0] == 'Y')
fprintf(stderr, "Please answer yes or no.\n"); break;
fprintf(stderr, "Please answer yes or no.\n");
}
if(buf[0] == 'y' || buf[0] == 'Y')
changepw = 1;
} }
if(buf[0] == 'y' || buf[0] == 'Y')
if(set_password (ent)) if(changepw)
if((*func)(ent))
return; return;
set_modified_by (ent); set_modified_by (ent);
@@ -82,7 +87,7 @@ doit2(HDB *db, hdb_entry *ent)
} }
static void static void
doit(const char *principal) doit(const char *principal, int changepw, int (*func)(hdb_entry *))
{ {
hdb_entry ent; hdb_entry ent;
krb5_error_code ret; krb5_error_code ret;
@@ -95,7 +100,7 @@ doit(const char *principal)
} }
krb5_parse_name(context, principal, &ent.principal); krb5_parse_name(context, principal, &ent.principal);
doit2(db, &ent); doit2(db, &ent, changepw, func);
db->close(context, db); db->close(context, db);
hdb_free_entry(context, &ent); hdb_free_entry(context, &ent);
} }
@@ -108,6 +113,30 @@ mod_entry(int argc, char **argv)
return 0; return 0;
} }
doit(argv[1]); doit(argv[1], 0, set_password);
return 0;
}
int
passwd(int argc, char **argv)
{
if(argc != 2) {
krb5_warnx(context, "Usage: passwd principal");
return 0;
}
doit(argv[1], 1, set_password);
return 0;
}
int
change_random_key(int argc, char **argv)
{
if(argc != 2) {
krb5_warnx(context, "Usage: change_random_key principal");
return 0;
}
doit(argv[1], 1, set_random_key);
return 0; return 0;
} }