improve: 拆分登录函数

This commit is contained in:
Mmx233
2022-10-21 14:31:35 +08:00
parent 93dfeab8e1
commit 16e207b8e2
3 changed files with 47 additions and 79 deletions

View File

@@ -1,17 +0,0 @@
package BitSrun
func GenerateLoginInfo(Form *LoginForm, Meta *LoginMeta) *LoginContext {
return &LoginContext{
Meta: Meta,
Form: &LoginForm{
UserName: func() string {
if Form.UserType == "" {
return Form.UserName
} else {
return Form.UserName + "@" + Form.UserType
}
}(),
PassWord: Form.PassWord,
},
}
}

View File

@@ -6,81 +6,79 @@ import (
log "github.com/sirupsen/logrus" log "github.com/sirupsen/logrus"
) )
func Login(c *Conf) error { func LoginStatus(c *Conf) (online bool, ip string, e error) {
c.initApi() c.initApi()
G := GenerateLoginInfo(c.LoginInfo.Form, c.LoginInfo.Meta)
log.Debugln("正在检查登录状态")
res, e := c.api.GetUserInfo() res, e := c.api.GetUserInfo()
if e != nil { if e != nil {
return e return false, "", e
} }
err, ok := res["error"] err, ok := res["error"]
if err == "ok" {
log.Debugln("已登录~")
return nil
}
log.Infoln("检测到用户未登录,开始尝试登录...")
log.Debugln("正在获取客户端 IP")
var ip interface{}
ip, ok = res["client_ip"]
if !ok { if !ok {
ip, ok = res["online_ip"] return false, "", ErrResultCannotFound
}
ipInterface, ok := res["client_ip"]
if !ok {
ipInterface, ok = res["online_ip"]
if !ok { if !ok {
return ErrResultCannotFound return false, "", ErrResultCannotFound
} }
} }
G.Ip = ip.(string)
log.Debugln("ip: ", G.Ip)
return err.(string) == "ok", ipInterface.(string), nil
}
func DoLogin(clientIP string, c *Conf) error {
log.Debugln("正在获取 Token") log.Debugln("正在获取 Token")
res, e = c.api.GetChallenge(G.Form.UserName, G.Ip) if c.LoginInfo.Form.UserType != "" {
c.LoginInfo.Form.UserName += "@" + c.LoginInfo.Form.UserType
}
res, e := c.api.GetChallenge(c.LoginInfo.Form.UserName, clientIP)
if e != nil { if e != nil {
return e return e
} }
var token interface{} token, ok := res["challenge"]
token, ok = res["challenge"]
if !ok { if !ok {
return ErrResultCannotFound return ErrResultCannotFound
} }
G.Token = token.(string) tokenStr := token.(string)
log.Debugln("token: ", G.Token) log.Debugln("token: ", tokenStr)
log.Debugln("发送登录请求") log.Debugln("发送登录请求")
info, e := json.Marshal(map[string]string{ info, e := json.Marshal(map[string]string{
"username": G.Form.UserName, "username": c.LoginInfo.Form.UserName,
"password": G.Form.PassWord, "password": c.LoginInfo.Form.PassWord,
"ip": G.Ip, "ip": clientIP,
"acid": G.Meta.Acid, "acid": c.LoginInfo.Meta.Acid,
"enc_ver": G.Meta.Enc, "enc_ver": c.LoginInfo.Meta.Enc,
}) })
if e != nil { if e != nil {
return e return e
} }
G.EncryptedInfo = "{SRBX1}" + Base64(XEncode(string(info), G.Token)) EncryptedInfo := "{SRBX1}" + Base64(XEncode(string(info), tokenStr))
G.Md5 = Md5(G.Token) Md5Str := Md5(tokenStr)
G.EncryptedMd5 = "{MD5}" + G.Md5 EncryptedMd5 := "{MD5}" + Md5Str
EncryptedChkstr := Sha1(
var chkstr = G.Token + G.Form.UserName + G.Token + G.Md5 tokenStr + c.LoginInfo.Form.UserName + tokenStr + Md5Str +
chkstr += G.Token + G.Meta.Acid + G.Token + G.Ip tokenStr + c.LoginInfo.Meta.Acid + tokenStr + clientIP +
chkstr += G.Token + G.Meta.N + G.Token + G.Meta.Type tokenStr + c.LoginInfo.Meta.N + tokenStr + c.LoginInfo.Meta.Type +
chkstr += G.Token + G.EncryptedInfo tokenStr + EncryptedInfo,
G.EncryptedChkstr = Sha1(chkstr) )
res, e = c.api.Login( res, e = c.api.Login(
G.Form.UserName, c.LoginInfo.Form.UserName,
G.EncryptedMd5, EncryptedMd5,
G.Meta.Acid, c.LoginInfo.Meta.Acid,
G.Ip, clientIP,
G.EncryptedInfo, EncryptedInfo,
G.EncryptedChkstr, EncryptedChkstr,
G.Meta.N, c.LoginInfo.Meta.N,
G.Meta.Type, c.LoginInfo.Meta.Type,
) )
if e != nil { if e != nil {
return e return e
@@ -90,10 +88,10 @@ func Login(c *Conf) error {
if !ok { if !ok {
return ErrResultCannotFound return ErrResultCannotFound
} }
G.LoginResult = result.(string) LoginResult := result.(string)
if G.LoginResult != "ok" { if LoginResult != "ok" {
return errors.New(G.LoginResult) return errors.New(LoginResult)
} }
return nil return nil

View File

@@ -38,16 +38,3 @@ type Conf struct {
func (a *Conf) initApi() { func (a *Conf) initApi() {
a.api.Init(a.Https, a.LoginInfo.Form.Domain, a.Client) a.api.Init(a.Https, a.LoginInfo.Form.Domain, a.Client)
} }
type LoginContext struct {
Ip string
Token string
EncryptedInfo string
Md5 string
EncryptedMd5 string
EncryptedChkstr string
LoginResult string
Form *LoginForm
Meta *LoginMeta
}