Packet: ChangeFireStateMessage

* Add ChangeFireStateMessage packets

* Add ChangeFireStateMessage tests

* Add ChangeFireStateMessage handler stubs
This commit is contained in:
tfarley 2016-07-23 18:00:43 -07:00 committed by pschord
parent f11b3d17c0
commit 4c4f1341be
5 changed files with 88 additions and 4 deletions

View file

@ -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

View file

@ -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]
}

View file

@ -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]
}

View file

@ -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
}
}
}
}

View file

@ -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}")
}