commands.go 4.3 KB

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