Valhalla Legends Archive

Programming => Battle.net Bot Development => Topic started by: FooSoft on October 18, 2006, 12:02 AM

Title: Need help: parsing D2GS packets
Post by: FooSoft on October 18, 2006, 12:02 AM
I'm working on a project that requires me to work with decompressed S > C packets. This means that if a packet is sent from the server decompressed it should be left alone, but if it is sent compressed in compressed format then then it should be decompressed. I have all of the decompression/compression stuff working fine, but I'm not sure how to tell if a packet in a "lump" recv'd from the D2GS is in compressed format or not.

For compressed packets we have
Size: 1-2 bytes (bytes[0] < 0xf0 ? 1 : 2)
PacketId: 1 byte
Data: ? bytes

For decompressed packets it's simply
PacketId: 1 byte
Data ? bytes

So when I receive a packet, is there any way to determine if the first byte is a:
1) First byte of a compressed packet's size
2) PacketId byte of a decompressed packet

I really appreciate any help with this matter   :)
Title: Re: Need help: parsing D2GS packets
Post by: l2k-Shadow on October 18, 2006, 12:07 AM
Quote from: FooSoft on October 18, 2006, 12:02 AM
I'm working on a project that requires me to work with decompressed S > C packets. This means that if a packet is sent from the server decompressed it should be left alone, but if it is sent compressed in compressed format then then it should be decompressed. I have all of the decompression/compression stuff working fine, but I'm not sure how to tell if a packet in a "lump" recv'd from the D2GS is in compressed format or not.

For compressed packets we have
Size: 1-2 bytes (bytes[0] < 0xf0 ? 1 : 2)
PacketId: 1 byte
Data: ? bytes

For decompressed packets it's simply
PacketId: 1 byte
Data ? bytes

So when I receive a packet, is there any way to determine if the first byte is a:
1) First byte of a compressed packet's size
2) PacketId byte of a decompressed packet

I really appreciate any help with this matter   :)

length of the packet... in any case the logic to that is obvious. since TCP data can be split among several packets, the packet must include a length for you to be able to receive all the data and then decompress.
Title: Re: Need help: parsing D2GS packets
Post by: FooSoft on October 18, 2006, 12:24 AM
Thanks for the reply, but I'm not sure I follow. Are you saying that a server "message" will always be enclosed in at least one whole packet regardless of whether or not it is compressed or decompressed? I found this not to be the case.

The whole problem is that I don't know how to distinguish between compressed and decompressed messages if multiple messages arrive in one packet. There just appears to be a total lack of context of how to interpret this data.

(messages being logical data D2GS sends out and packets are the TCP segmentation of it)
Title: Re: Need help: parsing D2GS packets
Post by: l2k-Shadow on October 18, 2006, 12:31 AM
they will always be compressed + D2GS messages have fixed lenghts.
Title: Re: Need help: parsing D2GS packets
Post by: FooSoft on October 18, 2006, 12:38 AM
Ah! All D2GS S > C messages are compressed? Awesome! I was under the impression that some were and some were not. That makes things a lot easier, thanks!
Title: Re: Need help: parsing D2GS packets
Post by: FooSoft on October 18, 2006, 11:00 AM
One more thing actually...

Anyone know offhand if the packet length list on this page still applicable to 1.11b?
http://forum.valhallalegends.com/index.php?topic=11756.75

Title: Re: Need help: parsing D2GS packets
Post by: NetNX on November 01, 2006, 10:38 AM
Most of that information is still accurate as far as packet structure although the packetids may be diffrent.