update sharpcifs

This commit is contained in:
Luke Pulverenti
2017-07-08 03:25:24 -04:00
parent a7187180bf
commit 71eb9f143f
220 changed files with 23703 additions and 25613 deletions

View File

@@ -20,215 +20,207 @@ using SharpCifs.Util.Sharpen;
namespace SharpCifs.Smb
{
internal class SmbComTreeConnectAndX : AndXServerMessageBlock
{
private static readonly bool DisablePlainTextPasswords
= Config.GetBoolean("jcifs.smb.client.disablePlainTextPasswords", true);
internal class SmbComTreeConnectAndX : AndXServerMessageBlock
{
private static readonly bool DisablePlainTextPasswords = Config.GetBoolean("jcifs.smb.client.disablePlainTextPasswords"
, true);
private SmbSession _session;
private SmbSession _session;
private bool _disconnectTid = false;
private bool _disconnectTid = false;
private string _service;
private string _service;
private byte[] _password;
private byte[] _password;
private int _passwordLength;
private int _passwordLength;
internal string path;
internal string path;
private static byte[] _batchLimits = { 1, 1, 1, 1, 1, 1, 1, 1, 0 };
private static byte[] _batchLimits = { 1, 1, 1, 1, 1, 1, 1, 1, 0 };
static SmbComTreeConnectAndX()
{
string s;
if ((s = Config.GetProperty("jcifs.smb.client.TreeConnectAndX.CheckDirectory")) != null)
{
_batchLimits[0] = byte.Parse(s);
}
if ((s = Config.GetProperty("jcifs.smb.client.TreeConnectAndX.CreateDirectory")) != null)
{
_batchLimits[2] = byte.Parse(s);
}
if ((s = Config.GetProperty("jcifs.smb.client.TreeConnectAndX.Delete")) != null)
{
_batchLimits[3] = byte.Parse(s);
}
if ((s = Config.GetProperty("jcifs.smb.client.TreeConnectAndX.DeleteDirectory")) != null)
{
_batchLimits[4] = byte.Parse(s);
}
if ((s = Config.GetProperty("jcifs.smb.client.TreeConnectAndX.OpenAndX")) != null)
{
_batchLimits[5] = byte.Parse(s);
}
if ((s = Config.GetProperty("jcifs.smb.client.TreeConnectAndX.Rename")) != null)
{
_batchLimits[6] = byte.Parse(s);
}
if ((s = Config.GetProperty("jcifs.smb.client.TreeConnectAndX.Transaction")) != null)
{
_batchLimits[7] = byte.Parse(s);
}
if ((s = Config.GetProperty("jcifs.smb.client.TreeConnectAndX.QueryInformation")) != null)
{
_batchLimits[8] = byte.Parse(s);
}
}
static SmbComTreeConnectAndX()
{
string s;
if ((s = Config.GetProperty("jcifs.smb.client.TreeConnectAndX.CheckDirectory")) !=
null)
{
_batchLimits[0] = byte.Parse(s);
}
if ((s = Config.GetProperty("jcifs.smb.client.TreeConnectAndX.CreateDirectory"))
!= null)
{
_batchLimits[2] = byte.Parse(s);
}
if ((s = Config.GetProperty("jcifs.smb.client.TreeConnectAndX.Delete")) != null)
{
_batchLimits[3] = byte.Parse(s);
}
if ((s = Config.GetProperty("jcifs.smb.client.TreeConnectAndX.DeleteDirectory"))
!= null)
{
_batchLimits[4] = byte.Parse(s);
}
if ((s = Config.GetProperty("jcifs.smb.client.TreeConnectAndX.OpenAndX")) != null)
{
_batchLimits[5] = byte.Parse(s);
}
if ((s = Config.GetProperty("jcifs.smb.client.TreeConnectAndX.Rename")) != null)
{
_batchLimits[6] = byte.Parse(s);
}
if ((s = Config.GetProperty("jcifs.smb.client.TreeConnectAndX.Transaction")) != null)
{
_batchLimits[7] = byte.Parse(s);
}
if ((s = Config.GetProperty("jcifs.smb.client.TreeConnectAndX.QueryInformation"))
!= null)
{
_batchLimits[8] = byte.Parse(s);
}
}
internal SmbComTreeConnectAndX(SmbSession session,
string path,
string service,
ServerMessageBlock andx) : base(andx)
{
this._session = session;
this.path = path;
this._service = service;
Command = SmbComTreeConnectAndx;
}
internal SmbComTreeConnectAndX(SmbSession session, string path, string service, ServerMessageBlock
andx) : base(andx)
{
this._session = session;
this.path = path;
this._service = service;
Command = SmbComTreeConnectAndx;
}
internal override int GetBatchLimit(byte command)
{
int c = command & unchecked(0xFF);
switch (c)
{
case SmbComCheckDirectory:
{
// why isn't this just return batchLimits[c]?
return _batchLimits[0];
}
internal override int GetBatchLimit(byte command)
{
int c = command & unchecked(0xFF);
switch (c)
{
case SmbComCheckDirectory:
{
// why isn't this just return batchLimits[c]?
return _batchLimits[0];
}
case SmbComCreateDirectory:
{
return _batchLimits[2];
}
case SmbComCreateDirectory:
{
return _batchLimits[2];
}
case SmbComDelete:
{
return _batchLimits[3];
}
case SmbComDelete:
{
return _batchLimits[3];
}
case SmbComDeleteDirectory:
{
return _batchLimits[4];
}
case SmbComDeleteDirectory:
{
return _batchLimits[4];
}
case SmbComOpenAndx:
{
return _batchLimits[5];
}
case SmbComOpenAndx:
{
return _batchLimits[5];
}
case SmbComRename:
{
return _batchLimits[6];
}
case SmbComRename:
{
return _batchLimits[6];
}
case SmbComTransaction:
{
return _batchLimits[7];
}
case SmbComTransaction:
{
return _batchLimits[7];
}
case SmbComQueryInformation:
{
return _batchLimits[8];
}
}
return 0;
}
case SmbComQueryInformation:
{
return _batchLimits[8];
}
}
return 0;
}
internal override int WriteParameterWordsWireFormat(byte[] dst, int dstIndex)
{
if (_session.transport.Server.Security == SmbConstants.SecurityShare
&& (_session.Auth.HashesExternal || _session.Auth.Password.Length > 0))
{
if (_session.transport.Server.EncryptedPasswords)
{
// encrypted
_password = _session.Auth.GetAnsiHash(_session.transport.Server.EncryptionKey);
_passwordLength = _password.Length;
}
else
{
if (DisablePlainTextPasswords)
{
throw new RuntimeException("Plain text passwords are disabled");
}
// plain text
_password = new byte[(_session.Auth.Password.Length + 1) * 2];
_passwordLength = WriteString(_session.Auth.Password, _password, 0);
}
}
else
{
// no password in tree connect
_passwordLength = 1;
}
dst[dstIndex++] = _disconnectTid
? unchecked((byte)unchecked(0x01))
: unchecked((byte)unchecked(0x00));
dst[dstIndex++] = unchecked(unchecked(0x00));
WriteInt2(_passwordLength, dst, dstIndex);
return 4;
}
internal override int WriteParameterWordsWireFormat(byte[] dst, int dstIndex)
{
if (_session.transport.Server.Security == SmbConstants.SecurityShare && (_session.Auth.HashesExternal
|| _session.Auth.Password.Length > 0))
{
if (_session.transport.Server.EncryptedPasswords)
{
// encrypted
_password = _session.Auth.GetAnsiHash(_session.transport.Server.EncryptionKey);
_passwordLength = _password.Length;
}
else
{
if (DisablePlainTextPasswords)
{
throw new RuntimeException("Plain text passwords are disabled");
}
// plain text
_password = new byte[(_session.Auth.Password.Length + 1) * 2];
_passwordLength = WriteString(_session.Auth.Password, _password, 0);
}
}
else
{
// no password in tree connect
_passwordLength = 1;
}
dst[dstIndex++] = _disconnectTid ? unchecked((byte)unchecked(0x01)) : unchecked(
(byte)unchecked(0x00));
dst[dstIndex++] = unchecked(unchecked(0x00));
WriteInt2(_passwordLength, dst, dstIndex);
return 4;
}
internal override int WriteBytesWireFormat(byte[] dst, int dstIndex)
{
int start = dstIndex;
if (_session.transport.Server.Security == SmbConstants.SecurityShare
&& (_session.Auth.HashesExternal || _session.Auth.Password.Length > 0))
{
Array.Copy(_password,
0,
dst,
dstIndex,
_passwordLength);
dstIndex += _passwordLength;
}
else
{
// no password in tree connect
dst[dstIndex++] = unchecked(unchecked(0x00));
}
dstIndex += WriteString(path, dst, dstIndex);
try
{
//Array.Copy(Runtime.GetBytesForString(_service, "ASCII"), 0, dst, dstIndex
// , _service.Length);
Array.Copy(Runtime.GetBytesForString(_service, "UTF-8"),
0,
dst,
dstIndex,
_service.Length);
}
catch (UnsupportedEncodingException)
{
return 0;
}
dstIndex += _service.Length;
dst[dstIndex++] = unchecked((byte)('\0'));
return dstIndex - start;
}
internal override int WriteBytesWireFormat(byte[] dst, int dstIndex)
{
int start = dstIndex;
if (_session.transport.Server.Security == SmbConstants.SecurityShare && (_session.Auth.HashesExternal
|| _session.Auth.Password.Length > 0))
{
Array.Copy(_password, 0, dst, dstIndex, _passwordLength);
dstIndex += _passwordLength;
}
else
{
// no password in tree connect
dst[dstIndex++] = unchecked(unchecked(0x00));
}
dstIndex += WriteString(path, dst, dstIndex);
try
{
// Array.Copy(Runtime.GetBytesForString(_service, "ASCII"), 0, dst, dstIndex
//, _service.Length);
Array.Copy(Runtime.GetBytesForString(_service, "UTF-8"), 0, dst, dstIndex
, _service.Length);
}
catch (UnsupportedEncodingException)
{
return 0;
}
dstIndex += _service.Length;
dst[dstIndex++] = unchecked((byte)('\0'));
return dstIndex - start;
}
internal override int ReadParameterWordsWireFormat(byte[] buffer, int bufferIndex)
{
return 0;
}
internal override int ReadParameterWordsWireFormat(byte[] buffer, int bufferIndex
)
{
return 0;
}
internal override int ReadBytesWireFormat(byte[] buffer, int bufferIndex)
{
return 0;
}
internal override int ReadBytesWireFormat(byte[] buffer, int bufferIndex)
{
return 0;
}
public override string ToString()
{
string result = "SmbComTreeConnectAndX["
+ base.ToString()
+ ",disconnectTid=" + _disconnectTid
+ ",passwordLength=" + _passwordLength
+ ",password=" + Hexdump.ToHexString(_password, _passwordLength, 0)
+ ",path=" + path
+ ",service=" + _service + "]";
return result;
}
}
public override string ToString()
{
string result = "SmbComTreeConnectAndX[" + base.ToString() + ",disconnectTid="
+ _disconnectTid + ",passwordLength=" + _passwordLength + ",password=" + Hexdump.
ToHexString(_password, _passwordLength, 0) + ",path=" + path + ",service=" + _service
+ "]";
return result;
}
}
}