BaseControlHandler.cs 4.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137
  1. using MediaBrowser.Controller.Configuration;
  2. using MediaBrowser.Controller.Dlna;
  3. using MediaBrowser.Dlna.Server;
  4. using MediaBrowser.Model.Logging;
  5. using System;
  6. using System.Collections.Generic;
  7. using System.Linq;
  8. using System.Text;
  9. using System.Xml;
  10. namespace MediaBrowser.Dlna.Service
  11. {
  12. public abstract class BaseControlHandler
  13. {
  14. private const string NS_SOAPENV = "http://schemas.xmlsoap.org/soap/envelope/";
  15. protected readonly IServerConfigurationManager Config;
  16. protected readonly ILogger Logger;
  17. protected BaseControlHandler(IServerConfigurationManager config, ILogger logger)
  18. {
  19. Config = config;
  20. Logger = logger;
  21. }
  22. public ControlResponse ProcessControlRequest(ControlRequest request)
  23. {
  24. try
  25. {
  26. var enableDebugLogging = Config.GetDlnaConfiguration().EnableDebugLog;
  27. if (enableDebugLogging)
  28. {
  29. LogRequest(request);
  30. }
  31. var response = ProcessControlRequestInternal(request);
  32. if (enableDebugLogging)
  33. {
  34. LogResponse(response);
  35. }
  36. return response;
  37. }
  38. catch (Exception ex)
  39. {
  40. Logger.ErrorException("Error processing control request", ex);
  41. return new ControlErrorHandler().GetResponse(ex);
  42. }
  43. }
  44. private ControlResponse ProcessControlRequestInternal(ControlRequest request)
  45. {
  46. var soap = new XmlDocument();
  47. soap.LoadXml(request.InputXml);
  48. var sparams = new Headers();
  49. var body = soap.GetElementsByTagName("Body", NS_SOAPENV).Item(0);
  50. var method = body.FirstChild;
  51. foreach (var p in method.ChildNodes)
  52. {
  53. var e = p as XmlElement;
  54. if (e == null)
  55. {
  56. continue;
  57. }
  58. sparams.Add(e.LocalName, e.InnerText.Trim());
  59. }
  60. Logger.Debug("Received control request {0}", method.LocalName);
  61. var result = GetResult(method.LocalName, sparams);
  62. var env = new XmlDocument();
  63. env.AppendChild(env.CreateXmlDeclaration("1.0", "utf-8", string.Empty));
  64. var envelope = env.CreateElement("SOAP-ENV", "Envelope", NS_SOAPENV);
  65. env.AppendChild(envelope);
  66. envelope.SetAttribute("encodingStyle", NS_SOAPENV, "http://schemas.xmlsoap.org/soap/encoding/");
  67. var rbody = env.CreateElement("SOAP-ENV:Body", NS_SOAPENV);
  68. env.DocumentElement.AppendChild(rbody);
  69. var response = env.CreateElement(String.Format("u:{0}Response", method.LocalName), method.NamespaceURI);
  70. rbody.AppendChild(response);
  71. foreach (var i in result)
  72. {
  73. var ri = env.CreateElement(i.Key);
  74. ri.InnerText = i.Value;
  75. response.AppendChild(ri);
  76. }
  77. var xml = env.OuterXml.Replace("xmlns:m=", "xmlns:u=");
  78. var controlResponse = new ControlResponse
  79. {
  80. Xml = xml,
  81. IsSuccessful = true
  82. };
  83. //Logger.Debug(xml);
  84. controlResponse.Headers.Add("EXT", string.Empty);
  85. return controlResponse;
  86. }
  87. protected abstract IEnumerable<KeyValuePair<string, string>> GetResult(string methodName, Headers methodParams);
  88. private void LogRequest(ControlRequest request)
  89. {
  90. var builder = new StringBuilder();
  91. var headers = string.Join(", ", request.Headers.Select(i => string.Format("{0}={1}", i.Key, i.Value)).ToArray());
  92. builder.AppendFormat("Headers: {0}", headers);
  93. builder.AppendLine();
  94. builder.Append(request.InputXml);
  95. Logger.LogMultiline("Control request", LogSeverity.Debug, builder);
  96. }
  97. private void LogResponse(ControlResponse response)
  98. {
  99. var builder = new StringBuilder();
  100. var headers = string.Join(", ", response.Headers.Select(i => string.Format("{0}={1}", i.Key, i.Value)).ToArray());
  101. builder.AppendFormat("Headers: {0}", headers);
  102. builder.AppendLine();
  103. builder.Append(response.Xml);
  104. Logger.LogMultiline("Control response", LogSeverity.Debug, builder);
  105. }
  106. }
  107. }