pull.go 2.7 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697
  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.Node, 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.ListenPort != cfg.Node.LocalListenPort {
  63. if err := wireguard.RemoveConf(resNode.Interface, false); err != nil {
  64. logger.Log(0, "error remove interface", resNode.Interface, err.Error())
  65. }
  66. err = ncutils.ModPort(&resNode)
  67. if err != nil {
  68. return nil, err
  69. }
  70. informPortChange(&resNode)
  71. }
  72. if err = config.ModNodeConfig(&resNode); err != nil {
  73. return nil, err
  74. }
  75. if iface {
  76. if err = wireguard.SetWGConfig(network, false, nodeGET.Peers[:]); err != nil {
  77. return nil, err
  78. }
  79. } else {
  80. if err = wireguard.SetWGConfig(network, true, nodeGET.Peers[:]); err != nil {
  81. if errors.Is(err, os.ErrNotExist) && !ncutils.IsFreeBSD() {
  82. return Pull(network, true)
  83. } else {
  84. return nil, err
  85. }
  86. }
  87. }
  88. var bkupErr = config.SaveBackup(network)
  89. if bkupErr != nil {
  90. logger.Log(0, "unable to update backup file for", network)
  91. }
  92. return &resNode, err
  93. }