commands.go 3.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144
  1. package command
  2. import (
  3. "crypto/ed25519"
  4. "crypto/rand"
  5. "strings"
  6. "github.com/gravitl/netmaker/logger"
  7. "github.com/gravitl/netmaker/netclient/config"
  8. "github.com/gravitl/netmaker/netclient/daemon"
  9. "github.com/gravitl/netmaker/netclient/functions"
  10. "github.com/gravitl/netmaker/netclient/ncutils"
  11. "github.com/gravitl/netmaker/tls"
  12. )
  13. // Join - join command to run from cli
  14. func Join(cfg *config.ClientConfig, privateKey string) error {
  15. var err error
  16. //join network
  17. err = functions.JoinNetwork(cfg, privateKey)
  18. if err != nil {
  19. if !strings.Contains(err.Error(), "ALREADY_INSTALLED") {
  20. logger.Log(1, "error installing: ", err.Error())
  21. err = functions.LeaveNetwork(cfg.Network, true)
  22. if err != nil {
  23. err = functions.WipeLocal(cfg.Network)
  24. if err != nil {
  25. logger.Log(1, "error removing artifacts: ", err.Error())
  26. }
  27. }
  28. if cfg.Daemon != "off" {
  29. if ncutils.IsLinux() {
  30. err = daemon.RemoveSystemDServices()
  31. }
  32. if err != nil {
  33. logger.Log(1, "error removing services: ", err.Error())
  34. }
  35. if ncutils.IsFreeBSD() {
  36. daemon.RemoveFreebsdDaemon()
  37. }
  38. }
  39. } else {
  40. logger.Log(0, "success")
  41. }
  42. if err != nil && strings.Contains(err.Error(), "ALREADY_INSTALLED") {
  43. logger.Log(0, err.Error())
  44. err = nil
  45. }
  46. return err
  47. }
  48. logger.Log(1, "joined ", cfg.Network)
  49. /*
  50. if ncutils.IsWindows() {
  51. logger.Log("setting up WireGuard app", 0)
  52. time.Sleep(time.Second >> 1)
  53. functions.Pull(cfg.Network, true)
  54. }
  55. */
  56. return err
  57. }
  58. // Leave - runs the leave command from cli
  59. func Leave(cfg *config.ClientConfig, force bool) error {
  60. err := functions.LeaveNetwork(cfg.Network, force)
  61. if err != nil {
  62. logger.Log(1, "error attempting to leave network "+cfg.Network)
  63. } else {
  64. logger.Log(0, "success")
  65. }
  66. return err
  67. }
  68. // Pull - runs pull command from cli
  69. func Pull(cfg *config.ClientConfig) error {
  70. var err error
  71. var networks = []string{}
  72. if cfg.Network == "all" {
  73. logger.Log(0, "No network selected. Running Pull for all networks.")
  74. networks, err = ncutils.GetSystemNetworks()
  75. if err != nil {
  76. logger.Log(1, "Error retrieving networks. Exiting.")
  77. return err
  78. }
  79. } else {
  80. networks = append(networks, cfg.Network)
  81. }
  82. var currentServers = make(map[string]config.ClientConfig)
  83. for _, network := range networks {
  84. currCfg, err := config.ReadConfig(network)
  85. if err != nil {
  86. logger.Log(1, "could not read config when pulling for network", network)
  87. continue
  88. }
  89. _, err = functions.Pull(network, true)
  90. if err != nil {
  91. logger.Log(1, "Error pulling network config for network: ", network, "\n", err.Error())
  92. } else {
  93. logger.Log(1, "pulled network config for "+network)
  94. }
  95. currentServers[currCfg.Server.Server] = *currCfg
  96. }
  97. for _, clientCfg := range currentServers {
  98. _, newKey, kerr := ed25519.GenerateKey(rand.Reader)
  99. if kerr == nil && err == nil {
  100. if kerr := tls.SaveKey(ncutils.GetNetclientPath(), ncutils.GetSeparator()+"client.key", newKey); kerr != nil {
  101. logger.Log(0, "error saving key", kerr.Error())
  102. } else {
  103. if kerr = functions.RegisterWithServer(&newKey, &clientCfg); err != nil {
  104. logger.Log(0, "registration error", kerr.Error())
  105. } else {
  106. daemon.Restart()
  107. }
  108. }
  109. }
  110. }
  111. logger.Log(1, "reset network and peer configs")
  112. return err
  113. }
  114. // List - runs list command from cli
  115. func List(cfg config.ClientConfig) error {
  116. err := functions.List(cfg.Network)
  117. return err
  118. }
  119. // Uninstall - runs uninstall command from cli
  120. func Uninstall() error {
  121. logger.Log(0, "uninstalling netclient...")
  122. err := functions.Uninstall()
  123. logger.Log(0, "uninstalled netclient")
  124. return err
  125. }
  126. // Daemon - runs the daemon
  127. func Daemon() error {
  128. err := functions.Daemon()
  129. return err
  130. }