diff options
author | Volker Lendecke <vlendec@samba.org> | 2006-01-11 12:09:30 +0000 |
---|---|---|
committer | Gerald (Jerry) Carter <jerry@samba.org> | 2007-10-10 11:06:04 -0500 |
commit | 2942f3594ba39748dca0238f1e1a5c744a7afffb (patch) | |
tree | 8895cf78006161fbdbf31541ddd2d05fa6ad14d9 /source/utils/smbpasswd.c | |
parent | 9c44fef5bec76d383d25b73ecc01dc1fc25b3f20 (diff) | |
download | samba-2942f3594ba39748dca0238f1e1a5c744a7afffb.tar.gz samba-2942f3594ba39748dca0238f1e1a5c744a7afffb.tar.xz samba-2942f3594ba39748dca0238f1e1a5c744a7afffb.zip |
r12840: Add -W to smbpasswd. Thanks to William Jojo <jojowil@hvcc.edu>.
Volker
Diffstat (limited to 'source/utils/smbpasswd.c')
-rw-r--r-- | source/utils/smbpasswd.c | 10 |
1 files changed, 9 insertions, 1 deletions
diff --git a/source/utils/smbpasswd.c b/source/utils/smbpasswd.c index 5aba1623890..7659bb2997a 100644 --- a/source/utils/smbpasswd.c +++ b/source/utils/smbpasswd.c @@ -92,7 +92,7 @@ static int process_options(int argc, char **argv, int local_flags) user_name[0] = '\0'; - while ((ch = getopt(argc, argv, "c:axdehminjr:sw:R:D:U:L")) != EOF) { + while ((ch = getopt(argc, argv, "c:axdehminjr:sw:R:D:U:LW")) != EOF) { switch(ch) { case 'L': local_flags |= LOCAL_AM_ROOT; @@ -153,6 +153,10 @@ static int process_options(int argc, char **argv, int local_flags) got_username = True; fstrcpy(user_name, optarg); break; + case 'W': + local_flags |= LOCAL_SET_LDAP_ADMIN_PW; + *ldap_secret = '\0'; + break; } case 'h': default: @@ -325,6 +329,10 @@ static int process_root(int local_flags) if (local_flags & LOCAL_SET_LDAP_ADMIN_PW) { printf("Setting stored password for \"%s\" in secrets.tdb\n", lp_ldap_admin_dn()); + if ( ! *ldap_secret ) { + new_passwd = prompt_for_new_password(stdin_passwd_get); + fstrcpy(ldap_secret, new_passwd); + } if (!store_ldap_admin_pw(ldap_secret)) DEBUG(0,("ERROR: Failed to store the ldap admin password!\n")); goto done; |