2024-01-04 14:03:15 +00:00
|
|
|
package template
|
|
|
|
|
|
|
|
import (
|
|
|
|
"encoding/hex"
|
|
|
|
"fmt"
|
|
|
|
"net/http"
|
|
|
|
"strconv"
|
|
|
|
"time"
|
|
|
|
|
|
|
|
"github.com/alist-org/alist/v3/drivers/base"
|
|
|
|
"github.com/alist-org/alist/v3/pkg/utils"
|
|
|
|
"github.com/foxxorcat/mopan-sdk-go"
|
|
|
|
"github.com/go-resty/resty/v2"
|
|
|
|
log "github.com/sirupsen/logrus"
|
|
|
|
)
|
|
|
|
|
|
|
|
func (d *ILanZou) login() error {
|
|
|
|
res, err := d.unproved("/login", http.MethodPost, func(req *resty.Request) {
|
|
|
|
req.SetBody(base.Json{
|
|
|
|
"loginName": d.Username,
|
|
|
|
"loginPwd": d.Password,
|
|
|
|
})
|
|
|
|
})
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
d.Token = utils.Json.Get(res, "data", "appToken").ToString()
|
|
|
|
if d.Token == "" {
|
|
|
|
return fmt.Errorf("failed to login: token is empty, resp: %s", res)
|
|
|
|
}
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
2024-01-10 08:58:10 +00:00
|
|
|
func getTimestamp(secret []byte) (string, error) {
|
2024-01-04 14:03:15 +00:00
|
|
|
ts := time.Now().UnixMilli()
|
|
|
|
tsStr := strconv.FormatInt(ts, 10)
|
2024-01-10 08:58:10 +00:00
|
|
|
res, err := mopan.AesEncrypt([]byte(tsStr), secret)
|
2024-01-04 14:03:15 +00:00
|
|
|
if err != nil {
|
|
|
|
return "", err
|
|
|
|
}
|
|
|
|
return hex.EncodeToString(res), nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func (d *ILanZou) request(pathname, method string, callback base.ReqCallback, proved bool, retry ...bool) ([]byte, error) {
|
|
|
|
req := base.RestyClient.R()
|
2024-01-10 08:58:10 +00:00
|
|
|
ts, err := getTimestamp(d.conf.secret)
|
2024-01-04 14:03:15 +00:00
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
req.SetQueryParams(map[string]string{
|
|
|
|
"uuid": d.UUID,
|
|
|
|
"devType": "6",
|
|
|
|
"devCode": d.UUID,
|
|
|
|
"devModel": "chrome",
|
2024-03-11 12:30:22 +00:00
|
|
|
"devVersion": d.conf.devVersion,
|
2024-01-04 14:03:15 +00:00
|
|
|
"appVersion": "",
|
|
|
|
"timestamp": ts,
|
|
|
|
//"appToken": d.Token,
|
|
|
|
"extra": "2",
|
|
|
|
})
|
2024-03-11 12:30:22 +00:00
|
|
|
req.SetHeaders(map[string]string{
|
2024-05-23 12:05:00 +00:00
|
|
|
"Origin": d.conf.site,
|
|
|
|
"Referer": d.conf.site + "/",
|
|
|
|
"User-Agent": "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_7) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/125.0.0.0 Safari/537.36 Edg/125.0.0.0",
|
2024-03-11 12:30:22 +00:00
|
|
|
})
|
2024-01-04 14:03:15 +00:00
|
|
|
if proved {
|
|
|
|
req.SetQueryParam("appToken", d.Token)
|
|
|
|
}
|
|
|
|
if callback != nil {
|
|
|
|
callback(req)
|
|
|
|
}
|
2024-01-10 08:58:10 +00:00
|
|
|
res, err := req.Execute(method, d.conf.base+pathname)
|
2024-01-04 14:03:15 +00:00
|
|
|
if err != nil {
|
|
|
|
if res != nil {
|
|
|
|
log.Errorf("[iLanZou] request error: %s", res.String())
|
|
|
|
}
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
isRetry := len(retry) > 0 && retry[0]
|
|
|
|
body := res.Body()
|
|
|
|
code := utils.Json.Get(body, "code").ToInt()
|
|
|
|
msg := utils.Json.Get(body, "msg").ToString()
|
|
|
|
if code != 200 {
|
|
|
|
if !isRetry && proved && (utils.SliceContains([]int{-1, -2}, code) || d.Token == "") {
|
|
|
|
err = d.login()
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
return d.request(pathname, method, callback, proved, true)
|
|
|
|
}
|
|
|
|
return nil, fmt.Errorf("%d: %s", code, msg)
|
|
|
|
}
|
|
|
|
return body, nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func (d *ILanZou) unproved(pathname, method string, callback base.ReqCallback) ([]byte, error) {
|
2024-01-10 08:58:10 +00:00
|
|
|
return d.request("/"+d.conf.unproved+pathname, method, callback, false)
|
2024-01-04 14:03:15 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
func (d *ILanZou) proved(pathname, method string, callback base.ReqCallback) ([]byte, error) {
|
2024-01-10 08:58:10 +00:00
|
|
|
return d.request("/"+d.conf.proved+pathname, method, callback, true)
|
2024-01-04 14:03:15 +00:00
|
|
|
}
|