mirror of
https://github.com/ViaVersion/ViaAprilFools.git
synced 2025-01-07 19:07:35 +01:00
114 lines
4.3 KiB
Markdown
114 lines
4.3 KiB
Markdown
# ViaAprilFools
|
|
ViaVersion addon to add support for some notable Minecraft snapshots.
|
|
|
|
ViaAprilFools itself runs on Paper and Velocity servers and can be implemented in any other platform which supports ViaVersion.
|
|
|
|
If you are looking to implement ViaAprilFools in your own software you can start by reading the [Usage](#usage) section.
|
|
If you just want to use ViaAprilFools yourself you can check out some projects which implement it in the [Projects](#projects-implementing-viaaprilfools) section.
|
|
|
|
### Added Server protocols
|
|
- 3D Shareware
|
|
- 20w14infinite
|
|
- Combat Test 8c
|
|
|
|
### Added Client protocols
|
|
- 3D Shareware
|
|
- Combat Test 8c
|
|
|
|
### Projects implementing ViaAprilFools
|
|
- [ViaProxy](https://github.com/ViaVersion/ViaProxy): Standalone proxy which uses ViaVersion to translate between Minecraft versions. Allows Minecraft 1.7+ clients to join to any version server.
|
|
- [ViaFabricPlus](https://github.com/ViaVersion/ViaFabricPlus): Fabric mod for the latest Minecraft version with QoL fixes and enhancements to the gameplay.
|
|
- [ViaFabric](https://github.com/ViaVersion/ViaFabric): Client-side and server-side ViaVersion implementation for Fabric
|
|
|
|
## Releases
|
|
### Gradle/Maven
|
|
To use ViaAprilFools with Gradle/Maven you can use the ViaVersion maven server:
|
|
```groovy
|
|
repositories {
|
|
maven { url "https://repo.viaversion.com" }
|
|
}
|
|
|
|
dependencies {
|
|
implementation("net.raphimc:viaaprilfools-common:x.x.x") // Get latest version from releases
|
|
}
|
|
```
|
|
|
|
```xml
|
|
<repositories>
|
|
<repository>
|
|
<id>viaversion</id>
|
|
<url>https://repo.viaversion.com</url>
|
|
</repository>
|
|
</repositories>
|
|
|
|
<dependencies>
|
|
<dependency>
|
|
<groupId>net.raphimc</groupId>
|
|
<artifactId>viaaprilfools-common</artifactId>
|
|
<version>x.x.x</version> <!-- Get latest version from releases -->
|
|
</dependency>
|
|
</dependencies>
|
|
```
|
|
|
|
### Jar File
|
|
If you just want the latest jar file you can download it from [GitHub Actions](https://github.com/RaphiMC/ViaAprilFools/actions/workflows/build.yml) or the [ViaVersion Jenkins](https://ci.viaversion.com/view/All/job/ViaAprilFools/).
|
|
|
|
## Usage
|
|
ViaAprilFools requires you to have an already functional ViaVersion implementation for your platform.
|
|
If you don't have one you can check out [ViaLoader](https://github.com/ViaVersion/ViaLoader) for an abstracted and simplified, but still customizable implementation.
|
|
You can also go to the other [ViaVersion](https://github.com/ViaVersion) repositories and look at their server and proxy implementations.
|
|
|
|
### Base Implementation
|
|
#### ViaAprilFools platform implementation
|
|
To get started you should create a class which implements the ViaAprilFools platform interface.
|
|
Here is an example:
|
|
```java
|
|
public class ViaAprilFoolsPlatformImpl implements ViaAprilFoolsPlatform {
|
|
|
|
public ViaAprilFoolsPlatformImpl() {
|
|
this.init(this.getDataFolder());
|
|
}
|
|
|
|
@Override
|
|
public Logger getLogger() {
|
|
return Via.getPlatform().getLogger();
|
|
}
|
|
|
|
@Override
|
|
public File getDataFolder() {
|
|
return Via.getPlatform().getDataFolder();
|
|
}
|
|
|
|
}
|
|
```
|
|
This is a very basic implementation which just uses the ViaVersion logger and data folder.
|
|
|
|
#### Loading the platform
|
|
After you have created your platform implementation you should load it in your ViaVersion implementation.
|
|
Here is an example:
|
|
```java
|
|
Via.getManager().addEnableListener(ViaAprilFoolsPlatformImpl::new);
|
|
```
|
|
Make sure to add the enable listener before the Via manager is initialized (``((ViaManagerImpl) Via.getManager()).init();``).
|
|
|
|
#### Note
|
|
If you want your platform to support the client protocols, you need the override the ``getClientProtocol`` function in your version provider:
|
|
```java
|
|
@Override
|
|
public ProtocolVersion getClientProtocol(UserConnection connection) {
|
|
final ProtocolVersion version = connection.getProtocolInfo().protocolVersion();
|
|
if (version.getVersionType() == VersionType.SPECIAL) {
|
|
return ProtocolVersion.getProtocol(VersionType.SPECIAL, version.getOriginalVersion());
|
|
} else {
|
|
return super.getClientProtocol(connection);
|
|
}
|
|
}
|
|
```
|
|
There is also a ``VAFServerVersionProvider`` which can act as wrapper class instead.
|
|
|
|
## Contact
|
|
If you encounter any issues, please report them on the
|
|
[issue tracker](https://github.com/ViaVersion/ViaAprilFools/issues).
|
|
If you just want to talk or need help implementing ViaAprilFools feel free to join the ViaVersion
|
|
[Discord](https://discord.gg/viaversion).
|