mirror of
https://github.com/Grasscutters/Grasscutter.git
synced 2025-01-25 08:13:01 +08:00
Merge branch 'Grasscutters:development' into development
This commit is contained in:
commit
042bdc2ff2
@ -1 +1 @@
|
|||||||
Subproject commit 0537e9cc4c7856a7c6f88bbbaa908a80c4ee677e
|
Subproject commit dd17415b71dfcff049e72dbe8a76173611f4b0ae
|
@ -29,7 +29,7 @@ public final class Config {
|
|||||||
public int Port = 443;
|
public int Port = 443;
|
||||||
public int PublicPort = 0;
|
public int PublicPort = 0;
|
||||||
public String KeystorePath = "./keystore.p12";
|
public String KeystorePath = "./keystore.p12";
|
||||||
public String KeystorePassword = "";
|
public String KeystorePassword = "123456";
|
||||||
public Boolean UseSSL = true;
|
public Boolean UseSSL = true;
|
||||||
public Boolean FrontHTTPS = true;
|
public Boolean FrontHTTPS = true;
|
||||||
|
|
||||||
|
@ -118,6 +118,7 @@ public final class Grasscutter {
|
|||||||
|
|
||||||
public static void startConsole() {
|
public static void startConsole() {
|
||||||
String input;
|
String input;
|
||||||
|
getLogger().info("Done! For help, type \"help\"");
|
||||||
try (BufferedReader br = new BufferedReader(new InputStreamReader(System.in))) {
|
try (BufferedReader br = new BufferedReader(new InputStreamReader(System.in))) {
|
||||||
while ((input = br.readLine()) != null) {
|
while ((input = br.readLine()) != null) {
|
||||||
try {
|
try {
|
||||||
|
@ -0,0 +1,29 @@
|
|||||||
|
package emu.grasscutter.command.commands;
|
||||||
|
|
||||||
|
import emu.grasscutter.command.Command;
|
||||||
|
import emu.grasscutter.command.CommandHandler;
|
||||||
|
import emu.grasscutter.game.GenshinPlayer;
|
||||||
|
import emu.grasscutter.game.inventory.Inventory;
|
||||||
|
import emu.grasscutter.game.inventory.ItemType;
|
||||||
|
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
@Command(label = "clearweapons", usage = "clearweapons",
|
||||||
|
description = "Deletes all unequipped and unlocked weapons, including yellow rarity ones from your inventory",
|
||||||
|
aliases = {"clearwpns"}, permission = "player.clearweapons")
|
||||||
|
public final class ClearWeaponsCommand implements CommandHandler {
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void execute(GenshinPlayer sender, List<String> args) {
|
||||||
|
if (sender == null) {
|
||||||
|
CommandHandler.sendMessage(null, "Run this command in-game.");
|
||||||
|
return; // TODO: clear player's weapons from console or other players
|
||||||
|
}
|
||||||
|
|
||||||
|
Inventory playerInventory = sender.getInventory();
|
||||||
|
playerInventory.getItems().values().stream()
|
||||||
|
.filter(item -> item.getItemType() == ItemType.ITEM_WEAPON)
|
||||||
|
.filter(item -> !item.isLocked() && !item.isEquipped())
|
||||||
|
.forEach(item -> playerInventory.removeItem(item, item.getCount()));
|
||||||
|
}
|
||||||
|
}
|
@ -18,6 +18,7 @@ import emu.grasscutter.game.friends.PlayerProfile;
|
|||||||
import emu.grasscutter.game.gacha.PlayerGachaInfo;
|
import emu.grasscutter.game.gacha.PlayerGachaInfo;
|
||||||
import emu.grasscutter.game.inventory.GenshinItem;
|
import emu.grasscutter.game.inventory.GenshinItem;
|
||||||
import emu.grasscutter.game.inventory.Inventory;
|
import emu.grasscutter.game.inventory.Inventory;
|
||||||
|
import emu.grasscutter.game.player.PlayerBirthday;
|
||||||
import emu.grasscutter.game.props.ActionReason;
|
import emu.grasscutter.game.props.ActionReason;
|
||||||
import emu.grasscutter.game.props.PlayerProperty;
|
import emu.grasscutter.game.props.PlayerProperty;
|
||||||
import emu.grasscutter.net.packet.GenshinPacket;
|
import emu.grasscutter.net.packet.GenshinPacket;
|
||||||
@ -73,6 +74,7 @@ public class GenshinPlayer {
|
|||||||
private int nameCardId = 210001;
|
private int nameCardId = 210001;
|
||||||
private Position pos;
|
private Position pos;
|
||||||
private Position rotation;
|
private Position rotation;
|
||||||
|
private PlayerBirthday birthday;
|
||||||
|
|
||||||
private Map<Integer, Integer> properties;
|
private Map<Integer, Integer> properties;
|
||||||
private Set<Integer> nameCardList;
|
private Set<Integer> nameCardList;
|
||||||
@ -139,6 +141,8 @@ public class GenshinPlayer {
|
|||||||
this.combatInvokeHandler = new InvokeHandler(PacketCombatInvocationsNotify.class);
|
this.combatInvokeHandler = new InvokeHandler(PacketCombatInvocationsNotify.class);
|
||||||
this.abilityInvokeHandler = new InvokeHandler(PacketAbilityInvocationsNotify.class);
|
this.abilityInvokeHandler = new InvokeHandler(PacketAbilityInvocationsNotify.class);
|
||||||
this.clientAbilityInitFinishHandler = new InvokeHandler(PacketClientAbilityInitFinishNotify.class);
|
this.clientAbilityInitFinishHandler = new InvokeHandler(PacketClientAbilityInitFinishNotify.class);
|
||||||
|
|
||||||
|
this.birthday = new PlayerBirthday();
|
||||||
}
|
}
|
||||||
|
|
||||||
// On player creation
|
// On player creation
|
||||||
@ -150,6 +154,7 @@ public class GenshinPlayer {
|
|||||||
this.nickname = "Traveler";
|
this.nickname = "Traveler";
|
||||||
this.signature = "";
|
this.signature = "";
|
||||||
this.teamManager = new TeamManager(this);
|
this.teamManager = new TeamManager(this);
|
||||||
|
this.birthday = new PlayerBirthday();
|
||||||
this.setProperty(PlayerProperty.PROP_PLAYER_LEVEL, 1);
|
this.setProperty(PlayerProperty.PROP_PLAYER_LEVEL, 1);
|
||||||
this.setProperty(PlayerProperty.PROP_IS_SPRING_AUTO_USE, 1);
|
this.setProperty(PlayerProperty.PROP_IS_SPRING_AUTO_USE, 1);
|
||||||
this.setProperty(PlayerProperty.PROP_SPRING_AUTO_USE_PERCENT, 50);
|
this.setProperty(PlayerProperty.PROP_SPRING_AUTO_USE_PERCENT, 50);
|
||||||
@ -642,6 +647,15 @@ public class GenshinPlayer {
|
|||||||
return onlineInfo.build();
|
return onlineInfo.build();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public PlayerBirthday getBirthday(){
|
||||||
|
return this.birthday;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setBirthday(int d, int m) {
|
||||||
|
this.birthday = new PlayerBirthday(d, m);
|
||||||
|
this.updateProfile();
|
||||||
|
}
|
||||||
|
|
||||||
public SocialDetail.Builder getSocialDetail() {
|
public SocialDetail.Builder getSocialDetail() {
|
||||||
SocialDetail.Builder social = SocialDetail.newBuilder()
|
SocialDetail.Builder social = SocialDetail.newBuilder()
|
||||||
.setUid(this.getUid())
|
.setUid(this.getUid())
|
||||||
@ -649,7 +663,7 @@ public class GenshinPlayer {
|
|||||||
.setNickname(this.getNickname())
|
.setNickname(this.getNickname())
|
||||||
.setSignature(this.getSignature())
|
.setSignature(this.getSignature())
|
||||||
.setLevel(this.getLevel())
|
.setLevel(this.getLevel())
|
||||||
.setBirthday(Birthday.newBuilder())
|
.setBirthday(this.getBirthday().getFilledProtoWhenNotEmpty())
|
||||||
.setWorldLevel(this.getWorldLevel())
|
.setWorldLevel(this.getWorldLevel())
|
||||||
.setUnk1(1)
|
.setUnk1(1)
|
||||||
.setUnk3(1)
|
.setUnk3(1)
|
||||||
|
@ -0,0 +1,70 @@
|
|||||||
|
package emu.grasscutter.game.player;
|
||||||
|
|
||||||
|
import dev.morphia.annotations.Entity;
|
||||||
|
import emu.grasscutter.net.proto.BirthdayOuterClass.Birthday;
|
||||||
|
|
||||||
|
@Entity
|
||||||
|
public class PlayerBirthday {
|
||||||
|
private int day;
|
||||||
|
private int month;
|
||||||
|
|
||||||
|
public PlayerBirthday(){
|
||||||
|
this.day = 0;
|
||||||
|
this.month = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
public PlayerBirthday(int day, int month){
|
||||||
|
this.day = day;
|
||||||
|
this.month = month;
|
||||||
|
}
|
||||||
|
|
||||||
|
public PlayerBirthday set(PlayerBirthday birth){
|
||||||
|
this.day = birth.day;
|
||||||
|
this.month = birth.month;
|
||||||
|
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public PlayerBirthday set(int d, int m){
|
||||||
|
this.day = d;
|
||||||
|
this.month = m;
|
||||||
|
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public PlayerBirthday setDay(int value){
|
||||||
|
this.day = value;
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public PlayerBirthday setMonth(int value){
|
||||||
|
this.month = value;
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public int getDay(){
|
||||||
|
return this.day;
|
||||||
|
}
|
||||||
|
|
||||||
|
public int getMonth(){
|
||||||
|
return this.month;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Birthday toProto(){
|
||||||
|
return Birthday.newBuilder()
|
||||||
|
.setDay(this.getDay())
|
||||||
|
.setMonth(this.getMonth())
|
||||||
|
.build();
|
||||||
|
}
|
||||||
|
|
||||||
|
public Birthday.Builder getFilledProtoWhenNotEmpty(){
|
||||||
|
if(this.getDay() > 0)
|
||||||
|
{
|
||||||
|
return Birthday.newBuilder()
|
||||||
|
.setDay(this.getDay())
|
||||||
|
.setMonth(this.getMonth());
|
||||||
|
}
|
||||||
|
|
||||||
|
return Birthday.newBuilder();
|
||||||
|
}
|
||||||
|
}
|
@ -1034,6 +1034,8 @@ public class PacketOpcodes {
|
|||||||
public static final int ShowTemplateReminderNotify = 3164;
|
public static final int ShowTemplateReminderNotify = 3164;
|
||||||
public static final int SignInInfoReq = 2510;
|
public static final int SignInInfoReq = 2510;
|
||||||
public static final int SignInInfoRsp = 2515;
|
public static final int SignInInfoRsp = 2515;
|
||||||
|
public static final int SitReq = 354;
|
||||||
|
public static final int SitRsp = 335;
|
||||||
public static final int SocialDataNotify = 4063;
|
public static final int SocialDataNotify = 4063;
|
||||||
public static final int SpringUseReq = 1720;
|
public static final int SpringUseReq = 1720;
|
||||||
public static final int SpringUseRsp = 1727;
|
public static final int SpringUseRsp = 1727;
|
||||||
@ -1208,5 +1210,4 @@ public class PacketOpcodes {
|
|||||||
public static final int WorldRoutineChangeNotify = 3548;
|
public static final int WorldRoutineChangeNotify = 3548;
|
||||||
public static final int WorldRoutineTypeCloseNotify = 3513;
|
public static final int WorldRoutineTypeCloseNotify = 3513;
|
||||||
public static final int WorldRoutineTypeRefreshNotify = 3545;
|
public static final int WorldRoutineTypeRefreshNotify = 3545;
|
||||||
|
|
||||||
}
|
}
|
@ -64,9 +64,8 @@ public class MihoyoKcpServer extends Thread {
|
|||||||
|
|
||||||
// Wait until the server socket is closed.
|
// Wait until the server socket is closed.
|
||||||
f.channel().closeFuture().sync();
|
f.channel().closeFuture().sync();
|
||||||
} catch (Exception e) {
|
} catch (Exception exception) {
|
||||||
// TODO Auto-generated catch block
|
Grasscutter.getLogger().error("Unable to start game server.", exception);
|
||||||
e.printStackTrace();
|
|
||||||
} finally {
|
} finally {
|
||||||
// Close
|
// Close
|
||||||
finish();
|
finish();
|
||||||
|
@ -24,6 +24,7 @@ import emu.grasscutter.utils.Utils;
|
|||||||
import javax.net.ssl.KeyManagerFactory;
|
import javax.net.ssl.KeyManagerFactory;
|
||||||
import javax.net.ssl.SSLContext;
|
import javax.net.ssl.SSLContext;
|
||||||
import java.io.*;
|
import java.io.*;
|
||||||
|
import java.net.BindException;
|
||||||
import java.net.InetSocketAddress;
|
import java.net.InetSocketAddress;
|
||||||
import java.net.URI;
|
import java.net.URI;
|
||||||
import java.net.URLDecoder;
|
import java.net.URLDecoder;
|
||||||
@ -158,12 +159,21 @@ public final class DispatchServer {
|
|||||||
Grasscutter.getLogger().error("[Dispatch] Error while initializing region info!", e);
|
Grasscutter.getLogger().error("[Dispatch] Error while initializing region info!", e);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private HttpServer safelyCreateServer(InetSocketAddress address) {
|
||||||
|
try {
|
||||||
|
return HttpServer.create(address, 0);
|
||||||
|
} catch (BindException ignored) {
|
||||||
|
Grasscutter.getLogger().error("Unable to bind to port: " + getAddress().getPort() + " (HTTP)");
|
||||||
|
} catch (Exception exception) {
|
||||||
|
Grasscutter.getLogger().error("Unable to start HTTP server.", exception);
|
||||||
|
} return null;
|
||||||
|
}
|
||||||
|
|
||||||
public void start() throws Exception {
|
public void start() throws Exception {
|
||||||
HttpServer server;
|
HttpServer server;
|
||||||
if (Grasscutter.getConfig().getDispatchOptions().UseSSL) {
|
if (Grasscutter.getConfig().getDispatchOptions().UseSSL) {
|
||||||
HttpsServer httpsServer;
|
HttpsServer httpsServer = HttpsServer.create(getAddress(), 0);
|
||||||
httpsServer = HttpsServer.create(getAddress(), 0);
|
|
||||||
SSLContext sslContext = SSLContext.getInstance("TLS");
|
SSLContext sslContext = SSLContext.getInstance("TLS");
|
||||||
try (FileInputStream fis = new FileInputStream(Grasscutter.getConfig().getDispatchOptions().KeystorePath)) {
|
try (FileInputStream fis = new FileInputStream(Grasscutter.getConfig().getDispatchOptions().KeystorePath)) {
|
||||||
char[] keystorePassword = Grasscutter.getConfig().getDispatchOptions().KeystorePassword.toCharArray();
|
char[] keystorePassword = Grasscutter.getConfig().getDispatchOptions().KeystorePassword.toCharArray();
|
||||||
@ -176,14 +186,20 @@ public final class DispatchServer {
|
|||||||
|
|
||||||
httpsServer.setHttpsConfigurator(new HttpsConfigurator(sslContext));
|
httpsServer.setHttpsConfigurator(new HttpsConfigurator(sslContext));
|
||||||
server = httpsServer;
|
server = httpsServer;
|
||||||
|
} catch (BindException ignored) {
|
||||||
|
Grasscutter.getLogger().error("Unable to bind to port: " + getAddress().getPort() + " (HTTPS)");
|
||||||
|
server = this.safelyCreateServer(this.getAddress());
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
Grasscutter.getLogger().warn("[Dispatch] No SSL cert found! Falling back to HTTP server.");
|
Grasscutter.getLogger().warn("[Dispatch] No SSL cert found! Falling back to HTTP server.");
|
||||||
Grasscutter.getConfig().getDispatchOptions().UseSSL = false;
|
Grasscutter.getConfig().getDispatchOptions().UseSSL = false;
|
||||||
server = HttpServer.create(getAddress(), 0);
|
server = this.safelyCreateServer(this.getAddress());
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
server = HttpServer.create(getAddress(), 0);
|
server = this.safelyCreateServer(this.getAddress());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if(server == null)
|
||||||
|
throw new NullPointerException("An HTTP server was not created.");
|
||||||
|
|
||||||
server.createContext("/", t -> responseHTML(t, "Hello"));
|
server.createContext("/", t -> responseHTML(t, "Hello"));
|
||||||
|
|
||||||
|
@ -0,0 +1,21 @@
|
|||||||
|
package emu.grasscutter.server.packet.recv;
|
||||||
|
|
||||||
|
import emu.grasscutter.net.packet.Opcodes;
|
||||||
|
import emu.grasscutter.net.packet.PacketOpcodes;
|
||||||
|
import emu.grasscutter.net.proto.EvtAvatarSitDownNotifyOuterClass.EvtAvatarSitDownNotify;
|
||||||
|
import emu.grasscutter.net.packet.PacketHandler;
|
||||||
|
import emu.grasscutter.server.game.GameSession;
|
||||||
|
import emu.grasscutter.server.packet.send.PacketEvtAvatarSitDownNotify;
|
||||||
|
|
||||||
|
@Opcodes(PacketOpcodes.EvtAvatarSitDownNotify)
|
||||||
|
public class HandleEvtAvatarSitDownNotify extends PacketHandler {
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void handle(GameSession session, byte[] header, byte[] payload) throws Exception {
|
||||||
|
EvtAvatarSitDownNotify notify = EvtAvatarSitDownNotify.parseFrom(payload);
|
||||||
|
|
||||||
|
session.send(new PacketEvtAvatarSitDownNotify(notify));
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
@ -0,0 +1,24 @@
|
|||||||
|
package emu.grasscutter.server.packet.recv;
|
||||||
|
|
||||||
|
import emu.grasscutter.net.packet.Opcodes;
|
||||||
|
import emu.grasscutter.net.packet.PacketHandler;
|
||||||
|
import emu.grasscutter.net.packet.PacketOpcodes;
|
||||||
|
import emu.grasscutter.net.proto.SitReqOuterClass;
|
||||||
|
import emu.grasscutter.server.game.GameSession;
|
||||||
|
import emu.grasscutter.server.packet.send.PacketSitRsp;
|
||||||
|
import emu.grasscutter.utils.Position;
|
||||||
|
|
||||||
|
@Opcodes(PacketOpcodes.SitReq)
|
||||||
|
public class HandleSitReq extends PacketHandler {
|
||||||
|
@Override
|
||||||
|
public void handle(GameSession session, byte[] header, byte[] payload) throws Exception {
|
||||||
|
SitReqOuterClass.SitReq req = SitReqOuterClass.SitReq.parseFrom(payload);
|
||||||
|
|
||||||
|
float x = req.getPosition().getX();
|
||||||
|
float y = req.getPosition().getY();
|
||||||
|
float z = req.getPosition().getZ();
|
||||||
|
|
||||||
|
session.send(new PacketSitRsp(req.getChairId(), new Position(x, y, z), session.getPlayer().getTeamManager().getCurrentAvatarEntity().getId()));
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
@ -0,0 +1,41 @@
|
|||||||
|
package emu.grasscutter.server.packet.recv;
|
||||||
|
|
||||||
|
import emu.grasscutter.game.entity.GenshinEntity;
|
||||||
|
import emu.grasscutter.game.props.LifeState;
|
||||||
|
import emu.grasscutter.net.packet.Opcodes;
|
||||||
|
import emu.grasscutter.net.packet.PacketHandler;
|
||||||
|
import emu.grasscutter.net.packet.PacketOpcodes;
|
||||||
|
import emu.grasscutter.net.proto.SceneEntityDrownReqOuterClass.SceneEntityDrownReq;
|
||||||
|
import emu.grasscutter.net.proto.VisionTypeOuterClass;
|
||||||
|
import emu.grasscutter.server.game.GameSession;
|
||||||
|
import emu.grasscutter.server.packet.send.PacketLifeStateChangeNotify;
|
||||||
|
import emu.grasscutter.server.packet.send.PacketSceneEntityDrownRsp;
|
||||||
|
|
||||||
|
@Opcodes(PacketOpcodes.SceneEntityDrownReq)
|
||||||
|
public class HandlerSceneEntityDrownReq extends PacketHandler {
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void handle(GameSession session, byte[] header, byte[] payload) throws Exception {
|
||||||
|
SceneEntityDrownReq req = SceneEntityDrownReq.parseFrom(payload);
|
||||||
|
|
||||||
|
|
||||||
|
GenshinEntity entity = session.getPlayer().getScene().getEntityById(req.getEntityId());
|
||||||
|
|
||||||
|
|
||||||
|
PacketLifeStateChangeNotify lifeStateChangeNotify = new PacketLifeStateChangeNotify(entity, entity, LifeState.LIFE_DEAD);
|
||||||
|
PacketSceneEntityDrownRsp drownRsp = new PacketSceneEntityDrownRsp(req.getEntityId());
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
//kill entity + broadcast it
|
||||||
|
|
||||||
|
session.getPlayer().getScene().broadcastPacket(lifeStateChangeNotify);
|
||||||
|
session.getPlayer().getScene().broadcastPacket(drownRsp);
|
||||||
|
|
||||||
|
//TODO: make a list somewhere of all entities to remove per tick rather than one by one
|
||||||
|
|
||||||
|
session.getPlayer().getScene().removeEntity(entity, VisionTypeOuterClass.VisionType.VisionDie);
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
@ -0,0 +1,38 @@
|
|||||||
|
package emu.grasscutter.server.packet.recv;
|
||||||
|
|
||||||
|
import emu.grasscutter.server.game.GameSession;
|
||||||
|
import emu.grasscutter.server.packet.send.PacketGetPlayerSocialDetailRsp;
|
||||||
|
import emu.grasscutter.server.packet.send.PacketSetPlayerBirthdayRsp;
|
||||||
|
|
||||||
|
import emu.grasscutter.net.packet.Opcodes;
|
||||||
|
import emu.grasscutter.net.packet.PacketOpcodes;
|
||||||
|
import emu.grasscutter.net.packet.PacketHandler;
|
||||||
|
|
||||||
|
import emu.grasscutter.net.proto.SocialDetailOuterClass.SocialDetail;
|
||||||
|
import emu.grasscutter.net.proto.SetPlayerBirthdayReqOuterClass.SetPlayerBirthdayReq;
|
||||||
|
|
||||||
|
import com.google.gson.Gson;
|
||||||
|
|
||||||
|
@Opcodes(PacketOpcodes.SetPlayerBirthdayReq)
|
||||||
|
public class HandlerSetPlayerBirthdayReq extends PacketHandler {
|
||||||
|
@Override
|
||||||
|
public void handle(GameSession session, byte[] header, byte[] payload) throws Exception {
|
||||||
|
SetPlayerBirthdayReq req = SetPlayerBirthdayReq.parseFrom(payload);
|
||||||
|
|
||||||
|
if(req.getBirth() != null && req.getBirth().getDay() > 0 && req.getBirth().getMonth() > 0)
|
||||||
|
{
|
||||||
|
int day = req.getBirth().getDay();
|
||||||
|
int month = req.getBirth().getMonth();
|
||||||
|
|
||||||
|
// Update birthday value
|
||||||
|
session.getPlayer().setBirthday(day, month);
|
||||||
|
|
||||||
|
// Save birthday month and day
|
||||||
|
session.getPlayer().save();
|
||||||
|
SocialDetail.Builder detail = session.getPlayer().getSocialDetail();
|
||||||
|
|
||||||
|
session.send(new PacketSetPlayerBirthdayRsp(session.getPlayer()));
|
||||||
|
session.send(new PacketGetPlayerSocialDetailRsp(detail));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,20 @@
|
|||||||
|
package emu.grasscutter.server.packet.send;
|
||||||
|
|
||||||
|
import emu.grasscutter.net.packet.GenshinPacket;
|
||||||
|
import emu.grasscutter.net.packet.PacketOpcodes;
|
||||||
|
import emu.grasscutter.net.proto.EvtAvatarSitDownNotifyOuterClass.EvtAvatarSitDownNotify;
|
||||||
|
|
||||||
|
public class PacketEvtAvatarSitDownNotify extends GenshinPacket {
|
||||||
|
|
||||||
|
public PacketEvtAvatarSitDownNotify(EvtAvatarSitDownNotify notify) {
|
||||||
|
super(PacketOpcodes.EvtAvatarSitDownNotify);
|
||||||
|
|
||||||
|
EvtAvatarSitDownNotify proto = EvtAvatarSitDownNotify.newBuilder()
|
||||||
|
.setEntityId(notify.getEntityId())
|
||||||
|
.setPosition(notify.getPosition())
|
||||||
|
.setChairId(notify.getChairId())
|
||||||
|
.build();
|
||||||
|
|
||||||
|
this.setData(proto);
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,20 @@
|
|||||||
|
package emu.grasscutter.server.packet.send;
|
||||||
|
|
||||||
|
import emu.grasscutter.game.entity.GenshinEntity;
|
||||||
|
import emu.grasscutter.net.packet.GenshinPacket;
|
||||||
|
import emu.grasscutter.net.packet.PacketOpcodes;
|
||||||
|
import emu.grasscutter.net.proto.SceneEntityDrownRspOuterClass.SceneEntityDrownRsp;
|
||||||
|
import emu.grasscutter.net.proto.VisionTypeOuterClass.VisionType;
|
||||||
|
|
||||||
|
public class PacketSceneEntityDrownRsp extends GenshinPacket {
|
||||||
|
|
||||||
|
public PacketSceneEntityDrownRsp(int entityId) {
|
||||||
|
super(PacketOpcodes.SceneEntityDrownRsp);
|
||||||
|
|
||||||
|
SceneEntityDrownRsp proto = new SceneEntityDrownRsp().toBuilder().setEntityId(entityId).build();
|
||||||
|
|
||||||
|
this.setData(proto);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
@ -0,0 +1,20 @@
|
|||||||
|
package emu.grasscutter.server.packet.send;
|
||||||
|
|
||||||
|
import emu.grasscutter.Grasscutter;
|
||||||
|
import emu.grasscutter.game.GenshinPlayer;
|
||||||
|
import emu.grasscutter.net.packet.GenshinPacket;
|
||||||
|
import emu.grasscutter.net.packet.PacketOpcodes;
|
||||||
|
import emu.grasscutter.net.proto.SetPlayerBirthdayRspOuterClass.SetPlayerBirthdayRsp;
|
||||||
|
import emu.grasscutter.net.proto.BirthdayOuterClass.Birthday;
|
||||||
|
|
||||||
|
public class PacketSetPlayerBirthdayRsp extends GenshinPacket {
|
||||||
|
public PacketSetPlayerBirthdayRsp(GenshinPlayer player) {
|
||||||
|
super(PacketOpcodes.SetPlayerBirthdayRsp);
|
||||||
|
|
||||||
|
SetPlayerBirthdayRsp proto = SetPlayerBirthdayRsp.newBuilder()
|
||||||
|
.setBirth(player.getBirthday().toProto())
|
||||||
|
.build();
|
||||||
|
|
||||||
|
this.setData(proto);
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,21 @@
|
|||||||
|
package emu.grasscutter.server.packet.send;
|
||||||
|
|
||||||
|
import emu.grasscutter.net.packet.GenshinPacket;
|
||||||
|
import emu.grasscutter.net.packet.PacketOpcodes;
|
||||||
|
import emu.grasscutter.net.proto.SitRspOuterClass.SitRsp;
|
||||||
|
import emu.grasscutter.utils.Position;
|
||||||
|
|
||||||
|
public class PacketSitRsp extends GenshinPacket {
|
||||||
|
|
||||||
|
public PacketSitRsp(long chairId, Position pos, int EntityId) {
|
||||||
|
super(PacketOpcodes.SitRsp);
|
||||||
|
|
||||||
|
SitRsp proto = SitRsp.newBuilder()
|
||||||
|
.setEntityId(EntityId)
|
||||||
|
.setPosition(pos.toProto())
|
||||||
|
.setChairId(chairId)
|
||||||
|
.build();
|
||||||
|
|
||||||
|
this.setData(proto);
|
||||||
|
}
|
||||||
|
}
|
@ -75,9 +75,9 @@ for /f "tokens=2*" %%a in ('reg query "HKCU\Software\Microsoft\Windows\CurrentVe
|
|||||||
@rem TODO: External proxy when ORIG_PROXY_ENABLE == 0x1
|
@rem TODO: External proxy when ORIG_PROXY_ENABLE == 0x1
|
||||||
echo set ws = createobject("wscript.shell") > "%temp%\proxy.vbs"
|
echo set ws = createobject("wscript.shell") > "%temp%\proxy.vbs"
|
||||||
if not "%MITMDUMP_PATH%" == "" (
|
if not "%MITMDUMP_PATH%" == "" (
|
||||||
echo ws.currentdirectory = "%MITMDUMP_PATH%" >> "%temp%\proxy.vbs"
|
echo ws.currentdirectory = "%MITMDUMP_PATH%" >> "%temp%\proxy.vbs"
|
||||||
)
|
)
|
||||||
echo ws.run "cmd /c mitmdump.exe -s "^&chr(34)^&"%PROXY_SCRIPT_NAME%"^&chr(34)^&" -k",0 >> "%temp%\proxy.vbs"
|
echo ws.run "cmd /c mitmdump.exe -s "^&chr(34)^&"%CUR_PATH%%PROXY_SCRIPT_NAME%"^&chr(34)^&" -k",0 >> "%temp%\proxy.vbs"
|
||||||
"%temp%\proxy.vbs"
|
"%temp%\proxy.vbs"
|
||||||
del /f /q "%temp%\proxy.vbs" >nul 2>nul
|
del /f /q "%temp%\proxy.vbs" >nul 2>nul
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user