2020-09-20 20:12:43 +08:00
|
|
|
|
Vue.component("http-firewall-config-box", {
|
2021-10-07 16:47:14 +08:00
|
|
|
|
props: ["v-firewall-config", "v-is-location", "v-is-group", "v-firewall-policy"],
|
2020-09-20 20:12:43 +08:00
|
|
|
|
data: function () {
|
|
|
|
|
|
let firewall = this.vFirewallConfig
|
|
|
|
|
|
if (firewall == null) {
|
|
|
|
|
|
firewall = {
|
2020-09-23 18:43:38 +08:00
|
|
|
|
isPrior: false,
|
2020-09-20 20:12:43 +08:00
|
|
|
|
isOn: false,
|
2023-03-01 16:46:49 +08:00
|
|
|
|
firewallPolicyId: 0,
|
|
|
|
|
|
ignoreGlobalRules: false
|
2020-09-20 20:12:43 +08:00
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
return {
|
2023-03-01 16:46:49 +08:00
|
|
|
|
firewall: firewall,
|
|
|
|
|
|
moreOptionsVisible: false
|
|
|
|
|
|
}
|
|
|
|
|
|
},
|
|
|
|
|
|
methods: {
|
|
|
|
|
|
changeOptionsVisible: function (v) {
|
|
|
|
|
|
this.moreOptionsVisible = v
|
2020-09-20 20:12:43 +08:00
|
|
|
|
}
|
|
|
|
|
|
},
|
|
|
|
|
|
template: `<div>
|
|
|
|
|
|
<input type="hidden" name="firewallJSON" :value="JSON.stringify(firewall)"/>
|
2023-03-01 16:46:49 +08:00
|
|
|
|
|
|
|
|
|
|
<table class="ui table selectable definition" v-show="!vIsGroup">
|
|
|
|
|
|
<tr>
|
|
|
|
|
|
<td class="title">全局WAF策略</td>
|
|
|
|
|
|
<td>
|
|
|
|
|
|
<div v-if="vFirewallPolicy != null">{{vFirewallPolicy.name}} <span v-if="vFirewallPolicy.modeInfo != null"> <span :class="{green: vFirewallPolicy.modeInfo.code == 'defend', blue: vFirewallPolicy.modeInfo.code == 'observe', grey: vFirewallPolicy.modeInfo.code == 'bypass'}">[{{vFirewallPolicy.modeInfo.name}}]</span> </span> <link-icon :href="'/servers/components/waf/policy?firewallPolicyId=' + vFirewallPolicy.id"></link-icon>
|
|
|
|
|
|
<p class="comment">当前服务所在集群的设置。</p>
|
|
|
|
|
|
</div>
|
|
|
|
|
|
<span v-else class="red">当前集群没有设置WAF策略,当前配置无法生效。</span>
|
|
|
|
|
|
</td>
|
|
|
|
|
|
</tr>
|
|
|
|
|
|
</table>
|
|
|
|
|
|
|
2020-09-20 20:12:43 +08:00
|
|
|
|
<table class="ui table selectable definition">
|
2021-10-07 16:47:14 +08:00
|
|
|
|
<prior-checkbox :v-config="firewall" v-if="vIsLocation || vIsGroup"></prior-checkbox>
|
|
|
|
|
|
<tbody v-show="(!vIsLocation && !vIsGroup) || firewall.isPrior">
|
2023-03-01 16:46:49 +08:00
|
|
|
|
<tr>
|
|
|
|
|
|
<td class="title">启用WAF</td>
|
2020-09-20 20:12:43 +08:00
|
|
|
|
<td>
|
2023-03-01 16:46:49 +08:00
|
|
|
|
<checkbox v-model="firewall.isOn"></checkbox>
|
|
|
|
|
|
<p class="comment">启用WAF之后,各项WAF设置才会生效。</p>
|
2020-09-20 20:12:43 +08:00
|
|
|
|
</td>
|
|
|
|
|
|
</tr>
|
2023-03-01 16:46:49 +08:00
|
|
|
|
</tbody>
|
|
|
|
|
|
<tr>
|
|
|
|
|
|
<td colspan="2"><more-options-indicator @change="changeOptionsVisible"></more-options-indicator></td>
|
|
|
|
|
|
</tr>
|
|
|
|
|
|
<tbody v-show="moreOptionsVisible">
|
2020-09-20 20:12:43 +08:00
|
|
|
|
<tr>
|
2023-03-01 16:46:49 +08:00
|
|
|
|
<td>不使用全局规则</td>
|
2020-09-20 20:12:43 +08:00
|
|
|
|
<td>
|
2023-03-01 16:46:49 +08:00
|
|
|
|
<checkbox v-model="firewall.ignoreGlobalRules"></checkbox>
|
|
|
|
|
|
<p class="comment">选中后,表示<strong>不使用</strong>系统全局WAF策略中定义的规则。</p>
|
2020-09-20 20:12:43 +08:00
|
|
|
|
</td>
|
|
|
|
|
|
</tr>
|
|
|
|
|
|
</tbody>
|
|
|
|
|
|
</table>
|
|
|
|
|
|
<div class="margin"></div>
|
|
|
|
|
|
</div>`
|
|
|
|
|
|
})
|