Merge branch 'ViaVersion:master' into master

This commit is contained in:
Huynh Tien 2022-06-05 11:12:19 +07:00 committed by GitHub
commit 39f12e1039
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
5 changed files with 46 additions and 42 deletions

View File

@ -27,12 +27,10 @@ Offline mode tutorial: https://youtu.be/lPdELnrxmp0
- [ViaVersion](https://viaversion.com), [ViaBackwards](https://viaversion.com/backwards) - [ViaVersion](https://viaversion.com), [ViaBackwards](https://viaversion.com/backwards)
and [ViaRewind](https://viaversion.com/rewind) translates the connections to backend server. and [ViaRewind](https://viaversion.com/rewind) translates the connections to backend server.
- VIAaaS auth page stores account credentials in the player's browser local storage. Check for XSS vulnerabilities on - VIAaaS auth page stores account credentials in the player's browser local storage.
your domain. - It requires a CORS Proxy for calling Mojang APIs.
- It requires a CORS Proxy for calling Mojang APIs, which may make Mojang see that as suspicious and block your account - Account credentials aren't sent to VIAaaS instance, though it's proxied by CORS Proxy.
password if the IP address seems suspect. - The web page receives and validates the joinGame's session hash from VIAaaS instance.
- Account credentials aren't sent to VIAaaS instance, though it's intermediated by CORS Proxy.
- The web page receives and validates the session hash from VIAaaS instance.
## Setting up server instance ## Setting up server instance
@ -53,33 +51,25 @@ java -jar VIAaaS-all.jar
### How to create a public server ### How to create a public server
- You need a domain wildcarding to VIAaaS instance, like ``*.example.com -> 192.168.123.123``. You can - You need a DNS wildcard pointing to VIAaaS instance, like ``*.example.com -> 192.168.123.123``. You can
use [DuckDNS](https://duckdns.org/) DDNS service. use [DuckDNS](https://duckdns.org/) DDNS service.
- Configure the hostname in the config - Configure the hostname in the config
- Open the Minecraft port (25565) - Open the Minecraft port (25565)
- The HTTPS page needs a certificate, you can use [Apache](https://httpd.apache.org/) (with - The HTTPS page needs a valid SSL certificate, you can use [Apache](https://httpd.apache.org/) (with
a [Let's Encrypt](https://letsencrypt.org/) certificate) as a reverse proxy. See apache_copypasta.txt file. a [Let's Encrypt](https://letsencrypt.org/) certificate) as a reverse proxy. See apache_copypasta.txt file.
## CORS Proxy ## CORS Proxy
- Due to Mojang API not allowing CORS request, we need to use a CORS proxy
- For less chance of Mojang seeing the login as suspect, you (the player) should set up a CORS proxy on your machine. - For less chance of Mojang seeing the login as suspect, you (the player) should set up a CORS proxy on your machine.
- Note the ending slash in cors-anywhere address - Note the ending slash in cors-anywhere address
- You can also try my public instance - The default CORS Proxy is hosted at https://crp123-cors.herokuapp.com/
at https://crp123-cors.herokuapp.com/ ([source](https://github.com/creeper123123321/cors-anywhere/)) ([source](https://github.com/creeper123123321/cors-anywhere/))
### Setting up [cors-anywhere](https://www.npmjs.com/package/cors-anywhere) on local machine:
```sh
git clone https://github.com/Rob--W/cors-anywhere
cd cors-anywhere
npm install
node server.js
```
- It will be available at ```http://localhost:8080/```
## Usage for players ## Usage for players
You can also connect to ```via.localhost`` and set the address parameters via web page.
#### Offline mode: #### Offline mode:
- Connect to ```mc.example.net.via.localhost``` - Connect to ```mc.example.net.via.localhost```
@ -88,19 +78,22 @@ node server.js
Web login: Web login:
- You can use the same username for front-end and back-end connection. It's also possible to use an offline mode
connection on front-end (use ``_of``).
- Go to VIAaaS auth webpage (default is https://localhost:25543/) - Go to VIAaaS auth webpage (default is https://localhost:25543/)
- Listen to the username A (you'll use it to connect to the VIAaaS instance). - Listen to the username A (you'll use it to connect to the VIAaaS instance).
- Add the account B (you'll use it in backend server). - Add the account B (you'll use it in backend server).
- Keep the page open - Keep the page open
- Connect with your account A to ```mc.example.com._u(account B).via.localhost``` (```_u``` can be removed if username - Connect with your account A to ```mc.example.com._u(account B).via.localhost```
is the same)
- Approve the login in the webpage - Approve the login in the webpage
Web login via token caching:
- Open the web page and save your account in your browser
- Send your access token to the instance
- Connect with ```mc.example.com.via.localhost```
Fabric/Forge client: Fabric/Forge client:
- Install [OpenAuthMod](https://github.com/RaphiMC/OpenAuthMod) in your Fabric or Forge client. - Install [OpenAuthMod](https://github.com/RaphiMC/OpenAuthMod) in your client.
- Join the server: ```mc.example.net.via.localhost``` - Join the server: ```mc.example.net.via.localhost```
- Approve the login - Approve the login
@ -118,18 +111,19 @@ Fabric/Forge client:
- ```server.example.net```: backend server address - ```server.example.net```: backend server address
- ```_p```: backend port - ```_p```: backend port
- ```_v```: backend version ([protocol id](https://wiki.vg/Protocol_version_numbers) or name, replace ``.`` with ``_``) - ```_v```: backend version ([protocol id](https://wiki.vg/Protocol_version_numbers) or name, replace ``.`` with ``_``)
. ```AUTO``` is default (1.8 fallback). . ```AUTO``` is default (with 1.8 as fallback).
- ```_o```: ```t``` to force online mode in frontend, ```f``` to force offline mode in frontend. If not set, it will be - ```_o```: ```true``` to force online mode in frontend, ```false``` to force offline mode in frontend. If not set, it
based on backend online mode. will be based on backend online mode.
- ```_u```: username to use in backend connection - ```_u```: username to use in backend connection (default is front-end username)
- ```via.example.com```: instance address (defined in config) - ```via.example.com```: instance address (defined in config)
## WARNING ## WARNING
- VIAaaS may trigger anti-cheats, due to block, item, movement and other differences between versions. USE AT OWN RISK. - VIAaaS may trigger anti-cheats, due to block, item, movement and other differences between versions. USE AT OWN RISK.
- Take care of browser local storage. Check for XSS vulnerabilities on your domain. - Take care of browser local storage. Check for XSS vulnerabilities on your domain.
- Check the security of CORS proxy, it will be used for calls to Mojang API. - Check the security of CORS proxy, it will be used for calling to Mojang API.
- Mojang may lock your account when API is called from a suspect IP address. - Mojang may [lock](https://wiki.geysermc.org/geyser/common-issues/#mojang-resetting-account-credentials) your account
when API is called from a suspect IP address.
## FAQ ## FAQ
@ -145,6 +139,9 @@ Fabric/Forge client:
- If you are using a public VIAaaS instance, use this page https://viaversion.github.io/VIAaaS/ and configure the - If you are using a public VIAaaS instance, use this page https://viaversion.github.io/VIAaaS/ and configure the
WebSocket address. WebSocket address.
- If you're an administrator of the instance, edit ```config/web/js/config.js``` (default is in the jar) and
configure your [Azure Client ID](https://wiki.vg/Microsoft_Authentication_Scheme#Microsoft_OAuth_Flow) and your domain
whitelist.
### Connection ### Connection
@ -153,9 +150,9 @@ Fabric/Forge client:
- When listening to 0.0.0.0, it should listen on IPv6 too. - When listening to 0.0.0.0, it should listen on IPv6 too.
- The hostname parser currently doesn't support direct IPv6, but you can use a DNS name with https://sslip.io/ - The hostname parser currently doesn't support direct IPv6, but you can use a DNS name with https://sslip.io/
#### I'm getting a DNS error/"Unknown host" while connecting to (...).localhost #### I'm getting a DNS error/"Unknown host" while connecting to via.localhost
- Try configuring via.localho.st as hostname suffix - Try configuring ```via.localho.st``` as hostname suffix instead
#### How to use with Geyser? #### How to use with Geyser?
@ -175,7 +172,8 @@ Fabric/Forge client:
#### Can you support more versions / Is there some alternative? #### Can you support more versions / Is there some alternative?
- See [DirtMultiVersion](https://github.com/DirtPowered/DirtMultiversion) and RK_01's ViaProxy server (viaproxy.raphimc.net) - See [DirtMultiVersion](https://github.com/DirtPowered/DirtMultiversion) and RK_01's ViaProxy server (
viaproxy.raphimc.net)
#### Can I customize the files of HTTP server? #### Can I customize the files of HTTP server?

View File

@ -57,7 +57,7 @@ dependencies {
implementation(kotlin("stdlib-jdk8")) implementation(kotlin("stdlib-jdk8"))
implementation(kotlin("reflect")) implementation(kotlin("reflect"))
val vvVer = "4.3.0-1.19-pre3-SNAPSHOT" val vvVer = "4.3.0-1.19-rc2-SNAPSHOT"
val vbVer = "4.3.0-1.19-pre2-SNAPSHOT" val vbVer = "4.3.0-1.19-pre2-SNAPSHOT"
val vrVer = "d189537" val vrVer = "d189537"
implementation("com.viaversion:viaversion:$vvVer") { isTransitive = false } implementation("com.viaversion:viaversion:$vvVer") { isTransitive = false }
@ -66,7 +66,7 @@ dependencies {
implementation("io.netty:netty-all:4.1.77.Final") implementation("io.netty:netty-all:4.1.77.Final")
implementation("io.netty:netty-tcnative-boringssl-static:2.0.52.Final") implementation("io.netty:netty-tcnative-boringssl-static:2.0.52.Final")
implementation("io.netty.incubator:netty-incubator-transport-native-io_uring:0.0.13.Final:linux-x86_64") implementation("io.netty.incubator:netty-incubator-transport-native-io_uring:0.0.14.Final:linux-x86_64")
implementation("com.google.guava:guava:31.1-jre") implementation("com.google.guava:guava:31.1-jre")
implementation("com.velocitypowered:velocity-native:3.1.0") implementation("com.velocitypowered:velocity-native:3.1.0")

View File

@ -1,2 +1,5 @@
jdk: jdk:
- openjdk17 - openjdk17
before_install:
- sdk install java 17.0.1-open
- sdk use java 17.0.1-open

View File

@ -118,7 +118,8 @@ frame-src 'self' https://login.microsoftonline.com/ https://login.live.com/"
<option value="false">Force offline (recommended for Geyser)</option> <option value="false">Force offline (recommended for Geyser)</option>
</select> </select>
<input id="connect_user" type="text" class="form-control" placeholder="Back Username" <input id="connect_user" type="text" class="form-control" placeholder="Back Username"
aria-label="Backend Username"> aria-label="Backend Username" list="backend_user_list">
<datalist id="backend_user_list"></datalist>
</form> </form>
<p>You can also use <a href="https://jo0001.github.io/ViaSetup/aspirin" id="viasetup_address">the address <p>You can also use <a href="https://jo0001.github.io/ViaSetup/aspirin" id="viasetup_address">the address
generator</a> to specify the server</p> generator</a> to specify the server</p>

View File

@ -105,20 +105,22 @@ function addMcAccountToList(account) {
$(accounts).append(line); $(accounts).append(line);
} }
function addListSendToken(username) { function addUsernameList(username) {
let line = $("<option class='mc_username'></option>"); let line = $("<option class='mc_username'></option>");
line.text(username); line.text(username);
$("#send_token_user").append(line); $("#send_token_user").append(line);
$("#backend_user_list").append(line.clone());
} }
function refreshAccountList() { function refreshAccountList() {
accounts.innerHTML = ""; accounts.innerHTML = "";
$("#send_token_user .mc_username").remove(); $("#send_token_user .mc_username").remove();
$("#backend_user_list .mc_username").remove();
getActiveAccounts() getActiveAccounts()
.sort((a, b) => a.name.localeCompare(b.name)) .sort((a, b) => a.name.localeCompare(b.name))
.forEach(it => { .forEach(it => {
addMcAccountToList(it) addMcAccountToList(it)
addListSendToken(it.name) addUsernameList(it.name)
}); });
} }
@ -420,7 +422,7 @@ class McAccount {
acquireActiveToken() { acquireActiveToken() {
return this.checkActive().then(success => { return this.checkActive().then(success => {
if (!success) { if (!success) {
return this.refresh(); return this.refresh().then(() => this);
} }
return this; return this;
}).catch(e => addToast("Failed to refresh token!", e)); }).catch(e => addToast("Failed to refresh token!", e));