whitelist groundwork

master
Jordan Orelli 8 years ago
parent 063bf79c03
commit de8f42be96

@ -22,13 +22,12 @@ func (g dataGram) String() string {
}
func (g *dataGram) Open(m *messageFactory) (proto.Message, error) {
msg := m.BuildDatagram(g.cmd)
if msg == nil {
return nil, fmt.Errorf("skipped")
}
err := proto.Unmarshal(g.body, msg)
msg, err := m.BuildDatagram(g.cmd)
if err != nil {
return nil, err
}
if err := proto.Unmarshal(g.body, msg); err != nil {
return nil, err
}
return msg, nil
}

@ -115,6 +115,24 @@ func (e entityType) String() string {
}
}
type messageStatus int
const (
m_Unknown messageStatus = iota
m_Skipped
)
func (m messageStatus) Error() string {
switch m {
case m_Unknown:
return "unknown message type"
case m_Skipped:
return "skipped message type"
default:
return "unknown message error"
}
}
type datagramFactory map[datagramType]func() proto.Message
type entityFactory map[entityType]func() proto.Message
@ -123,20 +141,20 @@ type messageFactory struct {
entities entityFactory
}
func (m *messageFactory) BuildDatagram(id datagramType) proto.Message {
func (m *messageFactory) BuildDatagram(id datagramType) (proto.Message, error) {
fn, ok := m.datagrams[id]
if !ok {
return nil
return nil, m_Unknown
}
return fn()
return fn(), nil
}
func (m *messageFactory) BuildEntity(id entityType) proto.Message {
func (m *messageFactory) BuildEntity(id entityType) (proto.Message, error) {
fn, ok := m.entities[id]
if !ok {
return nil
return nil, m_Unknown
}
return fn()
return fn(), nil
}
var messages = messageFactory{

@ -128,6 +128,7 @@ const (
EBaseUserMessages_UM_CloseCaptionPlaceholder entityType = 142
EBaseUserMessages_UM_CameraTransition entityType = 143
EBaseUserMessages_UM_AudioParameter entityType = 144
EBaseGameEvents_GE_VDebugGameSessionIDEvent entityType = 200
EBaseGameEvents_GE_PlaceDecalEvent entityType = 201
EBaseGameEvents_GE_ClearWorldDecalsEvent entityType = 202
EBaseGameEvents_GE_ClearEntityDecalsEvent entityType = 203
@ -431,6 +432,8 @@ func (e entityType) String() string {
return "EBaseUserMessages_UM_CameraTransition"
case EBaseUserMessages_UM_AudioParameter:
return "EBaseUserMessages_UM_AudioParameter"
case EBaseGameEvents_GE_VDebugGameSessionIDEvent:
return "EBaseGameEvents_GE_VDebugGameSessionIDEvent"
case EBaseGameEvents_GE_PlaceDecalEvent:
return "EBaseGameEvents_GE_PlaceDecalEvent"
case EBaseGameEvents_GE_ClearWorldDecalsEvent:
@ -644,6 +647,24 @@ func (e entityType) String() string {
}
}
type messageStatus int
const (
m_Unknown messageStatus = iota
m_Skipped
)
func (m messageStatus) Error() string {
switch m {
case m_Unknown:
return "unknown message type"
case m_Skipped:
return "skipped message type"
default:
return "unknown message error"
}
}
type datagramFactory map[datagramType]func() proto.Message
type entityFactory map[entityType]func() proto.Message
@ -652,20 +673,20 @@ type messageFactory struct {
entities entityFactory
}
func (m *messageFactory) BuildDatagram(id datagramType) proto.Message {
func (m *messageFactory) BuildDatagram(id datagramType) (proto.Message, error) {
fn, ok := m.datagrams[id]
if !ok {
return nil
return nil, m_Unknown
}
return fn()
return fn(), nil
}
func (m *messageFactory) BuildEntity(id entityType) proto.Message {
func (m *messageFactory) BuildEntity(id entityType) (proto.Message, error) {
fn, ok := m.entities[id]
if !ok {
return nil
return nil, m_Unknown
}
return fn()
return fn(), nil
}
var messages = messageFactory{
@ -766,6 +787,7 @@ var messages = messageFactory{
EBaseUserMessages_UM_CloseCaptionPlaceholder: func() proto.Message { return new(dota.CUserMessageCloseCaptionPlaceholder) },
EBaseUserMessages_UM_CameraTransition: func() proto.Message { return new(dota.CUserMessageCameraTransition) },
EBaseUserMessages_UM_AudioParameter: func() proto.Message { return new(dota.CUserMessageAudioParameter) },
EBaseGameEvents_GE_VDebugGameSessionIDEvent: func() proto.Message { return new(dota.CMsgVDebugGameSessionIDEvent) },
EBaseGameEvents_GE_PlaceDecalEvent: func() proto.Message { return new(dota.CMsgPlaceDecalEvent) },
EBaseGameEvents_GE_ClearWorldDecalsEvent: func() proto.Message { return new(dota.CMsgClearWorldDecalsEvent) },
EBaseGameEvents_GE_ClearEntityDecalsEvent: func() proto.Message { return new(dota.CMsgClearEntityDecalsEvent) },

@ -88,13 +88,12 @@ func (p *parser) handleDemoPacket(packet *dota.CDemoPacket) error {
if p.dumpPackets {
fmt.Printf("\t%v\n", entity{t: t, size: uint32(s), body: b})
}
e := messages.BuildEntity(t)
if e == nil {
fmt.Printf("\tno known entity for type id %d size: %d\n", int(t), len(b))
e, err := messages.BuildEntity(t)
if err != nil {
fmt.Printf("\tskipping entity of size %d, type %s: %v\n", len(b), t, err)
continue
}
err := proto.Unmarshal(b, e)
if err != nil {
if err := proto.Unmarshal(b, e); err != nil {
fmt.Printf("entity unmarshal error: %v\n", err)
}
}

Loading…
Cancel
Save