|
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206 |
- package http
-
- import (
- "fmt"
- "net/http"
-
- "github.com/gin-gonic/gin"
- "gitlink.org.cn/cloudream/common/pkgs/logger"
- "gitlink.org.cn/cloudream/jcs-pub/client/internal/http/types"
- cliapi "gitlink.org.cn/cloudream/jcs-pub/client/sdk/api/v1"
- "gitlink.org.cn/cloudream/jcs-pub/common/ecode"
- jcstypes "gitlink.org.cn/cloudream/jcs-pub/common/types"
- )
-
- type UserSpaceService struct {
- *Server
- }
-
- func (s *Server) UserSpace() *UserSpaceService {
- return &UserSpaceService{
- Server: s,
- }
- }
-
- func (s *UserSpaceService) DownloadPackage(ctx *gin.Context) {
- log := logger.WithField("HTTP", "UserSpace.DownloadPackage")
-
- var req cliapi.UserSpaceDownloadPackageReq
- if err := ctx.ShouldBindJSON(&req); err != nil {
- log.Warnf("binding body: %s", err.Error())
- ctx.JSON(http.StatusBadRequest, types.Failed(ecode.BadArgument, "missing argument or invalid argument"))
- return
- }
-
- err := s.svc.UserSpaceSvc().DownloadPackage(req.PackageID, req.UserSpaceID, req.RootPath)
- if err != nil {
- log.Warnf("downloading package: %s", err.Error())
- ctx.JSON(http.StatusOK, types.Failed(ecode.OperationFailed, "%v", err))
- return
- }
-
- ctx.JSON(http.StatusOK, types.OK(cliapi.UserSpaceDownloadPackageResp{}))
- }
-
- func (s *UserSpaceService) CreatePackage(ctx *gin.Context) {
- log := logger.WithField("HTTP", "UserSpace.CreatePackage")
-
- var req cliapi.UserSpaceCreatePackageReq
- if err := ctx.ShouldBindJSON(&req); err != nil {
- log.Warnf("binding body: %s", err.Error())
- ctx.JSON(http.StatusBadRequest, types.Failed(ecode.BadArgument, "missing argument or invalid argument"))
- return
- }
-
- pkg, err := s.svc.Uploader.UserSpaceUpload(req.UserSpaceID, jcstypes.PathFromJcsPathString(req.Path), req.BucketID, req.Name, req.SpaceAffinity)
- if err != nil {
- log.Warnf("userspace create package: %s", err.Error())
- ctx.JSON(http.StatusOK, types.Failed(ecode.OperationFailed, fmt.Sprintf("userspace create package: %v", err)))
- return
- }
-
- ctx.JSON(http.StatusOK, types.OK(cliapi.UserSpaceCreatePackageResp{
- Package: *pkg,
- }))
- }
-
- func (s *UserSpaceService) Get(ctx *gin.Context) {
- log := logger.WithField("HTTP", "UserSpace.Get")
-
- var req cliapi.UserSpaceGet
- if err := ctx.ShouldBindQuery(&req); err != nil {
- log.Warnf("binding query: %s", err.Error())
- ctx.JSON(http.StatusBadRequest, types.Failed(ecode.BadArgument, "missing argument or invalid argument"))
- return
- }
-
- info, err := s.svc.UserSpaceSvc().Get(req.UserSpaceID)
- if err != nil {
- log.Warnf("getting info: %s", err.Error())
- ctx.JSON(http.StatusOK, types.Failed(ecode.OperationFailed, "get userspace inf failed"))
- return
- }
-
- ctx.JSON(http.StatusOK, types.OK(cliapi.UserSpaceGetResp{
- UserSpace: info,
- }))
- }
-
- func (s *UserSpaceService) GetByName(ctx *gin.Context) {
- log := logger.WithField("HTTP", "UserSpace.GetByName")
-
- var req cliapi.UserSpaceGetByName
- if err := ctx.ShouldBindQuery(&req); err != nil {
- log.Warnf("binding query: %s", err.Error())
- ctx.JSON(http.StatusBadRequest, types.Failed(ecode.BadArgument, "missing argument or invalid argument"))
- return
- }
-
- info, err := s.svc.UserSpaceSvc().GetByName(req.Name)
- if err != nil {
- log.Warnf("getting info: %s", err.Error())
- ctx.JSON(http.StatusOK, types.Failed(ecode.OperationFailed, "get userspace info failed"))
- return
- }
-
- ctx.JSON(http.StatusOK, types.OK(cliapi.UserSpaceGetByNameResp{
- UserSpace: info,
- }))
- }
-
- func (s *UserSpaceService) GetAll(ctx *gin.Context) {
- log := logger.WithField("HTTP", "UserSpace.GetAll")
-
- allInfos, err := s.svc.UserSpaceSvc().GetAll()
- if err != nil {
- log.Warnf("getting info: %s", err.Error())
- ctx.JSON(http.StatusOK, types.Failed(ecode.OperationFailed, "get userspaces info failed"))
- return
- }
-
- ctx.JSON(http.StatusOK, types.OK(cliapi.UserSpaceGetAllResp{
- UserSpaces: allInfos,
- }))
- }
-
- func (s *UserSpaceService) Create(ctx *gin.Context) {
- log := logger.WithField("HTTP", "UserSpace.Create")
-
- req, err := types.ShouldBindJSONEx[cliapi.UserSpaceCreate](ctx)
- if err != nil {
- log.Warnf("binding body: %s", err.Error())
- ctx.JSON(http.StatusBadRequest, types.Failed(ecode.BadArgument, "missing argument or invalid argument"))
- return
- }
-
- resp, cerr := s.svc.UserSpaceSvc().Create(req)
- if cerr != nil {
- log.Warnf("creating userspace: %v", cerr)
- ctx.JSON(http.StatusOK, types.Failed(cerr.Code, cerr.Message))
- return
- }
-
- ctx.JSON(http.StatusOK, types.OK(resp))
- }
-
- func (s *UserSpaceService) Update(ctx *gin.Context) {
- log := logger.WithField("HTTP", "UserSpace.Update")
-
- var req cliapi.UserSpaceUpdate
- req, err := types.ShouldBindJSONEx[cliapi.UserSpaceUpdate](ctx)
- if err != nil {
- log.Warnf("binding body: %s", err.Error())
- ctx.JSON(http.StatusBadRequest, types.Failed(ecode.BadArgument, "missing argument or invalid argument"))
- return
- }
-
- resp, cerr := s.svc.UserSpaceSvc().Update(req)
- if cerr != nil {
- log.Warnf("updating userspace: %v", cerr)
- ctx.JSON(http.StatusOK, types.Failed(cerr.Code, cerr.Message))
- return
- }
-
- ctx.JSON(http.StatusOK, types.OK(resp))
- }
-
- func (s *UserSpaceService) Delete(ctx *gin.Context) {
- log := logger.WithField("HTTP", "UserSpace.Delete")
-
- var req cliapi.UserSpaceDelete
- if err := ctx.ShouldBindJSON(&req); err != nil {
- log.Warnf("binding body: %s", err.Error())
- ctx.JSON(http.StatusBadRequest, types.Failed(ecode.BadArgument, "missing argument or invalid argument"))
- return
- }
-
- resp, cerr := s.svc.UserSpaceSvc().Delete(req)
- if cerr != nil {
- log.Warnf("deleting userspace: %v", cerr)
- ctx.JSON(http.StatusOK, types.Failed(cerr.Code, cerr.Message))
- return
- }
-
- ctx.JSON(http.StatusOK, types.OK(resp))
- }
-
- func (s *UserSpaceService) Test(ctx *gin.Context) {
- log := logger.WithField("HTTP", "UserSpace.Test")
-
- var req cliapi.UserSpaceTest
- req, err := types.ShouldBindJSONEx[cliapi.UserSpaceTest](ctx)
- if err != nil {
- log.Warnf("binding body: %s", err.Error())
- ctx.JSON(http.StatusBadRequest, types.Failed(ecode.BadArgument, "missing argument or invalid argument"))
- return
- }
-
- resp, cerr := s.svc.UserSpaceSvc().Test(req)
- if cerr != nil {
- log.Warnf("testing userspace: %v", cerr)
- ctx.JSON(http.StatusOK, types.Failed(cerr.Code, cerr.Message))
- return
- }
-
- ctx.JSON(http.StatusOK, types.OK(resp))
- }
|