mirror of
https://github.com/TeaOSLab/EdgeAdmin.git
synced 2025-11-04 21:50:28 +08:00
98 lines
2.3 KiB
JavaScript
98 lines
2.3 KiB
JavaScript
// 请求限制
|
|
Vue.component("http-request-limit-config-box", {
|
|
props: ["v-request-limit-config"],
|
|
data: function () {
|
|
let config = this.vRequestLimitConfig
|
|
if (config == null) {
|
|
config = {
|
|
isPrior: false,
|
|
isOn: false,
|
|
maxConns: 0,
|
|
maxConnsPerIP: 0,
|
|
maxBodySize: {
|
|
count: -1,
|
|
unit: "kb"
|
|
},
|
|
outBandwidthPerConn: {
|
|
count: -1,
|
|
unit: "kb"
|
|
}
|
|
}
|
|
}
|
|
return {
|
|
config: config,
|
|
maxConns: config.maxConns,
|
|
maxConnsPerIP: config.maxConnsPerIP
|
|
}
|
|
},
|
|
watch: {
|
|
maxConns: function (v) {
|
|
let conns = parseInt(v, 10)
|
|
if (isNaN(conns)) {
|
|
this.config.maxConns = 0
|
|
return
|
|
}
|
|
if (conns < 0) {
|
|
this.config.maxConns = 0
|
|
} else {
|
|
this.config.maxConns = conns
|
|
}
|
|
},
|
|
maxConnsPerIP: function (v) {
|
|
let conns = parseInt(v, 10)
|
|
if (isNaN(conns)) {
|
|
this.config.maxConnsPerIP = 0
|
|
return
|
|
}
|
|
if (conns < 0) {
|
|
this.config.maxConnsPerIP = 0
|
|
} else {
|
|
this.config.maxConnsPerIP = conns
|
|
}
|
|
}
|
|
},
|
|
template: `<div>
|
|
<input type="hidden" name="requestLimitJSON" :value="JSON.stringify(config)"/>
|
|
<table class="ui table selectable definition">
|
|
<tbody>
|
|
<tr>
|
|
<td class="title">是否启用</td>
|
|
<td>
|
|
<checkbox v-model="config.isOn"></checkbox>
|
|
</td>
|
|
</tr>
|
|
</tbody>
|
|
<tbody v-show="config.isOn">
|
|
<tr>
|
|
<td>最大并发连接数</td>
|
|
<td>
|
|
<input type="text" maxlength="6" v-model="maxConns"/>
|
|
<p class="comment">为0表示不限制。</p>
|
|
</td>
|
|
</tr>
|
|
<tr>
|
|
<td>单IP最大并发连接数</td>
|
|
<td>
|
|
<input type="text" maxlength="6" v-model="maxConnsPerIP"/>
|
|
<p class="comment">为0表示不限制。</p>
|
|
</td>
|
|
</tr>
|
|
<tr>
|
|
<td>单连接带宽限制</td>
|
|
<td>
|
|
<size-capacity-box :v-value="config.outBandwidthPerConn" :v-supported-units="['byte', 'kb', 'mb']"></size-capacity-box>
|
|
<p class="comment">客户端单个请求每秒可以读取的下行流量。</p>
|
|
</td>
|
|
</tr>
|
|
<tr>
|
|
<td>单请求最大尺寸</td>
|
|
<td>
|
|
<size-capacity-box :v-value="config.maxBodySize" :v-supported-units="['byte', 'kb', 'mb', 'gb']"></size-capacity-box>
|
|
<p class="comment">单个请求能发送的最大内容尺寸。</p>
|
|
</td>
|
|
</tr>
|
|
</tbody>
|
|
</table>
|
|
<div class="margin"></div>
|
|
</div>`
|
|
}) |