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 3.0 kB

2 years ago
2 years ago
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990
  1. package services
  2. import (
  3. "fmt"
  4. "gitlink.org.cn/cloudream/client/internal/config"
  5. "gitlink.org.cn/cloudream/common/pkg/distlock/reqbuilder"
  6. agtcli "gitlink.org.cn/cloudream/rabbitmq/client/agent"
  7. agtmsg "gitlink.org.cn/cloudream/rabbitmq/message/agent"
  8. coormsg "gitlink.org.cn/cloudream/rabbitmq/message/coordinator"
  9. )
  10. type StorageService struct {
  11. *Service
  12. }
  13. func (svc *Service) StorageSvc() *StorageService {
  14. return &StorageService{Service: svc}
  15. }
  16. func (svc *StorageService) MoveObjectToStorage(userID int, objectID int, storageID int) error {
  17. mutex, err := reqbuilder.NewBuilder().
  18. Metadata().
  19. // 用于判断用户是否有Storage权限
  20. UserStorage().ReadOne(objectID, storageID).
  21. // 用于判断用户是否有对象权限
  22. UserBucket().ReadAny().
  23. // 用于读取对象信息
  24. Object().ReadOne(objectID).
  25. // 用于查询Rep配置
  26. ObjectRep().ReadOne(objectID).
  27. // 用于查询Block配置
  28. ObjectBlock().ReadAny().
  29. // 用于创建Move记录
  30. StorageObject().CreateOne(storageID, userID, objectID).
  31. Storage().
  32. // 用于创建对象文件
  33. CreateOneObject(storageID, userID, objectID).
  34. MutexLock(svc.distlock)
  35. if err != nil {
  36. return fmt.Errorf("acquire locks failed, err: %w", err)
  37. }
  38. defer mutex.Unlock()
  39. // 先向协调端请求文件相关的元数据
  40. preMoveResp, err := svc.coordinator.PreMoveObjectToStorage(coormsg.NewPreMoveObjectToStorageBody(objectID, storageID, userID))
  41. if err != nil {
  42. return fmt.Errorf("request to coordinator failed, err: %w", err)
  43. }
  44. if preMoveResp.IsFailed() {
  45. return fmt.Errorf("coordinator PreMoveObjectToStorage failed, code: %s, message: %s", preMoveResp.ErrorCode, preMoveResp.ErrorMessage)
  46. }
  47. // 然后向代理端发送移动文件的请求
  48. agentClient, err := agtcli.NewClient(preMoveResp.Body.NodeID, &config.Cfg().RabbitMQ)
  49. if err != nil {
  50. return fmt.Errorf("create agent client to %d failed, err: %w", preMoveResp.Body.NodeID, err)
  51. }
  52. defer agentClient.Close()
  53. agentMoveResp, err := agentClient.MoveObjectToStorage(
  54. agtmsg.NewMoveObjectToStorageBody(preMoveResp.Body.Directory,
  55. objectID,
  56. userID,
  57. preMoveResp.Body.FileSize,
  58. preMoveResp.Body.Redundancy,
  59. preMoveResp.Body.RedundancyData,
  60. ))
  61. if err != nil {
  62. return fmt.Errorf("request to agent %d failed, err: %w", preMoveResp.Body.NodeID, err)
  63. }
  64. if agentMoveResp.IsFailed() {
  65. return fmt.Errorf("agent %d operation failed, code: %s, messsage: %s", preMoveResp.Body.NodeID, agentMoveResp.ErrorCode, agentMoveResp.ErrorMessage)
  66. }
  67. moveResp, err := svc.coordinator.MoveObjectToStorage(coormsg.NewMoveObjectToStorageBody(objectID, storageID, userID))
  68. if err != nil {
  69. return fmt.Errorf("request to coordinator failed, err: %w", err)
  70. }
  71. if preMoveResp.IsFailed() {
  72. return fmt.Errorf("coordinator MoveObjectToStorage failed, code: %s, message: %s", moveResp.ErrorCode, moveResp.ErrorMessage)
  73. }
  74. return nil
  75. }
  76. func (svc *StorageService) DeleteStorageObject(userID int, objectID int, storageID int) error {
  77. // TODO
  78. panic("not implement yet")
  79. }

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