pull.go 2.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110
  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. "github.com/gravitl/netmaker/nm-proxy/manager"
  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.Proxy {
  64. ProxyMgmChan <- &manager.ManagerAction{
  65. Action: manager.AddInterface,
  66. Payload: nodeGET.ProxyUpdate,
  67. }
  68. }
  69. if !nodeGET.Node.Proxy {
  70. if nodeGET.Node.ListenPort != cfg.Node.LocalListenPort {
  71. if err := wireguard.RemoveConf(resNode.Interface, false); err != nil {
  72. logger.Log(0, "error remove interface", resNode.Interface, err.Error())
  73. }
  74. err = ncutils.ModPort(&resNode)
  75. if err != nil {
  76. return nil, err
  77. }
  78. informPortChange(&resNode)
  79. }
  80. }
  81. if err = config.ModNodeConfig(&resNode); err != nil {
  82. return nil, err
  83. }
  84. if !nodeGET.Node.Proxy {
  85. if iface {
  86. if err = wireguard.SetWGConfig(network, false, nodeGET.Peers[:]); err != nil {
  87. return nil, err
  88. }
  89. } else {
  90. if err = wireguard.SetWGConfig(network, true, nodeGET.Peers[:]); err != nil {
  91. if errors.Is(err, os.ErrNotExist) && !ncutils.IsFreeBSD() {
  92. return Pull(network, true)
  93. } else {
  94. return nil, err
  95. }
  96. }
  97. }
  98. }
  99. var bkupErr = config.SaveBackup(network)
  100. if bkupErr != nil {
  101. logger.Log(0, "unable to update backup file for", network)
  102. }
  103. return &resNode, err
  104. }