commands.go 3.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138
  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. return err
  50. }
  51. // Leave - runs the leave command from cli
  52. func Leave(cfg *config.ClientConfig, force bool) error {
  53. err := functions.LeaveNetwork(cfg.Network, force)
  54. if err != nil {
  55. logger.Log(1, "error attempting to leave network "+cfg.Network)
  56. } else {
  57. logger.Log(0, "success")
  58. }
  59. return err
  60. }
  61. // Pull - runs pull command from cli
  62. func Pull(cfg *config.ClientConfig) error {
  63. var err error
  64. var networks = []string{}
  65. if cfg.Network == "all" {
  66. logger.Log(0, "No network selected. Running Pull for all networks.")
  67. networks, err = ncutils.GetSystemNetworks()
  68. if err != nil {
  69. logger.Log(1, "Error retrieving networks. Exiting.")
  70. return err
  71. }
  72. } else {
  73. networks = append(networks, cfg.Network)
  74. }
  75. var currentServers = make(map[string]config.ClientConfig)
  76. for _, network := range networks {
  77. currCfg, err := config.ReadConfig(network)
  78. if err != nil {
  79. logger.Log(1, "could not read config when pulling for network", network)
  80. continue
  81. }
  82. _, err = functions.Pull(network, true)
  83. if err != nil {
  84. logger.Log(1, "Error pulling network config for network: ", network, "\n", err.Error())
  85. } else {
  86. logger.Log(1, "pulled network config for "+network)
  87. }
  88. currentServers[currCfg.Server.Server] = *currCfg
  89. }
  90. for _, clientCfg := range currentServers {
  91. _, newKey, kerr := ed25519.GenerateKey(rand.Reader)
  92. if kerr == nil && err == nil {
  93. if kerr := tls.SaveKey(ncutils.GetNetclientPath(), ncutils.GetSeparator()+"client.key", newKey); kerr != nil {
  94. logger.Log(0, "error saving key", kerr.Error())
  95. } else {
  96. if kerr = functions.RegisterWithServer(&newKey, &clientCfg); err != nil {
  97. logger.Log(0, "registration error", kerr.Error())
  98. } else {
  99. daemon.Restart()
  100. }
  101. }
  102. }
  103. }
  104. logger.Log(1, "reset network and peer configs")
  105. return err
  106. }
  107. // List - runs list command from cli
  108. func List(cfg config.ClientConfig) error {
  109. _, err := functions.List(cfg.Network)
  110. return err
  111. }
  112. // Uninstall - runs uninstall command from cli
  113. func Uninstall() error {
  114. logger.Log(0, "uninstalling netclient...")
  115. err := functions.Uninstall()
  116. logger.Log(0, "uninstalled netclient")
  117. return err
  118. }
  119. // Daemon - runs the daemon
  120. func Daemon() error {
  121. err := functions.Daemon()
  122. return err
  123. }