|
12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061 |
- package http
-
- import (
- "net/http"
-
- "github.com/gin-gonic/gin"
- "gitlink.org.cn/cloudream/common/consts/errorcode"
- "gitlink.org.cn/cloudream/common/pkgs/logger"
- cdssdk "gitlink.org.cn/cloudream/common/sdks/storage"
- )
-
- type BucketService struct {
- *Server
- }
-
- func (s *Server) Bucket() *BucketService {
- return &BucketService{
- Server: s,
- }
- }
-
- func (s *BucketService) Create(ctx *gin.Context) {
- log := logger.WithField("HTTP", "Bucket.Create")
-
- var req cdssdk.BucketCreateReq
- if err := ctx.ShouldBindJSON(&req); err != nil {
- log.Warnf("binding body: %s", err.Error())
- ctx.JSON(http.StatusBadRequest, Failed(errorcode.BadArgument, "missing argument or invalid argument"))
- return
- }
-
- bucketID, err := s.svc.BucketSvc().CreateBucket(req.UserID, req.BucketName)
- if err != nil {
- log.Warnf("creating bucket: %s", err.Error())
- ctx.JSON(http.StatusOK, Failed(errorcode.OperationFailed, "create bucket failed"))
- return
- }
-
- ctx.JSON(http.StatusOK, OK(cdssdk.BucketCreateResp{
- BucketID: bucketID,
- }))
- }
-
- func (s *BucketService) Delete(ctx *gin.Context) {
- log := logger.WithField("HTTP", "Bucket.Delete")
-
- var req cdssdk.BucketDeleteReq
- if err := ctx.ShouldBindJSON(&req); err != nil {
- log.Warnf("binding body: %s", err.Error())
- ctx.JSON(http.StatusBadRequest, Failed(errorcode.BadArgument, "missing argument or invalid argument"))
- return
- }
-
- if err := s.svc.BucketSvc().DeleteBucket(req.UserID, req.BucketID); err != nil {
- log.Warnf("deleting bucket: %s", err.Error())
- ctx.JSON(http.StatusOK, Failed(errorcode.OperationFailed, "delete bucket failed"))
- return
- }
-
- ctx.JSON(http.StatusOK, OK(nil))
- }
|