pull.go 2.5 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495
  1. package functions
  2. import (
  3. "encoding/json"
  4. "errors"
  5. "fmt"
  6. "io"
  7. "net/http"
  8. "os"
  9. "runtime"
  10. "strconv"
  11. "github.com/gravitl/netmaker/logger"
  12. "github.com/gravitl/netmaker/models"
  13. "github.com/gravitl/netmaker/netclient/config"
  14. "github.com/gravitl/netmaker/netclient/local"
  15. "github.com/gravitl/netmaker/netclient/ncutils"
  16. "github.com/gravitl/netmaker/netclient/wireguard"
  17. "golang.zx2c4.com/wireguard/wgctrl/wgtypes"
  18. //homedir "github.com/mitchellh/go-homedir"
  19. )
  20. // Pull - pulls the latest config from the server, if manual it will overwrite
  21. func Pull(network string, iface bool) (*models.Node, error) {
  22. cfg, err := config.ReadConfig(network)
  23. if err != nil {
  24. return nil, err
  25. }
  26. if cfg.Node.IPForwarding == "yes" && !ncutils.IsWindows() {
  27. if err = local.SetIPForwarding(); err != nil {
  28. return nil, err
  29. }
  30. }
  31. token, err := Authenticate(cfg)
  32. if err != nil {
  33. return nil, err
  34. }
  35. url := "https://" + cfg.Server.API + "/api/nodes/" + cfg.Network + "/" + cfg.Node.ID
  36. response, err := API("", http.MethodGet, url, token)
  37. if err != nil {
  38. return nil, err
  39. }
  40. if response.StatusCode != http.StatusOK {
  41. bytes, err := io.ReadAll(response.Body)
  42. if err != nil {
  43. fmt.Println(err)
  44. }
  45. return nil, (fmt.Errorf("%s %w", string(bytes), err))
  46. }
  47. defer response.Body.Close()
  48. var nodeGET models.NodeGet
  49. if err := json.NewDecoder(response.Body).Decode(&nodeGET); err != nil {
  50. return nil, fmt.Errorf("error decoding node %w", err)
  51. }
  52. resNode := nodeGET.Node
  53. // ensure that the OS never changes
  54. resNode.OS = runtime.GOOS
  55. if nodeGET.Peers == nil {
  56. nodeGET.Peers = []wgtypes.PeerConfig{}
  57. }
  58. if nodeGET.ServerConfig.API != "" && nodeGET.ServerConfig.MQPort != "" {
  59. if err = config.ModServerConfig(&nodeGET.ServerConfig, resNode.Network); err != nil {
  60. logger.Log(0, "unable to update server config: "+err.Error())
  61. }
  62. }
  63. if nodeGET.Node.ListenPort != cfg.Node.ListenPort {
  64. err = ncutils.ModPort(&resNode)
  65. if err != nil {
  66. return nil, err
  67. }
  68. logger.Log(0, "port is now", strconv.Itoa(int(resNode.ListenPort)))
  69. }
  70. if err = config.ModNodeConfig(&resNode); err != nil {
  71. return nil, err
  72. }
  73. if iface {
  74. if err = wireguard.SetWGConfig(network, false, nodeGET.Peers[:]); err != nil {
  75. return nil, err
  76. }
  77. } else {
  78. if err = wireguard.SetWGConfig(network, true, nodeGET.Peers[:]); err != nil {
  79. if errors.Is(err, os.ErrNotExist) && !ncutils.IsFreeBSD() {
  80. return Pull(network, true)
  81. } else {
  82. return nil, err
  83. }
  84. }
  85. }
  86. var bkupErr = config.SaveBackup(network)
  87. if bkupErr != nil {
  88. logger.Log(0, "unable to update backup file")
  89. }
  90. return &resNode, err
  91. }