mirror of
https://github.com/TeaOSLab/EdgeAdmin.git
synced 2025-11-04 05:00:25 +08:00
195 lines
7.8 KiB
JavaScript
195 lines
7.8 KiB
JavaScript
Vue.component("ip-list-table", {
|
|
props: ["v-items", "v-keyword", "v-show-search-button"],
|
|
data: function () {
|
|
return {
|
|
items: this.vItems,
|
|
keyword: (this.vKeyword != null) ? this.vKeyword : "",
|
|
selectedAll: false,
|
|
hasSelectedItems: false
|
|
}
|
|
},
|
|
methods: {
|
|
updateItem: function (itemId) {
|
|
this.$emit("update-item", itemId)
|
|
},
|
|
deleteItem: function (itemId) {
|
|
this.$emit("delete-item", itemId)
|
|
},
|
|
viewLogs: function (itemId) {
|
|
teaweb.popup("/servers/iplists/accessLogsPopup?itemId=" + itemId, {
|
|
width: "50em",
|
|
height: "30em"
|
|
})
|
|
},
|
|
changeSelectedAll: function () {
|
|
let boxes = this.$refs.itemCheckBox
|
|
if (boxes == null) {
|
|
return
|
|
}
|
|
|
|
let that = this
|
|
boxes.forEach(function (box) {
|
|
box.checked = that.selectedAll
|
|
})
|
|
|
|
this.hasSelectedItems = this.selectedAll
|
|
},
|
|
changeSelected: function (e) {
|
|
let that = this
|
|
that.hasSelectedItems = false
|
|
let boxes = that.$refs.itemCheckBox
|
|
if (boxes == null) {
|
|
return
|
|
}
|
|
boxes.forEach(function (box) {
|
|
if (box.checked) {
|
|
that.hasSelectedItems = true
|
|
}
|
|
})
|
|
},
|
|
deleteAll: function () {
|
|
let boxes = this.$refs.itemCheckBox
|
|
if (boxes == null) {
|
|
return
|
|
}
|
|
let itemIds = []
|
|
boxes.forEach(function (box) {
|
|
if (box.checked) {
|
|
itemIds.push(box.value)
|
|
}
|
|
})
|
|
if (itemIds.length == 0) {
|
|
return
|
|
}
|
|
|
|
Tea.action("/servers/iplists/deleteItems")
|
|
.post()
|
|
.params({
|
|
itemIds: itemIds
|
|
})
|
|
.success(function () {
|
|
teaweb.successToast("批量删除成功", 1200, teaweb.reload)
|
|
})
|
|
},
|
|
formatSeconds: function (seconds) {
|
|
if (seconds < 60) {
|
|
return seconds + "秒"
|
|
}
|
|
if (seconds < 3600) {
|
|
return Math.ceil(seconds / 60) + "分钟"
|
|
}
|
|
if (seconds < 86400) {
|
|
return Math.ceil(seconds / 3600) + "小时"
|
|
}
|
|
return Math.ceil(seconds / 86400) + "天"
|
|
}
|
|
},
|
|
template: `<div>
|
|
<div v-show="hasSelectedItems">
|
|
<a href="" @click.prevent="deleteAll">[批量删除]</a>
|
|
</div>
|
|
<table class="ui table selectable celled" v-if="items.length > 0">
|
|
<thead>
|
|
<tr>
|
|
<th style="width: 1em">
|
|
<div class="ui checkbox">
|
|
<input type="checkbox" v-model="selectedAll" @change="changeSelectedAll"/>
|
|
<label></label>
|
|
</div>
|
|
</th>
|
|
<th style="width:18em">IP</th>
|
|
<th style="width: 6em">类型</th>
|
|
<th style="width: 6em">级别</th>
|
|
<th style="width: 12em">过期时间</th>
|
|
<th>备注</th>
|
|
<th class="three op">操作</th>
|
|
</tr>
|
|
</thead>
|
|
<tbody v-for="item in items">
|
|
<tr>
|
|
<td>
|
|
<div class="ui checkbox">
|
|
<input type="checkbox" :value="item.id" @change="changeSelected" ref="itemCheckBox"/>
|
|
<label></label>
|
|
</div>
|
|
</td>
|
|
<td>
|
|
<span v-if="item.type != 'all'" :class="{green: item.list != null && item.list.type == 'white'}">
|
|
<keyword :v-word="keyword">{{item.ipFrom}}</keyword> <span> <span class="small red" v-if="item.isRead != null && !item.isRead"> New </span> <a :href="'/servers/iplists?ip=' + item.ipFrom" v-if="vShowSearchButton" title="搜索此IP"><span><i class="icon search small" style="color: #ccc"></i></span></a></span>
|
|
<span v-if="item.ipTo.length > 0"> - <keyword :v-word="keyword">{{item.ipTo}}</keyword></span></span>
|
|
<span v-else class="disabled">*</span>
|
|
|
|
<div v-if="item.region != null && item.region.length > 0">
|
|
<span class="grey small">{{item.region}}</span>
|
|
<span v-if="item.isp != null && item.isp.length > 0 && item.isp != '内网IP'" class="grey small"><span class="disabled">|</span> {{item.isp}}</span>
|
|
</div>
|
|
<div v-else-if="item.isp != null && item.isp.length > 0 && item.isp != '内网IP'"><span class="grey small">{{item.isp}}</span></div>
|
|
|
|
<div v-if="item.createdTime != null">
|
|
<span class="small grey">添加于 {{item.createdTime}}
|
|
<span v-if="item.list != null && item.list.id > 0">
|
|
@
|
|
|
|
<a :href="'/servers/iplists/list?listId=' + item.list.id" v-if="item.policy.id == 0"><span>[<span v-if="item.list.type == 'black'">黑</span><span v-if="item.list.type == 'white'">白</span>名单:{{item.list.name}}]</span></a>
|
|
<span v-else>[<span v-if="item.list.type == 'black'">黑</span><span v-if="item.list.type == 'white'">白</span>名单:{{item.list.name}}</span>
|
|
|
|
<span v-if="item.policy.id > 0">
|
|
<span v-if="item.policy.server != null">
|
|
<a :href="'/servers/server/settings/waf/ipadmin/allowList?serverId=' + item.policy.server.id + '&firewallPolicyId=' + item.policy.id" v-if="item.list.type == 'white'">[服务:{{item.policy.server.name}}]</a>
|
|
<a :href="'/servers/server/settings/waf/ipadmin/denyList?serverId=' + item.policy.server.id + '&firewallPolicyId=' + item.policy.id" v-if="item.list.type == 'black'">[服务:{{item.policy.server.name}}]</a>
|
|
</span>
|
|
<span v-else>
|
|
<a :href="'/servers/components/waf/ipadmin/lists?firewallPolicyId=' + item.policy.id + '&type=' + item.list.type">[策略:{{item.policy.name}}]</a>
|
|
</span>
|
|
</span>
|
|
</span>
|
|
</span>
|
|
</div>
|
|
</td>
|
|
<td>
|
|
<span v-if="item.type.length == 0">IPv4</span>
|
|
<span v-else-if="item.type == 'ipv4'">IPv4</span>
|
|
<span v-else-if="item.type == 'ipv6'">IPv6</span>
|
|
<span v-else-if="item.type == 'all'"><strong>所有IP</strong></span>
|
|
</td>
|
|
<td>
|
|
<span v-if="item.eventLevelName != null && item.eventLevelName.length > 0">{{item.eventLevelName}}</span>
|
|
<span v-else class="disabled">-</span>
|
|
</td>
|
|
<td>
|
|
<div v-if="item.expiredTime.length > 0">
|
|
{{item.expiredTime}}
|
|
<div v-if="item.isExpired" style="margin-top: 0.5em">
|
|
<span class="ui label tiny basic red">已过期</span>
|
|
</div>
|
|
<div v-if="item.lifeSeconds != null && item.lifeSeconds > 0">
|
|
<span class="small grey">{{formatSeconds(item.lifeSeconds)}}</span>
|
|
</div>
|
|
</div>
|
|
<span v-else class="disabled">不过期</span>
|
|
</td>
|
|
<td>
|
|
<span v-if="item.reason.length > 0">{{item.reason}}</span>
|
|
<span v-else class="disabled">-</span>
|
|
|
|
<div v-if="item.sourceNode != null && item.sourceNode.id > 0" style="margin-top: 0.4em">
|
|
<a :href="'/clusters/cluster/node?clusterId=' + item.sourceNode.clusterId + '&nodeId=' + item.sourceNode.id"><span class="small"><i class="icon cloud"></i>{{item.sourceNode.name}}</span></a>
|
|
</div>
|
|
<div style="margin-top: 0.4em" v-if="item.sourceServer != null && item.sourceServer.id > 0">
|
|
<a :href="'/servers/server?serverId=' + item.sourceServer.id" style="border: 0"><span class="small "><i class="icon clone outline"></i>{{item.sourceServer.name}}</span></a>
|
|
</div>
|
|
<div v-if="item.sourcePolicy != null && item.sourcePolicy.id > 0" style="margin-top: 0.4em">
|
|
<a :href="'/servers/components/waf/group?firewallPolicyId=' + item.sourcePolicy.id + '&type=inbound&groupId=' + item.sourceGroup.id + '#set' + item.sourceSet.id" v-if="item.sourcePolicy.serverId == 0"><span class="small "><i class="icon shield"></i>{{item.sourcePolicy.name}} » {{item.sourceGroup.name}} » {{item.sourceSet.name}}</span></a>
|
|
<a :href="'/servers/server/settings/waf/group?serverId=' + item.sourcePolicy.serverId + '&firewallPolicyId=' + item.sourcePolicy.id + '&type=inbound&groupId=' + item.sourceGroup.id + '#set' + item.sourceSet.id" v-if="item.sourcePolicy.serverId > 0"><span class="small "><i class="icon shield"></i> {{item.sourcePolicy.name}} » {{item.sourceGroup.name}} » {{item.sourceSet.name}}</span></a>
|
|
</div>
|
|
</td>
|
|
<td>
|
|
<a href="" @click.prevent="viewLogs(item.id)">日志</a>
|
|
<a href="" @click.prevent="updateItem(item.id)">修改</a>
|
|
<a href="" @click.prevent="deleteItem(item.id)">删除</a>
|
|
</td>
|
|
</tr>
|
|
</tbody>
|
|
</table>
|
|
</div>`
|
|
}) |