mirror of
https://github.com/mattermost/mattermost.git
synced 2025-02-25 18:55:24 -06:00
Added new email to email change notification
This commit is contained in:
@@ -18,7 +18,7 @@
|
||||
<tr>
|
||||
<td style="border-bottom: 1px solid #ddd; padding: 0 0 20px;">
|
||||
<h2 style="font-weight: normal; margin-top: 10px;">You updated your email</h2>
|
||||
<p>You email address for {{.Props.TeamDisplayName}} has been changed.<br>If you did not make this change, please contact the system administrator.</p>
|
||||
<p>You email address for {{.Props.TeamDisplayName}} has been changed to {{.Props.NewEmail}}.<br>If you did not make this change, please contact the system administrator.</p>
|
||||
</td>
|
||||
</tr>
|
||||
<tr>
|
||||
|
||||
11
api/user.go
11
api/user.go
@@ -887,7 +887,7 @@ func updateUser(c *Context, w http.ResponseWriter, r *http.Request) {
|
||||
l4g.Error(tresult.Err.Message)
|
||||
} else {
|
||||
team := tresult.Data.(*model.Team)
|
||||
fireAndForgetEmailChangeEmail(rusers[1].Email, team.DisplayName, c.GetTeamURLFromTeam(team), c.GetSiteURL())
|
||||
fireAndForgetEmailChangeEmail(rusers[1].Email, rusers[0].Email, team.DisplayName, c.GetTeamURLFromTeam(team), c.GetSiteURL())
|
||||
|
||||
if utils.Cfg.EmailSettings.RequireEmailVerification {
|
||||
FireAndForgetEmailChangeVerifyEmail(rusers[0].Id, rusers[0].Email, team.Name, team.DisplayName, c.GetSiteURL(), c.GetTeamURLFromTeam(team))
|
||||
@@ -1326,7 +1326,7 @@ func fireAndForgetPasswordChangeEmail(email, teamDisplayName, teamURL, siteURL,
|
||||
}()
|
||||
}
|
||||
|
||||
func fireAndForgetEmailChangeEmail(email, teamDisplayName, teamURL, siteURL string) {
|
||||
func fireAndForgetEmailChangeEmail(oldEmail, newEmail, teamDisplayName, teamURL, siteURL string) {
|
||||
go func() {
|
||||
|
||||
subjectPage := NewServerTemplatePage("email_change_subject")
|
||||
@@ -1336,9 +1336,10 @@ func fireAndForgetEmailChangeEmail(email, teamDisplayName, teamURL, siteURL stri
|
||||
bodyPage.Props["SiteURL"] = siteURL
|
||||
bodyPage.Props["TeamDisplayName"] = teamDisplayName
|
||||
bodyPage.Props["TeamURL"] = teamURL
|
||||
bodyPage.Props["NewEmail"] = newEmail
|
||||
|
||||
if err := utils.SendMail(email, subjectPage.Render(), bodyPage.Render()); err != nil {
|
||||
l4g.Error("Failed to send update password email successfully err=%v", err)
|
||||
if err := utils.SendMail(oldEmail, subjectPage.Render(), bodyPage.Render()); err != nil {
|
||||
l4g.Error("Failed to send email change notification email successfully err=%v", err)
|
||||
}
|
||||
|
||||
}()
|
||||
@@ -1358,7 +1359,7 @@ func FireAndForgetEmailChangeVerifyEmail(userId, newUserEmail, teamName, teamDis
|
||||
bodyPage.Props["VerifyUrl"] = link
|
||||
|
||||
if err := utils.SendMail(newUserEmail, subjectPage.Render(), bodyPage.Render()); err != nil {
|
||||
l4g.Error("Failed to send verification email successfully err=%v", err)
|
||||
l4g.Error("Failed to send email change verification email successfully err=%v", err)
|
||||
}
|
||||
}()
|
||||
}
|
||||
|
||||
@@ -115,26 +115,19 @@ export default class UserSettingsGeneralTab extends React.Component {
|
||||
}
|
||||
|
||||
user.email = email;
|
||||
|
||||
if (this.state.emailEnabled && this.state.emailVerificationEnabled) {
|
||||
this.submitUser(user, {emailChangeInProgress: true});
|
||||
} else {
|
||||
this.submitUser(user, {emailChangeInProgress: false});
|
||||
}
|
||||
this.submitUser(user);
|
||||
}
|
||||
submitUser(user, newState) {
|
||||
submitUser(user) {
|
||||
client.updateUser(user,
|
||||
function updateSuccess() {
|
||||
this.updateSection('');
|
||||
AsyncClient.getMe();
|
||||
const verificationEnabled = global.window.config.SendEmailNotifications === 'true' && global.window.config.RequireEmailVerification === 'true';
|
||||
|
||||
if (newState) {
|
||||
if (newState.emailChangeInProgress) {
|
||||
ErrorStore.storeLastError({message: 'Check your email at ' + user.email + ' to verify the address.'});
|
||||
ErrorStore.emitChange();
|
||||
}
|
||||
|
||||
this.setState(newState);
|
||||
if (verificationEnabled) {
|
||||
ErrorStore.storeLastError({message: 'Check your email at ' + user.email + ' to verify the address.'});
|
||||
ErrorStore.emitChange();
|
||||
this.setState({emailChangeInProgress: true});
|
||||
}
|
||||
}.bind(this),
|
||||
function updateFailure(err) {
|
||||
@@ -233,12 +226,9 @@ export default class UserSettingsGeneralTab extends React.Component {
|
||||
}
|
||||
setupInitialState(props) {
|
||||
var user = props.user;
|
||||
var emailEnabled = global.window.config.SendEmailNotifications === 'true';
|
||||
var emailVerificationEnabled = global.window.config.RequireEmailVerification === 'true';
|
||||
|
||||
return {username: user.username, firstName: user.first_name, lastName: user.last_name, nickname: user.nickname,
|
||||
email: user.email, confirmEmail: '', picture: null, loadingPicture: false, emailEnabled: emailEnabled,
|
||||
emailVerificationEnabled: emailVerificationEnabled, emailChangeInProgress: false};
|
||||
email: user.email, confirmEmail: '', picture: null, loadingPicture: false, emailChangeInProgress: false};
|
||||
}
|
||||
render() {
|
||||
var user = this.props.user;
|
||||
@@ -462,11 +452,13 @@ export default class UserSettingsGeneralTab extends React.Component {
|
||||
}
|
||||
var emailSection;
|
||||
if (this.props.activeSection === 'email') {
|
||||
const emailEnabled = global.window.config.SendEmailNotifications === 'true';
|
||||
const emailVerificationEnabled = global.window.config.RequireEmailVerification === 'true';
|
||||
let helpText = 'Email is used for notifications, and requires verification if changed.';
|
||||
|
||||
if (!this.state.emailEnabled) {
|
||||
if (!emailEnabled) {
|
||||
helpText = <div className='setting-list__hint text-danger'>{'Email has been disabled by your system administrator. No notification emails will be sent until it is enabled.'}</div>;
|
||||
} else if (!this.state.emailVerificationEnabled) {
|
||||
} else if (!emailVerificationEnabled) {
|
||||
helpText = 'Email is used for notifications.';
|
||||
} else if (this.state.emailChangeInProgress) {
|
||||
const newEmail = UserStore.getCurrentUser().email;
|
||||
|
||||
Reference in New Issue
Block a user