Cloudreve/pkg/filesystem/qiniu/handller.go

117 lines
3.3 KiB
Go
Raw Normal View History

2019-11-26 11:42:26 +08:00
package qiniu
import (
"context"
2020-01-15 10:14:15 +08:00
"errors"
2019-11-26 11:42:26 +08:00
"fmt"
2020-01-15 10:14:15 +08:00
model "github.com/HFO4/cloudreve/models"
"github.com/HFO4/cloudreve/pkg/filesystem/fsctx"
"github.com/HFO4/cloudreve/pkg/filesystem/response"
"github.com/HFO4/cloudreve/pkg/serializer"
2019-11-26 11:42:26 +08:00
"github.com/qiniu/api.v7/v7/auth"
2020-01-15 10:14:15 +08:00
"github.com/qiniu/api.v7/v7/auth/qbox"
2019-11-26 11:42:26 +08:00
"github.com/qiniu/api.v7/v7/storage"
2020-01-15 10:14:15 +08:00
"io"
"net/url"
2019-11-26 11:42:26 +08:00
)
// Handler 本地策略适配器
2020-01-15 10:14:15 +08:00
type Handler struct {
Policy *model.Policy
}
// Get 获取文件
func (handler Handler) Get(ctx context.Context, path string) (response.RSCloser, error) {
return nil, errors.New("未实现")
}
2019-11-26 11:42:26 +08:00
// Put 将文件流保存到指定目录
func (handler Handler) Put(ctx context.Context, file io.ReadCloser, dst string, size uint64) error {
2020-01-15 10:14:15 +08:00
return errors.New("未实现")
2019-11-26 11:42:26 +08:00
// 凭证生成
putPolicy := storage.PutPolicy{
Scope: "cloudrevetest",
}
mac := auth.New("YNzTBBpDUq4EEiFV0-vyJCZCJ0LvUEI0_WvxtEXE", "Clm9d9M2CH7pZ8vm049ZlGZStQxrRQVRTjU_T5_0")
upToken := putPolicy.UploadToken(mac)
cfg := storage.Config{}
// 空间对应的机房
cfg.Zone = &storage.ZoneHuadong
formUploader := storage.NewFormUploader(&cfg)
ret := storage.PutRet{}
putExtra := storage.PutExtra{
Params: map[string]string{},
}
defer file.Close()
err := formUploader.Put(ctx, &ret, upToken, dst, file, int64(size), &putExtra)
if err != nil {
fmt.Println(err)
return err
}
fmt.Println(ret.Key, ret.Hash)
return nil
}
// Delete 删除一个或多个文件,
2020-01-15 10:14:15 +08:00
// 返回未删除的文件,及遇到的最后一个错误
2019-11-26 11:42:26 +08:00
func (handler Handler) Delete(ctx context.Context, files []string) ([]string, error) {
2020-01-15 10:14:15 +08:00
return []string{}, errors.New("未实现")
}
// Thumb 获取文件缩略图
func (handler Handler) Thumb(ctx context.Context, path string) (*response.ContentResponse, error) {
return nil, errors.New("未实现")
}
// Source 获取外链URL
func (handler Handler) Source(
ctx context.Context,
path string,
baseURL url.URL,
ttl int64,
isDownload bool,
speed int,
) (string, error) {
return "", errors.New("未实现")
}
// Token 获取上传策略和认证Token
func (handler Handler) Token(ctx context.Context, TTL int64, key string) (serializer.UploadCredential, error) {
// 生成回调地址
siteURL := model.GetSiteURL()
apiBaseURI, _ := url.Parse("/api/v3/callback/qiniu/" + key)
apiURL := siteURL.ResolveReference(apiBaseURI)
// 读取上下文中生成的存储路径
savePath, ok := ctx.Value(fsctx.SavePathCtx).(string)
if !ok {
return serializer.UploadCredential{}, errors.New("无法获取存储路径")
2019-11-26 11:42:26 +08:00
}
2020-01-15 10:14:15 +08:00
// 创建上传策略
putPolicy := storage.PutPolicy{
Scope: handler.Policy.BucketName,
Expires: uint64(TTL),
CallbackURL: apiURL.String(),
CallbackBody: `{"name":"$(fname)","source_name":"$(key)","size":$(fsize),"pic_info":"$(imageInfo.width),$(imageInfo.height)"}`,
CallbackBodyType: "application/json",
SaveKey: savePath,
ForceSaveKey: true,
FsizeLimit: int64(handler.Policy.MaxSize),
}
// 是否开启了MIMEType限制
if handler.Policy.OptionsSerialized.MimeType != "" {
putPolicy.MimeLimit = handler.Policy.OptionsSerialized.MimeType
}
mac := qbox.NewMac(handler.Policy.AccessKey, handler.Policy.SecretKey)
upToken := putPolicy.UploadToken(mac)
return serializer.UploadCredential{
Token: upToken,
}, nil
2019-11-26 11:42:26 +08:00
}