2
0

commands.go 4.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156
  1. package command
  2. import (
  3. "strings"
  4. "github.com/gravitl/netmaker/logger"
  5. "github.com/gravitl/netmaker/netclient/config"
  6. "github.com/gravitl/netmaker/netclient/daemon"
  7. "github.com/gravitl/netmaker/netclient/functions"
  8. "github.com/gravitl/netmaker/netclient/ncutils"
  9. )
  10. // JoinComms -- Join the message queue comms network if it doesn't have it
  11. // tries to ping if already found locally, if fail ping pull for best effort for communication
  12. func JoinComms(cfg *config.ClientConfig) error {
  13. commsCfg := &config.ClientConfig{}
  14. commsCfg.Server.AccessKey = cfg.Server.AccessKey
  15. commsCfg.Server.CoreDNSAddr = cfg.Server.CoreDNSAddr
  16. if commsCfg.ConfigFileExists() {
  17. return nil
  18. }
  19. commsCfg.ReadConfig()
  20. if len(commsCfg.Node.Name) == 0 {
  21. if err := functions.JoinNetwork(commsCfg, "", true); err != nil {
  22. return err
  23. }
  24. } else { // check if comms is currently reachable
  25. if err := functions.PingServer(commsCfg); err != nil {
  26. if err = Pull(commsCfg); err != nil {
  27. return err
  28. }
  29. }
  30. }
  31. return nil
  32. }
  33. // Join - join command to run from cli
  34. func Join(cfg *config.ClientConfig, privateKey string) error {
  35. var err error
  36. //join network
  37. err = functions.JoinNetwork(cfg, privateKey, false)
  38. if err != nil && !cfg.DebugOn {
  39. if !strings.Contains(err.Error(), "ALREADY_INSTALLED") {
  40. logger.Log(1, "error installing: ", err.Error())
  41. err = functions.LeaveNetwork(cfg.Network, true)
  42. if err != nil {
  43. err = functions.WipeLocal(cfg.Network)
  44. if err != nil {
  45. logger.Log(1, "error removing artifacts: ", err.Error())
  46. }
  47. }
  48. if cfg.Daemon != "off" {
  49. if ncutils.IsLinux() {
  50. err = daemon.RemoveSystemDServices()
  51. }
  52. if err != nil {
  53. logger.Log(1, "error removing services: ", err.Error())
  54. }
  55. if ncutils.IsFreeBSD() {
  56. daemon.RemoveFreebsdDaemon()
  57. }
  58. }
  59. } else {
  60. logger.Log(0, "success")
  61. }
  62. if err != nil && strings.Contains(err.Error(), "ALREADY_INSTALLED") {
  63. logger.Log(0, err.Error())
  64. err = nil
  65. }
  66. return err
  67. }
  68. logger.Log(1, "joined ", cfg.Network)
  69. /*
  70. if ncutils.IsWindows() {
  71. logger.Log("setting up WireGuard app", 0)
  72. time.Sleep(time.Second >> 1)
  73. functions.Pull(cfg.Network, true)
  74. }
  75. */
  76. return err
  77. }
  78. // Leave - runs the leave command from cli
  79. func Leave(cfg *config.ClientConfig, force bool) error {
  80. err := functions.LeaveNetwork(cfg.Network, force)
  81. if err != nil {
  82. logger.Log(1, "error attempting to leave network "+cfg.Network)
  83. } else {
  84. logger.Log(0, "success")
  85. }
  86. //nets, err := ncutils.GetSystemNetworks()
  87. //if err == nil && len(nets) == 1 {
  88. //if nets[0] == cfg.Node.CommID {
  89. //logger.Log(1, "detected comms as remaining network, removing...")
  90. //err = functions.LeaveNetwork(nets[0], true)
  91. //}
  92. //}
  93. return err
  94. }
  95. // Pull - runs pull command from cli
  96. func Pull(cfg *config.ClientConfig) error {
  97. var err error
  98. if cfg.Network == "all" {
  99. logger.Log(0, "No network selected. Running Pull for all networks.")
  100. networks, err := ncutils.GetSystemNetworks()
  101. if err != nil {
  102. logger.Log(1, "Error retrieving networks. Exiting.")
  103. return err
  104. }
  105. for _, network := range networks {
  106. _, err = functions.Pull(network, true)
  107. if err != nil {
  108. logger.Log(1, "Error pulling network config for network: ", network, "\n", err.Error())
  109. } else {
  110. logger.Log(1, "pulled network config for "+network)
  111. }
  112. }
  113. err = nil
  114. } else {
  115. _, err = functions.Pull(cfg.Network, true)
  116. }
  117. logger.Log(1, "reset network and peer configs")
  118. if err == nil {
  119. logger.Log(1, "reset network and peer configs")
  120. logger.Log(1, "success")
  121. } else {
  122. logger.Log(0, "error occurred pulling configs from server")
  123. }
  124. return err
  125. }
  126. // List - runs list command from cli
  127. func List(cfg config.ClientConfig) error {
  128. err := functions.List(cfg.Network)
  129. return err
  130. }
  131. // Uninstall - runs uninstall command from cli
  132. func Uninstall() error {
  133. logger.Log(0, "uninstalling netclient...")
  134. err := functions.Uninstall()
  135. logger.Log(0, "uninstalled netclient")
  136. return err
  137. }
  138. // Daemon - runs the daemon
  139. func Daemon() error {
  140. err := functions.Daemon()
  141. return err
  142. }
  143. func Register(cfg *config.ClientConfig, key string) error {
  144. return functions.Register(cfg, key)
  145. }