ViaVersion as a Service - standalone ViaVersion proxy
Go to file
creeper123123321 6020bb653a
separate readme
2021-02-18 19:08:42 -03:00
.github/workflows Update gradle.yml 2020-10-31 07:35:45 -03:00
.well-known Create microsoft-identity-association.json 2021-01-31 13:19:47 -03:00
gradle/wrapper use Aspirin prefix instead of Cloud, use subcommand, add force online mode 2021-02-12 17:47:15 -03:00
src/main fix import, show backend address in login msg 2021-02-18 18:08:33 -03:00
.gitignore fix gitignore 2021-02-10 10:43:41 -03:00
build.gradle.kts 0.2.0 2021-02-16 20:05:18 -03:00
gradlew update gradle, use fetch 2021-01-19 14:36:45 -03:00
gradlew.bat update gradle, use fetch 2021-01-19 14:36:45 -03:00
index.html redirect page 2020-11-15 11:48:09 -03:00
LICENSE.md draft 2020-08-15 18:02:35 -03:00
README.md separate readme 2021-02-18 19:08:42 -03:00

VIAaaS

VIAaaS - ViaVersion acetylsalicylic acid as a Service - Standalone ViaVersion proxy

How does it work?

  • VIAaaS auth page stores account credentials in the player's browser local storage.
  • Due to technical/security reasons, it requires a CORS Proxy for calling Mojang APIs, which may make Mojang see that as suspicious and reset/block your account password if the IP address seems suspect.
  • Account credentials aren't sent to VIAaaS instance, though it could be intermediated by CORS Proxy.
  • VIAaaS receives a session hash from instance and then authenticates the session hash with Mojang.

Setting up server instance

Download: GitHub Actions (needs to be logged into GitHub)

How to start VIAaaS server:

  • Requires Java 11
  • java -jar VIAaaS-all.jar
  • Default Minecraft: viaaas.localhost with port 25565
  • Default WS URL: wss://localhost:25543/ws

CORS Proxy

Setting up cors-anywhere on local machine:

  • git clone https://github.com/Rob--W/cors-anywhere && cd cors-anywhere && npm install && node server.js

My cors-anywhere instance:

Usage for players

Usage for offline mode:

  • Connect to mc.example.com.viaaas.localhost

Usage for online mode:

  • You can use two accounts (avoids Bad Login error), the same account for front-end and back-end connections or use _of (offline mode in frontend, unencrypted).
  • You should set up a CORS Proxy (something like cors-anywhere) on the machine you are using the VIAaaS authenticator webpage. You can use a remote proxy but Mojang may see it as suspect.
  • Go to VIAaaS auth webpage (https://localhost:25543/), configure the CORS Proxy URL (something like http://localhost:8080/, note the ending slash) and listen to the username A you'll use to connect to the proxy.
  • Add the account B you'll use in _u(account B) parameter to browser auth page.
  • Connect to mc.example.com._u(account B).viaaas.localhost (_u parameter can be removed if you are using the same username)
  • Approve the login in auth webpage
  • If you use the same online mode account, your client will show Bad Login. You can use a mod like Auth Me or ReAuth for reauthenticating the client.

Example address: server.example.com._p25565._v1_12_2._ofalse._uBACKUSERNAME.viaaas.example.com (similar to tor to web proxies)

Address parts:

  • server.example.com: backend server address
  • _p: backend port
  • _v: backend version (protocol id or name with underline instead of dots). AUTO is default and 1.8 is fallback if it fails.
  • _o: t to force online mode in frontend, f to disable online mode in frontend. If not set, it will be based on backend online mode.
  • _u: username to use in backend connection
  • viaaas.example.com: hostname suffix (defined in config)

WARNING

  • VIAaaS may trigger anti-cheats, due to block, item, movement and other differences between versions. USE AT OWN RISK
  • VIAaaS server instance may have security vulnerabilities, make sure to block the ports in firewall
  • Take care of browser local storage.
  • Check the security of CORS proxy, it will intermediate Mojang API calls.
  • Mojang may lock your account when API is called from a suspect IP address

FAQ

VIAaaS is stuck when connecting with online mode:

My Microsoft account <18 years old is not able to log in, it's giving XSTS error:

Why a online webpage for online mode?:

  • It's easier to maintain in that way, because providing a chat with login requires encoding and decoding more packets which change through versions.
  • It allows your account password and token to be kept with you