mirror of
https://github.com/GeyserMC/GeyserConnect.git
synced 2025-06-26 14:15:22 +02:00
Support 1.18.30
This commit is contained in:
parent
90bbaf6c7f
commit
24437d3ae8
4 changed files with 11 additions and 93 deletions
2
pom.xml
2
pom.xml
|
@ -68,7 +68,7 @@
|
||||||
<dependency>
|
<dependency>
|
||||||
<groupId>org.geysermc</groupId>
|
<groupId>org.geysermc</groupId>
|
||||||
<artifactId>core</artifactId>
|
<artifactId>core</artifactId>
|
||||||
<version>2.0.2-SNAPSHOT</version>
|
<version>2.0.3-SNAPSHOT</version>
|
||||||
</dependency>
|
</dependency>
|
||||||
<dependency>
|
<dependency>
|
||||||
<groupId>net.minecrell</groupId>
|
<groupId>net.minecrell</groupId>
|
||||||
|
|
|
@ -178,16 +178,18 @@ public class PacketHandler implements BedrockPacketHandler {
|
||||||
AuthData authData = new AuthData(
|
AuthData authData = new AuthData(
|
||||||
extraData.get("displayName").asText(),
|
extraData.get("displayName").asText(),
|
||||||
UUID.fromString(extraData.get("identity").asText()),
|
UUID.fromString(extraData.get("identity").asText()),
|
||||||
extraData.get("XUID").asText(),
|
extraData.get("XUID").asText()
|
||||||
chainData, packet.getSkinData().toString()
|
|
||||||
);
|
);
|
||||||
|
|
||||||
// Create a new player and add it to the players list
|
// Create a new player and add it to the players list
|
||||||
player = new Player(authData, session);
|
player = new Player(authData, session);
|
||||||
masterServer.getPlayers().add(player);
|
masterServer.getPlayers().add(player);
|
||||||
|
|
||||||
|
player.setChainData(chainData);
|
||||||
|
|
||||||
// Store the full client data
|
// Store the full client data
|
||||||
player.setClientData(OBJECT_MAPPER.convertValue(OBJECT_MAPPER.readTree(skinData.getPayload().toBytes()), BedrockClientData.class));
|
player.setClientData(OBJECT_MAPPER.convertValue(OBJECT_MAPPER.readTree(skinData.getPayload().toBytes()), BedrockClientData.class));
|
||||||
|
player.getClientData().setOriginalString(packet.getSkinData().toString());
|
||||||
|
|
||||||
// Tell the client we have logged in successfully
|
// Tell the client we have logged in successfully
|
||||||
PlayStatusPacket playStatusPacket = new PlayStatusPacket();
|
PlayStatusPacket playStatusPacket = new PlayStatusPacket();
|
||||||
|
|
|
@ -25,6 +25,7 @@
|
||||||
|
|
||||||
package org.geysermc.connect.utils;
|
package org.geysermc.connect.utils;
|
||||||
|
|
||||||
|
import com.fasterxml.jackson.databind.JsonNode;
|
||||||
import com.nukkitx.math.vector.Vector2f;
|
import com.nukkitx.math.vector.Vector2f;
|
||||||
import com.nukkitx.math.vector.Vector3f;
|
import com.nukkitx.math.vector.Vector3f;
|
||||||
import com.nukkitx.math.vector.Vector3i;
|
import com.nukkitx.math.vector.Vector3i;
|
||||||
|
@ -41,6 +42,7 @@ import org.geysermc.connect.proxy.GeyserProxySession;
|
||||||
import org.geysermc.connect.ui.FormID;
|
import org.geysermc.connect.ui.FormID;
|
||||||
import org.geysermc.cumulus.Form;
|
import org.geysermc.cumulus.Form;
|
||||||
import org.geysermc.geyser.GeyserImpl;
|
import org.geysermc.geyser.GeyserImpl;
|
||||||
|
import org.geysermc.geyser.level.BedrockDimension;
|
||||||
import org.geysermc.geyser.network.UpstreamPacketHandler;
|
import org.geysermc.geyser.network.UpstreamPacketHandler;
|
||||||
import org.geysermc.geyser.registry.BlockRegistries;
|
import org.geysermc.geyser.registry.BlockRegistries;
|
||||||
import org.geysermc.geyser.registry.Registries;
|
import org.geysermc.geyser.registry.Registries;
|
||||||
|
@ -58,6 +60,8 @@ import java.util.List;
|
||||||
public class Player {
|
public class Player {
|
||||||
|
|
||||||
private final AuthData authData;
|
private final AuthData authData;
|
||||||
|
@Setter
|
||||||
|
private JsonNode chainData;
|
||||||
|
|
||||||
private final BedrockServerSession session;
|
private final BedrockServerSession session;
|
||||||
|
|
||||||
|
@ -100,7 +104,7 @@ public class Player {
|
||||||
startGamePacket.setPlayerPosition(Vector3f.from(0, 64 + 2, 0));
|
startGamePacket.setPlayerPosition(Vector3f.from(0, 64 + 2, 0));
|
||||||
startGamePacket.setRotation(Vector2f.ONE);
|
startGamePacket.setRotation(Vector2f.ONE);
|
||||||
|
|
||||||
startGamePacket.setSeed(-1);
|
startGamePacket.setSeed(-1L);
|
||||||
startGamePacket.setDimensionId(2);
|
startGamePacket.setDimensionId(2);
|
||||||
startGamePacket.setGeneratorId(1);
|
startGamePacket.setGeneratorId(1);
|
||||||
startGamePacket.setLevelGameType(GameType.CREATIVE);
|
startGamePacket.setLevelGameType(GameType.CREATIVE);
|
||||||
|
@ -266,6 +270,7 @@ public class Player {
|
||||||
geyserSession.setItemMappings(Registries.ITEMS.forVersion(session.getPacketCodec().getProtocolVersion()));
|
geyserSession.setItemMappings(Registries.ITEMS.forVersion(session.getPacketCodec().getProtocolVersion()));
|
||||||
|
|
||||||
geyserSession.setAuthData(authData);
|
geyserSession.setAuthData(authData);
|
||||||
|
geyserSession.setCertChainData(chainData);
|
||||||
geyserSession.setClientData(clientData);
|
geyserSession.setClientData(clientData);
|
||||||
|
|
||||||
return geyserSession;
|
return geyserSession;
|
||||||
|
|
|
@ -1,89 +0,0 @@
|
||||||
/*
|
|
||||||
* Copyright (c) 2019-2020 GeyserMC. http://geysermc.org
|
|
||||||
*
|
|
||||||
* Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
||||||
* of this software and associated documentation files (the "Software"), to deal
|
|
||||||
* in the Software without restriction, including without limitation the rights
|
|
||||||
* to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
||||||
* copies of the Software, and to permit persons to whom the Software is
|
|
||||||
* furnished to do so, subject to the following conditions:
|
|
||||||
*
|
|
||||||
* The above copyright notice and this permission notice shall be included in
|
|
||||||
* all copies or substantial portions of the Software.
|
|
||||||
*
|
|
||||||
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
||||||
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
||||||
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
||||||
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
||||||
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
||||||
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
|
|
||||||
* THE SOFTWARE.
|
|
||||||
*
|
|
||||||
* @author GeyserMC
|
|
||||||
* @link https://github.com/GeyserMC/GeyserConnect
|
|
||||||
*/
|
|
||||||
|
|
||||||
package org.geysermc.connect.utils;
|
|
||||||
|
|
||||||
import org.geysermc.connector.GeyserConnector;
|
|
||||||
|
|
||||||
import java.io.BufferedReader;
|
|
||||||
import java.io.IOException;
|
|
||||||
import java.io.InputStream;
|
|
||||||
import java.io.InputStreamReader;
|
|
||||||
import java.net.HttpURLConnection;
|
|
||||||
import java.net.URL;
|
|
||||||
|
|
||||||
public class WebUtils {
|
|
||||||
/**
|
|
||||||
* Makes a web request to the given URL and returns the body as a string
|
|
||||||
*
|
|
||||||
* @param reqURL URL to fetch
|
|
||||||
* @return Body contents or error message if the request fails
|
|
||||||
*/
|
|
||||||
public static String getBody(String reqURL) {
|
|
||||||
URL url;
|
|
||||||
try {
|
|
||||||
url = new URL(reqURL);
|
|
||||||
HttpURLConnection con = (HttpURLConnection) url.openConnection();
|
|
||||||
con.setRequestMethod("GET");
|
|
||||||
con.setRequestProperty("User-Agent", "Geyser-Connect/" + GeyserConnector.VERSION); // Otherwise Java 8 fails on checking updates
|
|
||||||
|
|
||||||
return connectionToString(con);
|
|
||||||
} catch (Exception e) {
|
|
||||||
return e.getMessage();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Get the string output from the passed {@link HttpURLConnection}
|
|
||||||
*
|
|
||||||
* @param con The connection to get the string from
|
|
||||||
* @return The body of the returned page
|
|
||||||
* @throws IOException If the request fails
|
|
||||||
*/
|
|
||||||
private static String connectionToString(HttpURLConnection con) throws IOException {
|
|
||||||
// Send the request (we dont use this but its required for getErrorStream() to work)
|
|
||||||
int code = con.getResponseCode();
|
|
||||||
|
|
||||||
// Read the error message if there is one if not just read normally
|
|
||||||
InputStream inputStream = con.getErrorStream();
|
|
||||||
if (inputStream == null) {
|
|
||||||
inputStream = con.getInputStream();
|
|
||||||
}
|
|
||||||
|
|
||||||
BufferedReader in = new BufferedReader(new InputStreamReader(inputStream));
|
|
||||||
String inputLine;
|
|
||||||
StringBuilder content = new StringBuilder();
|
|
||||||
|
|
||||||
while ((inputLine = in.readLine()) != null) {
|
|
||||||
content.append(inputLine);
|
|
||||||
content.append("\n");
|
|
||||||
}
|
|
||||||
|
|
||||||
in.close();
|
|
||||||
con.disconnect();
|
|
||||||
|
|
||||||
return content.toString();
|
|
||||||
}
|
|
||||||
}
|
|
Loading…
Add table
Reference in a new issue