mirror of
https://github.com/Melledy/Nebula.git
synced 2025-12-14 13:24:43 +01:00
Handle record rename/delete/lock/favorite
This commit is contained in:
@@ -0,0 +1,35 @@
|
||||
package emu.nebula.server.handlers;
|
||||
|
||||
import emu.nebula.net.NetHandler;
|
||||
import emu.nebula.net.NetMsgId;
|
||||
import emu.nebula.proto.StarTowerBuildDelete.StarTowerBuildDeleteReq;
|
||||
import emu.nebula.proto.StarTowerBuildDelete.StarTowerBuildDeleteResp;
|
||||
import emu.nebula.net.HandlerId;
|
||||
import emu.nebula.game.player.PlayerChangeInfo;
|
||||
import emu.nebula.net.GameSession;
|
||||
|
||||
@HandlerId(NetMsgId.star_tower_build_delete_req)
|
||||
public class HandlerStarTowerBuildDeleteReq extends NetHandler {
|
||||
|
||||
@Override
|
||||
public byte[] handle(GameSession session, byte[] message) throws Exception {
|
||||
// Parse request
|
||||
var req = StarTowerBuildDeleteReq.parseFrom(message);
|
||||
|
||||
//
|
||||
var changes = new PlayerChangeInfo();
|
||||
|
||||
// Delete
|
||||
for (var id : req.getBuildIds()) {
|
||||
session.getPlayer().getStarTowerManager().deleteBuild(id, changes);
|
||||
}
|
||||
|
||||
// Build response
|
||||
var rsp = StarTowerBuildDeleteResp.newInstance()
|
||||
.setChange(changes.toProto());
|
||||
|
||||
// Encode packet
|
||||
return this.encodeMsg(NetMsgId.star_tower_build_delete_succeed_ack, rsp);
|
||||
}
|
||||
|
||||
}
|
||||
@@ -0,0 +1,30 @@
|
||||
package emu.nebula.server.handlers;
|
||||
|
||||
import emu.nebula.net.NetHandler;
|
||||
import emu.nebula.net.NetMsgId;
|
||||
import emu.nebula.proto.StarTowerBuildLockUnlock.StarTowerBuildLockUnlockReq;
|
||||
import emu.nebula.net.HandlerId;
|
||||
import emu.nebula.net.GameSession;
|
||||
|
||||
@HandlerId(NetMsgId.star_tower_build_lock_unlock_req)
|
||||
public class HandlerStarTowerBuildLockUnlockReq extends NetHandler {
|
||||
|
||||
@Override
|
||||
public byte[] handle(GameSession session, byte[] message) throws Exception {
|
||||
// Parse request
|
||||
var req = StarTowerBuildLockUnlockReq.parseFrom(message);
|
||||
|
||||
// Get build
|
||||
var build = session.getPlayer().getStarTowerManager().getBuildById(req.getBuildId());
|
||||
|
||||
if (build == null) {
|
||||
return this.encodeMsg(NetMsgId.star_tower_build_lock_unlock_failed_ack);
|
||||
}
|
||||
|
||||
build.setLock(req.getLock());
|
||||
|
||||
// Encode packet
|
||||
return this.encodeMsg(NetMsgId.star_tower_build_lock_unlock_succeed_ack);
|
||||
}
|
||||
|
||||
}
|
||||
@@ -0,0 +1,36 @@
|
||||
package emu.nebula.server.handlers;
|
||||
|
||||
import emu.nebula.net.NetHandler;
|
||||
import emu.nebula.net.NetMsgId;
|
||||
import emu.nebula.proto.StarTowerBuildNameSet.StarTowerBuildNameSetReq;
|
||||
import emu.nebula.net.HandlerId;
|
||||
import emu.nebula.net.GameSession;
|
||||
|
||||
@HandlerId(NetMsgId.star_tower_build_name_set_req)
|
||||
public class HandlerStarTowerBuildNameSetReq extends NetHandler {
|
||||
|
||||
@Override
|
||||
public byte[] handle(GameSession session, byte[] message) throws Exception {
|
||||
// Parse request
|
||||
var req = StarTowerBuildNameSetReq.parseFrom(message);
|
||||
|
||||
// Sanity
|
||||
if (req.getName() == null || req.getName().isEmpty()) {
|
||||
return this.encodeMsg(NetMsgId.star_tower_build_name_set_failed_ack);
|
||||
}
|
||||
|
||||
// Get build
|
||||
var build = session.getPlayer().getStarTowerManager().getBuildById(req.getBuildId());
|
||||
|
||||
if (build == null) {
|
||||
return this.encodeMsg(NetMsgId.star_tower_build_name_set_failed_ack);
|
||||
}
|
||||
|
||||
// Set name
|
||||
build.setName(req.getName());
|
||||
|
||||
// Encode packet
|
||||
return this.encodeMsg(NetMsgId.star_tower_build_name_set_succeed_ack);
|
||||
}
|
||||
|
||||
}
|
||||
@@ -0,0 +1,43 @@
|
||||
package emu.nebula.server.handlers;
|
||||
|
||||
import emu.nebula.net.NetHandler;
|
||||
import emu.nebula.net.NetMsgId;
|
||||
import emu.nebula.proto.StarTowerBuildPreferenceSet.StarTowerBuildPreferenceSetReq;
|
||||
import emu.nebula.net.HandlerId;
|
||||
import emu.nebula.net.GameSession;
|
||||
|
||||
@HandlerId(NetMsgId.star_tower_build_preference_set_req)
|
||||
public class HandlerStarTowerBuildPreferenceSetReq extends NetHandler {
|
||||
|
||||
@Override
|
||||
public byte[] handle(GameSession session, byte[] message) throws Exception {
|
||||
// Parse request
|
||||
var req = StarTowerBuildPreferenceSetReq.parseFrom(message);
|
||||
|
||||
for (long id : req.getCheckInIds()) {
|
||||
// Get build
|
||||
var build = session.getPlayer().getStarTowerManager().getBuildById(id);
|
||||
|
||||
if (build == null) {
|
||||
continue;
|
||||
}
|
||||
|
||||
build.setPreference(true);
|
||||
}
|
||||
|
||||
for (long id : req.getCheckOutIds()) {
|
||||
// Get build
|
||||
var build = session.getPlayer().getStarTowerManager().getBuildById(id);
|
||||
|
||||
if (build == null) {
|
||||
continue;
|
||||
}
|
||||
|
||||
build.setPreference(false);
|
||||
}
|
||||
|
||||
// Encode packet
|
||||
return this.encodeMsg(NetMsgId.star_tower_build_preference_set_succeed_ack);
|
||||
}
|
||||
|
||||
}
|
||||
@@ -12,9 +12,9 @@ public class HandlerStarTowerInteractReq extends NetHandler {
|
||||
@Override
|
||||
public byte[] handle(GameSession session, byte[] message) throws Exception {
|
||||
// Get star tower instance
|
||||
var instance = session.getPlayer().getStarTowerManager().getInstance();
|
||||
var game = session.getPlayer().getStarTowerManager().getGame();
|
||||
|
||||
if (instance == null) {
|
||||
if (game == null) {
|
||||
return this.encodeMsg(NetMsgId.star_tower_interact_failed_ack);
|
||||
}
|
||||
|
||||
@@ -22,7 +22,7 @@ public class HandlerStarTowerInteractReq extends NetHandler {
|
||||
var req = StarTowerInteractReq.parseFrom(message);
|
||||
|
||||
// Handle interaction
|
||||
var rsp = instance.handleInteract(req);
|
||||
var rsp = game.handleInteract(req);
|
||||
|
||||
// Template
|
||||
return this.encodeMsg(NetMsgId.star_tower_interact_succeed_ack, rsp);
|
||||
|
||||
Reference in New Issue
Block a user