wireguard.html 2.7 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556
  1. {{define "form/wireguard"}}
  2. <a-form :colon="false" :label-col="{ md: {span:6} }" :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())">
  12. </a-icon>
  13. </a-tooltip>
  14. </template>
  15. <a-input v-model.trim="inbound.settings.secretKey"></a-input>
  16. </a-form-item>
  17. <a-form-item label='{{ i18n "pages.xray.wireguard.publicKey" }}'>
  18. <a-input disabled v-model="inbound.settings.pubKey"></a-input>
  19. </a-form-item>
  20. <a-form-item label='MTU'>
  21. <a-input-number v-model.number="inbound.settings.mtu"></a-input-number>
  22. </a-form-item>
  23. <a-form-item label='Kernel Mode'>
  24. <a-switch v-model="inbound.settings.kernelMode"></a-switch>
  25. </a-form-item>
  26. <a-form-item label="Peers">
  27. <a-button type="primary" size="small" @click="inbound.settings.addPeer()">+</a-button>
  28. </a-form-item>
  29. <a-form v-for="(peer, index) in inbound.settings.peers" :colon="false" :label-col="{ md: {span:6} }" :wrapper-col="{ md: {span:14} }">
  30. <a-divider style="margin:0;">
  31. Peer [[ index + 1 ]]
  32. <a-icon v-if="inbound.settings.peers.length>1" type="delete" @click="() => inbound.settings.delPeer(index)"
  33. style="color: rgb(255, 77, 79);cursor: pointer;"/>
  34. </a-divider>
  35. <a-form-item label='{{ i18n "pages.xray.wireguard.publicKey" }}'>
  36. <a-input v-model.trim="peer.publicKey"></a-input>
  37. </a-form-item>
  38. <a-form-item label='{{ i18n "pages.xray.wireguard.psk" }}'>
  39. <a-input v-model.trim="peer.psk"></a-input>
  40. </a-form-item>
  41. <a-form-item>
  42. <template slot="label">
  43. {{ i18n "pages.xray.wireguard.allowedIPs" }} <a-button type="primary" size="small" @click="peer.allowedIPs.push('')">+</a-button>
  44. </template>
  45. <template v-for="(aip, index) in peer.allowedIPs" style="margin-bottom: 10px;">
  46. <a-input v-model.trim="peer.allowedIPs[index]">
  47. <a-button v-if="peer.allowedIPs.length>1" slot="addonAfter" size="small" @click="peer.allowedIPs.splice(index, 1)">-</a-button>
  48. </a-input>
  49. </template>
  50. </a-form-item>
  51. <a-form-item label='Keep Alive'>
  52. <a-input-number v-model.number="peer.keepAlive" :min="0"></a-input>
  53. </a-form-item>
  54. </a-form>
  55. </a-form>
  56. {{end}}