|  | @@ -133,13 +133,12 @@ func SettingsEmails(ctx *middleware.Context) {
 | 
	
		
			
				|  |  |  	ctx.Data["PageIsUserSettings"] = true
 | 
	
		
			
				|  |  |  	ctx.Data["PageIsSettingsEmails"] = true
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -	var err error
 | 
	
		
			
				|  |  | -	ctx.Data["Emails"], err = models.GetEmailAddresses(ctx.User.Id)
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | +	emails, err := models.GetEmailAddresses(ctx.User.Id)
 | 
	
		
			
				|  |  |  	if err != nil {
 | 
	
		
			
				|  |  | -		ctx.Handle(500, "email.GetEmailAddresses", err)
 | 
	
		
			
				|  |  | +		ctx.Handle(500, "GetEmailAddresses", err)
 | 
	
		
			
				|  |  |  		return
 | 
	
		
			
				|  |  |  	}
 | 
	
		
			
				|  |  | +	ctx.Data["Emails"] = emails
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  	ctx.HTML(200, SETTINGS_EMAILS)
 | 
	
		
			
				|  |  |  }
 | 
	
	
		
			
				|  | @@ -149,16 +148,16 @@ func SettingsEmailPost(ctx *middleware.Context, form auth.AddEmailForm) {
 | 
	
		
			
				|  |  |  	ctx.Data["PageIsUserSettings"] = true
 | 
	
		
			
				|  |  |  	ctx.Data["PageIsSettingsEmails"] = true
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -	var err error
 | 
	
		
			
				|  |  | -	ctx.Data["Emails"], err = models.GetEmailAddresses(ctx.User.Id)
 | 
	
		
			
				|  |  | +	emails, err := models.GetEmailAddresses(ctx.User.Id)
 | 
	
		
			
				|  |  |  	if err != nil {
 | 
	
		
			
				|  |  | -		ctx.Handle(500, "email.GetEmailAddresses", err)
 | 
	
		
			
				|  |  | +		ctx.Handle(500, "GetEmailAddresses", err)
 | 
	
		
			
				|  |  |  		return
 | 
	
		
			
				|  |  |  	}
 | 
	
		
			
				|  |  | +	ctx.Data["Emails"] = emails
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -	// Delete Email address.
 | 
	
		
			
				|  |  | +	// Delete E-mail address.
 | 
	
		
			
				|  |  |  	if ctx.Query("_method") == "DELETE" {
 | 
	
		
			
				|  |  | -		id := com.StrTo(ctx.Query("id")).MustInt64()
 | 
	
		
			
				|  |  | +		id := ctx.QueryInt64("id")
 | 
	
		
			
				|  |  |  		if id <= 0 {
 | 
	
		
			
				|  |  |  			return
 | 
	
		
			
				|  |  |  		}
 | 
	
	
		
			
				|  | @@ -174,7 +173,7 @@ func SettingsEmailPost(ctx *middleware.Context, form auth.AddEmailForm) {
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  	// Make emailaddress primary.
 | 
	
		
			
				|  |  |  	if ctx.Query("_method") == "PRIMARY" {
 | 
	
		
			
				|  |  | -		id := com.StrTo(ctx.Query("id")).MustInt64()
 | 
	
		
			
				|  |  | +		id := ctx.QueryInt64("id")
 | 
	
		
			
				|  |  |  		if id <= 0 {
 | 
	
		
			
				|  |  |  			return
 | 
	
		
			
				|  |  |  		}
 | 
	
	
		
			
				|  | @@ -189,46 +188,41 @@ func SettingsEmailPost(ctx *middleware.Context, form auth.AddEmailForm) {
 | 
	
		
			
				|  |  |  	}
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  	// Add Email address.
 | 
	
		
			
				|  |  | -	if ctx.Req.Method == "POST" {
 | 
	
		
			
				|  |  | -		if ctx.HasError() {
 | 
	
		
			
				|  |  | -			ctx.HTML(200, SETTINGS_EMAILS)
 | 
	
		
			
				|  |  | -			return
 | 
	
		
			
				|  |  | -		}
 | 
	
		
			
				|  |  | +	if ctx.HasError() {
 | 
	
		
			
				|  |  | +		ctx.HTML(200, SETTINGS_EMAILS)
 | 
	
		
			
				|  |  | +		return
 | 
	
		
			
				|  |  | +	}
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -		cleanEmail := strings.Replace(form.Email, "\n", "", -1)
 | 
	
		
			
				|  |  | -		e := &models.EmailAddress{
 | 
	
		
			
				|  |  | -			Uid:         ctx.User.Id,
 | 
	
		
			
				|  |  | -			Email:       cleanEmail,
 | 
	
		
			
				|  |  | -			IsActivated: !setting.Service.RegisterEmailConfirm,
 | 
	
		
			
				|  |  | -		}
 | 
	
		
			
				|  |  | +	cleanEmail := strings.Replace(form.Email, "\n", "", -1)
 | 
	
		
			
				|  |  | +	e := &models.EmailAddress{
 | 
	
		
			
				|  |  | +		Uid:         ctx.User.Id,
 | 
	
		
			
				|  |  | +		Email:       cleanEmail,
 | 
	
		
			
				|  |  | +		IsActivated: !setting.Service.RegisterEmailConfirm,
 | 
	
		
			
				|  |  | +	}
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -		if err := models.AddEmailAddress(e); err != nil {
 | 
	
		
			
				|  |  | -			if err == models.ErrEmailAlreadyUsed {
 | 
	
		
			
				|  |  | -				ctx.RenderWithErr(ctx.Tr("form.email_has_been_used"), SETTINGS_EMAILS, &form)
 | 
	
		
			
				|  |  | -				return
 | 
	
		
			
				|  |  | -			}
 | 
	
		
			
				|  |  | -			ctx.Handle(500, "email.AddEmailAddress", err)
 | 
	
		
			
				|  |  | +	if err := models.AddEmailAddress(e); err != nil {
 | 
	
		
			
				|  |  | +		if err == models.ErrEmailAlreadyUsed {
 | 
	
		
			
				|  |  | +			ctx.RenderWithErr(ctx.Tr("form.email_been_used"), SETTINGS_EMAILS, &form)
 | 
	
		
			
				|  |  |  			return
 | 
	
		
			
				|  |  | -		} else {
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -			// Send confirmation e-mail
 | 
	
		
			
				|  |  | -			if setting.Service.RegisterEmailConfirm {
 | 
	
		
			
				|  |  | -				mailer.SendActivateEmail(ctx.Render, ctx.User, e)
 | 
	
		
			
				|  |  | +		}
 | 
	
		
			
				|  |  | +		ctx.Handle(500, "AddEmailAddress", err)
 | 
	
		
			
				|  |  | +		return
 | 
	
		
			
				|  |  | +	} else {
 | 
	
		
			
				|  |  | +		// Send confirmation e-mail
 | 
	
		
			
				|  |  | +		if setting.Service.RegisterEmailConfirm {
 | 
	
		
			
				|  |  | +			mailer.SendActivateEmail(ctx.Render, ctx.User, e)
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -				if err := ctx.Cache.Put("MailResendLimit_"+ctx.User.LowerName, ctx.User.LowerName, 180); err != nil {
 | 
	
		
			
				|  |  | -					log.Error(4, "Set cache(MailResendLimit) fail: %v", err)
 | 
	
		
			
				|  |  | -				}
 | 
	
		
			
				|  |  | -				ctx.Flash.Success(ctx.Tr("settings.add_email_success_confirmation_email_sent"))
 | 
	
		
			
				|  |  | -			} else {
 | 
	
		
			
				|  |  | -				ctx.Flash.Success(ctx.Tr("settings.add_email_success"))
 | 
	
		
			
				|  |  | +			if err := ctx.Cache.Put("MailResendLimit_"+ctx.User.LowerName, ctx.User.LowerName, 180); err != nil {
 | 
	
		
			
				|  |  | +				log.Error(4, "Set cache(MailResendLimit) fail: %v", err)
 | 
	
		
			
				|  |  |  			}
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -			log.Trace("Email address added: %s", e.Email)
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -			ctx.Redirect(setting.AppSubUrl + "/user/settings/email")
 | 
	
		
			
				|  |  | -			return
 | 
	
		
			
				|  |  | +			ctx.Flash.Success(ctx.Tr("settings.add_email_success_confirmation_email_sent"))
 | 
	
		
			
				|  |  | +		} else {
 | 
	
		
			
				|  |  | +			ctx.Flash.Success(ctx.Tr("settings.add_email_success"))
 | 
	
		
			
				|  |  |  		}
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | +		log.Trace("Email address added: %s", e.Email)
 | 
	
		
			
				|  |  | +		ctx.Redirect(setting.AppSubUrl + "/user/settings/email")
 | 
	
		
			
				|  |  | +		return
 | 
	
		
			
				|  |  |  	}
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  	ctx.HTML(200, SETTINGS_EMAILS)
 |