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.

metadata_node.go 2.0 kB

2 years ago
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263
  1. package reqbuilder
  2. import (
  3. "gitlink.org.cn/cloudream/common/pkgs/distlock"
  4. "gitlink.org.cn/cloudream/storage/common/pkgs/distlock/lockprovider"
  5. )
  6. type MetadataNodeLockReqBuilder struct {
  7. *MetadataLockReqBuilder
  8. }
  9. func (b *MetadataLockReqBuilder) Node() *MetadataNodeLockReqBuilder {
  10. return &MetadataNodeLockReqBuilder{MetadataLockReqBuilder: b}
  11. }
  12. func (b *MetadataNodeLockReqBuilder) ReadOne(nodeID int64) *MetadataNodeLockReqBuilder {
  13. b.locks = append(b.locks, distlock.Lock{
  14. Path: b.makePath("Node"),
  15. Name: lockprovider.METADATA_ELEMENT_READ_LOCK,
  16. Target: *lockprovider.NewStringLockTarget().Add(nodeID),
  17. })
  18. return b
  19. }
  20. func (b *MetadataNodeLockReqBuilder) WriteOne(nodeID int64) *MetadataNodeLockReqBuilder {
  21. b.locks = append(b.locks, distlock.Lock{
  22. Path: b.makePath("Node"),
  23. Name: lockprovider.METADATA_ELEMENT_WRITE_LOCK,
  24. Target: *lockprovider.NewStringLockTarget().Add(nodeID),
  25. })
  26. return b
  27. }
  28. func (b *MetadataNodeLockReqBuilder) CreateOne() *MetadataNodeLockReqBuilder {
  29. b.locks = append(b.locks, distlock.Lock{
  30. Path: b.makePath("Node"),
  31. Name: lockprovider.METADATA_ELEMENT_CREATE_LOCK,
  32. Target: *lockprovider.NewStringLockTarget(),
  33. })
  34. return b
  35. }
  36. func (b *MetadataNodeLockReqBuilder) ReadAny() *MetadataNodeLockReqBuilder {
  37. b.locks = append(b.locks, distlock.Lock{
  38. Path: b.makePath("Node"),
  39. Name: lockprovider.METADATA_SET_READ_LOCK,
  40. Target: *lockprovider.NewStringLockTarget(),
  41. })
  42. return b
  43. }
  44. func (b *MetadataNodeLockReqBuilder) WriteAny() *MetadataNodeLockReqBuilder {
  45. b.locks = append(b.locks, distlock.Lock{
  46. Path: b.makePath("Node"),
  47. Name: lockprovider.METADATA_SET_WRITE_LOCK,
  48. Target: *lockprovider.NewStringLockTarget(),
  49. })
  50. return b
  51. }
  52. func (b *MetadataNodeLockReqBuilder) CreateAny() *MetadataNodeLockReqBuilder {
  53. b.locks = append(b.locks, distlock.Lock{
  54. Path: b.makePath("Node"),
  55. Name: lockprovider.METADATA_SET_CREATE_LOCK,
  56. Target: *lockprovider.NewStringLockTarget(),
  57. })
  58. return b
  59. }

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