| package template |
|
|
| import ( |
| "encoding/hex" |
| "fmt" |
| "net/http" |
| "net/url" |
| "strconv" |
| "strings" |
| "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 |
| } |
|
|
| func getTimestamp(secret []byte) (int64, string, error) { |
| ts := time.Now().UnixMilli() |
| tsStr := strconv.FormatInt(ts, 10) |
| res, err := mopan.AesEncrypt([]byte(tsStr), secret) |
| if err != nil { |
| return 0, "", err |
| } |
| return ts, hex.EncodeToString(res), nil |
| } |
|
|
| func (d *ILanZou) request(pathname, method string, callback base.ReqCallback, proved bool, retry ...bool) ([]byte, error) { |
| _, ts_str, err := getTimestamp(d.conf.secret) |
| if err != nil { |
| return nil, err |
| } |
|
|
| params := []string{ |
| "uuid=" + url.QueryEscape(d.UUID), |
| "devType=6", |
| "devCode=" + url.QueryEscape(d.UUID), |
| "devModel=chrome", |
| "devVersion=" + url.QueryEscape(d.conf.devVersion), |
| "appVersion=", |
| "timestamp=" + ts_str, |
| } |
|
|
| if proved { |
| params = append(params, "appToken="+url.QueryEscape(d.Token)) |
| } |
|
|
| params = append(params, "extra=2") |
|
|
| queryString := strings.Join(params, "&") |
|
|
| req := base.RestyClient.R() |
| req.SetHeaders(map[string]string{ |
| "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", |
| }) |
|
|
| if callback != nil { |
| callback(req) |
| } |
|
|
| res, err := req.Execute(method, d.conf.base+pathname+"?"+queryString) |
| 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) { |
| return d.request("/"+d.conf.unproved+pathname, method, callback, false) |
| } |
|
|
| func (d *ILanZou) proved(pathname, method string, callback base.ReqCallback) ([]byte, error) { |
| return d.request("/"+d.conf.proved+pathname, method, callback, true) |
| } |
|
|