Fix a few for WsStream.cs

This commit is contained in:
sta 2014-05-13 15:31:39 +09:00
parent 87d48ed9ad
commit 4611ed7a8d

View File

@ -54,9 +54,9 @@ namespace WebSocketSharp
#endregion
#region Private Constructors
#region Internal Constructors
private WsStream (Stream innerStream, bool secure)
internal WsStream (Stream innerStream, bool secure)
{
_innerStream = innerStream;
_secure = secure;
@ -65,14 +65,14 @@ namespace WebSocketSharp
#endregion
#region Internal Constructors
#region Public Constructors
internal WsStream (NetworkStream innerStream)
public WsStream (NetworkStream innerStream)
: this (innerStream, false)
{
}
internal WsStream (SslStream innerStream)
public WsStream (SslStream innerStream)
: this (innerStream, true)
{
}
@ -109,10 +109,10 @@ namespace WebSocketSharp
private static string [] readHandshakeHeaders (Stream stream)
{
var buffer = new List<byte> ();
var buff = new List<byte> ();
var count = 0;
Action<int> add = i => {
buffer.Add ((byte) i);
buff.Add ((byte) i);
count++;
};
@ -132,56 +132,16 @@ namespace WebSocketSharp
"The header part of a handshake is greater than the limit length.");
var crlf = "\r\n";
return Encoding.UTF8.GetString (buffer.ToArray ())
return Encoding.UTF8.GetString (buff.ToArray ())
.Replace (crlf + " ", " ")
.Replace (crlf + "\t", " ")
.Split (new string [] { crlf }, StringSplitOptions.RemoveEmptyEntries);
.Split (new [] { crlf }, StringSplitOptions.RemoveEmptyEntries);
}
#endregion
#region Internal Methods
internal static WsStream CreateClientStream (
TcpClient client,
bool secure,
string host,
System.Net.Security.RemoteCertificateValidationCallback validationCallback)
{
var netStream = client.GetStream ();
if (secure) {
if (validationCallback == null)
validationCallback = (sender, certificate, chain, sslPolicyErrors) => true;
var sslStream = new SslStream (netStream, false, validationCallback);
sslStream.AuthenticateAsClient (host);
return new WsStream (sslStream);
}
return new WsStream (netStream);
}
internal static WsStream CreateServerStream (
TcpClient client, bool secure, X509Certificate cert)
{
var netStream = client.GetStream ();
if (secure) {
var sslStream = new SslStream (netStream, false);
sslStream.AuthenticateAsServer (cert);
return new WsStream (sslStream);
}
return new WsStream (netStream);
}
internal static WsStream CreateServerStream (HttpListenerContext context)
{
var conn = context.Connection;
return new WsStream (conn.Stream, conn.IsSecure);
}
internal T ReadHandshake<T> (Func<string [], T> parser, int millisecondsTimeout)
where T : HandshakeBase
{
@ -245,6 +205,46 @@ namespace WebSocketSharp
_innerStream.Close ();
}
public static WsStream CreateClientStream (
TcpClient client,
bool secure,
string host,
System.Net.Security.RemoteCertificateValidationCallback validationCallback)
{
var netStream = client.GetStream ();
if (secure) {
if (validationCallback == null)
validationCallback = (sender, certificate, chain, sslPolicyErrors) => true;
var sslStream = new SslStream (netStream, false, validationCallback);
sslStream.AuthenticateAsClient (host);
return new WsStream (sslStream);
}
return new WsStream (netStream);
}
public static WsStream CreateServerStream (
TcpClient client, bool secure, X509Certificate cert)
{
var netStream = client.GetStream ();
if (secure) {
var sslStream = new SslStream (netStream, false);
sslStream.AuthenticateAsServer (cert);
return new WsStream (sslStream);
}
return new WsStream (netStream);
}
public static WsStream CreateServerStream (HttpListenerContext context)
{
var conn = context.Connection;
return new WsStream (conn.Stream, conn.IsSecure);
}
public void Dispose ()
{
_innerStream.Dispose ();