Refactored WebSocketFrame.cs
This commit is contained in:
parent
48c6fac2f5
commit
5dc4703b33
@ -1141,7 +1141,7 @@ namespace WebSocketSharp
|
|||||||
}
|
}
|
||||||
|
|
||||||
return _stream.WriteBytes (
|
return _stream.WriteBytes (
|
||||||
WebSocketFrame.CreateFrame (fin, opcode, mask, data, compressed).ToByteArray ());
|
WebSocketFrame.CreateWebSocketFrame (fin, opcode, mask, data, compressed).ToByteArray ());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1424,7 +1424,7 @@ namespace WebSocketSharp
|
|||||||
try {
|
try {
|
||||||
byte[] cached;
|
byte[] cached;
|
||||||
if (!cache.TryGetValue (_compression, out cached)) {
|
if (!cache.TryGetValue (_compression, out cached)) {
|
||||||
cached = WebSocketFrame.CreateFrame (
|
cached = WebSocketFrame.CreateWebSocketFrame (
|
||||||
Fin.Final,
|
Fin.Final,
|
||||||
opcode,
|
opcode,
|
||||||
Mask.Unmask,
|
Mask.Unmask,
|
||||||
|
@ -38,10 +38,10 @@ namespace WebSocketSharp
|
|||||||
{
|
{
|
||||||
#region Private Fields
|
#region Private Fields
|
||||||
|
|
||||||
private byte [] _extPayloadLength;
|
private byte[] _extPayloadLength;
|
||||||
private Fin _fin;
|
private Fin _fin;
|
||||||
private Mask _mask;
|
private Mask _mask;
|
||||||
private byte [] _maskingKey;
|
private byte[] _maskingKey;
|
||||||
private Opcode _opcode;
|
private Opcode _opcode;
|
||||||
private PayloadData _payloadData;
|
private PayloadData _payloadData;
|
||||||
private byte _payloadLength;
|
private byte _payloadLength;
|
||||||
@ -51,9 +51,9 @@ namespace WebSocketSharp
|
|||||||
|
|
||||||
#endregion
|
#endregion
|
||||||
|
|
||||||
#region Internal Static Fields
|
#region Internal Fields
|
||||||
|
|
||||||
internal static readonly byte [] EmptyUnmaskPingData;
|
internal static readonly byte[] EmptyUnmaskPingData;
|
||||||
|
|
||||||
#endregion
|
#endregion
|
||||||
|
|
||||||
@ -74,24 +74,25 @@ namespace WebSocketSharp
|
|||||||
|
|
||||||
#endregion
|
#endregion
|
||||||
|
|
||||||
#region Public Constructors
|
#region Internal Constructors
|
||||||
|
|
||||||
public WebSocketFrame (Opcode opcode, PayloadData payload)
|
internal WebSocketFrame (Opcode opcode, PayloadData payload)
|
||||||
: this (Fin.Final, opcode, Mask.Mask, payload, false)
|
: this (Fin.Final, opcode, Mask.Mask, payload, false)
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
public WebSocketFrame (Opcode opcode, Mask mask, PayloadData payload)
|
internal WebSocketFrame (Opcode opcode, Mask mask, PayloadData payload)
|
||||||
: this (Fin.Final, opcode, mask, payload, false)
|
: this (Fin.Final, opcode, mask, payload, false)
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
public WebSocketFrame (Fin fin, Opcode opcode, Mask mask, PayloadData payload)
|
internal WebSocketFrame (Fin fin, Opcode opcode, Mask mask, PayloadData payload)
|
||||||
: this (fin, opcode, mask, payload, false)
|
: this (fin, opcode, mask, payload, false)
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
public WebSocketFrame (Fin fin, Opcode opcode, Mask mask, PayloadData payload, bool compressed)
|
internal WebSocketFrame (
|
||||||
|
Fin fin, Opcode opcode, Mask mask, PayloadData payload, bool compressed)
|
||||||
{
|
{
|
||||||
_fin = fin;
|
_fin = fin;
|
||||||
_rsv1 = isData (opcode) && compressed ? Rsv.On : Rsv.Off;
|
_rsv1 = isData (opcode) && compressed ? Rsv.On : Rsv.Off;
|
||||||
@ -103,7 +104,7 @@ namespace WebSocketSharp
|
|||||||
var len = payload.Length;
|
var len = payload.Length;
|
||||||
if (len < 126) {
|
if (len < 126) {
|
||||||
_payloadLength = (byte) len;
|
_payloadLength = (byte) len;
|
||||||
_extPayloadLength = new byte [0];
|
_extPayloadLength = new byte[0];
|
||||||
}
|
}
|
||||||
else if (len < 0x010000) {
|
else if (len < 0x010000) {
|
||||||
_payloadLength = (byte) 126;
|
_payloadLength = (byte) 126;
|
||||||
@ -119,7 +120,7 @@ namespace WebSocketSharp
|
|||||||
payload.Mask (_maskingKey);
|
payload.Mask (_maskingKey);
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
_maskingKey = new byte [0];
|
_maskingKey = new byte[0];
|
||||||
}
|
}
|
||||||
|
|
||||||
_payloadData = payload;
|
_payloadData = payload;
|
||||||
@ -129,7 +130,7 @@ namespace WebSocketSharp
|
|||||||
|
|
||||||
#region Public Properties
|
#region Public Properties
|
||||||
|
|
||||||
public byte [] ExtendedPayloadLength {
|
public byte[] ExtendedPayloadLength {
|
||||||
get {
|
get {
|
||||||
return _extPayloadLength;
|
return _extPayloadLength;
|
||||||
}
|
}
|
||||||
@ -231,7 +232,7 @@ namespace WebSocketSharp
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public byte [] MaskingKey {
|
public byte[] MaskingKey {
|
||||||
get {
|
get {
|
||||||
return _maskingKey;
|
return _maskingKey;
|
||||||
}
|
}
|
||||||
@ -277,9 +278,9 @@ namespace WebSocketSharp
|
|||||||
|
|
||||||
#region Private Methods
|
#region Private Methods
|
||||||
|
|
||||||
private static byte [] createMaskingKey ()
|
private static byte[] createMaskingKey ()
|
||||||
{
|
{
|
||||||
var key = new byte [4];
|
var key = new byte[4];
|
||||||
var rand = new Random ();
|
var rand = new Random ();
|
||||||
rand.NextBytes (key);
|
rand.NextBytes (key);
|
||||||
|
|
||||||
@ -333,15 +334,15 @@ namespace WebSocketSharp
|
|||||||
var j = i * 4;
|
var j = i * 4;
|
||||||
if (i < cnt)
|
if (i < cnt)
|
||||||
printLine (
|
printLine (
|
||||||
Convert.ToString (frameAsBytes [j], 2).PadLeft (8, '0'),
|
Convert.ToString (frameAsBytes[j], 2).PadLeft (8, '0'),
|
||||||
Convert.ToString (frameAsBytes [j + 1], 2).PadLeft (8, '0'),
|
Convert.ToString (frameAsBytes[j + 1], 2).PadLeft (8, '0'),
|
||||||
Convert.ToString (frameAsBytes [j + 2], 2).PadLeft (8, '0'),
|
Convert.ToString (frameAsBytes[j + 2], 2).PadLeft (8, '0'),
|
||||||
Convert.ToString (frameAsBytes [j + 3], 2).PadLeft (8, '0'));
|
Convert.ToString (frameAsBytes[j + 3], 2).PadLeft (8, '0'));
|
||||||
else if (rem > 0)
|
else if (rem > 0)
|
||||||
printLine (
|
printLine (
|
||||||
Convert.ToString (frameAsBytes [j], 2).PadLeft (8, '0'),
|
Convert.ToString (frameAsBytes[j], 2).PadLeft (8, '0'),
|
||||||
rem >= 2 ? Convert.ToString (frameAsBytes [j + 1], 2).PadLeft (8, '0') : String.Empty,
|
rem >= 2 ? Convert.ToString (frameAsBytes[j + 1], 2).PadLeft (8, '0') : String.Empty,
|
||||||
rem == 3 ? Convert.ToString (frameAsBytes [j + 2], 2).PadLeft (8, '0') : String.Empty,
|
rem == 3 ? Convert.ToString (frameAsBytes[j + 2], 2).PadLeft (8, '0') : String.Empty,
|
||||||
String.Empty);
|
String.Empty);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -359,114 +360,6 @@ namespace WebSocketSharp
|
|||||||
return opcode == Opcode.Text || opcode == Opcode.Binary;
|
return opcode == Opcode.Text || opcode == Opcode.Binary;
|
||||||
}
|
}
|
||||||
|
|
||||||
private static WebSocketFrame parse (byte [] header, Stream stream, bool unmask)
|
|
||||||
{
|
|
||||||
/* Header */
|
|
||||||
|
|
||||||
// FIN
|
|
||||||
var fin = (header [0] & 0x80) == 0x80 ? Fin.Final : Fin.More;
|
|
||||||
// RSV1
|
|
||||||
var rsv1 = (header [0] & 0x40) == 0x40 ? Rsv.On : Rsv.Off;
|
|
||||||
// RSV2
|
|
||||||
var rsv2 = (header [0] & 0x20) == 0x20 ? Rsv.On : Rsv.Off;
|
|
||||||
// RSV3
|
|
||||||
var rsv3 = (header [0] & 0x10) == 0x10 ? Rsv.On : Rsv.Off;
|
|
||||||
// Opcode
|
|
||||||
var opcode = (Opcode) (header [0] & 0x0f);
|
|
||||||
// MASK
|
|
||||||
var mask = (header [1] & 0x80) == 0x80 ? Mask.Mask : Mask.Unmask;
|
|
||||||
// Payload Length
|
|
||||||
var payloadLen = (byte) (header [1] & 0x7f);
|
|
||||||
|
|
||||||
// Check if correct frame.
|
|
||||||
var incorrect = isControl (opcode) && fin == Fin.More
|
|
||||||
? "A control frame is fragmented."
|
|
||||||
: !isData (opcode) && rsv1 == Rsv.On
|
|
||||||
? "A non data frame is compressed."
|
|
||||||
: null;
|
|
||||||
|
|
||||||
if (incorrect != null)
|
|
||||||
throw new WebSocketException (CloseStatusCode.IncorrectData, incorrect);
|
|
||||||
|
|
||||||
// Check if consistent frame.
|
|
||||||
if (isControl (opcode) && payloadLen > 125)
|
|
||||||
throw new WebSocketException (
|
|
||||||
CloseStatusCode.InconsistentData,
|
|
||||||
"The length of payload data of a control frame is greater than 125 bytes.");
|
|
||||||
|
|
||||||
var frame = new WebSocketFrame ();
|
|
||||||
frame._fin = fin;
|
|
||||||
frame._rsv1 = rsv1;
|
|
||||||
frame._rsv2 = rsv2;
|
|
||||||
frame._rsv3 = rsv3;
|
|
||||||
frame._opcode = opcode;
|
|
||||||
frame._mask = mask;
|
|
||||||
frame._payloadLength = payloadLen;
|
|
||||||
|
|
||||||
/* Extended Payload Length */
|
|
||||||
|
|
||||||
var size = payloadLen < 126
|
|
||||||
? 0
|
|
||||||
: payloadLen == 126
|
|
||||||
? 2
|
|
||||||
: 8;
|
|
||||||
|
|
||||||
var extPayloadLen = size > 0 ? stream.ReadBytes (size) : new byte [0];
|
|
||||||
if (size > 0 && extPayloadLen.Length != size)
|
|
||||||
throw new WebSocketException (
|
|
||||||
"The 'Extended Payload Length' of a frame cannot be read from the data source.");
|
|
||||||
|
|
||||||
frame._extPayloadLength = extPayloadLen;
|
|
||||||
|
|
||||||
/* Masking Key */
|
|
||||||
|
|
||||||
var masked = mask == Mask.Mask;
|
|
||||||
var maskingKey = masked ? stream.ReadBytes (4) : new byte [0];
|
|
||||||
if (masked && maskingKey.Length != 4)
|
|
||||||
throw new WebSocketException (
|
|
||||||
"The 'Masking Key' of a frame cannot be read from the data source.");
|
|
||||||
|
|
||||||
frame._maskingKey = maskingKey;
|
|
||||||
|
|
||||||
/* Payload Data */
|
|
||||||
|
|
||||||
ulong len = payloadLen < 126
|
|
||||||
? payloadLen
|
|
||||||
: payloadLen == 126
|
|
||||||
? extPayloadLen.ToUInt16 (ByteOrder.Big)
|
|
||||||
: extPayloadLen.ToUInt64 (ByteOrder.Big);
|
|
||||||
|
|
||||||
byte [] data = null;
|
|
||||||
if (len > 0) {
|
|
||||||
// Check if allowable payload data length.
|
|
||||||
if (payloadLen > 126 && len > PayloadData.MaxLength)
|
|
||||||
throw new WebSocketException (
|
|
||||||
CloseStatusCode.TooBig,
|
|
||||||
"The length of 'Payload Data' of a frame is greater than the allowable length.");
|
|
||||||
|
|
||||||
data = payloadLen > 126
|
|
||||||
? stream.ReadBytes ((long) len, 1024)
|
|
||||||
: stream.ReadBytes ((int) len);
|
|
||||||
|
|
||||||
if (data.LongLength != (long) len)
|
|
||||||
throw new WebSocketException (
|
|
||||||
"The 'Payload Data' of a frame cannot be read from the data source.");
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
data = new byte [0];
|
|
||||||
}
|
|
||||||
|
|
||||||
var payload = new PayloadData (data, masked);
|
|
||||||
if (masked && unmask) {
|
|
||||||
payload.Mask (maskingKey);
|
|
||||||
frame._mask = Mask.Unmask;
|
|
||||||
frame._maskingKey = new byte [0];
|
|
||||||
}
|
|
||||||
|
|
||||||
frame._payloadData = payload;
|
|
||||||
return frame;
|
|
||||||
}
|
|
||||||
|
|
||||||
private static string print (WebSocketFrame frame)
|
private static string print (WebSocketFrame frame)
|
||||||
{
|
{
|
||||||
/* Opcode */
|
/* Opcode */
|
||||||
@ -502,7 +395,7 @@ namespace WebSocketSharp
|
|||||||
? Encoding.UTF8.GetString (frame._payloadData.ApplicationData)
|
? Encoding.UTF8.GetString (frame._payloadData.ApplicationData)
|
||||||
: frame._payloadData.ToString ();
|
: frame._payloadData.ToString ();
|
||||||
|
|
||||||
var format =
|
var fmt =
|
||||||
@" FIN: {0}
|
@" FIN: {0}
|
||||||
RSV1: {1}
|
RSV1: {1}
|
||||||
RSV2: {2}
|
RSV2: {2}
|
||||||
@ -515,7 +408,7 @@ Extended Payload Length: {7}
|
|||||||
Payload Data: {9}";
|
Payload Data: {9}";
|
||||||
|
|
||||||
return String.Format (
|
return String.Format (
|
||||||
format,
|
fmt,
|
||||||
frame._fin,
|
frame._fin,
|
||||||
frame._rsv1,
|
frame._rsv1,
|
||||||
frame._rsv2,
|
frame._rsv2,
|
||||||
@ -528,95 +421,177 @@ Extended Payload Length: {7}
|
|||||||
payload);
|
payload);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private static WebSocketFrame read (byte[] header, Stream stream, bool unmask)
|
||||||
|
{
|
||||||
|
/* Header */
|
||||||
|
|
||||||
|
// FIN
|
||||||
|
var fin = (header[0] & 0x80) == 0x80 ? Fin.Final : Fin.More;
|
||||||
|
// RSV1
|
||||||
|
var rsv1 = (header[0] & 0x40) == 0x40 ? Rsv.On : Rsv.Off;
|
||||||
|
// RSV2
|
||||||
|
var rsv2 = (header[0] & 0x20) == 0x20 ? Rsv.On : Rsv.Off;
|
||||||
|
// RSV3
|
||||||
|
var rsv3 = (header[0] & 0x10) == 0x10 ? Rsv.On : Rsv.Off;
|
||||||
|
// Opcode
|
||||||
|
var opcode = (Opcode) (header[0] & 0x0f);
|
||||||
|
// MASK
|
||||||
|
var mask = (header[1] & 0x80) == 0x80 ? Mask.Mask : Mask.Unmask;
|
||||||
|
// Payload Length
|
||||||
|
var payloadLen = (byte) (header[1] & 0x7f);
|
||||||
|
|
||||||
|
// Check if correct frame.
|
||||||
|
var incorrect = isControl (opcode) && fin == Fin.More
|
||||||
|
? "A control frame is fragmented."
|
||||||
|
: !isData (opcode) && rsv1 == Rsv.On
|
||||||
|
? "A non data frame is compressed."
|
||||||
|
: null;
|
||||||
|
|
||||||
|
if (incorrect != null)
|
||||||
|
throw new WebSocketException (CloseStatusCode.IncorrectData, incorrect);
|
||||||
|
|
||||||
|
// Check if consistent frame.
|
||||||
|
if (isControl (opcode) && payloadLen > 125)
|
||||||
|
throw new WebSocketException (
|
||||||
|
CloseStatusCode.InconsistentData,
|
||||||
|
"The length of payload data of a control frame is greater than 125 bytes.");
|
||||||
|
|
||||||
|
var frame = new WebSocketFrame ();
|
||||||
|
frame._fin = fin;
|
||||||
|
frame._rsv1 = rsv1;
|
||||||
|
frame._rsv2 = rsv2;
|
||||||
|
frame._rsv3 = rsv3;
|
||||||
|
frame._opcode = opcode;
|
||||||
|
frame._mask = mask;
|
||||||
|
frame._payloadLength = payloadLen;
|
||||||
|
|
||||||
|
/* Extended Payload Length */
|
||||||
|
|
||||||
|
var size = payloadLen < 126
|
||||||
|
? 0
|
||||||
|
: payloadLen == 126
|
||||||
|
? 2
|
||||||
|
: 8;
|
||||||
|
|
||||||
|
var extPayloadLen = size > 0 ? stream.ReadBytes (size) : new byte[0];
|
||||||
|
if (size > 0 && extPayloadLen.Length != size)
|
||||||
|
throw new WebSocketException (
|
||||||
|
"The 'Extended Payload Length' of a frame cannot be read from the data source.");
|
||||||
|
|
||||||
|
frame._extPayloadLength = extPayloadLen;
|
||||||
|
|
||||||
|
/* Masking Key */
|
||||||
|
|
||||||
|
var masked = mask == Mask.Mask;
|
||||||
|
var maskingKey = masked ? stream.ReadBytes (4) : new byte[0];
|
||||||
|
if (masked && maskingKey.Length != 4)
|
||||||
|
throw new WebSocketException (
|
||||||
|
"The 'Masking Key' of a frame cannot be read from the data source.");
|
||||||
|
|
||||||
|
frame._maskingKey = maskingKey;
|
||||||
|
|
||||||
|
/* Payload Data */
|
||||||
|
|
||||||
|
ulong len = payloadLen < 126
|
||||||
|
? payloadLen
|
||||||
|
: payloadLen == 126
|
||||||
|
? extPayloadLen.ToUInt16 (ByteOrder.Big)
|
||||||
|
: extPayloadLen.ToUInt64 (ByteOrder.Big);
|
||||||
|
|
||||||
|
byte[] data = null;
|
||||||
|
if (len > 0) {
|
||||||
|
// Check if allowable payload data length.
|
||||||
|
if (payloadLen > 126 && len > PayloadData.MaxLength)
|
||||||
|
throw new WebSocketException (
|
||||||
|
CloseStatusCode.TooBig,
|
||||||
|
"The length of 'Payload Data' of a frame is greater than the allowable length.");
|
||||||
|
|
||||||
|
data = payloadLen > 126
|
||||||
|
? stream.ReadBytes ((long) len, 1024)
|
||||||
|
: stream.ReadBytes ((int) len);
|
||||||
|
|
||||||
|
if (data.LongLength != (long) len)
|
||||||
|
throw new WebSocketException (
|
||||||
|
"The 'Payload Data' of a frame cannot be read from the data source.");
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
data = new byte[0];
|
||||||
|
}
|
||||||
|
|
||||||
|
var payload = new PayloadData (data, masked);
|
||||||
|
if (masked && unmask) {
|
||||||
|
payload.Mask (maskingKey);
|
||||||
|
frame._mask = Mask.Unmask;
|
||||||
|
frame._maskingKey = new byte[0];
|
||||||
|
}
|
||||||
|
|
||||||
|
frame._payloadData = payload;
|
||||||
|
return frame;
|
||||||
|
}
|
||||||
|
|
||||||
#endregion
|
#endregion
|
||||||
|
|
||||||
#region Internal Methods
|
#region Internal Methods
|
||||||
|
|
||||||
|
internal static WebSocketFrame CreateCloseFrame (Mask mask, byte[] data)
|
||||||
|
{
|
||||||
|
return new WebSocketFrame (Opcode.Close, mask, new PayloadData (data));
|
||||||
|
}
|
||||||
|
|
||||||
internal static WebSocketFrame CreateCloseFrame (Mask mask, PayloadData payload)
|
internal static WebSocketFrame CreateCloseFrame (Mask mask, PayloadData payload)
|
||||||
{
|
{
|
||||||
return new WebSocketFrame (Opcode.Close, mask, payload);
|
return new WebSocketFrame (Opcode.Close, mask, payload);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
internal static WebSocketFrame CreateCloseFrame (Mask mask, CloseStatusCode code, string reason)
|
||||||
|
{
|
||||||
|
return new WebSocketFrame (
|
||||||
|
Opcode.Close, mask, new PayloadData (((ushort) code).Append (reason)));
|
||||||
|
}
|
||||||
|
|
||||||
|
internal static WebSocketFrame CreatePingFrame (Mask mask)
|
||||||
|
{
|
||||||
|
return new WebSocketFrame (Opcode.Ping, mask, new PayloadData ());
|
||||||
|
}
|
||||||
|
|
||||||
|
internal static WebSocketFrame CreatePingFrame (Mask mask, byte[] data)
|
||||||
|
{
|
||||||
|
return new WebSocketFrame (Opcode.Ping, mask, new PayloadData (data));
|
||||||
|
}
|
||||||
|
|
||||||
internal static WebSocketFrame CreatePongFrame (Mask mask, PayloadData payload)
|
internal static WebSocketFrame CreatePongFrame (Mask mask, PayloadData payload)
|
||||||
{
|
{
|
||||||
return new WebSocketFrame (Opcode.Pong, mask, payload);
|
return new WebSocketFrame (Opcode.Pong, mask, payload);
|
||||||
}
|
}
|
||||||
|
|
||||||
#endregion
|
internal static WebSocketFrame CreateWebSocketFrame (
|
||||||
|
Fin fin, Opcode opcode, Mask mask, byte[] data, bool compressed)
|
||||||
#region Public Methods
|
|
||||||
|
|
||||||
public static WebSocketFrame CreateCloseFrame (Mask mask, byte [] data)
|
|
||||||
{
|
|
||||||
return new WebSocketFrame (Opcode.Close, mask, new PayloadData (data));
|
|
||||||
}
|
|
||||||
|
|
||||||
public static WebSocketFrame CreateCloseFrame (Mask mask, CloseStatusCode code, string reason)
|
|
||||||
{
|
|
||||||
return new WebSocketFrame (
|
|
||||||
Opcode.Close, mask, new PayloadData (((ushort) code).Append (reason)));
|
|
||||||
}
|
|
||||||
|
|
||||||
public static WebSocketFrame CreateFrame (
|
|
||||||
Fin fin, Opcode opcode, Mask mask, byte [] data, bool compressed)
|
|
||||||
{
|
{
|
||||||
return new WebSocketFrame (fin, opcode, mask, new PayloadData (data), compressed);
|
return new WebSocketFrame (fin, opcode, mask, new PayloadData (data), compressed);
|
||||||
}
|
}
|
||||||
|
|
||||||
public static WebSocketFrame CreatePingFrame (Mask mask)
|
internal static WebSocketFrame Read (Stream stream)
|
||||||
{
|
{
|
||||||
return new WebSocketFrame (Opcode.Ping, mask, new PayloadData ());
|
return Read (stream, true);
|
||||||
}
|
}
|
||||||
|
|
||||||
public static WebSocketFrame CreatePingFrame (Mask mask, byte [] data)
|
internal static WebSocketFrame Read (Stream stream, bool unmask)
|
||||||
{
|
|
||||||
return new WebSocketFrame (Opcode.Ping, mask, new PayloadData (data));
|
|
||||||
}
|
|
||||||
|
|
||||||
public IEnumerator<byte> GetEnumerator ()
|
|
||||||
{
|
|
||||||
foreach (var b in ToByteArray ())
|
|
||||||
yield return b;
|
|
||||||
}
|
|
||||||
|
|
||||||
public static WebSocketFrame Parse (byte [] src)
|
|
||||||
{
|
|
||||||
return Parse (src, true);
|
|
||||||
}
|
|
||||||
|
|
||||||
public static WebSocketFrame Parse (Stream stream)
|
|
||||||
{
|
|
||||||
return Parse (stream, true);
|
|
||||||
}
|
|
||||||
|
|
||||||
public static WebSocketFrame Parse (byte [] src, bool unmask)
|
|
||||||
{
|
|
||||||
using (var stream = new MemoryStream (src))
|
|
||||||
return Parse (stream, unmask);
|
|
||||||
}
|
|
||||||
|
|
||||||
public static WebSocketFrame Parse (Stream stream, bool unmask)
|
|
||||||
{
|
{
|
||||||
var header = stream.ReadBytes (2);
|
var header = stream.ReadBytes (2);
|
||||||
if (header.Length != 2)
|
if (header.Length != 2)
|
||||||
throw new WebSocketException (
|
throw new WebSocketException (
|
||||||
"The header part of a frame cannot be read from the data source.");
|
"The header part of a frame cannot be read from the data source.");
|
||||||
|
|
||||||
return parse (header, stream, unmask);
|
return read (header, stream, unmask);
|
||||||
}
|
}
|
||||||
|
|
||||||
public static void ParseAsync (Stream stream, Action<WebSocketFrame> completed)
|
internal static void ReadAsync (
|
||||||
{
|
|
||||||
ParseAsync (stream, true, completed, null);
|
|
||||||
}
|
|
||||||
|
|
||||||
public static void ParseAsync (
|
|
||||||
Stream stream, Action<WebSocketFrame> completed, Action<Exception> error)
|
Stream stream, Action<WebSocketFrame> completed, Action<Exception> error)
|
||||||
{
|
{
|
||||||
ParseAsync (stream, true, completed, error);
|
ReadAsync (stream, true, completed, error);
|
||||||
}
|
}
|
||||||
|
|
||||||
public static void ParseAsync (
|
internal static void ReadAsync (
|
||||||
Stream stream, bool unmask, Action<WebSocketFrame> completed, Action<Exception> error)
|
Stream stream, bool unmask, Action<WebSocketFrame> completed, Action<Exception> error)
|
||||||
{
|
{
|
||||||
stream.ReadBytesAsync (
|
stream.ReadBytesAsync (
|
||||||
@ -626,13 +601,23 @@ Extended Payload Length: {7}
|
|||||||
throw new WebSocketException (
|
throw new WebSocketException (
|
||||||
"The header part of a frame cannot be read from the data source.");
|
"The header part of a frame cannot be read from the data source.");
|
||||||
|
|
||||||
var frame = parse (header, stream, unmask);
|
var frame = read (header, stream, unmask);
|
||||||
if (completed != null)
|
if (completed != null)
|
||||||
completed (frame);
|
completed (frame);
|
||||||
},
|
},
|
||||||
error);
|
error);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#endregion
|
||||||
|
|
||||||
|
#region Public Methods
|
||||||
|
|
||||||
|
public IEnumerator<byte> GetEnumerator ()
|
||||||
|
{
|
||||||
|
foreach (var b in ToByteArray ())
|
||||||
|
yield return b;
|
||||||
|
}
|
||||||
|
|
||||||
public void Print (bool dumped)
|
public void Print (bool dumped)
|
||||||
{
|
{
|
||||||
Console.WriteLine (dumped ? dump (this) : print (this));
|
Console.WriteLine (dumped ? dump (this) : print (this));
|
||||||
@ -645,7 +630,7 @@ Extended Payload Length: {7}
|
|||||||
: print (this);
|
: print (this);
|
||||||
}
|
}
|
||||||
|
|
||||||
public byte [] ToByteArray ()
|
public byte[] ToByteArray ()
|
||||||
{
|
{
|
||||||
using (var buff = new MemoryStream ()) {
|
using (var buff = new MemoryStream ()) {
|
||||||
var header = (int) _fin;
|
var header = (int) _fin;
|
||||||
|
@ -157,13 +157,13 @@ namespace WebSocketSharp
|
|||||||
|
|
||||||
internal WebSocketFrame ReadWebSocketFrame ()
|
internal WebSocketFrame ReadWebSocketFrame ()
|
||||||
{
|
{
|
||||||
return WebSocketFrame.Parse (_innerStream, true);
|
return WebSocketFrame.Read (_innerStream, true);
|
||||||
}
|
}
|
||||||
|
|
||||||
internal void ReadWebSocketFrameAsync (
|
internal void ReadWebSocketFrameAsync (
|
||||||
Action<WebSocketFrame> completed, Action<Exception> error)
|
Action<WebSocketFrame> completed, Action<Exception> error)
|
||||||
{
|
{
|
||||||
WebSocketFrame.ParseAsync (_innerStream, true, completed, error);
|
WebSocketFrame.ReadAsync (_innerStream, true, completed, error);
|
||||||
}
|
}
|
||||||
|
|
||||||
internal HttpResponse SendHttpRequest (HttpRequest request, int millisecondsTimeout)
|
internal HttpResponse SendHttpRequest (HttpRequest request, int millisecondsTimeout)
|
||||||
|
Loading…
Reference in New Issue
Block a user