update.go 2.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596
  1. package swarm
  2. import (
  3. "fmt"
  4. "time"
  5. "golang.org/x/net/context"
  6. "github.com/docker/docker/api/client"
  7. "github.com/docker/docker/cli"
  8. "github.com/docker/engine-api/types/swarm"
  9. "github.com/spf13/cobra"
  10. "github.com/spf13/pflag"
  11. )
  12. type updateOptions struct {
  13. autoAccept AutoAcceptOption
  14. secret string
  15. taskHistoryLimit int64
  16. dispatcherHeartbeat time.Duration
  17. }
  18. func newUpdateCommand(dockerCli *client.DockerCli) *cobra.Command {
  19. opts := updateOptions{autoAccept: NewAutoAcceptOption()}
  20. var flags *pflag.FlagSet
  21. cmd := &cobra.Command{
  22. Use: "update",
  23. Short: "update the Swarm.",
  24. Args: cli.NoArgs,
  25. RunE: func(cmd *cobra.Command, args []string) error {
  26. return runUpdate(dockerCli, flags, opts)
  27. },
  28. }
  29. flags = cmd.Flags()
  30. flags.Var(&opts.autoAccept, "auto-accept", "Auto acceptance policy (worker, manager or none)")
  31. flags.StringVar(&opts.secret, "secret", "", "Set secret value needed to accept nodes into cluster")
  32. flags.Int64Var(&opts.taskHistoryLimit, "task-history-limit", 10, "Task history retention limit")
  33. flags.DurationVar(&opts.dispatcherHeartbeat, "dispatcher-heartbeat", time.Duration(5*time.Second), "Dispatcher heartbeat period")
  34. return cmd
  35. }
  36. func runUpdate(dockerCli *client.DockerCli, flags *pflag.FlagSet, opts updateOptions) error {
  37. client := dockerCli.Client()
  38. ctx := context.Background()
  39. swarm, err := client.SwarmInspect(ctx)
  40. if err != nil {
  41. return err
  42. }
  43. err = mergeSwarm(&swarm, flags)
  44. if err != nil {
  45. return err
  46. }
  47. err = client.SwarmUpdate(ctx, swarm.Version, swarm.Spec)
  48. if err != nil {
  49. return err
  50. }
  51. fmt.Println("Swarm updated.")
  52. return nil
  53. }
  54. func mergeSwarm(swarm *swarm.Swarm, flags *pflag.FlagSet) error {
  55. spec := &swarm.Spec
  56. if flags.Changed("auto-accept") {
  57. value := flags.Lookup("auto-accept").Value.(*AutoAcceptOption)
  58. if len(spec.AcceptancePolicy.Policies) > 0 {
  59. spec.AcceptancePolicy.Policies = value.Policies(spec.AcceptancePolicy.Policies[0].Secret)
  60. } else {
  61. spec.AcceptancePolicy.Policies = value.Policies("")
  62. }
  63. }
  64. if flags.Changed("secret") {
  65. secret, _ := flags.GetString("secret")
  66. for _, policy := range spec.AcceptancePolicy.Policies {
  67. policy.Secret = secret
  68. }
  69. }
  70. if flags.Changed("task-history-limit") {
  71. spec.Orchestration.TaskHistoryRetentionLimit, _ = flags.GetInt64("task-history-limit")
  72. }
  73. if flags.Changed("dispatcher-heartbeat") {
  74. if v, err := flags.GetDuration("dispatcher-heartbeat"); err == nil {
  75. spec.Dispatcher.HeartbeatPeriod = uint64(v.Nanoseconds())
  76. }
  77. }
  78. return nil
  79. }