mirror of
				https://github.com/MHSanaei/3x-ui.git
				synced 2025-10-26 18:14:50 +00:00 
			
		
		
		
	random password button for SS & more
crypto.getRandomValues for uuid change name randomText to randomLowerAndNum
This commit is contained in:
		
							parent
							
								
									38b5d8983c
								
							
						
					
					
						commit
						88777ccf90
					
				
					 8 changed files with 29 additions and 26 deletions
				
			
		|  | @ -707,7 +707,7 @@ class RealityStreamSettings extends XrayCommonClass { | |||
|         minClient = '', | ||||
|         maxClient = '', | ||||
|         maxTimediff = 0, | ||||
|         shortIds = RandomUtil.randomShortId(8), | ||||
|         shortIds = RandomUtil.randomShortId(), | ||||
|         settings= new RealityStreamSettings.Settings() | ||||
|         ){ | ||||
|         super(); | ||||
|  | @ -1652,7 +1652,7 @@ Inbound.VmessSettings = class extends Inbound.Settings { | |||
|     } | ||||
| }; | ||||
| Inbound.VmessSettings.Vmess = class extends XrayCommonClass { | ||||
|     constructor(id=RandomUtil.randomUUID(), alterId=0, email=RandomUtil.randomText(8),limitIp=0, totalGB=0, expiryTime=0, enable=true, tgId='', subId=RandomUtil.randomText(16)) { | ||||
|     constructor(id=RandomUtil.randomUUID(), alterId=0, email=RandomUtil.randomLowerAndNum(8),limitIp=0, totalGB=0, expiryTime=0, enable=true, tgId='', subId=RandomUtil.randomLowerAndNum(16)) { | ||||
|         super(); | ||||
|         this.id = id; | ||||
|         this.alterId = alterId; | ||||
|  | @ -1744,7 +1744,7 @@ Inbound.VLESSSettings = class extends Inbound.Settings { | |||
| 
 | ||||
| }; | ||||
| Inbound.VLESSSettings.VLESS = class extends XrayCommonClass { | ||||
|     constructor(id=RandomUtil.randomUUID(), flow='', email=RandomUtil.randomText(8),limitIp=0, totalGB=0, expiryTime=0, enable=true, tgId='', subId=RandomUtil.randomText(16)) { | ||||
|     constructor(id=RandomUtil.randomUUID(), flow='', email=RandomUtil.randomLowerAndNum(8),limitIp=0, totalGB=0, expiryTime=0, enable=true, tgId='', subId=RandomUtil.randomLowerAndNum(16)) { | ||||
|         super(); | ||||
|         this.id = id; | ||||
|         this.flow = flow; | ||||
|  | @ -1867,7 +1867,7 @@ Inbound.TrojanSettings = class extends Inbound.Settings { | |||
|     } | ||||
| }; | ||||
| Inbound.TrojanSettings.Trojan = class extends XrayCommonClass { | ||||
|     constructor(password=RandomUtil.randomSeq(10), flow='', email=RandomUtil.randomText(8),limitIp=0, totalGB=0, expiryTime=0, enable=true, tgId='', subId=RandomUtil.randomText(16)) { | ||||
|     constructor(password=RandomUtil.randomSeq(10), flow='', email=RandomUtil.randomLowerAndNum(8),limitIp=0, totalGB=0, expiryTime=0, enable=true, tgId='', subId=RandomUtil.randomLowerAndNum(16)) { | ||||
|         super(); | ||||
|         this.password = password; | ||||
|         this.flow = flow; | ||||
|  | @ -2009,7 +2009,7 @@ Inbound.ShadowsocksSettings = class extends Inbound.Settings { | |||
| }; | ||||
| 
 | ||||
| Inbound.ShadowsocksSettings.Shadowsocks = class extends XrayCommonClass { | ||||
|     constructor(password=RandomUtil.randomShadowsocksPassword(), email=RandomUtil.randomText(8),limitIp=0, totalGB=0, expiryTime=0, enable=true, tgId='', subId=RandomUtil.randomText(16)) { | ||||
|     constructor(password=RandomUtil.randomShadowsocksPassword(), email=RandomUtil.randomLowerAndNum(8),limitIp=0, totalGB=0, expiryTime=0, enable=true, tgId='', subId=RandomUtil.randomLowerAndNum(16)) { | ||||
|         super(); | ||||
|         this.password = password; | ||||
|         this.email = email; | ||||
|  |  | |||
|  | @ -94,30 +94,32 @@ class RandomUtil { | |||
|         return str; | ||||
|     } | ||||
| 
 | ||||
|     static randomShortId(count) { | ||||
|     static randomShortId() { | ||||
|         let str = ''; | ||||
|         for (let i = 0; i < count; ++i) { | ||||
|         for (let i = 0; i < 8; ++i) { | ||||
|             str += seq[this.randomInt(16)]; | ||||
|         } | ||||
|         return str; | ||||
|     } | ||||
| 
 | ||||
|     static randomText(len) { | ||||
|     static randomLowerAndNum(len) { | ||||
|         let str = ''; | ||||
|         for (let i = 0; i < len; i++) { | ||||
|         for (let i = 0; i < len; ++i) { | ||||
|             str += seq[this.randomInt(36)]; | ||||
|         } | ||||
|         return str; | ||||
|     } | ||||
| 
 | ||||
|     static randomUUID() { | ||||
|         let d = new Date().getTime(); | ||||
|         return 'xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx'.replace(/[xy]/g, function (c) { | ||||
|             let r = (d + Math.random() * 16) % 16 | 0; | ||||
|             d = Math.floor(d / 16); | ||||
|             return (c === 'x' ? r : (r & 0x7 | 0x8)).toString(16); | ||||
|         const template = 'xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx'; | ||||
|         return template.replace(/[xy]/g, function (c) { | ||||
|           const randomValues = new Uint8Array(1); | ||||
|           crypto.getRandomValues(randomValues); | ||||
|           let randomValue = randomValues[0] % 16; | ||||
|           let calculatedValue = (c === 'x') ? randomValue : (randomValue & 0x3 | 0x8); | ||||
|           return calculatedValue.toString(16); | ||||
|         }); | ||||
|     }   | ||||
|     } | ||||
| 
 | ||||
|     static randomShadowsocksPassword() { | ||||
|         let array = new Uint8Array(32); | ||||
|  |  | |||
|  | @ -18,7 +18,7 @@ | |||
|                 </template> | ||||
|             </a-tooltip> | ||||
|         </span> | ||||
|         <a-icon @click="client.email = RandomUtil.randomText(8)" type="sync"> </a-icon> | ||||
|         <a-icon @click="client.email = RandomUtil.randomLowerAndNum(8)" type="sync"> </a-icon> | ||||
|         <a-input v-model.trim="client.email" style="width: 200px;"></a-input> | ||||
|     </a-form-item> | ||||
|     <a-form-item label="Password" v-if="inbound.protocol === Protocols.TROJAN || inbound.protocol === Protocols.SHADOWSOCKS"> | ||||
|  | @ -44,7 +44,7 @@ | |||
|                 <a-icon type="question-circle" theme="filled"></a-icon> | ||||
|             </a-tooltip> | ||||
|         </span> | ||||
|         <a-icon @click="client.subId = RandomUtil.randomText(16)" type="sync"> </a-icon> | ||||
|         <a-icon @click="client.subId = RandomUtil.randomLowerAndNum(16)" type="sync"> </a-icon> | ||||
|         <a-input v-model.trim="client.subId" style="width: 150px;"></a-input> | ||||
|     </a-form-item> | ||||
|     <a-form-item v-if="client.email && app.tgBotEnable" > | ||||
|  |  | |||
|  | @ -11,7 +11,7 @@ | |||
|                         </template> | ||||
|                     </a-tooltip> | ||||
|                 </span> | ||||
|                 <a-icon @click="client.email = RandomUtil.randomText(8)" type="sync"> </a-icon> | ||||
|                 <a-icon @click="client.email = RandomUtil.randomLowerAndNum(8)" type="sync"> </a-icon> | ||||
|                 <a-input v-model.trim="client.email" style="width: 200px;"></a-input> | ||||
|             </a-form-item> | ||||
|             <a-form-item label="Password"> | ||||
|  | @ -28,7 +28,7 @@ | |||
|                         <a-icon type="question-circle" theme="filled"></a-icon> | ||||
|                     </a-tooltip> | ||||
|                 </span> | ||||
|                 <a-icon @click="client.subId = RandomUtil.randomText(16)" type="sync"> </a-icon> | ||||
|                 <a-icon @click="client.subId = RandomUtil.randomLowerAndNum(16)" type="sync"> </a-icon> | ||||
|                 <a-input v-model.trim="client.subId" style="width: 150px;"></a-input> | ||||
|             </a-form-item> | ||||
|             <a-form-item v-if="client.email && app.tgBotEnable"> | ||||
|  | @ -112,6 +112,7 @@ | |||
|         </a-select> | ||||
|     </a-form-item> | ||||
|     <a-form-item label='{{ i18n "password" }}'> | ||||
|         <a-icon @click="inbound.settings.password = RandomUtil.randomShadowsocksPassword()" type="sync"> </a-icon> | ||||
|         <a-input v-model.trim="inbound.settings.password" style="width: 250px;"></a-input> | ||||
|     </a-form-item> | ||||
|     <a-form-item label='{{ i18n "pages.inbounds.network" }}'> | ||||
|  |  | |||
|  | @ -11,7 +11,7 @@ | |||
|                         </template> | ||||
|                     </a-tooltip> | ||||
|                 </span> | ||||
|                 <a-icon @click="client.email = RandomUtil.randomText(8)" type="sync"> </a-icon> | ||||
|                 <a-icon @click="client.email = RandomUtil.randomLowerAndNum(8)" type="sync"> </a-icon> | ||||
|                 <a-input v-model.trim="client.email" style="width: 200px;"></a-input> | ||||
|             </a-form-item> | ||||
|             <a-form-item label="Password"> | ||||
|  | @ -28,7 +28,7 @@ | |||
|                         <a-icon type="question-circle" theme="filled"></a-icon> | ||||
|                     </a-tooltip> | ||||
|                 </span> | ||||
|                 <a-icon @click="client.subId = RandomUtil.randomText(16)" type="sync"> </a-icon> | ||||
|                 <a-icon @click="client.subId = RandomUtil.randomLowerAndNum(16)" type="sync"> </a-icon> | ||||
|                 <a-input v-model.trim="client.subId" style="width: 150px;"></a-input> | ||||
|             </a-form-item> | ||||
|             <a-form-item v-if="client.email && app.tgBotEnable"> | ||||
|  |  | |||
|  | @ -11,7 +11,7 @@ | |||
|                         </template> | ||||
|                     </a-tooltip> | ||||
|                 </span> | ||||
|                 <a-icon @click="client.email = RandomUtil.randomText(8)" type="sync"> </a-icon> | ||||
|                 <a-icon @click="client.email = RandomUtil.randomLowerAndNum(8)" type="sync"> </a-icon> | ||||
|                 <a-input v-model.trim="client.email" style="width: 200px;"></a-input> | ||||
|             </a-form-item> | ||||
|             <a-form-item label="ID"> | ||||
|  | @ -28,7 +28,7 @@ | |||
|                         <a-icon type="question-circle" theme="filled"></a-icon> | ||||
|                     </a-tooltip> | ||||
|                 </span> | ||||
|                 <a-icon @click="client.subId = RandomUtil.randomText(16)" type="sync"> </a-icon> | ||||
|                 <a-icon @click="client.subId = RandomUtil.randomLowerAndNum(16)" type="sync"> </a-icon> | ||||
|                 <a-input v-model.trim="client.subId" style="width: 150px;"></a-input> | ||||
|             </a-form-item> | ||||
|             <a-form-item v-if="client.email && app.tgBotEnable"> | ||||
|  |  | |||
|  | @ -11,7 +11,7 @@ | |||
|                         </template> | ||||
|                     </a-tooltip> | ||||
|                 </span> | ||||
|                 <a-icon @click="client.email = RandomUtil.randomText(8)" type="sync"> </a-icon> | ||||
|                 <a-icon @click="client.email = RandomUtil.randomLowerAndNum(8)" type="sync"> </a-icon> | ||||
|                 <a-input v-model.trim="client.email" style="width: 200px;"></a-input> | ||||
|             </a-form-item> | ||||
|             <br> | ||||
|  | @ -33,7 +33,7 @@ | |||
|                         <a-icon type="question-circle" theme="filled"></a-icon> | ||||
|                     </a-tooltip> | ||||
|                 </span> | ||||
|                 <a-icon @click="client.subId = RandomUtil.randomText(16)" type="sync"> </a-icon> | ||||
|                 <a-icon @click="client.subId = RandomUtil.randomLowerAndNum(16)" type="sync"> </a-icon> | ||||
|                 <a-input v-model.trim="client.subId" style="width: 150px;"></a-input> | ||||
|             </a-form-item> | ||||
|             <a-form-item v-if="client.email && app.tgBotEnable"> | ||||
|  |  | |||
|  | @ -187,7 +187,7 @@ | |||
|         <a-input v-model.trim="inbound.stream.reality.serverNames" style="width: 300px"></a-input> | ||||
|     </a-form-item> | ||||
|     <a-form-item label="ShortIds"> | ||||
|         <a-icon @click="inbound.stream.reality.shortIds = RandomUtil.randomShortId(8)" type="sync"> </a-icon> | ||||
|         <a-icon @click="inbound.stream.reality.shortIds = RandomUtil.randomShortId()" type="sync"> </a-icon> | ||||
|         <a-input v-model.trim="inbound.stream.reality.shortIds" style="width: 150px;"></a-input> | ||||
|     </a-form-item> | ||||
|     <br> | ||||
|  |  | |||
		Loading…
	
		Reference in a new issue
	
	 MHSanaei
						MHSanaei