feat:支持后台模式与网络守护

This commit is contained in:
Mmx
2021-07-11 12:52:56 +08:00
parent e3f668c100
commit 257a9b7034
8 changed files with 192 additions and 86 deletions

21
controllers/guardian.go Normal file
View File

@@ -0,0 +1,21 @@
package controllers
import (
"Mmx/global"
"Mmx/util"
"time"
)
func Guardian() {
for {
time.Sleep(time.Duration(global.Config.Settings.Guardian) * time.Second)
go func() {
defer func() {
_ = recover()
}()
if !util.Checker.NetOk() {
Login(false)
}
}()
}
}

105
controllers/login.go Normal file
View File

@@ -0,0 +1,105 @@
package controllers
import (
"Mmx/global"
"Mmx/request"
"Mmx/util"
"encoding/json"
"fmt"
"time"
)
func Login(output bool) {
global.Status.Output = output
util.Log.Println("Step0: 检查状态…")
G := global.Config.Generate()
if !global.Status.Daemon && global.Config.Settings.QuitIfNetOk && util.Checker.NetOk() {
util.Log.Println("网络正常,程序退出")
return
}
util.Log.Println("Step1: 正在获取客户端ip")
{
body, err := request.Get(G.UrlLoginPage, nil)
if err != nil {
util.ErrHandler(err)
return
}
G.Ip, err = util.GetIp(body)
if err != nil {
util.ErrHandler(err)
return
}
}
util.Log.Println("Step2: 正在获取Token")
{
data, err := request.Get(G.UrlGetChallengeApi, map[string]string{
"callback": "jsonp1583251661367",
"username": G.Form.UserName,
"ip": G.Ip,
})
if err != nil {
util.ErrHandler(err)
return
}
G.Token, err = util.GetToken(data)
if err != nil {
util.ErrHandler(err)
return
}
}
util.Log.Println("Step3: 执行登录…")
{
info, err := 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 err != nil {
util.ErrHandler(err)
return
}
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)
res, err := request.Get(G.UrlLoginApi, map[string]string{
"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",
"_": fmt.Sprint(time.Now().UnixNano()),
})
if err != nil {
util.ErrHandler(err)
return
}
G.LoginResult, err = util.GetResult(res)
if err != nil {
util.ErrHandler(err)
return
}
util.Log.Println("登录结果: " + G.LoginResult)
if global.Config.Settings.DemoMode {
util.Log.Println(res)
}
}
}

View File

@@ -3,3 +3,8 @@ package global
import "Mmx/Modles" import "Mmx/Modles"
var Config *modles.Config var Config *modles.Config
var Status struct {
Output bool
Daemon bool
}

90
main.go
View File

@@ -1,17 +1,22 @@
package main package main
import ( import (
"Mmx/Global"
"Mmx/Request"
"Mmx/Util" "Mmx/Util"
"encoding/json" "Mmx/controllers"
"fmt" "Mmx/global"
"flag"
"os" "os"
"os/exec"
"runtime" "runtime"
"time"
) )
func main() { func main() {
goDaemon := flag.Bool("daemon", false, "")
flag.Parse()
if *goDaemon {
controllers.Guardian()
}
defer func() { defer func() {
if e := recover(); e != nil { if e := recover(); e != nil {
util.Log.Println(e) util.Log.Println(e)
@@ -20,74 +25,19 @@ func main() {
os.Exit(1) os.Exit(1)
} }
}() }()
util.Log.Println("Step0: 检查状态…") controllers.Login(true)
G := global.Config.Generate()
if global.Config.Settings.QuitIfNetOk && util.Checker.NetOk() { if global.Config.Settings.Guardian != 0 {
util.Log.Println("网络正常,程序退出") global.Status.Daemon = true
util.Log.Println("[Guardian mode]")
if global.Config.Settings.Daemon {
if err := exec.Command(os.Args[0], "-daemon").Start(); err != nil {
util.ErrHandler(err)
return return
} }
util.Log.Println("[Daemon mode entered]")
util.Log.Println("Step1: 正在获取客户端ip") return
{
body, err := request.Get(G.UrlLoginPage, nil)
util.ErrHandler(err)
G.Ip, err = util.GetIp(body)
util.ErrHandler(err)
}
util.Log.Println("Step2: 正在获取Token")
{
data, err := request.Get(G.UrlGetChallengeApi, map[string]string{
"callback": "jsonp1583251661367",
"username": G.Form.UserName,
"ip": G.Ip,
})
util.ErrHandler(err)
G.Token, err = util.GetToken(data)
util.ErrHandler(err)
}
util.Log.Println("Step3: 执行登录…")
{
info, err := 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,
})
util.ErrHandler(err)
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)
res, err := request.Get(G.UrlLoginApi, map[string]string{
"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",
"_": fmt.Sprint(time.Now().UnixNano()),
})
util.ErrHandler(err)
G.LoginResult, err = util.GetResult(res)
util.ErrHandler(err)
util.Log.Println("登录结果: " + G.LoginResult)
if global.Config.Settings.DemoMode {
util.Log.Println(res)
} }
controllers.Guardian()
} }
} }

View File

@@ -1,7 +1,7 @@
package modles package modles
import ( import (
"Mmx/Modles/util" "Mmx/modles/util"
"reflect" "reflect"
) )
@@ -9,7 +9,8 @@ type Settings struct {
QuitIfNetOk bool `json:"quit_if_net_ok"` QuitIfNetOk bool `json:"quit_if_net_ok"`
DemoMode bool `json:"demo_mode"` DemoMode bool `json:"demo_mode"`
Dns string `json:"dns"` Dns string `json:"dns"`
Daemon uint `json:"daemon"` Guardian uint `json:"guardian"`
Daemon bool `json:"daemon"`
} }
type Config struct { type Config struct {

View File

@@ -13,7 +13,11 @@ type file struct{}
var File file var File file
func (a *file) Exists(path string) bool { func (a *file) Exists(path string) bool {
_, err := os.Stat(a.GetRootPath() + path) root, err := a.GetRootPath()
if err != nil {
return false
}
_, err = os.Stat(root + path)
if err != nil { if err != nil {
if os.IsExist(err) { if os.IsExist(err) {
return true return true
@@ -24,7 +28,11 @@ func (a *file) Exists(path string) bool {
} }
func (a *file) Read(path string) ([]byte, error) { func (a *file) Read(path string) ([]byte, error) {
return ioutil.ReadFile(a.GetRootPath() + path) root, err := a.GetRootPath()
if err != nil {
return nil, err
}
return ioutil.ReadFile(root + path)
} }
func (a *file) ReadJson(path string, receiver interface{}) error { func (a *file) ReadJson(path string, receiver interface{}) error {
@@ -36,7 +44,11 @@ func (a *file) ReadJson(path string, receiver interface{}) error {
} }
func (a *file) Write(path string, data []byte) error { func (a *file) Write(path string, data []byte) error {
return ioutil.WriteFile(a.GetRootPath()+path, data, 700) root, err := a.GetRootPath()
if err != nil {
return err
}
return ioutil.WriteFile(root+path, data, 700)
} }
func (a *file) WriteJson(path string, receiver interface{}) error { func (a *file) WriteJson(path string, receiver interface{}) error {
@@ -47,16 +59,21 @@ func (a *file) WriteJson(path string, receiver interface{}) error {
return a.Write(path, data) return a.Write(path, data)
} }
func (*file) GetRootPath() string { func (*file) GetRootPath() (string, error) {
t, err := os.Executable() t, err := os.Executable()
if err != nil { if err != nil {
ErrHandler(err) ErrHandler(err)
return "", err
} }
return filepath.Dir(t) + "/" return filepath.Dir(t) + "/", nil
} }
func (a *file) Add(path string, c string) error { func (a *file) Add(path string, c string) error {
file, err := os.OpenFile(a.GetRootPath()+path, os.O_WRONLY|os.O_CREATE|os.O_APPEND, 700) root, err := a.GetRootPath()
if err != nil {
return err
}
file, err := os.OpenFile(root+path, os.O_WRONLY|os.O_CREATE|os.O_APPEND, 700)
defer file.Close() defer file.Close()
if err != nil { if err != nil {
return err return err

View File

@@ -39,6 +39,9 @@ func (c *loG) genTimeStamp() {
} }
func (c *loG) Println(a ...interface{}) { func (c *loG) Println(a ...interface{}) {
if !global.Status.Output {
return
}
c.genTimeStamp() c.genTimeStamp()
if global.Config.Settings.DemoMode { if global.Config.Settings.DemoMode {
c.WriteLog("Login-"+c.timeStamp+".log", a...) c.WriteLog("Login-"+c.timeStamp+".log", a...)
@@ -47,6 +50,9 @@ func (c *loG) Println(a ...interface{}) {
} }
func (c *loG) Fatalln(a ...interface{}) { func (c *loG) Fatalln(a ...interface{}) {
if !global.Status.Output {
return
}
c.genTimeStamp() c.genTimeStamp()
c.WriteLog("LoginError-"+c.timeStamp+".log", a...) c.WriteLog("LoginError-"+c.timeStamp+".log", a...)
log.Fatalln(a...) log.Fatalln(a...)

View File

@@ -52,13 +52,14 @@ func Sha1(content string) string {
} }
func ErrHandler(err error) { func ErrHandler(err error) {
if err != nil { if !global.Status.Output {
return
}
Log.Println("运行出错,状态异常") Log.Println("运行出错,状态异常")
if global.Config.Settings.DemoMode { if global.Config.Settings.DemoMode {
Log.Fatalln(err) Log.Fatalln(err)
} }
os.Exit(1) os.Exit(1)
}
} }
func NetDailEr() func(ctx context.Context, network, address string) (net.Conn, error) { func NetDailEr() func(ctx context.Context, network, address string) (net.Conn, error) {