Welcome to mirror list, hosted at ThFree Co, Russian Federation.

github.com/MHSanaei/3x-ui.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
path: root/web/html
diff options
context:
space:
mode:
authorMHSanaei <ho3ein.sanaei@gmail.com>2024-01-10 15:42:54 +0300
committerMHSanaei <ho3ein.sanaei@gmail.com>2024-01-10 15:42:54 +0300
commit722f5e716fb9801a1329dd754268d1199ad97957 (patch)
tree9e009cbe3cbad77a9a4688ca21904c961fb40366 /web/html
parentfdf31d80e7b378bc20e4958e2893b72caf088602 (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.html5
-rw-r--r--web/html/xui/form/protocol/wireguard.html56
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