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

54 lines
1.3 KiB

6 years ago
6 years ago
6 years ago
  1. package notification
  2. import (
  3. "github.com/chrislusf/seaweedfs/weed/glog"
  4. "github.com/chrislusf/seaweedfs/weed/util"
  5. "github.com/golang/protobuf/proto"
  6. "github.com/spf13/viper"
  7. )
  8. type MessageQueue interface {
  9. // GetName gets the name to locate the configuration in filer.toml file
  10. GetName() string
  11. // Initialize initializes the file store
  12. Initialize(configuration util.Configuration) error
  13. SendMessage(key string, message proto.Message) error
  14. }
  15. var (
  16. MessageQueues []MessageQueue
  17. Queue MessageQueue
  18. )
  19. func LoadConfiguration(config *viper.Viper) {
  20. if config == nil {
  21. return
  22. }
  23. enabledQueue := ""
  24. for _, queue := range MessageQueues {
  25. if config.GetBool(queue.GetName() + ".enabled") {
  26. if enabledQueue == "" {
  27. enabledQueue = queue.GetName()
  28. } else {
  29. glog.Fatalf("Notification message queue is enabled for both %s and %s", enabledQueue, queue.GetName())
  30. }
  31. }
  32. }
  33. for _, queue := range MessageQueues {
  34. if config.GetBool(queue.GetName() + ".enabled") {
  35. viperSub := config.Sub(queue.GetName())
  36. if err := queue.Initialize(viperSub); err != nil {
  37. glog.Fatalf("Failed to initialize notification for %s: %+v",
  38. queue.GetName(), err)
  39. }
  40. Queue = queue
  41. glog.V(0).Infof("Configure notification message queue for %s", queue.GetName())
  42. return
  43. }
  44. }
  45. }