mirror of
https://github.com/TeaOSLab/EdgeAdmin.git
synced 2025-11-05 06:10:26 +08:00
589 lines
16 KiB
JavaScript
589 lines
16 KiB
JavaScript
|
|
// 动作选择
|
|||
|
|
Vue.component("http-firewall-actions-box", {
|
|||
|
|
props: ["v-actions", "v-firewall-policy", "v-action-configs"],
|
|||
|
|
mounted: function () {
|
|||
|
|
let that = this
|
|||
|
|
Tea.action("/servers/iplists/levelOptions")
|
|||
|
|
.success(function (resp) {
|
|||
|
|
that.ipListLevels = resp.data.levels
|
|||
|
|
})
|
|||
|
|
.post()
|
|||
|
|
|
|||
|
|
this.loadJS(function () {
|
|||
|
|
let box = document.getElementById("actions-box")
|
|||
|
|
Sortable.create(box, {
|
|||
|
|
draggable: ".label",
|
|||
|
|
handle: ".icon.handle",
|
|||
|
|
onStart: function () {
|
|||
|
|
that.cancel()
|
|||
|
|
},
|
|||
|
|
onUpdate: function (event) {
|
|||
|
|
let labels = box.getElementsByClassName("label")
|
|||
|
|
let newConfigs = []
|
|||
|
|
for (let i = 0; i < labels.length; i++) {
|
|||
|
|
let index = parseInt(labels[i].getAttribute("data-index"))
|
|||
|
|
newConfigs.push(that.configs[index])
|
|||
|
|
}
|
|||
|
|
that.configs = newConfigs
|
|||
|
|
}
|
|||
|
|
})
|
|||
|
|
})
|
|||
|
|
},
|
|||
|
|
data: function () {
|
|||
|
|
if (this.vFirewallPolicy.inbound == null) {
|
|||
|
|
this.vFirewallPolicy.inbound = {}
|
|||
|
|
}
|
|||
|
|
if (this.vFirewallPolicy.inbound.groups == null) {
|
|||
|
|
this.vFirewallPolicy.inbound.groups = []
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
let id = 0
|
|||
|
|
let configs = []
|
|||
|
|
if (this.vActionConfigs != null) {
|
|||
|
|
configs = this.vActionConfigs
|
|||
|
|
configs.forEach(function (v) {
|
|||
|
|
v.id = (id++)
|
|||
|
|
})
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
return {
|
|||
|
|
id: id,
|
|||
|
|
|
|||
|
|
actions: this.vActions,
|
|||
|
|
configs: configs,
|
|||
|
|
isAdding: false,
|
|||
|
|
editingIndex: -1,
|
|||
|
|
|
|||
|
|
action: null,
|
|||
|
|
actionCode: "",
|
|||
|
|
actionOptions: {},
|
|||
|
|
|
|||
|
|
// IPList相关
|
|||
|
|
ipListLevels: [],
|
|||
|
|
|
|||
|
|
// 动作参数
|
|||
|
|
blockLife: "",
|
|||
|
|
captchaLife: "",
|
|||
|
|
get302Life: "",
|
|||
|
|
post307Life: "",
|
|||
|
|
recordIPType: "black",
|
|||
|
|
recordIPLevel: "critical",
|
|||
|
|
recordIPTimeout: "",
|
|||
|
|
recordIPListId: 0,
|
|||
|
|
recordIPListName: "",
|
|||
|
|
|
|||
|
|
tagTags: [],
|
|||
|
|
|
|||
|
|
goGroupName: "",
|
|||
|
|
goGroupId: 0,
|
|||
|
|
goGroup: null,
|
|||
|
|
|
|||
|
|
goSetId: 0,
|
|||
|
|
goSetName: ""
|
|||
|
|
}
|
|||
|
|
},
|
|||
|
|
watch: {
|
|||
|
|
actionCode: function (code) {
|
|||
|
|
this.action = this.actions.$find(function (k, v) {
|
|||
|
|
return v.code == code
|
|||
|
|
})
|
|||
|
|
this.actionOptions = {}
|
|||
|
|
},
|
|||
|
|
blockLife: function (v) {
|
|||
|
|
v = parseInt(v)
|
|||
|
|
if (isNaN(v)) {
|
|||
|
|
this.actionOptions["life"] = 0
|
|||
|
|
} else {
|
|||
|
|
this.actionOptions["life"] = v
|
|||
|
|
}
|
|||
|
|
},
|
|||
|
|
captchaLife: function (v) {
|
|||
|
|
v = parseInt(v)
|
|||
|
|
if (isNaN(v)) {
|
|||
|
|
this.actionOptions["life"] = 0
|
|||
|
|
} else {
|
|||
|
|
this.actionOptions["life"] = v
|
|||
|
|
}
|
|||
|
|
},
|
|||
|
|
get302Life: function (v) {
|
|||
|
|
v = parseInt(v)
|
|||
|
|
if (isNaN(v)) {
|
|||
|
|
this.actionOptions["life"] = 0
|
|||
|
|
} else {
|
|||
|
|
this.actionOptions["life"] = v
|
|||
|
|
}
|
|||
|
|
},
|
|||
|
|
post307Life: function (v) {
|
|||
|
|
v = parseInt(v)
|
|||
|
|
if (isNaN(v)) {
|
|||
|
|
this.actionOptions["life"] = 0
|
|||
|
|
} else {
|
|||
|
|
this.actionOptions["life"] = v
|
|||
|
|
}
|
|||
|
|
},
|
|||
|
|
recordIPType: function () {
|
|||
|
|
this.recordIPListId = 0
|
|||
|
|
},
|
|||
|
|
recordIPTimeout: function (v) {
|
|||
|
|
v = parseInt(v)
|
|||
|
|
if (isNaN(v)) {
|
|||
|
|
this.actionOptions["timeout"] = 0
|
|||
|
|
} else {
|
|||
|
|
this.actionOptions["timeout"] = v
|
|||
|
|
}
|
|||
|
|
},
|
|||
|
|
goGroupId: function (groupId) {
|
|||
|
|
let group = this.vFirewallPolicy.inbound.groups.$find(function (k, v) {
|
|||
|
|
return v.id == groupId
|
|||
|
|
})
|
|||
|
|
this.goGroup = group
|
|||
|
|
if (group == null) {
|
|||
|
|
this.goGroupName = ""
|
|||
|
|
} else {
|
|||
|
|
this.goGroupName = group.name
|
|||
|
|
}
|
|||
|
|
this.goSetId = 0
|
|||
|
|
this.goSetName = ""
|
|||
|
|
},
|
|||
|
|
goSetId: function (setId) {
|
|||
|
|
if (this.goGroup == null) {
|
|||
|
|
return
|
|||
|
|
}
|
|||
|
|
let set = this.goGroup.sets.$find(function (k, v) {
|
|||
|
|
return v.id == setId
|
|||
|
|
})
|
|||
|
|
if (set == null) {
|
|||
|
|
this.goSetId = 0
|
|||
|
|
this.goSetName = ""
|
|||
|
|
} else {
|
|||
|
|
this.goSetName = set.name
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
},
|
|||
|
|
methods: {
|
|||
|
|
add: function () {
|
|||
|
|
this.action = null
|
|||
|
|
this.actionCode = "block"
|
|||
|
|
this.isAdding = true
|
|||
|
|
this.actionOptions = {}
|
|||
|
|
|
|||
|
|
// 动作参数
|
|||
|
|
this.blockLife = ""
|
|||
|
|
this.captchaLife = ""
|
|||
|
|
this.get302Life = ""
|
|||
|
|
this.post307Life = ""
|
|||
|
|
|
|||
|
|
this.recordIPLevel = "critical"
|
|||
|
|
this.recordIPType = "black"
|
|||
|
|
this.recordIPTimeout = ""
|
|||
|
|
this.recordIPListId = 0
|
|||
|
|
this.recordIPListName = ""
|
|||
|
|
|
|||
|
|
this.tagTags = []
|
|||
|
|
|
|||
|
|
this.goGroupName = ""
|
|||
|
|
this.goGroupId = 0
|
|||
|
|
this.goGroup = null
|
|||
|
|
|
|||
|
|
this.goSetId = 0
|
|||
|
|
this.goSetName = ""
|
|||
|
|
|
|||
|
|
let that = this
|
|||
|
|
this.action = this.vActions.$find(function (k, v) {
|
|||
|
|
return v.code == that.actionCode
|
|||
|
|
})
|
|||
|
|
},
|
|||
|
|
remove: function (index) {
|
|||
|
|
this.configs.$remove(index)
|
|||
|
|
},
|
|||
|
|
update: function (index, config) {
|
|||
|
|
if (this.isAdding && this.editingIndex == index) {
|
|||
|
|
this.cancel()
|
|||
|
|
return
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
this.add()
|
|||
|
|
|
|||
|
|
this.isAdding = true
|
|||
|
|
this.editingIndex = index
|
|||
|
|
|
|||
|
|
this.actionCode = config.code
|
|||
|
|
|
|||
|
|
switch (config.code) {
|
|||
|
|
case "block":
|
|||
|
|
this.blockLife = ""
|
|||
|
|
if (config.options.life != null || config.options.life > 0) {
|
|||
|
|
this.blockLife = config.options.life.toString()
|
|||
|
|
}
|
|||
|
|
break
|
|||
|
|
case "allow":
|
|||
|
|
break
|
|||
|
|
case "log":
|
|||
|
|
break
|
|||
|
|
case "captcha":
|
|||
|
|
this.captchaLife = ""
|
|||
|
|
if (config.options.life != null || config.options.life > 0) {
|
|||
|
|
this.captchaLife = config.options.life.toString()
|
|||
|
|
}
|
|||
|
|
break
|
|||
|
|
case "notify":
|
|||
|
|
break
|
|||
|
|
case "get_302":
|
|||
|
|
this.get302Life = ""
|
|||
|
|
if (config.options.life != null || config.options.life > 0) {
|
|||
|
|
this.get302Life = config.options.life.toString()
|
|||
|
|
}
|
|||
|
|
break
|
|||
|
|
case "post_307":
|
|||
|
|
this.post307Life = ""
|
|||
|
|
if (config.options.life != null || config.options.life > 0) {
|
|||
|
|
this.post307Life = config.options.life.toString()
|
|||
|
|
}
|
|||
|
|
break;
|
|||
|
|
case "record_ip":
|
|||
|
|
if (config.options != null) {
|
|||
|
|
this.recordIPLevel = config.options.level
|
|||
|
|
this.recordIPType = config.options.type
|
|||
|
|
if (config.options.timeout > 0) {
|
|||
|
|
this.recordIPTimeout = config.options.timeout.toString()
|
|||
|
|
}
|
|||
|
|
this.recordIPListId = config.options.ipListId
|
|||
|
|
this.recordIPListName = config.options.ipListName
|
|||
|
|
}
|
|||
|
|
break
|
|||
|
|
case "tag":
|
|||
|
|
this.tagTags = []
|
|||
|
|
if (config.options.tags != null) {
|
|||
|
|
this.tagTags = config.options.tags
|
|||
|
|
}
|
|||
|
|
break
|
|||
|
|
case "go_group":
|
|||
|
|
if (config.options != null) {
|
|||
|
|
this.goGroupName = config.options.groupName
|
|||
|
|
this.goGroupId = config.options.groupId
|
|||
|
|
this.goGroup = this.vFirewallPolicy.inbound.groups.$find(function (k, v) {
|
|||
|
|
return v.id == config.options.groupId
|
|||
|
|
})
|
|||
|
|
}
|
|||
|
|
break
|
|||
|
|
case "go_set":
|
|||
|
|
if (config.options != null) {
|
|||
|
|
this.goGroupName = config.options.groupName
|
|||
|
|
this.goGroupId = config.options.groupId
|
|||
|
|
this.goGroup = this.vFirewallPolicy.inbound.groups.$find(function (k, v) {
|
|||
|
|
return v.id == config.options.groupId
|
|||
|
|
})
|
|||
|
|
|
|||
|
|
this.goSetId = config.options.setId
|
|||
|
|
if (this.goGroup != null) {
|
|||
|
|
let set = this.goGroup.sets.$find(function (k, v) {
|
|||
|
|
return v.id == config.options.setId
|
|||
|
|
})
|
|||
|
|
if (set != null) {
|
|||
|
|
this.goSetName = set.name
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
break
|
|||
|
|
}
|
|||
|
|
},
|
|||
|
|
cancel: function () {
|
|||
|
|
this.isAdding = false
|
|||
|
|
this.editingIndex = -1
|
|||
|
|
},
|
|||
|
|
confirm: function () {
|
|||
|
|
if (this.action == null) {
|
|||
|
|
return
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
if (this.actionOptions == null) {
|
|||
|
|
this.actionOptions = {}
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
// record_ip
|
|||
|
|
if (this.actionCode == "record_ip") {
|
|||
|
|
let timeout = parseInt(this.recordIPTimeout)
|
|||
|
|
if (isNaN(timeout)) {
|
|||
|
|
timeout = 0
|
|||
|
|
}
|
|||
|
|
if (this.recordIPListId <= 0) {
|
|||
|
|
return
|
|||
|
|
}
|
|||
|
|
this.actionOptions = {
|
|||
|
|
type: this.recordIPType,
|
|||
|
|
level: this.recordIPLevel,
|
|||
|
|
timeout: timeout,
|
|||
|
|
ipListId: this.recordIPListId,
|
|||
|
|
ipListName: this.recordIPListName
|
|||
|
|
}
|
|||
|
|
} else if (this.actionCode == "tag") { // tag
|
|||
|
|
if (this.tagTags == null || this.tagTags.length == 0) {
|
|||
|
|
return
|
|||
|
|
}
|
|||
|
|
this.actionOptions = {
|
|||
|
|
tags: this.tagTags
|
|||
|
|
}
|
|||
|
|
} else if (this.actionCode == "go_group") { // go_group
|
|||
|
|
let groupId = this.goGroupId
|
|||
|
|
if (typeof (groupId) == "string") {
|
|||
|
|
groupId = parseInt(groupId)
|
|||
|
|
if (isNaN(groupId)) {
|
|||
|
|
groupId = 0
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
if (groupId <= 0) {
|
|||
|
|
return
|
|||
|
|
}
|
|||
|
|
this.actionOptions = {
|
|||
|
|
groupId: groupId,
|
|||
|
|
groupName: this.goGroupName
|
|||
|
|
}
|
|||
|
|
} else if (this.actionCode == "go_set") { // go_set
|
|||
|
|
let groupId = this.goGroupId
|
|||
|
|
if (typeof (groupId) == "string") {
|
|||
|
|
groupId = parseInt(groupId)
|
|||
|
|
if (isNaN(groupId)) {
|
|||
|
|
groupId = 0
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
let setId = this.goSetId
|
|||
|
|
if (typeof (setId) == "string") {
|
|||
|
|
setId = parseInt(setId)
|
|||
|
|
if (isNaN(setId)) {
|
|||
|
|
setId = 0
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
if (setId <= 0) {
|
|||
|
|
return
|
|||
|
|
}
|
|||
|
|
this.actionOptions = {
|
|||
|
|
groupId: groupId,
|
|||
|
|
groupName: this.goGroupName,
|
|||
|
|
setId: setId,
|
|||
|
|
setName: this.goSetName
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
let options = {}
|
|||
|
|
for (let k in this.actionOptions) {
|
|||
|
|
if (this.actionOptions.hasOwnProperty(k)) {
|
|||
|
|
options[k] = this.actionOptions[k]
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
if (this.editingIndex > -1) {
|
|||
|
|
this.configs[this.editingIndex] = {
|
|||
|
|
id: this.configs[this.editingIndex].id,
|
|||
|
|
code: this.actionCode,
|
|||
|
|
name: this.action.name,
|
|||
|
|
options: options
|
|||
|
|
}
|
|||
|
|
} else {
|
|||
|
|
this.configs.push({
|
|||
|
|
id: (this.id++),
|
|||
|
|
code: this.actionCode,
|
|||
|
|
name: this.action.name,
|
|||
|
|
options: options
|
|||
|
|
})
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
this.cancel()
|
|||
|
|
},
|
|||
|
|
removeRecordIPList: function () {
|
|||
|
|
this.recordIPListId = 0
|
|||
|
|
},
|
|||
|
|
selectRecordIPList: function () {
|
|||
|
|
let that = this
|
|||
|
|
teaweb.popup("/servers/iplists/selectPopup?type=" + this.recordIPType, {
|
|||
|
|
width: "50em",
|
|||
|
|
height: "30em",
|
|||
|
|
callback: function (resp) {
|
|||
|
|
that.recordIPListId = resp.data.list.id
|
|||
|
|
that.recordIPListName = resp.data.list.name
|
|||
|
|
}
|
|||
|
|
})
|
|||
|
|
},
|
|||
|
|
changeTags: function (tags) {
|
|||
|
|
this.tagTags = tags
|
|||
|
|
},
|
|||
|
|
loadJS: function (callback) {
|
|||
|
|
if (typeof Sortable != "undefined") {
|
|||
|
|
callback()
|
|||
|
|
return
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
// 引入js
|
|||
|
|
let jsFile = document.createElement("script")
|
|||
|
|
jsFile.setAttribute("src", "/js/sortable.min.js")
|
|||
|
|
jsFile.addEventListener("load", function () {
|
|||
|
|
callback()
|
|||
|
|
})
|
|||
|
|
document.head.appendChild(jsFile)
|
|||
|
|
}
|
|||
|
|
},
|
|||
|
|
template: `<div>
|
|||
|
|
<input type="hidden" name="actionsJSON" :value="JSON.stringify(configs)"/>
|
|||
|
|
<div v-show="configs.length > 0" style="margin-bottom: 0.5em" id="actions-box">
|
|||
|
|
<div v-for="(config, index) in configs" :data-index="index" :key="config.id" class="ui label small basic" :class="{blue: index == editingIndex}" style="margin-bottom: 0.4em">
|
|||
|
|
{{config.name}} ({{config.code.toUpperCase()}})
|
|||
|
|
|
|||
|
|
<!-- record_ip -->
|
|||
|
|
<span v-if="config.code == 'record_ip'">:{{config.options.ipListName}}</span>
|
|||
|
|
|
|||
|
|
<!-- tag -->
|
|||
|
|
<span v-if="config.code == 'tag'">:{{config.options.tags.join(", ")}}</span>
|
|||
|
|
|
|||
|
|
<!-- go_group -->
|
|||
|
|
<span v-if="config.code == 'go_group'">:{{config.options.groupName}}</span>
|
|||
|
|
|
|||
|
|
<!-- go_set -->
|
|||
|
|
<span v-if="config.code == 'go_set'">:{{config.options.groupName}} / {{config.options.setName}}</span>
|
|||
|
|
|
|||
|
|
<!-- 操作按钮 -->
|
|||
|
|
<a href="" title="修改" @click.prevent="update(index, config)"><i class="icon pencil small"></i></a> <a href="" title="删除" @click.prevent="remove(index)"><i class="icon remove small"></i></a> <a href="" title="拖动改变顺序"><i class="icon bars handle"></i></a>
|
|||
|
|
</div>
|
|||
|
|
<div class="ui divider"></div>
|
|||
|
|
</div>
|
|||
|
|
<div style="margin-bottom: 0.5em" v-if="isAdding">
|
|||
|
|
<table class="ui table" :class="{blue: editingIndex > -1}">
|
|||
|
|
<tr>
|
|||
|
|
<td class="title">动作类型 *</td>
|
|||
|
|
<td>
|
|||
|
|
<select class="ui dropdown auto-width" v-model="actionCode">
|
|||
|
|
<option v-for="action in actions" :value="action.code">{{action.name}} ({{action.code.toUpperCase()}})</option>
|
|||
|
|
</select>
|
|||
|
|
<p class="comment" v-if="action != null && action.description.length > 0">{{action.description}}</p>
|
|||
|
|
</td>
|
|||
|
|
</tr>
|
|||
|
|
|
|||
|
|
<!-- block -->
|
|||
|
|
<tr v-if="actionCode == 'block'">
|
|||
|
|
<td>封锁时间</td>
|
|||
|
|
<td>
|
|||
|
|
<div class="ui input right labeled">
|
|||
|
|
<input type="text" style="width: 5em" maxlength="10" v-model="blockLife" @keyup.enter="confirm()" @keypress.enter.prevent="1"/>
|
|||
|
|
<span class="ui label">秒</span>
|
|||
|
|
</div>
|
|||
|
|
</td>
|
|||
|
|
</tr>
|
|||
|
|
|
|||
|
|
<!-- captcha -->
|
|||
|
|
<tr v-if="actionCode == 'captcha'">
|
|||
|
|
<td>有效时间</td>
|
|||
|
|
<td>
|
|||
|
|
<div class="ui input right labeled">
|
|||
|
|
<input type="text" style="width: 5em" maxlength="10" v-model="captchaLife" @keyup.enter="confirm()" @keypress.enter.prevent="1"/>
|
|||
|
|
<span class="ui label">秒</span>
|
|||
|
|
</div>
|
|||
|
|
<p class="comment">验证通过后在这个时间内不再验证。</p>
|
|||
|
|
</td>
|
|||
|
|
</tr>
|
|||
|
|
|
|||
|
|
<!-- get_302 -->
|
|||
|
|
<tr v-if="actionCode == 'get_302'">
|
|||
|
|
<td>有效时间</td>
|
|||
|
|
<td>
|
|||
|
|
<div class="ui input right labeled">
|
|||
|
|
<input type="text" style="width: 5em" maxlength="10" v-model="get302Life" @keyup.enter="confirm()" @keypress.enter.prevent="1"/>
|
|||
|
|
<span class="ui label">秒</span>
|
|||
|
|
</div>
|
|||
|
|
<p class="comment">验证通过后在这个时间内不再验证。</p>
|
|||
|
|
</td>
|
|||
|
|
</tr>
|
|||
|
|
|
|||
|
|
<!-- post_307 -->
|
|||
|
|
<tr v-if="actionCode == 'post_307'">
|
|||
|
|
<td>有效时间</td>
|
|||
|
|
<td>
|
|||
|
|
<div class="ui input right labeled">
|
|||
|
|
<input type="text" style="width: 5em" maxlength="10" v-model="post307Life" @keyup.enter="confirm()" @keypress.enter.prevent="1"/>
|
|||
|
|
<span class="ui label">秒</span>
|
|||
|
|
</div>
|
|||
|
|
<p class="comment">验证通过后在这个时间内不再验证。</p>
|
|||
|
|
</td>
|
|||
|
|
</tr>
|
|||
|
|
|
|||
|
|
<!-- record_ip -->
|
|||
|
|
<tr v-if="actionCode == 'record_ip'">
|
|||
|
|
<td>IP名单类型 *</td>
|
|||
|
|
<td>
|
|||
|
|
<select class="ui dropdown auto-width" v-model="recordIPType">
|
|||
|
|
<option value="black">黑名单</option>
|
|||
|
|
<option value="white">白名单</option>
|
|||
|
|
</select>
|
|||
|
|
</td>
|
|||
|
|
</tr>
|
|||
|
|
<tr v-if="actionCode == 'record_ip'">
|
|||
|
|
<td>选择IP名单</td>
|
|||
|
|
<td>
|
|||
|
|
<div v-if="recordIPListId > 0" class="ui label basic small">{{recordIPListName}} <a href="" @click.prevent="removeRecordIPList"><i class="icon remove small"></i></a></div>
|
|||
|
|
<button type="button" class="ui button tiny" @click.prevent="selectRecordIPList">+</button>
|
|||
|
|
<p class="comment">如不选择,则自动添加到当前策略的IP名单中。</p>
|
|||
|
|
</td>
|
|||
|
|
</tr>
|
|||
|
|
<tr v-if="actionCode == 'record_ip'">
|
|||
|
|
<td>级别</td>
|
|||
|
|
<td>
|
|||
|
|
<select class="ui dropdown auto-width" v-model="recordIPLevel">
|
|||
|
|
<option v-for="level in ipListLevels" :value="level.code">{{level.name}}</option>
|
|||
|
|
</select>
|
|||
|
|
</td>
|
|||
|
|
</tr>
|
|||
|
|
<tr v-if="actionCode == 'record_ip'">
|
|||
|
|
<td>超时时间</td>
|
|||
|
|
<td>
|
|||
|
|
<div class="ui input right labeled">
|
|||
|
|
<input type="text" style="width: 5em" maxlength="10" v-model="recordIPTimeout" @keyup.enter="confirm()" @keypress.enter.prevent="1"/>
|
|||
|
|
<span class="ui label">秒</span>
|
|||
|
|
</div>
|
|||
|
|
<p class="comment">0表示不超时。</p>
|
|||
|
|
</td>
|
|||
|
|
</tr>
|
|||
|
|
|
|||
|
|
<!-- tag -->
|
|||
|
|
<tr v-if="actionCode == 'tag'">
|
|||
|
|
<td>标签 *</td>
|
|||
|
|
<td>
|
|||
|
|
<values-box @change="changeTags" :values="tagTags"></values-box>
|
|||
|
|
</td>
|
|||
|
|
</tr>
|
|||
|
|
|
|||
|
|
<!-- 规则分组 -->
|
|||
|
|
<tr v-if="actionCode == 'go_group'">
|
|||
|
|
<td>下一个分组 *</td>
|
|||
|
|
<td>
|
|||
|
|
<select class="ui dropdown auto-width" v-model="goGroupId">
|
|||
|
|
<option value="0">[选择分组]</option>
|
|||
|
|
<option v-for="group in vFirewallPolicy.inbound.groups" :value="group.id">{{group.name}}</option>
|
|||
|
|
</select>
|
|||
|
|
</td>
|
|||
|
|
</tr>
|
|||
|
|
|
|||
|
|
<!-- 规则集 -->
|
|||
|
|
<tr v-if="actionCode == 'go_set'">
|
|||
|
|
<td>下一个分组 *</td>
|
|||
|
|
<td>
|
|||
|
|
<select class="ui dropdown auto-width" v-model="goGroupId">
|
|||
|
|
<option value="0">[选择分组]</option>
|
|||
|
|
<option v-for="group in vFirewallPolicy.inbound.groups" :value="group.id">{{group.name}}</option>
|
|||
|
|
</select>
|
|||
|
|
</td>
|
|||
|
|
</tr>
|
|||
|
|
<tr v-if="actionCode == 'go_set' && goGroup != null">
|
|||
|
|
<td>下一个规则集 *</td>
|
|||
|
|
<td>
|
|||
|
|
<select class="ui dropdown auto-width" v-model="goSetId">
|
|||
|
|
<option value="0">[选择规则集]</option>
|
|||
|
|
<option v-for="set in goGroup.sets" :value="set.id">{{set.name}}</option>
|
|||
|
|
</select>
|
|||
|
|
</td>
|
|||
|
|
</tr>
|
|||
|
|
</table>
|
|||
|
|
<button class="ui button tiny" type="button" @click.prevent="confirm">确定</button>
|
|||
|
|
<a href="" @click.prevent="cancel" title="取消"><i class="icon remove small"></i></a>
|
|||
|
|
</div>
|
|||
|
|
<div v-if="!isAdding">
|
|||
|
|
<button class="ui button tiny" type="button" @click.prevent="add">+</button>
|
|||
|
|
</div>
|
|||
|
|
</div>`
|
|||
|
|
})
|