commands.go 5.0 KB

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