Cloudreve/pkg/request/slave.go

57 lines
1.6 KiB
Go
Raw Normal View History

2019-12-29 17:04:08 +08:00
package request
import (
"bytes"
"encoding/json"
"errors"
"github.com/HFO4/cloudreve/pkg/auth"
"github.com/HFO4/cloudreve/pkg/conf"
"github.com/HFO4/cloudreve/pkg/serializer"
"github.com/HFO4/cloudreve/pkg/util"
"time"
)
// RemoteCallback 发送远程存储策略上传回调请求
func RemoteCallback(url string, body serializer.RemoteUploadCallback) error {
callbackBody, err := json.Marshal(struct {
Data serializer.RemoteUploadCallback `json:"data"`
}{
Data: body,
})
2019-12-29 17:04:08 +08:00
if err != nil {
return serializer.NewError(serializer.CodeCallbackError, "无法编码回调正文", err)
}
2019-12-29 17:11:54 +08:00
resp := GeneralClient.Request(
2019-12-29 17:04:08 +08:00
"POST",
url,
bytes.NewReader(callbackBody),
WithTimeout(time.Duration(conf.SlaveConfig.CallbackTimeout)*time.Second),
WithCredential(auth.General, int64(conf.SlaveConfig.SignatureTTL)),
)
if resp.Err != nil {
return serializer.NewError(serializer.CodeCallbackError, "无法发起回调请求", resp.Err)
}
// 检查返回HTTP状态码
rawResp, err := resp.GetResponse(200)
2019-12-29 17:04:08 +08:00
if err != nil {
return serializer.NewError(serializer.CodeCallbackError, "服务器返回异常响应", err)
2019-12-29 17:04:08 +08:00
}
// 解析回调服务端响应
var response serializer.Response
err = json.Unmarshal([]byte(rawResp), &response)
2019-12-29 17:04:08 +08:00
if err != nil {
util.Log().Debug("无法解析回调服务端响应:%s", string(rawResp))
return serializer.NewError(serializer.CodeCallbackError, "无法解析服务端返回的响应", err)
}
if response.Code != 0 {
return serializer.NewError(response.Code, response.Msg, errors.New(response.Error))
}
return nil
}