Packet: ItemTransactionMessage (#37)

* Add TransactionType

* Add ItemTransactionMessage packet

* Add ItemTransactionMessage test

* Add ItemTransactionMessage handler stub
This commit is contained in:
tfarley 2016-07-25 21:36:22 -07:00 committed by pschord
parent d496fc1c2e
commit 49e7ab2c53
5 changed files with 115 additions and 1 deletions

View file

@ -399,7 +399,7 @@ object GamePacketOpcode extends Enumeration {
case DismountVehicleCargoMsg => noDecoder(opcode)
case CargoMountPointStatusMessage => noDecoder(opcode)
case BeginZoningMessage => noDecoder(opcode)
case ItemTransactionMessage => noDecoder(opcode)
case ItemTransactionMessage => game.ItemTransactionMessage.decode
case ItemTransactionResultMessage => noDecoder(opcode)
// OPCODE 70

View file

@ -0,0 +1,30 @@
// Copyright (c) 2016 PSForever.net to present
package net.psforever.packet.game
import net.psforever.packet.{GamePacketOpcode, Marshallable, PacketHelpers, PlanetSideGamePacket}
import net.psforever.types.TransactionType
import scodec.Codec
import scodec.codecs._
final case class ItemTransactionMessage(terminal_guid : PlanetSideGUID,
transaction_type : TransactionType.Value,
item_page : Int,
item_name : String,
unk1 : Int,
item_guid : PlanetSideGUID)
extends PlanetSideGamePacket {
type Packet = ItemTransactionMessage
def opcode = GamePacketOpcode.ItemTransactionMessage
def encode = ItemTransactionMessage.encode(this)
}
object ItemTransactionMessage extends Marshallable[ItemTransactionMessage] {
implicit val codec : Codec[ItemTransactionMessage] = (
("terminal_guid" | PlanetSideGUID.codec) ::
("transaction_type" | TransactionType.codec) ::
("item_page" | uint16L) ::
("item_name" | PacketHelpers.encodedStringAligned(5)) ::
("unk1" | uint8L) ::
("item_guid" | PlanetSideGUID.codec)
).as[ItemTransactionMessage]
}

View file

@ -0,0 +1,20 @@
// Copyright (c) 2016 PSForever.net to present
package net.psforever.types
import net.psforever.packet.PacketHelpers
import scodec.codecs._
object TransactionType extends Enumeration {
type Type = Value
val Unk0,
Unk1,
Buy,
Sell,
Unk4,
Unk5,
Unk6,
Unk7
= Value
implicit val codec = PacketHelpers.createEnumerationCodec(this, uintL(3))
}

View file

@ -519,5 +519,66 @@ class GamePacketTest extends Specification {
pkt mustEqual string
}
}
"ItemTransactionMessage" should {
val string_buy = hex"44 4C03 4000110070756E6973686572000000"
val string_sell = hex"44 5303 60001000004E00"
val string_forget = hex"44 BA00 600011006861726173736572000000"
"decode" in {
PacketCoding.DecodePacket(string_buy).require match {
case ItemTransactionMessage(terminal_guid, transaction_type, item_page, item_name, unk1, item_guid) =>
terminal_guid mustEqual PlanetSideGUID(844)
transaction_type mustEqual TransactionType.Buy
item_page mustEqual 0
item_name mustEqual "punisher"
unk1 mustEqual 0
item_guid mustEqual PlanetSideGUID(0)
case default =>
ko
}
PacketCoding.DecodePacket(string_sell).require match {
case ItemTransactionMessage(terminal_guid, transaction_type, item_page, item_name, unk1, item_guid) =>
terminal_guid mustEqual PlanetSideGUID(851)
transaction_type mustEqual TransactionType.Sell
item_page mustEqual 0
item_name mustEqual ""
unk1 mustEqual 0
item_guid mustEqual PlanetSideGUID(78)
case default =>
ko
}
PacketCoding.DecodePacket(string_forget).require match {
case ItemTransactionMessage(terminal_guid, transaction_type, item_page, item_name, unk1, item_guid) =>
terminal_guid mustEqual PlanetSideGUID(186)
transaction_type mustEqual TransactionType.Sell
item_page mustEqual 0
item_name mustEqual "harasser"
unk1 mustEqual 0
item_guid mustEqual PlanetSideGUID(0)
case default =>
ko
}
}
"encode" in {
val msg_buy = ItemTransactionMessage(PlanetSideGUID(844), TransactionType.Buy, 0, "punisher", 0, PlanetSideGUID(0))
val pkt_buy = PacketCoding.EncodePacket(msg_buy).require.toByteVector
pkt_buy mustEqual string_buy
val msg_sell = ItemTransactionMessage(PlanetSideGUID(851), TransactionType.Sell, 0, "", 0, PlanetSideGUID(78))
val pkt_sell = PacketCoding.EncodePacket(msg_sell).require.toByteVector
pkt_sell mustEqual string_sell
val msg_forget = ItemTransactionMessage(PlanetSideGUID(186), TransactionType.Sell, 0, "harasser", 0, PlanetSideGUID(0))
val pkt_forget = PacketCoding.EncodePacket(msg_forget).require.toByteVector
pkt_forget mustEqual string_forget
}
}
}
}

View file

@ -203,6 +203,9 @@ class WorldSessionActor extends Actor with MDCContextAware {
case msg @ GenericObjectStateMsg(object_guid, unk1) =>
log.info("GenericObjectState: " + msg)
case msg @ ItemTransactionMessage(terminal_guid, transaction_type, item_page, item_name, unk1, item_guid) =>
log.info("ItemTransaction: " + msg)
case default => log.debug(s"Unhandled GamePacket ${pkt}")
}