mirror of
https://github.com/TeaOSLab/EdgeAdmin.git
synced 2025-11-03 12:20:28 +08:00
IP名单中可以批量删除最多10000个IP
This commit is contained in:
82
internal/web/actions/default/servers/iplists/deleteCount.go
Normal file
82
internal/web/actions/default/servers/iplists/deleteCount.go
Normal file
@@ -0,0 +1,82 @@
|
|||||||
|
// Copyright 2023 Liuxiangchao iwind.liu@gmail.com. All rights reserved.
|
||||||
|
|
||||||
|
package iplists
|
||||||
|
|
||||||
|
import (
|
||||||
|
"github.com/TeaOSLab/EdgeAdmin/internal/web/actions/actionutils"
|
||||||
|
"github.com/TeaOSLab/EdgeAdmin/internal/web/helpers"
|
||||||
|
"github.com/TeaOSLab/EdgeCommon/pkg/langs/codes"
|
||||||
|
"github.com/TeaOSLab/EdgeCommon/pkg/rpc/pb"
|
||||||
|
"github.com/iwind/TeaGo/types"
|
||||||
|
"strings"
|
||||||
|
)
|
||||||
|
|
||||||
|
type DeleteCountAction struct {
|
||||||
|
actionutils.ParentAction
|
||||||
|
}
|
||||||
|
|
||||||
|
func (this *DeleteCountAction) RunPost(params struct {
|
||||||
|
Ip string
|
||||||
|
Keyword string
|
||||||
|
GlobalOnly bool
|
||||||
|
Unread bool
|
||||||
|
EventLevel string
|
||||||
|
ListType string
|
||||||
|
|
||||||
|
Count int64
|
||||||
|
}) {
|
||||||
|
|
||||||
|
var count = params.Count
|
||||||
|
if count <= 0 || count >= 100_000 {
|
||||||
|
this.Fail("'count' 参数错误")
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
itemIdsResp, err := this.RPC().IPItemRPC().ListAllIPItemIds(this.AdminContext(), &pb.ListAllIPItemIdsRequest{
|
||||||
|
Keyword: params.Keyword,
|
||||||
|
GlobalOnly: params.GlobalOnly,
|
||||||
|
Unread: params.Unread,
|
||||||
|
EventLevel: params.EventLevel,
|
||||||
|
ListType: params.ListType,
|
||||||
|
Ip: params.Ip,
|
||||||
|
Offset: 0,
|
||||||
|
Size: count,
|
||||||
|
})
|
||||||
|
if err != nil {
|
||||||
|
this.ErrorPage(err)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
var itemIds = itemIdsResp.IpItemIds
|
||||||
|
|
||||||
|
if len(itemIds) == 0 {
|
||||||
|
this.Success()
|
||||||
|
}
|
||||||
|
|
||||||
|
// 记录日志
|
||||||
|
defer func() {
|
||||||
|
var itemIdStrings = []string{}
|
||||||
|
for _, itemId := range itemIds {
|
||||||
|
itemIdStrings = append(itemIdStrings, types.String(itemId))
|
||||||
|
}
|
||||||
|
|
||||||
|
var itemIdsDescription = ""
|
||||||
|
if len(itemIdStrings) > 10 {
|
||||||
|
itemIdsDescription = strings.Join(itemIdStrings[:10], ", ") + " ..."
|
||||||
|
} else {
|
||||||
|
itemIdsDescription = strings.Join(itemIdStrings, ", ")
|
||||||
|
}
|
||||||
|
this.CreateLogInfo(codes.IPList_LogDeleteIPBatch, itemIdsDescription)
|
||||||
|
}()
|
||||||
|
|
||||||
|
_, err = this.RPC().IPItemRPC().DeleteIPItems(this.AdminContext(), &pb.DeleteIPItemsRequest{IpItemIds: itemIds})
|
||||||
|
if err != nil {
|
||||||
|
this.ErrorPage(err)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
// 通知左侧菜单Badge更新
|
||||||
|
helpers.NotifyIPItemsCountChanges()
|
||||||
|
|
||||||
|
this.Success()
|
||||||
|
}
|
||||||
@@ -63,6 +63,7 @@ func (this *IndexAction) RunGet(params struct {
|
|||||||
}
|
}
|
||||||
var count = countResp.Count
|
var count = countResp.Count
|
||||||
var page = this.NewPage(count)
|
var page = this.NewPage(count)
|
||||||
|
this.Data["totalItems"] = count
|
||||||
this.Data["page"] = page.AsHTML()
|
this.Data["page"] = page.AsHTML()
|
||||||
|
|
||||||
itemsResp, err := this.RPC().IPItemRPC().ListAllEnabledIPItems(this.AdminContext(), &pb.ListAllEnabledIPItemsRequest{
|
itemsResp, err := this.RPC().IPItemRPC().ListAllEnabledIPItems(this.AdminContext(), &pb.ListAllEnabledIPItemsRequest{
|
||||||
|
|||||||
@@ -22,6 +22,7 @@ func init() {
|
|||||||
Get("/exportData", new(ExportDataAction)).
|
Get("/exportData", new(ExportDataAction)).
|
||||||
Post("/delete", new(DeleteAction)).
|
Post("/delete", new(DeleteAction)).
|
||||||
Post("/deleteItems", new(DeleteItemsAction)).
|
Post("/deleteItems", new(DeleteItemsAction)).
|
||||||
|
Post("/deleteCount", new(DeleteCountAction)).
|
||||||
GetPost("/test", new(TestAction)).
|
GetPost("/test", new(TestAction)).
|
||||||
GetPost("/update", new(UpdateAction)).
|
GetPost("/update", new(UpdateAction)).
|
||||||
Get("/items", new(ItemsAction)).
|
Get("/items", new(ItemsAction)).
|
||||||
|
|||||||
@@ -1,11 +1,18 @@
|
|||||||
Vue.component("ip-list-table", {
|
Vue.component("ip-list-table", {
|
||||||
props: ["v-items", "v-keyword", "v-show-search-button"],
|
props: ["v-items", "v-keyword", "v-show-search-button", "v-total"/** total items >= items length **/],
|
||||||
data: function () {
|
data: function () {
|
||||||
|
let maxDeletes = 10000
|
||||||
|
if (this.vTotal != null && this.vTotal > 0 && this.vTotal < maxDeletes) {
|
||||||
|
maxDeletes = this.vTotal
|
||||||
|
}
|
||||||
|
|
||||||
return {
|
return {
|
||||||
items: this.vItems,
|
items: this.vItems,
|
||||||
keyword: (this.vKeyword != null) ? this.vKeyword : "",
|
keyword: (this.vKeyword != null) ? this.vKeyword : "",
|
||||||
selectedAll: false,
|
selectedAll: false,
|
||||||
hasSelectedItems: false
|
hasSelectedItems: false,
|
||||||
|
|
||||||
|
MaxDeletes: maxDeletes
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
methods: {
|
methods: {
|
||||||
@@ -71,6 +78,21 @@ Vue.component("ip-list-table", {
|
|||||||
teaweb.successToast("批量删除成功", 1200, teaweb.reload)
|
teaweb.successToast("批量删除成功", 1200, teaweb.reload)
|
||||||
})
|
})
|
||||||
},
|
},
|
||||||
|
deleteCount: function () {
|
||||||
|
let that = this
|
||||||
|
teaweb.confirm("确定要批量删除当前列表中的" + this.MaxDeletes + "个IP吗?", function () {
|
||||||
|
let query = window.location.search
|
||||||
|
if (query.startsWith("?")) {
|
||||||
|
query = query.substring(1)
|
||||||
|
}
|
||||||
|
Tea.action("/servers/iplists/deleteCount?" + query)
|
||||||
|
.post()
|
||||||
|
.params({count: that.MaxDeletes})
|
||||||
|
.success(function () {
|
||||||
|
teaweb.successToast("批量删除成功", 1200, teaweb.reload)
|
||||||
|
})
|
||||||
|
})
|
||||||
|
},
|
||||||
formatSeconds: function (seconds) {
|
formatSeconds: function (seconds) {
|
||||||
if (seconds < 60) {
|
if (seconds < 60) {
|
||||||
return seconds + "秒"
|
return seconds + "秒"
|
||||||
@@ -86,7 +108,9 @@ Vue.component("ip-list-table", {
|
|||||||
},
|
},
|
||||||
template: `<div>
|
template: `<div>
|
||||||
<div v-show="hasSelectedItems">
|
<div v-show="hasSelectedItems">
|
||||||
<a href="" @click.prevent="deleteAll">[批量删除]</a>
|
<button class="ui button basic" type="button" @click.prevent="deleteAll">批量删除所选</button>
|
||||||
|
|
||||||
|
<button class="ui button basic" type="button" @click.prevent="deleteCount" v-if="vTotal != null && vTotal >= MaxDeletes">批量删除{{MaxDeletes}}个</button>
|
||||||
</div>
|
</div>
|
||||||
<table class="ui table selectable celled" v-if="items.length > 0">
|
<table class="ui table selectable celled" v-if="items.length > 0">
|
||||||
<thead>
|
<thead>
|
||||||
|
|||||||
@@ -50,6 +50,6 @@
|
|||||||
|
|
||||||
<p class="comment" v-if="items.length == 0">暂时还没有IP。</p>
|
<p class="comment" v-if="items.length == 0">暂时还没有IP。</p>
|
||||||
|
|
||||||
<ip-list-table v-if="items.length > 0" :v-items="items" @update-item="updateItem" @delete-item="deleteItem" :v-keyword="keyword" :v-show-search-button="true"></ip-list-table>
|
<ip-list-table v-if="items.length > 0" :v-items="items" @update-item="updateItem" @delete-item="deleteItem" :v-keyword="keyword" :v-show-search-button="true" :v-total="totalItems"></ip-list-table>
|
||||||
|
|
||||||
<div class="page" v-html="page"></div>
|
<div class="page" v-html="page"></div>
|
||||||
Reference in New Issue
Block a user