mirror of
				https://github.com/jellyfin/jellyfin.git
				synced 2025-11-03 19:17:24 -05:00 
			
		
		
		
	
		
			
				
	
	
		
			80 lines
		
	
	
		
			2.2 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
			
		
		
	
	
			80 lines
		
	
	
		
			2.2 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
using System;
 | 
						|
using System.Text;
 | 
						|
 | 
						|
namespace SocketHttpListener
 | 
						|
{
 | 
						|
    /// <summary>
 | 
						|
    /// Contains the event data associated with a <see cref="WebSocket.OnClose"/> event.
 | 
						|
    /// </summary>
 | 
						|
    /// <remarks>
 | 
						|
    /// A <see cref="WebSocket.OnClose"/> event occurs when the WebSocket connection has been closed.
 | 
						|
    /// If you would like to get the reason for the close, you should access the <see cref="Code"/> or
 | 
						|
    /// <see cref="Reason"/> property.
 | 
						|
    /// </remarks>
 | 
						|
    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
 | 
						|
 | 
						|
        /// <summary>
 | 
						|
        /// Gets the status code for the close.
 | 
						|
        /// </summary>
 | 
						|
        /// <value>
 | 
						|
        /// A <see cref="ushort"/> that represents the status code for the close if any.
 | 
						|
        /// </value>
 | 
						|
        public ushort Code => _code;
 | 
						|
 | 
						|
        /// <summary>
 | 
						|
        /// Gets the reason for the close.
 | 
						|
        /// </summary>
 | 
						|
        /// <value>
 | 
						|
        /// A <see cref="string"/> that represents the reason for the close if any.
 | 
						|
        /// </value>
 | 
						|
        public string Reason => _reason;
 | 
						|
 | 
						|
        /// <summary>
 | 
						|
        /// Gets a value indicating whether the WebSocket connection has been closed cleanly.
 | 
						|
        /// </summary>
 | 
						|
        /// <value>
 | 
						|
        /// <c>true</c> if the WebSocket connection has been closed cleanly; otherwise, <c>false</c>.
 | 
						|
        /// </value>
 | 
						|
        public bool WasClean
 | 
						|
        {
 | 
						|
            get => _clean;
 | 
						|
 | 
						|
            internal set => _clean = value;
 | 
						|
        }
 | 
						|
 | 
						|
        #endregion
 | 
						|
    }
 | 
						|
}
 |