feat: 支持作为module引用

This commit is contained in:
Mmx
2021-11-25 08:57:54 +08:00
parent 66df79e68f
commit 9c55cc9d1a
5 changed files with 162 additions and 114 deletions

View File

@@ -1,108 +1,20 @@
package controllers
import (
"encoding/json"
"errors"
"github.com/Mmx233/BitSrunLoginGo/global"
"github.com/Mmx233/BitSrunLoginGo/util"
"github.com/Mmx233/tool"
"time"
BitSrun "github.com/Mmx233/BitSrunLoginGo/v1"
"github.com/Mmx233/BitSrunLoginGo/v1/transfer"
)
func Login(output bool, skipCheck bool) error {
util.Log.OutPut = output
G := global.Config.Generate()
if !skipCheck {
util.Log.Println("Step0: 检查状态…")
if util.Checker.NetOk(global.Config.Settings.Timeout) {
util.Log.Println("网络 ok")
return nil
}
}
util.Log.Println("Step1: 正在获取客户端ip")
{
if _, body, e := tool.HTTP.GetString(&tool.GetRequest{
Url: G.UrlLoginPage,
Redirect: true,
}); e != nil {
return e
} else if G.Ip, e = util.GetIp(body); e != nil {
return e
}
}
util.Log.Println("Step2: 正在获取Token")
{
if _, data, e := tool.HTTP.GetString(&tool.GetRequest{
Url: G.UrlGetChallengeApi,
Query: map[string]interface{}{
"callback": "jsonp1583251661367",
"username": G.Form.UserName,
"ip": G.Ip,
},
Redirect: true,
}); e != nil {
return e
} else if G.Token, e = util.GetToken(data); e != nil {
return e
}
}
util.Log.Println("Step3: 执行登录…")
{
info, e := json.Marshal(map[string]string{
"username": G.Form.UserName,
"password": G.Form.PassWord,
"ip": G.Ip,
"acid": G.Meta.Acid,
"enc_ver": G.Meta.Enc,
})
if e != nil {
return e
}
G.EncryptedInfo = "{SRBX1}" + util.Base64(util.XEncode(string(info), G.Token))
G.Md5 = util.Md5(G.Token)
G.EncryptedMd5 = "{MD5}" + G.Md5
var chkstr = G.Token + G.Form.UserName + G.Token + G.Md5
chkstr += G.Token + G.Meta.Acid + G.Token + G.Ip
chkstr += G.Token + G.Meta.N + G.Token + G.Meta.Type
chkstr += G.Token + G.EncryptedInfo
G.EncryptedChkstr = util.Sha1(chkstr)
if _, res, e := tool.HTTP.GetString(&tool.GetRequest{
Url: G.UrlLoginApi,
Query: map[string]interface{}{
"callback": "jQuery112401157665",
"action": "login",
"username": G.Form.UserName,
"password": G.EncryptedMd5,
"ac_id": G.Meta.Acid,
"ip": G.Ip,
"info": G.EncryptedInfo,
"chksum": G.EncryptedChkstr,
"n": G.Meta.N,
"type": G.Meta.Type,
"os": "Windows 10",
"name": "windows",
"double_stack": 0,
"_": time.Now().UnixNano(),
},
Redirect: true,
}); e != nil {
return e
} else if G.LoginResult, e = util.GetResult(res); e != nil {
return e
} else {
util.Log.Println("登录结果: " + G.LoginResult)
if global.Config.Settings.DemoMode {
util.Log.Println(res)
}
}
if G.LoginResult != "ok" {
return errors.New(G.LoginResult)
}
}
return nil
return BitSrun.Login(&transfer.Login{
Demo: global.Config.Settings.DemoMode,
OutPut: output,
CheckNet: !skipCheck,
Timeout: global.Config.Settings.Timeout,
LoginInfo: transfer.LoginInfo{
Form: &global.Config.Form,
Meta: &global.Config.Meta,
},
})
}

View File

@@ -22,17 +22,3 @@ type Config struct {
Meta LoginMeta `json:"meta"`
Settings Settings `json:"settings"`
}
func (a *Config) Generate() *LoginInfo {
return &LoginInfo{
UrlLoginPage: "http://" + a.Form.Domain + "/srun_portal_success",
UrlGetChallengeApi: "http://" + a.Form.Domain + "/cgi-bin/get_challenge",
UrlLoginApi: "http://" + a.Form.Domain + "/cgi-bin/srun_portal",
UrlCheckApi: "http://" + a.Form.Domain + "/cgi-bin/rad_user_info",
Meta: &a.Meta,
Form: &LoginForm{
UserName: a.Form.UserName + "@" + a.Form.UserType,
PassWord: a.Form.PassWord,
},
}
}

17
util/config.go Normal file
View File

@@ -0,0 +1,17 @@
package util
import "github.com/Mmx233/BitSrunLoginGo/models"
func GenerateLoginInfo(Form *models.LoginForm, Meta *models.LoginMeta) *models.LoginInfo {
return &models.LoginInfo{
UrlLoginPage: "http://" + Form.Domain + "/srun_portal_success",
UrlGetChallengeApi: "http://" + Form.Domain + "/cgi-bin/get_challenge",
UrlLoginApi: "http://" + Form.Domain + "/cgi-bin/srun_portal",
UrlCheckApi: "http://" + Form.Domain + "/cgi-bin/rad_user_info",
Meta: Meta,
Form: &models.LoginForm{
UserName: Form.UserName + "@" + Form.UserType,
PassWord: Form.PassWord,
},
}
}

112
v1/login.go Normal file
View File

@@ -0,0 +1,112 @@
package BitSrun
import (
"encoding/json"
"errors"
"github.com/Mmx233/BitSrunLoginGo/util"
"github.com/Mmx233/BitSrunLoginGo/v1/transfer"
"github.com/Mmx233/tool"
"time"
)
func Login(c *transfer.Login) error {
util.Log.Demo = c.Demo
util.Log.OutPut = c.OutPut
G := util.GenerateLoginInfo(c.LoginInfo.Form, c.LoginInfo.Meta)
if c.CheckNet {
util.Log.Println("Step0: 检查状态…")
if util.Checker.NetOk(c.Timeout) {
util.Log.Println("网络 ok")
return nil
}
}
util.Log.Println("Step1: 正在获取客户端ip")
{
if _, body, e := tool.HTTP.GetString(&tool.GetRequest{
Url: G.UrlLoginPage,
Redirect: true,
}); e != nil {
return e
} else if G.Ip, e = util.GetIp(body); e != nil {
return e
}
}
util.Log.Println("Step2: 正在获取Token")
{
if _, data, e := tool.HTTP.GetString(&tool.GetRequest{
Url: G.UrlGetChallengeApi,
Query: map[string]interface{}{
"callback": "jsonp1583251661367",
"username": G.Form.UserName,
"ip": G.Ip,
},
Redirect: true,
}); e != nil {
return e
} else if G.Token, e = util.GetToken(data); e != nil {
return e
}
}
util.Log.Println("Step3: 执行登录…")
{
info, e := json.Marshal(map[string]string{
"username": G.Form.UserName,
"password": G.Form.PassWord,
"ip": G.Ip,
"acid": G.Meta.Acid,
"enc_ver": G.Meta.Enc,
})
if e != nil {
return e
}
G.EncryptedInfo = "{SRBX1}" + util.Base64(util.XEncode(string(info), G.Token))
G.Md5 = util.Md5(G.Token)
G.EncryptedMd5 = "{MD5}" + G.Md5
var chkstr = G.Token + G.Form.UserName + G.Token + G.Md5
chkstr += G.Token + G.Meta.Acid + G.Token + G.Ip
chkstr += G.Token + G.Meta.N + G.Token + G.Meta.Type
chkstr += G.Token + G.EncryptedInfo
G.EncryptedChkstr = util.Sha1(chkstr)
if _, res, e := tool.HTTP.GetString(&tool.GetRequest{
Url: G.UrlLoginApi,
Query: map[string]interface{}{
"callback": "jQuery112401157665",
"action": "login",
"username": G.Form.UserName,
"password": G.EncryptedMd5,
"ac_id": G.Meta.Acid,
"ip": G.Ip,
"info": G.EncryptedInfo,
"chksum": G.EncryptedChkstr,
"n": G.Meta.N,
"type": G.Meta.Type,
"os": "Windows 10",
"name": "windows",
"double_stack": 0,
"_": time.Now().UnixNano(),
},
Redirect: true,
}); e != nil {
return e
} else if G.LoginResult, e = util.GetResult(res); e != nil {
return e
} else {
util.Log.Println("登录结果: " + G.LoginResult)
if c.Demo {
util.Log.Println(res)
}
}
if G.LoginResult != "ok" {
return errors.New(G.LoginResult)
}
}
return nil
}

21
v1/transfer/login.go Normal file
View File

@@ -0,0 +1,21 @@
package transfer
import "github.com/Mmx233/BitSrunLoginGo/models"
type LoginInfo struct {
Form *models.LoginForm
Meta *models.LoginMeta
}
type Login struct {
//文件日志输出开关
Demo bool
//控制台日志打印开关
OutPut bool
//登陆前是否检查网络,只在离线时登录
CheckNet bool
//网络检查超时时间
Timeout uint
//登录参数,不可缺省
LoginInfo LoginInfo
}