vless.html 3.2 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273
  1. {{define "form/vless"}}
  2. <a-collapse activeKey="0" v-for="(client, index) in inbound.settings.vlesses.slice(0,1)" v-if="!isEdit">
  3. <a-collapse-panel header='{{ i18n "pages.inbounds.client" }}'>
  4. {{template "form/client"}}
  5. </a-collapse-panel>
  6. </a-collapse>
  7. <a-collapse v-else>
  8. <a-collapse-panel :header="'{{ i18n "pages.client.clientCount"}} : ' + inbound.settings.vlesses.length">
  9. <table width="100%">
  10. <tr class="client-table-header">
  11. <th>{{ i18n "pages.inbounds.email" }}</th>
  12. <th>ID</th>
  13. </tr>
  14. <tr v-for="(client, index) in inbound.settings.vlesses" :class="index % 2 == 1 ? 'client-table-odd-row' : ''">
  15. <td>[[ client.email ]]</td>
  16. <td>[[ client.id ]]</td>
  17. </tr>
  18. </table>
  19. </a-collapse-panel>
  20. </a-collapse>
  21. <template v-if="!inbound.stream.isTLS || !inbound.stream.isReality">
  22. <a-form :colon="false" :label-col="{ md: {span:8} }" :wrapper-col="{ md: {span:14} }">
  23. <a-form-item label="Authentication">
  24. <a-select v-model="inbound.settings.selectedAuth" @change="getNewVlessEnc" :dropdown-class-name="themeSwitcher.currentTheme">
  25. <a-select-option :value="undefined">None</a-select-option>
  26. <a-select-option value="X25519, not Post-Quantum">X25519 (not Post-Quantum)</a-select-option>
  27. <a-select-option value="ML-KEM-768, Post-Quantum">ML-KEM-768 (Post-Quantum)</a-select-option>
  28. </a-select>
  29. </a-form-item>
  30. <a-form-item label="decryption">
  31. <a-input v-model.trim="inbound.settings.decryption"></a-input>
  32. </a-form-item>
  33. <a-form-item label="encryption">
  34. <a-input v-model="inbound.settings.encryption" disabled></a-input>
  35. </a-form-item>
  36. <a-form-item label=" ">
  37. <a-space>
  38. <a-button type="primary" icon="import" @click="getNewVlessEnc">Get New keys</a-button>
  39. <a-button danger @click="clearKeys">Clear</a-button>
  40. </a-space>
  41. </a-form-item>
  42. </a-form>
  43. </template>
  44. <template v-if="inbound.isTcp && !inbound.settings.encryption">
  45. <a-form :colon="false" :label-col="{ md: {span:8} }" :wrapper-col="{ md: {span:14} }">
  46. <a-form-item label="Fallbacks">
  47. <a-button icon="plus" type="primary" size="small" @click="inbound.settings.addFallback()"></a-button>
  48. </a-form-item>
  49. </a-form>
  50. <!-- vless fallbacks -->
  51. <a-form v-for="(fallback, index) in inbound.settings.fallbacks" :colon="false" :label-col="{ md: {span:8} }" :wrapper-col="{ md: {span:14} }">
  52. <a-divider :style="{ margin: '0' }"> Fallback [[ index + 1 ]] <a-icon type="delete" @click="() => inbound.settings.delFallback(index)" :style="{ color: 'rgb(255, 77, 79)', cursor: 'pointer' }"></a-icon>
  53. </a-divider>
  54. <a-form-item label='SNI'>
  55. <a-input v-model="fallback.name"></a-input>
  56. </a-form-item>
  57. <a-form-item label='ALPN'>
  58. <a-input v-model="fallback.alpn"></a-input>
  59. </a-form-item>
  60. <a-form-item label='Path'>
  61. <a-input v-model="fallback.path"></a-input>
  62. </a-form-item>
  63. <a-form-item label='Dest'>
  64. <a-input v-model="fallback.dest"></a-input>
  65. </a-form-item>
  66. <a-form-item label='xVer'>
  67. <a-input-number v-model.number="fallback.xver" :min="0" :max="2"></a-input-number>
  68. </a-form-item>
  69. </a-form>
  70. <a-divider :style="{ margin: '5px 0' }"></a-divider>
  71. </template>
  72. {{end}}