| 
									
										
										
										
											2023-02-09 19:18:06 +00:00
										 |  |  | <!DOCTYPE html> | 
					
						
							|  |  |  | <html lang="en"> | 
					
						
							|  |  |  | {{template "head" .}} | 
					
						
							|  |  |  | <style> | 
					
						
							|  |  |  |     @media (min-width: 769px) { | 
					
						
							|  |  |  |         .ant-layout-content { | 
					
						
							|  |  |  |             margin: 24px 16px; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     .ant-col-sm-24 { | 
					
						
							|  |  |  |         margin-top: 10px; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     .ant-tabs-bar { | 
					
						
							|  |  |  |         margin: 0; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     .ant-list-item { | 
					
						
							|  |  |  |         display: block; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-03-17 16:07:49 +00:00
										 |  |  |     :not(.ant-card-dark)>.ant-tabs-top-bar { | 
					
						
							| 
									
										
										
										
											2023-02-09 19:18:06 +00:00
										 |  |  |         background: white; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | </style> | 
					
						
							| 
									
										
										
										
											2023-04-18 06:51:12 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-02-09 19:18:06 +00:00
										 |  |  | <body> | 
					
						
							| 
									
										
										
										
											2023-04-18 06:51:12 +00:00
										 |  |  |     <a-layout id="app" v-cloak> | 
					
						
							|  |  |  |         {{ template "commonSider" . }} | 
					
						
							|  |  |  |         <a-layout id="content-layout" :style="siderDrawer.isDarkTheme ? bgDarkStyle : ''"> | 
					
						
							|  |  |  |             <a-layout-content> | 
					
						
							|  |  |  |                 <a-spin :spinning="spinning" :delay="500" tip="loading"> | 
					
						
							|  |  |  |                     <a-space direction="vertical"> | 
					
						
							|  |  |  |                         <a-space direction="horizontal"> | 
					
						
							|  |  |  |                             <a-button type="primary" :disabled="saveBtnDisable" @click="updateAllSetting">{{ i18n "pages.setting.save" }}</a-button> | 
					
						
							|  |  |  |                             <a-button type="danger" :disabled="!saveBtnDisable" @click="restartPanel">{{ i18n "pages.setting.restartPanel" }}</a-button> | 
					
						
							|  |  |  |                         </a-space> | 
					
						
							| 
									
										
										
										
											2023-02-09 19:18:06 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-04-18 06:51:12 +00:00
										 |  |  |                         <a-tabs default-active-key="1" :class="siderDrawer.isDarkTheme ? darkClass : ''"> | 
					
						
							|  |  |  |                             <a-tab-pane key="1" tab='{{ i18n "pages.setting.panelConfig"}}'> | 
					
						
							|  |  |  |                                 <a-list item-layout="horizontal" :style="siderDrawer.isDarkTheme ? 'color: hsla(0,0%,100%,.65);': 'background: white;'"> | 
					
						
							|  |  |  |                                     <setting-list-item type="text" title='{{ i18n "pages.setting.panelListeningIP"}}' desc='{{ i18n "pages.setting.panelListeningIPDesc"}}' v-model="allSetting.webListen"></setting-list-item> | 
					
						
							|  |  |  |                                     <setting-list-item type="number" title='{{ i18n "pages.setting.panelPort"}}' desc='{{ i18n "pages.setting.panelPortDesc"}}' v-model.number="allSetting.webPort"></setting-list-item> | 
					
						
							|  |  |  |                                     <setting-list-item type="text" title='{{ i18n "pages.setting.publicKeyPath"}}' desc='{{ i18n "pages.setting.publicKeyPathDesc"}}' v-model="allSetting.webCertFile"></setting-list-item> | 
					
						
							|  |  |  |                                     <setting-list-item type="text" title='{{ i18n "pages.setting.privateKeyPath"}}' desc='{{ i18n "pages.setting.privateKeyPathDesc"}}' v-model="allSetting.webKeyFile"></setting-list-item> | 
					
						
							|  |  |  |                                     <setting-list-item type="text" title='{{ i18n "pages.setting.panelUrlPath"}}' desc='{{ i18n "pages.setting.panelUrlPathDesc"}}' v-model="allSetting.webBasePath"></setting-list-item> | 
					
						
							| 
									
										
										
										
											2023-04-25 11:30:21 +00:00
										 |  |  |                                     <setting-list-item type="number" title='{{ i18n "pages.setting.sessionMaxAge" }}' desc='{{ i18n "pages.setting.sessionMaxAgeDesc" }}'  v-model="allSetting.sessionMaxAge" :min="0"></setting-list-item> | 
					
						
							| 
									
										
										
										
											2023-04-18 06:51:12 +00:00
										 |  |  |                                     <setting-list-item type="number" title='{{ i18n "pages.setting.expireTimeDiff" }}' desc='{{ i18n "pages.setting.expireTimeDiffDesc" }}'  v-model="allSetting.expireDiff" :min="0"></setting-list-item> | 
					
						
							|  |  |  |                                     <setting-list-item type="number" title='{{ i18n "pages.setting.trafficDiff" }}' desc='{{ i18n "pages.setting.trafficDiffDesc" }}'  v-model="allSetting.trafficDiff" :min="0"></setting-list-item> | 
					
						
							|  |  |  |                                     <a-list-item> | 
					
						
							|  |  |  |                                         <a-row style="padding: 20px"> | 
					
						
							|  |  |  |                                             <a-col :lg="24" :xl="12"> | 
					
						
							|  |  |  |                                                 <a-list-item-meta title="Language" /> | 
					
						
							|  |  |  |                                             </a-col> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                                             <a-col :lg="24" :xl="12"> | 
					
						
							|  |  |  |                                                 <template> | 
					
						
							|  |  |  |                                                     <a-select | 
					
						
							| 
									
										
										
										
											2023-02-09 19:18:06 +00:00
										 |  |  |                                                         ref="selectLang" | 
					
						
							|  |  |  |                                                         v-model="lang" | 
					
						
							|  |  |  |                                                         @change="setLang(lang)" | 
					
						
							| 
									
										
										
										
											2023-03-17 16:07:49 +00:00
										 |  |  |                                                         :dropdown-class-name="siderDrawer.isDarkTheme ? 'ant-card-dark' : ''" | 
					
						
							| 
									
										
										
										
											2023-02-09 19:18:06 +00:00
										 |  |  |                                                         style="width: 100%" | 
					
						
							| 
									
										
										
										
											2023-04-18 06:51:12 +00:00
										 |  |  |                                                     > | 
					
						
							|  |  |  |                                                         <a-select-option :value="l.value" :label="l.value" v-for="l in supportLangs"> | 
					
						
							|  |  |  |                                                             <span role="img" aria-label="l.name" v-text="l.icon"></span>  <span v-text="l.name"></span> | 
					
						
							|  |  |  |                                                         </a-select-option> | 
					
						
							|  |  |  |                                                     </a-select> | 
					
						
							|  |  |  |                                                 </template> | 
					
						
							|  |  |  |                                             </a-col> | 
					
						
							|  |  |  |                                         </a-row> | 
					
						
							|  |  |  |                                     </a-list-item> | 
					
						
							|  |  |  |                                 </a-list> | 
					
						
							|  |  |  |                             </a-tab-pane> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                             <a-tab-pane key="2" tab='{{ i18n "pages.setting.userSetting"}}'> | 
					
						
							|  |  |  |                                 <a-form :style="siderDrawer.isDarkTheme ? 'color: hsla(0,0%,100%,.65); padding: 20px;': 'background: white; padding: 20px;'"> | 
					
						
							|  |  |  |                                     <a-form-item label='{{ i18n "pages.setting.oldUsername"}}'> | 
					
						
							|  |  |  |                                         <a-input v-model="user.oldUsername" style="max-width: 300px"></a-input> | 
					
						
							|  |  |  |                                     </a-form-item> | 
					
						
							|  |  |  |                                     <a-form-item label='{{ i18n "pages.setting.currentPassword"}}'> | 
					
						
							|  |  |  |                                         <a-input type="password" v-model="user.oldPassword" style="max-width: 300px"></a-input> | 
					
						
							|  |  |  |                                     </a-form-item> | 
					
						
							|  |  |  |                                     <a-form-item label='{{ i18n "pages.setting.newUsername"}}'> | 
					
						
							|  |  |  |                                         <a-input v-model="user.newUsername" style="max-width: 300px"></a-input> | 
					
						
							|  |  |  |                                     </a-form-item> | 
					
						
							|  |  |  |                                     <a-form-item label='{{ i18n "pages.setting.newPassword"}}'> | 
					
						
							|  |  |  |                                         <a-input type="password" v-model="user.newPassword" style="max-width: 300px"></a-input> | 
					
						
							|  |  |  |                                     </a-form-item> | 
					
						
							|  |  |  |                                     <a-form-item> | 
					
						
							|  |  |  |                                         <a-button type="primary" @click="updateUser">{{ i18n "confirm" }}</a-button> | 
					
						
							|  |  |  |                                     </a-form-item> | 
					
						
							|  |  |  |                                 </a-form> | 
					
						
							| 
									
										
										
										
											2023-04-21 15:30:14 +00:00
										 |  |  |                                 <a-form :style="siderDrawer.isDarkTheme ? 'color: hsla(0,0%,100%,.65); padding: 20px;': 'background: white; padding: 20px;'"> | 
					
						
							|  |  |  |                                     <a-list-item style="padding: 20px"> | 
					
						
							|  |  |  |                                        <a-row> | 
					
						
							|  |  |  |                                          <a-col :lg="24" :xl="12"> | 
					
						
							|  |  |  |                                             <a-list-item-meta title='{{ i18n "pages.setting.loginSecurity" }}' description='{{ i18n "pages.setting.loginSecurityDesc" }}'/> | 
					
						
							|  |  |  |                                          </a-col> | 
					
						
							|  |  |  |                                          <a-col :lg="24" :xl="12"> | 
					
						
							|  |  |  |                                             <template> | 
					
						
							|  |  |  |                                                 <a-switch @change="toggleToken(allSetting.secretEnable)" v-model="allSetting.secretEnable"></a-switch> | 
					
						
							|  |  |  |                                             </template> | 
					
						
							|  |  |  |                                          </a-col> | 
					
						
							|  |  |  |                                        </a-row> | 
					
						
							|  |  |  |                                     </a-list-item> | 
					
						
							|  |  |  |                                     <a-list-item style="padding: 20px"> | 
					
						
							|  |  |  |                                       <a-row> | 
					
						
							|  |  |  |                                         <a-col :lg="24" :xl="12"> | 
					
						
							|  |  |  |                                           <a-list-item-meta title='{{ i18n "pages.setting.secretToken" }}' description='{{ i18n "pages.setting.secretTokenDesc" }}'/> | 
					
						
							|  |  |  |                                  | 
					
						
							|  |  |  |                                         </a-col> | 
					
						
							|  |  |  |                                         <a-col :lg="24" :xl="12"> | 
					
						
							|  |  |  |                                            <svg  | 
					
						
							|  |  |  |                                                   @click="getNewSecret" | 
					
						
							|  |  |  |                                                   xmlns="http://www.w3.org/2000/svg" width="16" height="16" fill="currentColor" class="anticon anticon-question-circle" viewBox="0 0 16 16"> <path d="M11.534 7h3.932a.25.25 0 0 1 .192.41l-1.966 2.36a.25.25 0 0 1-.384 0l-1.966-2.36a.25.25 0 0 1 .192-.41zm-11 2h3.932a.25.25 0 0 0 .192-.41L2.692 6.23a.25.25 0 0 0-.384 0L.342 8.59A.25.25 0 0 0 .534 9z"/> <path fill-rule="evenodd" d="M8 3c-1.552 0-2.94.707-3.857 1.818a.5.5 0 1 1-.771-.636A6.002 6.002 0 0 1 13.917 7H12.9A5.002 5.002 0 0 0 8 3zM3.1 9a5.002 5.002 0 0 0 8.757 2.182.5.5 0 1 1 .771.636A6.002 6.002 0 0 1 2.083 9H3.1z"/>  | 
					
						
							|  |  |  |                                            </svg> | 
					
						
							|  |  |  |                                            <template> | 
					
						
							|  |  |  |                                                <a-textarea type="text" id='token' :disabled="!allSetting.secretEnable" v-model="user.loginSecret"></a-textarea> | 
					
						
							|  |  |  |                                            </template> | 
					
						
							|  |  |  |                                         </a-col> | 
					
						
							|  |  |  |                                       </a-row> | 
					
						
							|  |  |  |                                     </a-list-item> | 
					
						
							|  |  |  |                                     <a-button type="primary" @click="updateSecret">{{ i18n "confirm" }}</a-button> | 
					
						
							|  |  |  |                                 </a-form> | 
					
						
							| 
									
										
										
										
											2023-04-18 06:51:12 +00:00
										 |  |  |                             </a-tab-pane> | 
					
						
							|  |  |  |                             <a-tab-pane key="3" tab='{{ i18n "pages.setting.xrayConfiguration"}}'> | 
					
						
							|  |  |  |                                 <a-list item-layout="horizontal" :style="siderDrawer.isDarkTheme ? 'color: hsla(0,0%,100%,.65);': 'background: white;'"> | 
					
						
							| 
									
										
										
										
											2023-04-18 16:54:32 +00:00
										 |  |  |                                     <a-divider>{{ i18n "pages.setting.actions"}}</a-divider> | 
					
						
							|  |  |  |                                     <a-space direction="horizontal" style="padding: 0 20px"> | 
					
						
							|  |  |  |                                         <a-button type="primary" @click="resetXrayConfigToDefault">{{ i18n "pages.setting.resetDefaultConfig" }}</a-button> | 
					
						
							|  |  |  |                                     </a-space> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                                     <a-divider>{{ i18n "pages.setting.basicTemplate"}}</a-divider> | 
					
						
							|  |  |  |                                     <a-collapse> | 
					
						
							|  |  |  |                                         <a-collapse-panel header='{{ i18n "pages.setting.generalConfigs"}}'> | 
					
						
							| 
									
										
										
										
											2023-04-18 23:32:53 +00:00
										 |  |  |                                             <a-row :xs="24" :sm="24" :lg="12"> | 
					
						
							|  |  |  |                                                 <h2 style="color: inherit; font-weight: bold; font-size: 18px; padding: 10px 20px; border-bottom: 2px solid;"> | 
					
						
							|  |  |  |                                                     <a-icon type="warning" style="color: inherit; font-size: 24px;"></a-icon> | 
					
						
							|  |  |  |                                                     {{ i18n "pages.setting.generalConfigsDesc" }} | 
					
						
							|  |  |  |                                                 </h2> | 
					
						
							|  |  |  |                                             </a-row> | 
					
						
							| 
									
										
										
										
											2023-04-18 16:54:32 +00:00
										 |  |  |                                             <setting-list-item type="switch" title='{{ i18n "pages.setting.xrayConfigTorrent"}}' desc='{{ i18n "pages.setting.xrayConfigTorrentDesc"}}'  v-model="torrentSettings"></setting-list-item> | 
					
						
							|  |  |  |                                             <setting-list-item type="switch" title='{{ i18n "pages.setting.xrayConfigPrivateIp"}}' desc='{{ i18n "pages.setting.xrayConfigPrivateIpDesc"}}'  v-model="privateIpSettings"></setting-list-item> | 
					
						
							|  |  |  |                                             <setting-list-item type="switch" title='{{ i18n "pages.setting.xrayConfigAds"}}' desc='{{ i18n "pages.setting.xrayConfigAdsDesc"}}'  v-model="AdsSettings"></setting-list-item> | 
					
						
							|  |  |  |                                             <setting-list-item type="switch" title='{{ i18n "pages.setting.xrayConfigPorn"}}' desc='{{ i18n "pages.setting.xrayConfigPornDesc"}}'  v-model="PornSettings"></setting-list-item> | 
					
						
							|  |  |  |                                         </a-collapse-panel> | 
					
						
							|  |  |  |                                         <a-collapse-panel header='{{ i18n "pages.setting.countryConfigs"}}'> | 
					
						
							| 
									
										
										
										
											2023-04-18 23:32:53 +00:00
										 |  |  |                                             <a-row :xs="24" :sm="24" :lg="12"> | 
					
						
							|  |  |  |                                                 <h2 style="color: inherit; font-weight: bold; font-size: 18px; padding: 10px 20px; border-bottom: 2px solid;"> | 
					
						
							|  |  |  |                                                     <a-icon type="warning" style="color: inherit; font-size: 24px;"></a-icon> | 
					
						
							|  |  |  |                                                     {{ i18n "pages.setting.countryConfigsDesc" }} | 
					
						
							|  |  |  |                                                 </h2> | 
					
						
							|  |  |  |                                             </a-row> | 
					
						
							| 
									
										
										
										
											2023-04-18 16:54:32 +00:00
										 |  |  |                                             <setting-list-item type="switch" title='{{ i18n "pages.setting.xrayConfigIRIp"}}' desc='{{ i18n "pages.setting.xrayConfigIRIpDesc"}}'  v-model="IRIpSettings"></setting-list-item> | 
					
						
							|  |  |  |                                             <setting-list-item type="switch" title='{{ i18n "pages.setting.xrayConfigIRDomain"}}' desc='{{ i18n "pages.setting.xrayConfigIRDomainDesc"}}'  v-model="IRDomainSettings"></setting-list-item> | 
					
						
							|  |  |  |                                             <setting-list-item type="switch" title='{{ i18n "pages.setting.xrayConfigChinaIp"}}' desc='{{ i18n "pages.setting.xrayConfigChinaIpDesc"}}'  v-model="ChinaIpSettings"></setting-list-item> | 
					
						
							|  |  |  |                                             <setting-list-item type="switch" title='{{ i18n "pages.setting.xrayConfigChinaDomain"}}' desc='{{ i18n "pages.setting.xrayConfigChinaDomainDesc"}}'  v-model="ChinaDomainSettings"></setting-list-item> | 
					
						
							|  |  |  |                                             <setting-list-item type="switch" title='{{ i18n "pages.setting.xrayConfigRussiaIp"}}' desc='{{ i18n "pages.setting.xrayConfigRussiaIpDesc"}}'  v-model="RussiaIpSettings"></setting-list-item> | 
					
						
							|  |  |  |                                             <setting-list-item type="switch" title='{{ i18n "pages.setting.xrayConfigRussiaDomain"}}' desc='{{ i18n "pages.setting.xrayConfigRussiaDomainDesc"}}'  v-model="RussiaDomainSettings"></setting-list-item> | 
					
						
							|  |  |  |                                         </a-collapse-panel> | 
					
						
							|  |  |  |                                         <a-collapse-panel header='{{ i18n "pages.setting.ipv4Configs"}}'> | 
					
						
							| 
									
										
										
										
											2023-04-18 23:32:53 +00:00
										 |  |  |                                             <a-row :xs="24" :sm="24" :lg="12"> | 
					
						
							|  |  |  |                                                 <h2 style="color: inherit; font-weight: bold; font-size: 18px; padding: 10px 20px; border-bottom: 2px solid;"> | 
					
						
							|  |  |  |                                                     <a-icon type="warning" style="color: inherit; font-size: 24px;"></a-icon> | 
					
						
							|  |  |  |                                                     {{ i18n "pages.setting.ipv4ConfigsDesc" }} | 
					
						
							|  |  |  |                                                 </h2> | 
					
						
							|  |  |  |                                             </a-row> | 
					
						
							| 
									
										
										
										
											2023-04-18 16:54:32 +00:00
										 |  |  |                                             <setting-list-item type="switch" title='{{ i18n "pages.setting.xrayConfigGoogleIPv4"}}' desc='{{ i18n "pages.setting.xrayConfigGoogleIPv4Desc"}}'  v-model="GoogleIPv4Settings"></setting-list-item> | 
					
						
							|  |  |  |                                             <setting-list-item type="switch" title='{{ i18n "pages.setting.xrayConfigNetflixIPv4"}}' desc='{{ i18n "pages.setting.xrayConfigNetflixIPv4Desc"}}'  v-model="NetflixIPv4Settings"></setting-list-item> | 
					
						
							|  |  |  |                                         </a-collapse-panel> | 
					
						
							|  |  |  |                                         <a-collapse-panel header='{{ i18n "pages.setting.warpConfigs"}}'> | 
					
						
							| 
									
										
										
										
											2023-04-18 23:32:53 +00:00
										 |  |  |                                             <a-row :xs="24" :sm="24" :lg="12"> | 
					
						
							|  |  |  |                                                 <h2 style="color: inherit; font-weight: bold; font-size: 18px; padding: 10px 20px; border-bottom: 2px solid;"> | 
					
						
							|  |  |  |                                                     <a-icon type="warning" style="color: inherit; font-size: 24px;"></a-icon> | 
					
						
							|  |  |  |                                                     {{ i18n "pages.setting.warpConfigsDesc" }} | 
					
						
							|  |  |  |                                                 </h2> | 
					
						
							|  |  |  |                                             </a-row> | 
					
						
							| 
									
										
										
										
											2023-04-18 16:54:32 +00:00
										 |  |  |                                             <setting-list-item type="switch" title='{{ i18n "pages.setting.xrayConfigGoogleWARP"}}' desc='{{ i18n "pages.setting.xrayConfigGoogleWARPDesc"}}'  v-model="GoogleWARPSettings"></setting-list-item> | 
					
						
							|  |  |  |                                             <setting-list-item type="switch" title='{{ i18n "pages.setting.xrayConfigOpenAIWARP"}}' desc='{{ i18n "pages.setting.xrayConfigOpenAIWARPDesc"}}'  v-model="OpenAIWARPSettings"></setting-list-item> | 
					
						
							|  |  |  |                                             <setting-list-item type="switch" title='{{ i18n "pages.setting.xrayConfigNetflixWARP"}}' desc='{{ i18n "pages.setting.xrayConfigNetflixWARPDesc"}}'  v-model="NetflixWARPSettings"></setting-list-item> | 
					
						
							|  |  |  |                                             <setting-list-item type="switch" title='{{ i18n "pages.setting.xrayConfigSpotifyWARP"}}' desc='{{ i18n "pages.setting.xrayConfigSpotifyWARPDesc"}}'  v-model="SpotifyWARPSettings"></setting-list-item> | 
					
						
							|  |  |  |                                         </a-collapse-panel> | 
					
						
							|  |  |  |                                     </a-collapse> | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-04-18 06:51:12 +00:00
										 |  |  |                                     <a-divider>{{ i18n "pages.setting.advancedTemplate"}}</a-divider> | 
					
						
							|  |  |  |                                     <a-collapse> | 
					
						
							|  |  |  |                                         <a-collapse-panel header='{{ i18n "pages.setting.xrayConfigInbounds"}}'> | 
					
						
							|  |  |  |                                             <setting-list-item type="textarea" title='{{ i18n "pages.setting.xrayConfigInbounds"}}' desc='{{ i18n "pages.setting.xrayConfigInboundsDesc"}}' v-model="inboundSettings"></setting-list-item> | 
					
						
							|  |  |  |                                         </a-collapse-panel> | 
					
						
							|  |  |  |                                         <a-collapse-panel header='{{ i18n "pages.setting.xrayConfigOutbounds"}}'> | 
					
						
							|  |  |  |                                             <setting-list-item type="textarea" title='{{ i18n "pages.setting.xrayConfigOutbounds"}}' desc='{{ i18n "pages.setting.xrayConfigOutboundsDesc"}}' v-model="outboundSettings"></setting-list-item> | 
					
						
							|  |  |  |                                         </a-collapse-panel> | 
					
						
							|  |  |  |                                         <a-collapse-panel header='{{ i18n "pages.setting.xrayConfigRoutings"}}'> | 
					
						
							|  |  |  |                                             <setting-list-item type="textarea" title='{{ i18n "pages.setting.xrayConfigRoutings"}}' desc='{{ i18n "pages.setting.xrayConfigRoutingsDesc"}}' v-model="routingRuleSettings"></setting-list-item> | 
					
						
							|  |  |  |                                         </a-collapse-panel> | 
					
						
							|  |  |  |                                     </a-collapse> | 
					
						
							| 
									
										
										
										
											2023-04-18 16:54:32 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-04-18 06:51:12 +00:00
										 |  |  |                                     <a-divider>{{ i18n "pages.setting.completeTemplate"}}</a-divider> | 
					
						
							|  |  |  |                                     <setting-list-item type="textarea" title='{{ i18n "pages.setting.xrayConfigTemplate"}}' desc='{{ i18n "pages.setting.xrayConfigTemplateDesc"}}' v-model="allSetting.xrayTemplateConfig"></setting-list-item> | 
					
						
							|  |  |  |                                 </a-list> | 
					
						
							|  |  |  |                             </a-tab-pane> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                             <a-tab-pane key="4" tab='{{ i18n "pages.setting.TGReminder"}}'> | 
					
						
							|  |  |  |                                 <a-list item-layout="horizontal" :style="siderDrawer.isDarkTheme ? 'color: hsla(0,0%,100%,.65);': 'background: white;'"> | 
					
						
							|  |  |  |                                     <setting-list-item type="switch" title='{{ i18n "pages.setting.telegramBotEnable" }}' desc='{{ i18n "pages.setting.telegramBotEnableDesc" }}' v-model="allSetting.tgBotEnable"></setting-list-item> | 
					
						
							|  |  |  |                                     <setting-list-item type="text" title='{{ i18n "pages.setting.telegramToken"}}' desc='{{ i18n "pages.setting.telegramTokenDesc"}}' v-model="allSetting.tgBotToken"></setting-list-item> | 
					
						
							|  |  |  |                                     <setting-list-item type="text" title='{{ i18n "pages.setting.telegramChatId"}}' desc='{{ i18n "pages.setting.telegramChatIdDesc"}}' v-model="allSetting.tgBotChatId"></setting-list-item> | 
					
						
							|  |  |  |                                     <setting-list-item type="text" title='{{ i18n "pages.setting.telegramNotifyTime"}}' desc='{{ i18n "pages.setting.telegramNotifyTimeDesc"}}' v-model="allSetting.tgRunTime"></setting-list-item> | 
					
						
							|  |  |  |                                     <setting-list-item type="switch" title='{{ i18n "pages.setting.tgNotifyBackup" }}' desc='{{ i18n "pages.setting.tgNotifyBackupDesc" }}' v-model="allSetting.tgBotBackup"></setting-list-item> | 
					
						
							|  |  |  |                                     <setting-list-item type="number" title='{{ i18n "pages.setting.tgNotifyCpu" }}' desc='{{ i18n "pages.setting.tgNotifyCpuDesc" }}' v-model="allSetting.tgCpu" :min="0" :max="100"></setting-list-item> | 
					
						
							|  |  |  |                                 </a-list> | 
					
						
							|  |  |  |                             </a-tab-pane> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                             <a-tab-pane key="5" tab='{{ i18n "pages.setting.otherSetting"}}'> | 
					
						
							|  |  |  |                                 <a-list item-layout="horizontal" :style="siderDrawer.isDarkTheme ? 'color: hsla(0,0%,100%,.65);': 'background: white;'"> | 
					
						
							|  |  |  |                                     <setting-list-item type="text" title='{{ i18n "pages.setting.timeZonee"}}' desc='{{ i18n "pages.setting.timeZoneDesc"}}' v-model="allSetting.timeLocation"></setting-list-item> | 
					
						
							|  |  |  |                                 </a-list> | 
					
						
							|  |  |  |                             </a-tab-pane> | 
					
						
							|  |  |  |                         </a-tabs> | 
					
						
							|  |  |  |                     </a-space> | 
					
						
							|  |  |  |                 </a-spin> | 
					
						
							|  |  |  |             </a-layout-content> | 
					
						
							|  |  |  |         </a-layout> | 
					
						
							| 
									
										
										
										
											2023-02-09 19:18:06 +00:00
										 |  |  |     </a-layout> | 
					
						
							| 
									
										
										
										
											2023-04-18 06:51:12 +00:00
										 |  |  |     {{template "js" .}} | 
					
						
							|  |  |  |     {{template "component/setting"}} | 
					
						
							|  |  |  |     <script> | 
					
						
							| 
									
										
										
										
											2023-02-09 19:18:06 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-04-18 16:54:32 +00:00
										 |  |  |         const app = new Vue({ | 
					
						
							| 
									
										
										
										
											2023-04-18 06:52:44 +00:00
										 |  |  |             delimiters: ['[[', ']]'], | 
					
						
							|  |  |  |             el: '#app', | 
					
						
							|  |  |  |             data: { | 
					
						
							|  |  |  |                 siderDrawer, | 
					
						
							|  |  |  |                 spinning: false, | 
					
						
							|  |  |  |                 oldAllSetting: new AllSetting(), | 
					
						
							|  |  |  |                 allSetting: new AllSetting(), | 
					
						
							|  |  |  |                 saveBtnDisable: true, | 
					
						
							| 
									
										
										
										
											2023-04-21 15:30:14 +00:00
										 |  |  |                 user: new User(), | 
					
						
							| 
									
										
										
										
											2023-04-18 06:52:44 +00:00
										 |  |  |                 lang: getLang(), | 
					
						
							|  |  |  |                 ipv4Settings: { | 
					
						
							|  |  |  |                     tag: "IPv4", | 
					
						
							|  |  |  |                     protocol: "freedom", | 
					
						
							|  |  |  |                     settings: { | 
					
						
							|  |  |  |                         domainStrategy: "UseIPv4" | 
					
						
							|  |  |  |                     } | 
					
						
							|  |  |  |                 }, | 
					
						
							|  |  |  |                 warpSettings: { | 
					
						
							|  |  |  |                     tag: "WARP", | 
					
						
							|  |  |  |                     protocol: "socks", | 
					
						
							|  |  |  |                     settings: { | 
					
						
							|  |  |  |                         servers: [ | 
					
						
							|  |  |  |                             { | 
					
						
							|  |  |  |                                 address: "127.0.0.1", | 
					
						
							|  |  |  |                                 port: 40000 | 
					
						
							|  |  |  |                             } | 
					
						
							|  |  |  |                         ] | 
					
						
							|  |  |  |                     } | 
					
						
							|  |  |  |                 }, | 
					
						
							|  |  |  |                 settingsData: { | 
					
						
							|  |  |  |                     protocols: { | 
					
						
							|  |  |  |                         bittorrent: ["bittorrent"], | 
					
						
							|  |  |  |                     }, | 
					
						
							|  |  |  |                     ips: { | 
					
						
							|  |  |  |                         local: ["geoip:private"], | 
					
						
							|  |  |  |                         google: ["geoip:google"], | 
					
						
							|  |  |  |                         cn: ["geoip:cn"], | 
					
						
							|  |  |  |                         ir: ["geoip:ir"], | 
					
						
							| 
									
										
										
										
											2023-04-18 16:53:12 +00:00
										 |  |  |                         ru: ["geoip:ru"], | 
					
						
							| 
									
										
										
										
											2023-04-18 06:52:44 +00:00
										 |  |  |                     }, | 
					
						
							|  |  |  |                     domains: { | 
					
						
							|  |  |  |                         ads: [ | 
					
						
							|  |  |  |                             "geosite:category-ads-all", | 
					
						
							|  |  |  |                             "geosite:category-ads", | 
					
						
							|  |  |  |                             "geosite:google-ads", | 
					
						
							|  |  |  |                             "geosite:spotify-ads" | 
					
						
							|  |  |  |                         ], | 
					
						
							|  |  |  |                         porn: ["geosite:category-porn"], | 
					
						
							|  |  |  |                         openai: ["geosite:openai"], | 
					
						
							|  |  |  |                         google: ["geosite:google"], | 
					
						
							|  |  |  |                         spotify: ["geosite:spotify"], | 
					
						
							|  |  |  |                         netflix: ["geosite:netflix"], | 
					
						
							|  |  |  |                         cn: ["geosite:cn"], | 
					
						
							| 
									
										
										
										
											2023-04-18 16:53:12 +00:00
										 |  |  |                         ru: ["geosite:category-ru-gov"], | 
					
						
							| 
									
										
										
										
											2023-04-18 06:52:44 +00:00
										 |  |  |                         ir: [ | 
					
						
							|  |  |  |                             "regexp:.*\\.ir$", | 
					
						
							|  |  |  |                             "ext:iran.dat:ir", | 
					
						
							|  |  |  |                             "ext:iran.dat:other", | 
					
						
							| 
									
										
										
										
											2023-04-18 16:53:12 +00:00
										 |  |  |                             "ext:iran.dat:ads", | 
					
						
							|  |  |  |                             "geosite:category-ir" | 
					
						
							| 
									
										
										
										
											2023-04-18 06:52:44 +00:00
										 |  |  |                         ] | 
					
						
							|  |  |  |                     }, | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  |             }, | 
					
						
							| 
									
										
										
										
											2023-04-18 06:53:15 +00:00
										 |  |  |             methods: { | 
					
						
							| 
									
										
										
										
											2023-04-21 15:30:14 +00:00
										 |  |  |                 loading(spinning = true , obj) { | 
					
						
							|  |  |  |                 if(obj == null) | 
					
						
							|  |  |  |                   this.spinning = spinning; | 
					
						
							| 
									
										
										
										
											2023-04-18 06:53:15 +00:00
										 |  |  |                 }, | 
					
						
							|  |  |  |                 async getAllSetting() { | 
					
						
							| 
									
										
										
										
											2023-04-23 23:18:17 +00:00
										 |  |  |                     this.loading(true); | 
					
						
							| 
									
										
										
										
											2023-04-18 06:53:15 +00:00
										 |  |  |                     const msg = await HttpUtil.post("/xui/setting/all"); | 
					
						
							| 
									
										
										
										
											2023-04-23 23:18:17 +00:00
										 |  |  |                     this.loading(false); | 
					
						
							| 
									
										
										
										
											2023-04-18 06:53:15 +00:00
										 |  |  |                     if (msg.success) { | 
					
						
							|  |  |  |                         this.oldAllSetting = new AllSetting(msg.obj); | 
					
						
							|  |  |  |                         this.allSetting = new AllSetting(msg.obj); | 
					
						
							|  |  |  |                         this.saveBtnDisable = true; | 
					
						
							|  |  |  |                     } | 
					
						
							| 
									
										
										
										
											2023-04-21 15:30:14 +00:00
										 |  |  |                     await this.getUserSecret(); | 
					
						
							| 
									
										
										
										
											2023-04-18 06:53:15 +00:00
										 |  |  |                 }, | 
					
						
							|  |  |  |                 async updateAllSetting() { | 
					
						
							| 
									
										
										
										
											2023-04-23 23:18:17 +00:00
										 |  |  |                     this.loading(true); | 
					
						
							| 
									
										
										
										
											2023-04-18 06:53:15 +00:00
										 |  |  |                     const msg = await HttpUtil.post("/xui/setting/update", this.allSetting); | 
					
						
							| 
									
										
										
										
											2023-04-23 23:18:17 +00:00
										 |  |  |                     this.loading(false); | 
					
						
							| 
									
										
										
										
											2023-04-18 06:53:15 +00:00
										 |  |  |                     if (msg.success) { | 
					
						
							|  |  |  |                         await this.getAllSetting(); | 
					
						
							|  |  |  |                     } | 
					
						
							|  |  |  |                 }, | 
					
						
							|  |  |  |                 async updateUser() { | 
					
						
							| 
									
										
										
										
											2023-04-23 23:18:17 +00:00
										 |  |  |                     this.loading(true); | 
					
						
							| 
									
										
										
										
											2023-04-18 06:53:15 +00:00
										 |  |  |                     const msg = await HttpUtil.post("/xui/setting/updateUser", this.user); | 
					
						
							| 
									
										
										
										
											2023-04-23 23:18:17 +00:00
										 |  |  |                     this.loading(false); | 
					
						
							| 
									
										
										
										
											2023-04-18 06:53:15 +00:00
										 |  |  |                     if (msg.success) { | 
					
						
							|  |  |  |                         this.user = {}; | 
					
						
							| 
									
										
										
										
											2023-05-02 12:49:49 +00:00
										 |  |  |                         window.location.replace("/logout") | 
					
						
							| 
									
										
										
										
											2023-04-18 06:53:15 +00:00
										 |  |  |                     } | 
					
						
							|  |  |  |                 }, | 
					
						
							|  |  |  |                 async restartPanel() { | 
					
						
							|  |  |  |                     await new Promise(resolve => { | 
					
						
							|  |  |  |                         this.$confirm({ | 
					
						
							|  |  |  |                             title: '{{ i18n "pages.setting.restartPanel" }}', | 
					
						
							|  |  |  |                             content: '{{ i18n "pages.setting.restartPanelDesc" }}', | 
					
						
							|  |  |  |                             okText: '{{ i18n "sure" }}', | 
					
						
							|  |  |  |                             cancelText: '{{ i18n "cancel" }}', | 
					
						
							|  |  |  |                             onOk: () => resolve(), | 
					
						
							|  |  |  |                         }); | 
					
						
							| 
									
										
										
										
											2023-02-09 19:18:06 +00:00
										 |  |  |                     }); | 
					
						
							| 
									
										
										
										
											2023-04-23 23:18:17 +00:00
										 |  |  |                     this.loading(true); | 
					
						
							| 
									
										
										
										
											2023-04-18 06:53:15 +00:00
										 |  |  |                     const msg = await HttpUtil.post("/xui/setting/restartPanel"); | 
					
						
							| 
									
										
										
										
											2023-04-23 23:18:17 +00:00
										 |  |  |                     this.loading(false); | 
					
						
							| 
									
										
										
										
											2023-04-18 06:53:15 +00:00
										 |  |  |                     if (msg.success) { | 
					
						
							| 
									
										
										
										
											2023-04-23 23:18:17 +00:00
										 |  |  |                         this.loading(true); | 
					
						
							| 
									
										
										
										
											2023-04-18 06:53:15 +00:00
										 |  |  |                         await PromiseUtil.sleep(5000); | 
					
						
							|  |  |  |                         location.reload(); | 
					
						
							|  |  |  |                     } | 
					
						
							|  |  |  |                 }, | 
					
						
							| 
									
										
										
										
											2023-04-21 15:30:14 +00:00
										 |  |  |                 async getUserSecret(){ | 
					
						
							|  |  |  |                 const user_msg = await HttpUtil.post("/xui/setting/getUserSecret", this.user); | 
					
						
							|  |  |  |                 if (user_msg.success){ | 
					
						
							|  |  |  |                     this.user = user_msg.obj; | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  |                 this.loading(false); | 
					
						
							| 
									
										
										
										
											2023-05-02 12:49:49 +00:00
										 |  |  |                 }, | 
					
						
							|  |  |  |                 async updateSecret(){ | 
					
						
							| 
									
										
										
										
											2023-04-23 23:18:17 +00:00
										 |  |  |                 this.loading(true); | 
					
						
							| 
									
										
										
										
											2023-04-21 15:30:14 +00:00
										 |  |  |                 const msg = await HttpUtil.post("/xui/setting/updateUserSecret", this.user); | 
					
						
							|  |  |  |                 if (msg.success){ | 
					
						
							|  |  |  |                     this.user = msg.obj; | 
					
						
							| 
									
										
										
										
											2023-05-02 12:49:49 +00:00
										 |  |  |                     window.location.replace("/logout") | 
					
						
							| 
									
										
										
										
											2023-04-21 15:30:14 +00:00
										 |  |  |                 } | 
					
						
							| 
									
										
										
										
											2023-04-23 23:18:17 +00:00
										 |  |  |                 this.loading(false); | 
					
						
							| 
									
										
										
										
											2023-04-21 15:30:14 +00:00
										 |  |  |                 await this.updateAllSetting(); | 
					
						
							| 
									
										
										
										
											2023-05-02 12:49:49 +00:00
										 |  |  |                 }, | 
					
						
							|  |  |  |                 async getNewSecret(){ | 
					
						
							| 
									
										
										
										
											2023-04-23 23:18:17 +00:00
										 |  |  |                 this.loading(true); | 
					
						
							| 
									
										
										
										
											2023-04-21 15:30:14 +00:00
										 |  |  |                 await PromiseUtil.sleep(1000); | 
					
						
							|  |  |  |                 var chars = 'abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ1234567890'; | 
					
						
							|  |  |  |                 var string = ''; | 
					
						
							|  |  |  |                 var len = 64; | 
					
						
							|  |  |  |                 for(var ii=0; ii<len; ii++){ | 
					
						
							|  |  |  |                     string += chars[Math.floor(Math.random() * chars.length)]; | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  |                 this.user.loginSecret = string; | 
					
						
							|  |  |  |                 document.getElementById('token').value =this.user.loginSecret;  | 
					
						
							| 
									
										
										
										
											2023-04-23 23:18:17 +00:00
										 |  |  |                 this.loading(false); | 
					
						
							| 
									
										
										
										
											2023-05-02 12:49:49 +00:00
										 |  |  |                 }, | 
					
						
							|  |  |  |                 async toggleToken(value){ | 
					
						
							| 
									
										
										
										
											2023-04-21 15:30:14 +00:00
										 |  |  |                 if(value) | 
					
						
							|  |  |  |                   this.getNewSecret(); | 
					
						
							|  |  |  |                 else  | 
					
						
							|  |  |  |                   this.user.loginSecret = ""; | 
					
						
							| 
									
										
										
										
											2023-05-02 12:49:49 +00:00
										 |  |  |                 }, | 
					
						
							| 
									
										
										
										
											2023-04-18 16:53:51 +00:00
										 |  |  |                 async resetXrayConfigToDefault() { | 
					
						
							| 
									
										
										
										
											2023-04-23 23:18:17 +00:00
										 |  |  |                     this.loading(true); | 
					
						
							| 
									
										
										
										
											2023-04-18 16:53:51 +00:00
										 |  |  |                     const msg = await HttpUtil.get("/xui/setting/getDefaultJsonConfig"); | 
					
						
							| 
									
										
										
										
											2023-04-23 23:18:17 +00:00
										 |  |  |                     this.loading(false); | 
					
						
							| 
									
										
										
										
											2023-04-18 16:53:51 +00:00
										 |  |  |                     if (msg.success) { | 
					
						
							|  |  |  |                         this.templateSettings = JSON.parse(JSON.stringify(msg.obj, null, 2)); | 
					
						
							|  |  |  |                         this.saveBtnDisable = true; | 
					
						
							|  |  |  |                     } | 
					
						
							|  |  |  |                 }, | 
					
						
							| 
									
										
										
										
											2023-04-18 06:53:15 +00:00
										 |  |  |                 checkRequiredOutbounds() { | 
					
						
							|  |  |  |                     const newTemplateSettings = this.templateSettings; | 
					
						
							|  |  |  |                     const haveIPv4Outbounds = newTemplateSettings.outbounds.some((o) => o?.tag === "IPv4"); | 
					
						
							|  |  |  |                     const haveIPv4Rules = newTemplateSettings.routing.rules.some((r) => r?.outboundTag === "IPv4"); | 
					
						
							|  |  |  |                     const haveWARPOutbounds = newTemplateSettings.outbounds.some((o) => o?.tag === "WARP"); | 
					
						
							|  |  |  |                     const haveWARPRules = newTemplateSettings.routing.rules.some((r) => r?.outboundTag === "WARP"); | 
					
						
							|  |  |  |                     if (haveWARPRules && !haveWARPOutbounds) { | 
					
						
							|  |  |  |                         newTemplateSettings.outbounds.push(this.warpSettings); | 
					
						
							|  |  |  |                     } | 
					
						
							|  |  |  |                     if (haveIPv4Rules && !haveIPv4Outbounds) { | 
					
						
							|  |  |  |                         newTemplateSettings.outbounds.push(this.ipv4Settings); | 
					
						
							|  |  |  |                     } | 
					
						
							|  |  |  |                     this.templateSettings = newTemplateSettings; | 
					
						
							|  |  |  |                 }, | 
					
						
							|  |  |  |                 templateRuleGetter(routeSettings) { | 
					
						
							|  |  |  |                     const { data, property, outboundTag } = routeSettings; | 
					
						
							|  |  |  |                     let result = false; | 
					
						
							|  |  |  |                     if (this.templateSettings != null) { | 
					
						
							|  |  |  |                         this.templateSettings.routing.rules.forEach( | 
					
						
							|  |  |  |                             (routingRule) => { | 
					
						
							|  |  |  |                                 if ( | 
					
						
							|  |  |  |                                     routingRule.hasOwnProperty(property) && | 
					
						
							|  |  |  |                                     routingRule.hasOwnProperty("outboundTag") && | 
					
						
							|  |  |  |                                     routingRule.outboundTag === outboundTag | 
					
						
							|  |  |  |                                 ) { | 
					
						
							|  |  |  |                                     if (data.includes(routingRule[property][0])) { | 
					
						
							|  |  |  |                                         result = true; | 
					
						
							|  |  |  |                                     } | 
					
						
							|  |  |  |                                 } | 
					
						
							|  |  |  |                             } | 
					
						
							|  |  |  |                         ); | 
					
						
							|  |  |  |                     } | 
					
						
							|  |  |  |                     return result; | 
					
						
							|  |  |  |                 }, | 
					
						
							|  |  |  |                 templateRuleSetter(routeSettings) { | 
					
						
							|  |  |  |                     const { newValue, data, property, outboundTag } = routeSettings; | 
					
						
							|  |  |  |                     const oldTemplateSettings = this.templateSettings; | 
					
						
							|  |  |  |                     const newTemplateSettings = oldTemplateSettings; | 
					
						
							|  |  |  |                     if (newValue) { | 
					
						
							|  |  |  |                         const propertyRule = { | 
					
						
							|  |  |  |                             type: "field", | 
					
						
							|  |  |  |                             outboundTag, | 
					
						
							|  |  |  |                             [property]: data | 
					
						
							|  |  |  |                         }; | 
					
						
							|  |  |  |                         newTemplateSettings.routing.rules.push(propertyRule); | 
					
						
							|  |  |  |                     } | 
					
						
							|  |  |  |                     else { | 
					
						
							|  |  |  |                         const newRules = []; | 
					
						
							|  |  |  |                         newTemplateSettings.routing.rules.forEach( | 
					
						
							|  |  |  |                             (routingRule) => { | 
					
						
							|  |  |  |                                 if ( | 
					
						
							|  |  |  |                                     routingRule.hasOwnProperty(property) && | 
					
						
							|  |  |  |                                     routingRule.hasOwnProperty("outboundTag") && | 
					
						
							|  |  |  |                                     routingRule.outboundTag === outboundTag | 
					
						
							|  |  |  |                                 ) { | 
					
						
							|  |  |  |                                     if (data.includes(routingRule[property][0])) { | 
					
						
							|  |  |  |                                         return; | 
					
						
							|  |  |  |                                     } | 
					
						
							|  |  |  |                                 } | 
					
						
							|  |  |  |                                 newRules.push(routingRule); | 
					
						
							|  |  |  |                             } | 
					
						
							|  |  |  |                         ); | 
					
						
							|  |  |  |                         newTemplateSettings.routing.rules = newRules; | 
					
						
							|  |  |  |                     } | 
					
						
							|  |  |  |                     this.templateSettings = newTemplateSettings; | 
					
						
							|  |  |  |                     this.checkRequiredOutbounds(); | 
					
						
							| 
									
										
										
										
											2023-02-09 19:18:06 +00:00
										 |  |  |                 } | 
					
						
							| 
									
										
										
										
											2023-04-18 06:53:15 +00:00
										 |  |  |             }, | 
					
						
							| 
									
										
										
										
											2023-04-18 06:53:43 +00:00
										 |  |  |             async mounted() { | 
					
						
							|  |  |  |                 await this.getAllSetting(); | 
					
						
							|  |  |  |                 while (true) { | 
					
						
							|  |  |  |                     await PromiseUtil.sleep(1000); | 
					
						
							|  |  |  |                     this.saveBtnDisable = this.oldAllSetting.equals(this.allSetting); | 
					
						
							|  |  |  |                 } | 
					
						
							| 
									
										
										
										
											2023-03-17 16:07:49 +00:00
										 |  |  |             }, | 
					
						
							| 
									
										
										
										
											2023-04-18 06:53:43 +00:00
										 |  |  |             computed: { | 
					
						
							|  |  |  |                 templateSettings: { | 
					
						
							|  |  |  |                     get: function () { return this.allSetting.xrayTemplateConfig ? JSON.parse(this.allSetting.xrayTemplateConfig) : null; }, | 
					
						
							|  |  |  |                     set: function (newValue) { this.allSetting.xrayTemplateConfig = JSON.stringify(newValue, null, 2) }, | 
					
						
							| 
									
										
										
										
											2023-03-17 16:07:49 +00:00
										 |  |  |                 }, | 
					
						
							| 
									
										
										
										
											2023-04-18 06:53:43 +00:00
										 |  |  |                 inboundSettings: { | 
					
						
							|  |  |  |                     get: function () { return this.templateSettings ? JSON.stringify(this.templateSettings.inbounds, null, 2) : null; }, | 
					
						
							|  |  |  |                     set: function (newValue) { | 
					
						
							|  |  |  |                         newTemplateSettings = this.templateSettings; | 
					
						
							|  |  |  |                         newTemplateSettings.inbounds = JSON.parse(newValue) | 
					
						
							|  |  |  |                         this.templateSettings = newTemplateSettings | 
					
						
							|  |  |  |                     }, | 
					
						
							| 
									
										
										
										
											2023-03-17 16:07:49 +00:00
										 |  |  |                 }, | 
					
						
							| 
									
										
										
										
											2023-04-18 06:53:43 +00:00
										 |  |  |                 outboundSettings: { | 
					
						
							|  |  |  |                     get: function () { return this.templateSettings ? JSON.stringify(this.templateSettings.outbounds, null, 2) : null; }, | 
					
						
							|  |  |  |                     set: function (newValue) { | 
					
						
							|  |  |  |                         newTemplateSettings = this.templateSettings; | 
					
						
							|  |  |  |                         newTemplateSettings.outbounds = JSON.parse(newValue) | 
					
						
							|  |  |  |                         this.templateSettings = newTemplateSettings | 
					
						
							|  |  |  |                     }, | 
					
						
							| 
									
										
										
										
											2023-03-17 16:07:49 +00:00
										 |  |  |                 }, | 
					
						
							| 
									
										
										
										
											2023-04-18 06:53:43 +00:00
										 |  |  |                 routingRuleSettings: { | 
					
						
							|  |  |  |                     get: function () { return this.templateSettings ? JSON.stringify(this.templateSettings.routing.rules, null, 2) : null; }, | 
					
						
							|  |  |  |                     set: function (newValue) { | 
					
						
							|  |  |  |                         newTemplateSettings = this.templateSettings; | 
					
						
							|  |  |  |                         newTemplateSettings.routing.rules = JSON.parse(newValue) | 
					
						
							|  |  |  |                         this.templateSettings = newTemplateSettings | 
					
						
							|  |  |  |                     }, | 
					
						
							|  |  |  |                 }, | 
					
						
							|  |  |  |                 torrentSettings: { | 
					
						
							|  |  |  |                     get: function () { | 
					
						
							|  |  |  |                         return this.templateRuleGetter({ | 
					
						
							|  |  |  |                             outboundTag: "blocked", | 
					
						
							|  |  |  |                             property: "protocol", | 
					
						
							|  |  |  |                             data: this.settingsData.protocols.bittorrent | 
					
						
							| 
									
										
										
										
											2023-03-17 16:07:49 +00:00
										 |  |  |                         }); | 
					
						
							| 
									
										
										
										
											2023-04-18 06:53:43 +00:00
										 |  |  |                     }, | 
					
						
							|  |  |  |                     set: function (newValue) { | 
					
						
							|  |  |  |                         this.templateRuleSetter({ | 
					
						
							|  |  |  |                             newValue, | 
					
						
							|  |  |  |                             outboundTag: "blocked", | 
					
						
							|  |  |  |                             property: "protocol", | 
					
						
							|  |  |  |                             data: this.settingsData.protocols.bittorrent | 
					
						
							|  |  |  |                         }); | 
					
						
							|  |  |  |                     }, | 
					
						
							| 
									
										
										
										
											2023-03-17 16:07:49 +00:00
										 |  |  |                 }, | 
					
						
							| 
									
										
										
										
											2023-04-18 06:53:43 +00:00
										 |  |  |                 privateIpSettings: { | 
					
						
							|  |  |  |                     get: function () { | 
					
						
							|  |  |  |                         return this.templateRuleGetter({ | 
					
						
							|  |  |  |                             outboundTag: "blocked", | 
					
						
							|  |  |  |                             property: "ip", | 
					
						
							|  |  |  |                             data: this.settingsData.ips.local | 
					
						
							| 
									
										
										
										
											2023-03-17 16:07:49 +00:00
										 |  |  |                         }); | 
					
						
							| 
									
										
										
										
											2023-04-18 06:53:43 +00:00
										 |  |  |                     }, | 
					
						
							|  |  |  |                     set: function (newValue) { | 
					
						
							|  |  |  |                         this.templateRuleSetter({ | 
					
						
							|  |  |  |                             newValue, | 
					
						
							|  |  |  |                             outboundTag: "blocked", | 
					
						
							|  |  |  |                             property: "ip", | 
					
						
							|  |  |  |                             data: this.settingsData.ips.local | 
					
						
							|  |  |  |                         }); | 
					
						
							|  |  |  |                     }, | 
					
						
							| 
									
										
										
										
											2023-03-17 16:07:49 +00:00
										 |  |  |                 }, | 
					
						
							| 
									
										
										
										
											2023-04-18 06:53:43 +00:00
										 |  |  |                 AdsSettings: { | 
					
						
							|  |  |  |                     get: function () { | 
					
						
							|  |  |  |                         return this.templateRuleGetter({ | 
					
						
							|  |  |  |                             outboundTag: "blocked", | 
					
						
							|  |  |  |                             property: "domain", | 
					
						
							|  |  |  |                             data: this.settingsData.domains.ads | 
					
						
							| 
									
										
										
										
											2023-03-17 16:07:49 +00:00
										 |  |  |                         }); | 
					
						
							| 
									
										
										
										
											2023-04-18 06:53:43 +00:00
										 |  |  |                     }, | 
					
						
							|  |  |  |                     set: function (newValue) { | 
					
						
							|  |  |  |                         this.templateRuleSetter({ | 
					
						
							|  |  |  |                             newValue, | 
					
						
							|  |  |  |                             outboundTag: "blocked", | 
					
						
							|  |  |  |                             property: "domain", | 
					
						
							|  |  |  |                             data: this.settingsData.domains.ads | 
					
						
							|  |  |  |                         }); | 
					
						
							|  |  |  |                     }, | 
					
						
							| 
									
										
										
										
											2023-03-17 16:07:49 +00:00
										 |  |  |                 }, | 
					
						
							| 
									
										
										
										
											2023-04-18 06:53:43 +00:00
										 |  |  |                 PornSettings: { | 
					
						
							|  |  |  |                     get: function () { | 
					
						
							|  |  |  |                         return this.templateRuleGetter({ | 
					
						
							|  |  |  |                             outboundTag: "blocked", | 
					
						
							|  |  |  |                             property: "domain", | 
					
						
							|  |  |  |                             data: this.settingsData.domains.porn | 
					
						
							| 
									
										
										
										
											2023-03-17 16:07:49 +00:00
										 |  |  |                         }); | 
					
						
							| 
									
										
										
										
											2023-04-18 06:53:43 +00:00
										 |  |  |                     }, | 
					
						
							|  |  |  |                     set: function (newValue) { | 
					
						
							|  |  |  |                         this.templateRuleSetter({ | 
					
						
							|  |  |  |                             newValue, | 
					
						
							|  |  |  |                             outboundTag: "blocked", | 
					
						
							|  |  |  |                             property: "domain", | 
					
						
							|  |  |  |                             data: this.settingsData.domains.porn | 
					
						
							|  |  |  |                         }); | 
					
						
							|  |  |  |                     }, | 
					
						
							| 
									
										
										
										
											2023-03-17 16:07:49 +00:00
										 |  |  |                 }, | 
					
						
							| 
									
										
										
										
											2023-04-18 06:53:43 +00:00
										 |  |  |                 GoogleIPv4Settings: { | 
					
						
							|  |  |  |                     get: function () { | 
					
						
							|  |  |  |                         return this.templateRuleGetter({ | 
					
						
							|  |  |  |                             outboundTag: "IPv4", | 
					
						
							|  |  |  |                             property: "domain", | 
					
						
							|  |  |  |                             data: this.settingsData.domains.google | 
					
						
							| 
									
										
										
										
											2023-03-30 21:22:48 +00:00
										 |  |  |                         }); | 
					
						
							| 
									
										
										
										
											2023-04-18 06:53:43 +00:00
										 |  |  |                     }, | 
					
						
							|  |  |  |                     set: function (newValue) { | 
					
						
							|  |  |  |                         this.templateRuleSetter({ | 
					
						
							|  |  |  |                             newValue, | 
					
						
							|  |  |  |                             outboundTag: "IPv4", | 
					
						
							|  |  |  |                             property: "domain", | 
					
						
							|  |  |  |                             data: this.settingsData.domains.google | 
					
						
							|  |  |  |                         }); | 
					
						
							|  |  |  |                     }, | 
					
						
							| 
									
										
										
										
											2023-03-30 21:22:48 +00:00
										 |  |  |                 }, | 
					
						
							| 
									
										
										
										
											2023-04-18 06:53:43 +00:00
										 |  |  |                 NetflixIPv4Settings: { | 
					
						
							|  |  |  |                     get: function () { | 
					
						
							|  |  |  |                         return this.templateRuleGetter({ | 
					
						
							|  |  |  |                             outboundTag: "IPv4", | 
					
						
							|  |  |  |                             property: "domain", | 
					
						
							|  |  |  |                             data: this.settingsData.domains.netflix | 
					
						
							| 
									
										
										
										
											2023-03-30 21:22:48 +00:00
										 |  |  |                         }); | 
					
						
							| 
									
										
										
										
											2023-04-18 06:53:43 +00:00
										 |  |  |                     }, | 
					
						
							|  |  |  |                     set: function (newValue) { | 
					
						
							|  |  |  |                         this.templateRuleSetter({ | 
					
						
							|  |  |  |                             newValue, | 
					
						
							|  |  |  |                             outboundTag: "IPv4", | 
					
						
							|  |  |  |                             property: "domain", | 
					
						
							|  |  |  |                             data: this.settingsData.domains.netflix | 
					
						
							|  |  |  |                         }); | 
					
						
							|  |  |  |                     }, | 
					
						
							| 
									
										
										
										
											2023-03-30 21:22:48 +00:00
										 |  |  |                 }, | 
					
						
							| 
									
										
										
										
											2023-04-18 06:53:43 +00:00
										 |  |  |                 IRIpSettings: { | 
					
						
							|  |  |  |                     get: function () { | 
					
						
							|  |  |  |                         return this.templateRuleGetter({ | 
					
						
							|  |  |  |                             outboundTag: "blocked", | 
					
						
							|  |  |  |                             property: "ip", | 
					
						
							|  |  |  |                             data: this.settingsData.ips.ir | 
					
						
							| 
									
										
										
										
											2023-03-30 21:22:48 +00:00
										 |  |  |                         }); | 
					
						
							| 
									
										
										
										
											2023-04-18 06:53:43 +00:00
										 |  |  |                     }, | 
					
						
							|  |  |  |                     set: function (newValue) { | 
					
						
							|  |  |  |                         this.templateRuleSetter({ | 
					
						
							|  |  |  |                             newValue, | 
					
						
							|  |  |  |                             outboundTag: "blocked", | 
					
						
							|  |  |  |                             property: "ip", | 
					
						
							|  |  |  |                             data: this.settingsData.ips.ir | 
					
						
							|  |  |  |                         }); | 
					
						
							|  |  |  |                     }, | 
					
						
							| 
									
										
										
										
											2023-03-30 21:22:48 +00:00
										 |  |  |                 }, | 
					
						
							| 
									
										
										
										
											2023-04-18 06:53:43 +00:00
										 |  |  |                 IRDomainSettings: { | 
					
						
							|  |  |  |                     get: function () { | 
					
						
							|  |  |  |                         return this.templateRuleGetter({ | 
					
						
							|  |  |  |                             outboundTag: "blocked", | 
					
						
							|  |  |  |                             property: "domain", | 
					
						
							|  |  |  |                             data: this.settingsData.domains.ir | 
					
						
							| 
									
										
										
										
											2023-03-30 21:22:48 +00:00
										 |  |  |                         }); | 
					
						
							| 
									
										
										
										
											2023-04-18 06:53:43 +00:00
										 |  |  |                     }, | 
					
						
							|  |  |  |                     set: function (newValue) { | 
					
						
							|  |  |  |                         this.templateRuleSetter({ | 
					
						
							|  |  |  |                             newValue, | 
					
						
							|  |  |  |                             outboundTag: "blocked", | 
					
						
							|  |  |  |                             property: "domain", | 
					
						
							|  |  |  |                             data: this.settingsData.domains.ir | 
					
						
							|  |  |  |                         }); | 
					
						
							|  |  |  |                     }, | 
					
						
							| 
									
										
										
										
											2023-03-30 21:22:48 +00:00
										 |  |  |                 }, | 
					
						
							| 
									
										
										
										
											2023-04-18 06:53:43 +00:00
										 |  |  |                 ChinaIpSettings: { | 
					
						
							|  |  |  |                     get: function () { | 
					
						
							|  |  |  |                         return this.templateRuleGetter({ | 
					
						
							|  |  |  |                             outboundTag: "blocked", | 
					
						
							|  |  |  |                             property: "ip", | 
					
						
							|  |  |  |                             data: this.settingsData.ips.cn | 
					
						
							|  |  |  |                         }); | 
					
						
							|  |  |  |                     }, | 
					
						
							|  |  |  |                     set: function (newValue) { | 
					
						
							|  |  |  |                         this.templateRuleSetter({ | 
					
						
							|  |  |  |                             newValue, | 
					
						
							|  |  |  |                             outboundTag: "blocked", | 
					
						
							|  |  |  |                             property: "ip", | 
					
						
							|  |  |  |                             data: this.settingsData.ips.cn | 
					
						
							|  |  |  |                         }); | 
					
						
							|  |  |  |                     }, | 
					
						
							|  |  |  |                 }, | 
					
						
							|  |  |  |                 ChinaDomainSettings: { | 
					
						
							|  |  |  |                     get: function () { | 
					
						
							|  |  |  |                         return this.templateRuleGetter({ | 
					
						
							|  |  |  |                             outboundTag: "blocked", | 
					
						
							|  |  |  |                             property: "domain", | 
					
						
							|  |  |  |                             data: this.settingsData.domains.cn | 
					
						
							|  |  |  |                         }); | 
					
						
							|  |  |  |                     }, | 
					
						
							|  |  |  |                     set: function (newValue) { | 
					
						
							|  |  |  |                         this.templateRuleSetter({ | 
					
						
							|  |  |  |                             newValue, | 
					
						
							|  |  |  |                             outboundTag: "blocked", | 
					
						
							|  |  |  |                             property: "domain", | 
					
						
							|  |  |  |                             data: this.settingsData.domains.cn | 
					
						
							|  |  |  |                         }); | 
					
						
							|  |  |  |                     }, | 
					
						
							|  |  |  |                 }, | 
					
						
							| 
									
										
										
										
											2023-04-18 16:54:32 +00:00
										 |  |  |                 RussiaIpSettings: { | 
					
						
							|  |  |  |                     get: function () { | 
					
						
							|  |  |  |                         return this.templateRuleGetter({ | 
					
						
							|  |  |  |                             outboundTag: "blocked", | 
					
						
							|  |  |  |                             property: "ip", | 
					
						
							|  |  |  |                             data: this.settingsData.ips.ru | 
					
						
							|  |  |  |                         }); | 
					
						
							|  |  |  |                     }, | 
					
						
							|  |  |  |                     set: function (newValue) { | 
					
						
							|  |  |  |                         this.templateRuleSetter({ | 
					
						
							|  |  |  |                             newValue, | 
					
						
							|  |  |  |                             outboundTag: "blocked", | 
					
						
							|  |  |  |                             property: "ip", | 
					
						
							|  |  |  |                             data: this.settingsData.ips.ru | 
					
						
							|  |  |  |                         }); | 
					
						
							|  |  |  |                     }, | 
					
						
							|  |  |  |                 }, | 
					
						
							|  |  |  |                 RussiaDomainSettings: { | 
					
						
							|  |  |  |                     get: function () { | 
					
						
							|  |  |  |                         return this.templateRuleGetter({ | 
					
						
							|  |  |  |                             outboundTag: "blocked", | 
					
						
							|  |  |  |                             property: "domain", | 
					
						
							|  |  |  |                             data: this.settingsData.domains.ru | 
					
						
							|  |  |  |                         }); | 
					
						
							|  |  |  |                     }, | 
					
						
							|  |  |  |                     set: function (newValue) { | 
					
						
							|  |  |  |                         this.templateRuleSetter({ | 
					
						
							|  |  |  |                             newValue, | 
					
						
							|  |  |  |                             outboundTag: "blocked", | 
					
						
							|  |  |  |                             property: "domain", | 
					
						
							|  |  |  |                             data: this.settingsData.domains.ru | 
					
						
							|  |  |  |                         }); | 
					
						
							|  |  |  |                     }, | 
					
						
							|  |  |  |                 }, | 
					
						
							| 
									
										
										
										
											2023-04-18 06:53:43 +00:00
										 |  |  |                 GoogleWARPSettings: { | 
					
						
							|  |  |  |                     get: function () { | 
					
						
							|  |  |  |                         return this.templateRuleGetter({ | 
					
						
							|  |  |  |                             outboundTag: "WARP", | 
					
						
							|  |  |  |                             property: "domain", | 
					
						
							|  |  |  |                             data: this.settingsData.domains.google | 
					
						
							|  |  |  |                         }); | 
					
						
							|  |  |  |                     }, | 
					
						
							|  |  |  |                     set: function (newValue) { | 
					
						
							|  |  |  |                         this.templateRuleSetter({ | 
					
						
							|  |  |  |                             newValue, | 
					
						
							|  |  |  |                             outboundTag: "WARP", | 
					
						
							|  |  |  |                             property: "domain", | 
					
						
							|  |  |  |                             data: this.settingsData.domains.google | 
					
						
							|  |  |  |                         }); | 
					
						
							|  |  |  |                     }, | 
					
						
							|  |  |  |                 }, | 
					
						
							|  |  |  |                 OpenAIWARPSettings: { | 
					
						
							|  |  |  |                     get: function () { | 
					
						
							|  |  |  |                         return this.templateRuleGetter({ | 
					
						
							|  |  |  |                             outboundTag: "WARP", | 
					
						
							|  |  |  |                             property: "domain", | 
					
						
							|  |  |  |                             data: this.settingsData.domains.openai | 
					
						
							|  |  |  |                         }); | 
					
						
							|  |  |  |                     }, | 
					
						
							|  |  |  |                     set: function (newValue) { | 
					
						
							|  |  |  |                         this.templateRuleSetter({ | 
					
						
							|  |  |  |                             newValue, | 
					
						
							|  |  |  |                             outboundTag: "WARP", | 
					
						
							|  |  |  |                             property: "domain", | 
					
						
							|  |  |  |                             data: this.settingsData.domains.openai | 
					
						
							|  |  |  |                         }); | 
					
						
							|  |  |  |                     }, | 
					
						
							|  |  |  |                 }, | 
					
						
							|  |  |  |                 NetflixWARPSettings: { | 
					
						
							|  |  |  |                     get: function () { | 
					
						
							|  |  |  |                         return this.templateRuleGetter({ | 
					
						
							|  |  |  |                             outboundTag: "WARP", | 
					
						
							|  |  |  |                             property: "domain", | 
					
						
							|  |  |  |                             data: this.settingsData.domains.netflix | 
					
						
							|  |  |  |                         }); | 
					
						
							|  |  |  |                     }, | 
					
						
							|  |  |  |                     set: function (newValue) { | 
					
						
							|  |  |  |                         this.templateRuleSetter({ | 
					
						
							|  |  |  |                             newValue, | 
					
						
							|  |  |  |                             outboundTag: "WARP", | 
					
						
							|  |  |  |                             property: "domain", | 
					
						
							|  |  |  |                             data: this.settingsData.domains.netflix | 
					
						
							|  |  |  |                         }); | 
					
						
							|  |  |  |                     }, | 
					
						
							|  |  |  |                 }, | 
					
						
							|  |  |  |                 SpotifyWARPSettings: { | 
					
						
							|  |  |  |                     get: function () { | 
					
						
							|  |  |  |                         return this.templateRuleGetter({ | 
					
						
							|  |  |  |                             outboundTag: "WARP", | 
					
						
							|  |  |  |                             property: "domain", | 
					
						
							|  |  |  |                             data: this.settingsData.domains.spotify | 
					
						
							|  |  |  |                         }); | 
					
						
							|  |  |  |                     }, | 
					
						
							|  |  |  |                     set: function (newValue) { | 
					
						
							|  |  |  |                         this.templateRuleSetter({ | 
					
						
							|  |  |  |                             newValue, | 
					
						
							|  |  |  |                             outboundTag: "WARP", | 
					
						
							|  |  |  |                             property: "domain", | 
					
						
							|  |  |  |                             data: this.settingsData.domains.spotify | 
					
						
							|  |  |  |                         }); | 
					
						
							|  |  |  |                     }, | 
					
						
							|  |  |  |                 }, | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |         }); | 
					
						
							| 
									
										
										
										
											2023-02-09 19:18:06 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-04-18 06:53:43 +00:00
										 |  |  |     </script> | 
					
						
							| 
									
										
										
										
											2023-02-09 19:18:06 +00:00
										 |  |  | </body> | 
					
						
							| 
									
										
										
										
											2023-04-18 06:53:43 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | </html> |