mirror of
https://github.com/Melledy/Nebula.git
synced 2025-12-16 22:34:41 +01:00
Implement character emblem locking/reforging
This commit is contained in:
@@ -0,0 +1,44 @@
|
||||
package emu.nebula.server.handlers;
|
||||
|
||||
import emu.nebula.net.NetHandler;
|
||||
import emu.nebula.net.NetMsgId;
|
||||
import emu.nebula.proto.CharGemRefresh.CharGemRefreshReq;
|
||||
import emu.nebula.proto.CharGemRefresh.CharGemRefreshResp;
|
||||
import emu.nebula.net.HandlerId;
|
||||
import emu.nebula.game.character.CharacterGem;
|
||||
import emu.nebula.net.GameSession;
|
||||
|
||||
@HandlerId(NetMsgId.char_gem_refresh_req)
|
||||
public class HandlerCharGemRefreshReq extends NetHandler {
|
||||
|
||||
@Override
|
||||
public byte[] handle(GameSession session, byte[] message) throws Exception {
|
||||
// Parse request
|
||||
var req = CharGemRefreshReq.parseFrom(message);
|
||||
|
||||
// Get character
|
||||
var character = session.getPlayer().getCharacters().getCharacterById(req.getCharId());
|
||||
|
||||
if (character == null) {
|
||||
return session.encodeMsg(NetMsgId.char_gem_refresh_failed_ack);
|
||||
}
|
||||
|
||||
// Refresh gem attributes
|
||||
var change = character.refreshGem(req.getSlotId(), req.getGemIndex(), req.getLockAttrs());
|
||||
|
||||
if (change == null) {
|
||||
return session.encodeMsg(NetMsgId.char_gem_refresh_failed_ack);
|
||||
}
|
||||
|
||||
var gem = (CharacterGem) change.getExtraData();
|
||||
|
||||
// Build response
|
||||
var rsp = CharGemRefreshResp.newInstance()
|
||||
.setChangeInfo(change.toProto())
|
||||
.addAllAttributes(gem.getAlterAttributes());
|
||||
|
||||
// Encode and send
|
||||
return session.encodeMsg(NetMsgId.char_gem_refresh_succeed_ack, rsp);
|
||||
}
|
||||
|
||||
}
|
||||
@@ -0,0 +1,35 @@
|
||||
package emu.nebula.server.handlers;
|
||||
|
||||
import emu.nebula.net.NetHandler;
|
||||
import emu.nebula.net.NetMsgId;
|
||||
import emu.nebula.proto.CharGemRenamePreset.CharGemRenamePresetReq;
|
||||
import emu.nebula.net.HandlerId;
|
||||
import emu.nebula.net.GameSession;
|
||||
|
||||
@HandlerId(NetMsgId.char_gem_rename_preset_req)
|
||||
public class HandlerCharGemRenamePresetReq extends NetHandler {
|
||||
|
||||
@Override
|
||||
public byte[] handle(GameSession session, byte[] message) throws Exception {
|
||||
// Parse request
|
||||
var req = CharGemRenamePresetReq.parseFrom(message);
|
||||
|
||||
// Get character
|
||||
var character = session.getPlayer().getCharacters().getCharacterById(req.getCharId());
|
||||
|
||||
if (character == null) {
|
||||
return session.encodeMsg(NetMsgId.char_gem_rename_preset_failed_ack);
|
||||
}
|
||||
|
||||
// Rename
|
||||
boolean success = character.renameGemPreset(req.getPresetId(), req.getNewName());
|
||||
|
||||
if (success == false) {
|
||||
return session.encodeMsg(NetMsgId.char_gem_rename_preset_failed_ack);
|
||||
}
|
||||
|
||||
// Encode and send
|
||||
return session.encodeMsg(NetMsgId.char_gem_rename_preset_succeed_ack);
|
||||
}
|
||||
|
||||
}
|
||||
@@ -0,0 +1,35 @@
|
||||
package emu.nebula.server.handlers;
|
||||
|
||||
import emu.nebula.net.NetHandler;
|
||||
import emu.nebula.net.NetMsgId;
|
||||
import emu.nebula.proto.CharGemReplaceAttribute.CharGemReplaceAttributeReq;
|
||||
import emu.nebula.net.HandlerId;
|
||||
import emu.nebula.net.GameSession;
|
||||
|
||||
@HandlerId(NetMsgId.char_gem_replace_attribute_req)
|
||||
public class HandlerCharGemReplaceAttributeReq extends NetHandler {
|
||||
|
||||
@Override
|
||||
public byte[] handle(GameSession session, byte[] message) throws Exception {
|
||||
// Parse request
|
||||
var req = CharGemReplaceAttributeReq.parseFrom(message);
|
||||
|
||||
// Get character
|
||||
var character = session.getPlayer().getCharacters().getCharacterById(req.getCharId());
|
||||
|
||||
if (character == null) {
|
||||
return session.encodeMsg(NetMsgId.char_gem_replace_attribute_failed_ack);
|
||||
}
|
||||
|
||||
// Replace attributes
|
||||
boolean success = character.replaceGemAttributes(req.getSlotId(), req.getGemIndex());
|
||||
|
||||
if (success == false) {
|
||||
return session.encodeMsg(NetMsgId.char_gem_replace_attribute_failed_ack);
|
||||
}
|
||||
|
||||
// Encode and send
|
||||
return session.encodeMsg(NetMsgId.char_gem_replace_attribute_succeed_ack);
|
||||
}
|
||||
|
||||
}
|
||||
@@ -0,0 +1,35 @@
|
||||
package emu.nebula.server.handlers;
|
||||
|
||||
import emu.nebula.net.NetHandler;
|
||||
import emu.nebula.net.NetMsgId;
|
||||
import emu.nebula.proto.CharGemUpdateGemLockStatus.CharGemUpdateGemLockStatusReq;
|
||||
import emu.nebula.net.HandlerId;
|
||||
import emu.nebula.net.GameSession;
|
||||
|
||||
@HandlerId(NetMsgId.char_gem_update_gem_lock_status_req)
|
||||
public class HandlerCharGemUpdateGemLockStatusReq extends NetHandler {
|
||||
|
||||
@Override
|
||||
public byte[] handle(GameSession session, byte[] message) throws Exception {
|
||||
// Parse request
|
||||
var req = CharGemUpdateGemLockStatusReq.parseFrom(message);
|
||||
|
||||
// Get character
|
||||
var character = session.getPlayer().getCharacters().getCharacterById(req.getCharId());
|
||||
|
||||
if (character == null) {
|
||||
return session.encodeMsg(NetMsgId.char_gem_update_gem_lock_status_failed_ack);
|
||||
}
|
||||
|
||||
// Lock gem
|
||||
boolean success = character.lockGem(req.getSlotId(), req.getGemIndex(), req.getLock());
|
||||
|
||||
if (success == false) {
|
||||
return session.encodeMsg(NetMsgId.char_gem_update_gem_lock_status_failed_ack);
|
||||
}
|
||||
|
||||
// Encode and send
|
||||
return session.encodeMsg(NetMsgId.char_gem_update_gem_lock_status_succeed_ack);
|
||||
}
|
||||
|
||||
}
|
||||
Reference in New Issue
Block a user