initialize.go 2.7 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182
  1. //go:build ee
  2. // +build ee
  3. package ee
  4. import (
  5. controller "github.com/gravitl/netmaker/controllers"
  6. "github.com/gravitl/netmaker/ee/ee_controllers"
  7. eelogic "github.com/gravitl/netmaker/ee/logic"
  8. "github.com/gravitl/netmaker/logger"
  9. "github.com/gravitl/netmaker/logic"
  10. "github.com/gravitl/netmaker/models"
  11. "github.com/gravitl/netmaker/servercfg"
  12. )
  13. // InitEE - Initialize EE Logic
  14. func InitEE() {
  15. setIsEnterprise()
  16. models.SetLogo(retrieveEELogo())
  17. controller.HttpHandlers = append(
  18. controller.HttpHandlers,
  19. ee_controllers.MetricHandlers,
  20. ee_controllers.NetworkUsersHandlers,
  21. ee_controllers.UserGroupsHandlers,
  22. )
  23. logic.EnterpriseCheckFuncs = append(logic.EnterpriseCheckFuncs, func() {
  24. // == License Handling ==
  25. ValidateLicense()
  26. if Limits.FreeTier {
  27. logger.Log(0, "proceeding with Free Tier license")
  28. logic.SetFreeTierForTelemetry(true)
  29. } else {
  30. logger.Log(0, "proceeding with Paid Tier license")
  31. logic.SetFreeTierForTelemetry(false)
  32. }
  33. // == End License Handling ==
  34. AddLicenseHooks()
  35. resetFailover()
  36. })
  37. logic.EnterpriseFailoverFunc = eelogic.SetFailover
  38. logic.EnterpriseResetFailoverFunc = eelogic.ResetFailover
  39. logic.EnterpriseResetAllPeersFailovers = eelogic.WipeAffectedFailoversOnly
  40. }
  41. func setControllerLimits() {
  42. logic.Node_Limit = Limits.Nodes
  43. logic.Users_Limit = Limits.Users
  44. logic.Clients_Limit = Limits.Clients
  45. logic.Free_Tier = Limits.FreeTier
  46. servercfg.Is_EE = true
  47. if logic.Free_Tier {
  48. logic.Networks_Limit = 3
  49. }
  50. }
  51. func resetFailover() {
  52. nets, err := logic.GetNetworks()
  53. if err == nil {
  54. for _, net := range nets {
  55. err = eelogic.ResetFailover(net.NetID)
  56. if err != nil {
  57. logger.Log(0, "failed to reset failover on network", net.NetID, ":", err.Error())
  58. }
  59. }
  60. }
  61. }
  62. func retrieveEELogo() string {
  63. return `
  64. __ __ ______ ______ __ __ ______ __ __ ______ ______
  65. /\ "-.\ \ /\ ___\ /\__ _\ /\ "-./ \ /\ __ \ /\ \/ / /\ ___\ /\ == \
  66. \ \ \-. \ \ \ __\ \/_/\ \/ \ \ \-./\ \ \ \ __ \ \ \ _"-. \ \ __\ \ \ __<
  67. \ \_\\"\_\ \ \_____\ \ \_\ \ \_\ \ \_\ \ \_\ \_\ \ \_\ \_\ \ \_____\ \ \_\ \_\
  68. \/_/ \/_/ \/_____/ \/_/ \/_/ \/_/ \/_/\/_/ \/_/\/_/ \/_____/ \/_/ /_/
  69. ___ ___ ____
  70. ____ ____ ____ / _ \ / _ \ / __ \ ____ ____ ____
  71. /___/ /___/ /___/ / ___/ / , _// /_/ / /___/ /___/ /___/
  72. /___/ /___/ /___/ /_/ /_/|_| \____/ /___/ /___/ /___/
  73. `
  74. }