netmaker/pro/initialize.go

122 lines
4.1 KiB
Go
Raw Normal View History

2022-09-15 01:26:31 +08:00
//go:build ee
// +build ee
package pro
2022-09-15 01:26:31 +08:00
import (
2024-01-19 17:21:51 +08:00
"time"
2022-09-15 01:26:31 +08:00
controller "github.com/gravitl/netmaker/controllers"
2024-01-19 21:40:07 +08:00
"github.com/gravitl/netmaker/logger"
2022-09-15 01:26:31 +08:00
"github.com/gravitl/netmaker/logic"
"github.com/gravitl/netmaker/models"
"github.com/gravitl/netmaker/mq"
proControllers "github.com/gravitl/netmaker/pro/controllers"
proLogic "github.com/gravitl/netmaker/pro/logic"
2022-09-23 03:01:59 +08:00
"github.com/gravitl/netmaker/servercfg"
"golang.org/x/exp/slog"
2022-09-15 01:26:31 +08:00
)
// InitPro - Initialize Pro Logic
func InitPro() {
servercfg.IsPro = true
models.SetLogo(retrieveProLogo())
controller.HttpMiddlewares = append(
controller.HttpMiddlewares,
proControllers.OnlyServerAPIWhenUnlicensedMiddleware,
)
controller.HttpHandlers = append(
controller.HttpHandlers,
proControllers.MetricHandlers,
proControllers.RelayHandlers,
proControllers.UserHandlers,
proControllers.FailOverHandlers,
)
2022-09-15 01:26:31 +08:00
logic.EnterpriseCheckFuncs = append(logic.EnterpriseCheckFuncs, func() {
// == License Handling ==
2024-01-19 17:21:51 +08:00
enableLicenseHook := false
2024-01-19 21:40:07 +08:00
licenseKeyValue := servercfg.GetLicenseKey()
netmakerTenantID := servercfg.GetNetmakerTenantID()
if licenseKeyValue != "" && netmakerTenantID != "" {
2024-01-19 17:21:51 +08:00
enableLicenseHook = true
}
2024-01-19 21:40:07 +08:00
if !enableLicenseHook {
err := initTrial()
if err != nil {
logger.FatalLog0("failed to init trail", err.Error())
}
trialEndDate, err := getTrialEndDate()
if err != nil {
slog.Error("failed to get trial end date", "error", err)
enableLicenseHook = true
2024-01-23 11:51:19 +08:00
} else {
// check if trial ended
if time.Now().After(trialEndDate) {
// trial ended already
enableLicenseHook = true
}
2024-01-19 21:40:07 +08:00
}
2024-01-23 11:51:19 +08:00
2024-01-19 17:21:51 +08:00
}
2024-01-19 21:40:07 +08:00
2024-01-19 17:21:51 +08:00
if enableLicenseHook {
slog.Info("starting license checker")
ClearLicenseCache()
if err := ValidateLicense(); err != nil {
slog.Error(err.Error())
return
}
slog.Info("proceeding with Paid Tier license")
logic.SetFreeTierForTelemetry(false)
// == End License Handling ==
AddLicenseHooks()
} else {
2024-01-23 11:38:08 +08:00
slog.Info("starting trial license hook")
2024-01-19 17:21:51 +08:00
addTrialLicenseHook()
}
2024-01-19 17:21:51 +08:00
if servercfg.GetServerConfig().RacAutoDisable {
AddRacHooks()
}
2024-01-19 17:21:51 +08:00
2022-09-15 01:26:31 +08:00
})
logic.ResetFailOver = proLogic.ResetFailOver
logic.ResetFailedOverPeer = proLogic.ResetFailedOverPeer
logic.DenyClientNodeAccess = proLogic.DenyClientNode
logic.IsClientNodeAllowed = proLogic.IsClientNodeAllowed
logic.AllowClientNodeAccess = proLogic.RemoveDeniedNodeFromClient
logic.SetClientDefaultACLs = proLogic.SetClientDefaultACLs
logic.SetClientACLs = proLogic.SetClientACLs
logic.UpdateProNodeACLs = proLogic.UpdateProNodeACLs
logic.GetMetrics = proLogic.GetMetrics
logic.UpdateMetrics = proLogic.UpdateMetrics
logic.DeleteMetrics = proLogic.DeleteMetrics
logic.GetRelays = proLogic.GetRelays
logic.GetAllowedIpsForRelayed = proLogic.GetAllowedIpsForRelayed
logic.RelayedAllowedIPs = proLogic.RelayedAllowedIPs
logic.UpdateRelayed = proLogic.UpdateRelayed
logic.SetRelayedNodes = proLogic.SetRelayedNodes
logic.RelayUpdates = proLogic.RelayUpdates
logic.IsInternetGw = proLogic.IsInternetGw
logic.SetInternetGw = proLogic.SetInternetGw
logic.GetTrialEndDate = getTrialEndDate
mq.UpdateMetrics = proLogic.MQUpdateMetrics
mq.UpdateMetricsFallBack = proLogic.MQUpdateMetricsFallBack
2022-09-15 01:26:31 +08:00
}
func retrieveProLogo() string {
2022-09-15 01:26:31 +08:00
return `
__ __ ______ ______ __ __ ______ __ __ ______ ______
/\ "-.\ \ /\ ___\ /\__ _\ /\ "-./ \ /\ __ \ /\ \/ / /\ ___\ /\ == \
\ \ \-. \ \ \ __\ \/_/\ \/ \ \ \-./\ \ \ \ __ \ \ \ _"-. \ \ __\ \ \ __<
\ \_\\"\_\ \ \_____\ \ \_\ \ \_\ \ \_\ \ \_\ \_\ \ \_\ \_\ \ \_____\ \ \_\ \_\
\/_/ \/_/ \/_____/ \/_/ \/_/ \/_/ \/_/\/_/ \/_/\/_/ \/_____/ \/_/ /_/
___ ___ ____
____ ____ ____ / _ \ / _ \ / __ \ ____ ____ ____
/___/ /___/ /___/ / ___/ / , _// /_/ / /___/ /___/ /___/
/___/ /___/ /___/ /_/ /_/|_| \____/ /___/ /___/ /___/
`
}