Files
open-im-server/internal/api/third/minio_storage_credential.go
T

277 lines
11 KiB
Go
Raw Normal View History

2023-02-23 19:15:30 +08:00
package third
2022-02-18 17:06:27 +08:00
import (
2023-02-23 19:15:30 +08:00
api "OpenIM/pkg/apistruct"
"OpenIM/pkg/common/config"
"OpenIM/pkg/common/constant"
"OpenIM/pkg/common/log"
"OpenIM/pkg/common/tokenverify"
_ "OpenIM/pkg/common/tokenverify"
"OpenIM/pkg/utils"
2022-03-23 15:44:34 +08:00
"context"
2022-02-18 17:06:27 +08:00
"github.com/gin-gonic/gin"
2022-03-23 15:44:34 +08:00
"github.com/minio/minio-go/v7"
2022-02-19 18:48:15 +08:00
_ "github.com/minio/minio-go/v7"
cr "github.com/minio/minio-go/v7/pkg/credentials"
"net/http"
2022-08-10 19:31:57 +08:00
"strconv"
"strings"
2022-02-18 17:06:27 +08:00
)
2022-06-29 11:18:19 +08:00
// @Summary minio上传文件(web api)
// @Description minio上传文件(web api), 请注意本api请求为form并非json
// @Tags 第三方服务相关
// @ID MinioUploadFile
// @Accept json
// @Param token header string true "im token"
// @Param file formData file true "要上传的文件文件"
// @Param fileType formData int true "文件类型"
// @Param operationID formData string true "操作唯一ID"
// @Produce json
// @Success 0 {object} api.MinioUploadFileResp ""
2022-06-29 18:48:17 +08:00
// @Failure 500 {object} api.Swagger500Resp "errCode为500 一般为服务器内部错误"
// @Failure 400 {object} api.Swagger400Resp "errCode为400 一般为参数输入错误, token未带上等"
2022-06-29 11:18:19 +08:00
// @Router /third/minio_upload [post]
2022-03-23 15:44:34 +08:00
func MinioUploadFile(c *gin.Context) {
var (
2022-06-29 11:18:19 +08:00
req api.MinioUploadFileReq
2022-06-29 18:48:17 +08:00
resp api.MinioUploadFile
2022-03-23 15:44:34 +08:00
)
2022-03-23 16:13:18 +08:00
defer func() {
if r := recover(); r != nil {
log.NewError(req.OperationID, utils.GetSelfFuncName(), r)
2022-03-23 17:15:46 +08:00
c.JSON(http.StatusBadRequest, gin.H{"errCode": 400, "errMsg": "missing file or snapShot args"})
2022-03-23 16:13:18 +08:00
return
}
}()
if err := c.Bind(&req); err != nil {
2022-03-23 15:44:34 +08:00
log.NewError("0", utils.GetSelfFuncName(), "BindJSON failed ", err.Error())
c.JSON(http.StatusBadRequest, gin.H{"errCode": 400, "errMsg": err.Error()})
return
}
2022-05-10 10:44:43 +08:00
log.NewInfo(req.OperationID, utils.GetSelfFuncName(), req)
2022-05-07 11:55:19 +08:00
var ok bool
var errInfo string
2023-02-09 14:40:49 +08:00
ok, _, errInfo = tokenverify.GetUserIDFromToken(c.Request.Header.Get("token"), req.OperationID)
2022-03-25 18:46:27 +08:00
if !ok {
2022-05-07 11:55:19 +08:00
errMsg := req.OperationID + " " + "GetUserIDFromToken failed " + errInfo + " token:" + c.Request.Header.Get("token")
log.NewError(req.OperationID, errMsg)
2022-06-29 11:18:19 +08:00
c.JSON(http.StatusBadRequest, gin.H{"errCode": 500, "errMsg": errMsg})
2022-03-25 18:46:27 +08:00
return
}
2022-05-07 11:55:19 +08:00
2022-03-23 15:44:34 +08:00
log.NewInfo(req.OperationID, utils.GetSelfFuncName(), req)
switch req.FileType {
2022-03-25 18:46:27 +08:00
// videoType upload snapShot
2022-03-23 15:44:34 +08:00
case constant.VideoType:
2022-03-23 17:15:46 +08:00
snapShotFile, err := c.FormFile("snapShot")
if err != nil {
c.JSON(http.StatusBadRequest, gin.H{"errCode": 400, "errMsg": "missing snapshot arg: " + err.Error()})
return
}
2022-03-23 15:44:34 +08:00
snapShotFileObj, err := snapShotFile.Open()
if err != nil {
log.NewError(req.OperationID, utils.GetSelfFuncName(), "Open file error", err.Error())
c.JSON(http.StatusBadRequest, gin.H{"errCode": 400, "errMsg": err.Error()})
2022-03-23 16:13:18 +08:00
return
2022-03-23 15:44:34 +08:00
}
2022-03-23 17:40:51 +08:00
snapShotNewName, snapShotNewType := utils.GetNewFileNameAndContentType(snapShotFile.Filename, constant.ImageType)
2022-03-23 17:15:46 +08:00
log.Debug(req.OperationID, utils.GetSelfFuncName(), snapShotNewName, snapShotNewType)
2022-05-10 10:44:43 +08:00
_, err = MinioClient.PutObject(context.Background(), config.Config.Credential.Minio.Bucket, snapShotNewName, snapShotFileObj, snapShotFile.Size, minio.PutObjectOptions{ContentType: snapShotNewType})
2022-03-23 15:44:34 +08:00
if err != nil {
log.NewError(req.OperationID, utils.GetSelfFuncName(), "PutObject snapShotFile error", err.Error())
c.JSON(http.StatusBadRequest, gin.H{"errCode": 400, "errMsg": err.Error()})
2022-03-23 16:13:18 +08:00
return
2022-03-23 15:44:34 +08:00
}
resp.SnapshotURL = config.Config.Credential.Minio.Endpoint + "/" + config.Config.Credential.Minio.Bucket + "/" + snapShotNewName
resp.SnapshotNewName = snapShotNewName
}
2022-03-23 17:15:46 +08:00
file, err := c.FormFile("file")
if err != nil {
2022-05-10 10:44:43 +08:00
log.NewError(req.OperationID, utils.GetSelfFuncName(), "FormFile failed", err.Error())
2022-03-23 17:40:51 +08:00
c.JSON(http.StatusBadRequest, gin.H{"errCode": 400, "errMsg": "missing file arg: " + err.Error()})
2022-03-23 17:15:46 +08:00
return
}
2022-03-23 15:44:34 +08:00
fileObj, err := file.Open()
if err != nil {
log.NewError(req.OperationID, utils.GetSelfFuncName(), "Open file error", err.Error())
c.JSON(http.StatusBadRequest, gin.H{"errCode": 400, "errMsg": "invalid file path" + err.Error()})
return
}
2022-03-23 17:40:51 +08:00
newName, newType := utils.GetNewFileNameAndContentType(file.Filename, req.FileType)
2022-05-10 16:07:58 +08:00
log.Debug(req.OperationID, utils.GetSelfFuncName(), config.Config.Credential.Minio.Bucket, newName, fileObj, file.Size, newType, MinioClient.EndpointURL())
2022-05-10 10:44:43 +08:00
_, err = MinioClient.PutObject(context.Background(), config.Config.Credential.Minio.Bucket, newName, fileObj, file.Size, minio.PutObjectOptions{ContentType: newType})
2022-03-23 15:44:34 +08:00
if err != nil {
2022-06-16 16:49:21 +08:00
log.NewError(req.OperationID, utils.GetSelfFuncName(), "upload file error", err.Error())
2022-05-10 10:44:43 +08:00
c.JSON(http.StatusInternalServerError, gin.H{"errCode": 500, "errMsg": "upload file error" + err.Error()})
2022-03-23 15:44:34 +08:00
return
}
resp.NewName = newName
resp.URL = config.Config.Credential.Minio.Endpoint + "/" + config.Config.Credential.Minio.Bucket + "/" + newName
log.NewInfo(req.OperationID, utils.GetSelfFuncName(), "resp: ", resp)
c.JSON(http.StatusOK, gin.H{"errCode": 0, "errMsg": "", "data": resp})
return
}
2022-02-18 17:06:27 +08:00
func MinioStorageCredential(c *gin.Context) {
var (
2022-06-29 11:18:19 +08:00
req api.MinioStorageCredentialReq
resp api.MiniostorageCredentialResp
2022-02-18 17:06:27 +08:00
)
2022-02-19 18:48:15 +08:00
if err := c.BindJSON(&req); err != nil {
log.NewError("0", utils.GetSelfFuncName(), "BindJSON failed ", err.Error())
c.JSON(http.StatusBadRequest, gin.H{"errCode": 400, "errMsg": err.Error()})
2022-02-18 17:06:27 +08:00
return
}
2022-05-10 10:44:43 +08:00
log.NewInfo(req.OperationID, utils.GetSelfFuncName(), "req: ", req)
2022-05-07 11:55:19 +08:00
var ok bool
var errInfo string
2023-02-09 14:40:49 +08:00
ok, _, errInfo = tokenverify.GetUserIDFromToken(c.Request.Header.Get("token"), req.OperationID)
2022-02-28 17:57:03 +08:00
if !ok {
2022-05-07 11:55:19 +08:00
errMsg := req.OperationID + " " + "GetUserIDFromToken failed " + errInfo + " token:" + c.Request.Header.Get("token")
log.NewError(req.OperationID, errMsg)
c.JSON(http.StatusInternalServerError, gin.H{"errCode": 500, "errMsg": errMsg})
2022-02-28 17:57:03 +08:00
return
}
2022-05-07 11:55:19 +08:00
2022-02-19 18:48:15 +08:00
var stsOpts cr.STSAssumeRoleOptions
stsOpts.AccessKey = config.Config.Credential.Minio.AccessKeyID
stsOpts.SecretKey = config.Config.Credential.Minio.SecretAccessKey
stsOpts.DurationSeconds = constant.MinioDurationTimes
2022-04-11 17:08:54 +08:00
var endpoint string
if config.Config.Credential.Minio.EndpointInnerEnable {
endpoint = config.Config.Credential.Minio.EndpointInner
} else {
endpoint = config.Config.Credential.Minio.Endpoint
}
li, err := cr.NewSTSAssumeRole(endpoint, stsOpts)
2022-02-19 18:48:15 +08:00
if err != nil {
2022-09-06 11:57:22 +08:00
log.NewError(req.OperationID, utils.GetSelfFuncName(), "NewSTSAssumeRole failed", err.Error(), stsOpts, config.Config.Credential.Minio.Endpoint)
2022-02-19 18:48:15 +08:00
c.JSON(http.StatusBadRequest, gin.H{"errCode": 400, "errMsg": err.Error()})
return
}
v, err := li.Get()
if err != nil {
2022-09-06 11:57:22 +08:00
log.NewError(req.OperationID, utils.GetSelfFuncName(), "li.Get error", err.Error())
2022-02-19 18:48:15 +08:00
c.JSON(http.StatusBadRequest, gin.H{"errCode": 400, "errMsg": err.Error()})
return
}
resp.SessionToken = v.SessionToken
resp.SecretAccessKey = v.SecretAccessKey
resp.AccessKeyID = v.AccessKeyID
resp.BucketName = config.Config.Credential.Minio.Bucket
resp.StsEndpointURL = config.Config.Credential.Minio.Endpoint
2022-07-29 14:36:07 +08:00
resp.StorageTime = config.Config.Credential.Minio.StorageTime
2022-08-01 14:33:01 +08:00
resp.IsDistributedMod = config.Config.Credential.Minio.IsDistributedMod
2022-03-17 11:57:21 +08:00
c.JSON(http.StatusOK, gin.H{"errCode": 0, "errMsg": "", "data": resp})
2022-02-18 17:06:27 +08:00
}
2022-05-10 16:53:58 +08:00
func UploadUpdateApp(c *gin.Context) {
var (
2022-06-29 11:18:19 +08:00
req api.UploadUpdateAppReq
resp api.UploadUpdateAppResp
2022-05-10 16:53:58 +08:00
)
if err := c.Bind(&req); err != nil {
log.NewError(req.OperationID, utils.GetSelfFuncName(), "BindJSON failed ", err.Error())
c.JSON(http.StatusBadRequest, gin.H{"errCode": 400, "errMsg": err.Error()})
return
}
log.NewInfo(req.OperationID, utils.GetSelfFuncName(), "req: ", req)
2022-08-10 19:40:10 +08:00
2022-05-10 18:28:57 +08:00
var yamlName string
if req.Yaml == nil {
yamlName = ""
} else {
yamlName = req.Yaml.Filename
}
2022-05-10 18:22:18 +08:00
fileObj, err := req.File.Open()
if err != nil {
log.NewError(req.OperationID, utils.GetSelfFuncName(), "Open file error", err.Error())
c.JSON(http.StatusBadRequest, gin.H{"errCode": 400, "errMsg": "Open file error" + err.Error()})
return
}
2022-05-11 11:07:04 +08:00
_, err = MinioClient.PutObject(context.Background(), config.Config.Credential.Minio.AppBucket, req.File.Filename, fileObj, req.File.Size, minio.PutObjectOptions{})
2022-05-10 16:53:58 +08:00
if err != nil {
log.NewError(req.OperationID, utils.GetSelfFuncName(), "PutObject file error")
c.JSON(http.StatusInternalServerError, gin.H{"errCode": 500, "errMsg": "PutObject file error" + err.Error()})
return
}
2022-05-11 10:46:54 +08:00
if yamlName != "" {
2022-05-10 18:28:57 +08:00
yamlObj, err := req.Yaml.Open()
if err == nil {
2022-05-11 11:07:04 +08:00
_, err = MinioClient.PutObject(context.Background(), config.Config.Credential.Minio.AppBucket, yamlName, yamlObj, req.Yaml.Size, minio.PutObjectOptions{})
2022-05-10 18:28:57 +08:00
if err != nil {
log.NewError(req.OperationID, utils.GetSelfFuncName(), "PutObject yaml error")
c.JSON(http.StatusInternalServerError, gin.H{"errCode": 500, "errMsg": "PutObject yaml error" + err.Error()})
return
}
} else {
log.NewError(req.OperationID, utils.GetSelfFuncName(), err.Error())
2022-05-10 18:22:18 +08:00
}
2022-05-10 16:53:58 +08:00
}
2022-05-11 10:46:54 +08:00
if err := imdb.UpdateAppVersion(req.Type, req.Version, req.ForceUpdate, req.File.Filename, yamlName, req.UpdateLog); err != nil {
2022-05-10 16:53:58 +08:00
log.NewError(req.OperationID, utils.GetSelfFuncName(), "UpdateAppVersion error", err.Error())
resp.ErrCode = http.StatusInternalServerError
resp.ErrMsg = err.Error()
c.JSON(http.StatusInternalServerError, resp)
return
}
log.NewInfo(req.OperationID, utils.GetSelfFuncName())
c.JSON(http.StatusOK, resp)
}
2022-08-10 19:31:57 +08:00
func version2Int(version string) (int, error) {
versions := strings.Split(version, ".")
s := strings.Join(versions, "")
versionInt, err := strconv.Atoi(s)
return versionInt, err
}
2022-05-10 16:53:58 +08:00
func GetDownloadURL(c *gin.Context) {
var (
2022-06-29 11:18:19 +08:00
req api.GetDownloadURLReq
resp api.GetDownloadURLResp
2022-05-10 16:53:58 +08:00
)
defer func() {
log.NewInfo(req.OperationID, utils.GetSelfFuncName(), "resp: ", resp)
}()
if err := c.Bind(&req); err != nil {
log.NewError("0", utils.GetSelfFuncName(), "BindJSON failed ", err.Error())
c.JSON(http.StatusBadRequest, gin.H{"errCode": 400, "errMsg": err.Error()})
return
}
log.NewInfo(req.OperationID, utils.GetSelfFuncName(), "req: ", req)
app, err := imdb.GetNewestVersion(req.Type)
if err != nil {
log.NewError(req.OperationID, utils.GetSelfFuncName(), "getNewestVersion failed", err.Error())
}
2022-05-10 17:23:28 +08:00
log.Debug(req.OperationID, utils.GetSelfFuncName(), "app: ", app)
2022-05-10 17:17:20 +08:00
if app != nil {
2022-08-10 19:31:57 +08:00
appVersion, err := version2Int(app.Version)
reqVersion, err := version2Int(req.Version)
if err != nil {
log.NewError(req.OperationID, utils.GetSelfFuncName(), err.Error(), "req version", req.Version, "app version", app.Version)
}
log.NewDebug(req.OperationID, utils.GetSelfFuncName(), "req version:", reqVersion, "app version:", appVersion)
if appVersion > reqVersion && app.Version != "" {
2022-05-10 17:17:20 +08:00
resp.Data.HasNewVersion = true
if app.ForceUpdate == true {
resp.Data.ForceUpdate = true
}
2022-05-10 18:22:18 +08:00
if app.YamlName != "" {
resp.Data.YamlURL = config.Config.Credential.Minio.Endpoint + "/" + config.Config.Credential.Minio.AppBucket + "/" + app.YamlName
}
2022-05-10 17:17:20 +08:00
resp.Data.FileURL = config.Config.Credential.Minio.Endpoint + "/" + config.Config.Credential.Minio.AppBucket + "/" + app.FileName
2022-05-11 10:19:58 +08:00
resp.Data.Version = app.Version
resp.Data.UpdateLog = app.UpdateLog
2022-05-10 17:17:20 +08:00
c.JSON(http.StatusOK, resp)
2022-05-10 17:23:28 +08:00
return
2022-05-10 17:17:20 +08:00
} else {
resp.Data.HasNewVersion = false
c.JSON(http.StatusOK, resp)
2022-05-10 17:23:28 +08:00
return
2022-05-10 16:53:58 +08:00
}
}
2022-05-10 17:17:20 +08:00
c.JSON(http.StatusBadRequest, gin.H{"errCode": 0, "errMsg": "not found app version"})
2022-05-10 16:53:58 +08:00
}