/// <summary> /// to decode the smb data: from the general SmbDada to the concrete Smb Data. /// </summary> protected override void DecodeData() { this.smbData = TypeMarshal.ToStruct<SMB_COM_LOGOFF_ANDX_Request_SMB_Data>( TypeMarshal.ToBytes(this.smbDataBlock)); }
/// <summary> /// to create a LogoffAndx request packet. /// </summary> /// <param name="messageId">This field SHOULD be the multiplex ID that is used to associate a response with a /// request.</param> /// <param name="uid">This field SHOULD identify the authenticated instance of the user.</param> /// <param name="flags">An 8-bit field of 1-bit flags describing various features in effect for the /// message</param> /// <param name="flags2">A 16-bit field of 1-bit flags that represent various features in effect for the /// message. Unspecified bits are reserved and MUST be zero.</param> /// <param name="andxPacket">the andx packet.</param> /// <returns>a LogoffAndx request packet</returns> public SmbLogoffAndxRequestPacket CreateLogoffAndxRequest( ushort messageId, ushort uid, SmbFlags flags, SmbFlags2 flags2, SmbPacket andxPacket) { SmbLogoffAndxRequestPacket packet = new SmbLogoffAndxRequestPacket(); packet.SmbHeader = CifsMessageUtils.CreateSmbHeader(SmbCommand.SMB_COM_LOGOFF_ANDX, messageId, uid, 0, flags, flags2); SMB_COM_LOGOFF_ANDX_Request_SMB_Parameters smbParameters = new SMB_COM_LOGOFF_ANDX_Request_SMB_Parameters(); smbParameters.AndXReserved = 0; if (andxPacket == null) { smbParameters.AndXCommand = SmbCommand.SMB_COM_NO_ANDX_COMMAND; } else { smbParameters.AndXCommand = andxPacket.SmbHeader.Command; } smbParameters.WordCount = (byte)(Marshal.SizeOf(smbParameters) / NumBytesOfWord); SMB_COM_LOGOFF_ANDX_Request_SMB_Data smbData = new SMB_COM_LOGOFF_ANDX_Request_SMB_Data(); smbData.ByteCount = 0; packet.SmbParameters = smbParameters; packet.SmbData = smbData; packet.AndxPacket = andxPacket; return packet; }