serverctl.go 3.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110
  1. package serverctl
  2. import (
  3. "strings"
  4. "github.com/gravitl/netmaker/database"
  5. "github.com/gravitl/netmaker/logger"
  6. "github.com/gravitl/netmaker/logic"
  7. "github.com/gravitl/netmaker/logic/acls"
  8. "github.com/gravitl/netmaker/logic/acls/nodeacls"
  9. "golang.org/x/exp/slog"
  10. )
  11. const (
  12. // NETMAKER_BINARY_NAME - name of netmaker binary
  13. NETMAKER_BINARY_NAME = "netmaker"
  14. )
  15. func SetDefaults() error {
  16. if err := setNodeDefaults(); err != nil {
  17. return err
  18. }
  19. if err := setNetworkDefaults(); err != nil {
  20. return err
  21. }
  22. if err := setUserDefaults(); err != nil {
  23. return err
  24. }
  25. return nil
  26. }
  27. // setNodeDefaults - runs through each node and set defaults
  28. func setNodeDefaults() error {
  29. // upgraded systems will not have ACL's set, which is why we need this function
  30. nodes, err := logic.GetAllNodes()
  31. if err != nil {
  32. return err
  33. }
  34. for i := range nodes {
  35. logic.SetNodeDefaults(&nodes[i])
  36. logic.UpdateNode(&nodes[i], &nodes[i])
  37. currentNodeACL, err := nodeacls.FetchNodeACL(nodeacls.NetworkID(nodes[i].Network), nodeacls.NodeID(nodes[i].ID.String()))
  38. if (err != nil && (database.IsEmptyRecord(err) || strings.Contains(err.Error(), "no node ACL present"))) || currentNodeACL == nil {
  39. if _, err = nodeacls.CreateNodeACL(nodeacls.NetworkID(nodes[i].Network), nodeacls.NodeID(nodes[i].ID.String()), acls.Allowed); err != nil {
  40. logger.Log(1, "could not create a default ACL for node", nodes[i].ID.String())
  41. }
  42. }
  43. }
  44. return nil
  45. }
  46. func setNetworkDefaults() error {
  47. // upgraded systems will not have NetworkUsers's set, which is why we need this function
  48. networks, err := logic.GetNetworks()
  49. if err != nil && !database.IsEmptyRecord(err) {
  50. return err
  51. }
  52. for _, network := range networks {
  53. update := false
  54. newNet := network
  55. if strings.Contains(network.NetID, ".") {
  56. newNet.NetID = strings.ReplaceAll(network.NetID, ".", "")
  57. newNet.DefaultInterface = strings.ReplaceAll(network.DefaultInterface, ".", "")
  58. update = true
  59. }
  60. if strings.ContainsAny(network.NetID, "ABCDEFGHIJKLMNOPQRSTUVWXYZ") {
  61. newNet.NetID = strings.ToLower(network.NetID)
  62. newNet.DefaultInterface = strings.ToLower(network.DefaultInterface)
  63. update = true
  64. }
  65. if update {
  66. newNet.SetDefaults()
  67. if err := logic.SaveNetwork(&newNet); err != nil {
  68. logger.Log(0, "error saving networks during initial update:", err.Error())
  69. }
  70. if err := logic.DeleteNetwork(network.NetID); err != nil {
  71. logger.Log(0, "error deleting old network:", err.Error())
  72. }
  73. } else {
  74. network.SetDefaults()
  75. _, _, _, err = logic.UpdateNetwork(&network, &network)
  76. if err != nil {
  77. logger.Log(0, "could not set defaults on network", network.NetID)
  78. }
  79. }
  80. }
  81. return nil
  82. }
  83. func setUserDefaults() error {
  84. users, err := logic.GetUsers()
  85. if err != nil && !database.IsEmptyRecord(err) {
  86. return err
  87. }
  88. for _, user := range users {
  89. updateUser, err := logic.GetUser(user.UserName)
  90. if err != nil {
  91. slog.Error("could not get user", "user", updateUser.UserName, "error", err.Error())
  92. }
  93. logic.SetUserDefaults(updateUser)
  94. err = logic.UpsertUser(*updateUser)
  95. if err != nil {
  96. slog.Error("could not update user", "user", updateUser.UserName, "error", err.Error())
  97. }
  98. }
  99. return nil
  100. }