serverctl.go 6.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223
  1. package serverctl
  2. import (
  3. "net"
  4. "os"
  5. "strings"
  6. "github.com/gravitl/netmaker/database"
  7. "github.com/gravitl/netmaker/logger"
  8. "github.com/gravitl/netmaker/logic"
  9. "github.com/gravitl/netmaker/logic/acls"
  10. "github.com/gravitl/netmaker/logic/acls/nodeacls"
  11. "github.com/gravitl/netmaker/logic/pro"
  12. "github.com/gravitl/netmaker/netclient/ncutils"
  13. "github.com/gravitl/netmaker/servercfg"
  14. )
  15. const (
  16. // NETMAKER_BINARY_NAME - name of netmaker binary
  17. NETMAKER_BINARY_NAME = "netmaker"
  18. )
  19. // InitServerNetclient - intializes the server netclient
  20. // 1. Check if config directory exists, if not attempt to make
  21. // 2. Check current networks and run pull to get interface up to date in case of restart
  22. func InitServerNetclient() error {
  23. netclientDir := ncutils.GetNetclientPath()
  24. _, err := os.Stat(netclientDir + "/config")
  25. if os.IsNotExist(err) {
  26. os.MkdirAll(netclientDir+"/config", 0700)
  27. } else if err != nil {
  28. logger.Log(1, "could not find or create", netclientDir)
  29. return err
  30. }
  31. var networks, netsErr = logic.GetNetworks()
  32. if netsErr == nil || database.IsEmptyRecord(netsErr) {
  33. for _, network := range networks {
  34. var currentServerNode, nodeErr = logic.GetNetworkServerLocal(network.NetID)
  35. if nodeErr == nil {
  36. if currentServerNode.Version != servercfg.Version {
  37. currentServerNode.Version = servercfg.Version
  38. logic.UpdateNode(&currentServerNode, &currentServerNode)
  39. }
  40. if err = logic.ServerPull(&currentServerNode, true); err != nil {
  41. logger.Log(1, "failed pull for network", network.NetID, ", on server node", currentServerNode.ID)
  42. }
  43. }
  44. if err = logic.InitializeNetUsers(&network); err != nil {
  45. logger.Log(0, "something went wrong syncing usrs on network", network.NetID, "-", err.Error())
  46. }
  47. }
  48. }
  49. return nil
  50. }
  51. func SyncServerNetworkWithProxy() error {
  52. networks, err := logic.GetNetworks()
  53. if err != nil {
  54. logger.Log(1, "error retrieving networks for keepalive", err.Error())
  55. }
  56. for _, network := range networks {
  57. serverNetworkSettings, err := logic.GetNetwork(network.NetID)
  58. if err != nil {
  59. continue
  60. }
  61. localnets, err := net.Interfaces()
  62. if err != nil {
  63. return err
  64. }
  65. ifaceExists := false
  66. for _, localnet := range localnets {
  67. if serverNetworkSettings.DefaultInterface == localnet.Name {
  68. ifaceExists = true
  69. }
  70. }
  71. if ifaceExists {
  72. serverNode, err := logic.GetNetworkServerLocal(network.NetID)
  73. if err != nil {
  74. logger.Log(1, "failed to retrieve local server node: ", serverNode.ID)
  75. continue
  76. }
  77. proxyPayload, err := logic.GetPeersForProxy(&serverNode, false)
  78. if err != nil && !ncutils.IsEmptyRecord(err) {
  79. logger.Log(1, "failed to retrieve peers for server node: ", serverNode.ID)
  80. continue
  81. }
  82. logic.ProxyMgmChan <- &proxyPayload
  83. }
  84. }
  85. return nil
  86. }
  87. // SyncServerNetwork - ensures a wg interface and node exists for server
  88. func SyncServerNetwork(network string) error {
  89. serverNetworkSettings, err := logic.GetNetwork(network)
  90. if err != nil {
  91. return err
  92. }
  93. localnets, err := net.Interfaces()
  94. if err != nil {
  95. return err
  96. }
  97. ifaceExists := false
  98. for _, localnet := range localnets {
  99. if serverNetworkSettings.DefaultInterface == localnet.Name {
  100. ifaceExists = true
  101. }
  102. }
  103. serverNode, err := logic.GetNetworkServerLocal(network)
  104. if !ifaceExists && (err == nil && serverNode.ID != "") {
  105. return logic.ServerUpdate(&serverNode, true)
  106. } else if !ifaceExists {
  107. _, err := logic.ServerJoin(&serverNetworkSettings)
  108. if err != nil {
  109. logger.Log(0, "network add failed for "+serverNetworkSettings.NetID)
  110. }
  111. }
  112. return nil
  113. }
  114. func SetDefaults() error {
  115. if err := setNodeDefaults(); err != nil {
  116. return err
  117. }
  118. if err := setNetworkDefaults(); err != nil {
  119. return err
  120. }
  121. if err := setUserDefaults(); err != nil {
  122. return err
  123. }
  124. return nil
  125. }
  126. // setNodeDefaults - runs through each node and set defaults
  127. func setNodeDefaults() error {
  128. // upgraded systems will not have ACL's set, which is why we need this function
  129. nodes, err := logic.GetAllNodes()
  130. if err != nil {
  131. return err
  132. }
  133. for i := range nodes {
  134. logic.SetNodeDefaults(&nodes[i])
  135. logic.UpdateNode(&nodes[i], &nodes[i])
  136. currentNodeACL, err := nodeacls.FetchNodeACL(nodeacls.NetworkID(nodes[i].Network), nodeacls.NodeID(nodes[i].ID))
  137. if (err != nil && (database.IsEmptyRecord(err) || strings.Contains(err.Error(), "no node ACL present"))) || currentNodeACL == nil {
  138. if _, err = nodeacls.CreateNodeACL(nodeacls.NetworkID(nodes[i].Network), nodeacls.NodeID(nodes[i].ID), acls.Allowed); err != nil {
  139. logger.Log(1, "could not create a default ACL for node", nodes[i].ID)
  140. }
  141. }
  142. }
  143. return nil
  144. }
  145. func setNetworkDefaults() error {
  146. // upgraded systems will not have NetworkUsers's set, which is why we need this function
  147. networks, err := logic.GetNetworks()
  148. if err != nil && !database.IsEmptyRecord(err) {
  149. return err
  150. }
  151. for _, net := range networks {
  152. if err = pro.InitializeNetworkUsers(net.NetID); err != nil {
  153. logger.Log(0, "could not initialize NetworkUsers on network", net.NetID)
  154. }
  155. pro.AddProNetDefaults(&net)
  156. update := false
  157. newNet := net
  158. if strings.Contains(net.NetID, ".") {
  159. newNet.NetID = strings.ReplaceAll(net.NetID, ".", "")
  160. newNet.DefaultInterface = strings.ReplaceAll(net.DefaultInterface, ".", "")
  161. update = true
  162. }
  163. if strings.ContainsAny(net.NetID, "ABCDEFGHIJKLMNOPQRSTUVWXYZ") {
  164. newNet.NetID = strings.ToLower(net.NetID)
  165. newNet.DefaultInterface = strings.ToLower(net.DefaultInterface)
  166. update = true
  167. }
  168. if update {
  169. newNet.SetDefaults()
  170. if err := logic.SaveNetwork(&newNet); err != nil {
  171. logger.Log(0, "error saving networks during initial update:", err.Error())
  172. }
  173. if err := logic.DeleteNetwork(net.NetID); err != nil {
  174. logger.Log(0, "error deleting old network:", err.Error())
  175. }
  176. } else {
  177. net.SetDefaults()
  178. _, _, _, _, _, _, err = logic.UpdateNetwork(&net, &net)
  179. if err != nil {
  180. logger.Log(0, "could not set defaults on network", net.NetID)
  181. }
  182. }
  183. }
  184. return nil
  185. }
  186. func setUserDefaults() error {
  187. users, err := logic.GetUsers()
  188. if err != nil && !database.IsEmptyRecord(err) {
  189. return err
  190. }
  191. for _, user := range users {
  192. updateUser, err := logic.GetUser(user.UserName)
  193. if err != nil {
  194. logger.Log(0, "could not update user", updateUser.UserName)
  195. }
  196. logic.SetUserDefaults(&updateUser)
  197. copyUser := updateUser
  198. copyUser.Password = ""
  199. if _, err = logic.UpdateUser(copyUser, updateUser); err != nil {
  200. logger.Log(0, "could not update user", updateUser.UserName)
  201. }
  202. }
  203. return nil
  204. }