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;
|
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; }
|
|
|
|
}
|
|
|
|
|
2010-11-27 06:06:34 +00:00
|
|
|
private string m_ProfileServerURI;
|
2011-02-05 01:05:45 +00:00
|
|
|
private bool m_OutboundPermission;
|
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;
|
|
|
|
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
|
|
|
{
|
2010-11-27 06:06:34 +00:00
|
|
|
m_ProfileServerURI = thisModuleConfig.GetString("ProfileServerURI", string.Empty);
|
2011-02-05 01:05:45 +00:00
|
|
|
m_OutboundPermission = thisModuleConfig.GetBoolean("OutboundPermission", true);
|
|
|
|
}
|
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);
|
2010-11-27 06:06:34 +00:00
|
|
|
m_assMapper = new HGAssetMapper(scene, m_ProfileServerURI);
|
2010-01-30 17:23:07 +00:00
|
|
|
scene.EventManager.OnNewInventoryItemUploadComplete += UploadInventoryItem;
|
2008-11-25 16:00:55 +00:00
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
#endregion
|
|
|
|
|
|
|
|
#region Event handlers
|
|
|
|
|
|
|
|
public void UploadInventoryItem(UUID avatarID, UUID assetID, string name, int userlevel)
|
|
|
|
{
|
2010-01-30 17:23:07 +00:00
|
|
|
string userAssetServer = string.Empty;
|
2011-02-05 01:05:45 +00:00
|
|
|
if (IsForeignUser(avatarID, out userAssetServer) && m_OutboundPermission)
|
2008-11-25 16:00:55 +00:00
|
|
|
{
|
2010-11-27 06:06:34 +00:00
|
|
|
Util.FireAndForget(delegate { 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
|
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;
|
|
|
|
}
|
|
|
|
|
|
|
|
///
|
|
|
|
/// DeleteToInventory
|
|
|
|
///
|
2010-06-01 00:27:30 +00:00
|
|
|
public override UUID DeleteToInventory(DeRezAction action, UUID folderID, List<SceneObjectGroup> objectGroups, IClientAPI remoteClient)
|
2008-11-25 16:00:55 +00:00
|
|
|
{
|
2010-06-01 00:27:30 +00:00
|
|
|
UUID ret = UUID.Zero;
|
|
|
|
|
|
|
|
// HACK: Only works for lists of length one.
|
|
|
|
// Intermediate version, just to make things compile
|
|
|
|
foreach (SceneObjectGroup g in objectGroups)
|
|
|
|
ret = DeleteToInventory(action, folderID, g, remoteClient);
|
|
|
|
|
|
|
|
return ret;
|
|
|
|
}
|
|
|
|
|
2010-07-05 14:14:32 +00:00
|
|
|
// DO NOT OVERRIDE THE BASE METHOD
|
2010-09-03 20:28:57 +00:00
|
|
|
public new virtual UUID DeleteToInventory(DeRezAction action, UUID folderID,
|
2010-06-01 00:27:30 +00:00
|
|
|
SceneObjectGroup objectGroup, IClientAPI remoteClient)
|
|
|
|
{
|
|
|
|
UUID assetID = base.DeleteToInventory(action, folderID, new List<SceneObjectGroup>() {objectGroup}, remoteClient);
|
2008-11-25 16:00:55 +00:00
|
|
|
|
|
|
|
if (!assetID.Equals(UUID.Zero))
|
|
|
|
{
|
2010-07-05 14:14:32 +00:00
|
|
|
if (remoteClient != null)
|
|
|
|
UploadInventoryItem(remoteClient.AgentId, assetID, "", 0);
|
2008-11-25 16:00:55 +00:00
|
|
|
}
|
|
|
|
else
|
|
|
|
m_log.Debug("[HGScene]: Scene.Inventory did not create asset");
|
|
|
|
|
|
|
|
return assetID;
|
|
|
|
}
|
|
|
|
|
|
|
|
///
|
|
|
|
/// 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
|
2010-01-30 17:23:07 +00:00
|
|
|
return base.RezObject(remoteClient, itemID, RayEnd, RayStart, RayTargetID, BypassRayCast, RayEndIsIntersection,
|
2008-11-25 16:00:55 +00:00
|
|
|
RezSelected, RemoveItem, fromTaskID, attachment);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
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;
|
|
|
|
if (IsForeignUser(sender, out userAssetServer))
|
|
|
|
m_assMapper.Get(item.AssetID, sender, userAssetServer);
|
2009-10-13 00:00:01 +00:00
|
|
|
|
2011-02-05 01:05:45 +00:00
|
|
|
if (IsForeignUser(receiver, out userAssetServer) && m_OutboundPermission)
|
2010-01-30 17:23:07 +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
|
|
|
UserAccount account = null;
|
|
|
|
if (m_Scene.UserAccountService != null)
|
|
|
|
account = m_Scene.UserAccountService.GetUserAccount(m_Scene.RegionInfo.ScopeID, userID);
|
|
|
|
|
2010-01-30 17:23:07 +00:00
|
|
|
if (account == null) // foreign
|
|
|
|
{
|
|
|
|
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();
|
2010-01-30 23:43:10 +00:00
|
|
|
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
|
|
|
|
2010-07-04 21:59:15 +00:00
|
|
|
#endregion
|
|
|
|
|
2010-07-04 20:56:03 +00:00
|
|
|
protected override InventoryItemBase GetItem(UUID agentID, UUID itemID)
|
|
|
|
{
|
|
|
|
InventoryItemBase item = base.GetItem(agentID, itemID);
|
|
|
|
|
|
|
|
string userAssetServer = string.Empty;
|
|
|
|
if (IsForeignUser(agentID, out userAssetServer))
|
|
|
|
m_assMapper.Get(item.AssetID, agentID, userAssetServer);
|
|
|
|
|
|
|
|
return item;
|
|
|
|
}
|
2010-01-30 17:23:07 +00:00
|
|
|
}
|
2008-11-25 16:00:55 +00:00
|
|
|
}
|