diff --git a/web/assets/js/model/inbound.js b/web/assets/js/model/inbound.js index aecedf75..0718b20c 100644 --- a/web/assets/js/model/inbound.js +++ b/web/assets/js/model/inbound.js @@ -729,8 +729,8 @@ class RealityStreamSettings extends XrayCommonClass { constructor( show = false, xver = 0, - target = 'google.com:443', - serverNames = 'google.com,www.google.com', + target = '', + serverNames = '', privateKey = '', minClientVer = '', maxClientVer = '', @@ -740,6 +740,14 @@ class RealityStreamSettings extends XrayCommonClass { settings = new RealityStreamSettings.Settings() ) { super(); + // If target/serverNames are not provided, use random values + if (!target && !serverNames) { + const randomTarget = typeof getRandomRealityTarget !== 'undefined' + ? getRandomRealityTarget() + : { target: 'google.com:443', sni: 'google.com,www.google.com' }; + target = randomTarget.target; + serverNames = randomTarget.sni; + } this.show = show; this.xver = xver; this.target = target; diff --git a/web/assets/js/model/reality_targets.js b/web/assets/js/model/reality_targets.js new file mode 100644 index 00000000..348ff296 --- /dev/null +++ b/web/assets/js/model/reality_targets.js @@ -0,0 +1,86 @@ +// List of popular services for VLESS Reality Target/SNI randomization +const REALITY_TARGETS = [ + // CDN & Cloud Infrastructure + { target: 'www.cloudflare.com:443', sni: 'www.cloudflare.com,cloudflare.com' }, + { target: 'www.microsoft.com:443', sni: 'www.microsoft.com,microsoft.com' }, + { target: 'www.apple.com:443', sni: 'www.apple.com,apple.com' }, + { target: 'www.amazon.com:443', sni: 'www.amazon.com,amazon.com' }, + { target: 'cloud.google.com:443', sni: 'cloud.google.com,www.google.com' }, + { target: 'azure.microsoft.com:443', sni: 'azure.microsoft.com,www.azure.com' }, + { target: 'aws.amazon.com:443', sni: 'aws.amazon.com,amazon.com' }, + { target: 'www.digitalocean.com:443', sni: 'www.digitalocean.com,digitalocean.com' }, + + // Social Media + { target: 'www.facebook.com:443', sni: 'www.facebook.com,facebook.com' }, + { target: 'www.instagram.com:443', sni: 'www.instagram.com,instagram.com' }, + { target: 'www.twitter.com:443', sni: 'www.twitter.com,twitter.com' }, + { target: 'www.linkedin.com:443', sni: 'www.linkedin.com,linkedin.com' }, + { target: 'www.reddit.com:443', sni: 'www.reddit.com,reddit.com' }, + { target: 'www.pinterest.com:443', sni: 'www.pinterest.com,pinterest.com' }, + { target: 'www.tumblr.com:443', sni: 'www.tumblr.com,tumblr.com' }, + + // Video & Streaming + { target: 'www.youtube.com:443', sni: 'www.youtube.com,youtube.com' }, + { target: 'www.netflix.com:443', sni: 'www.netflix.com,netflix.com' }, + { target: 'www.twitch.tv:443', sni: 'www.twitch.tv,twitch.tv' }, + { target: 'vimeo.com:443', sni: 'vimeo.com,www.vimeo.com' }, + { target: 'www.hulu.com:443', sni: 'www.hulu.com,hulu.com' }, + { target: 'www.disneyplus.com:443', sni: 'www.disneyplus.com,disneyplus.com' }, + + // News & Media + { target: 'www.bbc.com:443', sni: 'www.bbc.com,bbc.com' }, + { target: 'www.cnn.com:443', sni: 'www.cnn.com,cnn.com' }, + { target: 'www.nytimes.com:443', sni: 'www.nytimes.com,nytimes.com' }, + { target: 'www.theguardian.com:443', sni: 'www.theguardian.com,theguardian.com' }, + { target: 'www.reuters.com:443', sni: 'www.reuters.com,reuters.com' }, + { target: 'www.bloomberg.com:443', sni: 'www.bloomberg.com,bloomberg.com' }, + + // E-commerce + { target: 'www.ebay.com:443', sni: 'www.ebay.com,ebay.com' }, + { target: 'www.alibaba.com:443', sni: 'www.alibaba.com,alibaba.com' }, + { target: 'www.shopify.com:443', sni: 'www.shopify.com,shopify.com' }, + { target: 'www.walmart.com:443', sni: 'www.walmart.com,walmart.com' }, + { target: 'www.target.com:443', sni: 'www.target.com,target.com' }, + + // Tech Companies + { target: 'www.github.com:443', sni: 'www.github.com,github.com' }, + { target: 'www.stackoverflow.com:443', sni: 'www.stackoverflow.com,stackoverflow.com' }, + { target: 'www.gitlab.com:443', sni: 'www.gitlab.com,gitlab.com' }, + { target: 'www.docker.com:443', sni: 'www.docker.com,docker.com' }, + { target: 'www.nvidia.com:443', sni: 'www.nvidia.com,nvidia.com' }, + { target: 'www.intel.com:443', sni: 'www.intel.com,intel.com' }, + { target: 'www.amd.com:443', sni: 'www.amd.com,amd.com' }, + + // Communication & Productivity + { target: 'www.zoom.us:443', sni: 'www.zoom.us,zoom.us' }, + { target: 'slack.com:443', sni: 'slack.com,www.slack.com' }, + { target: 'www.dropbox.com:443', sni: 'www.dropbox.com,dropbox.com' }, + { target: 'www.notion.so:443', sni: 'www.notion.so,notion.so' }, + { target: 'www.atlassian.com:443', sni: 'www.atlassian.com,atlassian.com' }, + { target: 'www.salesforce.com:443', sni: 'www.salesforce.com,salesforce.com' }, + + // Search & General + { target: 'www.wikipedia.org:443', sni: 'www.wikipedia.org,wikipedia.org' }, + { target: 'www.bing.com:443', sni: 'www.bing.com,bing.com' }, + { target: 'www.yahoo.com:443', sni: 'www.yahoo.com,yahoo.com' }, + { target: 'www.duckduckgo.com:443', sni: 'www.duckduckgo.com,duckduckgo.com' }, + + // Gaming + { target: 'store.steampowered.com:443', sni: 'store.steampowered.com,steampowered.com' }, + { target: 'www.ea.com:443', sni: 'www.ea.com,ea.com' }, + { target: 'www.epicgames.com:443', sni: 'www.epicgames.com,epicgames.com' }, +]; + +/** + * Returns a random Reality target configuration from the predefined list + * @returns {Object} Object with target and sni properties + */ +function getRandomRealityTarget() { + const randomIndex = Math.floor(Math.random() * REALITY_TARGETS.length); + const selected = REALITY_TARGETS[randomIndex]; + // Return a copy to avoid reference issues + return { + target: selected.target, + sni: selected.sni + }; +} diff --git a/web/html/form/reality_settings.html b/web/html/form/reality_settings.html index 218ba86d..29170f03 100644 --- a/web/html/form/reality_settings.html +++ b/web/html/form/reality_settings.html @@ -12,10 +12,26 @@ [[ key ]] - + + - + + diff --git a/web/html/inbounds.html b/web/html/inbounds.html index 2ab00f09..8616dce5 100644 --- a/web/html/inbounds.html +++ b/web/html/inbounds.html @@ -602,6 +602,7 @@ {{template "page/body_scripts" .}} + {{template "component/aSidebar" .}} diff --git a/web/html/modals/inbound_modal.html b/web/html/modals/inbound_modal.html index 176f2eee..3c844381 100644 --- a/web/html/modals/inbound_modal.html +++ b/web/html/modals/inbound_modal.html @@ -158,6 +158,13 @@ this.inbound.stream.reality.mldsa65Seed = ''; this.inbound.stream.reality.settings.mldsa65Verify = ''; }, + randomizeRealityTarget() { + if (typeof getRandomRealityTarget !== 'undefined') { + const randomTarget = getRandomRealityTarget(); + this.inbound.stream.reality.target = randomTarget.target; + this.inbound.stream.reality.serverNames = randomTarget.sni; + } + }, async getNewEchCert() { inModal.loading(true); const msg = await HttpUtil.post('/panel/api/server/getNewEchCert', { sni: inModal.inbound.stream.tls.sni });