aboutsummaryrefslogtreecommitdiff
path: root/Emby.Dlna/ConnectionManager/ConnectionManagerService.cs
diff options
context:
space:
mode:
authorcrobibero <cody@robibe.ro>2020-09-01 18:24:42 -0600
committercrobibero <cody@robibe.ro>2020-09-01 18:24:42 -0600
commitf443c534bfac9feea4c92033e85a9aa5097ec4f5 (patch)
tree6d0bcffc442c283f999232c54536c9d774a6f672 /Emby.Dlna/ConnectionManager/ConnectionManagerService.cs
parent852213d90cd6fe3c4e7b6922ca1f8162bc34c55e (diff)
parent506fc7cbaeb8f82716f84b125ac598ff740bf552 (diff)
Merge remote-tracking branch 'upstream/master' into package-install-repo
Diffstat (limited to 'Emby.Dlna/ConnectionManager/ConnectionManagerService.cs')
-rw-r--r--Emby.Dlna/ConnectionManager/ConnectionManagerService.cs43
1 files changed, 43 insertions, 0 deletions
diff --git a/Emby.Dlna/ConnectionManager/ConnectionManagerService.cs b/Emby.Dlna/ConnectionManager/ConnectionManagerService.cs
new file mode 100644
index 000000000..12338e2b4
--- /dev/null
+++ b/Emby.Dlna/ConnectionManager/ConnectionManagerService.cs
@@ -0,0 +1,43 @@
+#pragma warning disable CS1591
+
+using System.Threading.Tasks;
+using Emby.Dlna.Service;
+using MediaBrowser.Common.Net;
+using MediaBrowser.Controller.Configuration;
+using MediaBrowser.Controller.Dlna;
+using Microsoft.Extensions.Logging;
+
+namespace Emby.Dlna.ConnectionManager
+{
+ public class ConnectionManagerService : BaseService, IConnectionManager
+ {
+ private readonly IDlnaManager _dlna;
+ private readonly IServerConfigurationManager _config;
+
+ public ConnectionManagerService(
+ IDlnaManager dlna,
+ IServerConfigurationManager config,
+ ILogger<ConnectionManagerService> logger,
+ IHttpClient httpClient)
+ : base(logger, httpClient)
+ {
+ _dlna = dlna;
+ _config = config;
+ }
+
+ /// <inheritdoc />
+ public string GetServiceXml()
+ {
+ return new ConnectionManagerXmlBuilder().GetXml();
+ }
+
+ /// <inheritdoc />
+ public Task<ControlResponse> ProcessControlRequestAsync(ControlRequest request)
+ {
+ var profile = _dlna.GetProfile(request.Headers) ??
+ _dlna.GetDefaultProfile();
+
+ return new ControlHandler(_config, Logger, profile).ProcessControlRequestAsync(request);
+ }
+ }
+}