Merge pull request #169 from aphedox/hackmessage

Add HackMessage skeleton
This commit is contained in:
Fate-JH 2017-10-07 15:39:06 -04:00 committed by GitHub
commit 973f8f3640
3 changed files with 75 additions and 1 deletions

View file

@ -418,7 +418,7 @@ object GamePacketOpcode extends Enumeration {
case 0x51 => game.TriggerEffectMessage.decode
case 0x52 => game.WeaponDryFireMessage.decode
case 0x53 => noDecoder(DroppodLaunchRequestMessage)
case 0x54 => noDecoder(HackMessage)
case 0x54 => game.HackMessage.decode
case 0x55 => noDecoder(DroppodLaunchResponseMessage)
case 0x56 => noDecoder(GenericObjectActionMessage)
case 0x57 => game.AvatarVehicleTimerMessage.decode

View file

@ -0,0 +1,41 @@
// Copyright (c) 2017 PSForever
package net.psforever.packet.game
import net.psforever.packet.{GamePacketOpcode, Marshallable, PacketHelpers, PlanetSideGamePacket}
import scodec.Codec
import scodec.codecs._
/**
*
* @param unk1 na
* @param unk2 na
* @param unk3 na
* @param unk4 na
* @param unk5 na
* @param unk6 na
* @param unk7 na
*/
final case class HackMessage(unk1 : Int,
unk2 : Int,
unk3 : Int,
unk4 : Int,
unk5 : Long,
unk6 : Int,
unk7 : Long)
extends PlanetSideGamePacket {
type Packet = HackMessage
def opcode = GamePacketOpcode.HackMessage
def encode = HackMessage.encode(this)
}
object HackMessage extends Marshallable[HackMessage] {
implicit val codec : Codec[HackMessage] = (
("unk1" | uint2L) ::
("unk2" | uint16L) ::
("unk3" | uint16L) ::
("unk4" | uint8L) ::
("unk5" | uint32L) ::
("unk6" | uint8L) ::
("unk7" | uint32L)
).as[HackMessage]
}

View file

@ -0,0 +1,33 @@
// Copyright (c) 2017 PSForever
package game
import org.specs2.mutable._
import net.psforever.packet._
import net.psforever.packet.game._
import scodec.bits._
class HackMessageTest extends Specification {
// Record 62 in PSCap-hack-door-tower.gcap
val string = hex"54 000105c3800000202fc04200000000"
"decode" in {
PacketCoding.DecodePacket(string).require match {
case HackMessage(unk1, unk2, unk3, unk4, unk5, unk6, unk7) =>
unk1 mustEqual 0
unk2 mustEqual 1024
unk3 mustEqual 3607
unk4 mustEqual 0
unk5 mustEqual 3212836864L
unk6 mustEqual 1
unk7 mustEqual 8L
case _ =>
ko
}
}
"encode" in {
val msg = HackMessage(0,1024,3607,0,3212836864L,1,8L)
val pkt = PacketCoding.EncodePacket(msg).require.toByteVector
pkt mustEqual string
}
}