pull.go 2.9 KB

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