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
|
|
|
}
|