Renamed ResponseHandshake.cs to HandshakeResponse.cs
This commit is contained in:
parent
7f61f6c491
commit
7deddda2f9
@ -1,6 +1,6 @@
|
|||||||
#region License
|
#region License
|
||||||
/*
|
/*
|
||||||
* ResponseHandshake.cs
|
* HandshakeResponse.cs
|
||||||
*
|
*
|
||||||
* The MIT License
|
* The MIT License
|
||||||
*
|
*
|
||||||
@ -33,18 +33,18 @@ using WebSocketSharp.Net;
|
|||||||
|
|
||||||
namespace WebSocketSharp
|
namespace WebSocketSharp
|
||||||
{
|
{
|
||||||
internal class ResponseHandshake : HandshakeBase
|
internal class HandshakeResponse : HandshakeBase
|
||||||
{
|
{
|
||||||
#region Public Constructors
|
#region Public Constructors
|
||||||
|
|
||||||
public ResponseHandshake ()
|
public HandshakeResponse ()
|
||||||
: this (HttpStatusCode.SwitchingProtocols)
|
: this (HttpStatusCode.SwitchingProtocols)
|
||||||
{
|
{
|
||||||
AddHeader ("Upgrade", "websocket");
|
AddHeader ("Upgrade", "websocket");
|
||||||
AddHeader ("Connection", "Upgrade");
|
AddHeader ("Connection", "Upgrade");
|
||||||
}
|
}
|
||||||
|
|
||||||
public ResponseHandshake (HttpStatusCode code)
|
public HandshakeResponse (HttpStatusCode code)
|
||||||
{
|
{
|
||||||
StatusCode = ((int) code).ToString ();
|
StatusCode = ((int) code).ToString ();
|
||||||
Reason = code.GetDescription ();
|
Reason = code.GetDescription ();
|
||||||
@ -101,15 +101,15 @@ namespace WebSocketSharp
|
|||||||
|
|
||||||
#region Public Methods
|
#region Public Methods
|
||||||
|
|
||||||
public static ResponseHandshake CreateCloseResponse (HttpStatusCode code)
|
public static HandshakeResponse CreateCloseResponse (HttpStatusCode code)
|
||||||
{
|
{
|
||||||
var res = new ResponseHandshake (code);
|
var res = new HandshakeResponse (code);
|
||||||
res.AddHeader ("Connection", "close");
|
res.AddHeader ("Connection", "close");
|
||||||
|
|
||||||
return res;
|
return res;
|
||||||
}
|
}
|
||||||
|
|
||||||
public static ResponseHandshake Parse (string [] response)
|
public static HandshakeResponse Parse (string [] response)
|
||||||
{
|
{
|
||||||
var statusLine = response [0].Split (' ');
|
var statusLine = response [0].Split (' ');
|
||||||
if (statusLine.Length < 3)
|
if (statusLine.Length < 3)
|
||||||
@ -123,7 +123,7 @@ namespace WebSocketSharp
|
|||||||
for (int i = 1; i < response.Length; i++)
|
for (int i = 1; i < response.Length; i++)
|
||||||
headers.SetInternal (response [i], true);
|
headers.SetInternal (response [i], true);
|
||||||
|
|
||||||
return new ResponseHandshake {
|
return new HandshakeResponse {
|
||||||
Headers = headers,
|
Headers = headers,
|
||||||
Reason = reason.ToString (),
|
Reason = reason.ToString (),
|
||||||
StatusCode = statusLine [1],
|
StatusCode = statusLine [1],
|
@ -500,7 +500,7 @@ namespace WebSocketSharp {
|
|||||||
private bool acceptHandshake ()
|
private bool acceptHandshake ()
|
||||||
{
|
{
|
||||||
return processHandshakeRequest ()
|
return processHandshakeRequest ()
|
||||||
? send (createResponseHandshake ())
|
? send (createHandshakeResponse ())
|
||||||
: false;
|
: false;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -532,7 +532,7 @@ namespace WebSocketSharp {
|
|||||||
if (state == WsState.CONNECTING)
|
if (state == WsState.CONNECTING)
|
||||||
{
|
{
|
||||||
if (!_client)
|
if (!_client)
|
||||||
args.WasClean = send (createResponseHandshake (HttpStatusCode.BadRequest));
|
args.WasClean = send (createHandshakeResponse (HttpStatusCode.BadRequest));
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
@ -708,19 +708,6 @@ namespace WebSocketSharp {
|
|||||||
return frame;
|
return frame;
|
||||||
}
|
}
|
||||||
|
|
||||||
// As client
|
|
||||||
private string createRequestExtensions()
|
|
||||||
{
|
|
||||||
var extensions = new StringBuilder(64);
|
|
||||||
var comp = createCompressionExtension(_compression);
|
|
||||||
if (comp.Length > 0)
|
|
||||||
extensions.Append(comp);
|
|
||||||
|
|
||||||
return extensions.Length > 0
|
|
||||||
? extensions.ToString()
|
|
||||||
: String.Empty;
|
|
||||||
}
|
|
||||||
|
|
||||||
// As client
|
// As client
|
||||||
private HandshakeRequest createHandshakeRequest ()
|
private HandshakeRequest createHandshakeRequest ()
|
||||||
{
|
{
|
||||||
@ -756,9 +743,9 @@ namespace WebSocketSharp {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// As server
|
// As server
|
||||||
private ResponseHandshake createResponseHandshake()
|
private HandshakeResponse createHandshakeResponse ()
|
||||||
{
|
{
|
||||||
var res = new ResponseHandshake();
|
var res = new HandshakeResponse ();
|
||||||
res.AddHeader ("Sec-WebSocket-Accept", createResponseKey ());
|
res.AddHeader ("Sec-WebSocket-Accept", createResponseKey ());
|
||||||
if (_extensions.Length > 0)
|
if (_extensions.Length > 0)
|
||||||
res.AddHeader ("Sec-WebSocket-Extensions", _extensions);
|
res.AddHeader ("Sec-WebSocket-Extensions", _extensions);
|
||||||
@ -770,14 +757,27 @@ namespace WebSocketSharp {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// As server
|
// As server
|
||||||
private ResponseHandshake createResponseHandshake(HttpStatusCode code)
|
private HandshakeResponse createHandshakeResponse (HttpStatusCode code)
|
||||||
{
|
{
|
||||||
var res = ResponseHandshake.CreateCloseResponse(code);
|
var res = HandshakeResponse.CreateCloseResponse (code);
|
||||||
res.AddHeader ("Sec-WebSocket-Version", _version);
|
res.AddHeader ("Sec-WebSocket-Version", _version);
|
||||||
|
|
||||||
return res;
|
return res;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// As client
|
||||||
|
private string createRequestExtensions ()
|
||||||
|
{
|
||||||
|
var extensions = new StringBuilder (64);
|
||||||
|
var comp = createCompressionExtension (_compression);
|
||||||
|
if (comp.Length > 0)
|
||||||
|
extensions.Append (comp);
|
||||||
|
|
||||||
|
return extensions.Length > 0
|
||||||
|
? extensions.ToString ()
|
||||||
|
: String.Empty;
|
||||||
|
}
|
||||||
|
|
||||||
private string createResponseKey ()
|
private string createResponseKey ()
|
||||||
{
|
{
|
||||||
var buffer = new StringBuilder (_base64key, 64);
|
var buffer = new StringBuilder (_base64key, 64);
|
||||||
@ -792,7 +792,7 @@ namespace WebSocketSharp {
|
|||||||
private bool doHandshake ()
|
private bool doHandshake ()
|
||||||
{
|
{
|
||||||
setClientStream ();
|
setClientStream ();
|
||||||
return processResponseHandshake (sendHandshakeRequest ());
|
return processHandshakeResponse (sendHandshakeRequest ());
|
||||||
}
|
}
|
||||||
|
|
||||||
private void error(string message)
|
private void error(string message)
|
||||||
@ -866,7 +866,7 @@ namespace WebSocketSharp {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// As client
|
// As client
|
||||||
private bool isValidResponseHandshake(ResponseHandshake response)
|
private bool isValidHandshakeResponse (HandshakeResponse response)
|
||||||
{
|
{
|
||||||
return !response.IsWebSocketResponse
|
return !response.IsWebSocketResponse
|
||||||
? false
|
? false
|
||||||
@ -1112,11 +1112,11 @@ namespace WebSocketSharp {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// As client
|
// As client
|
||||||
private bool processResponseHandshake(ResponseHandshake response)
|
private bool processHandshakeResponse (HandshakeResponse response)
|
||||||
{
|
{
|
||||||
var msg = response.IsUnauthorized
|
var msg = response.IsUnauthorized
|
||||||
? String.Format ("An HTTP {0} authorization is required.", response.AuthChallenge.Scheme)
|
? String.Format ("An HTTP {0} authorization is required.", response.AuthChallenge.Scheme)
|
||||||
: !isValidResponseHandshake(response)
|
: !isValidHandshakeResponse (response)
|
||||||
? "Invalid response to this WebSocket connection request."
|
? "Invalid response to this WebSocket connection request."
|
||||||
: String.Empty;
|
: String.Empty;
|
||||||
|
|
||||||
@ -1144,10 +1144,10 @@ namespace WebSocketSharp {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// As client
|
// As client
|
||||||
private ResponseHandshake receiveResponseHandshake()
|
private HandshakeResponse receiveHandshakeResponse ()
|
||||||
{
|
{
|
||||||
var res = ResponseHandshake.Parse(_stream.ReadHandshake());
|
var res = HandshakeResponse.Parse (_stream.ReadHandshake ());
|
||||||
_logger.Debug("Response handshake from server:\n" + res.ToString());
|
_logger.Debug ("A handshake response from the server:\n" + res.ToString ());
|
||||||
|
|
||||||
return res;
|
return res;
|
||||||
}
|
}
|
||||||
@ -1160,9 +1160,9 @@ namespace WebSocketSharp {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// As server
|
// As server
|
||||||
private bool send (ResponseHandshake response)
|
private bool send (HandshakeResponse response)
|
||||||
{
|
{
|
||||||
_logger.Debug ("Response handshake to client:\n" + response.ToString ());
|
_logger.Debug ("A handshake response to a client:\n" + response.ToString ());
|
||||||
return _stream.WriteHandshake (response);
|
return _stream.WriteHandshake (response);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1301,7 +1301,7 @@ namespace WebSocketSharp {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// As client
|
// As client
|
||||||
private ResponseHandshake sendHandshakeRequest ()
|
private HandshakeResponse sendHandshakeRequest ()
|
||||||
{
|
{
|
||||||
var req = createHandshakeRequest ();
|
var req = createHandshakeRequest ();
|
||||||
var res = sendHandshakeRequest (req);
|
var res = sendHandshakeRequest (req);
|
||||||
@ -1316,10 +1316,10 @@ namespace WebSocketSharp {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// As client
|
// As client
|
||||||
private ResponseHandshake sendHandshakeRequest (HandshakeRequest request)
|
private HandshakeResponse sendHandshakeRequest (HandshakeRequest request)
|
||||||
{
|
{
|
||||||
send (request);
|
send (request);
|
||||||
return receiveResponseHandshake ();
|
return receiveHandshakeResponse ();
|
||||||
}
|
}
|
||||||
|
|
||||||
// As client
|
// As client
|
||||||
@ -1367,7 +1367,7 @@ namespace WebSocketSharp {
|
|||||||
internal void Close (HttpStatusCode code)
|
internal void Close (HttpStatusCode code)
|
||||||
{
|
{
|
||||||
_readyState = WsState.CLOSING;
|
_readyState = WsState.CLOSING;
|
||||||
send (createResponseHandshake (code));
|
send (createHandshakeResponse (code));
|
||||||
closeResources ();
|
closeResources ();
|
||||||
_readyState = WsState.CLOSED;
|
_readyState = WsState.CLOSED;
|
||||||
}
|
}
|
||||||
|
@ -72,7 +72,6 @@
|
|||||||
<Compile Include="Server\WebSocketServer.cs" />
|
<Compile Include="Server\WebSocketServer.cs" />
|
||||||
<Compile Include="Server\WebSocketService.cs" />
|
<Compile Include="Server\WebSocketService.cs" />
|
||||||
<Compile Include="WsStream.cs" />
|
<Compile Include="WsStream.cs" />
|
||||||
<Compile Include="ResponseHandshake.cs" />
|
|
||||||
<Compile Include="Net\AuthenticationSchemeSelector.cs" />
|
<Compile Include="Net\AuthenticationSchemeSelector.cs" />
|
||||||
<Compile Include="Net\AuthenticationSchemes.cs" />
|
<Compile Include="Net\AuthenticationSchemes.cs" />
|
||||||
<Compile Include="Net\ChunkStream.cs" />
|
<Compile Include="Net\ChunkStream.cs" />
|
||||||
@ -128,6 +127,7 @@
|
|||||||
<Compile Include="Logger.cs" />
|
<Compile Include="Logger.cs" />
|
||||||
<Compile Include="HandshakeBase.cs" />
|
<Compile Include="HandshakeBase.cs" />
|
||||||
<Compile Include="HandshakeRequest.cs" />
|
<Compile Include="HandshakeRequest.cs" />
|
||||||
|
<Compile Include="HandshakeResponse.cs" />
|
||||||
</ItemGroup>
|
</ItemGroup>
|
||||||
<Import Project="$(MSBuildBinPath)\Microsoft.CSharp.targets" />
|
<Import Project="$(MSBuildBinPath)\Microsoft.CSharp.targets" />
|
||||||
<ItemGroup>
|
<ItemGroup>
|
||||||
|
Loading…
Reference in New Issue
Block a user