summaryrefslogtreecommitdiffstats
path: root/models/user_mail.go
diff options
context:
space:
mode:
authorLunny Xiao <xiaolunwen@gmail.com>2016-12-15 16:49:06 +0800
committerGitHub <noreply@github.com>2016-12-15 16:49:06 +0800
commitb4c794058aa57426679877444b52561e7e16ef2b (patch)
tree0835bc252a72077f7fe9f7daa4d02ff4059d8c27 /models/user_mail.go
parentd771e978a108517ca5833b5e2f17b45e2d7dc6ca (diff)
downloadgitea-b4c794058aa57426679877444b52561e7e16ef2b.tar.gz
gitea-b4c794058aa57426679877444b52561e7e16ef2b.zip
fixed vulnerabilities (#392)
Diffstat (limited to 'models/user_mail.go')
-rw-r--r--models/user_mail.go25
1 files changed, 21 insertions, 4 deletions
diff --git a/models/user_mail.go b/models/user_mail.go
index 69f87c2b37..49d1bf78b2 100644
--- a/models/user_mail.go
+++ b/models/user_mail.go
@@ -5,10 +5,16 @@
package models
import (
+ "errors"
"fmt"
"strings"
)
+var (
+ // ErrEmailAddressNotExist email address not exist
+ ErrEmailAddressNotExist = errors.New("Email address does not exist")
+)
+
// EmailAddress is the list of all email addresses of a user. Can contain the
// primary email address, but is not obligatory.
type EmailAddress struct {
@@ -139,14 +145,25 @@ func (email *EmailAddress) Activate() error {
// DeleteEmailAddress deletes an email address of given user.
func DeleteEmailAddress(email *EmailAddress) (err error) {
+ var deleted int64
+ // ask to check UID
+ var address = EmailAddress{
+ UID: email.UID,
+ }
if email.ID > 0 {
- _, err = x.Id(email.ID).Delete(new(EmailAddress))
+ deleted, err = x.Id(email.ID).Delete(&address)
} else {
- _, err = x.
+ deleted, err = x.
Where("email=?", email.Email).
- Delete(new(EmailAddress))
+ Delete(&address)
}
- return err
+
+ if err != nil {
+ return err
+ } else if deleted != 1 {
+ return ErrEmailAddressNotExist
+ }
+ return nil
}
// DeleteEmailAddresses deletes multiple email addresses