mirror of
https://github.com/TeaOSLab/EdgeAdmin.git
synced 2025-11-03 20:40:26 +08:00
203 lines
5.4 KiB
Go
203 lines
5.4 KiB
Go
// Copyright 2021 Liuxiangchao iwind.liu@gmail.com. All rights reserved.
|
|
|
|
package iplists
|
|
|
|
import (
|
|
"github.com/TeaOSLab/EdgeAdmin/internal/web/actions/actionutils"
|
|
"github.com/TeaOSLab/EdgeCommon/pkg/iplibrary"
|
|
"github.com/TeaOSLab/EdgeCommon/pkg/rpc/pb"
|
|
"github.com/TeaOSLab/EdgeCommon/pkg/serverconfigs/firewallconfigs"
|
|
"github.com/iwind/TeaGo/maps"
|
|
timeutil "github.com/iwind/TeaGo/utils/time"
|
|
"time"
|
|
)
|
|
|
|
type IndexAction struct {
|
|
actionutils.ParentAction
|
|
}
|
|
|
|
func (this *IndexAction) Init() {
|
|
this.Nav("", "", "index")
|
|
}
|
|
|
|
func (this *IndexAction) RunGet(params struct {
|
|
Ip string
|
|
Keyword string
|
|
GlobalOnly bool
|
|
Unread bool
|
|
EventLevel string
|
|
ListType string
|
|
}) {
|
|
this.Data["type"] = ""
|
|
this.Data["keyword"] = params.Keyword
|
|
this.Data["globalOnly"] = params.GlobalOnly
|
|
this.Data["unread"] = params.Unread
|
|
this.Data["eventLevel"] = params.EventLevel
|
|
this.Data["listType"] = params.ListType
|
|
|
|
countUnreadResp, err := this.RPC().IPItemRPC().CountAllEnabledIPItems(this.AdminContext(), &pb.CountAllEnabledIPItemsRequest{
|
|
Keyword: params.Keyword,
|
|
GlobalOnly: params.GlobalOnly,
|
|
Unread: true,
|
|
EventLevel: params.EventLevel,
|
|
ListType: params.ListType,
|
|
Ip: params.Ip,
|
|
})
|
|
if err != nil {
|
|
this.ErrorPage(err)
|
|
return
|
|
}
|
|
this.Data["countUnread"] = countUnreadResp.Count
|
|
|
|
countResp, err := this.RPC().IPItemRPC().CountAllEnabledIPItems(this.AdminContext(), &pb.CountAllEnabledIPItemsRequest{
|
|
Keyword: params.Keyword,
|
|
GlobalOnly: params.GlobalOnly,
|
|
Unread: params.Unread,
|
|
EventLevel: params.EventLevel,
|
|
ListType: params.ListType,
|
|
Ip: params.Ip,
|
|
})
|
|
if err != nil {
|
|
this.ErrorPage(err)
|
|
return
|
|
}
|
|
var count = countResp.Count
|
|
var page = this.NewPage(count)
|
|
this.Data["totalItems"] = count
|
|
this.Data["page"] = page.AsHTML()
|
|
|
|
itemsResp, err := this.RPC().IPItemRPC().ListAllEnabledIPItems(this.AdminContext(), &pb.ListAllEnabledIPItemsRequest{
|
|
Keyword: params.Keyword,
|
|
GlobalOnly: params.GlobalOnly,
|
|
Unread: params.Unread,
|
|
EventLevel: params.EventLevel,
|
|
ListType: params.ListType,
|
|
Ip: params.Ip,
|
|
Offset: page.Offset,
|
|
Size: page.Size,
|
|
})
|
|
if err != nil {
|
|
this.ErrorPage(err)
|
|
return
|
|
}
|
|
|
|
var itemMaps = []maps.Map{}
|
|
for _, result := range itemsResp.Results {
|
|
var item = result.IpItem
|
|
expiredTime := ""
|
|
if item.ExpiredAt > 0 {
|
|
expiredTime = timeutil.FormatTime("Y-m-d H:i:s", item.ExpiredAt)
|
|
}
|
|
|
|
// policy
|
|
var sourcePolicyMap = maps.Map{"id": 0}
|
|
if item.SourceHTTPFirewallPolicy != nil {
|
|
sourcePolicyMap = maps.Map{
|
|
"id": item.SourceHTTPFirewallPolicy.Id,
|
|
"name": item.SourceHTTPFirewallPolicy.Name,
|
|
"serverId": item.SourceHTTPFirewallPolicy.ServerId,
|
|
}
|
|
}
|
|
|
|
// group
|
|
var sourceGroupMap = maps.Map{"id": 0}
|
|
if item.SourceHTTPFirewallRuleGroup != nil {
|
|
sourceGroupMap = maps.Map{
|
|
"id": item.SourceHTTPFirewallRuleGroup.Id,
|
|
"name": item.SourceHTTPFirewallRuleGroup.Name,
|
|
}
|
|
}
|
|
|
|
// set
|
|
var sourceSetMap = maps.Map{"id": 0}
|
|
if item.SourceHTTPFirewallRuleSet != nil {
|
|
sourceSetMap = maps.Map{
|
|
"id": item.SourceHTTPFirewallRuleSet.Id,
|
|
"name": item.SourceHTTPFirewallRuleSet.Name,
|
|
}
|
|
}
|
|
|
|
// server
|
|
var sourceServerMap = maps.Map{"id": 0}
|
|
if item.SourceServer != nil {
|
|
sourceServerMap = maps.Map{
|
|
"id": item.SourceServer.Id,
|
|
"name": item.SourceServer.Name,
|
|
}
|
|
}
|
|
|
|
// IP名单
|
|
var listMap = maps.Map{"id": 0}
|
|
if result.IpList != nil {
|
|
listMap = maps.Map{
|
|
"id": result.IpList.Id,
|
|
"name": result.IpList.Name,
|
|
"type": result.IpList.Type,
|
|
}
|
|
}
|
|
|
|
// policy
|
|
var policyMap = maps.Map{"id": 0}
|
|
if result.HttpFirewallPolicy != nil {
|
|
policyMap = maps.Map{
|
|
"id": result.HttpFirewallPolicy.Id,
|
|
"name": result.HttpFirewallPolicy.Name,
|
|
}
|
|
|
|
if result.Server != nil {
|
|
policyMap["server"] = maps.Map{"id": result.Server.Id, "name": result.Server.Name}
|
|
}
|
|
}
|
|
|
|
// node
|
|
var sourceNodeMap = maps.Map{"id": 0}
|
|
if item.SourceNode != nil && item.SourceNode.NodeCluster != nil {
|
|
sourceNodeMap = maps.Map{
|
|
"id": item.SourceNode.Id,
|
|
"name": item.SourceNode.Name,
|
|
"clusterId": item.SourceNode.NodeCluster.Id,
|
|
}
|
|
}
|
|
|
|
// 区域 & ISP
|
|
var region = ""
|
|
var isp = ""
|
|
if len(item.IpFrom) > 0 && len(item.IpTo) == 0 {
|
|
var ipRegion = iplibrary.LookupIP(item.IpFrom)
|
|
if ipRegion != nil && ipRegion.IsOk() {
|
|
region = ipRegion.RegionSummary()
|
|
isp = ipRegion.ProviderName()
|
|
}
|
|
}
|
|
|
|
itemMaps = append(itemMaps, maps.Map{
|
|
"id": item.Id,
|
|
"ipFrom": item.IpFrom,
|
|
"ipTo": item.IpTo,
|
|
"createdTime": timeutil.FormatTime("Y-m-d", item.CreatedAt),
|
|
"isExpired": item.ExpiredAt < time.Now().Unix(),
|
|
"expiredTime": expiredTime,
|
|
"reason": item.Reason,
|
|
"type": item.Type,
|
|
"isRead": item.IsRead,
|
|
"lifeSeconds": item.ExpiredAt - time.Now().Unix(),
|
|
"eventLevelName": firewallconfigs.FindFirewallEventLevelName(item.EventLevel),
|
|
"sourcePolicy": sourcePolicyMap,
|
|
"sourceGroup": sourceGroupMap,
|
|
"sourceSet": sourceSetMap,
|
|
"sourceServer": sourceServerMap,
|
|
"sourceNode": sourceNodeMap,
|
|
"list": listMap,
|
|
"policy": policyMap,
|
|
"region": region,
|
|
"isp": isp,
|
|
})
|
|
}
|
|
this.Data["items"] = itemMaps
|
|
|
|
// 所有级别
|
|
this.Data["eventLevels"] = firewallconfigs.FindAllFirewallEventLevels()
|
|
|
|
this.Show()
|
|
}
|