wireguard.html 3.3 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182
  1. {{define "form/wireguard"}}
  2. <a-form :colon="false" :label-col="{ md: {span:8} }" :wrapper-col="{ md: {span:14} }">
  3. <a-form-item>
  4. <template slot="label">
  5. <a-tooltip>
  6. <template slot="title">
  7. <span>{{ i18n "reset" }}</span>
  8. </template>
  9. {{ i18n "pages.xray.wireguard.secretKey" }}
  10. <a-icon type="sync"
  11. @click="[inbound.settings.pubKey, inbound.settings.secretKey] = Object.values(Wireguard.generateKeypair())"></a-icon>
  12. </a-tooltip>
  13. </template>
  14. <a-input v-model.trim="inbound.settings.secretKey"></a-input>
  15. </a-form-item>
  16. <a-form-item label='{{ i18n "pages.xray.wireguard.publicKey" }}'>
  17. <a-input disabled v-model="inbound.settings.pubKey"></a-input>
  18. </a-form-item>
  19. <a-form-item label='MTU'>
  20. <a-input-number v-model.number="inbound.settings.mtu"></a-input-number>
  21. </a-form-item>
  22. <a-form-item label='No Kernel Tun'>
  23. <a-switch v-model="inbound.settings.noKernelTun"></a-switch>
  24. </a-form-item>
  25. <a-form-item label="Peers">
  26. <a-button icon="plus" type="primary" size="small" @click="inbound.settings.addPeer()"></a-button>
  27. </a-form-item>
  28. <a-form v-for="(peer, index) in inbound.settings.peers" :colon="false" :label-col="{ md: {span:8} }"
  29. :wrapper-col="{ md: {span:14} }">
  30. <a-divider :style="{ margin: '0' }"> Peer [[ index + 1 ]] <a-icon v-if="inbound.settings.peers.length>1"
  31. type="delete" @click="() => inbound.settings.delPeer(index)"
  32. :style="{ color: 'rgb(255, 77, 79)', cursor: 'pointer' }"></a-icon>
  33. </a-divider>
  34. <a-form-item>
  35. <template slot="label">
  36. <a-tooltip>
  37. <template slot="title">
  38. <span>{{ i18n "reset" }}</span>
  39. </template>
  40. {{ i18n "pages.xray.wireguard.secretKey" }}
  41. <a-icon @click="[peer.publicKey, peer.privateKey] = Object.values(Wireguard.generateKeypair())"
  42. type="sync"></a-icon>
  43. </a-tooltip>
  44. </template>
  45. <a-input v-model.trim="peer.privateKey"></a-input>
  46. </a-form-item>
  47. <a-form-item>
  48. <template slot="label">
  49. {{ i18n "pages.xray.wireguard.publicKey" }}
  50. </template>
  51. <a-input v-model.trim="peer.publicKey"></a-input>
  52. </a-form-item>
  53. <a-form-item>
  54. <template slot="label">
  55. <a-tooltip>
  56. <template slot="title">
  57. <span>{{ i18n "reset" }}</span>
  58. </template>
  59. {{ i18n "pages.xray.wireguard.psk" }}
  60. <a-icon @click="peer.psk = Wireguard.keyToBase64(Wireguard.generatePresharedKey())" type="sync"></a-icon>
  61. </a-tooltip>
  62. </template>
  63. <a-input v-model.trim="peer.psk"></a-input>
  64. </a-form-item>
  65. <a-form-item>
  66. <template slot="label">
  67. {{ i18n "pages.xray.wireguard.allowedIPs" }}
  68. <a-button icon="plus" type="primary" size="small" @click="peer.allowedIPs.push('')"></a-button>
  69. </template>
  70. <template v-for="(aip, index) in peer.allowedIPs" :style="{ marginBottom: '10px' }">
  71. <a-input v-model.trim="peer.allowedIPs[index]">
  72. <a-button icon="minus" v-if="peer.allowedIPs.length>1" slot="addonAfter" size="small"
  73. @click="peer.allowedIPs.splice(index, 1)"></a-button>
  74. </a-input>
  75. </template>
  76. </a-form-item>
  77. <a-form-item label='Keep Alive'>
  78. <a-input-number v-model.number="peer.keepAlive" :min="0"></a-input-number>
  79. </a-form-item>
  80. </a-form>
  81. </a-form>
  82. {{end}}