123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118 |
- using System;
- using System.Collections.Generic;
- using System.Text;
- using Utilities;
- namespace SMBLibrary.SMB1
- {
-
-
-
-
- public class WriteAndXRequest : SMBAndXCommand
- {
- public const int ParametersFixedLength = 24;
-
-
-
-
- public ushort FID;
- public ulong Offset;
- public uint Timeout;
- public WriteMode WriteMode;
- public ushort Remaining;
-
-
-
-
-
- public byte[] Data;
- public WriteAndXRequest() : base()
- {}
- public WriteAndXRequest(byte[] buffer, int offset, bool isUnicode) : base(buffer, offset, isUnicode)
- {
- FID = LittleEndianConverter.ToUInt16(this.SMBParameters, 4);
- Offset = LittleEndianConverter.ToUInt32(this.SMBParameters, 6);
- Timeout = LittleEndianConverter.ToUInt32(this.SMBParameters, 10);
- WriteMode = (WriteMode)LittleEndianConverter.ToUInt16(this.SMBParameters, 14);
- Remaining = LittleEndianConverter.ToUInt16(this.SMBParameters, 16);
- ushort dataLengthHigh = LittleEndianConverter.ToUInt16(this.SMBParameters, 18);
- uint DataLength = LittleEndianConverter.ToUInt16(this.SMBParameters, 20);
- ushort DataOffset = LittleEndianConverter.ToUInt16(this.SMBParameters, 22);
- if (SMBParameters.Length == ParametersFixedLength + 4)
- {
- uint offsetHigh = LittleEndianConverter.ToUInt32(this.SMBParameters, 24);
- Offset |= ((ulong)offsetHigh << 32);
- }
- DataLength |= (uint)(dataLengthHigh << 16);
- Data = ByteReader.ReadBytes(buffer, (int)DataOffset, (int)DataLength);
- }
- public override byte[] GetBytes(bool isUnicode)
- {
- uint DataLength = (uint)Data.Length;
-
- ushort DataOffset = SMB1Header.Length + 3 + ParametersFixedLength;
- if (isUnicode)
- {
- DataOffset++;
- }
- ushort dataLengthHigh = (ushort)(DataLength >> 16);
-
- int parametersLength = ParametersFixedLength;
- if (Offset > UInt32.MaxValue)
- {
- parametersLength += 4;
- DataOffset += 4;
- }
- this.SMBParameters = new byte[parametersLength];
- LittleEndianWriter.WriteUInt16(this.SMBParameters, 4, FID);
- LittleEndianWriter.WriteUInt32(this.SMBParameters, 6, (uint)(Offset & 0xFFFFFFFF));
- LittleEndianWriter.WriteUInt32(this.SMBParameters, 10, Timeout);
- LittleEndianWriter.WriteUInt16(this.SMBParameters, 14, (ushort)WriteMode);
- LittleEndianWriter.WriteUInt16(this.SMBParameters, 16, Remaining);
- LittleEndianWriter.WriteUInt16(this.SMBParameters, 18, dataLengthHigh);
- LittleEndianWriter.WriteUInt16(this.SMBParameters, 20, (ushort)(DataLength & 0xFFFF));
- LittleEndianWriter.WriteUInt16(this.SMBParameters, 22, DataOffset);
- if (Offset > UInt32.MaxValue)
- {
- uint offsetHigh = (uint)(Offset >> 32);
- LittleEndianWriter.WriteUInt32(this.SMBParameters, 24, offsetHigh);
- }
- int smbDataLength = Data.Length;
- if (isUnicode)
- {
- smbDataLength++;
- }
- this.SMBData = new byte[smbDataLength];
- int offset = 0;
- if (isUnicode)
- {
- offset++;
- }
- ByteWriter.WriteBytes(this.SMBData, ref offset, this.Data);
- return base.GetBytes(isUnicode);
- }
- public override CommandName CommandName
- {
- get
- {
- return CommandName.SMB_COM_WRITE_ANDX;
- }
- }
- }
- }
|