diff options
| author | MHSanaei <ho3ein.sanaei@gmail.com> | 2024-01-10 15:42:54 +0300 |
|---|---|---|
| committer | MHSanaei <ho3ein.sanaei@gmail.com> | 2024-01-10 15:42:54 +0300 |
| commit | 722f5e716fb9801a1329dd754268d1199ad97957 (patch) | |
| tree | 9e009cbe3cbad77a9a4688ca21904c961fb40366 /web/html | |
| parent | fdf31d80e7b378bc20e4958e2893b72caf088602 (diff) | |
[feature] wireguard inbound
Co-Authored-By: Alireza Ahmadi <alireza7@gmail.com>
Diffstat (limited to 'web/html')
| -rw-r--r-- | web/html/xui/form/inbound.html | 5 | ||||
| -rw-r--r-- | web/html/xui/form/protocol/wireguard.html | 56 |
2 files changed, 61 insertions, 0 deletions
diff --git a/web/html/xui/form/inbound.html b/web/html/xui/form/inbound.html index 5da8ec56..b19be9ac 100644 --- a/web/html/xui/form/inbound.html +++ b/web/html/xui/form/inbound.html @@ -97,6 +97,11 @@ {{template "form/http"}} </template> +<!-- wireguard --> +<template v-if="inbound.protocol === Protocols.WIREGUARD"> + {{template "form/wireguard"}} +</template> + <!-- stream settings --> <template v-if="inbound.canEnableStream()"> {{template "form/streamSettings"}} diff --git a/web/html/xui/form/protocol/wireguard.html b/web/html/xui/form/protocol/wireguard.html new file mode 100644 index 00000000..553f5d42 --- /dev/null +++ b/web/html/xui/form/protocol/wireguard.html @@ -0,0 +1,56 @@ +{{define "form/wireguard"}} +<a-form :colon="false" :label-col="{ md: {span:6} }" :wrapper-col="{ md: {span:14} }"> + <a-form-item> + <template slot="label"> + <a-tooltip> + <template slot="title"> + <span>{{ i18n "reset" }}</span> + </template> + {{ i18n "pages.xray.wireguard.secretKey" }} + <a-icon type="sync" + @click="[inbound.settings.pubKey, inbound.settings.secretKey] = Object.values(Wireguard.generateKeypair())"> + </a-icon> + </a-tooltip> + </template> + <a-input v-model.trim="inbound.settings.secretKey"></a-input> + </a-form-item> + <a-form-item label='{{ i18n "pages.xray.wireguard.publicKey" }}'> + <a-input disabled v-model="inbound.settings.pubKey"></a-input> + </a-form-item> + <a-form-item label='MTU'> + <a-input-number v-model.number="inbound.settings.mtu"></a-input-number> + </a-form-item> + <a-form-item label='Kernel Mode'> + <a-switch v-model="inbound.settings.kernelMode"></a-switch> + </a-form-item> + <a-form-item label="Peers"> + <a-button type="primary" size="small" @click="inbound.settings.addPeer()">+</a-button> + </a-form-item> + <a-form v-for="(peer, index) in inbound.settings.peers" :colon="false" :label-col="{ md: {span:6} }" :wrapper-col="{ md: {span:14} }"> + <a-divider style="margin:0;"> + Peer [[ index + 1 ]] + <a-icon v-if="inbound.settings.peers.length>1" type="delete" @click="() => inbound.settings.delPeer(index)" + style="color: rgb(255, 77, 79);cursor: pointer;"/> + </a-divider> + <a-form-item label='{{ i18n "pages.xray.wireguard.publicKey" }}'> + <a-input v-model.trim="peer.publicKey"></a-input> + </a-form-item> + <a-form-item label='{{ i18n "pages.xray.wireguard.psk" }}'> + <a-input v-model.trim="peer.psk"></a-input> + </a-form-item> + <a-form-item> + <template slot="label"> + {{ i18n "pages.xray.wireguard.allowedIPs" }} <a-button type="primary" size="small" @click="peer.allowedIPs.push('')">+</a-button> + </template> + <template v-for="(aip, index) in peer.allowedIPs" style="margin-bottom: 10px;"> + <a-input v-model.trim="peer.allowedIPs[index]"> + <a-button v-if="peer.allowedIPs.length>1" slot="addonAfter" size="small" @click="peer.allowedIPs.splice(index, 1)">-</a-button> + </a-input> + </template> + </a-form-item> + <a-form-item label='Keep Alive'> + <a-input-number v-model.number="peer.keepAlive" :min="0"></a-input> + </a-form-item> + </a-form> +</a-form> +{{end}}
\ No newline at end of file |
