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.

node.go 1.4 kB

2 years ago
12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364
  1. package coordinator
  2. import (
  3. "gitlink.org.cn/cloudream/common/pkgs/mq"
  4. "gitlink.org.cn/cloudream/storage/common/pkgs/db/model"
  5. )
  6. type NodeService interface {
  7. GetUserNodes(msg *GetUserNodes) (*GetUserNodesResp, *mq.CodeMessage)
  8. GetNodes(msg *GetNodes) (*GetNodesResp, *mq.CodeMessage)
  9. }
  10. // 查询用户可用的节点
  11. var _ = Register(Service.GetUserNodes)
  12. type GetUserNodes struct {
  13. mq.MessageBodyBase
  14. UserID int64 `json:"userID"`
  15. }
  16. type GetUserNodesResp struct {
  17. mq.MessageBodyBase
  18. Nodes []model.Node `json:"nodes"`
  19. }
  20. func NewGetUserNodes(userID int64) *GetUserNodes {
  21. return &GetUserNodes{
  22. UserID: userID,
  23. }
  24. }
  25. func NewGetUserNodesResp(nodes []model.Node) *GetUserNodesResp {
  26. return &GetUserNodesResp{
  27. Nodes: nodes,
  28. }
  29. }
  30. func (client *Client) GetUserNodes(msg *GetUserNodes) (*GetUserNodesResp, error) {
  31. return mq.Request(Service.GetUserNodes, client.rabbitCli, msg)
  32. }
  33. // 获取指定节点的信息
  34. var _ = Register(Service.GetNodes)
  35. type GetNodes struct {
  36. mq.MessageBodyBase
  37. NodeIDs []int64 `json:"nodeIDs"`
  38. }
  39. type GetNodesResp struct {
  40. mq.MessageBodyBase
  41. Nodes []model.Node `json:"nodes"`
  42. }
  43. func NewGetNodes(nodeIDs []int64) *GetNodes {
  44. return &GetNodes{
  45. NodeIDs: nodeIDs,
  46. }
  47. }
  48. func NewGetNodesResp(nodes []model.Node) *GetNodesResp {
  49. return &GetNodesResp{
  50. Nodes: nodes,
  51. }
  52. }
  53. func (client *Client) GetNodes(msg *GetNodes) (*GetNodesResp, error) {
  54. return mq.Request(Service.GetNodes, client.rabbitCli, msg)
  55. }

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