netmaker/pro/trial.go

162 lines
4 KiB
Go
Raw Normal View History

2024-01-25 09:47:13 +08:00
//go:build ee
// +build ee
2024-01-19 17:21:51 +08:00
package pro
import (
"crypto/rand"
"encoding/json"
"errors"
"time"
"github.com/gravitl/netmaker/database"
"github.com/gravitl/netmaker/logger"
"github.com/gravitl/netmaker/logic"
"github.com/gravitl/netmaker/models"
"github.com/gravitl/netmaker/netclient/ncutils"
2024-01-23 12:32:46 +08:00
"github.com/gravitl/netmaker/servercfg"
2024-01-19 17:21:51 +08:00
"golang.org/x/crypto/nacl/box"
)
type TrialInfo struct {
PrivKey []byte `json:"priv_key"`
PubKey []byte `json:"pub_key"`
2024-01-20 03:00:46 +08:00
Secret []byte `json:"secret"`
2024-01-19 17:21:51 +08:00
}
func addTrialLicenseHook() {
logic.HookManagerCh <- models.HookDetails{
Hook: TrialLicenseHook,
Interval: time.Hour,
}
}
type TrialDates struct {
TrialStartedAt time.Time `json:"trial_started_at"`
TrialEndsAt time.Time `json:"trial_ends_at"`
}
const trial_table_name = "trial"
const trial_data_key = "trialdata"
2024-01-23 12:32:46 +08:00
// stores trial end date
2024-01-19 21:40:07 +08:00
func initTrial() error {
telData := logic.FetchTelemetryData()
2024-01-19 17:21:51 +08:00
if telData.Hosts > 0 || telData.Networks > 0 || telData.Users > 0 {
2024-01-23 11:51:19 +08:00
return nil // database is already populated, so skip creating trial
2024-01-19 17:21:51 +08:00
}
2024-01-22 15:55:30 +08:00
database.CreateTable(trial_table_name)
records, err := database.FetchRecords(trial_table_name)
if err != nil && !database.IsEmptyRecord(err) {
2024-01-19 17:21:51 +08:00
return err
}
2024-01-22 15:55:30 +08:00
if len(records) > 0 {
return nil
}
2024-01-19 17:21:51 +08:00
// setup encryption keys
trafficPubKey, trafficPrivKey, err := box.GenerateKey(rand.Reader) // generate traffic keys
if err != nil {
return err
}
tPriv, err := ncutils.ConvertKeyToBytes(trafficPrivKey)
if err != nil {
return err
}
tPub, err := ncutils.ConvertKeyToBytes(trafficPubKey)
if err != nil {
return err
}
trialDates := TrialDates{
TrialStartedAt: time.Now(),
2024-01-24 21:39:33 +08:00
TrialEndsAt: time.Now().Add(time.Hour * 24 * 14),
2024-01-19 17:21:51 +08:00
}
t := TrialInfo{
PrivKey: tPriv,
PubKey: tPub,
}
tel, err := logic.FetchTelemetryRecord()
if err != nil {
return err
}
trialDatesData, err := json.Marshal(trialDates)
if err != nil {
return err
}
2024-01-20 03:40:13 +08:00
telePubKey, err := ncutils.ConvertBytesToKey(tel.TrafficKeyPub)
if err != nil {
return err
}
trialDatesSecret, err := ncutils.BoxEncrypt(trialDatesData, telePubKey, trafficPrivKey)
2024-01-19 17:21:51 +08:00
if err != nil {
return err
}
2024-01-20 03:00:46 +08:00
t.Secret = trialDatesSecret
2024-01-19 17:21:51 +08:00
trialData, err := json.Marshal(t)
if err != nil {
return err
}
err = database.Insert(trial_data_key, string(trialData), trial_table_name)
if err != nil {
return err
}
return nil
}
2024-01-23 12:32:46 +08:00
// TrialLicenseHook - hook func to check if pro trial has ended
2024-01-19 17:21:51 +08:00
func TrialLicenseHook() error {
endDate, err := getTrialEndDate()
if err != nil {
logger.FatalLog0("failed to trial end date", err.Error())
}
if time.Now().After(endDate) {
2024-01-23 12:32:46 +08:00
logger.Log(0, "***IMPORTANT: Your Trial Has Ended, to continue using pro version, please visit https://app.netmaker.io/ and create on-prem tenant to obtain a license***\nIf you wish to downgrade to community version, please run this command `/root/nm-quick.sh -d`")
err = errors.New("your trial has ended")
servercfg.ErrLicenseValidation = err
return err
2024-01-19 17:21:51 +08:00
}
return nil
}
// get trial date
func getTrialEndDate() (time.Time, error) {
record, err := database.FetchRecord(trial_table_name, trial_data_key)
if err != nil {
return logic.DefaultTrialEndDate, err
2024-01-19 17:21:51 +08:00
}
var trialInfo TrialInfo
err = json.Unmarshal([]byte(record), &trialInfo)
if err != nil {
return logic.DefaultTrialEndDate, err
2024-01-19 17:21:51 +08:00
}
tel, err := logic.FetchTelemetryRecord()
if err != nil {
return logic.DefaultTrialEndDate, err
2024-01-19 17:21:51 +08:00
}
2024-01-20 03:40:13 +08:00
telePrivKey, err := ncutils.ConvertBytesToKey(tel.TrafficKeyPriv)
if err != nil {
return logic.DefaultTrialEndDate, err
2024-01-20 03:40:13 +08:00
}
trialPubKey, err := ncutils.ConvertBytesToKey(trialInfo.PubKey)
if err != nil {
return logic.DefaultTrialEndDate, err
2024-01-20 03:40:13 +08:00
}
2024-01-19 17:21:51 +08:00
// decrypt secret
2024-01-20 03:40:13 +08:00
secretDecrypt, err := ncutils.BoxDecrypt(trialInfo.Secret, trialPubKey, telePrivKey)
2024-01-19 17:21:51 +08:00
if err != nil {
return logic.DefaultTrialEndDate, err
2024-01-19 17:21:51 +08:00
}
trialDates := TrialDates{}
err = json.Unmarshal(secretDecrypt, &trialDates)
if err != nil {
return logic.DefaultTrialEndDate, err
2024-01-19 17:21:51 +08:00
}
if trialDates.TrialEndsAt.IsZero() {
return logic.DefaultTrialEndDate, errors.New("invalid date")
2024-01-19 17:21:51 +08:00
}
return trialDates.TrialEndsAt, nil
}