WebFetchInvDescModule.cs 6.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168
  1. /*
  2. * Copyright (c) Contributors, http://opensimulator.org/
  3. * See CONTRIBUTORS.TXT for a full list of copyright holders.
  4. *
  5. * Redistribution and use in source and binary forms, with or without
  6. * modification, are permitted provided that the following conditions are met:
  7. * * Redistributions of source code must retain the above copyright
  8. * notice, this list of conditions and the following disclaimer.
  9. * * Redistributions in binary form must reproduce the above copyright
  10. * notice, this list of conditions and the following disclaimer in the
  11. * documentation and/or other materials provided with the distribution.
  12. * * Neither the name of the OpenSimulator Project nor the
  13. * names of its contributors may be used to endorse or promote products
  14. * derived from this software without specific prior written permission.
  15. *
  16. * THIS SOFTWARE IS PROVIDED BY THE DEVELOPERS ``AS IS'' AND ANY
  17. * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
  18. * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
  19. * DISCLAIMED. IN NO EVENT SHALL THE CONTRIBUTORS BE LIABLE FOR ANY
  20. * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
  21. * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
  22. * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
  23. * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
  24. * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
  25. * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
  26. */
  27. using System;
  28. using System.Collections;
  29. using System.Reflection;
  30. using log4net;
  31. using Nini.Config;
  32. using Mono.Addins;
  33. using OpenMetaverse;
  34. using OpenSim.Framework;
  35. using OpenSim.Framework.Servers.HttpServer;
  36. using OpenSim.Region.Framework.Interfaces;
  37. using OpenSim.Region.Framework.Scenes;
  38. using OpenSim.Services.Interfaces;
  39. using Caps = OpenSim.Framework.Capabilities.Caps;
  40. using OpenSim.Capabilities.Handlers;
  41. namespace OpenSim.Region.ClientStack.Linden
  42. {
  43. /// <summary>
  44. /// This module implements both WebFetchInventoryDescendents and FetchInventoryDescendents2 capabilities.
  45. /// </summary>
  46. [Extension(Path = "/OpenSim/RegionModules", NodeName = "RegionModule", Id = "WebFetchInvDescModule")]
  47. public class WebFetchInvDescModule : INonSharedRegionModule
  48. {
  49. // private static readonly ILog m_log = LogManager.GetLogger(MethodBase.GetCurrentMethod().DeclaringType);
  50. private Scene m_scene;
  51. private IInventoryService m_InventoryService;
  52. private ILibraryService m_LibraryService;
  53. private bool m_Enabled;
  54. private string m_fetchInventoryDescendents2Url;
  55. private string m_webFetchInventoryDescendentsUrl;
  56. private WebFetchInvDescHandler m_webFetchHandler;
  57. #region ISharedRegionModule Members
  58. public void Initialise(IConfigSource source)
  59. {
  60. IConfig config = source.Configs["ClientStack.LindenCaps"];
  61. if (config == null)
  62. return;
  63. m_fetchInventoryDescendents2Url = config.GetString("Cap_FetchInventoryDescendents2", string.Empty);
  64. m_webFetchInventoryDescendentsUrl = config.GetString("Cap_WebFetchInventoryDescendents", string.Empty);
  65. if (m_fetchInventoryDescendents2Url != string.Empty || m_webFetchInventoryDescendentsUrl != string.Empty)
  66. {
  67. m_Enabled = true;
  68. }
  69. }
  70. public void AddRegion(Scene s)
  71. {
  72. if (!m_Enabled)
  73. return;
  74. m_scene = s;
  75. }
  76. public void RemoveRegion(Scene s)
  77. {
  78. if (!m_Enabled)
  79. return;
  80. m_scene.EventManager.OnRegisterCaps -= RegisterCaps;
  81. m_scene = null;
  82. }
  83. public void RegionLoaded(Scene s)
  84. {
  85. if (!m_Enabled)
  86. return;
  87. m_InventoryService = m_scene.InventoryService;
  88. m_LibraryService = m_scene.LibraryService;
  89. // We'll reuse the same handler for all requests.
  90. if (m_fetchInventoryDescendents2Url == "localhost" || m_webFetchInventoryDescendentsUrl == "localhost")
  91. m_webFetchHandler = new WebFetchInvDescHandler(m_InventoryService, m_LibraryService);
  92. m_scene.EventManager.OnRegisterCaps += RegisterCaps;
  93. }
  94. public void PostInitialise()
  95. {
  96. }
  97. public void Close() { }
  98. public string Name { get { return "WebFetchInvDescModule"; } }
  99. public Type ReplaceableInterface
  100. {
  101. get { return null; }
  102. }
  103. #endregion
  104. private void RegisterCaps(UUID agentID, Caps caps)
  105. {
  106. if (m_webFetchInventoryDescendentsUrl != "")
  107. RegisterFetchCap(agentID, caps, "WebFetchInventoryDescendents", m_webFetchInventoryDescendentsUrl);
  108. if (m_fetchInventoryDescendents2Url != "")
  109. RegisterFetchCap(agentID, caps, "FetchInventoryDescendents2", m_fetchInventoryDescendents2Url);
  110. }
  111. private void RegisterFetchCap(UUID agentID, Caps caps, string capName, string url)
  112. {
  113. string capUrl;
  114. if (url == "localhost")
  115. {
  116. capUrl = "/CAPS/" + UUID.Random();
  117. IRequestHandler reqHandler
  118. = new RestStreamHandler(
  119. "POST",
  120. capUrl,
  121. m_webFetchHandler.FetchInventoryDescendentsRequest,
  122. "FetchInventoryDescendents2",
  123. agentID.ToString());
  124. caps.RegisterHandler(capName, reqHandler);
  125. }
  126. else
  127. {
  128. capUrl = url;
  129. caps.RegisterHandler(capName, capUrl);
  130. }
  131. // m_log.DebugFormat(
  132. // "[WEB FETCH INV DESC MODULE]: Registered capability {0} at {1} in region {2} for {3}",
  133. // capName, capUrl, m_scene.RegionInfo.RegionName, agentID);
  134. }
  135. }
  136. }