initialize.go 3.3 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889
  1. //go:build ee
  2. // +build ee
  3. package pro
  4. import (
  5. controller "github.com/gravitl/netmaker/controllers"
  6. "github.com/gravitl/netmaker/logic"
  7. "github.com/gravitl/netmaker/models"
  8. "github.com/gravitl/netmaker/mq"
  9. proControllers "github.com/gravitl/netmaker/pro/controllers"
  10. proLogic "github.com/gravitl/netmaker/pro/logic"
  11. "github.com/gravitl/netmaker/servercfg"
  12. "golang.org/x/exp/slog"
  13. )
  14. // InitPro - Initialize Pro Logic
  15. func InitPro() {
  16. servercfg.IsPro = true
  17. models.SetLogo(retrieveProLogo())
  18. controller.HttpMiddlewares = append(
  19. controller.HttpMiddlewares,
  20. proControllers.OnlyServerAPIWhenUnlicensedMiddleware,
  21. )
  22. controller.HttpHandlers = append(
  23. controller.HttpHandlers,
  24. proControllers.MetricHandlers,
  25. proControllers.RelayHandlers,
  26. proControllers.UserHandlers,
  27. )
  28. logic.EnterpriseCheckFuncs = append(logic.EnterpriseCheckFuncs, func() {
  29. // == License Handling ==
  30. if err := ValidateLicense(); err != nil {
  31. slog.Error(err.Error())
  32. return
  33. }
  34. slog.Info("proceeding with Paid Tier license")
  35. logic.SetFreeTierForTelemetry(false)
  36. // == End License Handling ==
  37. AddLicenseHooks()
  38. resetFailover()
  39. })
  40. logic.EnterpriseFailoverFunc = proLogic.SetFailover
  41. logic.EnterpriseResetFailoverFunc = proLogic.ResetFailover
  42. logic.EnterpriseResetAllPeersFailovers = proLogic.WipeAffectedFailoversOnly
  43. logic.DenyClientNodeAccess = proLogic.DenyClientNode
  44. logic.IsClientNodeAllowed = proLogic.IsClientNodeAllowed
  45. logic.AllowClientNodeAccess = proLogic.RemoveDeniedNodeFromClient
  46. logic.SetClientDefaultACLs = proLogic.SetClientDefaultACLs
  47. logic.SetClientACLs = proLogic.SetClientACLs
  48. logic.UpdateProNodeACLs = proLogic.UpdateProNodeACLs
  49. logic.GetMetrics = proLogic.GetMetrics
  50. logic.UpdateMetrics = proLogic.UpdateMetrics
  51. logic.DeleteMetrics = proLogic.DeleteMetrics
  52. logic.GetAllowedIpsForRelayed = proLogic.GetAllowedIpsForRelayed
  53. logic.RelayedAllowedIPs = proLogic.RelayedAllowedIPs
  54. logic.UpdateRelayed = proLogic.UpdateRelayed
  55. logic.SetRelayedNodes = proLogic.SetRelayedNodes
  56. logic.RelayUpdates = proLogic.RelayUpdates
  57. mq.UpdateMetrics = proLogic.MQUpdateMetrics
  58. }
  59. func resetFailover() {
  60. nets, err := logic.GetNetworks()
  61. if err == nil {
  62. for _, net := range nets {
  63. err = proLogic.ResetFailover(net.NetID)
  64. if err != nil {
  65. slog.Error("failed to reset failover", "network", net.NetID, "error", err.Error())
  66. }
  67. }
  68. }
  69. }
  70. func retrieveProLogo() string {
  71. return `
  72. __ __ ______ ______ __ __ ______ __ __ ______ ______
  73. /\ "-.\ \ /\ ___\ /\__ _\ /\ "-./ \ /\ __ \ /\ \/ / /\ ___\ /\ == \
  74. \ \ \-. \ \ \ __\ \/_/\ \/ \ \ \-./\ \ \ \ __ \ \ \ _"-. \ \ __\ \ \ __<
  75. \ \_\\"\_\ \ \_____\ \ \_\ \ \_\ \ \_\ \ \_\ \_\ \ \_\ \_\ \ \_____\ \ \_\ \_\
  76. \/_/ \/_/ \/_____/ \/_/ \/_/ \/_/ \/_/\/_/ \/_/\/_/ \/_____/ \/_/ /_/
  77. ___ ___ ____
  78. ____ ____ ____ / _ \ / _ \ / __ \ ____ ____ ____
  79. /___/ /___/ /___/ / ___/ / , _// /_/ / /___/ /___/ /___/
  80. /___/ /___/ /___/ /_/ /_/|_| \____/ /___/ /___/ /___/
  81. `
  82. }