76 lines
2.0 KiB
Go
76 lines
2.0 KiB
Go
package archive
|
|
|
|
import (
|
|
"context"
|
|
"crypto/tls"
|
|
"fmt"
|
|
"go-common/library/ecode"
|
|
"go-common/library/log"
|
|
"io/ioutil"
|
|
"net"
|
|
"net/http"
|
|
"net/url"
|
|
"strconv"
|
|
"strings"
|
|
"time"
|
|
)
|
|
|
|
const (
|
|
_nsMd5 = "/videoup/ns/md5"
|
|
_notifyURL = "https://wax.gtloadbalance.cn:38080/InterfaceInfo/GetResult"
|
|
)
|
|
|
|
// AddNetSafeMd5 fn
|
|
func (d *Dao) AddNetSafeMd5(c context.Context, nid int64, md5 string) (err error) {
|
|
params := url.Values{}
|
|
params.Set("nid", strconv.FormatInt(nid, 10))
|
|
params.Set("md5", md5)
|
|
var res struct {
|
|
Code int `json:"code"`
|
|
}
|
|
if err = d.client.Post(c, d.nsMd5, "", params, &res); err != nil {
|
|
log.Error("d.client.Post(%s,%s) err(%v)", d.nsMd5, params.Encode(), err)
|
|
err = ecode.CreativeArchiveAPIErr
|
|
return
|
|
}
|
|
if res.Code != 0 {
|
|
log.Error("d.client.res.Code (%s,%s) err(%v)", d.nsMd5, params.Encode(), res.Code)
|
|
err = ecode.Int(res.Code)
|
|
return
|
|
}
|
|
return
|
|
}
|
|
|
|
// NotifyNetSafe fn
|
|
func (d *Dao) NotifyNetSafe(c context.Context, nid int64) (err error) {
|
|
req, err := http.NewRequest("POST", _notifyURL, strings.NewReader(fmt.Sprintf(`nid=%d&companyId=%d`, nid, 2)))
|
|
if err != nil {
|
|
log.Error("http.NewRequest error(%v) | uri(%s)", err, _notifyURL)
|
|
return
|
|
}
|
|
req.Header.Add("Content-Type", "application/x-www-form-urlencoded")
|
|
req.Header.Add("cache-control", "no-cache")
|
|
httpClient := &http.Client{
|
|
Timeout: time.Duration(time.Duration(5) * time.Second),
|
|
Transport: &http.Transport{
|
|
TLSClientConfig: &tls.Config{InsecureSkipVerify: true},
|
|
Dial: (&net.Dialer{
|
|
Timeout: 5 * time.Second,
|
|
Deadline: time.Now().Add(5 * time.Second),
|
|
KeepAlive: 5 * time.Second,
|
|
}).Dial,
|
|
TLSHandshakeTimeout: 5 * time.Second,
|
|
ResponseHeaderTimeout: time.Second * 2,
|
|
},
|
|
}
|
|
var resp *http.Response
|
|
if resp, err = httpClient.Do(req); err != nil {
|
|
log.Error("NotifyNetSafe d.client.Do error(%v) | uri(%s)", err, _notifyURL)
|
|
return
|
|
}
|
|
defer resp.Body.Close()
|
|
body, err := ioutil.ReadAll(resp.Body)
|
|
log.Warn("NotifyNetSafe ret body (%+v), nid(%+v)", string(body), nid)
|
|
return
|
|
}
|