You can not select more than 25 topics Topics must start with a chinese character,a letter or number, can include dashes ('-') and can be up to 35 characters long.

storage.go 4.8 kB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162
  1. package http
  2. import (
  3. "net/http"
  4. "time"
  5. "github.com/gin-gonic/gin"
  6. "gitlink.org.cn/cloudream/common/consts/errorcode"
  7. "gitlink.org.cn/cloudream/common/pkgs/logger"
  8. cdssdk "gitlink.org.cn/cloudream/common/sdks/storage"
  9. )
  10. type StorageService struct {
  11. *Server
  12. }
  13. func (s *Server) Storage() *StorageService {
  14. return &StorageService{
  15. Server: s,
  16. }
  17. }
  18. type StorageLoadPackageReq struct {
  19. UserID *cdssdk.UserID `json:"userID" binding:"required"`
  20. PackageID *cdssdk.PackageID `json:"packageID" binding:"required"`
  21. StorageID *cdssdk.StorageID `json:"storageID" binding:"required"`
  22. }
  23. type StorageLoadPackageResp struct {
  24. cdssdk.StorageLoadPackageResp
  25. }
  26. func (s *StorageService) LoadPackage(ctx *gin.Context) {
  27. log := logger.WithField("HTTP", "Storage.LoadPackage")
  28. var req StorageLoadPackageReq
  29. if err := ctx.ShouldBindJSON(&req); err != nil {
  30. log.Warnf("binding body: %s", err.Error())
  31. ctx.JSON(http.StatusBadRequest, Failed(errorcode.BadArgument, "missing argument or invalid argument"))
  32. return
  33. }
  34. nodeID, taskID, err := s.svc.StorageSvc().StartStorageLoadPackage(*req.UserID, *req.PackageID, *req.StorageID)
  35. if err != nil {
  36. log.Warnf("start storage load package: %s", err.Error())
  37. ctx.JSON(http.StatusOK, Failed(errorcode.OperationFailed, "storage load package failed"))
  38. return
  39. }
  40. for {
  41. complete, fullPath, err := s.svc.StorageSvc().WaitStorageLoadPackage(nodeID, taskID, time.Second*10)
  42. if complete {
  43. if err != nil {
  44. log.Warnf("loading complete with: %s", err.Error())
  45. ctx.JSON(http.StatusOK, Failed(errorcode.OperationFailed, "storage load package failed"))
  46. return
  47. }
  48. ctx.JSON(http.StatusOK, OK(StorageLoadPackageResp{
  49. StorageLoadPackageResp: cdssdk.StorageLoadPackageResp{
  50. FullPath: fullPath,
  51. },
  52. }))
  53. return
  54. }
  55. if err != nil {
  56. log.Warnf("wait loadding: %s", err.Error())
  57. ctx.JSON(http.StatusOK, Failed(errorcode.OperationFailed, "storage load package failed"))
  58. return
  59. }
  60. }
  61. }
  62. type StorageCreatePackageReq struct {
  63. UserID *cdssdk.UserID `json:"userID" binding:"required"`
  64. StorageID *cdssdk.StorageID `json:"storageID" binding:"required"`
  65. Path string `json:"path" binding:"required"`
  66. BucketID *cdssdk.BucketID `json:"bucketID" binding:"required"`
  67. Name string `json:"name" binding:"required"`
  68. NodeAffinity *cdssdk.NodeID `json:"nodeAffinity"`
  69. }
  70. type StorageCreatePackageResp struct {
  71. PackageID cdssdk.PackageID `json:"packageID"`
  72. }
  73. func (s *StorageService) CreatePackage(ctx *gin.Context) {
  74. log := logger.WithField("HTTP", "Storage.CreatePackage")
  75. var req StorageCreatePackageReq
  76. if err := ctx.ShouldBindJSON(&req); err != nil {
  77. log.Warnf("binding body: %s", err.Error())
  78. ctx.JSON(http.StatusBadRequest, Failed(errorcode.BadArgument, "missing argument or invalid argument"))
  79. return
  80. }
  81. nodeID, taskID, err := s.svc.StorageSvc().StartStorageCreatePackage(
  82. *req.UserID, *req.BucketID, req.Name, *req.StorageID, req.Path, req.NodeAffinity)
  83. if err != nil {
  84. log.Warnf("start storage create package: %s", err.Error())
  85. ctx.JSON(http.StatusOK, Failed(errorcode.OperationFailed, "storage create package failed"))
  86. return
  87. }
  88. for {
  89. complete, packageID, err := s.svc.StorageSvc().WaitStorageCreatePackage(nodeID, taskID, time.Second*10)
  90. if complete {
  91. if err != nil {
  92. log.Warnf("creating complete with: %s", err.Error())
  93. ctx.JSON(http.StatusOK, Failed(errorcode.OperationFailed, "storage create package failed"))
  94. return
  95. }
  96. ctx.JSON(http.StatusOK, OK(StorageCreatePackageResp{
  97. PackageID: packageID,
  98. }))
  99. return
  100. }
  101. if err != nil {
  102. log.Warnf("wait creating: %s", err.Error())
  103. ctx.JSON(http.StatusOK, Failed(errorcode.OperationFailed, "storage create package failed"))
  104. return
  105. }
  106. }
  107. }
  108. type StorageGetInfoReq struct {
  109. UserID *cdssdk.UserID `form:"userID" binding:"required"`
  110. StorageID *cdssdk.StorageID `form:"storageID" binding:"required"`
  111. }
  112. type StorageGetInfoResp struct {
  113. cdssdk.StorageGetInfoResp
  114. }
  115. func (s *StorageService) GetInfo(ctx *gin.Context) {
  116. log := logger.WithField("HTTP", "Storage.GetInfo")
  117. var req StorageGetInfoReq
  118. if err := ctx.ShouldBindQuery(&req); err != nil {
  119. log.Warnf("binding query: %s", err.Error())
  120. ctx.JSON(http.StatusBadRequest, Failed(errorcode.BadArgument, "missing argument or invalid argument"))
  121. return
  122. }
  123. info, err := s.svc.StorageSvc().GetInfo(*req.UserID, *req.StorageID)
  124. if err != nil {
  125. log.Warnf("getting info: %s", err.Error())
  126. ctx.JSON(http.StatusOK, Failed(errorcode.OperationFailed, "get storage inf failed"))
  127. return
  128. }
  129. ctx.JSON(http.StatusOK, OK(StorageGetInfoResp{
  130. StorageGetInfoResp: cdssdk.StorageGetInfoResp{
  131. Name: info.Name,
  132. NodeID: info.NodeID,
  133. Directory: info.Directory,
  134. },
  135. }))
  136. }

本项目旨在将云际存储公共基础设施化,使个人及企业可低门槛使用高效的云际存储服务(安装开箱即用云际存储客户端即可,无需关注其他组件的部署),同时支持用户灵活便捷定制云际存储的功能细节。