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.

plan_builder.go 1.9 kB

2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104
  1. package plans
  2. import (
  3. "fmt"
  4. "github.com/google/uuid"
  5. cdssdk "gitlink.org.cn/cloudream/common/sdks/storage"
  6. "gitlink.org.cn/cloudream/storage/common/pkgs/ioswitch"
  7. )
  8. type StreamInfo struct {
  9. ID ioswitch.StreamID
  10. }
  11. type PlanBuilder struct {
  12. streams []*StreamInfo
  13. agentPlans map[cdssdk.NodeID]*AgentPlanBuilder
  14. }
  15. func (b *PlanBuilder) Build() (*ComposedPlan, error) {
  16. planID := uuid.NewString()
  17. var agentPlans []AgentPlan
  18. for _, b := range b.agentPlans {
  19. plan, err := b.Build(ioswitch.PlanID(planID))
  20. if err != nil {
  21. return nil, err
  22. }
  23. agentPlans = append(agentPlans, plan)
  24. }
  25. return &ComposedPlan{
  26. ID: ioswitch.PlanID(planID),
  27. AgentPlans: agentPlans,
  28. }, nil
  29. }
  30. func (b *PlanBuilder) newStream() *StreamInfo {
  31. str := &StreamInfo{
  32. ID: ioswitch.StreamID(fmt.Sprintf("%d", len(b.streams)+1)),
  33. }
  34. b.streams = append(b.streams, str)
  35. return str
  36. }
  37. func NewPlanBuilder() PlanBuilder {
  38. return PlanBuilder{
  39. agentPlans: make(map[cdssdk.NodeID]*AgentPlanBuilder),
  40. }
  41. }
  42. func (b *PlanBuilder) FromExecutor() *FromExecutorStream {
  43. return &FromExecutorStream{
  44. owner: b,
  45. info: b.newStream(),
  46. }
  47. }
  48. func (b *PlanBuilder) AtAgent(node cdssdk.Node) *AgentPlanBuilder {
  49. agtPlan, ok := b.agentPlans[node.NodeID]
  50. if !ok {
  51. agtPlan = &AgentPlanBuilder{
  52. owner: b,
  53. node: node,
  54. }
  55. b.agentPlans[node.NodeID] = agtPlan
  56. }
  57. return agtPlan
  58. }
  59. type FromExecutorStream struct {
  60. owner *PlanBuilder
  61. info *StreamInfo
  62. toNode *cdssdk.Node
  63. }
  64. func (s *FromExecutorStream) ToNode(node cdssdk.Node) *AgentStream {
  65. s.toNode = &node
  66. return &AgentStream{
  67. owner: s.owner.AtAgent(node),
  68. info: s.info,
  69. }
  70. }
  71. type ToExecutorStream struct {
  72. info *StreamInfo
  73. fromNode *cdssdk.Node
  74. }
  75. type MultiStream struct {
  76. Streams []*AgentStream
  77. }
  78. func (m *MultiStream) Count() int {
  79. return len(m.Streams)
  80. }
  81. func (m *MultiStream) Stream(index int) *AgentStream {
  82. return m.Streams[index]
  83. }

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