2010-08-13 22:28:28 +00:00
|
|
|
/*
|
2009-04-05 02:51:10 +00:00
|
|
|
* Copyright (c) Contributors, http://opensimulator.org/
|
2008-11-25 16:00:55 +00:00
|
|
|
* See CONTRIBUTORS.TXT for a full list of copyright holders.
|
2009-04-05 02:51:10 +00:00
|
|
|
*
|
|
|
|
* Redistribution and use in source and binary forms, with or without
|
|
|
|
* modification, are permitted provided that the following conditions are met:
|
|
|
|
* * Redistributions of source code must retain the above copyright
|
|
|
|
* notice, this list of conditions and the following disclaimer.
|
|
|
|
* * Redistributions in binary form must reproduce the above copyright
|
|
|
|
* notice, this list of conditions and the following disclaimer in the
|
|
|
|
* documentation and/or other materials provided with the distribution.
|
2009-06-01 06:37:14 +00:00
|
|
|
* * Neither the name of the OpenSimulator Project nor the
|
2009-04-05 02:51:10 +00:00
|
|
|
* names of its contributors may be used to endorse or promote products
|
|
|
|
* derived from this software without specific prior written permission.
|
|
|
|
*
|
|
|
|
* THIS SOFTWARE IS PROVIDED BY THE DEVELOPERS ``AS IS'' AND ANY
|
|
|
|
* EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
|
|
|
|
* WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
|
|
|
|
* DISCLAIMED. IN NO EVENT SHALL THE CONTRIBUTORS BE LIABLE FOR ANY
|
|
|
|
* DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
|
|
|
|
* (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
|
|
|
|
* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
|
|
|
|
* ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
|
|
|
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
|
|
|
|
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
2008-11-25 16:00:55 +00:00
|
|
|
*/
|
|
|
|
|
2010-01-30 17:23:07 +00:00
|
|
|
using System;
|
|
|
|
using System.Collections.Generic;
|
2008-11-25 16:00:55 +00:00
|
|
|
using System.Reflection;
|
2010-01-11 15:51:33 +00:00
|
|
|
|
2010-01-30 17:23:07 +00:00
|
|
|
using OpenSim.Framework;
|
2012-04-07 03:34:31 +00:00
|
|
|
using OpenSim.Framework.Client;
|
2009-10-13 00:00:01 +00:00
|
|
|
using OpenSim.Region.Framework.Interfaces;
|
2010-01-30 17:23:07 +00:00
|
|
|
using OpenSim.Region.Framework.Scenes;
|
|
|
|
using OpenSim.Services.Connectors.Hypergrid;
|
2010-01-10 18:40:07 +00:00
|
|
|
using OpenSim.Services.Interfaces;
|
2010-01-30 17:23:07 +00:00
|
|
|
using OpenSim.Server.Base;
|
|
|
|
|
|
|
|
using GridRegion = OpenSim.Services.Interfaces.GridRegion;
|
2008-11-25 16:00:55 +00:00
|
|
|
|
2010-01-30 17:23:07 +00:00
|
|
|
using OpenMetaverse;
|
|
|
|
using log4net;
|
|
|
|
using Nini.Config;
|
|
|
|
|
|
|
|
namespace OpenSim.Region.CoreModules.Framework.InventoryAccess
|
2008-11-25 16:00:55 +00:00
|
|
|
{
|
2010-02-24 16:03:30 +00:00
|
|
|
public class HGInventoryAccessModule : BasicInventoryAccessModule, INonSharedRegionModule, IInventoryAccessModule
|
2008-11-25 16:00:55 +00:00
|
|
|
{
|
|
|
|
private static readonly ILog m_log = LogManager.GetLogger(MethodBase.GetCurrentMethod().DeclaringType);
|
|
|
|
|
2010-01-30 17:23:07 +00:00
|
|
|
private static HGAssetMapper m_assMapper;
|
|
|
|
public static HGAssetMapper AssetMapper
|
2009-10-13 00:00:01 +00:00
|
|
|
{
|
|
|
|
get { return m_assMapper; }
|
|
|
|
}
|
|
|
|
|
2012-01-12 17:56:35 +00:00
|
|
|
private string m_HomeURI;
|
2011-02-05 01:05:45 +00:00
|
|
|
private bool m_OutboundPermission;
|
2011-06-03 16:04:34 +00:00
|
|
|
private string m_ThisGatekeeper;
|
2012-04-07 03:34:31 +00:00
|
|
|
private bool m_RestrictInventoryAccessAbroad;
|
2010-11-27 06:06:34 +00:00
|
|
|
|
2010-08-13 22:28:28 +00:00
|
|
|
// private bool m_Initialized = false;
|
2010-01-30 17:23:07 +00:00
|
|
|
|
|
|
|
#region INonSharedRegionModule
|
|
|
|
|
|
|
|
public override string Name
|
|
|
|
{
|
|
|
|
get { return "HGInventoryAccessModule"; }
|
|
|
|
}
|
|
|
|
|
|
|
|
public override void Initialise(IConfigSource source)
|
2009-10-13 00:00:01 +00:00
|
|
|
{
|
2010-01-30 17:23:07 +00:00
|
|
|
IConfig moduleConfig = source.Configs["Modules"];
|
|
|
|
if (moduleConfig != null)
|
2009-10-13 00:00:01 +00:00
|
|
|
{
|
2010-01-30 17:23:07 +00:00
|
|
|
string name = moduleConfig.GetString("InventoryAccessModule", "");
|
|
|
|
if (name == Name)
|
|
|
|
{
|
|
|
|
m_Enabled = true;
|
2011-04-18 19:03:53 +00:00
|
|
|
|
|
|
|
InitialiseCommon(source);
|
|
|
|
|
2010-01-30 17:23:07 +00:00
|
|
|
m_log.InfoFormat("[HG INVENTORY ACCESS MODULE]: {0} enabled.", Name);
|
2010-11-27 06:06:34 +00:00
|
|
|
|
|
|
|
IConfig thisModuleConfig = source.Configs["HGInventoryAccessModule"];
|
|
|
|
if (thisModuleConfig != null)
|
2011-02-05 01:05:45 +00:00
|
|
|
{
|
2012-01-12 17:56:35 +00:00
|
|
|
// legacy configuration [obsolete]
|
|
|
|
m_HomeURI = thisModuleConfig.GetString("ProfileServerURI", string.Empty);
|
|
|
|
// preferred
|
|
|
|
m_HomeURI = thisModuleConfig.GetString("HomeURI", m_HomeURI);
|
2011-02-05 01:05:45 +00:00
|
|
|
m_OutboundPermission = thisModuleConfig.GetBoolean("OutboundPermission", true);
|
2011-06-03 16:04:34 +00:00
|
|
|
m_ThisGatekeeper = thisModuleConfig.GetString("Gatekeeper", string.Empty);
|
2012-11-02 15:05:56 +00:00
|
|
|
m_RestrictInventoryAccessAbroad = thisModuleConfig.GetBoolean("RestrictInventoryAccessAbroad", true);
|
2011-02-05 01:05:45 +00:00
|
|
|
}
|
2010-11-27 06:06:34 +00:00
|
|
|
else
|
|
|
|
m_log.Warn("[HG INVENTORY ACCESS MODULE]: HGInventoryAccessModule configs not found. ProfileServerURI not set!");
|
2010-01-30 17:23:07 +00:00
|
|
|
}
|
2009-10-13 00:00:01 +00:00
|
|
|
}
|
|
|
|
}
|
2008-11-25 16:00:55 +00:00
|
|
|
|
2010-01-30 17:23:07 +00:00
|
|
|
public override void AddRegion(Scene scene)
|
2008-11-25 16:00:55 +00:00
|
|
|
{
|
2010-01-30 17:23:07 +00:00
|
|
|
if (!m_Enabled)
|
|
|
|
return;
|
|
|
|
|
|
|
|
base.AddRegion(scene);
|
2012-01-12 17:56:35 +00:00
|
|
|
m_assMapper = new HGAssetMapper(scene, m_HomeURI);
|
2010-01-30 17:23:07 +00:00
|
|
|
scene.EventManager.OnNewInventoryItemUploadComplete += UploadInventoryItem;
|
2012-04-07 03:34:31 +00:00
|
|
|
scene.EventManager.OnTeleportStart += TeleportStart;
|
|
|
|
scene.EventManager.OnTeleportFail += TeleportFail;
|
2008-11-25 16:00:55 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
#endregion
|
|
|
|
|
|
|
|
#region Event handlers
|
|
|
|
|
2012-04-07 03:34:31 +00:00
|
|
|
protected override void OnNewClient(IClientAPI client)
|
|
|
|
{
|
|
|
|
base.OnNewClient(client);
|
|
|
|
client.OnCompleteMovementToRegion += new Action<IClientAPI, bool>(OnCompleteMovementToRegion);
|
|
|
|
}
|
|
|
|
|
|
|
|
protected void OnCompleteMovementToRegion(IClientAPI client, bool arg2)
|
|
|
|
{
|
|
|
|
//m_log.DebugFormat("[HG INVENTORY ACCESS MODULE]: OnCompleteMovementToRegion of user {0}", client.Name);
|
|
|
|
object sp = null;
|
|
|
|
if (client.Scene.TryGetScenePresence(client.AgentId, out sp))
|
|
|
|
{
|
|
|
|
if (sp is ScenePresence)
|
|
|
|
{
|
|
|
|
AgentCircuitData aCircuit = ((ScenePresence)sp).Scene.AuthenticateHandler.GetAgentCircuitData(client.AgentId);
|
|
|
|
if ((aCircuit.teleportFlags & (uint)Constants.TeleportFlags.ViaHGLogin) != 0)
|
|
|
|
{
|
|
|
|
if (m_RestrictInventoryAccessAbroad)
|
|
|
|
{
|
|
|
|
IUserManagement uMan = m_Scene.RequestModuleInterface<IUserManagement>();
|
|
|
|
if (uMan.IsLocalGridUser(client.AgentId))
|
|
|
|
ProcessInventoryForComingHome(client);
|
|
|
|
else
|
|
|
|
ProcessInventoryForArriving(client);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
protected void TeleportStart(IClientAPI client, GridRegion destination, GridRegion finalDestination, uint teleportFlags, bool gridLogout)
|
|
|
|
{
|
|
|
|
if (gridLogout && m_RestrictInventoryAccessAbroad)
|
|
|
|
{
|
|
|
|
IUserManagement uMan = m_Scene.RequestModuleInterface<IUserManagement>();
|
|
|
|
if (uMan != null && uMan.IsLocalGridUser(client.AgentId))
|
|
|
|
{
|
|
|
|
// local grid user
|
|
|
|
ProcessInventoryForHypergriding(client);
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
// Foreigner
|
|
|
|
ProcessInventoryForLeaving(client);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
protected void TeleportFail(IClientAPI client, bool gridLogout)
|
|
|
|
{
|
|
|
|
if (gridLogout && m_RestrictInventoryAccessAbroad)
|
|
|
|
{
|
|
|
|
IUserManagement uMan = m_Scene.RequestModuleInterface<IUserManagement>();
|
|
|
|
if (uMan.IsLocalGridUser(client.AgentId))
|
|
|
|
{
|
|
|
|
ProcessInventoryForComingHome(client);
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
ProcessInventoryForArriving(client);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2008-11-25 16:00:55 +00:00
|
|
|
public void UploadInventoryItem(UUID avatarID, UUID assetID, string name, int userlevel)
|
|
|
|
{
|
2010-01-30 17:23:07 +00:00
|
|
|
string userAssetServer = string.Empty;
|
2011-05-24 16:38:03 +00:00
|
|
|
if (IsForeignUser(avatarID, out userAssetServer) && userAssetServer != string.Empty && m_OutboundPermission)
|
2008-11-25 16:00:55 +00:00
|
|
|
{
|
2012-02-26 05:00:19 +00:00
|
|
|
m_assMapper.Post(assetID, avatarID, userAssetServer);
|
2008-11-25 16:00:55 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
#endregion
|
|
|
|
|
2010-01-30 17:23:07 +00:00
|
|
|
#region Overrides of Basic Inventory Access methods
|
2011-06-03 16:04:34 +00:00
|
|
|
|
2011-06-03 18:48:24 +00:00
|
|
|
protected override string GenerateLandmark(ScenePresence presence, out string prefix, out string suffix)
|
2011-06-03 16:04:34 +00:00
|
|
|
{
|
2011-12-30 00:12:06 +00:00
|
|
|
if (UserManagementModule != null && !UserManagementModule.IsLocalGridUser(presence.UUID))
|
2011-06-03 18:48:24 +00:00
|
|
|
prefix = "HG ";
|
|
|
|
else
|
|
|
|
prefix = string.Empty;
|
2011-06-03 16:04:34 +00:00
|
|
|
suffix = " @ " + m_ThisGatekeeper;
|
|
|
|
Vector3 pos = presence.AbsolutePosition;
|
2011-06-03 17:26:58 +00:00
|
|
|
return String.Format("Landmark version 2\nregion_id {0}\nlocal_pos {1} {2} {3}\nregion_handle {4}\ngatekeeper {5}\n",
|
2011-06-03 16:04:34 +00:00
|
|
|
presence.Scene.RegionInfo.RegionID,
|
|
|
|
pos.X, pos.Y, pos.Z,
|
|
|
|
presence.RegionHandle,
|
|
|
|
m_ThisGatekeeper);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2008-11-25 16:00:55 +00:00
|
|
|
///
|
|
|
|
/// CapsUpdateInventoryItemAsset
|
|
|
|
///
|
|
|
|
public override UUID CapsUpdateInventoryItemAsset(IClientAPI remoteClient, UUID itemID, byte[] data)
|
|
|
|
{
|
|
|
|
UUID newAssetID = base.CapsUpdateInventoryItemAsset(remoteClient, itemID, data);
|
|
|
|
|
|
|
|
UploadInventoryItem(remoteClient.AgentId, newAssetID, "", 0);
|
|
|
|
|
|
|
|
return newAssetID;
|
|
|
|
}
|
|
|
|
|
|
|
|
///
|
2011-04-15 23:42:40 +00:00
|
|
|
/// Used in DeleteToInventory
|
2008-11-25 16:00:55 +00:00
|
|
|
///
|
2011-04-15 23:42:40 +00:00
|
|
|
protected override void ExportAsset(UUID agentID, UUID assetID)
|
2008-11-25 16:00:55 +00:00
|
|
|
{
|
|
|
|
if (!assetID.Equals(UUID.Zero))
|
2011-04-15 23:42:40 +00:00
|
|
|
UploadInventoryItem(agentID, assetID, "", 0);
|
2008-11-25 16:00:55 +00:00
|
|
|
else
|
|
|
|
m_log.Debug("[HGScene]: Scene.Inventory did not create asset");
|
|
|
|
}
|
|
|
|
|
|
|
|
///
|
|
|
|
/// RezObject
|
|
|
|
///
|
|
|
|
public override SceneObjectGroup RezObject(IClientAPI remoteClient, UUID itemID, Vector3 RayEnd, Vector3 RayStart,
|
|
|
|
UUID RayTargetID, byte BypassRayCast, bool RayEndIsIntersection,
|
|
|
|
bool RezSelected, bool RemoveItem, UUID fromTaskID, bool attachment)
|
|
|
|
{
|
2009-09-05 05:30:30 +00:00
|
|
|
m_log.DebugFormat("[HGScene] RezObject itemID={0} fromTaskID={1}", itemID, fromTaskID);
|
|
|
|
|
|
|
|
//if (fromTaskID.Equals(UUID.Zero))
|
|
|
|
//{
|
|
|
|
InventoryItemBase item = new InventoryItemBase(itemID);
|
|
|
|
item.Owner = remoteClient.AgentId;
|
2010-01-30 17:23:07 +00:00
|
|
|
item = m_Scene.InventoryService.GetItem(item);
|
2009-09-05 05:30:30 +00:00
|
|
|
//if (item == null)
|
|
|
|
//{ // Fetch the item
|
|
|
|
// item = new InventoryItemBase();
|
|
|
|
// item.Owner = remoteClient.AgentId;
|
|
|
|
// item.ID = itemID;
|
|
|
|
// item = m_assMapper.Get(item, userInfo.RootFolder.ID, userInfo);
|
|
|
|
//}
|
2010-01-30 17:23:07 +00:00
|
|
|
string userAssetServer = string.Empty;
|
|
|
|
if (item != null && IsForeignUser(remoteClient.AgentId, out userAssetServer))
|
2008-11-25 16:00:55 +00:00
|
|
|
{
|
2010-01-30 17:23:07 +00:00
|
|
|
m_assMapper.Get(item.AssetID, remoteClient.AgentId, userAssetServer);
|
2009-09-05 05:30:30 +00:00
|
|
|
|
2008-11-25 16:00:55 +00:00
|
|
|
}
|
2009-09-05 05:30:30 +00:00
|
|
|
//}
|
2008-11-25 16:00:55 +00:00
|
|
|
|
|
|
|
// OK, we're done fetching. Pass it up to the default RezObject
|
2012-09-22 21:41:19 +00:00
|
|
|
SceneObjectGroup sog = base.RezObject(remoteClient, itemID, RayEnd, RayStart, RayTargetID, BypassRayCast, RayEndIsIntersection,
|
|
|
|
RezSelected, RemoveItem, fromTaskID, attachment);
|
|
|
|
|
|
|
|
if (sog == null)
|
|
|
|
remoteClient.SendAgentAlertMessage("Unable to rez: problem accessing inventory or locating assets", false);
|
|
|
|
|
|
|
|
return sog;
|
2008-11-25 16:00:55 +00:00
|
|
|
|
|
|
|
}
|
|
|
|
|
2010-01-30 17:23:07 +00:00
|
|
|
public override void TransferInventoryAssets(InventoryItemBase item, UUID sender, UUID receiver)
|
2009-10-13 00:00:01 +00:00
|
|
|
{
|
2010-01-30 17:23:07 +00:00
|
|
|
string userAssetServer = string.Empty;
|
2011-05-24 16:38:03 +00:00
|
|
|
if (IsForeignUser(sender, out userAssetServer) && userAssetServer != string.Empty)
|
2010-01-30 17:23:07 +00:00
|
|
|
m_assMapper.Get(item.AssetID, sender, userAssetServer);
|
2009-10-13 00:00:01 +00:00
|
|
|
|
2011-05-24 16:38:03 +00:00
|
|
|
if (IsForeignUser(receiver, out userAssetServer) && userAssetServer != string.Empty && m_OutboundPermission)
|
2012-03-09 17:48:12 +00:00
|
|
|
m_assMapper.Post(item.AssetID, receiver, userAssetServer);
|
2009-10-13 00:00:01 +00:00
|
|
|
}
|
2008-11-25 16:00:55 +00:00
|
|
|
|
2010-07-04 21:59:15 +00:00
|
|
|
public override bool IsForeignUser(UUID userID, out string assetServerURL)
|
2010-01-30 17:23:07 +00:00
|
|
|
{
|
|
|
|
assetServerURL = string.Empty;
|
2010-01-30 23:43:10 +00:00
|
|
|
|
2011-12-30 00:12:06 +00:00
|
|
|
if (UserManagementModule != null && !UserManagementModule.IsLocalGridUser(userID))
|
|
|
|
{ // foreign
|
2010-01-30 17:23:07 +00:00
|
|
|
ScenePresence sp = null;
|
2010-03-19 12:58:34 +00:00
|
|
|
if (m_Scene.TryGetScenePresence(userID, out sp))
|
2010-01-30 17:23:07 +00:00
|
|
|
{
|
|
|
|
AgentCircuitData aCircuit = m_Scene.AuthenticateHandler.GetAgentCircuitData(sp.ControllingClient.CircuitCode);
|
|
|
|
if (aCircuit.ServiceURLs.ContainsKey("AssetServerURI"))
|
|
|
|
{
|
|
|
|
assetServerURL = aCircuit.ServiceURLs["AssetServerURI"].ToString();
|
2011-05-24 16:38:03 +00:00
|
|
|
assetServerURL = assetServerURL.Trim(new char[] { '/' });
|
2010-01-30 17:23:07 +00:00
|
|
|
}
|
|
|
|
}
|
2011-05-24 16:38:03 +00:00
|
|
|
else
|
|
|
|
{
|
|
|
|
assetServerURL = UserManagementModule.GetUserServerURL(userID, "AssetServerURI");
|
|
|
|
assetServerURL = assetServerURL.Trim(new char[] { '/' });
|
|
|
|
}
|
|
|
|
return true;
|
2010-01-30 17:23:07 +00:00
|
|
|
}
|
2008-11-25 16:00:55 +00:00
|
|
|
|
2010-01-30 17:23:07 +00:00
|
|
|
return false;
|
|
|
|
}
|
2010-07-04 20:56:03 +00:00
|
|
|
|
|
|
|
protected override InventoryItemBase GetItem(UUID agentID, UUID itemID)
|
|
|
|
{
|
|
|
|
InventoryItemBase item = base.GetItem(agentID, itemID);
|
2012-09-13 17:00:29 +00:00
|
|
|
if (item == null)
|
|
|
|
return null;
|
2010-07-04 20:56:03 +00:00
|
|
|
|
|
|
|
string userAssetServer = string.Empty;
|
|
|
|
if (IsForeignUser(agentID, out userAssetServer))
|
|
|
|
m_assMapper.Get(item.AssetID, agentID, userAssetServer);
|
|
|
|
|
|
|
|
return item;
|
|
|
|
}
|
2012-04-07 03:34:31 +00:00
|
|
|
|
|
|
|
#endregion
|
|
|
|
|
|
|
|
#region Inventory manipulation upon arriving/leaving
|
|
|
|
|
|
|
|
//
|
|
|
|
// These 2 are for local and foreign users coming back, respectively
|
|
|
|
//
|
|
|
|
|
|
|
|
private void ProcessInventoryForComingHome(IClientAPI client)
|
|
|
|
{
|
|
|
|
m_log.DebugFormat("[HG INVENTORY ACCESS MODULE]: Restoring root folder for local user {0}", client.Name);
|
|
|
|
if (client is IClientCore)
|
|
|
|
{
|
|
|
|
IClientCore core = (IClientCore)client;
|
|
|
|
IClientInventory inv;
|
|
|
|
|
|
|
|
if (core.TryGet<IClientInventory>(out inv))
|
|
|
|
{
|
|
|
|
InventoryFolderBase root = m_Scene.InventoryService.GetRootFolder(client.AgentId);
|
|
|
|
InventoryCollection content = m_Scene.InventoryService.GetFolderContent(client.AgentId, root.ID);
|
|
|
|
|
|
|
|
inv.SendBulkUpdateInventory(content.Folders.ToArray(), content.Items.ToArray());
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
private void ProcessInventoryForArriving(IClientAPI client)
|
|
|
|
{
|
2012-11-02 15:05:56 +00:00
|
|
|
// No-op for now, but we may need to do something for freign users inventory
|
2012-04-07 03:34:31 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
//
|
|
|
|
// These 2 are for local and foreign users going away respectively
|
|
|
|
//
|
|
|
|
|
|
|
|
private void ProcessInventoryForHypergriding(IClientAPI client)
|
|
|
|
{
|
|
|
|
if (client is IClientCore)
|
|
|
|
{
|
|
|
|
IClientCore core = (IClientCore)client;
|
|
|
|
IClientInventory inv;
|
|
|
|
|
|
|
|
if (core.TryGet<IClientInventory>(out inv))
|
|
|
|
{
|
|
|
|
InventoryFolderBase root = m_Scene.InventoryService.GetRootFolder(client.AgentId);
|
|
|
|
if (root != null)
|
|
|
|
{
|
|
|
|
m_log.DebugFormat("[HG INVENTORY ACCESS MODULE]: Changing root inventory for user {0}", client.Name);
|
|
|
|
InventoryCollection content = m_Scene.InventoryService.GetFolderContent(client.AgentId, root.ID);
|
2012-05-25 03:03:16 +00:00
|
|
|
|
2012-04-07 03:34:31 +00:00
|
|
|
List<InventoryFolderBase> keep = new List<InventoryFolderBase>();
|
|
|
|
|
|
|
|
foreach (InventoryFolderBase f in content.Folders)
|
|
|
|
{
|
|
|
|
if (f.Name != "My Suitcase")
|
|
|
|
{
|
|
|
|
f.Name = f.Name + " (Unavailable)";
|
|
|
|
keep.Add(f);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// items directly under the root folder
|
|
|
|
foreach (InventoryItemBase it in content.Items)
|
|
|
|
it.Name = it.Name + " (Unavailable)"; ;
|
|
|
|
|
|
|
|
// Send the new names
|
|
|
|
inv.SendBulkUpdateInventory(keep.ToArray(), content.Items.ToArray());
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
private void ProcessInventoryForLeaving(IClientAPI client)
|
|
|
|
{
|
2012-11-02 15:05:56 +00:00
|
|
|
// No-op for now
|
2012-04-07 03:34:31 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
#endregion
|
2010-01-30 17:23:07 +00:00
|
|
|
}
|
2012-05-25 03:03:16 +00:00
|
|
|
}
|