commands.go 3.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136
  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 && !cfg.DebugOn {
  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. if cfg.Network == "all" {
  72. logger.Log(0, "No network selected. Running Pull for all networks.")
  73. networks, err := ncutils.GetSystemNetworks()
  74. if err != nil {
  75. logger.Log(1, "Error retrieving networks. Exiting.")
  76. return err
  77. }
  78. for _, network := range networks {
  79. _, err = functions.Pull(network, true)
  80. if err != nil {
  81. logger.Log(1, "Error pulling network config for network: ", network, "\n", err.Error())
  82. } else {
  83. logger.Log(1, "pulled network config for "+network)
  84. }
  85. }
  86. err = nil
  87. } else {
  88. _, err = functions.Pull(cfg.Network, true)
  89. _, newKey, kerr := ed25519.GenerateKey(rand.Reader)
  90. if kerr == nil && err == nil {
  91. if kerr := tls.SaveKey(ncutils.GetNetclientPath(), ncutils.GetSeparator()+"client.key", newKey); kerr != nil {
  92. logger.Log(0, "error saving key", kerr.Error())
  93. } else {
  94. if kerr = functions.RegisterWithServer(&newKey, cfg); err != nil {
  95. logger.Log(0, "registration error", kerr.Error())
  96. } else {
  97. daemon.Restart()
  98. }
  99. }
  100. }
  101. }
  102. logger.Log(1, "reset network and peer configs")
  103. if err == nil {
  104. logger.Log(1, "reset network and peer configs")
  105. logger.Log(1, "success")
  106. } else {
  107. logger.Log(0, "error occurred pulling configs from server")
  108. }
  109. return err
  110. }
  111. // List - runs list command from cli
  112. func List(cfg config.ClientConfig) error {
  113. err := functions.List(cfg.Network)
  114. return err
  115. }
  116. // Uninstall - runs uninstall command from cli
  117. func Uninstall() error {
  118. logger.Log(0, "uninstalling netclient...")
  119. err := functions.Uninstall()
  120. logger.Log(0, "uninstalled netclient")
  121. return err
  122. }
  123. // Daemon - runs the daemon
  124. func Daemon() error {
  125. err := functions.Daemon()
  126. return err
  127. }