增加商业版激活功能

This commit is contained in:
GoEdgeLab
2021-09-16 10:32:58 +08:00
parent f4f268d9b7
commit 35fd437aaa
8 changed files with 100 additions and 15 deletions

View File

@@ -0,0 +1,52 @@
// Copyright 2021 Liuxiangchao iwind.liu@gmail.com. All rights reserved.
package server
import (
"github.com/TeaOSLab/EdgeAdmin/internal/web/actions/actionutils"
"github.com/TeaOSLab/EdgeCommon/pkg/rpc/pb"
"github.com/iwind/TeaGo/actions"
)
type ActivateAction struct {
actionutils.ParentAction
}
func (this *ActivateAction) Init() {
this.Nav("", "", "activate")
}
func (this *ActivateAction) RunGet(params struct{}) {
this.Show()
}
func (this *ActivateAction) RunPost(params struct {
Key string
Must *actions.Must
CSRF *actionutils.CSRF
}) {
if len(params.Key) == 0 {
this.FailField("key", "请输入激活码")
}
resp, err := this.RPC().AuthorityKeyRPC().ValidateAuthorityKey(this.AdminContext(), &pb.ValidateAuthorityKeyRequest{Key: params.Key})
if err != nil {
this.ErrorPage(err)
return
}
if resp.IsOk {
_, err := this.RPC().AuthorityKeyRPC().UpdateAuthorityKey(this.AdminContext(), &pb.UpdateAuthorityKeyRequest{
Value: params.Key,
})
if err != nil {
this.ErrorPage(err)
return
}
this.Success()
} else {
this.FailField("key", "无法激活:"+resp.Error)
}
}

View File

@@ -8,6 +8,7 @@ import (
"github.com/TeaOSLab/EdgeCommon/pkg/rpc/pb"
"github.com/iwind/TeaGo/maps"
timeutil "github.com/iwind/TeaGo/utils/time"
"time"
)
type IndexAction struct {
@@ -26,24 +27,28 @@ func (this *IndexAction) RunGet(params struct{}) {
}
var keyMap maps.Map = nil
teaconst.IsPlus = false
if keyResp.AuthorityKey != nil {
if len(keyResp.AuthorityKey.MacAddresses) == 0 {
keyResp.AuthorityKey.MacAddresses = []string{}
var key = keyResp.AuthorityKey
if key != nil {
if len(key.MacAddresses) == 0 {
key.MacAddresses = []string{}
}
isActive := len(keyResp.AuthorityKey.DayTo) > 0 && keyResp.AuthorityKey.DayTo >= timeutil.Format("Y-m-d")
isActive := len(key.DayTo) > 0 && key.DayTo >= timeutil.Format("Y-m-d")
if isActive {
teaconst.IsPlus = true
}
isExpiring := isActive && key.DayTo < timeutil.Format("Y-m-d", time.Now().AddDate(0, 0, 7))
keyMap = maps.Map{
"dayFrom": keyResp.AuthorityKey.DayFrom,
"dayTo": keyResp.AuthorityKey.DayTo,
"macAddresses": keyResp.AuthorityKey.MacAddresses,
"hostname": keyResp.AuthorityKey.Hostname,
"company": keyResp.AuthorityKey.Company,
"nodes": keyResp.AuthorityKey.Nodes,
"dayFrom": key.DayFrom,
"dayTo": key.DayTo,
"macAddresses": key.MacAddresses,
"hostname": key.Hostname,
"company": key.Company,
"nodes": key.Nodes,
"isExpired": !isActive,
"isExpiring": isExpiring,
"updatedTime": timeutil.FormatTime("Y-m-d H:i:s", keyResp.AuthorityKey.UpdatedAt),
}
}

View File

@@ -14,6 +14,7 @@ func init() {
Helper(settingutils.NewAdvancedHelper("authority")).
Prefix("/settings/authority").
Get("", new(IndexAction)).
GetPost("/activate", new(ActivateAction)).
EndAll()
})
}

View File

@@ -39,7 +39,7 @@ func (this *AdvancedHelper) BeforeAction(actionPtr actions.ActionWrapper) (goNex
tabbar.Add("监控节点", "", "/settings/monitorNodes", "", this.tab == "monitorNodes")
}
if teaconst.BuildPlus {
tabbar.Add("业版认证", "", "/settings/authority", "", this.tab == "authority")
tabbar.Add("业版认证", "", "/settings/authority", "", this.tab == "authority")
}
//tabbar.Add("备份", "", "/settings/backup", "", this.tab == "backup")

View File

@@ -1,4 +1,5 @@
<first-menu>
<menu-item href="/settings/authority" code="index">认证信息</menu-item>
<menu-item href="/settings/authority/nodes" code="node">认证节点</menu-item>
<!--<menu-item href="/settings/authority/nodes" code="node">认证节点</menu-item>-->
<menu-item href="/settings/authority/activate" code="activate">激活</menu-item>
</first-menu>

View File

@@ -0,0 +1,18 @@
{$layout}
{$template "menu"}
<div class="margin"></div>
<form class="ui form" data-tea-action="$" data-tea-success="success" spellcheck="false">
<csrf-token></csrf-token>
<table class="ui table definition selectable">
<tr>
<td class="title">激活码 *</td>
<td>
<textarea rows="4" name="key" ref="focus"></textarea>
<p class="comment">请输入商业版激活码。</p>
</td>
</tr>
</table>
<submit-btn>激活</submit-btn>
</form>

View File

@@ -0,0 +1,3 @@
Tea.context(function () {
this.success = NotifySuccess("激活成功", "/settings/authority")
})

View File

@@ -6,7 +6,7 @@
<div v-if="key != null">
<div class="margin"></div>
<div class="ui message green icon">
<div class="ui message green icon" v-if="!key.isExpired">
<i class="icon gem outline small yellow"></i>
<div class="content">
恭喜您已经成为尊贵的商业版用户。
@@ -18,7 +18,9 @@
<tr>
<td class="title">状态</td>
<td>
<span class="green">已认证</span>
<span class="red" v-if="key.isExpiring">即将过期</span>
<span class="red" v-else-if="key.isExpired">已过期</span>
<span class="green" v-else>已认证</span>
</td>
</tr>
<tr v-if="key.nodes > 0">
@@ -36,7 +38,10 @@
<tr>
<td class="title">结束日期</td>
<td>{{key.dayTo}}
<div v-if="key.isExpired" style="margin-top: 0.5em">
<div v-if="key.isExpiring" style="margin-top: 0.5em">
<span class="red">即将过期</span>
</div>
<div v-else-if="key.isExpired" style="margin-top: 0.5em">
<span class="red">已过期,请尽快更新认证信息。</span>
</div>
</td>