mirror of
https://github.com/TeaOSLab/EdgeAdmin.git
synced 2025-11-03 20:40:26 +08:00
区分社区版和商业版
This commit is contained in:
7
internal/const/build.go
Normal file
7
internal/const/build.go
Normal file
@@ -0,0 +1,7 @@
|
|||||||
|
// Copyright 2021 Liuxiangchao iwind.liu@gmail.com. All rights reserved.
|
||||||
|
// +build community
|
||||||
|
|
||||||
|
package teaconst
|
||||||
|
|
||||||
|
const BuildCommunity = true
|
||||||
|
const BuildPlus = false
|
||||||
@@ -1,93 +0,0 @@
|
|||||||
// Copyright 2021 Liuxiangchao iwind.liu@gmail.com. All rights reserved.
|
|
||||||
|
|
||||||
package tasks
|
|
||||||
|
|
||||||
import (
|
|
||||||
"github.com/TeaOSLab/EdgeAdmin/internal/configs"
|
|
||||||
teaconst "github.com/TeaOSLab/EdgeAdmin/internal/const"
|
|
||||||
"github.com/TeaOSLab/EdgeAdmin/internal/events"
|
|
||||||
"github.com/TeaOSLab/EdgeAdmin/internal/rpc"
|
|
||||||
"github.com/TeaOSLab/EdgeAdmin/internal/setup"
|
|
||||||
"github.com/TeaOSLab/EdgeCommon/pkg/rpc/pb"
|
|
||||||
"github.com/iwind/TeaGo/Tea"
|
|
||||||
"github.com/iwind/TeaGo/logs"
|
|
||||||
timeutil "github.com/iwind/TeaGo/utils/time"
|
|
||||||
"time"
|
|
||||||
)
|
|
||||||
|
|
||||||
func init() {
|
|
||||||
events.On(events.EventStart, func() {
|
|
||||||
task := NewAuthorityTask()
|
|
||||||
go task.Start()
|
|
||||||
})
|
|
||||||
}
|
|
||||||
|
|
||||||
type AuthorityTask struct {
|
|
||||||
}
|
|
||||||
|
|
||||||
func NewAuthorityTask() *AuthorityTask {
|
|
||||||
return &AuthorityTask{}
|
|
||||||
}
|
|
||||||
|
|
||||||
func (this *AuthorityTask) Start() {
|
|
||||||
// 从缓存中读取
|
|
||||||
config := configs.ReadPlusConfig()
|
|
||||||
if config != nil {
|
|
||||||
teaconst.IsPlus = config.IsPlus
|
|
||||||
}
|
|
||||||
|
|
||||||
// 开始计时器
|
|
||||||
ticker := time.NewTicker(10 * time.Minute)
|
|
||||||
if Tea.IsTesting() {
|
|
||||||
// 快速测试
|
|
||||||
ticker = time.NewTicker(1 * time.Minute)
|
|
||||||
}
|
|
||||||
|
|
||||||
// 初始化的时候先获取一次
|
|
||||||
timeout := time.NewTimer(3 * time.Second)
|
|
||||||
<-timeout.C
|
|
||||||
err := this.Loop()
|
|
||||||
if err != nil {
|
|
||||||
logs.Println("[TASK][AuthorityTask]" + err.Error())
|
|
||||||
}
|
|
||||||
|
|
||||||
// 定时获取
|
|
||||||
for range ticker.C {
|
|
||||||
err := this.Loop()
|
|
||||||
if err != nil {
|
|
||||||
logs.Println("[TASK][AuthorityTask]" + err.Error())
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func (this *AuthorityTask) Loop() error {
|
|
||||||
// 如果还没有安装直接返回
|
|
||||||
if !setup.IsConfigured() {
|
|
||||||
return nil
|
|
||||||
}
|
|
||||||
|
|
||||||
rpcClient, err := rpc.SharedRPC()
|
|
||||||
if err != nil {
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
resp, err := rpcClient.AuthorityKeyRPC().ReadAuthorityKey(rpcClient.Context(0), &pb.ReadAuthorityKeyRequest{})
|
|
||||||
if err != nil {
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
if resp.AuthorityKey == nil {
|
|
||||||
teaconst.IsPlus = false
|
|
||||||
return nil
|
|
||||||
}
|
|
||||||
var oldState = teaconst.IsPlus
|
|
||||||
if resp.AuthorityKey != nil && len(resp.AuthorityKey.Value) > 0 && resp.AuthorityKey.DayTo >= timeutil.Format("Y-m-d") {
|
|
||||||
teaconst.IsPlus = true
|
|
||||||
} else {
|
|
||||||
teaconst.IsPlus = false
|
|
||||||
}
|
|
||||||
|
|
||||||
if oldState != teaconst.IsPlus {
|
|
||||||
_ = configs.WritePlusConfig(&configs.PlusConfig{IsPlus: teaconst.IsPlus})
|
|
||||||
}
|
|
||||||
|
|
||||||
return nil
|
|
||||||
}
|
|
||||||
@@ -38,7 +38,9 @@ func (this *AdvancedHelper) BeforeAction(actionPtr actions.ActionWrapper) (goNex
|
|||||||
if teaconst.IsPlus {
|
if teaconst.IsPlus {
|
||||||
tabbar.Add("监控节点", "", "/settings/monitorNodes", "", this.tab == "monitorNodes")
|
tabbar.Add("监控节点", "", "/settings/monitorNodes", "", this.tab == "monitorNodes")
|
||||||
}
|
}
|
||||||
tabbar.Add("企业版认证", "", "/settings/authority", "", this.tab == "authority")
|
if teaconst.BuildPlus {
|
||||||
|
tabbar.Add("企业版认证", "", "/settings/authority", "", this.tab == "authority")
|
||||||
|
}
|
||||||
|
|
||||||
//tabbar.Add("备份", "", "/settings/backup", "", this.tab == "backup")
|
//tabbar.Add("备份", "", "/settings/backup", "", this.tab == "backup")
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user