feat:获取资源详情

This commit is contained in:
Hiven 2023-08-09 14:58:20 +08:00
parent d5e5cdc8f0
commit 7b32eb9154
2 changed files with 83 additions and 136 deletions

View File

@ -1,21 +1,16 @@
package logic package logic
import ( import (
"fusenapi/model/gmodel"
"fusenapi/utils/auth" "fusenapi/utils/auth"
"fusenapi/utils/basic" "fusenapi/utils/basic"
"fusenapi/utils/file" "fusenapi/utils/file"
"fusenapi/utils/hash" "fusenapi/utils/hash"
"time"
"context" "context"
"fusenapi/server/upload/internal/svc" "fusenapi/server/upload/internal/svc"
"fusenapi/server/upload/internal/types" "fusenapi/server/upload/internal/types"
"github.com/aws/aws-sdk-go/aws"
"github.com/aws/aws-sdk-go/aws/request"
"github.com/aws/aws-sdk-go/service/s3"
"github.com/zeromicro/go-zero/core/logx" "github.com/zeromicro/go-zero/core/logx"
) )
@ -66,91 +61,35 @@ func (l *UploadFileBaseLogic) UploadFileBase(req *types.UploadFileBaseReq, useri
} }
} }
// 定义存储桶名称 // 根据hash 查询数据资源
var bucketName *string
var apiType int64 = req.ApiType
// 根据类别选择存储桶
switch req.UploadBucket {
case 2:
bucketName = basic.TempfileBucketName
default:
bucketName = basic.StorageBucketName
}
// 设置AWS会话的区域
l.svcCtx.AwsSession.Config.Region = aws.String("us-west-1")
// 创建新的S3服务实例
svc := s3.New(l.svcCtx.AwsSession)
// 定义S3请求和当前时间
var s3req *request.Request
var resourceId string = hash.JsonHashKey(req.FileKey) var resourceId string = hash.JsonHashKey(req.FileKey)
var uploadUrl = UploadUrl{} // 上传文件
resourceModel := gmodel.NewFsResourceModel(l.svcCtx.MysqlConn) var upload = file.Upload{
resourceInfo, err := resourceModel.FindOneById(l.ctx, resourceId) Ctx: l.ctx,
if err == nil && resourceInfo.ResourceId != "" { MysqlConn: l.svcCtx.MysqlConn,
uploadUrl.Status = 1 AwsSession: l.svcCtx.AwsSession,
uploadUrl.ResourceId = resourceId
uploadUrl.ResourceUrl = *resourceInfo.ResourceUrl
} else {
dist, contentType, err := file.FileBase64ToByte(req.FileData)
if err != nil {
logx.Error(err)
return resp.SetStatus(basic.CodeFileUploadErr, "file upload err,base64tobyte error")
} }
uploadRes, err := upload.UploadFileByBase64(&file.UploadBaseReq{
// 创建S3对象存储请求 FileHash: resourceId,
s3req, _ = svc.PutObjectRequest( FileData: req.FileData,
&s3.PutObjectInput{ UploadBucket: req.UploadBucket,
Bucket: bucketName, ApiType: req.ApiType,
Key: &resourceId, UserId: userId,
}, GuestId: guestId,
)
// 设置请求体为文件数据
s3req.SetBufferBody(dist)
// 发送请求
err = s3req.Send()
// 检查是否有错误
if err != nil {
logx.Error(err)
uploadUrl.Status = 0
} else {
var url = s3req.HTTPRequest.URL.String()
// 打印请求URL
logx.Info(url)
uploadUrl.Status = 1
uploadUrl.ResourceId = resourceId
uploadUrl.ResourceUrl = url
var version string = "0.0.1"
var nowTime = time.Now()
_, err = resourceModel.Create(l.ctx, &gmodel.FsResource{
ResourceId: resourceId,
UserId: &userId,
GuestId: &guestId,
ResourceType: &contentType,
ResourceUrl: &url,
Version: &version,
UploadedAt: &nowTime,
Metadata: &req.Metadata,
ApiType: &apiType,
BucketName: bucketName,
}) })
if err != nil { if err != nil {
logx.Error(err) logx.Error(err)
} return resp.SetStatus(basic.CodeFileUploadErr, "upload file failed")
}
} }
// 返回成功的响应和上传URL // 返回成功的响应和上传URL
return resp.SetStatus(basic.CodeOK, map[string]interface{}{ return resp.SetStatus(basic.CodeOK, map[string]interface{}{
"upload_data": uploadUrl, "upload_data": UploadUrl{
Status: 1,
ResourceId: uploadRes.ResourceId,
ResourceUrl: uploadRes.ResourceUrl,
},
}) })
} }

View File

@ -65,7 +65,9 @@ func (upload *Upload) UploadFileByBase64(req *UploadBaseReq) (*UploadBaseRes, er
var uploadBaseRes = UploadBaseRes{} var uploadBaseRes = UploadBaseRes{}
resourceModel := gmodel.NewFsResourceModel(upload.MysqlConn) resourceModel := gmodel.NewFsResourceModel(upload.MysqlConn)
resourceInfo, err := resourceModel.FindOneById(upload.Ctx, resourceId) err := resourceModel.Trans(upload.Ctx, func(ctx context.Context, connGorm *gorm.DB) error {
resourceModelTS := gmodel.NewFsResourceModel(connGorm)
resourceInfo, err := resourceModelTS.FindOneById(ctx, resourceId)
if err == nil && resourceInfo.ResourceId != "" { if err == nil && resourceInfo.ResourceId != "" {
uploadBaseRes.Status = 1 uploadBaseRes.Status = 1
uploadBaseRes.ResourceId = resourceId uploadBaseRes.ResourceId = resourceId
@ -75,7 +77,7 @@ func (upload *Upload) UploadFileByBase64(req *UploadBaseReq) (*UploadBaseRes, er
if err != nil { if err != nil {
logx.Errorf("err:%+vdesc:%+v", err, "fail.upload.resourceInfoGet.mysql") logx.Errorf("err:%+vdesc:%+v", err, "fail.upload.resourceInfoGet.mysql")
return nil, err return err
} }
// 创建S3对象存储请求 // 创建S3对象存储请求
@ -95,7 +97,7 @@ func (upload *Upload) UploadFileByBase64(req *UploadBaseReq) (*UploadBaseRes, er
// 检查是否有错误 // 检查是否有错误
if err != nil { if err != nil {
logx.Errorf("err:%+vdesc:%+v", err, "fail.upload.s3req") logx.Errorf("err:%+vdesc:%+v", err, "fail.upload.s3req")
return nil, err return err
} else { } else {
var url = s3req.HTTPRequest.URL.String() var url = s3req.HTTPRequest.URL.String()
// 打印请求URL // 打印请求URL
@ -105,7 +107,7 @@ func (upload *Upload) UploadFileByBase64(req *UploadBaseReq) (*UploadBaseRes, er
uploadBaseRes.ResourceUrl = url uploadBaseRes.ResourceUrl = url
var version string = "0.0.1" var version string = "0.0.1"
var nowTime = time.Now() var nowTime = time.Now()
_, err = resourceModel.Create(upload.Ctx, &gmodel.FsResource{ _, err = resourceModelTS.Create(upload.Ctx, &gmodel.FsResource{
ResourceId: resourceId, ResourceId: resourceId,
UserId: &req.UserId, UserId: &req.UserId,
GuestId: &req.GuestId, GuestId: &req.GuestId,
@ -119,9 +121,15 @@ func (upload *Upload) UploadFileByBase64(req *UploadBaseReq) (*UploadBaseRes, er
}) })
if err != nil { if err != nil {
logx.Errorf("err:%+vdesc:%+v", err, "fail.upload.resourceInfoAdd.mysql") logx.Errorf("err:%+vdesc:%+v", err, "fail.upload.resourceInfoAdd.mysql")
return err
}
}
}
return nil
})
if err != nil {
return nil, err return nil, err
} }
}
}
return &uploadBaseRes, err return &uploadBaseRes, err
} }