aboutsummaryrefslogtreecommitdiff
path: root/Emby.Server.Implementations/HttpServer
diff options
context:
space:
mode:
authorCody Robibero <cody@robibe.ro>2023-07-02 16:14:44 -0600
committerGitHub <noreply@github.com>2023-07-02 16:14:44 -0600
commit52252fcd554a7ac1105374ca6d1b440787820f0a (patch)
treed7dd8598fd04dddd3a180e146bb222810a6fd4c0 /Emby.Server.Implementations/HttpServer
parentba8f4757fd1323ab017c3dbf1c9143b256ff428a (diff)
Fix sending websocket messages (#9948)
Diffstat (limited to 'Emby.Server.Implementations/HttpServer')
-rw-r--r--Emby.Server.Implementations/HttpServer/WebSocketConnection.cs32
1 files changed, 9 insertions, 23 deletions
diff --git a/Emby.Server.Implementations/HttpServer/WebSocketConnection.cs b/Emby.Server.Implementations/HttpServer/WebSocketConnection.cs
index af79c18c4..fd7653a32 100644
--- a/Emby.Server.Implementations/HttpServer/WebSocketConnection.cs
+++ b/Emby.Server.Implementations/HttpServer/WebSocketConnection.cs
@@ -10,6 +10,7 @@ using System.Threading.Tasks;
using Jellyfin.Extensions.Json;
using MediaBrowser.Controller.Net;
using MediaBrowser.Controller.Net.WebSocketMessages;
+using MediaBrowser.Controller.Net.WebSocketMessages.Outbound;
using MediaBrowser.Model.Session;
using Microsoft.Extensions.Logging;
@@ -85,26 +86,15 @@ namespace Emby.Server.Implementations.HttpServer
/// <value>The state.</value>
public WebSocketState State => _socket.State;
- /// <summary>
- /// Sends a message asynchronously.
- /// </summary>
- /// <param name="message">The message.</param>
- /// <param name="cancellationToken">The cancellation token.</param>
- /// <returns>Task.</returns>
- public Task SendAsync(WebSocketMessage message, CancellationToken cancellationToken)
+ /// <inheritdoc />
+ public Task SendAsync(OutboundWebSocketMessage message, CancellationToken cancellationToken)
{
var json = JsonSerializer.SerializeToUtf8Bytes(message, _jsonOptions);
return _socket.SendAsync(json, WebSocketMessageType.Text, true, cancellationToken);
}
- /// <summary>
- /// Sends a message asynchronously.
- /// </summary>
- /// <typeparam name="T">The type of the message.</typeparam>
- /// <param name="message">The message.</param>
- /// <param name="cancellationToken">The cancellation token.</param>
- /// <returns>Task.</returns>
- public Task SendAsync<T>(WebSocketMessage<T> message, CancellationToken cancellationToken)
+ /// <inheritdoc />
+ public Task SendAsync<T>(OutboundWebSocketMessage<T> message, CancellationToken cancellationToken)
{
var json = JsonSerializer.SerializeToUtf8Bytes(message, _jsonOptions);
return _socket.SendAsync(json, WebSocketMessageType.Text, true, cancellationToken);
@@ -183,7 +173,7 @@ namespace Emby.Server.Implementations.HttpServer
return;
}
- WebSocketMessage<object>? stub;
+ InboundWebSocketMessage<object>? stub;
long bytesConsumed;
try
{
@@ -224,10 +214,10 @@ namespace Emby.Server.Implementations.HttpServer
}
}
- internal WebSocketMessage<object>? DeserializeWebSocketMessage(ReadOnlySequence<byte> bytes, out long bytesConsumed)
+ internal InboundWebSocketMessage<object>? DeserializeWebSocketMessage(ReadOnlySequence<byte> bytes, out long bytesConsumed)
{
var jsonReader = new Utf8JsonReader(bytes);
- var ret = JsonSerializer.Deserialize<WebSocketMessage<object>>(ref jsonReader, _jsonOptions);
+ var ret = JsonSerializer.Deserialize<InboundWebSocketMessage<object>>(ref jsonReader, _jsonOptions);
bytesConsumed = jsonReader.BytesConsumed;
return ret;
}
@@ -236,11 +226,7 @@ namespace Emby.Server.Implementations.HttpServer
{
LastKeepAliveDate = DateTime.UtcNow;
return SendAsync(
- new OutboundWebSocketMessage
- {
- MessageId = Guid.NewGuid(),
- MessageType = SessionMessageType.KeepAlive
- },
+ new OutboundKeepAliveMessage(),
CancellationToken.None);
}