serverctl.go 6.5 KB

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