| 
									
										
										
										
											2023-02-09 19:18:06 +00:00
										 |  |  | {{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" | 
					
						
							| 
									
										
										
										
											2023-12-04 18:17:38 +00:00
										 |  |  |          :class="themeSwitcher.currentTheme" | 
					
						
							| 
									
										
										
										
											2023-02-09 19:18:06 +00:00
										 |  |  |          :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); | 
					
						
							|  |  |  |         }, | 
					
						
							| 
									
										
										
										
											2023-05-08 14:44:22 +00:00
										 |  |  |         show({ title = '', okText = '{{ i18n "sure" }}', inbound = null, dbInbound = null, confirm = (inbound, dbInbound) => {}, isEdit = false }) { | 
					
						
							| 
									
										
										
										
											2023-02-09 19:18:06 +00:00
										 |  |  |             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); | 
					
						
							|  |  |  |         }, | 
					
						
							| 
									
										
										
										
											2024-02-21 11:39:56 +00:00
										 |  |  |         loading(loading=true) { | 
					
						
							| 
									
										
										
										
											2023-02-09 19:18:06 +00:00
										 |  |  |             inModal.confirmLoading = loading; | 
					
						
							|  |  |  |         }, | 
					
						
							|  |  |  |     }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     new Vue({ | 
					
						
							|  |  |  |         delimiters: ['[[', ']]'], | 
					
						
							|  |  |  |         el: '#inbound-modal', | 
					
						
							|  |  |  |         data: { | 
					
						
							|  |  |  |             inModal: inModal, | 
					
						
							| 
									
										
										
										
											2023-04-18 18:04:06 +00:00
										 |  |  |             delayedStart: false, | 
					
						
							| 
									
										
										
										
											2023-02-09 19:18:06 +00:00
										 |  |  |             get inbound() { | 
					
						
							|  |  |  |                 return inModal.inbound; | 
					
						
							|  |  |  |             }, | 
					
						
							|  |  |  |             get dbInbound() { | 
					
						
							|  |  |  |                 return inModal.dbInbound; | 
					
						
							|  |  |  |             }, | 
					
						
							|  |  |  |             get isEdit() { | 
					
						
							|  |  |  |                 return inModal.isEdit; | 
					
						
							|  |  |  |             }, | 
					
						
							| 
									
										
										
										
											2023-04-18 18:04:06 +00:00
										 |  |  |             get client() { | 
					
						
							| 
									
										
										
										
											2023-12-08 17:45:21 +00:00
										 |  |  |                 return inModal.inbound.clients[0]; | 
					
						
							| 
									
										
										
										
											2023-02-09 19:18:06 +00:00
										 |  |  |             }, | 
					
						
							| 
									
										
										
										
											2024-01-02 08:32:21 +00:00
										 |  |  |             get datepicker() { | 
					
						
							|  |  |  |                 return app.datepicker; | 
					
						
							|  |  |  |             }, | 
					
						
							| 
									
										
										
										
											2023-04-18 18:04:06 +00:00
										 |  |  |             get delayedExpireDays() { | 
					
						
							|  |  |  |                 return this.client && this.client.expiryTime < 0 ? this.client.expiryTime / -86400000 : 0; | 
					
						
							| 
									
										
										
										
											2023-02-09 19:18:06 +00:00
										 |  |  |             }, | 
					
						
							| 
									
										
										
										
											2023-05-08 14:44:22 +00:00
										 |  |  |             set delayedExpireDays(days) { | 
					
						
							| 
									
										
										
										
											2023-04-18 18:04:06 +00:00
										 |  |  |                 this.client.expiryTime = -86400000 * days; | 
					
						
							| 
									
										
										
										
											2023-02-09 19:18:06 +00:00
										 |  |  |             }, | 
					
						
							| 
									
										
										
										
											2023-12-08 17:45:21 +00:00
										 |  |  |             get externalProxy() { | 
					
						
							|  |  |  |                 return this.inbound.stream.externalProxy.length > 0; | 
					
						
							| 
									
										
										
										
											2023-05-22 14:01:41 +00:00
										 |  |  |             }, | 
					
						
							| 
									
										
										
										
											2023-12-08 17:45:21 +00:00
										 |  |  |             set externalProxy(value) { | 
					
						
							| 
									
										
										
										
											2023-05-22 14:01:41 +00:00
										 |  |  |                 if (value) { | 
					
						
							| 
									
										
										
										
											2023-12-08 17:45:21 +00:00
										 |  |  |                     inModal.inbound.stream.externalProxy = [{ | 
					
						
							|  |  |  |                         forceTls: "same", | 
					
						
							|  |  |  |                         dest: window.location.hostname, | 
					
						
							|  |  |  |                         port: inModal.inbound.port, | 
					
						
							|  |  |  |                         remark: "" | 
					
						
							|  |  |  |                     }]; | 
					
						
							| 
									
										
										
										
											2023-05-22 14:01:41 +00:00
										 |  |  |                 } else { | 
					
						
							| 
									
										
										
										
											2023-12-08 17:45:21 +00:00
										 |  |  |                     inModal.inbound.stream.externalProxy = []; | 
					
						
							| 
									
										
										
										
											2023-05-22 14:01:41 +00:00
										 |  |  |                 } | 
					
						
							|  |  |  |             } | 
					
						
							| 
									
										
										
										
											2023-04-18 18:04:06 +00:00
										 |  |  |         }, | 
					
						
							|  |  |  |         methods: { | 
					
						
							|  |  |  |             streamNetworkChange() { | 
					
						
							| 
									
										
										
										
											2023-12-08 15:46:44 +00:00
										 |  |  |                 if (!inModal.inbound.canEnableTls()) { | 
					
						
							| 
									
										
										
										
											2023-04-18 18:04:06 +00:00
										 |  |  |                     this.inModal.inbound.stream.security = 'none'; | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  |                 if (!inModal.inbound.canEnableReality()) { | 
					
						
							|  |  |  |                     this.inModal.inbound.reality = false; | 
					
						
							|  |  |  |                 } | 
					
						
							| 
									
										
										
										
											2023-07-17 22:24:26 +00:00
										 |  |  |                 if (this.inModal.inbound.protocol == Protocols.VLESS && !inModal.inbound.canEnableTlsFlow()) { | 
					
						
							|  |  |  |                     this.inModal.inbound.settings.vlesses.forEach(client => { | 
					
						
							|  |  |  |                         client.flow = ""; | 
					
						
							| 
									
										
										
										
											2023-12-13 15:57:36 +00:00
										 |  |  |                     }); | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  |                 if ((this.inModal.inbound.protocol == Protocols.VLESS || this.inModal.inbound.protocol == Protocols.TROJAN) && !inModal.inbound.xtls) { | 
					
						
							|  |  |  |                     this.inModal.inbound.settings.vlesses.forEach(client => { | 
					
						
							|  |  |  |                         client.flow = ""; | 
					
						
							| 
									
										
										
										
											2023-07-17 22:24:26 +00:00
										 |  |  |                     }); | 
					
						
							|  |  |  |                 } | 
					
						
							| 
									
										
										
										
											2023-02-09 19:18:06 +00:00
										 |  |  |             }, | 
					
						
							| 
									
										
										
										
											2023-07-17 23:49:01 +00:00
										 |  |  |             SSMethodChange() { | 
					
						
							|  |  |  |                 if (this.inModal.inbound.isSSMultiUser) { | 
					
						
							|  |  |  |                     if (this.inModal.inbound.settings.shadowsockses.length ==0){ | 
					
						
							|  |  |  |                         this.inModal.inbound.settings.shadowsockses = [new Inbound.ShadowsocksSettings.Shadowsocks()]; | 
					
						
							|  |  |  |                     } | 
					
						
							| 
									
										
										
										
											2023-08-26 12:31:02 +00:00
										 |  |  |                     if (!this.inModal.inbound.isSS2022) { | 
					
						
							| 
									
										
										
										
											2023-07-27 08:28:12 +00:00
										 |  |  |                         this.inModal.inbound.settings.shadowsockses.forEach(client => { | 
					
						
							|  |  |  |                             client.method = this.inModal.inbound.settings.method; | 
					
						
							|  |  |  |                         }) | 
					
						
							|  |  |  |                     } else { | 
					
						
							|  |  |  |                         this.inModal.inbound.settings.shadowsockses.forEach(client => { | 
					
						
							|  |  |  |                             client.method = ""; | 
					
						
							|  |  |  |                         }) | 
					
						
							|  |  |  |                     } | 
					
						
							| 
									
										
										
										
											2023-07-17 23:49:01 +00:00
										 |  |  |                 } else { | 
					
						
							|  |  |  |                     if (this.inModal.inbound.settings.shadowsockses.length > 0){ | 
					
						
							|  |  |  |                         this.inModal.inbound.settings.shadowsockses = []; | 
					
						
							|  |  |  |                     } | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  |             }, | 
					
						
							| 
									
										
										
										
											2023-05-16 21:25:19 +00:00
										 |  |  |             setDefaultCertData(index) { | 
					
						
							|  |  |  |                 inModal.inbound.stream.tls.certs[index].certFile = app.defaultCert; | 
					
						
							|  |  |  |                 inModal.inbound.stream.tls.certs[index].keyFile = app.defaultKey; | 
					
						
							| 
									
										
										
										
											2023-04-09 19:43:18 +00:00
										 |  |  |             }, | 
					
						
							| 
									
										
										
										
											2023-05-16 21:25:19 +00:00
										 |  |  |             setDefaultCertXtls(index) { | 
					
						
							|  |  |  |                 inModal.inbound.stream.xtls.certs[index].certFile = app.defaultCert; | 
					
						
							|  |  |  |                 inModal.inbound.stream.xtls.certs[index].keyFile = app.defaultKey; | 
					
						
							| 
									
										
										
										
											2023-05-01 17:28:00 +00:00
										 |  |  |             }, | 
					
						
							| 
									
										
										
										
											2023-05-08 14:44:22 +00:00
										 |  |  |             async getNewX25519Cert() { | 
					
						
							| 
									
										
										
										
											2023-04-18 18:04:06 +00:00
										 |  |  |                 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; | 
					
						
							| 
									
										
										
										
											2023-02-09 19:18:06 +00:00
										 |  |  |             } | 
					
						
							|  |  |  |         }, | 
					
						
							|  |  |  |     }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | </script> | 
					
						
							| 
									
										
										
										
											2023-03-17 16:07:49 +00:00
										 |  |  | {{end}} |