2014-04-11 02:20:58 +08:00
|
|
|
// Copyright 2014 The Gogs Authors. All rights reserved.
|
|
|
|
// Use of this source code is governed by a MIT-style
|
|
|
|
// license that can be found in the LICENSE file.
|
|
|
|
|
|
|
|
package models
|
|
|
|
|
2014-04-12 01:01:30 +08:00
|
|
|
import (
|
|
|
|
"errors"
|
|
|
|
)
|
2014-04-11 02:20:58 +08:00
|
|
|
|
2014-06-21 12:51:41 +08:00
|
|
|
type OauthType int
|
|
|
|
|
2014-04-11 02:20:58 +08:00
|
|
|
const (
|
2014-06-21 12:51:41 +08:00
|
|
|
GITHUB OauthType = iota + 1
|
|
|
|
GOOGLE
|
|
|
|
TWITTER
|
|
|
|
QQ
|
|
|
|
WEIBO
|
|
|
|
BITBUCKET
|
|
|
|
FACEBOOK
|
2014-04-11 02:20:58 +08:00
|
|
|
)
|
|
|
|
|
|
|
|
var (
|
2014-04-14 06:12:07 +08:00
|
|
|
ErrOauth2RecordNotExist = errors.New("OAuth2 record does not exist")
|
|
|
|
ErrOauth2NotAssociated = errors.New("OAuth2 is not associated with user")
|
2014-04-11 02:20:58 +08:00
|
|
|
)
|
|
|
|
|
|
|
|
type Oauth2 struct {
|
|
|
|
Id int64
|
2014-04-12 01:01:30 +08:00
|
|
|
Uid int64 `xorm:"unique(s)"` // userId
|
2014-04-11 02:20:58 +08:00
|
|
|
User *User `xorm:"-"`
|
2014-04-12 01:01:30 +08:00
|
|
|
Type int `xorm:"unique(s) unique(oauth)"` // twitter,github,google...
|
|
|
|
Identity string `xorm:"unique(s) unique(oauth)"` // id..
|
2014-04-12 23:19:17 +08:00
|
|
|
Token string `xorm:"TEXT not null"`
|
2014-04-11 02:20:58 +08:00
|
|
|
}
|
|
|
|
|
2014-04-12 01:01:30 +08:00
|
|
|
func BindUserOauth2(userId, oauthId int64) error {
|
2014-06-21 12:51:41 +08:00
|
|
|
_, err := x.Id(oauthId).Update(&Oauth2{Uid: userId})
|
2014-04-12 01:01:30 +08:00
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
2014-04-14 06:12:07 +08:00
|
|
|
func AddOauth2(oa *Oauth2) error {
|
2014-06-21 12:51:41 +08:00
|
|
|
_, err := x.Insert(oa)
|
2014-04-14 06:12:07 +08:00
|
|
|
return err
|
2014-04-11 02:20:58 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
func GetOauth2(identity string) (oa *Oauth2, err error) {
|
|
|
|
oa = &Oauth2{Identity: identity}
|
2014-06-21 12:51:41 +08:00
|
|
|
isExist, err := x.Get(oa)
|
2014-04-11 02:20:58 +08:00
|
|
|
if err != nil {
|
|
|
|
return
|
|
|
|
} else if !isExist {
|
2014-04-14 06:12:07 +08:00
|
|
|
return nil, ErrOauth2RecordNotExist
|
2014-04-12 23:19:17 +08:00
|
|
|
} else if oa.Uid == -1 {
|
2014-04-14 06:12:07 +08:00
|
|
|
return oa, ErrOauth2NotAssociated
|
2014-04-11 02:20:58 +08:00
|
|
|
}
|
|
|
|
oa.User, err = GetUserById(oa.Uid)
|
|
|
|
return oa, err
|
|
|
|
}
|
2014-04-12 01:01:30 +08:00
|
|
|
|
|
|
|
func GetOauth2ById(id int64) (oa *Oauth2, err error) {
|
|
|
|
oa = new(Oauth2)
|
2014-06-21 12:51:41 +08:00
|
|
|
has, err := x.Id(id).Get(oa)
|
2014-04-12 01:01:30 +08:00
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
2014-04-14 06:12:07 +08:00
|
|
|
} else if !has {
|
|
|
|
return nil, ErrOauth2RecordNotExist
|
2014-04-12 01:01:30 +08:00
|
|
|
}
|
|
|
|
return oa, nil
|
|
|
|
}
|
2014-04-14 09:00:12 +08:00
|
|
|
|
|
|
|
// GetOauthByUserId returns list of oauthes that are releated to given user.
|
|
|
|
func GetOauthByUserId(uid int64) (oas []*Oauth2, err error) {
|
2014-06-21 12:51:41 +08:00
|
|
|
err = x.Find(&oas, Oauth2{Uid: uid})
|
2014-04-14 09:00:12 +08:00
|
|
|
return oas, err
|
|
|
|
}
|
2014-05-06 04:21:43 +08:00
|
|
|
|
|
|
|
// DeleteOauth2ById deletes a oauth2 by ID.
|
|
|
|
func DeleteOauth2ById(id int64) error {
|
2014-06-21 12:51:41 +08:00
|
|
|
_, err := x.Delete(&Oauth2{Id: id})
|
2014-05-06 04:21:43 +08:00
|
|
|
return err
|
|
|
|
}
|
2014-05-07 01:47:47 +08:00
|
|
|
|
|
|
|
// CleanUnbindOauth deletes all unbind OAuthes.
|
|
|
|
func CleanUnbindOauth() error {
|
2014-06-21 12:51:41 +08:00
|
|
|
_, err := x.Delete(&Oauth2{Uid: -1})
|
2014-05-07 01:47:47 +08:00
|
|
|
return err
|
|
|
|
}
|