From e94fa076cbe6335a9d5e498967e1ed4098750eb3 Mon Sep 17 00:00:00 2001
From: Mark Spencer <markster@digium.com>
Date: Sun, 5 Sep 2004 18:31:50 +0000
Subject: [PATCH] Fix some small voicemail password bugs (bug #2373)

git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@3727 65c4cc65-6c06-0410-ace0-fbb531ad65f3
---
 apps/app_voicemail.c | 6 +++++-
 1 file changed, 5 insertions(+), 1 deletion(-)

diff --git a/apps/app_voicemail.c b/apps/app_voicemail.c
index 4684e6fedd..7a80aa82f8 100755
--- a/apps/app_voicemail.c
+++ b/apps/app_voicemail.c
@@ -589,6 +589,7 @@ static void vm_change_password(struct ast_vm_user *vmu, char *newpassword)
 		char tmpin[AST_CONFIG_MAX_PATH];
 		char tmpout[AST_CONFIG_MAX_PATH];
 		char *user, *pass, *rest, *trim, *tempcontext;
+		struct stat statbuf;
 		tempcontext = NULL;
 		snprintf(tmpin, sizeof(tmpin), "%s/voicemail.conf", ast_config_AST_CONFIG_DIR);
 		snprintf(tmpout, sizeof(tmpout), "%s/voicemail.conf.new", ast_config_AST_CONFIG_DIR);
@@ -663,7 +664,7 @@ static void vm_change_password(struct ast_vm_user *vmu, char *newpassword)
 				
 				/* Compare user, pass AND context */
 				if (user && *user && !strcmp(user, vmu->mailbox) &&
-					 pass && *pass && !strcmp(pass, vmu->password) &&
+					 pass && !strcmp(pass, vmu->password) &&
 					 currcontext && *currcontext && !strcmp(currcontext, vmu->context)) {
 					/* This is the line */
 					if (rest) {
@@ -680,6 +681,9 @@ static void vm_change_password(struct ast_vm_user *vmu, char *newpassword)
         fclose(configin);
         fclose(configout);
 
+		stat((char *)tmpin, &statbuf);
+		chmod((char *)tmpout, statbuf.st_mode);
+		chown((char *)tmpout, statbuf.st_uid, statbuf.st_gid);
         unlink((char *)tmpin);
         rename((char *)tmpout,(char *)tmpin);
 	reset_user_pw(vmu->context, vmu->mailbox, newpassword);
-- 
GitLab