commands.go 5.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191
  1. package command
  2. import (
  3. "crypto/ed25519"
  4. "crypto/rand"
  5. "errors"
  6. "fmt"
  7. "strings"
  8. "github.com/gravitl/netmaker/logger"
  9. "github.com/gravitl/netmaker/netclient/config"
  10. "github.com/gravitl/netmaker/netclient/daemon"
  11. "github.com/gravitl/netmaker/netclient/functions"
  12. "github.com/gravitl/netmaker/netclient/ncutils"
  13. "github.com/gravitl/netmaker/tls"
  14. )
  15. // Join - join command to run from cli
  16. func Join(cfg *config.ClientConfig, privateKey string) error {
  17. var err error
  18. //join network
  19. if cfg.SsoServer != "" {
  20. // User wants to get access key from the OIDC server
  21. // Do that before the Joining Network flow by performing the end point auth flow
  22. // if performed successfully an access key is obtained from the server and then we
  23. // proceed with the usual flow 'pretending' that user is feeded us with an access token
  24. if len(cfg.Network) == 0 || cfg.Network == "all" {
  25. return fmt.Errorf("no network provided. Specify network with \"-n <net name>\"")
  26. }
  27. logger.Log(1, "Logging into %s via:", cfg.Network, cfg.SsoServer)
  28. err = functions.JoinViaSSo(cfg, privateKey)
  29. if err != nil {
  30. logger.Log(0, "Join failed: ", err.Error())
  31. return err
  32. }
  33. if cfg.AccessKey == "" {
  34. return errors.New("login failed")
  35. }
  36. }
  37. logger.Log(1, "Joining network: ", cfg.Network)
  38. err = functions.JoinNetwork(cfg, privateKey)
  39. if err != nil {
  40. if !strings.Contains(err.Error(), "ALREADY_INSTALLED") {
  41. logger.Log(0, "error installing: ", err.Error())
  42. err = functions.WipeLocal(cfg)
  43. if err != nil {
  44. logger.Log(1, "error removing artifacts: ", err.Error())
  45. }
  46. if cfg.Daemon != "off" {
  47. if ncutils.IsLinux() {
  48. err = daemon.RemoveSystemDServices()
  49. }
  50. if err != nil {
  51. logger.Log(1, "error removing services: ", err.Error())
  52. }
  53. if ncutils.IsFreeBSD() {
  54. daemon.RemoveFreebsdDaemon()
  55. }
  56. }
  57. }
  58. if err != nil && strings.Contains(err.Error(), "ALREADY_INSTALLED") {
  59. logger.Log(0, err.Error())
  60. err = nil
  61. }
  62. return err
  63. }
  64. logger.Log(1, "joined", cfg.Network)
  65. return err
  66. }
  67. // Leave - runs the leave command from cli
  68. func Leave(cfg *config.ClientConfig) error {
  69. err := functions.LeaveNetwork(cfg.Network)
  70. if err != nil {
  71. logger.Log(1, "error attempting to leave network "+cfg.Network)
  72. } else {
  73. logger.Log(0, "success")
  74. }
  75. return err
  76. }
  77. // Pull - runs pull command from cli
  78. func Pull(cfg *config.ClientConfig) error {
  79. var err error
  80. var networks = []string{}
  81. if cfg.Network == "all" {
  82. logger.Log(0, "No network selected. Running Pull for all networks.")
  83. networks, err = ncutils.GetSystemNetworks()
  84. if err != nil {
  85. logger.Log(1, "Error retrieving networks. Exiting.")
  86. return err
  87. }
  88. } else {
  89. networks = append(networks, cfg.Network)
  90. }
  91. var currentServers = make(map[string]config.ClientConfig)
  92. for _, network := range networks {
  93. currCfg, err := config.ReadConfig(network)
  94. if err != nil {
  95. logger.Log(1, "could not read config when pulling for network", network)
  96. continue
  97. }
  98. _, err = functions.Pull(network, true)
  99. if err != nil {
  100. logger.Log(1, "error pulling network config for network: ", network, "\n", err.Error())
  101. } else {
  102. logger.Log(1, "pulled network config for "+network)
  103. }
  104. currentServers[currCfg.Server.Server] = *currCfg
  105. }
  106. //generate new client key if one doesn' exist
  107. var private *ed25519.PrivateKey
  108. private, err = tls.ReadKeyFromFile(ncutils.GetNetclientPath() + ncutils.GetSeparator() + "client.key")
  109. if err != nil {
  110. _, newKey, err := ed25519.GenerateKey(rand.Reader)
  111. if err != nil {
  112. return err
  113. }
  114. if err := tls.SaveKeyToFile(ncutils.GetNetclientPath(), ncutils.GetSeparator()+"client.key", newKey); err != nil {
  115. return err
  116. }
  117. private = &newKey
  118. }
  119. // re-register with server -- get new certs for broker
  120. for _, clientCfg := range currentServers {
  121. if err = functions.RegisterWithServer(private, &clientCfg); err != nil {
  122. logger.Log(0, "registration error", err.Error())
  123. } else {
  124. daemon.Restart()
  125. }
  126. }
  127. logger.Log(1, "reset network", cfg.Network, "and peer configs")
  128. return err
  129. }
  130. // List - runs list command from cli
  131. func List(cfg config.ClientConfig) error {
  132. _, err := functions.List(cfg.Network)
  133. return err
  134. }
  135. // Uninstall - runs uninstall command from cli
  136. func Uninstall() error {
  137. logger.Log(0, "uninstalling netclient...")
  138. err := functions.Uninstall()
  139. logger.Log(0, "uninstalled netclient")
  140. return err
  141. }
  142. // Daemon - runs the daemon
  143. func Daemon() error {
  144. err := functions.Daemon()
  145. return err
  146. }
  147. // Install - installs binary and daemon
  148. func Install() error {
  149. return functions.Install()
  150. }
  151. // Connect - re-instates a connection of a node
  152. func Connect(cfg config.ClientConfig) error {
  153. networkName := cfg.Network
  154. if networkName == "" {
  155. networkName = cfg.Node.Network
  156. }
  157. if networkName == "all" {
  158. return fmt.Errorf("no network specified")
  159. }
  160. return functions.Connect(networkName)
  161. }
  162. // Disconnect - disconnects a connection of a node
  163. func Disconnect(cfg config.ClientConfig) error {
  164. networkName := cfg.Network
  165. if networkName == "" {
  166. networkName = cfg.Node.Network
  167. }
  168. if networkName == "all" {
  169. return fmt.Errorf("no network specified")
  170. }
  171. return functions.Disconnect(networkName)
  172. }