using System; using System.Text; namespace SocketHttpListener { /// /// Contains the event data associated with a event. /// /// /// A event occurs when the WebSocket connection has been closed. /// If you would like to get the reason for the close, you should access the or /// property. /// public class CloseEventArgs : EventArgs { #region Private Fields private bool _clean; private ushort _code; private string _reason; #endregion #region Internal Constructors internal CloseEventArgs(PayloadData payload) { var data = payload.ApplicationData; var len = data.Length; _code = len > 1 ? data.SubArray(0, 2).ToUInt16(ByteOrder.Big) : (ushort)CloseStatusCode.NoStatusCode; _reason = len > 2 ? GetUtf8String(data.SubArray(2, len - 2)) : string.Empty; } private static string GetUtf8String(byte[] bytes) { return Encoding.UTF8.GetString(bytes, 0, bytes.Length); } #endregion #region Public Properties /// /// Gets the status code for the close. /// /// /// A that represents the status code for the close if any. /// public ushort Code => _code; /// /// Gets the reason for the close. /// /// /// A that represents the reason for the close if any. /// public string Reason => _reason; /// /// Gets a value indicating whether the WebSocket connection has been closed cleanly. /// /// /// true if the WebSocket connection has been closed cleanly; otherwise, false. /// public bool WasClean { get => _clean; internal set => _clean = value; } #endregion } }