summaryrefslogtreecommitdiff
path: root/source3
diff options
context:
space:
mode:
authorTim Potter <tpot@samba.org>2000-07-26 03:55:17 +0000
committerTim Potter <tpot@samba.org>2000-07-26 03:55:17 +0000
commit18db0514fddf15c9aa5eeefa18891bbf3e0637f5 (patch)
tree786759cf73eb4349a65db8ccc75ff3706cfe55c2 /source3
parentc89cf814cc976924c9e1db7ea448af3893a6f70d (diff)
downloadsamba-18db0514fddf15c9aa5eeefa18891bbf3e0637f5.tar.gz
samba-18db0514fddf15c9aa5eeefa18891bbf3e0637f5.tar.bz2
samba-18db0514fddf15c9aa5eeefa18891bbf3e0637f5.zip
Fixed memory leaks in root and non-root password changing.
(This used to be commit f3a4f81a5e51e411f1c7c6245597cca01e9ad5b2)
Diffstat (limited to 'source3')
-rw-r--r--source3/utils/smbpasswd.c27
1 files changed, 20 insertions, 7 deletions
diff --git a/source3/utils/smbpasswd.c b/source3/utils/smbpasswd.c
index 7f26c1d0e9..318047db20 100644
--- a/source3/utils/smbpasswd.c
+++ b/source3/utils/smbpasswd.c
@@ -193,16 +193,18 @@ static char *prompt_for_new_password(BOOL stdin_get)
p = get_pass("New SMB password:", stdin_get);
fstrcpy(new_passwd, p);
+ safe_free(p);
p = get_pass("Retype new SMB password:", stdin_get);
if (strcmp(p, new_passwd)) {
fprintf(stderr, "Mismatch - password unchanged.\n");
ZERO_ARRAY(new_passwd);
+ safe_free(p);
return NULL;
}
- return xstrdup(p);
+ return p;
}
@@ -249,7 +251,7 @@ static BOOL password_change(const char *remote_machine, char *user_name,
static int process_root(int argc, char *argv[])
{
struct passwd *pwd;
- int ch;
+ int result = 0, ch;
BOOL joining_domain = False;
int local_flags = 0;
BOOL stdin_passwd_get = False;
@@ -417,7 +419,8 @@ static int process_root(int argc, char *argv[])
if (!password_change(remote_machine, user_name, old_passwd, new_passwd, local_flags)) {
fprintf(stderr,"Failed to modify password entry for user %s\n", user_name);
- return 1;
+ result = 1;
+ goto done;
}
if(!(local_flags & (LOCAL_ADD_USER|LOCAL_DISABLE_USER|LOCAL_ENABLE_USER|LOCAL_DELETE_USER|LOCAL_SET_NO_PASSWORD))) {
@@ -429,7 +432,10 @@ static int process_root(int argc, char *argv[])
printf(" User has no password flag set.");
printf("\n");
}
- return 0;
+
+ done:
+ safe_free(new_passwd);
+ return result;
}
@@ -439,7 +445,7 @@ handle password changing for non-root
static int process_nonroot(int argc, char *argv[])
{
struct passwd *pwd = NULL;
- int ch;
+ int result = 0, ch;
BOOL stdin_passwd_get = False;
char *old_passwd = NULL;
char *remote_machine = NULL;
@@ -514,11 +520,18 @@ static int process_nonroot(int argc, char *argv[])
if (!password_change(remote_machine, user_name, old_passwd, new_passwd, 0)) {
fprintf(stderr,"Failed to change password for %s\n", user_name);
- return 1;
+ result = 1;
+ goto done;
}
printf("Password changed for user %s\n", user_name);
- return 0;
+
+ done:
+ safe_free(old_passwd);
+ safe_free(new_passwd);
+ safe_free(user_name);
+
+ return result;
}