|
|
|
package weishi
|
|
|
|
|
|
|
|
import (
|
|
|
|
"errors"
|
|
|
|
"go.dtapp.net/dorm"
|
|
|
|
"go.dtapp.net/golog"
|
|
|
|
"go.dtapp.net/gorequest"
|
|
|
|
"net/http"
|
|
|
|
"strings"
|
|
|
|
)
|
|
|
|
|
|
|
|
// client *dorm.GormClient
|
|
|
|
type gormClientFun func() *dorm.GormClient
|
|
|
|
|
|
|
|
// client *dorm.MongoClient
|
|
|
|
// databaseName string
|
|
|
|
type mongoClientFun func() (*dorm.MongoClient, string)
|
|
|
|
|
|
|
|
// ClientConfig 实例配置
|
|
|
|
type ClientConfig struct {
|
|
|
|
GormClientFun gormClientFun // 日志配置
|
|
|
|
MongoClientFun mongoClientFun // 日志配置
|
|
|
|
Debug bool // 日志开关
|
|
|
|
ZapLog *golog.ZapLog // 日志服务
|
|
|
|
}
|
|
|
|
|
|
|
|
// Client 实例
|
|
|
|
type Client struct {
|
|
|
|
requestClient *gorequest.App // 请求服务
|
|
|
|
zapLog *golog.ZapLog // 日志服务
|
|
|
|
config struct {
|
|
|
|
ua string // 用户代理
|
|
|
|
}
|
|
|
|
log struct {
|
|
|
|
gorm bool // 日志开关
|
|
|
|
gormClient *dorm.GormClient // 日志数据库
|
|
|
|
logGormClient *golog.ApiClient // 日志服务
|
|
|
|
mongo bool // 日志开关
|
|
|
|
mongoClient *dorm.MongoClient // 日志数据库
|
|
|
|
logMongoClient *golog.ApiClient // 日志服务
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// NewClient 创建实例化
|
|
|
|
func NewClient(config *ClientConfig) (*Client, error) {
|
|
|
|
|
|
|
|
var err error
|
|
|
|
c := &Client{}
|
|
|
|
|
|
|
|
c.zapLog = config.ZapLog
|
|
|
|
|
|
|
|
c.config.ua = "Mozilla/5.0 (iPhone; CPU iPhone OS 11_0 like Mac OS X) AppleWebKit/604.1.38 (KHTML, like Gecko) Version/11.0 Mobile/15A372 Safari/604.1"
|
|
|
|
|
|
|
|
c.requestClient = gorequest.NewHttp()
|
|
|
|
|
|
|
|
gormClient := config.GormClientFun()
|
|
|
|
if gormClient != nil && gormClient.Db != nil {
|
|
|
|
c.log.logGormClient, err = golog.NewApiGormClient(&golog.ApiGormClientConfig{
|
|
|
|
GormClientFun: func() (*dorm.GormClient, string) {
|
|
|
|
return gormClient, logTable
|
|
|
|
},
|
|
|
|
Debug: config.Debug,
|
|
|
|
ZapLog: c.zapLog,
|
|
|
|
})
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
c.log.gorm = true
|
|
|
|
c.log.gormClient = gormClient
|
|
|
|
}
|
|
|
|
|
|
|
|
mongoClient, databaseName := config.MongoClientFun()
|
|
|
|
if mongoClient != nil && mongoClient.Db != nil {
|
|
|
|
c.log.logMongoClient, err = golog.NewApiMongoClient(&golog.ApiMongoClientConfig{
|
|
|
|
MongoClientFun: func() (*dorm.MongoClient, string, string) {
|
|
|
|
return mongoClient, databaseName, logTable
|
|
|
|
},
|
|
|
|
Debug: config.Debug,
|
|
|
|
ZapLog: c.zapLog,
|
|
|
|
})
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
c.log.mongo = true
|
|
|
|
c.log.mongoClient = mongoClient
|
|
|
|
}
|
|
|
|
|
|
|
|
return c, nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func (c *Client) urlJudge(str string) string {
|
|
|
|
if strings.Index(str, "weishi.qq.com") != -1 {
|
|
|
|
return str
|
|
|
|
}
|
|
|
|
return ""
|
|
|
|
}
|
|
|
|
|
|
|
|
func (c *Client) request302(url string) (string, error) {
|
|
|
|
req, err := http.NewRequest("GET", url, nil)
|
|
|
|
if err != nil {
|
|
|
|
return "", err
|
|
|
|
}
|
|
|
|
client := new(http.Client)
|
|
|
|
client.CheckRedirect = func(req *http.Request, via []*http.Request) error {
|
|
|
|
return errors.New("redirect")
|
|
|
|
}
|
|
|
|
|
|
|
|
response, err := client.Do(req)
|
|
|
|
if err != nil {
|
|
|
|
if response.StatusCode == http.StatusFound {
|
|
|
|
location, err := response.Location()
|
|
|
|
return location.String(), err
|
|
|
|
} else {
|
|
|
|
return "", err
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return "", nil
|
|
|
|
}
|