Feat: create SFC for oss callback
This commit is contained in:
parent
e8c4660c38
commit
c30c19ca3e
12 changed files with 229 additions and 3 deletions
1
go.mod
1
go.mod
|
@ -39,6 +39,7 @@ require (
|
||||||
github.com/smartystreets/goconvey v1.6.4 // indirect
|
github.com/smartystreets/goconvey v1.6.4 // indirect
|
||||||
github.com/speps/go-hashids v2.0.0+incompatible
|
github.com/speps/go-hashids v2.0.0+incompatible
|
||||||
github.com/stretchr/testify v1.4.0
|
github.com/stretchr/testify v1.4.0
|
||||||
|
github.com/tencentcloud/tencentcloud-sdk-go v3.0.125+incompatible
|
||||||
github.com/tencentyun/cos-go-sdk-v5 v0.0.0-20200120023323-87ff3bc489ac
|
github.com/tencentyun/cos-go-sdk-v5 v0.0.0-20200120023323-87ff3bc489ac
|
||||||
github.com/upyun/go-sdk v2.1.0+incompatible
|
github.com/upyun/go-sdk v2.1.0+incompatible
|
||||||
golang.org/x/net v0.0.0-20190724013045-ca1201d0de80
|
golang.org/x/net v0.0.0-20190724013045-ca1201d0de80
|
||||||
|
|
2
go.sum
2
go.sum
|
@ -210,6 +210,8 @@ github.com/stretchr/testify v1.2.2/go.mod h1:a8OnRcib4nhh0OaRAV+Yts87kKdq0PP7pXf
|
||||||
github.com/stretchr/testify v1.3.0/go.mod h1:M5WIy9Dh21IEIfnGCwXGc5bZfKNJtfHm1UVUgZn+9EI=
|
github.com/stretchr/testify v1.3.0/go.mod h1:M5WIy9Dh21IEIfnGCwXGc5bZfKNJtfHm1UVUgZn+9EI=
|
||||||
github.com/stretchr/testify v1.4.0 h1:2E4SXV/wtOkTonXsotYi4li6zVWxYlZuYNCXe9XRJyk=
|
github.com/stretchr/testify v1.4.0 h1:2E4SXV/wtOkTonXsotYi4li6zVWxYlZuYNCXe9XRJyk=
|
||||||
github.com/stretchr/testify v1.4.0/go.mod h1:j7eGeouHqKxXV5pUuKE4zz7dFj8WfuZ+81PSLYec5m4=
|
github.com/stretchr/testify v1.4.0/go.mod h1:j7eGeouHqKxXV5pUuKE4zz7dFj8WfuZ+81PSLYec5m4=
|
||||||
|
github.com/tencentcloud/tencentcloud-sdk-go v3.0.125+incompatible h1:dqpmYaez7VBT7PCRBcBxkzlDOiTk7Td8ATiia1b1GuE=
|
||||||
|
github.com/tencentcloud/tencentcloud-sdk-go v3.0.125+incompatible/go.mod h1:0PfYow01SHPMhKY31xa+EFz2RStxIqj6JFAJS+IkCi4=
|
||||||
github.com/tencentyun/cos-go-sdk-v5 v0.0.0-20200120023323-87ff3bc489ac h1:PSBhZblOjdwH7SIVgcue+7OlnLHkM45KuScLZ+PiVbQ=
|
github.com/tencentyun/cos-go-sdk-v5 v0.0.0-20200120023323-87ff3bc489ac h1:PSBhZblOjdwH7SIVgcue+7OlnLHkM45KuScLZ+PiVbQ=
|
||||||
github.com/tencentyun/cos-go-sdk-v5 v0.0.0-20200120023323-87ff3bc489ac/go.mod h1:wQBO5HdAkLjj2q6XQiIfDSP8DXDNrppDRw2Kp/1BODA=
|
github.com/tencentyun/cos-go-sdk-v5 v0.0.0-20200120023323-87ff3bc489ac/go.mod h1:wQBO5HdAkLjj2q6XQiIfDSP8DXDNrppDRw2Kp/1BODA=
|
||||||
github.com/ugorji/go v1.1.4/go.mod h1:uQMGLiO92mf5W77hV/PUCpI3pbzQx3CRekS0kk+RGrc=
|
github.com/ugorji/go v1.1.4/go.mod h1:uQMGLiO92mf5W77hV/PUCpI3pbzQx3CRekS0kk+RGrc=
|
||||||
|
|
|
@ -108,6 +108,7 @@ solid #e9e9e9;"bgcolor="#fff"><tbody><tr style="font-family: 'Helvetica Neue',He
|
||||||
{Name: "onedrive_callback_check", Value: `20`, Type: "timeout"},
|
{Name: "onedrive_callback_check", Value: `20`, Type: "timeout"},
|
||||||
{Name: "aria2_call_timeout", Value: `5`, Type: "timeout"},
|
{Name: "aria2_call_timeout", Value: `5`, Type: "timeout"},
|
||||||
{Name: "onedrive_chunk_retries", Value: `1`, Type: "retry"},
|
{Name: "onedrive_chunk_retries", Value: `1`, Type: "retry"},
|
||||||
|
{Name: "reset_after_upload_failed", Value: `0`, Type: "upload"},
|
||||||
{Name: "login_captcha", Value: `0`, Type: "login"},
|
{Name: "login_captcha", Value: `0`, Type: "login"},
|
||||||
{Name: "qq_login", Value: `0`, Type: "login"},
|
{Name: "qq_login", Value: `0`, Type: "login"},
|
||||||
{Name: "qq_direct_login", Value: `0`, Type: "login"},
|
{Name: "qq_direct_login", Value: `0`, Type: "login"},
|
||||||
|
|
|
@ -46,6 +46,27 @@ type Driver struct {
|
||||||
HTTPClient request.Client
|
HTTPClient request.Client
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// CORS 创建跨域策略
|
||||||
|
func (handler Driver) CORS() error {
|
||||||
|
_, err := handler.Client.Bucket.PutCORS(context.Background(), &cossdk.BucketPutCORSOptions{
|
||||||
|
Rules: []cossdk.BucketCORSRule{{
|
||||||
|
AllowedMethods: []string{
|
||||||
|
"GET",
|
||||||
|
"POST",
|
||||||
|
"PUT",
|
||||||
|
"DELETE",
|
||||||
|
"HEAD",
|
||||||
|
},
|
||||||
|
AllowedOrigins: []string{"*"},
|
||||||
|
AllowedHeaders: []string{"*"},
|
||||||
|
MaxAgeSeconds: 3600,
|
||||||
|
ExposeHeaders: []string{},
|
||||||
|
}},
|
||||||
|
})
|
||||||
|
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
// Get 获取文件
|
// Get 获取文件
|
||||||
func (handler Driver) Get(ctx context.Context, path string) (response.RSCloser, error) {
|
func (handler Driver) Get(ctx context.Context, path string) (response.RSCloser, error) {
|
||||||
// 获取文件源地址
|
// 获取文件源地址
|
||||||
|
@ -221,13 +242,17 @@ func (handler Driver) Token(ctx context.Context, TTL int64, key string) (seriali
|
||||||
map[string]string{"$key": savePath},
|
map[string]string{"$key": savePath},
|
||||||
map[string]string{"x-cos-meta-callback": apiURL},
|
map[string]string{"x-cos-meta-callback": apiURL},
|
||||||
map[string]string{"x-cos-meta-key": key},
|
map[string]string{"x-cos-meta-key": key},
|
||||||
[]interface{}{"content-length-range", 0, handler.Policy.MaxSize},
|
|
||||||
map[string]string{"q-sign-algorithm": "sha1"},
|
map[string]string{"q-sign-algorithm": "sha1"},
|
||||||
map[string]string{"q-ak": handler.Policy.AccessKey},
|
map[string]string{"q-ak": handler.Policy.AccessKey},
|
||||||
map[string]string{"q-sign-time": keyTime},
|
map[string]string{"q-sign-time": keyTime},
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if handler.Policy.MaxSize > 0 {
|
||||||
|
postPolicy.Conditions = append(postPolicy.Conditions,
|
||||||
|
[]interface{}{"content-length-range", 0, handler.Policy.MaxSize})
|
||||||
|
}
|
||||||
|
|
||||||
res, err := handler.getUploadCredential(ctx, postPolicy, keyTime)
|
res, err := handler.getUploadCredential(ctx, postPolicy, keyTime)
|
||||||
if err == nil {
|
if err == nil {
|
||||||
res.Callback = apiURL
|
res.Callback = apiURL
|
||||||
|
|
133
pkg/filesystem/driver/cos/scf.go
Normal file
133
pkg/filesystem/driver/cos/scf.go
Normal file
|
@ -0,0 +1,133 @@
|
||||||
|
package cos
|
||||||
|
|
||||||
|
import (
|
||||||
|
"archive/zip"
|
||||||
|
"bytes"
|
||||||
|
"encoding/base64"
|
||||||
|
model "github.com/HFO4/cloudreve/models"
|
||||||
|
"github.com/HFO4/cloudreve/pkg/hashid"
|
||||||
|
"github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/common"
|
||||||
|
"github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/common/profile"
|
||||||
|
scf "github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/scf/v20180416"
|
||||||
|
"io"
|
||||||
|
"io/ioutil"
|
||||||
|
"net/url"
|
||||||
|
"strconv"
|
||||||
|
"strings"
|
||||||
|
"time"
|
||||||
|
)
|
||||||
|
|
||||||
|
const scfFunc = `# -*- coding: utf8 -*-
|
||||||
|
# SCF配置COS触发,向 Cloudreve 发送回调
|
||||||
|
from qcloud_cos_v5 import CosConfig
|
||||||
|
from qcloud_cos_v5 import CosS3Client
|
||||||
|
from qcloud_cos_v5 import CosServiceError
|
||||||
|
from qcloud_cos_v5 import CosClientError
|
||||||
|
import sys
|
||||||
|
import logging
|
||||||
|
import requests
|
||||||
|
|
||||||
|
logging.basicConfig(level=logging.INFO, stream=sys.stdout)
|
||||||
|
logger = logging.getLogger()
|
||||||
|
|
||||||
|
|
||||||
|
def main_handler(event, context):
|
||||||
|
logger.info("start main handler")
|
||||||
|
for record in event['Records']:
|
||||||
|
try:
|
||||||
|
if "x-cos-meta-callback" not in record['cos']['cosObject']['meta']:
|
||||||
|
logger.info("Cannot find callback URL, skiped.")
|
||||||
|
return 'Success'
|
||||||
|
callback = record['cos']['cosObject']['meta']['x-cos-meta-callback']
|
||||||
|
key = record['cos']['cosObject']['key']
|
||||||
|
logger.info("Callback URL is " + callback)
|
||||||
|
|
||||||
|
r = requests.get(callback)
|
||||||
|
print(r.text)
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
except Exception as e:
|
||||||
|
print(e)
|
||||||
|
print('Error getting object {} callback url. '.format(key))
|
||||||
|
raise e
|
||||||
|
return "Fail"
|
||||||
|
|
||||||
|
return "Success"
|
||||||
|
`
|
||||||
|
|
||||||
|
// CreateSCF 创建回调云函数
|
||||||
|
func CreateSCF(policy *model.Policy, region string) error {
|
||||||
|
// 初始化客户端
|
||||||
|
credential := common.NewCredential(
|
||||||
|
policy.AccessKey,
|
||||||
|
policy.SecretKey,
|
||||||
|
)
|
||||||
|
cpf := profile.NewClientProfile()
|
||||||
|
client, err := scf.NewClient(credential, region, cpf)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
// 创建回调代码数据
|
||||||
|
buff := &bytes.Buffer{}
|
||||||
|
bs64 := base64.NewEncoder(base64.StdEncoding, buff)
|
||||||
|
zipWriter := zip.NewWriter(bs64)
|
||||||
|
header := zip.FileHeader{
|
||||||
|
Name: "callback.py",
|
||||||
|
Method: zip.Deflate,
|
||||||
|
}
|
||||||
|
writer, err := zipWriter.CreateHeader(&header)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
_, err = io.Copy(writer, strings.NewReader(scfFunc))
|
||||||
|
zipWriter.Close()
|
||||||
|
|
||||||
|
// 创建云函数
|
||||||
|
req := scf.NewCreateFunctionRequest()
|
||||||
|
funcName := "cloudreve_" + hashid.HashID(policy.ID, hashid.PolicyID) + strconv.FormatInt(time.Now().Unix(), 10)
|
||||||
|
zipFileBytes, _ := ioutil.ReadAll(buff)
|
||||||
|
zipFileStr := string(zipFileBytes)
|
||||||
|
codeSource := "ZipFile"
|
||||||
|
handler := "callback.main_handler"
|
||||||
|
desc := "Cloudreve 用回调函数"
|
||||||
|
timeout := int64(60)
|
||||||
|
runtime := "Python3.6"
|
||||||
|
req.FunctionName = &funcName
|
||||||
|
req.Code = &scf.Code{
|
||||||
|
ZipFile: &zipFileStr,
|
||||||
|
}
|
||||||
|
req.Handler = &handler
|
||||||
|
req.Description = &desc
|
||||||
|
req.Timeout = &timeout
|
||||||
|
req.Runtime = &runtime
|
||||||
|
req.CodeSource = &codeSource
|
||||||
|
|
||||||
|
_, err = client.CreateFunction(req)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
time.Sleep(time.Duration(5) * time.Second)
|
||||||
|
|
||||||
|
// 创建触发器
|
||||||
|
server, _ := url.Parse(policy.Server)
|
||||||
|
triggerType := "cos"
|
||||||
|
triggerDesc := `{"event":"cos:ObjectCreated:Post","filter":{"Prefix":"","Suffix":""}}`
|
||||||
|
enable := "OPEN"
|
||||||
|
|
||||||
|
trigger := scf.NewCreateTriggerRequest()
|
||||||
|
trigger.FunctionName = &funcName
|
||||||
|
trigger.TriggerName = &server.Host
|
||||||
|
trigger.Type = &triggerType
|
||||||
|
trigger.TriggerDesc = &triggerDesc
|
||||||
|
trigger.Enable = &enable
|
||||||
|
|
||||||
|
_, err = client.CreateTrigger(trigger)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
return nil
|
||||||
|
}
|
|
@ -6,6 +6,7 @@ import (
|
||||||
"github.com/HFO4/cloudreve/pkg/cache"
|
"github.com/HFO4/cloudreve/pkg/cache"
|
||||||
"github.com/HFO4/cloudreve/pkg/filesystem/driver/local"
|
"github.com/HFO4/cloudreve/pkg/filesystem/driver/local"
|
||||||
"github.com/HFO4/cloudreve/pkg/filesystem/fsctx"
|
"github.com/HFO4/cloudreve/pkg/filesystem/fsctx"
|
||||||
|
"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"
|
||||||
"github.com/gin-gonic/gin"
|
"github.com/gin-gonic/gin"
|
||||||
|
@ -26,6 +27,7 @@ func (fs *FileSystem) Upload(ctx context.Context, file FileHeader) (err error) {
|
||||||
// 上传前的钩子
|
// 上传前的钩子
|
||||||
err = fs.Trigger(ctx, "BeforeUpload")
|
err = fs.Trigger(ctx, "BeforeUpload")
|
||||||
if err != nil {
|
if err != nil {
|
||||||
|
request.BlackHole(file)
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -5,6 +5,7 @@ import (
|
||||||
"encoding/json"
|
"encoding/json"
|
||||||
"errors"
|
"errors"
|
||||||
"fmt"
|
"fmt"
|
||||||
|
model "github.com/HFO4/cloudreve/models"
|
||||||
"github.com/HFO4/cloudreve/pkg/auth"
|
"github.com/HFO4/cloudreve/pkg/auth"
|
||||||
"github.com/HFO4/cloudreve/pkg/serializer"
|
"github.com/HFO4/cloudreve/pkg/serializer"
|
||||||
"github.com/HFO4/cloudreve/pkg/util"
|
"github.com/HFO4/cloudreve/pkg/util"
|
||||||
|
@ -271,3 +272,13 @@ func (instance NopRSCloser) Seek(offset int64, whence int) (int64, error) {
|
||||||
return 0, errors.New("未实现")
|
return 0, errors.New("未实现")
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// BlackHole 将客户端发来的数据放入黑洞
|
||||||
|
func BlackHole(r io.Reader) {
|
||||||
|
if !model.IsTrueVal(model.GetSettingByName("reset_after_upload_failed")) {
|
||||||
|
_, err := io.Copy(ioutil.Discard, r)
|
||||||
|
if err != nil {
|
||||||
|
util.Log().Debug("黑洞数据出错,%s", err)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
|
@ -183,3 +183,14 @@ func AdminAddCORS(c *gin.Context) {
|
||||||
c.JSON(200, ErrorResponse(err))
|
c.JSON(200, ErrorResponse(err))
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// AdminAddCORS 创建跨域策略
|
||||||
|
func AdminAddSCF(c *gin.Context) {
|
||||||
|
var service admin.PolicyService
|
||||||
|
if err := c.ShouldBindJSON(&service); err == nil {
|
||||||
|
res := service.AddSCF()
|
||||||
|
c.JSON(200, res)
|
||||||
|
} else {
|
||||||
|
c.JSON(200, ErrorResponse(err))
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
|
@ -8,6 +8,7 @@ import (
|
||||||
"github.com/HFO4/cloudreve/pkg/filesystem"
|
"github.com/HFO4/cloudreve/pkg/filesystem"
|
||||||
"github.com/HFO4/cloudreve/pkg/filesystem/driver/local"
|
"github.com/HFO4/cloudreve/pkg/filesystem/driver/local"
|
||||||
"github.com/HFO4/cloudreve/pkg/filesystem/fsctx"
|
"github.com/HFO4/cloudreve/pkg/filesystem/fsctx"
|
||||||
|
"github.com/HFO4/cloudreve/pkg/request"
|
||||||
"github.com/HFO4/cloudreve/pkg/serializer"
|
"github.com/HFO4/cloudreve/pkg/serializer"
|
||||||
"github.com/HFO4/cloudreve/service/explorer"
|
"github.com/HFO4/cloudreve/service/explorer"
|
||||||
"github.com/gin-gonic/gin"
|
"github.com/gin-gonic/gin"
|
||||||
|
@ -276,6 +277,7 @@ func FileUploadStream(c *gin.Context) {
|
||||||
|
|
||||||
// 非可用策略时拒绝上传
|
// 非可用策略时拒绝上传
|
||||||
if user, ok := c.Get("user"); ok && !user.(*model.User).Policy.IsTransitUpload(fileSize) {
|
if user, ok := c.Get("user"); ok && !user.(*model.User).Policy.IsTransitUpload(fileSize) {
|
||||||
|
request.BlackHole(c.Request.Body)
|
||||||
c.JSON(200, serializer.Err(serializer.CodePolicyNotAllowed, "当前存储策略无法使用", nil))
|
c.JSON(200, serializer.Err(serializer.CodePolicyNotAllowed, "当前存储策略无法使用", nil))
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
|
@ -6,6 +6,7 @@ import (
|
||||||
model "github.com/HFO4/cloudreve/models"
|
model "github.com/HFO4/cloudreve/models"
|
||||||
"github.com/HFO4/cloudreve/pkg/authn"
|
"github.com/HFO4/cloudreve/pkg/authn"
|
||||||
"github.com/HFO4/cloudreve/pkg/qq"
|
"github.com/HFO4/cloudreve/pkg/qq"
|
||||||
|
"github.com/HFO4/cloudreve/pkg/request"
|
||||||
"github.com/HFO4/cloudreve/pkg/serializer"
|
"github.com/HFO4/cloudreve/pkg/serializer"
|
||||||
"github.com/HFO4/cloudreve/pkg/thumb"
|
"github.com/HFO4/cloudreve/pkg/thumb"
|
||||||
"github.com/HFO4/cloudreve/pkg/util"
|
"github.com/HFO4/cloudreve/pkg/util"
|
||||||
|
@ -298,6 +299,7 @@ func UploadAvatar(c *gin.Context) {
|
||||||
// 取得头像上传大小限制
|
// 取得头像上传大小限制
|
||||||
maxSize := model.GetIntSetting("avatar_size", 2097152)
|
maxSize := model.GetIntSetting("avatar_size", 2097152)
|
||||||
if c.Request.ContentLength == -1 || c.Request.ContentLength > int64(maxSize) {
|
if c.Request.ContentLength == -1 || c.Request.ContentLength > int64(maxSize) {
|
||||||
|
request.BlackHole(c.Request.Body)
|
||||||
c.JSON(200, serializer.Err(serializer.CodeUploadFailed, "头像尺寸太大", nil))
|
c.JSON(200, serializer.Err(serializer.CodeUploadFailed, "头像尺寸太大", nil))
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
|
@ -334,8 +334,10 @@ func InitMasterRouter() *gin.Engine {
|
||||||
policy.POST("test/slave", controllers.AdminTestSlave)
|
policy.POST("test/slave", controllers.AdminTestSlave)
|
||||||
// 创建存储策略
|
// 创建存储策略
|
||||||
policy.POST("", controllers.AdminAddPolicy)
|
policy.POST("", controllers.AdminAddPolicy)
|
||||||
// 创建存储策略
|
// 创建跨域策略
|
||||||
policy.POST("cors", controllers.AdminAddCORS)
|
policy.POST("cors", controllers.AdminAddCORS)
|
||||||
|
// 创建COS回调函数
|
||||||
|
policy.POST("scf", controllers.AdminAddSCF)
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -7,10 +7,13 @@ import (
|
||||||
model "github.com/HFO4/cloudreve/models"
|
model "github.com/HFO4/cloudreve/models"
|
||||||
"github.com/HFO4/cloudreve/pkg/auth"
|
"github.com/HFO4/cloudreve/pkg/auth"
|
||||||
"github.com/HFO4/cloudreve/pkg/conf"
|
"github.com/HFO4/cloudreve/pkg/conf"
|
||||||
|
"github.com/HFO4/cloudreve/pkg/filesystem/driver/cos"
|
||||||
"github.com/HFO4/cloudreve/pkg/filesystem/driver/oss"
|
"github.com/HFO4/cloudreve/pkg/filesystem/driver/oss"
|
||||||
"github.com/HFO4/cloudreve/pkg/request"
|
"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"
|
||||||
|
cossdk "github.com/tencentyun/cos-go-sdk-v5"
|
||||||
|
"net/http"
|
||||||
"net/url"
|
"net/url"
|
||||||
"os"
|
"os"
|
||||||
"path/filepath"
|
"path/filepath"
|
||||||
|
@ -40,7 +43,22 @@ type AddPolicyService struct {
|
||||||
|
|
||||||
// PolicyService 存储策略ID服务
|
// PolicyService 存储策略ID服务
|
||||||
type PolicyService struct {
|
type PolicyService struct {
|
||||||
ID uint `json:"id" binding:"required"`
|
ID uint `json:"id" binding:"required"`
|
||||||
|
Region string `json:"region"`
|
||||||
|
}
|
||||||
|
|
||||||
|
// AddSCF 创建回调云函数
|
||||||
|
func (service *PolicyService) AddSCF() serializer.Response {
|
||||||
|
policy, err := model.GetPolicyByID(service.ID)
|
||||||
|
if err != nil {
|
||||||
|
return serializer.Err(serializer.CodeNotFound, "存储策略不存在", nil)
|
||||||
|
}
|
||||||
|
|
||||||
|
if err := cos.CreateSCF(&policy, service.Region); err != nil {
|
||||||
|
return serializer.Err(serializer.CodeInternalSetting, "云函数创建失败", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
return serializer.Response{}
|
||||||
}
|
}
|
||||||
|
|
||||||
// AddCORS 创建跨域策略
|
// AddCORS 创建跨域策略
|
||||||
|
@ -59,6 +77,22 @@ func (service *PolicyService) AddCORS() serializer.Response {
|
||||||
if err := handler.CORS(); err != nil {
|
if err := handler.CORS(); err != nil {
|
||||||
return serializer.Err(serializer.CodeInternalSetting, "跨域策略添加失败", err)
|
return serializer.Err(serializer.CodeInternalSetting, "跨域策略添加失败", err)
|
||||||
}
|
}
|
||||||
|
case "cos":
|
||||||
|
u, _ := url.Parse(policy.Server)
|
||||||
|
b := &cossdk.BaseURL{BucketURL: u}
|
||||||
|
handler := cos.Driver{
|
||||||
|
Policy: &policy,
|
||||||
|
HTTPClient: request.HTTPClient{},
|
||||||
|
Client: cossdk.NewClient(b, &http.Client{
|
||||||
|
Transport: &cossdk.AuthorizationTransport{
|
||||||
|
SecretID: policy.AccessKey,
|
||||||
|
SecretKey: policy.SecretKey,
|
||||||
|
},
|
||||||
|
}),
|
||||||
|
}
|
||||||
|
if err := handler.CORS(); err != nil {
|
||||||
|
return serializer.Err(serializer.CodeInternalSetting, "跨域策略添加失败", err)
|
||||||
|
}
|
||||||
default:
|
default:
|
||||||
return serializer.ParamErr("不支持此策略", nil)
|
return serializer.ParamErr("不支持此策略", nil)
|
||||||
}
|
}
|
||||||
|
|
Loading…
Add table
Reference in a new issue