mirror of
https://github.com/psforever/PSF-LoginServer.git
synced 2026-01-19 18:44:45 +00:00
Packet: ChangeFireStateMessage
* Add ChangeFireStateMessage packets * Add ChangeFireStateMessage tests * Add ChangeFireStateMessage handler stubs
This commit is contained in:
parent
f11b3d17c0
commit
4c4f1341be
|
|
@ -87,8 +87,8 @@ object GamePacketOpcode extends Enumeration {
|
|||
PickupItemMessage,
|
||||
DropItemMessage,
|
||||
InventoryStateMessage,
|
||||
ChangeFireStateMessage_Duplicate,
|
||||
ChangeFireStateMessage,
|
||||
ChangeFireStateMessage_Start,
|
||||
ChangeFireStateMessage_Stop,
|
||||
UnknownMessage59,
|
||||
|
||||
// OPCODE 60
|
||||
|
|
@ -386,8 +386,8 @@ object GamePacketOpcode extends Enumeration {
|
|||
case PickupItemMessage => noDecoder(opcode)
|
||||
case DropItemMessage => noDecoder(opcode)
|
||||
case InventoryStateMessage => noDecoder(opcode)
|
||||
case ChangeFireStateMessage_Duplicate => noDecoder(opcode)
|
||||
case ChangeFireStateMessage => noDecoder(opcode)
|
||||
case ChangeFireStateMessage_Start => game.ChangeFireStateMessage_Start.decode
|
||||
case ChangeFireStateMessage_Stop => game.ChangeFireStateMessage_Stop.decode
|
||||
case UnknownMessage59 => noDecoder(opcode)
|
||||
|
||||
// OPCODE 60
|
||||
|
|
|
|||
|
|
@ -0,0 +1,19 @@
|
|||
// Copyright (c) 2016 PSForever.net to present
|
||||
package net.psforever.packet.game
|
||||
|
||||
import net.psforever.packet.{GamePacketOpcode, Marshallable, PacketHelpers, PlanetSideGamePacket}
|
||||
import scodec.Codec
|
||||
import scodec.codecs._
|
||||
|
||||
final case class ChangeFireStateMessage_Start(item_guid : PlanetSideGUID)
|
||||
extends PlanetSideGamePacket {
|
||||
type Packet = ChangeFireStateMessage_Start
|
||||
def opcode = GamePacketOpcode.ChangeFireStateMessage_Start
|
||||
def encode = ChangeFireStateMessage_Start.encode(this)
|
||||
}
|
||||
|
||||
object ChangeFireStateMessage_Start extends Marshallable[ChangeFireStateMessage_Start] {
|
||||
implicit val codec : Codec[ChangeFireStateMessage_Start] = (
|
||||
("item_guid" | PlanetSideGUID.codec)
|
||||
).as[ChangeFireStateMessage_Start]
|
||||
}
|
||||
|
|
@ -0,0 +1,19 @@
|
|||
// Copyright (c) 2016 PSForever.net to present
|
||||
package net.psforever.packet.game
|
||||
|
||||
import net.psforever.packet.{GamePacketOpcode, Marshallable, PacketHelpers, PlanetSideGamePacket}
|
||||
import scodec.Codec
|
||||
import scodec.codecs._
|
||||
|
||||
final case class ChangeFireStateMessage_Stop(item_guid : PlanetSideGUID)
|
||||
extends PlanetSideGamePacket {
|
||||
type Packet = ChangeFireStateMessage_Stop
|
||||
def opcode = GamePacketOpcode.ChangeFireStateMessage_Stop
|
||||
def encode = ChangeFireStateMessage_Stop.encode(this)
|
||||
}
|
||||
|
||||
object ChangeFireStateMessage_Stop extends Marshallable[ChangeFireStateMessage_Stop] {
|
||||
implicit val codec : Codec[ChangeFireStateMessage_Stop] = (
|
||||
("item_guid" | PlanetSideGUID.codec)
|
||||
).as[ChangeFireStateMessage_Stop]
|
||||
}
|
||||
|
|
@ -224,5 +224,45 @@ class GamePacketTest extends Specification {
|
|||
pkt mustEqual string
|
||||
}
|
||||
}
|
||||
|
||||
"ChangeFireStateMessage_Start" should {
|
||||
val string = hex"39 4C00"
|
||||
|
||||
"decode" in {
|
||||
PacketCoding.DecodePacket(string).require match {
|
||||
case ChangeFireStateMessage_Start(item_guid) =>
|
||||
item_guid mustEqual PlanetSideGUID(76)
|
||||
case default =>
|
||||
ko
|
||||
}
|
||||
}
|
||||
|
||||
"encode" in {
|
||||
val msg = ChangeFireStateMessage_Start(PlanetSideGUID(76))
|
||||
val pkt = PacketCoding.EncodePacket(msg).require.toByteVector
|
||||
|
||||
pkt mustEqual string
|
||||
}
|
||||
}
|
||||
|
||||
"ChangeFireStateMessage_Stop" should {
|
||||
val string = hex"3A 4C00"
|
||||
|
||||
"decode" in {
|
||||
PacketCoding.DecodePacket(string).require match {
|
||||
case ChangeFireStateMessage_Stop(item_guid) =>
|
||||
item_guid mustEqual PlanetSideGUID(76)
|
||||
case default =>
|
||||
ko
|
||||
}
|
||||
}
|
||||
|
||||
"encode" in {
|
||||
val msg = ChangeFireStateMessage_Stop(PlanetSideGUID(76))
|
||||
val pkt = PacketCoding.EncodePacket(msg).require.toByteVector
|
||||
|
||||
pkt mustEqual string
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
|
|||
|
|
@ -157,6 +157,12 @@ class WorldSessionActor extends Actor with MDCContextAware {
|
|||
case msg @ ChangeFireModeMessage(item_guid, fire_mode) =>
|
||||
log.info("ChangeFireMode: " + msg)
|
||||
|
||||
case msg @ ChangeFireStateMessage_Start(item_guid) =>
|
||||
log.info("ChangeFireState_Start: " + msg)
|
||||
|
||||
case msg @ ChangeFireStateMessage_Stop(item_guid) =>
|
||||
log.info("ChangeFireState_Stop: " + msg)
|
||||
|
||||
case default => log.debug(s"Unhandled GamePacket ${pkt}")
|
||||
}
|
||||
|
||||
|
|
|
|||
Loading…
Reference in a new issue