commands.go 4.2 KB

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