| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142 |
- {{define "form/streamTCP"}}
- <!-- tcp type -->
- <a-form
- :colon="false"
- :label-col="{ md: {span:8} }"
- :wrapper-col="{ md: {span:14} }"
- >
- <a-form-item label="Proxy Protocol" v-if="inbound.canEnableTls()">
- <a-switch v-model="inbound.stream.tcp.acceptProxyProtocol"></a-switch>
- </a-form-item>
- <a-form-item label='HTTP {{ i18n "camouflage" }}'>
- <a-switch
- :checked="inbound.stream.tcp.type === 'http'"
- @change="checked => inbound.stream.tcp.type = checked ? 'http' : 'none'"
- ></a-switch>
- </a-form-item>
- </a-form>
- <a-form
- v-if="inbound.stream.tcp.type === 'http'"
- :colon="false"
- :label-col="{ md: {span:8} }"
- :wrapper-col="{ md: {span:14} }"
- >
- <!-- tcp request -->
- <a-divider :style="{ margin: '0' }"
- >{{ i18n "pages.inbounds.stream.general.request" }}</a-divider
- >
- <a-form-item label='{{ i18n "pages.inbounds.stream.tcp.version" }}'>
- <a-input v-model.trim="inbound.stream.tcp.request.version"></a-input>
- </a-form-item>
- <a-form-item label='{{ i18n "pages.inbounds.stream.tcp.method" }}'>
- <a-input v-model.trim="inbound.stream.tcp.request.method"></a-input>
- </a-form-item>
- <a-form-item>
- <template slot="label"
- >{{ i18n "pages.inbounds.stream.tcp.path" }}
- <a-button
- icon="plus"
- size="small"
- @click="inbound.stream.tcp.request.addPath('/')"
- ></a-button>
- </template>
- <template v-for="(path, index) in inbound.stream.tcp.request.path">
- <a-input v-model.trim="inbound.stream.tcp.request.path[index]">
- <a-button
- icon="minus"
- size="small"
- slot="addonAfter"
- @click="inbound.stream.tcp.request.removePath(index)"
- v-if="inbound.stream.tcp.request.path.length>1"
- ></a-button>
- </a-input>
- </template>
- </a-form-item>
- <a-form-item label='{{ i18n "pages.inbounds.stream.tcp.requestHeader" }}'>
- <a-button
- icon="plus"
- size="small"
- @click="inbound.stream.tcp.request.addHeader('Host', '')"
- ></a-button>
- </a-form-item>
- <a-form-item :wrapper-col="{span:24}">
- <a-input-group
- compact
- v-for="(header, index) in inbound.stream.tcp.request.headers"
- >
- <a-input
- :style="{ width: '50%' }"
- v-model.trim="header.name"
- placeholder='{{ i18n "pages.inbounds.stream.general.name" }}'
- >
- <template slot="addonBefore" :style="{ margin: '0' }"
- >[[ index+1 ]]</template
- >
- </a-input>
- <a-input
- :style="{ width: '50%' }"
- v-model.trim="header.value"
- placeholder='{{ i18n "pages.inbounds.stream.general.value" }}'
- >
- <a-button
- icon="minus"
- slot="addonAfter"
- size="small"
- @click="inbound.stream.tcp.request.removeHeader(index)"
- ></a-button>
- </a-input>
- </a-input-group>
- </a-form-item>
- <!-- tcp response -->
- <a-divider :style="{ margin: '0' }"
- >{{ i18n "pages.inbounds.stream.general.response" }}</a-divider
- >
- <a-form-item label='{{ i18n "pages.inbounds.stream.tcp.version" }}'>
- <a-input v-model.trim="inbound.stream.tcp.response.version"></a-input>
- </a-form-item>
- <a-form-item label='{{ i18n "pages.inbounds.stream.tcp.status" }}'>
- <a-input v-model.trim="inbound.stream.tcp.response.status"></a-input>
- </a-form-item>
- <a-form-item label='{{ i18n "pages.inbounds.stream.tcp.statusDescription" }}'>
- <a-input v-model.trim="inbound.stream.tcp.response.reason"></a-input>
- </a-form-item>
- <a-form-item label='{{ i18n "pages.inbounds.stream.tcp.responseHeader" }}'>
- <a-button
- icon="plus"
- size="small"
- @click="inbound.stream.tcp.response.addHeader('Content-Type', 'application/octet-stream')"
- ></a-button>
- </a-form-item>
- <a-form-item :wrapper-col="{span:24}">
- <a-input-group
- compact
- v-for="(header, index) in inbound.stream.tcp.response.headers"
- >
- <a-input
- :style="{ width: '50%' }"
- v-model.trim="header.name"
- placeholder='{{ i18n "pages.inbounds.stream.general.name" }}'
- >
- <template slot="addonBefore" :style="{ margin: '0' }"
- >[[ index+1 ]]</template
- >
- </a-input>
- <a-input
- :style="{ width: '50%' }"
- v-model.trim="header.value"
- placeholder='{{ i18n "pages.inbounds.stream.general.value" }}'
- >
- <template slot="addonAfter">
- <a-button
- icon="minus"
- size="small"
- @click="inbound.stream.tcp.response.removeHeader(index)"
- ></a-button>
- </template>
- </a-input>
- </a-input-group>
- </a-form-item>
- </a-form>
- {{end}}
|