BaseControlHandler.cs 4.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135
  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. if (Config.GetDlnaConfiguration().EnableDebugLogging)
  27. {
  28. LogRequest(request);
  29. }
  30. var response = ProcessControlRequestInternal(request);
  31. if (Config.GetDlnaConfiguration().EnableDebugLogging)
  32. {
  33. LogResponse(response);
  34. }
  35. return response;
  36. }
  37. catch (Exception ex)
  38. {
  39. Logger.ErrorException("Error processing control request", ex);
  40. return new ControlErrorHandler().GetResponse(ex);
  41. }
  42. }
  43. private ControlResponse ProcessControlRequestInternal(ControlRequest request)
  44. {
  45. var soap = new XmlDocument();
  46. soap.LoadXml(request.InputXml);
  47. var sparams = new Headers();
  48. var body = soap.GetElementsByTagName("Body", NS_SOAPENV).Item(0);
  49. var method = body.FirstChild;
  50. foreach (var p in method.ChildNodes)
  51. {
  52. var e = p as XmlElement;
  53. if (e == null)
  54. {
  55. continue;
  56. }
  57. sparams.Add(e.LocalName, e.InnerText.Trim());
  58. }
  59. Logger.Debug("Received control request {0}", method.LocalName);
  60. var result = GetResult(method.LocalName, sparams);
  61. var env = new XmlDocument();
  62. env.AppendChild(env.CreateXmlDeclaration("1.0", "utf-8", string.Empty));
  63. var envelope = env.CreateElement("SOAP-ENV", "Envelope", NS_SOAPENV);
  64. env.AppendChild(envelope);
  65. envelope.SetAttribute("encodingStyle", NS_SOAPENV, "http://schemas.xmlsoap.org/soap/encoding/");
  66. var rbody = env.CreateElement("SOAP-ENV:Body", NS_SOAPENV);
  67. env.DocumentElement.AppendChild(rbody);
  68. var response = env.CreateElement(String.Format("u:{0}Response", method.LocalName), method.NamespaceURI);
  69. rbody.AppendChild(response);
  70. foreach (var i in result)
  71. {
  72. var ri = env.CreateElement(i.Key);
  73. ri.InnerText = i.Value;
  74. response.AppendChild(ri);
  75. }
  76. var xml = env.OuterXml.Replace("xmlns:m=", "xmlns:u=");
  77. var controlResponse = new ControlResponse
  78. {
  79. Xml = xml,
  80. IsSuccessful = true
  81. };
  82. //Logger.Debug(xml);
  83. controlResponse.Headers.Add("EXT", string.Empty);
  84. return controlResponse;
  85. }
  86. protected abstract IEnumerable<KeyValuePair<string, string>> GetResult(string methodName, Headers methodParams);
  87. private void LogRequest(ControlRequest request)
  88. {
  89. var builder = new StringBuilder();
  90. var headers = string.Join(", ", request.Headers.Select(i => string.Format("{0}={1}", i.Key, i.Value)).ToArray());
  91. builder.AppendFormat("Headers: {0}", headers);
  92. builder.AppendLine();
  93. builder.Append(request.InputXml);
  94. Logger.LogMultiline("Control request", LogSeverity.Debug, builder);
  95. }
  96. private void LogResponse(ControlResponse response)
  97. {
  98. var builder = new StringBuilder();
  99. var headers = string.Join(", ", response.Headers.Select(i => string.Format("{0}={1}", i.Key, i.Value)).ToArray());
  100. builder.AppendFormat("Headers: {0}", headers);
  101. builder.AppendLine();
  102. builder.Append(response.Xml);
  103. Logger.LogMultiline("Control response", LogSeverity.Debug, builder);
  104. }
  105. }
  106. }