| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150 | {{define "inboundModal"}}<a-modal id="inbound-modal" v-model="inModal.visible" :title="inModal.title" @ok="inModal.ok"         :confirm-loading="inModal.confirmLoading" :closable="true" :mask-closable="false"         :class="themeSwitcher.darkCardClass"         :ok-text="inModal.okText" cancel-text='{{ i18n "close" }}'>    {{template "form/inbound"}}</a-modal><script>    const inModal = {        title: '',        visible: false,        confirmLoading: false,        okText: '{{ i18n "sure" }}',        isEdit: false,        confirm: null,        inbound: new Inbound(),        dbInbound: new DBInbound(),        ok() {            ObjectUtil.execute(inModal.confirm, inModal.inbound, inModal.dbInbound);        },        show({ title = '', okText = '{{ i18n "sure" }}', inbound = null, dbInbound = null, confirm = (inbound, dbInbound) => {}, isEdit = false }) {            this.title = title;            this.okText = okText;            if (inbound) {                this.inbound = Inbound.fromJson(inbound.toJson());            } else {                this.inbound = new Inbound();            }            if (dbInbound) {                this.dbInbound = new DBInbound(dbInbound);            } else {                this.dbInbound = new DBInbound();            }            this.confirm = confirm;            this.visible = true;            this.isEdit = isEdit;        },        close() {            inModal.visible = false;            inModal.loading(false);        },        loading(loading) {            inModal.confirmLoading = loading;        },        getClients(protocol, clientSettings) {            switch (protocol) {                case Protocols.VMESS: return clientSettings.vmesses;                case Protocols.VLESS: return clientSettings.vlesses;                case Protocols.TROJAN: return clientSettings.trojans;                case Protocols.SHADOWSOCKS: return clientSettings.shadowsockses;                default: return null;            }        },    };    new Vue({        delimiters: ['[[', ']]'],        el: '#inbound-modal',        data: {            inModal: inModal,            delayedStart: false,            get inbound() {                return inModal.inbound;            },            get dbInbound() {                return inModal.dbInbound;            },            get isEdit() {                return inModal.isEdit;            },            get client() {                return inModal.getClients(this.inbound.protocol, this.inbound.settings)[0];            },            get delayedExpireDays() {                return this.client && this.client.expiryTime < 0 ? this.client.expiryTime / -86400000 : 0;            },            set delayedExpireDays(days) {                this.client.expiryTime = -86400000 * days;            },            get multiDomain() {                return this.inbound.stream.tls.settings.domains.length > 0;            },            set multiDomain(value) {                if (value) {                    inModal.inbound.stream.tls.server = "";                    inModal.inbound.stream.tls.settings.domains = [{ remark: "", domain: window.location.hostname }];                } else {                    inModal.inbound.stream.tls.server = "";                    inModal.inbound.stream.tls.settings.domains = [];                }            }        },        methods: {            streamNetworkChange() {                if (!inModal.inbound.canSetTls()) {                    this.inModal.inbound.stream.security = 'none';                }                if (!inModal.inbound.canEnableReality()) {                    this.inModal.inbound.reality = false;                }                if (this.inModal.inbound.protocol == Protocols.VLESS && !inModal.inbound.canEnableTlsFlow()) {                    this.inModal.inbound.settings.vlesses.forEach(client => {                        client.flow = "";                    });                }            },            SSMethodChange() {                if (this.inModal.inbound.isSSMultiUser) {                    if (this.inModal.inbound.settings.shadowsockses.length ==0){                        this.inModal.inbound.settings.shadowsockses = [new Inbound.ShadowsocksSettings.Shadowsocks()];                    }                    if (!this.inModal.inbound.isSS2022) {                        this.inModal.inbound.settings.shadowsockses.forEach(client => {                            client.method = this.inModal.inbound.settings.method;                        })                    } else {                        this.inModal.inbound.settings.shadowsockses.forEach(client => {                            client.method = "";                        })                    }                } else {                    if (this.inModal.inbound.settings.shadowsockses.length > 0){                        this.inModal.inbound.settings.shadowsockses = [];                    }                }            },            setDefaultCertData(index) {                inModal.inbound.stream.tls.certs[index].certFile = app.defaultCert;                inModal.inbound.stream.tls.certs[index].keyFile = app.defaultKey;            },            setDefaultCertXtls(index) {                inModal.inbound.stream.xtls.certs[index].certFile = app.defaultCert;                inModal.inbound.stream.xtls.certs[index].keyFile = app.defaultKey;            },            async getNewX25519Cert() {                inModal.loading(true);                const msg = await HttpUtil.post('/server/getNewX25519Cert');                inModal.loading(false);                if (!msg.success) {                    return;                }                inModal.inbound.stream.reality.privateKey = msg.obj.privateKey;                inModal.inbound.stream.reality.settings.publicKey = msg.obj.publicKey;            }        },    });</script>{{end}}
 |