fusenapi/server/upload/internal/logic/uploadfilesfrontendlogic.go

146 lines
4.0 KiB
Go
Raw Normal View History

2023-08-01 10:13:30 +00:00
package logic
import (
"fusenapi/utils/auth"
"fusenapi/utils/basic"
2023-08-01 11:49:56 +00:00
"time"
2023-08-01 10:13:30 +00:00
"context"
"fusenapi/server/upload/internal/svc"
"fusenapi/server/upload/internal/types"
2023-08-01 11:49:56 +00:00
"github.com/aws/aws-sdk-go/aws"
"github.com/aws/aws-sdk-go/service/s3"
2023-08-01 10:13:30 +00:00
"github.com/zeromicro/go-zero/core/logx"
2023-08-01 11:49:56 +00:00
"github.com/zeromicro/go-zero/core/mr"
2023-08-01 10:13:30 +00:00
)
type UploadFilesFrontendLogic struct {
logx.Logger
ctx context.Context
svcCtx *svc.ServiceContext
}
func NewUploadFilesFrontendLogic(ctx context.Context, svcCtx *svc.ServiceContext) *UploadFilesFrontendLogic {
return &UploadFilesFrontendLogic{
Logger: logx.WithContext(ctx),
ctx: ctx,
svcCtx: svcCtx,
}
}
// 处理进入前逻辑w,r
// func (l *UploadFilesFrontendLogic) BeforeLogic(w http.ResponseWriter, r *http.Request) {
// }
// 处理逻辑后 w,r 如:重定向, resp 必须重新处理
// func (l *UploadFilesFrontendLogic) AfterLogic(w http.ResponseWriter, r *http.Request, resp *basic.Response) {
// // httpx.OkJsonCtx(r.Context(), w, resp)
// }
func (l *UploadFilesFrontendLogic) UploadFilesFrontend(req *types.UploadFilesReq, userinfo *auth.UserInfo) (resp *basic.Response) {
// 返回值必须调用Set重新返回, resp可以空指针调用 resp.SetStatus(basic.CodeOK, data)
// userinfo 传入值时, 一定不为null
2023-08-01 11:49:56 +00:00
// 定义用户ID和S3键名格式
// var userId int64
// var guestId int64
2023-08-01 10:13:30 +00:00
2023-08-01 11:49:56 +00:00
// 检查用户是否是游客
// if userinfo.IsGuest() {
// // 如果是使用游客ID和游客键名格式
// guestId = userinfo.GuestId
// } else {
// // 否则使用用户ID和用户键名格式
// userId = userinfo.UserId
// }
var aa = make([]types.UploadInfo, 2)
aa[0].FileKeys = "202308011632"
aa[1].FileKeys = "202308011633"
req.UploadInfo = aa
var fileLen = len(req.UploadInfo)
if fileLen == 0 {
return resp.SetStatus(basic.CodeFileUploadErr, "file upload err,no files")
}
if req.ApiType == 1 && fileLen > 100 {
return resp.SetStatus(basic.CodeFileUploadErr, "file upload err, files count is beyond the maximum")
}
var uploadBucket = req.UploadBucket
// 设置AWS会话的区域
l.svcCtx.AwsSession.Config.Region = aws.String("us-west-1")
// 创建新的S3服务实例
svc := s3.New(l.svcCtx.AwsSession)
result, err := mr.MapReduce(func(source chan<- interface{}) {
for _, info := range req.UploadInfo {
if info.FileSize <= 1024*1024*500 {
// 一系列业务逻辑....验证类型,文件大小
var fileKey string = info.FileKeys
source <- uploadData{
FileKey: fileKey,
FileSize: info.FileSize,
Bucket: uploadBucket,
}
}
}
}, func(item interface{}, writer mr.Writer[interface{}], cancel func(error)) {
var uploadUrl = uploadUrl{}
uploadDataInfo := item.(uploadData)
s3req, _ := svc.PutObjectRequest(
&s3.PutObjectInput{
Bucket: &uploadBucket,
Key: &uploadDataInfo.FileKey,
ContentLength: aws.Int64(uploadDataInfo.FileSize),
},
)
url, err := s3req.Presign(time.Minute * 5)
if err != nil {
logx.Error(err)
uploadUrl.Status = 0
uploadUrl.Url = ""
uploadUrl.Key = uploadDataInfo.FileKey
} else {
// 打印请求URL
logx.Info(url)
uploadUrl.Status = 1
uploadUrl.Url = url
uploadUrl.Key = uploadDataInfo.FileKey
}
// Notice 这个必须加!
writer.Write(uploadUrl)
}, func(pipe <-chan interface{}, writer mr.Writer[interface{}], cancel func(error)) {
var uploadUrlList = make(map[string][]*uploadUrl)
var uploadUrlListFail []*uploadUrl
var uploadUrlListSuccess []*uploadUrl
for p := range pipe {
var uploadUrl = p.(uploadUrl)
if uploadUrl.Status == 1 {
uploadUrlListSuccess = append(uploadUrlListSuccess, &uploadUrl)
} else {
uploadUrlListFail = append(uploadUrlListFail, &uploadUrl)
}
}
// Notice 这个必须加!
uploadUrlList["success"] = uploadUrlListSuccess
uploadUrlList["fail"] = uploadUrlListFail
writer.Write(uploadUrlList)
})
if err != nil {
logx.Error(err)
}
// 返回成功的响应和上传URL
return resp.SetStatus(basic.CodeOK, map[string]interface{}{
"upload_urls": result,
})
2023-08-01 10:13:30 +00:00
}