|
|
@ -1,12 +1,19 @@
|
|
|
|
package admin
|
|
|
|
package admin
|
|
|
|
|
|
|
|
|
|
|
|
import (
|
|
|
|
import (
|
|
|
|
|
|
|
|
"bytes"
|
|
|
|
|
|
|
|
"encoding/json"
|
|
|
|
"fmt"
|
|
|
|
"fmt"
|
|
|
|
model "github.com/HFO4/cloudreve/models"
|
|
|
|
model "github.com/HFO4/cloudreve/models"
|
|
|
|
|
|
|
|
"github.com/HFO4/cloudreve/pkg/auth"
|
|
|
|
|
|
|
|
"github.com/HFO4/cloudreve/pkg/conf"
|
|
|
|
|
|
|
|
"github.com/HFO4/cloudreve/pkg/request"
|
|
|
|
"github.com/HFO4/cloudreve/pkg/serializer"
|
|
|
|
"github.com/HFO4/cloudreve/pkg/serializer"
|
|
|
|
"github.com/HFO4/cloudreve/pkg/util"
|
|
|
|
"github.com/HFO4/cloudreve/pkg/util"
|
|
|
|
|
|
|
|
"net/url"
|
|
|
|
"os"
|
|
|
|
"os"
|
|
|
|
"path/filepath"
|
|
|
|
"path/filepath"
|
|
|
|
|
|
|
|
"time"
|
|
|
|
)
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
|
|
// PathTestService 本地路径测试服务
|
|
|
|
// PathTestService 本地路径测试服务
|
|
|
@ -14,11 +21,87 @@ type PathTestService struct {
|
|
|
|
Path string `json:"path" binding:"required"`
|
|
|
|
Path string `json:"path" binding:"required"`
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// SlaveTestService 从机测试服务
|
|
|
|
|
|
|
|
type SlaveTestService struct {
|
|
|
|
|
|
|
|
Secret string `json:"secret" binding:"required"`
|
|
|
|
|
|
|
|
Server string `json:"server" binding:"required"`
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// SlavePingService 从机相应ping
|
|
|
|
|
|
|
|
type SlavePingService struct {
|
|
|
|
|
|
|
|
Callback string `json:"callback" binding:"required"`
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// AddPolicyService 存储策略添加服务
|
|
|
|
// AddPolicyService 存储策略添加服务
|
|
|
|
type AddPolicyService struct {
|
|
|
|
type AddPolicyService struct {
|
|
|
|
Policy model.Policy `json:"policy" binding:"required"`
|
|
|
|
Policy model.Policy `json:"policy" binding:"required"`
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// Test 从机响应ping
|
|
|
|
|
|
|
|
func (service *SlavePingService) Test() serializer.Response {
|
|
|
|
|
|
|
|
master, err := url.Parse(service.Callback)
|
|
|
|
|
|
|
|
if err != nil {
|
|
|
|
|
|
|
|
return serializer.ParamErr("无法解析主机站点地址,请检查主机 参数设置 - 站点信息 - 站点URL设置,"+err.Error(), nil)
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
controller, _ := url.Parse("/api/v3/site/ping")
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
r := request.HTTPClient{}
|
|
|
|
|
|
|
|
res, err := r.Request(
|
|
|
|
|
|
|
|
"GET",
|
|
|
|
|
|
|
|
master.ResolveReference(controller).String(),
|
|
|
|
|
|
|
|
nil,
|
|
|
|
|
|
|
|
request.WithTimeout(time.Duration(10)*time.Second),
|
|
|
|
|
|
|
|
).DecodeResponse()
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if err != nil {
|
|
|
|
|
|
|
|
return serializer.ParamErr("从机无法向主机发送回调请求,请检查主机端 参数设置 - 站点信息 - 站点URL设置,并确保从机可以连接到此地址,"+err.Error(), nil)
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if res.Data.(string) != conf.BackendVersion {
|
|
|
|
|
|
|
|
return serializer.ParamErr("Cloudreve版本不一致,主机:"+res.Data.(string)+",从机:"+conf.BackendVersion, nil)
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
return serializer.Response{}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// Test 测试从机通信
|
|
|
|
|
|
|
|
func (service *SlaveTestService) Test() serializer.Response {
|
|
|
|
|
|
|
|
slave, err := url.Parse(service.Server)
|
|
|
|
|
|
|
|
if err != nil {
|
|
|
|
|
|
|
|
return serializer.ParamErr("无法解析从机端地址,"+err.Error(), nil)
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
controller, _ := url.Parse("/api/v3/slave/ping")
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// 请求正文
|
|
|
|
|
|
|
|
body := map[string]string{
|
|
|
|
|
|
|
|
"callback": model.GetSiteURL().String(),
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
bodyByte, _ := json.Marshal(body)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
r := request.HTTPClient{}
|
|
|
|
|
|
|
|
res, err := r.Request(
|
|
|
|
|
|
|
|
"POST",
|
|
|
|
|
|
|
|
slave.ResolveReference(controller).String(),
|
|
|
|
|
|
|
|
bytes.NewReader(bodyByte),
|
|
|
|
|
|
|
|
request.WithTimeout(time.Duration(10)*time.Second),
|
|
|
|
|
|
|
|
request.WithCredential(
|
|
|
|
|
|
|
|
auth.HMACAuth{SecretKey: []byte(service.Secret)},
|
|
|
|
|
|
|
|
int64(model.GetIntSetting("slave_api_timeout", 60)),
|
|
|
|
|
|
|
|
),
|
|
|
|
|
|
|
|
).DecodeResponse()
|
|
|
|
|
|
|
|
if err != nil {
|
|
|
|
|
|
|
|
return serializer.ParamErr("无连接到从机,"+err.Error(), nil)
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if res.Code != 0 {
|
|
|
|
|
|
|
|
return serializer.ParamErr("成功接到从机,但是"+res.Msg, nil)
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
return serializer.Response{}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// Add 添加存储策略
|
|
|
|
// Add 添加存储策略
|
|
|
|
func (service *AddPolicyService) Add() serializer.Response {
|
|
|
|
func (service *AddPolicyService) Add() serializer.Response {
|
|
|
|
if err := model.DB.Create(&service.Policy).Error; err != nil {
|
|
|
|
if err := model.DB.Create(&service.Policy).Error; err != nil {
|
|
|
@ -54,7 +137,7 @@ func (service *AdminListService) Policies() serializer.Response {
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
for k, v := range service.Conditions {
|
|
|
|
for k, v := range service.Conditions {
|
|
|
|
tx = tx.Where("? = ?", k, v)
|
|
|
|
tx = tx.Where(k+" = ?", v)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// 计算总数用于分页
|
|
|
|
// 计算总数用于分页
|
|
|
|