public void Test_Constructor_EncryptedDataFrame()
            {
                var dev = new CaptureFileReaderDevice("../../CaptureFiles/80211_encrypted_data_frame.pcap");

                dev.Open();
                var rawCapture = dev.GetNextPacket();

                dev.Close();

                Packet        p     = Packet.ParsePacket(rawCapture.LinkLayerType, rawCapture.Data);
                DataDataFrame frame = (DataDataFrame)p.PayloadPacket;

                Assert.AreEqual(0, frame.FrameControl.ProtocolVersion);
                Assert.AreEqual(FrameControlField.FrameSubTypes.Data, frame.FrameControl.SubType);
                Assert.IsFalse(frame.FrameControl.ToDS);
                Assert.IsTrue(frame.FrameControl.FromDS);
                Assert.IsFalse(frame.FrameControl.MoreFragments);
                Assert.IsFalse(frame.FrameControl.Retry);
                Assert.IsFalse(frame.FrameControl.PowerManagement);
                Assert.IsFalse(frame.FrameControl.MoreData);
                Assert.IsTrue(frame.FrameControl.Protected);
                Assert.IsFalse(frame.FrameControl.Order);
                Assert.AreEqual(0, frame.Duration.Field); //this need expanding on in the future
                Assert.AreEqual("33330000000C", frame.DestinationAddress.ToString().ToUpper());
                Assert.AreEqual("00173FB72C29", frame.SourceAddress.ToString().ToUpper());
                Assert.AreEqual("0024B2F8D706", frame.BssId.ToString().ToUpper());
                Assert.AreEqual(0, frame.SequenceControl.FragmentNumber);
                Assert.AreEqual(1561, frame.SequenceControl.SequenceNumber);

                Assert.AreEqual(0xC77B6323, frame.FrameCheckSequence);
                Assert.AreEqual(24, frame.FrameSize);
                Assert.AreEqual(218, frame.PayloadData.Length);
            }
Exemple #2
0
            public void Test_Bytes_ParsedPacketWithFcsNotIncluded()
            {
                var dev = new CaptureFileReaderDevice("../../CaptureFiles/80211_unencrypted_data_frame.pcap");

                dev.Open();
                var rawCapture = dev.GetNextPacket();

                dev.Close();

                //For this test we are just going to ignore the radio packet that precedes the data frame
                Packet p = Packet.ParsePacket(rawCapture.LinkLayerType, rawCapture.Data);

                DataDataFrame frame = (DataDataFrame)p.PayloadPacket;

                frame.AppendFcs = false;

                var frameBytes     = frame.Bytes;
                var expectedLength = frame.FrameSize + frame.PayloadData.Length;

                Assert.AreEqual(expectedLength, frameBytes.Length);


                Assert.AreEqual(EndianBitConverter.Big.ToUInt32(frame.PayloadData, frame.PayloadData.Length - 4),
                                EndianBitConverter.Big.ToUInt32(frameBytes, frameBytes.Length - 4));
            }
Exemple #3
0
            public void Test_Bytes_ConstructedPacketWithFcsIncluded()
            {
                //We will use a DataDataFrame for this test but the
                //type isn't really important.
                var dataFrame = new DataDataFrame();

                dataFrame.FrameControl.FromDS = true;
                dataFrame.BssId              = PhysicalAddress.Parse("AABBCCDDEEFF");
                dataFrame.SourceAddress      = PhysicalAddress.Parse("AABBCCDDEEFF");
                dataFrame.DestinationAddress = PhysicalAddress.Parse("112233445566");
                dataFrame.PayloadData        = new Byte[] { 0x1, 0x2, 0x3, 0x4 };

                //Force it to recalculate the FCS and include it when serialised
                dataFrame.UpdateFrameCheckSequence();
                dataFrame.AppendFcs = true;
                Assert.IsTrue(dataFrame.FCSValid);

                var expectedLength = dataFrame.FrameSize + dataFrame.PayloadData.Length + 4;

                Byte[] frameBytes = dataFrame.Bytes;

                Assert.AreEqual(expectedLength, frameBytes.Length);
                Assert.AreEqual(dataFrame.FrameCheckSequence.ToString("X"),
                                EndianBitConverter.Big.ToUInt32(frameBytes, frameBytes.Length - 4).ToString("X"));
                Assert.AreEqual(dataFrame.FrameCheckSequence,
                                EndianBitConverter.Big.ToUInt32(frameBytes, frameBytes.Length - 4));
            }
            public void Test_ConstructorWithCorruptBuffer()
            {
                //buffer is way too short for frame. We are just checking it doesn't throw
                byte[]        corruptBuffer = new byte[] { 0x01 };
                DataDataFrame frame         = new DataDataFrame(new ByteArraySegment(corruptBuffer));

                Assert.IsFalse(frame.FCSValid);
            }
            public void Test_Constructor_UnecryptedDataFrameFromValues()
            {
                DataDataFrame frame = new DataDataFrame();

                frame.FrameControl.ToDS          = false;
                frame.FrameControl.FromDS        = true;
                frame.FrameControl.MoreFragments = true;

                frame.SequenceControl.SequenceNumber = 0x89;
                frame.SequenceControl.FragmentNumber = 0x1;

                frame.Duration.Field = 0x1234;

                frame.DestinationAddress = PhysicalAddress.Parse("111111111111");
                frame.SourceAddress      = PhysicalAddress.Parse("222222222222");
                frame.BssId = PhysicalAddress.Parse("333333333333");

                frame.PayloadData = new byte[] { 0x01, 0x02, 0x03, 0x04, 0x05 };

                frame.UpdateFrameCheckSequence();
                UInt32 fcs = frame.FrameCheckSequence;

                //serialize the frame into a byte buffer
                var bytes = frame.Bytes;
                var bas   = new ByteArraySegment(bytes);

                //create a new frame that should be identical to the original
                DataDataFrame recreatedFrame = MacFrame.ParsePacket(bas) as DataDataFrame;

                recreatedFrame.UpdateFrameCheckSequence();

                Assert.AreEqual(FrameControlField.FrameSubTypes.Data, recreatedFrame.FrameControl.SubType);
                Assert.IsFalse(recreatedFrame.FrameControl.ToDS);
                Assert.IsTrue(recreatedFrame.FrameControl.FromDS);
                Assert.IsTrue(recreatedFrame.FrameControl.MoreFragments);

                Assert.AreEqual(0x89, recreatedFrame.SequenceControl.SequenceNumber);
                Assert.AreEqual(0x1, recreatedFrame.SequenceControl.FragmentNumber);

                Assert.AreEqual("111111111111", recreatedFrame.DestinationAddress.ToString().ToUpper());
                Assert.AreEqual("222222222222", recreatedFrame.SourceAddress.ToString().ToUpper());
                Assert.AreEqual("333333333333", recreatedFrame.BssId.ToString().ToUpper());

                CollectionAssert.AreEqual(new byte[] { 0x01, 0x02, 0x03, 0x04, 0x05 }, recreatedFrame.PayloadData);

                Assert.AreEqual(fcs, recreatedFrame.FrameCheckSequence);
            }
Exemple #6
0
            public void Test_Bytes_ConstructedPacketWithFcsNotIncluded()
            {
                //We will use a DataDataFrame for this test but the
                //type isn't really important.
                var dataFrame = new DataDataFrame();

                dataFrame.FrameControl.FromDS = true;
                dataFrame.BssId              = PhysicalAddress.Parse("AABBCCDDEEFF");
                dataFrame.SourceAddress      = PhysicalAddress.Parse("AABBCCDDEEFF");
                dataFrame.DestinationAddress = PhysicalAddress.Parse("112233445566");
                dataFrame.PayloadData        = new Byte[] { 0x01, 0x02, 0x03, 0x04 };

                //Force it to recalculate the FCS but don't include it when serialised
                dataFrame.UpdateFrameCheckSequence();
                dataFrame.AppendFcs = false;

                var expectedLength = dataFrame.FrameSize + dataFrame.PayloadData.Length;
                var frameBytes     = dataFrame.Bytes;

                Assert.AreEqual(expectedLength, frameBytes.Length);
                //Check that we get last four bytes of data at the end rather than the FCS
                Assert.AreEqual(0x01020304, EndianBitConverter.Big.ToUInt32(frameBytes, frameBytes.Length - 4));
            }
			public void Test_ConstructorWithCorruptBuffer ()
			{
				//buffer is way too short for frame. We are just checking it doesn't throw
				byte[] corruptBuffer = new byte[]{0x01};
				DataDataFrame frame = new DataDataFrame(new ByteArraySegment(corruptBuffer));
				Assert.IsFalse(frame.FCSValid);
			}
            public void Test_Constructor_UnecryptedDataFrameFromValues ()
            {
                DataDataFrame frame = new DataDataFrame ();
                
                frame.FrameControl.ToDS = false;
                frame.FrameControl.FromDS = true;
                frame.FrameControl.MoreFragments = true;
                
                frame.SequenceControl.SequenceNumber = 0x89;
                frame.SequenceControl.FragmentNumber = 0x1;
                
                frame.Duration.Field = 0x1234;
                
                frame.DestinationAddress = PhysicalAddress.Parse ("111111111111");
                frame.SourceAddress = PhysicalAddress.Parse ("222222222222");
                frame.BssId = PhysicalAddress.Parse ("333333333333");
                
                frame.PayloadData = new byte[]{0x01, 0x02, 0x03, 0x04, 0x05};
                
                frame.UpdateFrameCheckSequence ();
                UInt32 fcs = frame.FrameCheckSequence;
                
                //serialize the frame into a byte buffer
                var bytes = frame.Bytes;
                var bas = new ByteArraySegment (bytes);

                //create a new frame that should be identical to the original
                DataDataFrame recreatedFrame = MacFrame.ParsePacket (bas) as DataDataFrame;
                recreatedFrame.UpdateFrameCheckSequence();
                
                Assert.AreEqual (FrameControlField.FrameSubTypes.Data, recreatedFrame.FrameControl.SubType);
                Assert.IsFalse (recreatedFrame.FrameControl.ToDS);
                Assert.IsTrue (recreatedFrame.FrameControl.FromDS);
                Assert.IsTrue (recreatedFrame.FrameControl.MoreFragments);
                
                Assert.AreEqual (0x89, recreatedFrame.SequenceControl.SequenceNumber);
                Assert.AreEqual (0x1, recreatedFrame.SequenceControl.FragmentNumber);
                
                Assert.AreEqual ("111111111111", recreatedFrame.DestinationAddress.ToString ().ToUpper ());
                Assert.AreEqual ("222222222222", recreatedFrame.SourceAddress.ToString ().ToUpper ());
                Assert.AreEqual ("333333333333", recreatedFrame.BssId.ToString ().ToUpper ());
                
                CollectionAssert.AreEqual (new byte[]{0x01, 0x02, 0x03, 0x04, 0x05}, recreatedFrame.PayloadData);
                
                Assert.AreEqual (fcs, recreatedFrame.FrameCheckSequence);
            }
Exemple #9
0
            /// <summary>
            /// Parses the <see cref="Kavprot.Packets.Utils.ByteArraySegment"/> into a MacFrame.
            /// </summary>
            /// <returns>
            /// The parsed MacFrame or null if it could not be parsed.
            /// </returns>
            /// <param name='bas'>
            /// The bytes of the packet. bas.Offset should point to the first byte in the mac frame.
            /// </param>
            /// <remarks>If the provided bytes contain the FCS then call <see cref="MacFrame.ParsePacketWithFcs"/> instead. The presence of the
            /// FCS is usually determined by configuration of the device used to capture the packets.</remarks>
            public static MacFrame ParsePacket(ByteArraySegment bas)
            {
                if (bas.Length < MacFields.FrameControlLength)
                {
                    //there isn't enough data to even try and work out what type of packet it is
                    return(null);
                }
                //this is a bit ugly as we will end up parsing the framecontrol field twice, once here and once
                //inside the packet constructor. Could create the framecontrol and pass it to the packet but I think that is equally ugly
                FrameControlField frameControl = new FrameControlField(
                    EndianBitConverter.Big.ToUInt16(bas.Bytes, bas.Offset));

                MacFrame macFrame = null;

                switch (frameControl.SubType)
                {
                case FrameControlField.FrameSubTypes.ManagementAssociationRequest:
                {
                    macFrame = new AssociationRequestFrame(bas);
                    break;
                }

                case FrameControlField.FrameSubTypes.ManagementAssociationResponse:
                {
                    macFrame = new AssociationResponseFrame(bas);
                    break;
                }

                case FrameControlField.FrameSubTypes.ManagementReassociationRequest:
                {
                    macFrame = new ReassociationRequestFrame(bas);
                    break;
                }

                case FrameControlField.FrameSubTypes.ManagementReassociationResponse:
                {
                    macFrame = new AssociationResponseFrame(bas);
                    break;
                }

                case FrameControlField.FrameSubTypes.ManagementProbeRequest:
                {
                    macFrame = new ProbeRequestFrame(bas);
                    break;
                }

                case FrameControlField.FrameSubTypes.ManagementProbeResponse:
                {
                    macFrame = new ProbeResponseFrame(bas);
                    break;
                }

                case FrameControlField.FrameSubTypes.ManagementReserved0:
                    break; //TODO

                case FrameControlField.FrameSubTypes.ManagementReserved1:
                    break; //TODO

                case FrameControlField.FrameSubTypes.ManagementBeacon:
                {
                    macFrame = new BeaconFrame(bas);
                    break;
                }

                case FrameControlField.FrameSubTypes.ManagementATIM:
                    break; //TODO

                case FrameControlField.FrameSubTypes.ManagementDisassociation:
                {
                    macFrame = new DisassociationFrame(bas);
                    break;
                }

                case FrameControlField.FrameSubTypes.ManagementAuthentication:
                {
                    macFrame = new AuthenticationFrame(bas);
                    break;
                }

                case FrameControlField.FrameSubTypes.ManagementDeauthentication:
                {
                    macFrame = new DeauthenticationFrame(bas);
                    break;
                }

                case FrameControlField.FrameSubTypes.ManagementAction:
                {
                    macFrame = new ActionFrame(bas);
                    break;
                }

                case FrameControlField.FrameSubTypes.ManagementReserved3:
                    break; //TODO

                case FrameControlField.FrameSubTypes.ControlBlockAcknowledgmentRequest:
                {
                    macFrame = new BlockAcknowledgmentRequestFrame(bas);
                    break;
                }

                case FrameControlField.FrameSubTypes.ControlBlockAcknowledgment:
                {
                    macFrame = new BlockAcknowledgmentFrame(bas);
                    break;
                }

                case FrameControlField.FrameSubTypes.ControlPSPoll:
                    break; //TODO

                case FrameControlField.FrameSubTypes.ControlRTS:
                {
                    macFrame = new RtsFrame(bas);
                    break;
                }

                case FrameControlField.FrameSubTypes.ControlCTS:
                {
                    macFrame = new CtsFrame(bas);
                    break;
                }

                case FrameControlField.FrameSubTypes.ControlACK:
                {
                    macFrame = new AckFrame(bas);
                    break;
                }

                case FrameControlField.FrameSubTypes.ControlCFEnd:
                {
                    macFrame = new ContentionFreeEndFrame(bas);
                    break;
                }

                case FrameControlField.FrameSubTypes.ControlCFEndCFACK:
                    break; //TODO

                case FrameControlField.FrameSubTypes.Data:
                case FrameControlField.FrameSubTypes.DataCFACK:
                case FrameControlField.FrameSubTypes.DataCFPoll:
                case FrameControlField.FrameSubTypes.DataCFAckCFPoll:
                {
                    macFrame = new DataDataFrame(bas);
                    break;
                }

                case FrameControlField.FrameSubTypes.DataNullFunctionNoData:
                case FrameControlField.FrameSubTypes.DataCFAckNoData:
                case FrameControlField.FrameSubTypes.DataCFPollNoData:
                case FrameControlField.FrameSubTypes.DataCFAckCFPollNoData:
                {
                    macFrame = new NullDataFrame(bas);
                    break;
                }

                case FrameControlField.FrameSubTypes.QosData:
                case FrameControlField.FrameSubTypes.QosDataAndCFAck:
                case FrameControlField.FrameSubTypes.QosDataAndCFPoll:
                case FrameControlField.FrameSubTypes.QosDataAndCFAckAndCFPoll:
                {
                    macFrame = new QosDataFrame(bas);
                    break;
                }

                case FrameControlField.FrameSubTypes.QosNullData:
                case FrameControlField.FrameSubTypes.QosCFAck:
                case FrameControlField.FrameSubTypes.QosCFPoll:
                case FrameControlField.FrameSubTypes.QosCFAckAndCFPoll:
                {
                    macFrame = new QosNullDataFrame(bas);
                    break;
                }

                default:
                    //this is an unsupported (and unknown) packet type
                    break;
                }

                return(macFrame);
            }
 public void Test_Bytes_ConstructedPacketWithFcsNotIncluded()
 {
     //We will use a DataDataFrame for this test but the 
     //type isn't really important.
     var dataFrame = new DataDataFrame();
     dataFrame.FrameControl.FromDS = true;
     dataFrame.BssId = PhysicalAddress.Parse("AABBCCDDEEFF");
     dataFrame.SourceAddress = PhysicalAddress.Parse("AABBCCDDEEFF");
     dataFrame.DestinationAddress = PhysicalAddress.Parse("112233445566");
     dataFrame.PayloadData = new byte[]{0x01, 0x02, 0x03, 0x04};
     
     //Force it to recalculate the FCS but don't include it when serialised
     dataFrame.UpdateFrameCheckSequence();
     dataFrame.AppendFcs = false;
     
     var expectedLength = dataFrame.FrameSize + dataFrame.PayloadData.Length;
     var frameBytes = dataFrame.Bytes;
     
     Assert.AreEqual(expectedLength, frameBytes.Length);
     //Check that we get last four bytes of data at the end rather than the FCS
     Assert.AreEqual(0x01020304, EndianBitConverter.Big.ToUInt32(frameBytes, frameBytes.Length - 4));
 }
 public void Test_Bytes_ConstructedPacketWithFcsIncluded()
 {
     //We will use a DataDataFrame for this test but the 
     //type isn't really important.
     var dataFrame = new DataDataFrame();
     dataFrame.FrameControl.FromDS = true;
     dataFrame.BssId = PhysicalAddress.Parse("AABBCCDDEEFF");
     dataFrame.SourceAddress = PhysicalAddress.Parse("AABBCCDDEEFF");
     dataFrame.DestinationAddress = PhysicalAddress.Parse("112233445566");
     dataFrame.PayloadData = new byte[]{0x1, 0x2, 0x3, 0x4};
     
     //Force it to recalculate the FCS and include it when serialised
     dataFrame.UpdateFrameCheckSequence();
     dataFrame.AppendFcs = true;
     Assert.IsTrue(dataFrame.FCSValid);
     
     var expectedLength = dataFrame.FrameSize + dataFrame.PayloadData.Length + 4;
     
     byte[] frameBytes = dataFrame.Bytes;
     
     Assert.AreEqual(expectedLength, frameBytes.Length);
     Assert.AreEqual(dataFrame.FrameCheckSequence.ToString("X"),
                     EndianBitConverter.Big.ToUInt32(frameBytes, frameBytes.Length - 4).ToString("X"));
     Assert.AreEqual(dataFrame.FrameCheckSequence,
                     EndianBitConverter.Big.ToUInt32(frameBytes, frameBytes.Length - 4));
     
 }