aboutsummaryrefslogtreecommitdiff
path: root/Emby.Server.Implementations/SocketSharp/WebSocketSharpListener.cs
diff options
context:
space:
mode:
authorClaus Vium <clausvium@gmail.com>2019-02-26 15:13:06 +0100
committerClaus Vium <clausvium@gmail.com>2019-02-26 22:11:21 +0100
commitd6c6f3c10cff68b11df884be502c58a17da0d332 (patch)
treedaa3ff89ee2ab5c503abda29c35d84a50a508746 /Emby.Server.Implementations/SocketSharp/WebSocketSharpListener.cs
parent38f52a139e8017ddaaef55e1eb4cc97f1d4d8c04 (diff)
Still broken
Diffstat (limited to 'Emby.Server.Implementations/SocketSharp/WebSocketSharpListener.cs')
-rw-r--r--Emby.Server.Implementations/SocketSharp/WebSocketSharpListener.cs48
1 files changed, 34 insertions, 14 deletions
diff --git a/Emby.Server.Implementations/SocketSharp/WebSocketSharpListener.cs b/Emby.Server.Implementations/SocketSharp/WebSocketSharpListener.cs
index 824c9a822..b64fc0683 100644
--- a/Emby.Server.Implementations/SocketSharp/WebSocketSharpListener.cs
+++ b/Emby.Server.Implementations/SocketSharp/WebSocketSharpListener.cs
@@ -1,6 +1,7 @@
using System;
using System.Collections.Generic;
using System.Net;
+using System.Net.WebSockets;
using System.Threading;
using System.Threading.Tasks;
using Emby.Server.Implementations.HttpServer;
@@ -144,22 +145,41 @@ using Microsoft.Extensions.Logging;
_logger.LogDebug("Web socket connection allowed");
var webSocketContext = await ctx.WebSockets.AcceptWebSocketAsync(null).ConfigureAwait(false);
+ var socket = new SharpWebSocket(webSocketContext, _logger);
+ await socket.ConnectAsServerAsync().ConfigureAwait(false);
- if (WebSocketConnected != null)
+ WebSocketConnected(new WebSocketConnectEventArgs
{
- //SharpWebSocket socket = new SharpWebSocket(webSocketContext, _logger);
- //await socket.ConnectAsServerAsync().ConfigureAwait(false);
-
- //WebSocketConnected(new WebSocketConnectEventArgs
- //{
- // Url = url,
- // QueryString = queryString,
- // WebSocket = socket,
- // Endpoint = endpoint
- //});
-
- //await ReceiveWebSocketAsync(ctx, socket).ConfigureAwait(false);
- }
+ Url = url,
+ QueryString = queryString,
+ WebSocket = socket,
+ Endpoint = endpoint
+ });
+
+ //await ReceiveWebSocketAsync(ctx, socket).ConfigureAwait(false);
+ var buffer = WebSocket.CreateClientBuffer(1024 * 4, 1024 * 4);
+ WebSocketReceiveResult result = await webSocketContext.ReceiveAsync(buffer, CancellationToken.None);
+ socket.OnReceiveBytes(buffer.Array);
+ //while (!result.CloseStatus.HasValue)
+ //{
+ // await webSocketContext.SendAsync(new ArraySegment<byte>(buffer, 0, result.Count), result.MessageType, result.EndOfMessage, CancellationToken.None);
+
+ // result = await webSocketContext.ReceiveAsync(new ArraySegment<byte>(buffer), CancellationToken.None);
+ //}
+ //WebSocketConnected?.Invoke(new WebSocketConnectEventArgs
+ //{
+ // Url = url,
+ // QueryString = queryString,
+ // WebSocket = webSocketContext,
+ // Endpoint = endpoint
+ //});
+ await webSocketContext.CloseAsync(result.CloseStatus.Value, result.CloseStatusDescription, CancellationToken.None);
+ //SharpWebSocket socket = new SharpWebSocket(webSocketContext, _logger);
+ //await socket.ConnectAsServerAsync().ConfigureAwait(false);
+
+
+
+ //await ReceiveWebSocketAsync(ctx, socket).ConfigureAwait(false);
}
else
{