Merge branch 'bigmerge' of ssh://3dhosting.de/var/git/careminster into bigmerge
commit
d1c80efd41
|
@ -1,68 +0,0 @@
|
||||||
/*
|
|
||||||
* Copyright (c) Contributors, http://opensimulator.org/
|
|
||||||
* See CONTRIBUTORS.TXT for a full list of copyright holders.
|
|
||||||
*
|
|
||||||
* 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.
|
|
||||||
* * Neither the name of the OpenSimulator Project nor the
|
|
||||||
* 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.
|
|
||||||
*/
|
|
||||||
|
|
||||||
using System.Collections.Generic;
|
|
||||||
using OpenMetaverse;
|
|
||||||
|
|
||||||
namespace OpenSim.Framework
|
|
||||||
{
|
|
||||||
public delegate void ExpectUserDelegate(AgentCircuitData agent);
|
|
||||||
|
|
||||||
|
|
||||||
public delegate void UpdateNeighbours(List<RegionInfo> neighbours);
|
|
||||||
|
|
||||||
public delegate void AgentCrossing(UUID agentID, Vector3 position, bool isFlying);
|
|
||||||
|
|
||||||
public delegate void PrimCrossing(UUID primID, Vector3 position, bool isPhysical);
|
|
||||||
|
|
||||||
public delegate void AcknowledgeAgentCross(UUID agentID);
|
|
||||||
|
|
||||||
public delegate void AcknowledgePrimCross(UUID PrimID);
|
|
||||||
|
|
||||||
public delegate bool CloseAgentConnection(UUID agentID);
|
|
||||||
|
|
||||||
public delegate bool ChildAgentUpdate(ChildAgentDataUpdate cAgentData);
|
|
||||||
|
|
||||||
public delegate void LogOffUser(UUID agentID, UUID regionSecret, string message);
|
|
||||||
|
|
||||||
public delegate LandData GetLandData(uint x, uint y);
|
|
||||||
|
|
||||||
public interface IRegionCommsListener
|
|
||||||
{
|
|
||||||
event ExpectUserDelegate OnExpectUser;
|
|
||||||
event GenericCall2 OnExpectChildAgent;
|
|
||||||
event AgentCrossing OnAvatarCrossingIntoRegion;
|
|
||||||
event PrimCrossing OnPrimCrossingIntoRegion;
|
|
||||||
event AcknowledgeAgentCross OnAcknowledgeAgentCrossed;
|
|
||||||
event AcknowledgePrimCross OnAcknowledgePrimCrossed;
|
|
||||||
event UpdateNeighbours OnNeighboursUpdate;
|
|
||||||
event CloseAgentConnection OnCloseAgentConnection;
|
|
||||||
event ChildAgentUpdate OnChildAgentUpdate;
|
|
||||||
event LogOffUser OnLogOffUser;
|
|
||||||
event GetLandData OnGetLandData;
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -1,204 +0,0 @@
|
||||||
/*
|
|
||||||
* Copyright (c) Contributors, http://opensimulator.org/
|
|
||||||
* See CONTRIBUTORS.TXT for a full list of copyright holders.
|
|
||||||
*
|
|
||||||
* 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.
|
|
||||||
* * Neither the name of the OpenSimulator Project nor the
|
|
||||||
* 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.
|
|
||||||
*/
|
|
||||||
|
|
||||||
using System;
|
|
||||||
using System.Collections.Generic;
|
|
||||||
using OpenMetaverse;
|
|
||||||
|
|
||||||
namespace OpenSim.Framework
|
|
||||||
{
|
|
||||||
/// <summary>
|
|
||||||
/// Sandbox mode region comms listener. There is one of these per region
|
|
||||||
/// </summary>
|
|
||||||
public class RegionCommsListener : IRegionCommsListener
|
|
||||||
{
|
|
||||||
public string debugRegionName = String.Empty;
|
|
||||||
private AcknowledgeAgentCross handlerAcknowledgeAgentCrossed = null; // OnAcknowledgeAgentCrossed;
|
|
||||||
private AcknowledgePrimCross handlerAcknowledgePrimCrossed = null; // OnAcknowledgePrimCrossed;
|
|
||||||
private AgentCrossing handlerAvatarCrossingIntoRegion = null; // OnAvatarCrossingIntoRegion;
|
|
||||||
private ChildAgentUpdate handlerChildAgentUpdate = null; // OnChildAgentUpdate;
|
|
||||||
private CloseAgentConnection handlerCloseAgentConnection = null; // OnCloseAgentConnection;
|
|
||||||
private GenericCall2 handlerExpectChildAgent = null; // OnExpectChildAgent;
|
|
||||||
private ExpectUserDelegate handlerExpectUser = null; // OnExpectUser
|
|
||||||
private UpdateNeighbours handlerNeighboursUpdate = null; // OnNeighboursUpdate;
|
|
||||||
// private PrimCrossing handlerPrimCrossingIntoRegion = null; // OnPrimCrossingIntoRegion;
|
|
||||||
private LogOffUser handlerLogOffUser = null;
|
|
||||||
private GetLandData handlerGetLandData = null;
|
|
||||||
|
|
||||||
#region IRegionCommsListener Members
|
|
||||||
|
|
||||||
public event ExpectUserDelegate OnExpectUser;
|
|
||||||
public event GenericCall2 OnExpectChildAgent;
|
|
||||||
public event AgentCrossing OnAvatarCrossingIntoRegion;
|
|
||||||
public event PrimCrossing OnPrimCrossingIntoRegion;
|
|
||||||
public event UpdateNeighbours OnNeighboursUpdate;
|
|
||||||
public event AcknowledgeAgentCross OnAcknowledgeAgentCrossed;
|
|
||||||
public event AcknowledgePrimCross OnAcknowledgePrimCrossed;
|
|
||||||
public event CloseAgentConnection OnCloseAgentConnection;
|
|
||||||
public event ChildAgentUpdate OnChildAgentUpdate;
|
|
||||||
public event LogOffUser OnLogOffUser;
|
|
||||||
public event GetLandData OnGetLandData;
|
|
||||||
|
|
||||||
#endregion
|
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
///
|
|
||||||
/// </summary>
|
|
||||||
/// <param name="agent"></param>
|
|
||||||
/// <returns></returns>
|
|
||||||
public virtual bool TriggerExpectUser(AgentCircuitData agent)
|
|
||||||
{
|
|
||||||
handlerExpectUser = OnExpectUser;
|
|
||||||
if (handlerExpectUser != null)
|
|
||||||
{
|
|
||||||
handlerExpectUser(agent);
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
// From User Server
|
|
||||||
public virtual void TriggerLogOffUser(UUID agentID, UUID RegionSecret, string message)
|
|
||||||
{
|
|
||||||
handlerLogOffUser = OnLogOffUser;
|
|
||||||
if (handlerLogOffUser != null)
|
|
||||||
{
|
|
||||||
handlerLogOffUser(agentID, RegionSecret, message);
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
public virtual bool TriggerChildAgentUpdate(ChildAgentDataUpdate cAgentData)
|
|
||||||
{
|
|
||||||
handlerChildAgentUpdate = OnChildAgentUpdate;
|
|
||||||
if (handlerChildAgentUpdate != null)
|
|
||||||
{
|
|
||||||
handlerChildAgentUpdate(cAgentData);
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
public virtual bool TriggerExpectAvatarCrossing(UUID agentID, Vector3 position, bool isFlying)
|
|
||||||
{
|
|
||||||
handlerAvatarCrossingIntoRegion = OnAvatarCrossingIntoRegion;
|
|
||||||
if (handlerAvatarCrossingIntoRegion != null)
|
|
||||||
{
|
|
||||||
handlerAvatarCrossingIntoRegion(agentID, position, isFlying);
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
public virtual bool TriggerAcknowledgeAgentCrossed(UUID agentID)
|
|
||||||
{
|
|
||||||
handlerAcknowledgeAgentCrossed = OnAcknowledgeAgentCrossed;
|
|
||||||
if (handlerAcknowledgeAgentCrossed != null)
|
|
||||||
{
|
|
||||||
handlerAcknowledgeAgentCrossed(agentID);
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
public virtual bool TriggerAcknowledgePrimCrossed(UUID primID)
|
|
||||||
{
|
|
||||||
handlerAcknowledgePrimCrossed = OnAcknowledgePrimCrossed;
|
|
||||||
if (handlerAcknowledgePrimCrossed != null)
|
|
||||||
{
|
|
||||||
handlerAcknowledgePrimCrossed(primID);
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
public virtual bool TriggerCloseAgentConnection(UUID agentID)
|
|
||||||
{
|
|
||||||
handlerCloseAgentConnection = OnCloseAgentConnection;
|
|
||||||
if (handlerCloseAgentConnection != null)
|
|
||||||
{
|
|
||||||
handlerCloseAgentConnection(agentID);
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
///
|
|
||||||
/// </summary>
|
|
||||||
/// <remarks>TODO: Doesnt take any args??</remarks>
|
|
||||||
/// <returns></returns>
|
|
||||||
public virtual bool TriggerExpectChildAgent()
|
|
||||||
{
|
|
||||||
handlerExpectChildAgent = OnExpectChildAgent;
|
|
||||||
if (handlerExpectChildAgent != null)
|
|
||||||
{
|
|
||||||
handlerExpectChildAgent();
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
///
|
|
||||||
/// </summary>
|
|
||||||
/// <remarks>Added to avoid a unused compiler warning on OnNeighboursUpdate, TODO: Check me</remarks>
|
|
||||||
/// <param name="neighbours"></param>
|
|
||||||
/// <returns></returns>
|
|
||||||
public virtual bool TriggerOnNeighboursUpdate(List<RegionInfo> neighbours)
|
|
||||||
{
|
|
||||||
handlerNeighboursUpdate = OnNeighboursUpdate;
|
|
||||||
if (handlerNeighboursUpdate != null)
|
|
||||||
{
|
|
||||||
handlerNeighboursUpdate(neighbours);
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
public bool TriggerTellRegionToCloseChildConnection(UUID agentID)
|
|
||||||
{
|
|
||||||
handlerCloseAgentConnection = OnCloseAgentConnection;
|
|
||||||
if (handlerCloseAgentConnection != null)
|
|
||||||
return handlerCloseAgentConnection(agentID);
|
|
||||||
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
public LandData TriggerGetLandData(uint x, uint y)
|
|
||||||
{
|
|
||||||
handlerGetLandData = OnGetLandData;
|
|
||||||
if (handlerGetLandData != null)
|
|
||||||
return handlerGetLandData(x, y);
|
|
||||||
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -243,17 +243,32 @@ namespace OpenSim.Framework.Servers
|
||||||
/// </summary>
|
/// </summary>
|
||||||
protected string GetThreadsReport()
|
protected string GetThreadsReport()
|
||||||
{
|
{
|
||||||
|
// This should be a constant field.
|
||||||
|
string reportFormat = "{0,6} {1,35} {2,16} {3,13} {4,10} {5,30}";
|
||||||
|
|
||||||
StringBuilder sb = new StringBuilder();
|
StringBuilder sb = new StringBuilder();
|
||||||
Watchdog.ThreadWatchdogInfo[] threads = Watchdog.GetThreads();
|
Watchdog.ThreadWatchdogInfo[] threads = Watchdog.GetThreads();
|
||||||
|
|
||||||
sb.Append(threads.Length + " threads are being tracked:" + Environment.NewLine);
|
sb.Append(threads.Length + " threads are being tracked:" + Environment.NewLine);
|
||||||
|
|
||||||
|
int timeNow = Util.EnvironmentTickCount();
|
||||||
|
|
||||||
|
sb.AppendFormat(reportFormat, "ID", "NAME", "LAST UPDATE (MS)", "LIFETIME (MS)", "PRIORITY", "STATE");
|
||||||
|
sb.Append(Environment.NewLine);
|
||||||
|
|
||||||
foreach (Watchdog.ThreadWatchdogInfo twi in threads)
|
foreach (Watchdog.ThreadWatchdogInfo twi in threads)
|
||||||
{
|
{
|
||||||
Thread t = twi.Thread;
|
Thread t = twi.Thread;
|
||||||
|
|
||||||
sb.Append(
|
sb.AppendFormat(
|
||||||
"ID: " + t.ManagedThreadId + ", Name: " + t.Name + ", TimeRunning: "
|
reportFormat,
|
||||||
+ "Pri: " + t.Priority + ", State: " + t.ThreadState);
|
t.ManagedThreadId,
|
||||||
|
t.Name,
|
||||||
|
timeNow - twi.LastTick,
|
||||||
|
timeNow - twi.FirstTick,
|
||||||
|
t.Priority,
|
||||||
|
t.ThreadState);
|
||||||
|
|
||||||
sb.Append(Environment.NewLine);
|
sb.Append(Environment.NewLine);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -69,6 +69,9 @@ namespace OpenSim.Framework.Servers.HttpServer
|
||||||
while (m_running)
|
while (m_running)
|
||||||
{
|
{
|
||||||
PollServiceHttpRequest req = m_request.Dequeue();
|
PollServiceHttpRequest req = m_request.Dequeue();
|
||||||
|
|
||||||
|
Watchdog.UpdateThread();
|
||||||
|
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
if (req.PollServiceArgs.HasEvents(req.RequestID, req.PollServiceArgs.Id))
|
if (req.PollServiceArgs.HasEvents(req.RequestID, req.PollServiceArgs.Id))
|
||||||
|
|
|
@ -48,6 +48,18 @@ namespace OpenSim.Framework
|
||||||
public class ThreadWatchdogInfo
|
public class ThreadWatchdogInfo
|
||||||
{
|
{
|
||||||
public Thread Thread { get; private set; }
|
public Thread Thread { get; private set; }
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Approximate tick when this thread was started.
|
||||||
|
/// </summary>
|
||||||
|
/// <remarks>
|
||||||
|
/// Not terribly good since this quickly wraps around.
|
||||||
|
/// </remarks>
|
||||||
|
public int FirstTick { get; private set; }
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// First time this heartbeat update was invoked
|
||||||
|
/// </summary>
|
||||||
public int LastTick { get; set; }
|
public int LastTick { get; set; }
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
|
@ -64,7 +76,8 @@ namespace OpenSim.Framework
|
||||||
{
|
{
|
||||||
Thread = thread;
|
Thread = thread;
|
||||||
Timeout = timeout;
|
Timeout = timeout;
|
||||||
LastTick = Environment.TickCount & Int32.MaxValue;
|
FirstTick = Environment.TickCount & Int32.MaxValue;
|
||||||
|
LastTick = FirstTick;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -29,6 +29,7 @@ using System;
|
||||||
using System.Collections;
|
using System.Collections;
|
||||||
using System.Collections.Generic;
|
using System.Collections.Generic;
|
||||||
using System.Reflection;
|
using System.Reflection;
|
||||||
|
using System.Threading;
|
||||||
using log4net;
|
using log4net;
|
||||||
using Nini.Config;
|
using Nini.Config;
|
||||||
using Nwc.XmlRpc;
|
using Nwc.XmlRpc;
|
||||||
|
@ -79,10 +80,20 @@ namespace OpenSim.Region.CoreModules.Avatar.Friends
|
||||||
protected IFriendsService m_FriendsService = null;
|
protected IFriendsService m_FriendsService = null;
|
||||||
protected FriendsSimConnector m_FriendsSimConnector;
|
protected FriendsSimConnector m_FriendsSimConnector;
|
||||||
|
|
||||||
protected Dictionary<UUID, UserFriendData> m_Friends =
|
/// <summary>
|
||||||
new Dictionary<UUID, UserFriendData>();
|
/// Cache friends lists for users.
|
||||||
|
/// </summary>
|
||||||
|
/// <remarks>
|
||||||
|
/// This is a complex and error-prone thing to do. At the moment, we assume that the efficiency gained in
|
||||||
|
/// permissions checks outweighs the disadvantages of that complexity.
|
||||||
|
/// </remarks>
|
||||||
|
protected Dictionary<UUID, UserFriendData> m_Friends = new Dictionary<UUID, UserFriendData>();
|
||||||
|
|
||||||
protected HashSet<UUID> m_NeedsListOfFriends = new HashSet<UUID>();
|
/// <summary>
|
||||||
|
/// Maintain a record of viewers that need to be sent notifications for friends that are online. This only
|
||||||
|
/// needs to be done on login. Subsequent online/offline friend changes are sent by a different mechanism.
|
||||||
|
/// </summary>
|
||||||
|
protected HashSet<UUID> m_NeedsListOfOnlineFriends = new HashSet<UUID>();
|
||||||
|
|
||||||
protected IPresenceService PresenceService
|
protected IPresenceService PresenceService
|
||||||
{
|
{
|
||||||
|
@ -189,6 +200,7 @@ namespace OpenSim.Region.CoreModules.Avatar.Friends
|
||||||
{
|
{
|
||||||
if (!m_Enabled)
|
if (!m_Enabled)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
m_log.DebugFormat("[FRIENDS MODULE]: AddRegion on {0}", Name);
|
m_log.DebugFormat("[FRIENDS MODULE]: AddRegion on {0}", Name);
|
||||||
|
|
||||||
m_Scenes.Add(scene);
|
m_Scenes.Add(scene);
|
||||||
|
@ -241,16 +253,25 @@ namespace OpenSim.Region.CoreModules.Avatar.Friends
|
||||||
client.OnInstantMessage += OnInstantMessage;
|
client.OnInstantMessage += OnInstantMessage;
|
||||||
client.OnApproveFriendRequest += OnApproveFriendRequest;
|
client.OnApproveFriendRequest += OnApproveFriendRequest;
|
||||||
client.OnDenyFriendRequest += OnDenyFriendRequest;
|
client.OnDenyFriendRequest += OnDenyFriendRequest;
|
||||||
client.OnTerminateFriendship += OnTerminateFriendship;
|
client.OnTerminateFriendship += (thisClient, agentID, exfriendID) => RemoveFriendship(thisClient, exfriendID);
|
||||||
client.OnGrantUserRights += OnGrantUserRights;
|
client.OnGrantUserRights += OnGrantUserRights;
|
||||||
|
|
||||||
Util.FireAndForget(delegate { FetchFriendslist(client); });
|
// Do not do this asynchronously. If we do, then subsequent code can outrace CacheFriends() and
|
||||||
|
// return misleading results from the still empty friends cache.
|
||||||
|
// If we absolutely need to do this asynchronously, then a signalling mechanism is needed so that calls
|
||||||
|
// to GetFriends() will wait until CacheFriends() completes. Locks are insufficient.
|
||||||
|
CacheFriends(client);
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Fetch the friends list or increment the refcount for the existing
|
/// <summary>
|
||||||
/// friends list
|
/// Cache the friends list or increment the refcount for the existing friends list.
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="client">
|
||||||
|
/// </param>
|
||||||
|
/// <returns>
|
||||||
/// Returns true if the list was fetched, false if it wasn't
|
/// Returns true if the list was fetched, false if it wasn't
|
||||||
protected virtual bool FetchFriendslist(IClientAPI client)
|
/// </returns>
|
||||||
|
protected virtual bool CacheFriends(IClientAPI client)
|
||||||
{
|
{
|
||||||
UUID agentID = client.AgentId;
|
UUID agentID = client.AgentId;
|
||||||
lock (m_Friends)
|
lock (m_Friends)
|
||||||
|
@ -297,7 +318,7 @@ namespace OpenSim.Region.CoreModules.Avatar.Friends
|
||||||
|
|
||||||
private void OnMakeRootAgent(ScenePresence sp)
|
private void OnMakeRootAgent(ScenePresence sp)
|
||||||
{
|
{
|
||||||
RefetchFriends(sp.ControllingClient);
|
RecacheFriends(sp.ControllingClient);
|
||||||
}
|
}
|
||||||
|
|
||||||
private void OnClientLogin(IClientAPI client)
|
private void OnClientLogin(IClientAPI client)
|
||||||
|
@ -309,8 +330,8 @@ namespace OpenSim.Region.CoreModules.Avatar.Friends
|
||||||
StatusChange(agentID, true);
|
StatusChange(agentID, true);
|
||||||
|
|
||||||
// Register that we need to send the list of online friends to this user
|
// Register that we need to send the list of online friends to this user
|
||||||
lock (m_NeedsListOfFriends)
|
lock (m_NeedsListOfOnlineFriends)
|
||||||
m_NeedsListOfFriends.Add(agentID);
|
m_NeedsListOfOnlineFriends.Add(agentID);
|
||||||
}
|
}
|
||||||
|
|
||||||
public virtual bool SendFriendsOnlineIfNeeded(IClientAPI client)
|
public virtual bool SendFriendsOnlineIfNeeded(IClientAPI client)
|
||||||
|
@ -318,9 +339,9 @@ namespace OpenSim.Region.CoreModules.Avatar.Friends
|
||||||
UUID agentID = client.AgentId;
|
UUID agentID = client.AgentId;
|
||||||
|
|
||||||
// Check if the online friends list is needed
|
// Check if the online friends list is needed
|
||||||
lock (m_NeedsListOfFriends)
|
lock (m_NeedsListOfOnlineFriends)
|
||||||
{
|
{
|
||||||
if (!m_NeedsListOfFriends.Remove(agentID))
|
if (!m_NeedsListOfOnlineFriends.Remove(agentID))
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -328,7 +349,10 @@ namespace OpenSim.Region.CoreModules.Avatar.Friends
|
||||||
List<UUID> online = GetOnlineFriends(agentID);
|
List<UUID> online = GetOnlineFriends(agentID);
|
||||||
if (online.Count > 0)
|
if (online.Count > 0)
|
||||||
{
|
{
|
||||||
m_log.DebugFormat("[FRIENDS MODULE]: User {0} in region {1} has {2} friends online", client.AgentId, client.Scene.RegionInfo.RegionName, online.Count);
|
m_log.DebugFormat(
|
||||||
|
"[FRIENDS MODULE]: User {0} in region {1} has {2} friends online",
|
||||||
|
client.Name, client.Scene.RegionInfo.RegionName, online.Count);
|
||||||
|
|
||||||
client.SendAgentOnline(online.ToArray());
|
client.SendAgentOnline(online.ToArray());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -586,7 +610,7 @@ namespace OpenSim.Region.CoreModules.Avatar.Friends
|
||||||
}
|
}
|
||||||
|
|
||||||
// Update the local cache
|
// Update the local cache
|
||||||
RefetchFriends(client);
|
RecacheFriends(client);
|
||||||
|
|
||||||
//
|
//
|
||||||
// Notify the friend
|
// Notify the friend
|
||||||
|
@ -642,13 +666,13 @@ namespace OpenSim.Region.CoreModules.Avatar.Friends
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private void OnTerminateFriendship(IClientAPI client, UUID agentID, UUID exfriendID)
|
public void RemoveFriendship(IClientAPI client, UUID exfriendID)
|
||||||
{
|
{
|
||||||
if (!DeleteFriendship(agentID, exfriendID))
|
if (!DeleteFriendship(client.AgentId, exfriendID))
|
||||||
client.SendAlertMessage("Unable to terminate friendship on this sim.");
|
client.SendAlertMessage("Unable to terminate friendship on this sim.");
|
||||||
|
|
||||||
// Update local cache
|
// Update local cache
|
||||||
RefetchFriends(client);
|
RecacheFriends(client);
|
||||||
|
|
||||||
client.SendTerminateFriend(exfriendID);
|
client.SendTerminateFriend(exfriendID);
|
||||||
|
|
||||||
|
@ -667,7 +691,7 @@ namespace OpenSim.Region.CoreModules.Avatar.Friends
|
||||||
if (friendSession != null)
|
if (friendSession != null)
|
||||||
{
|
{
|
||||||
GridRegion region = GridService.GetRegionByUUID(m_Scenes[0].RegionInfo.ScopeID, friendSession.RegionID);
|
GridRegion region = GridService.GetRegionByUUID(m_Scenes[0].RegionInfo.ScopeID, friendSession.RegionID);
|
||||||
m_FriendsSimConnector.FriendshipTerminated(region, agentID, exfriendID);
|
m_FriendsSimConnector.FriendshipTerminated(region, client.AgentId, exfriendID);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -769,7 +793,7 @@ namespace OpenSim.Region.CoreModules.Avatar.Friends
|
||||||
|
|
||||||
|
|
||||||
// Update the local cache
|
// Update the local cache
|
||||||
RefetchFriends(friendClient);
|
RecacheFriends(friendClient);
|
||||||
|
|
||||||
// we're done
|
// we're done
|
||||||
return true;
|
return true;
|
||||||
|
@ -802,7 +826,7 @@ namespace OpenSim.Region.CoreModules.Avatar.Friends
|
||||||
// the friend in this sim as root agent
|
// the friend in this sim as root agent
|
||||||
friendClient.SendTerminateFriend(exfriendID);
|
friendClient.SendTerminateFriend(exfriendID);
|
||||||
// update local cache
|
// update local cache
|
||||||
RefetchFriends(friendClient);
|
RecacheFriends(friendClient);
|
||||||
// we're done
|
// we're done
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
@ -819,16 +843,15 @@ namespace OpenSim.Region.CoreModules.Avatar.Friends
|
||||||
if (onlineBitChanged)
|
if (onlineBitChanged)
|
||||||
{
|
{
|
||||||
if ((rights & (int)FriendRights.CanSeeOnline) == 1)
|
if ((rights & (int)FriendRights.CanSeeOnline) == 1)
|
||||||
friendClient.SendAgentOnline(new UUID[] { new UUID(userID) });
|
friendClient.SendAgentOnline(new UUID[] { userID });
|
||||||
else
|
else
|
||||||
friendClient.SendAgentOffline(new UUID[] { new UUID(userID) });
|
friendClient.SendAgentOffline(new UUID[] { userID });
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
bool canEditObjectsChanged = ((rights ^ userFlags) & (int)FriendRights.CanModifyObjects) != 0;
|
bool canEditObjectsChanged = ((rights ^ userFlags) & (int)FriendRights.CanModifyObjects) != 0;
|
||||||
if (canEditObjectsChanged)
|
if (canEditObjectsChanged)
|
||||||
friendClient.SendChangeUserRights(userID, friendID, rights);
|
friendClient.SendChangeUserRights(userID, friendID, rights);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// Update local cache
|
// Update local cache
|
||||||
|
@ -847,7 +870,7 @@ namespace OpenSim.Region.CoreModules.Avatar.Friends
|
||||||
IClientAPI friendClient = LocateClientObject(friendID);
|
IClientAPI friendClient = LocateClientObject(friendID);
|
||||||
if (friendClient != null)
|
if (friendClient != null)
|
||||||
{
|
{
|
||||||
// the friend in this sim as root agent
|
// the friend in this sim as root agent
|
||||||
if (online)
|
if (online)
|
||||||
friendClient.SendAgentOnline(new UUID[] { userID });
|
friendClient.SendAgentOnline(new UUID[] { userID });
|
||||||
else
|
else
|
||||||
|
@ -902,8 +925,10 @@ namespace OpenSim.Region.CoreModules.Avatar.Friends
|
||||||
return FriendsService.GetFriends(client.AgentId);
|
return FriendsService.GetFriends(client.AgentId);
|
||||||
}
|
}
|
||||||
|
|
||||||
private void RefetchFriends(IClientAPI client)
|
private void RecacheFriends(IClientAPI client)
|
||||||
{
|
{
|
||||||
|
// FIXME: Ideally, we want to avoid doing this here since it sits the EventManager.OnMakeRootAgent event
|
||||||
|
// is on the critical path for transferring an avatar from one region to another.
|
||||||
UUID agentID = client.AgentId;
|
UUID agentID = client.AgentId;
|
||||||
lock (m_Friends)
|
lock (m_Friends)
|
||||||
{
|
{
|
||||||
|
|
|
@ -30,7 +30,6 @@ using System.Collections;
|
||||||
using System.Collections.Generic;
|
using System.Collections.Generic;
|
||||||
using System.Reflection;
|
using System.Reflection;
|
||||||
using System.Threading;
|
using System.Threading;
|
||||||
|
|
||||||
using log4net;
|
using log4net;
|
||||||
using Nini.Config;
|
using Nini.Config;
|
||||||
using Nwc.XmlRpc;
|
using Nwc.XmlRpc;
|
||||||
|
@ -84,9 +83,11 @@ namespace OpenSim.Region.CoreModules.Avatar.Friends
|
||||||
|
|
||||||
#endregion
|
#endregion
|
||||||
|
|
||||||
protected override bool FetchFriendslist(IClientAPI client)
|
protected override bool CacheFriends(IClientAPI client)
|
||||||
{
|
{
|
||||||
if (base.FetchFriendslist(client))
|
// m_log.DebugFormat("[HGFRIENDS MODULE]: Entered CacheFriends for {0}", client.Name);
|
||||||
|
|
||||||
|
if (base.CacheFriends(client))
|
||||||
{
|
{
|
||||||
UUID agentID = client.AgentId;
|
UUID agentID = client.AgentId;
|
||||||
// we do this only for the root agent
|
// we do this only for the root agent
|
||||||
|
@ -110,14 +111,20 @@ namespace OpenSim.Region.CoreModules.Avatar.Friends
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// m_log.DebugFormat("[HGFRIENDS MODULE]: Exiting CacheFriends for {0} since detected root agent", client.Name);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// m_log.DebugFormat("[HGFRIENDS MODULE]: Exiting CacheFriends for {0} since detected not root agent", client.Name);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
public override bool SendFriendsOnlineIfNeeded(IClientAPI client)
|
public override bool SendFriendsOnlineIfNeeded(IClientAPI client)
|
||||||
{
|
{
|
||||||
|
// m_log.DebugFormat("[HGFRIENDS MODULE]: Entering SendFriendsOnlineIfNeeded for {0}", client.Name);
|
||||||
|
|
||||||
if (base.SendFriendsOnlineIfNeeded(client))
|
if (base.SendFriendsOnlineIfNeeded(client))
|
||||||
{
|
{
|
||||||
AgentCircuitData aCircuit = ((Scene)client.Scene).AuthenticateHandler.GetAgentCircuitData(client.AgentId);
|
AgentCircuitData aCircuit = ((Scene)client.Scene).AuthenticateHandler.GetAgentCircuitData(client.AgentId);
|
||||||
|
@ -134,11 +141,15 @@ namespace OpenSim.Region.CoreModules.Avatar.Friends
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// m_log.DebugFormat("[HGFRIENDS MODULE]: Exiting SendFriendsOnlineIfNeeded for {0}", client.Name);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
protected override void GetOnlineFriends(UUID userID, List<string> friendList, /*collector*/ List<UUID> online)
|
protected override void GetOnlineFriends(UUID userID, List<string> friendList, /*collector*/ List<UUID> online)
|
||||||
{
|
{
|
||||||
|
// m_log.DebugFormat("[HGFRIENDS MODULE]: Entering GetOnlineFriends for {0}", userID);
|
||||||
|
|
||||||
List<string> fList = new List<string>();
|
List<string> fList = new List<string>();
|
||||||
foreach (string s in friendList)
|
foreach (string s in friendList)
|
||||||
{
|
{
|
||||||
|
@ -157,6 +168,8 @@ namespace OpenSim.Region.CoreModules.Avatar.Friends
|
||||||
if (UUID.TryParse(pi.UserID, out presenceID))
|
if (UUID.TryParse(pi.UserID, out presenceID))
|
||||||
online.Add(presenceID);
|
online.Add(presenceID);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// m_log.DebugFormat("[HGFRIENDS MODULE]: Exiting GetOnlineFriends for {0}", userID);
|
||||||
}
|
}
|
||||||
|
|
||||||
//protected override void GetOnlineFriends(UUID userID, List<string> friendList, /*collector*/ List<UUID> online)
|
//protected override void GetOnlineFriends(UUID userID, List<string> friendList, /*collector*/ List<UUID> online)
|
||||||
|
@ -246,6 +259,8 @@ namespace OpenSim.Region.CoreModules.Avatar.Friends
|
||||||
|
|
||||||
protected override void StatusNotify(List<FriendInfo> friendList, UUID userID, bool online)
|
protected override void StatusNotify(List<FriendInfo> friendList, UUID userID, bool online)
|
||||||
{
|
{
|
||||||
|
// m_log.DebugFormat("[HGFRIENDS MODULE]: Entering StatusNotify for {0}", userID);
|
||||||
|
|
||||||
// First, let's divide the friends on a per-domain basis
|
// First, let's divide the friends on a per-domain basis
|
||||||
Dictionary<string, List<FriendInfo>> friendsPerDomain = new Dictionary<string, List<FriendInfo>>();
|
Dictionary<string, List<FriendInfo>> friendsPerDomain = new Dictionary<string, List<FriendInfo>>();
|
||||||
foreach (FriendInfo friend in friendList)
|
foreach (FriendInfo friend in friendList)
|
||||||
|
@ -298,6 +313,8 @@ namespace OpenSim.Region.CoreModules.Avatar.Friends
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// m_log.DebugFormat("[HGFRIENDS MODULE]: Exiting StatusNotify for {0}", userID);
|
||||||
}
|
}
|
||||||
|
|
||||||
protected override bool GetAgentInfo(UUID scopeID, string fid, out UUID agentID, out string first, out string last)
|
protected override bool GetAgentInfo(UUID scopeID, string fid, out UUID agentID, out string first, out string last)
|
||||||
|
@ -351,6 +368,8 @@ namespace OpenSim.Region.CoreModules.Avatar.Friends
|
||||||
|
|
||||||
protected override FriendInfo[] GetFriendsFromService(IClientAPI client)
|
protected override FriendInfo[] GetFriendsFromService(IClientAPI client)
|
||||||
{
|
{
|
||||||
|
// m_log.DebugFormat("[HGFRIENDS MODULE]: Entering GetFriendsFromService for {0}", client.Name);
|
||||||
|
|
||||||
UserAccount account1 = UserAccountService.GetUserAccount(m_Scenes[0].RegionInfo.ScopeID, client.AgentId);
|
UserAccount account1 = UserAccountService.GetUserAccount(m_Scenes[0].RegionInfo.ScopeID, client.AgentId);
|
||||||
if (account1 != null)
|
if (account1 != null)
|
||||||
return base.GetFriendsFromService(client);
|
return base.GetFriendsFromService(client);
|
||||||
|
@ -365,6 +384,9 @@ namespace OpenSim.Region.CoreModules.Avatar.Friends
|
||||||
finfos = FriendsService.GetFriends(agentUUI);
|
finfos = FriendsService.GetFriends(agentUUI);
|
||||||
m_log.DebugFormat("[HGFRIENDS MODULE]: Fetched {0} local friends for visitor {1}", finfos.Length, agentUUI);
|
m_log.DebugFormat("[HGFRIENDS MODULE]: Fetched {0} local friends for visitor {1}", finfos.Length, agentUUI);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// m_log.DebugFormat("[HGFRIENDS MODULE]: Exiting GetFriendsFromService for {0}", client.Name);
|
||||||
|
|
||||||
return finfos;
|
return finfos;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -401,7 +423,6 @@ namespace OpenSim.Region.CoreModules.Avatar.Friends
|
||||||
}
|
}
|
||||||
|
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
protected override void StoreBackwards(UUID friendID, UUID agentID)
|
protected override void StoreBackwards(UUID friendID, UUID agentID)
|
||||||
|
|
|
@ -71,12 +71,12 @@ namespace OpenSim.Region.CoreModules.Avatar.Friends.Tests
|
||||||
|
|
||||||
ScenePresence sp = SceneHelpers.AddScenePresence(m_scene, userId);
|
ScenePresence sp = SceneHelpers.AddScenePresence(m_scene, userId);
|
||||||
|
|
||||||
Assert.That(((TestClient)sp.ControllingClient).OfflineNotificationsReceived.Count, Is.EqualTo(0));
|
Assert.That(((TestClient)sp.ControllingClient).ReceivedOfflineNotifications.Count, Is.EqualTo(0));
|
||||||
Assert.That(((TestClient)sp.ControllingClient).OnlineNotificationsReceived.Count, Is.EqualTo(0));
|
Assert.That(((TestClient)sp.ControllingClient).ReceivedOnlineNotifications.Count, Is.EqualTo(0));
|
||||||
}
|
}
|
||||||
|
|
||||||
[Test]
|
[Test]
|
||||||
public void TestAddFriendWhileOnline()
|
public void TestAddFriendshipWhileOnline()
|
||||||
{
|
{
|
||||||
TestHelpers.InMethod();
|
TestHelpers.InMethod();
|
||||||
// log4net.Config.XmlConfigurator.Configure();
|
// log4net.Config.XmlConfigurator.Configure();
|
||||||
|
@ -91,8 +91,28 @@ namespace OpenSim.Region.CoreModules.Avatar.Friends.Tests
|
||||||
// notification.
|
// notification.
|
||||||
m_fm.AddFriendship(sp.ControllingClient, user2Id);
|
m_fm.AddFriendship(sp.ControllingClient, user2Id);
|
||||||
|
|
||||||
Assert.That(((TestClient)sp.ControllingClient).OfflineNotificationsReceived.Count, Is.EqualTo(0));
|
Assert.That(((TestClient)sp.ControllingClient).ReceivedOfflineNotifications.Count, Is.EqualTo(0));
|
||||||
Assert.That(((TestClient)sp.ControllingClient).OnlineNotificationsReceived.Count, Is.EqualTo(1));
|
Assert.That(((TestClient)sp.ControllingClient).ReceivedOnlineNotifications.Count, Is.EqualTo(1));
|
||||||
|
}
|
||||||
|
|
||||||
|
[Test]
|
||||||
|
public void TestRemoveFriendshipWhileOnline()
|
||||||
|
{
|
||||||
|
TestHelpers.InMethod();
|
||||||
|
// log4net.Config.XmlConfigurator.Configure();
|
||||||
|
|
||||||
|
UUID user1Id = TestHelpers.ParseTail(0x1);
|
||||||
|
UUID user2Id = TestHelpers.ParseTail(0x2);
|
||||||
|
|
||||||
|
ScenePresence sp = SceneHelpers.AddScenePresence(m_scene, user1Id);
|
||||||
|
SceneHelpers.AddScenePresence(m_scene, user2Id);
|
||||||
|
|
||||||
|
m_fm.AddFriendship(sp.ControllingClient, user2Id);
|
||||||
|
m_fm.RemoveFriendship(sp.ControllingClient, user2Id);
|
||||||
|
|
||||||
|
TestClient user1Client = sp.ControllingClient as TestClient;
|
||||||
|
Assert.That(user1Client.ReceivedFriendshipTerminations.Count, Is.EqualTo(1));
|
||||||
|
Assert.That(user1Client.ReceivedFriendshipTerminations[0], Is.EqualTo(user2Id));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
|
@ -31,7 +31,6 @@ using System.Reflection;
|
||||||
|
|
||||||
using OpenSim.Framework;
|
using OpenSim.Framework;
|
||||||
using OpenSim.Framework.Console;
|
using OpenSim.Framework.Console;
|
||||||
|
|
||||||
using OpenSim.Region.Framework;
|
using OpenSim.Region.Framework;
|
||||||
using OpenSim.Region.Framework.Interfaces;
|
using OpenSim.Region.Framework.Interfaces;
|
||||||
using OpenSim.Region.Framework.Scenes;
|
using OpenSim.Region.Framework.Scenes;
|
||||||
|
@ -44,13 +43,13 @@ using Nini.Config;
|
||||||
|
|
||||||
namespace OpenSim.Region.CoreModules.Framework.UserManagement
|
namespace OpenSim.Region.CoreModules.Framework.UserManagement
|
||||||
{
|
{
|
||||||
struct UserData
|
class UserData
|
||||||
{
|
{
|
||||||
public UUID Id;
|
public UUID Id { get; set; }
|
||||||
public string FirstName;
|
public string FirstName { get; set; }
|
||||||
public string LastName;
|
public string LastName { get; set; }
|
||||||
public string HomeURL;
|
public string HomeURL { get; set; }
|
||||||
public Dictionary<string, object> ServerURLs;
|
public Dictionary<string, object> ServerURLs { get; set; }
|
||||||
}
|
}
|
||||||
|
|
||||||
public class UserManagementModule : ISharedRegionModule, IUserManagement
|
public class UserManagementModule : ISharedRegionModule, IUserManagement
|
||||||
|
@ -130,7 +129,9 @@ namespace OpenSim.Region.CoreModules.Framework.UserManagement
|
||||||
public void Close()
|
public void Close()
|
||||||
{
|
{
|
||||||
m_Scenes.Clear();
|
m_Scenes.Clear();
|
||||||
m_UserCache.Clear();
|
|
||||||
|
lock (m_UserCache)
|
||||||
|
m_UserCache.Clear();
|
||||||
}
|
}
|
||||||
|
|
||||||
#endregion ISharedRegionModule
|
#endregion ISharedRegionModule
|
||||||
|
@ -188,11 +189,14 @@ namespace OpenSim.Region.CoreModules.Framework.UserManagement
|
||||||
{
|
{
|
||||||
string[] returnstring = new string[2];
|
string[] returnstring = new string[2];
|
||||||
|
|
||||||
if (m_UserCache.ContainsKey(uuid))
|
lock (m_UserCache)
|
||||||
{
|
{
|
||||||
returnstring[0] = m_UserCache[uuid].FirstName;
|
if (m_UserCache.ContainsKey(uuid))
|
||||||
returnstring[1] = m_UserCache[uuid].LastName;
|
{
|
||||||
return returnstring;
|
returnstring[0] = m_UserCache[uuid].FirstName;
|
||||||
|
returnstring[1] = m_UserCache[uuid].LastName;
|
||||||
|
return returnstring;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
UserAccount account = m_Scenes[0].UserAccountService.GetUserAccount(UUID.Zero, uuid);
|
UserAccount account = m_Scenes[0].UserAccountService.GetUserAccount(UUID.Zero, uuid);
|
||||||
|
@ -237,22 +241,36 @@ namespace OpenSim.Region.CoreModules.Framework.UserManagement
|
||||||
|
|
||||||
public string GetUserHomeURL(UUID userID)
|
public string GetUserHomeURL(UUID userID)
|
||||||
{
|
{
|
||||||
if (m_UserCache.ContainsKey(userID))
|
lock (m_UserCache)
|
||||||
return m_UserCache[userID].HomeURL;
|
{
|
||||||
|
if (m_UserCache.ContainsKey(userID))
|
||||||
|
return m_UserCache[userID].HomeURL;
|
||||||
|
}
|
||||||
|
|
||||||
return string.Empty;
|
return string.Empty;
|
||||||
}
|
}
|
||||||
|
|
||||||
public string GetUserServerURL(UUID userID, string serverType)
|
public string GetUserServerURL(UUID userID, string serverType)
|
||||||
{
|
{
|
||||||
if (m_UserCache.ContainsKey(userID))
|
UserData userdata;
|
||||||
{
|
lock (m_UserCache)
|
||||||
UserData userdata = m_UserCache[userID];
|
m_UserCache.TryGetValue(userID, out userdata);
|
||||||
if (userdata.ServerURLs != null && userdata.ServerURLs.ContainsKey(serverType) && userdata.ServerURLs[serverType] != null)
|
|
||||||
return userdata.ServerURLs[serverType].ToString();
|
|
||||||
|
|
||||||
if (userdata.HomeURL != string.Empty)
|
if (userdata != null)
|
||||||
|
{
|
||||||
|
// m_log.DebugFormat("[USER MANAGEMENT MODULE]: Requested url type {0} for {1}", serverType, userID);
|
||||||
|
|
||||||
|
if (userdata.ServerURLs != null && userdata.ServerURLs.ContainsKey(serverType) && userdata.ServerURLs[serverType] != null)
|
||||||
{
|
{
|
||||||
|
return userdata.ServerURLs[serverType].ToString();
|
||||||
|
}
|
||||||
|
|
||||||
|
if (userdata.HomeURL != null && userdata.HomeURL != string.Empty)
|
||||||
|
{
|
||||||
|
m_log.DebugFormat(
|
||||||
|
"[USER MANAGEMENT MODULE]: Did not find url type {0} so requesting urls from '{1}' for {2}",
|
||||||
|
serverType, userdata.HomeURL, userID);
|
||||||
|
|
||||||
UserAgentServiceConnector uConn = new UserAgentServiceConnector(userdata.HomeURL);
|
UserAgentServiceConnector uConn = new UserAgentServiceConnector(userdata.HomeURL);
|
||||||
userdata.ServerURLs = uConn.GetServerURLs(userID);
|
userdata.ServerURLs = uConn.GetServerURLs(userID);
|
||||||
if (userdata.ServerURLs != null && userdata.ServerURLs.ContainsKey(serverType) && userdata.ServerURLs[serverType] != null)
|
if (userdata.ServerURLs != null && userdata.ServerURLs.ContainsKey(serverType) && userdata.ServerURLs[serverType] != null)
|
||||||
|
@ -269,9 +287,12 @@ namespace OpenSim.Region.CoreModules.Framework.UserManagement
|
||||||
if (account != null)
|
if (account != null)
|
||||||
return userID.ToString();
|
return userID.ToString();
|
||||||
|
|
||||||
if (m_UserCache.ContainsKey(userID))
|
UserData ud;
|
||||||
|
lock (m_UserCache)
|
||||||
|
m_UserCache.TryGetValue(userID, out ud);
|
||||||
|
|
||||||
|
if (ud != null)
|
||||||
{
|
{
|
||||||
UserData ud = m_UserCache[userID];
|
|
||||||
string homeURL = ud.HomeURL;
|
string homeURL = ud.HomeURL;
|
||||||
string first = ud.FirstName, last = ud.LastName;
|
string first = ud.FirstName, last = ud.LastName;
|
||||||
if (ud.LastName.StartsWith("@"))
|
if (ud.LastName.StartsWith("@"))
|
||||||
|
@ -291,8 +312,11 @@ namespace OpenSim.Region.CoreModules.Framework.UserManagement
|
||||||
|
|
||||||
public void AddUser(UUID uuid, string first, string last)
|
public void AddUser(UUID uuid, string first, string last)
|
||||||
{
|
{
|
||||||
if (m_UserCache.ContainsKey(uuid))
|
lock (m_UserCache)
|
||||||
return;
|
{
|
||||||
|
if (m_UserCache.ContainsKey(uuid))
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
UserData user = new UserData();
|
UserData user = new UserData();
|
||||||
user.Id = uuid;
|
user.Id = uuid;
|
||||||
|
@ -310,8 +334,11 @@ namespace OpenSim.Region.CoreModules.Framework.UserManagement
|
||||||
|
|
||||||
public void AddUser(UUID id, string creatorData)
|
public void AddUser(UUID id, string creatorData)
|
||||||
{
|
{
|
||||||
if (m_UserCache.ContainsKey(id))
|
lock (m_UserCache)
|
||||||
return;
|
{
|
||||||
|
if (m_UserCache.ContainsKey(id))
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
// m_log.DebugFormat("[USER MANAGEMENT MODULE]: Adding user with id {0}, craetorData {1}", id, creatorData);
|
// m_log.DebugFormat("[USER MANAGEMENT MODULE]: Adding user with id {0}, craetorData {1}", id, creatorData);
|
||||||
|
|
||||||
|
@ -402,22 +429,24 @@ namespace OpenSim.Region.CoreModules.Framework.UserManagement
|
||||||
|
|
||||||
private void HandleShowUsers(string module, string[] cmd)
|
private void HandleShowUsers(string module, string[] cmd)
|
||||||
{
|
{
|
||||||
if (m_UserCache.Count == 0)
|
lock (m_UserCache)
|
||||||
{
|
{
|
||||||
MainConsole.Instance.Output("No users not found");
|
if (m_UserCache.Count == 0)
|
||||||
|
{
|
||||||
|
MainConsole.Instance.Output("No users not found");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
MainConsole.Instance.Output("UUID User Name");
|
||||||
|
MainConsole.Instance.Output("-----------------------------------------------------------------------------");
|
||||||
|
foreach (KeyValuePair<UUID, UserData> kvp in m_UserCache)
|
||||||
|
{
|
||||||
|
MainConsole.Instance.Output(String.Format("{0} {1} {2}",
|
||||||
|
kvp.Key, kvp.Value.FirstName, kvp.Value.LastName));
|
||||||
|
}
|
||||||
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
MainConsole.Instance.Output("UUID User Name");
|
|
||||||
MainConsole.Instance.Output("-----------------------------------------------------------------------------");
|
|
||||||
foreach (KeyValuePair<UUID, UserData> kvp in m_UserCache)
|
|
||||||
{
|
|
||||||
MainConsole.Instance.Output(String.Format("{0} {1} {2}",
|
|
||||||
kvp.Key, kvp.Value.FirstName, kvp.Value.LastName));
|
|
||||||
}
|
|
||||||
return;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
|
@ -480,7 +480,6 @@ namespace OpenSim.Region.CoreModules.World.Permissions
|
||||||
|
|
||||||
protected bool IsFriendWithPerms(UUID user,UUID objectOwner)
|
protected bool IsFriendWithPerms(UUID user,UUID objectOwner)
|
||||||
{
|
{
|
||||||
|
|
||||||
if (user == UUID.Zero)
|
if (user == UUID.Zero)
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
|
|
|
@ -65,7 +65,6 @@ namespace OpenSim.Region.CoreModules.World.WorldMap
|
||||||
|
|
||||||
private OpenSim.Framework.BlockingQueue<MapRequestState> requests = new OpenSim.Framework.BlockingQueue<MapRequestState>();
|
private OpenSim.Framework.BlockingQueue<MapRequestState> requests = new OpenSim.Framework.BlockingQueue<MapRequestState>();
|
||||||
|
|
||||||
//private IConfig m_config;
|
|
||||||
protected Scene m_scene;
|
protected Scene m_scene;
|
||||||
private List<MapBlockData> cachedMapBlocks = new List<MapBlockData>();
|
private List<MapBlockData> cachedMapBlocks = new List<MapBlockData>();
|
||||||
private int cachedTime = 0;
|
private int cachedTime = 0;
|
||||||
|
@ -348,7 +347,11 @@ namespace OpenSim.Region.CoreModules.World.WorldMap
|
||||||
|
|
||||||
// m_log.Debug("[WORLD MAP]: Starting remote MapItem request thread");
|
// m_log.Debug("[WORLD MAP]: Starting remote MapItem request thread");
|
||||||
|
|
||||||
Watchdog.StartThread(process, "MapItemRequestThread", ThreadPriority.BelowNormal, true);
|
Watchdog.StartThread(
|
||||||
|
process,
|
||||||
|
string.Format("MapItemRequestThread ({0})", m_scene.RegionInfo.RegionName),
|
||||||
|
ThreadPriority.BelowNormal,
|
||||||
|
true);
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
|
@ -357,7 +360,7 @@ namespace OpenSim.Region.CoreModules.World.WorldMap
|
||||||
private void StopThread()
|
private void StopThread()
|
||||||
{
|
{
|
||||||
MapRequestState st = new MapRequestState();
|
MapRequestState st = new MapRequestState();
|
||||||
st.agentID=STOP_UUID;
|
st.agentID = STOP_UUID;
|
||||||
st.EstateID=0;
|
st.EstateID=0;
|
||||||
st.flags=0;
|
st.flags=0;
|
||||||
st.godlike=false;
|
st.godlike=false;
|
||||||
|
|
|
@ -44,6 +44,17 @@ namespace OpenSim.Region.Framework.Interfaces
|
||||||
/// <param name="friendID"></param>
|
/// <param name="friendID"></param>
|
||||||
void AddFriendship(IClientAPI client, UUID friendID);
|
void AddFriendship(IClientAPI client, UUID friendID);
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Remove a friendship between two users.
|
||||||
|
/// </summary>
|
||||||
|
/// <remarks>
|
||||||
|
/// Ultimately, it would be more useful to take in a user account here rather than having to have a user
|
||||||
|
/// present in the scene.
|
||||||
|
/// </remarks>
|
||||||
|
/// <param name="client"></param>
|
||||||
|
/// <param name="exFriendID"></param>
|
||||||
|
void RemoveFriendship(IClientAPI client, UUID exFriendID);
|
||||||
|
|
||||||
uint GetFriendPerms(UUID PrincipalID, UUID FriendID);
|
uint GetFriendPerms(UUID PrincipalID, UUID FriendID);
|
||||||
bool SendFriendsOnlineIfNeeded(IClientAPI client);
|
bool SendFriendsOnlineIfNeeded(IClientAPI client);
|
||||||
}
|
}
|
||||||
|
|
|
@ -103,7 +103,11 @@ namespace OpenSim.Region.Framework.Scenes
|
||||||
public virtual uint LocalId
|
public virtual uint LocalId
|
||||||
{
|
{
|
||||||
get { return m_localId; }
|
get { return m_localId; }
|
||||||
set { m_localId = value; }
|
set
|
||||||
|
{
|
||||||
|
m_localId = value;
|
||||||
|
// m_log.DebugFormat("[ENTITY BASE]: Set part {0} to local id {1}", Name, m_localId);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
|
|
|
@ -79,7 +79,7 @@ namespace OpenSim.Region.Framework.Scenes
|
||||||
{
|
{
|
||||||
List<EntityBase> tmp = new List<EntityBase>();
|
List<EntityBase> tmp = new List<EntityBase>();
|
||||||
|
|
||||||
m_entities.ForEach(
|
ForEach(
|
||||||
delegate(EntityBase entity)
|
delegate(EntityBase entity)
|
||||||
{
|
{
|
||||||
if (entity is T)
|
if (entity is T)
|
||||||
|
@ -93,7 +93,7 @@ namespace OpenSim.Region.Framework.Scenes
|
||||||
public EntityBase[] GetEntities()
|
public EntityBase[] GetEntities()
|
||||||
{
|
{
|
||||||
List<EntityBase> tmp = new List<EntityBase>(m_entities.Count);
|
List<EntityBase> tmp = new List<EntityBase>(m_entities.Count);
|
||||||
m_entities.ForEach(delegate(EntityBase entity) { tmp.Add(entity); });
|
ForEach(delegate(EntityBase entity) { tmp.Add(entity); });
|
||||||
return tmp.ToArray();
|
return tmp.ToArray();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -77,8 +77,10 @@ namespace OpenSim.Region.Framework.Scenes
|
||||||
/// </summary>
|
/// </summary>
|
||||||
public event OnNewClientDelegate OnNewClient;
|
public event OnNewClientDelegate OnNewClient;
|
||||||
|
|
||||||
public delegate void OnClientLoginDelegate(IClientAPI client);
|
/// <summary>
|
||||||
public event OnClientLoginDelegate OnClientLogin;
|
/// Fired if the client entering this sim is doing so as a new login
|
||||||
|
/// </summary>
|
||||||
|
public event Action<IClientAPI> OnClientLogin;
|
||||||
|
|
||||||
public delegate void OnNewPresenceDelegate(ScenePresence presence);
|
public delegate void OnNewPresenceDelegate(ScenePresence presence);
|
||||||
|
|
||||||
|
@ -214,10 +216,15 @@ namespace OpenSim.Region.Framework.Scenes
|
||||||
public delegate void OnMakeChildAgentDelegate(ScenePresence presence);
|
public delegate void OnMakeChildAgentDelegate(ScenePresence presence);
|
||||||
public event OnMakeChildAgentDelegate OnMakeChildAgent;
|
public event OnMakeChildAgentDelegate OnMakeChildAgent;
|
||||||
|
|
||||||
public delegate void OnMakeRootAgentDelegate(ScenePresence presence);
|
|
||||||
public delegate void OnSaveNewWindlightProfileDelegate();
|
public delegate void OnSaveNewWindlightProfileDelegate();
|
||||||
public delegate void OnSendNewWindlightProfileTargetedDelegate(RegionLightShareData wl, UUID user);
|
public delegate void OnSendNewWindlightProfileTargetedDelegate(RegionLightShareData wl, UUID user);
|
||||||
public event OnMakeRootAgentDelegate OnMakeRootAgent;
|
|
||||||
|
/// <summary>
|
||||||
|
/// This event is on the critical path for transferring an avatar from one region to another. Try and do
|
||||||
|
/// as little work on this event as possible, or do work asynchronously.
|
||||||
|
/// </summary>
|
||||||
|
public event Action<ScenePresence> OnMakeRootAgent;
|
||||||
|
|
||||||
public event OnSendNewWindlightProfileTargetedDelegate OnSendNewWindlightProfileTargeted;
|
public event OnSendNewWindlightProfileTargetedDelegate OnSendNewWindlightProfileTargeted;
|
||||||
public event OnSaveNewWindlightProfileDelegate OnSaveNewWindlightProfile;
|
public event OnSaveNewWindlightProfileDelegate OnSaveNewWindlightProfile;
|
||||||
|
|
||||||
|
@ -655,10 +662,10 @@ namespace OpenSim.Region.Framework.Scenes
|
||||||
|
|
||||||
public void TriggerOnClientLogin(IClientAPI client)
|
public void TriggerOnClientLogin(IClientAPI client)
|
||||||
{
|
{
|
||||||
OnClientLoginDelegate handlerClientLogin = OnClientLogin;
|
Action<IClientAPI> handlerClientLogin = OnClientLogin;
|
||||||
if (handlerClientLogin != null)
|
if (handlerClientLogin != null)
|
||||||
{
|
{
|
||||||
foreach (OnClientLoginDelegate d in handlerClientLogin.GetInvocationList())
|
foreach (Action<IClientAPI> d in handlerClientLogin.GetInvocationList())
|
||||||
{
|
{
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
|
@ -1344,10 +1351,10 @@ namespace OpenSim.Region.Framework.Scenes
|
||||||
|
|
||||||
public void TriggerOnMakeRootAgent(ScenePresence presence)
|
public void TriggerOnMakeRootAgent(ScenePresence presence)
|
||||||
{
|
{
|
||||||
OnMakeRootAgentDelegate handlerMakeRootAgent = OnMakeRootAgent;
|
Action<ScenePresence> handlerMakeRootAgent = OnMakeRootAgent;
|
||||||
if (handlerMakeRootAgent != null)
|
if (handlerMakeRootAgent != null)
|
||||||
{
|
{
|
||||||
foreach (OnMakeRootAgentDelegate d in handlerMakeRootAgent.GetInvocationList())
|
foreach (Action<ScenePresence> d in handlerMakeRootAgent.GetInvocationList())
|
||||||
{
|
{
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
|
|
|
@ -1148,8 +1148,8 @@ namespace OpenSim.Region.Framework.Scenes
|
||||||
|
|
||||||
m_sceneGraph.Close();
|
m_sceneGraph.Close();
|
||||||
|
|
||||||
// De-register with region communications (events cleanup)
|
if (!GridService.DeregisterRegion(m_regInfo.RegionID))
|
||||||
UnRegisterRegionWithComms();
|
m_log.WarnFormat("[SCENE]: Deregister from grid failed for region {0}", m_regInfo.RegionName);
|
||||||
|
|
||||||
// call the base class Close method.
|
// call the base class Close method.
|
||||||
base.Close();
|
base.Close();
|
||||||
|
@ -1177,7 +1177,9 @@ namespace OpenSim.Region.Framework.Scenes
|
||||||
}
|
}
|
||||||
m_lastUpdate = Util.EnvironmentTickCount();
|
m_lastUpdate = Util.EnvironmentTickCount();
|
||||||
|
|
||||||
HeartbeatThread = Watchdog.StartThread(Heartbeat, "Heartbeat for region " + RegionInfo.RegionName, ThreadPriority.Normal, false);
|
HeartbeatThread
|
||||||
|
= Watchdog.StartThread(
|
||||||
|
Heartbeat, string.Format("Heartbeat ({0})", RegionInfo.RegionName), ThreadPriority.Normal, false);
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
|
@ -1663,8 +1665,6 @@ namespace OpenSim.Region.Framework.Scenes
|
||||||
/// <exception cref="System.Exception">Thrown if registration of the region itself fails.</exception>
|
/// <exception cref="System.Exception">Thrown if registration of the region itself fails.</exception>
|
||||||
public void RegisterRegionWithGrid()
|
public void RegisterRegionWithGrid()
|
||||||
{
|
{
|
||||||
RegisterCommsEvents();
|
|
||||||
|
|
||||||
m_sceneGridService.SetScene(this);
|
m_sceneGridService.SetScene(this);
|
||||||
|
|
||||||
GridRegion region = new GridRegion(RegionInfo);
|
GridRegion region = new GridRegion(RegionInfo);
|
||||||
|
@ -2665,11 +2665,12 @@ namespace OpenSim.Region.Framework.Scenes
|
||||||
// Send all scene object to the new client
|
// Send all scene object to the new client
|
||||||
Util.FireAndForget(delegate
|
Util.FireAndForget(delegate
|
||||||
{
|
{
|
||||||
Entities.ForEach(delegate(EntityBase e)
|
EntityBase[] entities = Entities.GetEntities();
|
||||||
|
foreach(EntityBase e in entities)
|
||||||
{
|
{
|
||||||
if (e != null && e is SceneObjectGroup)
|
if (e != null && e is SceneObjectGroup)
|
||||||
((SceneObjectGroup)e).SendFullUpdateToClient(client);
|
((SceneObjectGroup)e).SendFullUpdateToClient(client);
|
||||||
});
|
}
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -3331,40 +3332,6 @@ namespace OpenSim.Region.Framework.Scenes
|
||||||
|
|
||||||
#region RegionComms
|
#region RegionComms
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// Register the methods that should be invoked when this scene receives various incoming events
|
|
||||||
/// </summary>
|
|
||||||
public void RegisterCommsEvents()
|
|
||||||
{
|
|
||||||
m_sceneGridService.OnAvatarCrossingIntoRegion += AgentCrossing;
|
|
||||||
m_sceneGridService.OnCloseAgentConnection += IncomingCloseAgent;
|
|
||||||
//m_eventManager.OnRegionUp += OtherRegionUp;
|
|
||||||
//m_sceneGridService.OnChildAgentUpdate += IncomingChildAgentDataUpdate;
|
|
||||||
//m_sceneGridService.OnRemoveKnownRegionFromAvatar += HandleRemoveKnownRegionsFromAvatar;
|
|
||||||
m_sceneGridService.OnLogOffUser += HandleLogOffUserFromGrid;
|
|
||||||
m_sceneGridService.OnGetLandData += GetLandData;
|
|
||||||
}
|
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// Deregister this scene from receiving incoming region events
|
|
||||||
/// </summary>
|
|
||||||
public void UnRegisterRegionWithComms()
|
|
||||||
{
|
|
||||||
m_sceneGridService.OnLogOffUser -= HandleLogOffUserFromGrid;
|
|
||||||
//m_sceneGridService.OnRemoveKnownRegionFromAvatar -= HandleRemoveKnownRegionsFromAvatar;
|
|
||||||
//m_sceneGridService.OnChildAgentUpdate -= IncomingChildAgentDataUpdate;
|
|
||||||
//m_eventManager.OnRegionUp -= OtherRegionUp;
|
|
||||||
m_sceneGridService.OnAvatarCrossingIntoRegion -= AgentCrossing;
|
|
||||||
m_sceneGridService.OnCloseAgentConnection -= IncomingCloseAgent;
|
|
||||||
m_sceneGridService.OnGetLandData -= GetLandData;
|
|
||||||
|
|
||||||
// this does nothing; should be removed
|
|
||||||
m_sceneGridService.Close();
|
|
||||||
|
|
||||||
if (!GridService.DeregisterRegion(m_regInfo.RegionID))
|
|
||||||
m_log.WarnFormat("[SCENE]: Deregister from grid failed for region {0}", m_regInfo.RegionName);
|
|
||||||
}
|
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Do the work necessary to initiate a new user connection for a particular scene.
|
/// Do the work necessary to initiate a new user connection for a particular scene.
|
||||||
/// At the moment, this consists of setting up the caps infrastructure
|
/// At the moment, this consists of setting up the caps infrastructure
|
||||||
|
|
|
@ -56,88 +56,12 @@ namespace OpenSim.Region.Framework.Scenes
|
||||||
protected RegionInfo m_regionInfo;
|
protected RegionInfo m_regionInfo;
|
||||||
protected Scene m_scene;
|
protected Scene m_scene;
|
||||||
|
|
||||||
protected RegionCommsListener regionCommsHost;
|
|
||||||
|
|
||||||
protected List<UUID> m_agentsInTransit;
|
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// An agent is crossing into this region
|
|
||||||
/// </summary>
|
|
||||||
public event AgentCrossing OnAvatarCrossingIntoRegion;
|
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// A user will arrive shortly, set up appropriate credentials so it can connect
|
|
||||||
/// </summary>
|
|
||||||
// public event ExpectUserDelegate OnExpectUser;
|
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// A Prim will arrive shortly
|
|
||||||
/// </summary>
|
|
||||||
public event CloseAgentConnection OnCloseAgentConnection;
|
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// A new prim has arrived
|
|
||||||
/// </summary>
|
|
||||||
// public event PrimCrossing OnPrimCrossingIntoRegion;
|
|
||||||
|
|
||||||
///// <summary>
|
|
||||||
///// A New Region is up and available
|
|
||||||
///// </summary>
|
|
||||||
//public event RegionUp OnRegionUp;
|
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// We have a child agent for this avatar and we're getting a status update about it
|
|
||||||
/// </summary>
|
|
||||||
// public event ChildAgentUpdate OnChildAgentUpdate;
|
|
||||||
//public event RemoveKnownRegionsFromAvatarList OnRemoveKnownRegionFromAvatar;
|
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// Time to log one of our users off. Grid Service sends this mostly
|
|
||||||
/// </summary>
|
|
||||||
public event LogOffUser OnLogOffUser;
|
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// A region wants land data from us!
|
|
||||||
/// </summary>
|
|
||||||
public event GetLandData OnGetLandData;
|
|
||||||
|
|
||||||
// private AgentCrossing handlerAvatarCrossingIntoRegion = null; // OnAvatarCrossingIntoRegion;
|
|
||||||
// private ExpectUserDelegate handlerExpectUser = null; // OnExpectUser;
|
|
||||||
// private CloseAgentConnection handlerCloseAgentConnection = null; // OnCloseAgentConnection;
|
|
||||||
// private PrimCrossing handlerPrimCrossingIntoRegion = null; // OnPrimCrossingIntoRegion;
|
|
||||||
//private RegionUp handlerRegionUp = null; // OnRegionUp;
|
|
||||||
// private ChildAgentUpdate handlerChildAgentUpdate = null; // OnChildAgentUpdate;
|
|
||||||
//private RemoveKnownRegionsFromAvatarList handlerRemoveKnownRegionFromAvatar = null; // OnRemoveKnownRegionFromAvatar;
|
|
||||||
// private LogOffUser handlerLogOffUser = null;
|
|
||||||
// private GetLandData handlerGetLandData = null; // OnGetLandData
|
|
||||||
|
|
||||||
public SceneCommunicationService()
|
|
||||||
{
|
|
||||||
}
|
|
||||||
|
|
||||||
public void SetScene(Scene s)
|
public void SetScene(Scene s)
|
||||||
{
|
{
|
||||||
m_scene = s;
|
m_scene = s;
|
||||||
m_regionInfo = s.RegionInfo;
|
m_regionInfo = s.RegionInfo;
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// Register a region with the grid
|
|
||||||
/// </summary>
|
|
||||||
/// <param name="regionInfos"></param>
|
|
||||||
/// <exception cref="System.Exception">Thrown if region registration fails.</exception>
|
|
||||||
public void RegisterRegion(IInterregionCommsOut comms_out, RegionInfo regionInfos)
|
|
||||||
{
|
|
||||||
}
|
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// This region is shutting down, de-register all events!
|
|
||||||
/// De-Register region from Grid!
|
|
||||||
/// </summary>
|
|
||||||
public void Close()
|
|
||||||
{
|
|
||||||
}
|
|
||||||
|
|
||||||
public delegate void InformNeighbourThatRegionUpDelegate(INeighbourService nService, RegionInfo region, ulong regionhandle);
|
public delegate void InformNeighbourThatRegionUpDelegate(INeighbourService nService, RegionInfo region, ulong regionhandle);
|
||||||
|
|
||||||
private void InformNeighborsThatRegionisUpCompleted(IAsyncResult iar)
|
private void InformNeighborsThatRegionisUpCompleted(IAsyncResult iar)
|
||||||
|
@ -173,7 +97,6 @@ namespace OpenSim.Region.Framework.Scenes
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
public void InformNeighborsThatRegionisUp(INeighbourService neighbourService, RegionInfo region)
|
public void InformNeighborsThatRegionisUp(INeighbourService neighbourService, RegionInfo region)
|
||||||
{
|
{
|
||||||
//m_log.Info("[INTER]: " + debugRegionName + ": SceneCommunicationService: Sending InterRegion Notification that region is up " + region.RegionName);
|
//m_log.Info("[INTER]: " + debugRegionName + ": SceneCommunicationService: Sending InterRegion Notification that region is up " + region.RegionName);
|
||||||
|
@ -191,7 +114,6 @@ namespace OpenSim.Region.Framework.Scenes
|
||||||
|
|
||||||
public delegate void SendChildAgentDataUpdateDelegate(AgentPosition cAgentData, UUID scopeID, GridRegion dest);
|
public delegate void SendChildAgentDataUpdateDelegate(AgentPosition cAgentData, UUID scopeID, GridRegion dest);
|
||||||
|
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// This informs all neighboring regions about the settings of it's child agent.
|
/// This informs all neighboring regions about the settings of it's child agent.
|
||||||
/// Calls an asynchronous method to do so.. so it doesn't lag the sim.
|
/// Calls an asynchronous method to do so.. so it doesn't lag the sim.
|
||||||
|
@ -295,6 +217,5 @@ namespace OpenSim.Region.Framework.Scenes
|
||||||
{
|
{
|
||||||
return m_scene.GridService.GetRegionsByName(UUID.Zero, name, maxNumber);
|
return m_scene.GridService.GetRegionsByName(UUID.Zero, name, maxNumber);
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -533,7 +533,11 @@ namespace OpenSim.Region.Framework.Scenes
|
||||||
public uint LocalId
|
public uint LocalId
|
||||||
{
|
{
|
||||||
get { return m_localId; }
|
get { return m_localId; }
|
||||||
set { m_localId = value; }
|
set
|
||||||
|
{
|
||||||
|
m_localId = value;
|
||||||
|
// m_log.DebugFormat("[SCENE OBJECT PART]: Set part {0} to local id {1}", Name, m_localId);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public virtual string Name
|
public virtual string Name
|
||||||
|
|
|
@ -757,7 +757,7 @@ namespace OpenSim.Region.Framework.Scenes
|
||||||
m_name = String.Format("{0} {1}", Firstname, Lastname);
|
m_name = String.Format("{0} {1}", Firstname, Lastname);
|
||||||
m_scene = world;
|
m_scene = world;
|
||||||
m_uuid = client.AgentId;
|
m_uuid = client.AgentId;
|
||||||
m_localId = m_scene.AllocateLocalId();
|
LocalId = m_scene.AllocateLocalId();
|
||||||
|
|
||||||
UserAccount account = m_scene.UserAccountService.GetUserAccount(m_scene.RegionInfo.ScopeID, m_uuid);
|
UserAccount account = m_scene.UserAccountService.GetUserAccount(m_scene.RegionInfo.ScopeID, m_uuid);
|
||||||
if (account != null)
|
if (account != null)
|
||||||
|
@ -860,9 +860,15 @@ namespace OpenSim.Region.Framework.Scenes
|
||||||
#region Status Methods
|
#region Status Methods
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// This turns a child agent, into a root agent
|
/// Turns a child agent into a root agent.
|
||||||
/// This is called when an agent teleports into a region, or if an
|
/// </summary>
|
||||||
/// agent crosses into this region from a neighbor over the border
|
/// Child agents are logged into neighbouring sims largely to observe changes. Root agents exist when the
|
||||||
|
/// avatar is actual in the sim. They can perform all actions.
|
||||||
|
/// This change is made whenever an avatar enters a region, whether by crossing over from a neighbouring sim,
|
||||||
|
/// teleporting in or on initial login.
|
||||||
|
///
|
||||||
|
/// This method is on the critical path for transferring an avatar from one region to another. Delay here
|
||||||
|
/// delays that crossing.
|
||||||
/// </summary>
|
/// </summary>
|
||||||
public void MakeRootAgent(Vector3 pos, bool isFlying)
|
public void MakeRootAgent(Vector3 pos, bool isFlying)
|
||||||
{
|
{
|
||||||
|
|
|
@ -25,8 +25,10 @@
|
||||||
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
using log4net;
|
||||||
using System;
|
using System;
|
||||||
using System.Collections.Generic;
|
using System.Collections.Generic;
|
||||||
|
using System.Reflection;
|
||||||
using OpenSim.Framework;
|
using OpenSim.Framework;
|
||||||
using OpenMetaverse;
|
using OpenMetaverse;
|
||||||
|
|
||||||
|
@ -46,10 +48,10 @@ namespace OpenSim.Region.Physics.Manager
|
||||||
|
|
||||||
public enum PIDHoverType
|
public enum PIDHoverType
|
||||||
{
|
{
|
||||||
Ground
|
Ground,
|
||||||
, GroundAndWater
|
GroundAndWater,
|
||||||
, Water
|
Water,
|
||||||
, Absolute
|
Absolute
|
||||||
}
|
}
|
||||||
|
|
||||||
public struct ContactPoint
|
public struct ContactPoint
|
||||||
|
@ -114,6 +116,8 @@ namespace OpenSim.Region.Physics.Manager
|
||||||
|
|
||||||
public abstract class PhysicsActor
|
public abstract class PhysicsActor
|
||||||
{
|
{
|
||||||
|
// private static readonly ILog m_log = LogManager.GetLogger(MethodBase.GetCurrentMethod().DeclaringType);
|
||||||
|
|
||||||
public delegate void RequestTerseUpdate();
|
public delegate void RequestTerseUpdate();
|
||||||
public delegate void CollisionUpdate(EventArgs e);
|
public delegate void CollisionUpdate(EventArgs e);
|
||||||
public delegate void OutOfBounds(Vector3 pos);
|
public delegate void OutOfBounds(Vector3 pos);
|
||||||
|
@ -197,10 +201,10 @@ namespace OpenSim.Region.Physics.Manager
|
||||||
{
|
{
|
||||||
CollisionUpdate handler = OnCollisionUpdate;
|
CollisionUpdate handler = OnCollisionUpdate;
|
||||||
|
|
||||||
|
// m_log.DebugFormat("[PHYSICS ACTOR]: Sending collision for {0}", LocalID);
|
||||||
|
|
||||||
if (handler != null)
|
if (handler != null)
|
||||||
{
|
|
||||||
handler(e);
|
handler(e);
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public virtual void SetMaterial (int material)
|
public virtual void SetMaterial (int material)
|
||||||
|
|
|
@ -108,7 +108,6 @@ namespace OpenSim.Region.Physics.OdePlugin
|
||||||
/// </summary>
|
/// </summary>
|
||||||
private Vector3 m_taintForce;
|
private Vector3 m_taintForce;
|
||||||
|
|
||||||
internal uint m_localID = 0;
|
|
||||||
// taints and their non-tainted counterparts
|
// taints and their non-tainted counterparts
|
||||||
private bool m_isPhysical = false; // the current physical status
|
private bool m_isPhysical = false; // the current physical status
|
||||||
private bool m_tainted_isPhysical = false; // set when the physical status is tainted (false=not existing in physics engine, true=existing)
|
private bool m_tainted_isPhysical = false; // set when the physical status is tainted (false=not existing in physics engine, true=existing)
|
||||||
|
@ -231,11 +230,6 @@ namespace OpenSim.Region.Physics.OdePlugin
|
||||||
set { m_alwaysRun = value; }
|
set { m_alwaysRun = value; }
|
||||||
}
|
}
|
||||||
|
|
||||||
public override uint LocalID
|
|
||||||
{
|
|
||||||
set { m_localID = value; }
|
|
||||||
}
|
|
||||||
|
|
||||||
public override bool Grabbed
|
public override bool Grabbed
|
||||||
{
|
{
|
||||||
set { return; }
|
set { return; }
|
||||||
|
|
|
@ -142,8 +142,6 @@ namespace OpenSim.Region.Physics.OdePlugin
|
||||||
public bool m_taintselected { get; private set; }
|
public bool m_taintselected { get; private set; }
|
||||||
public bool m_taintCollidesWater { get; private set; }
|
public bool m_taintCollidesWater { get; private set; }
|
||||||
|
|
||||||
public uint m_localID { get; private set; }
|
|
||||||
|
|
||||||
private bool m_taintforce = false;
|
private bool m_taintforce = false;
|
||||||
private bool m_taintaddangularforce = false;
|
private bool m_taintaddangularforce = false;
|
||||||
private Vector3 m_force;
|
private Vector3 m_force;
|
||||||
|
@ -290,13 +288,6 @@ namespace OpenSim.Region.Physics.OdePlugin
|
||||||
set { return; }
|
set { return; }
|
||||||
}
|
}
|
||||||
|
|
||||||
public override uint LocalID
|
|
||||||
{
|
|
||||||
set {
|
|
||||||
//m_log.Info("[PHYSICS]: Setting TrackerID: " + value);
|
|
||||||
m_localID = value; }
|
|
||||||
}
|
|
||||||
|
|
||||||
public override bool Grabbed
|
public override bool Grabbed
|
||||||
{
|
{
|
||||||
set { return; }
|
set { return; }
|
||||||
|
@ -1058,7 +1049,7 @@ Console.WriteLine("ZProcessTaints for " + Name);
|
||||||
private void AddChildPrim(OdePrim prim)
|
private void AddChildPrim(OdePrim prim)
|
||||||
{
|
{
|
||||||
//Console.WriteLine("AddChildPrim " + Name);
|
//Console.WriteLine("AddChildPrim " + Name);
|
||||||
if (this.m_localID != prim.m_localID)
|
if (LocalID != prim.LocalID)
|
||||||
{
|
{
|
||||||
if (Body == IntPtr.Zero)
|
if (Body == IntPtr.Zero)
|
||||||
{
|
{
|
||||||
|
|
|
@ -378,12 +378,13 @@ namespace OpenSim.Region.Physics.OdePlugin
|
||||||
// Loop over contacts, build results.
|
// Loop over contacts, build results.
|
||||||
for (int i = 0; i < count; i++)
|
for (int i = 0; i < count; i++)
|
||||||
{
|
{
|
||||||
if (p1 != null) {
|
if (p1 != null)
|
||||||
|
{
|
||||||
if (p1 is OdePrim)
|
if (p1 is OdePrim)
|
||||||
{
|
{
|
||||||
ContactResult collisionresult = new ContactResult();
|
ContactResult collisionresult = new ContactResult();
|
||||||
|
|
||||||
collisionresult.ConsumerID = ((OdePrim)p1).m_localID;
|
collisionresult.ConsumerID = p1.LocalID;
|
||||||
collisionresult.Pos = new Vector3(contacts[i].pos.X, contacts[i].pos.Y, contacts[i].pos.Z);
|
collisionresult.Pos = new Vector3(contacts[i].pos.X, contacts[i].pos.Y, contacts[i].pos.Z);
|
||||||
collisionresult.Depth = contacts[i].depth;
|
collisionresult.Depth = contacts[i].depth;
|
||||||
collisionresult.Normal = new Vector3(contacts[i].normal.X, contacts[i].normal.Y,
|
collisionresult.Normal = new Vector3(contacts[i].normal.X, contacts[i].normal.Y,
|
||||||
|
@ -399,7 +400,7 @@ namespace OpenSim.Region.Physics.OdePlugin
|
||||||
{
|
{
|
||||||
ContactResult collisionresult = new ContactResult();
|
ContactResult collisionresult = new ContactResult();
|
||||||
|
|
||||||
collisionresult.ConsumerID = ((OdePrim)p2).m_localID;
|
collisionresult.ConsumerID = p2.LocalID;
|
||||||
collisionresult.Pos = new Vector3(contacts[i].pos.X, contacts[i].pos.Y, contacts[i].pos.Z);
|
collisionresult.Pos = new Vector3(contacts[i].pos.X, contacts[i].pos.Y, contacts[i].pos.Z);
|
||||||
collisionresult.Depth = contacts[i].depth;
|
collisionresult.Depth = contacts[i].depth;
|
||||||
collisionresult.Normal = new Vector3(contacts[i].normal.X, contacts[i].normal.Y,
|
collisionresult.Normal = new Vector3(contacts[i].normal.X, contacts[i].normal.Y,
|
||||||
|
|
|
@ -219,9 +219,14 @@ namespace OpenSim.Region.Physics.OdePlugin
|
||||||
private readonly List<d.ContactGeom> _perloopContact = new List<d.ContactGeom>();
|
private readonly List<d.ContactGeom> _perloopContact = new List<d.ContactGeom>();
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// A list of actors that should receive collision events.
|
/// A dictionary of actors that should receive collision events.
|
||||||
/// </summary>
|
/// </summary>
|
||||||
private readonly List<PhysicsActor> _collisionEventPrim = new List<PhysicsActor>();
|
private readonly Dictionary<uint, PhysicsActor> _collisionEventPrim = new Dictionary<uint, PhysicsActor>();
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// A dictionary of collision event changes that are waiting to be processed.
|
||||||
|
/// </summary>
|
||||||
|
private readonly Dictionary<uint, PhysicsActor> _collisionEventPrimChanges = new Dictionary<uint, PhysicsActor>();
|
||||||
|
|
||||||
private readonly HashSet<OdeCharacter> _badCharacter = new HashSet<OdeCharacter>();
|
private readonly HashSet<OdeCharacter> _badCharacter = new HashSet<OdeCharacter>();
|
||||||
public Dictionary<IntPtr, String> geom_name_map = new Dictionary<IntPtr, String>();
|
public Dictionary<IntPtr, String> geom_name_map = new Dictionary<IntPtr, String>();
|
||||||
|
@ -1301,8 +1306,8 @@ namespace OpenSim.Region.Physics.OdePlugin
|
||||||
{
|
{
|
||||||
case ActorTypes.Agent:
|
case ActorTypes.Agent:
|
||||||
cc1 = (OdeCharacter)p1;
|
cc1 = (OdeCharacter)p1;
|
||||||
obj2LocalID = cc1.m_localID;
|
obj2LocalID = cc1.LocalID;
|
||||||
cc1.AddCollisionEvent(cc2.m_localID, contact);
|
cc1.AddCollisionEvent(cc2.LocalID, contact);
|
||||||
//ctype = (int)CollisionCategories.Character;
|
//ctype = (int)CollisionCategories.Character;
|
||||||
|
|
||||||
//if (cc1.CollidingObj)
|
//if (cc1.CollidingObj)
|
||||||
|
@ -1317,8 +1322,8 @@ namespace OpenSim.Region.Physics.OdePlugin
|
||||||
if (p1 is OdePrim)
|
if (p1 is OdePrim)
|
||||||
{
|
{
|
||||||
cp1 = (OdePrim) p1;
|
cp1 = (OdePrim) p1;
|
||||||
obj2LocalID = cp1.m_localID;
|
obj2LocalID = cp1.LocalID;
|
||||||
cp1.AddCollisionEvent(cc2.m_localID, contact);
|
cp1.AddCollisionEvent(cc2.LocalID, contact);
|
||||||
}
|
}
|
||||||
//ctype = (int)CollisionCategories.Geom;
|
//ctype = (int)CollisionCategories.Geom;
|
||||||
|
|
||||||
|
@ -1354,8 +1359,8 @@ namespace OpenSim.Region.Physics.OdePlugin
|
||||||
if (p1 is OdeCharacter)
|
if (p1 is OdeCharacter)
|
||||||
{
|
{
|
||||||
cc1 = (OdeCharacter) p1;
|
cc1 = (OdeCharacter) p1;
|
||||||
obj2LocalID = cc1.m_localID;
|
obj2LocalID = cc1.LocalID;
|
||||||
cc1.AddCollisionEvent(cp2.m_localID, contact);
|
cc1.AddCollisionEvent(cp2.LocalID, contact);
|
||||||
//ctype = (int)CollisionCategories.Character;
|
//ctype = (int)CollisionCategories.Character;
|
||||||
|
|
||||||
//if (cc1.CollidingObj)
|
//if (cc1.CollidingObj)
|
||||||
|
@ -1370,8 +1375,8 @@ namespace OpenSim.Region.Physics.OdePlugin
|
||||||
if (p1 is OdePrim)
|
if (p1 is OdePrim)
|
||||||
{
|
{
|
||||||
cp1 = (OdePrim) p1;
|
cp1 = (OdePrim) p1;
|
||||||
obj2LocalID = cp1.m_localID;
|
obj2LocalID = cp1.LocalID;
|
||||||
cp1.AddCollisionEvent(cp2.m_localID, contact);
|
cp1.AddCollisionEvent(cp2.LocalID, contact);
|
||||||
//ctype = (int)CollisionCategories.Geom;
|
//ctype = (int)CollisionCategories.Geom;
|
||||||
|
|
||||||
//if (cp1.CollidingObj)
|
//if (cp1.CollidingObj)
|
||||||
|
@ -1633,13 +1638,10 @@ namespace OpenSim.Region.Physics.OdePlugin
|
||||||
/// <param name="obj"></param>
|
/// <param name="obj"></param>
|
||||||
internal void AddCollisionEventReporting(PhysicsActor obj)
|
internal void AddCollisionEventReporting(PhysicsActor obj)
|
||||||
{
|
{
|
||||||
// m_log.DebugFormat("[PHYSICS]: Adding {0} to collision event reporting", obj.SOPName);
|
// m_log.DebugFormat("[PHYSICS]: Adding {0} {1} to collision event reporting", obj.SOPName, obj.LocalID);
|
||||||
|
|
||||||
lock (_collisionEventPrim)
|
lock (_collisionEventPrimChanges)
|
||||||
{
|
_collisionEventPrimChanges[obj.LocalID] = obj;
|
||||||
if (!_collisionEventPrim.Contains(obj))
|
|
||||||
_collisionEventPrim.Add(obj);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
|
@ -1648,10 +1650,10 @@ namespace OpenSim.Region.Physics.OdePlugin
|
||||||
/// <param name="obj"></param>
|
/// <param name="obj"></param>
|
||||||
internal void RemoveCollisionEventReporting(PhysicsActor obj)
|
internal void RemoveCollisionEventReporting(PhysicsActor obj)
|
||||||
{
|
{
|
||||||
// m_log.DebugFormat("[PHYSICS]: Removing {0} from collision event reporting", obj.SOPName);
|
// m_log.DebugFormat("[PHYSICS]: Removing {0} {1} from collision event reporting", obj.SOPName, obj.LocalID);
|
||||||
|
|
||||||
lock (_collisionEventPrim)
|
lock (_collisionEventPrimChanges)
|
||||||
_collisionEventPrim.Remove(obj);
|
_collisionEventPrimChanges[obj.LocalID] = null;
|
||||||
}
|
}
|
||||||
|
|
||||||
#region Add/Remove Entities
|
#region Add/Remove Entities
|
||||||
|
@ -1752,9 +1754,7 @@ namespace OpenSim.Region.Physics.OdePlugin
|
||||||
public override PhysicsActor AddPrimShape(string primName, PrimitiveBaseShape pbs, Vector3 position,
|
public override PhysicsActor AddPrimShape(string primName, PrimitiveBaseShape pbs, Vector3 position,
|
||||||
Vector3 size, Quaternion rotation, bool isPhysical, uint localid)
|
Vector3 size, Quaternion rotation, bool isPhysical, uint localid)
|
||||||
{
|
{
|
||||||
#if SPAM
|
// m_log.DebugFormat("[ODE SCENE]: Adding physics actor to {0} {1}", primName, localid);
|
||||||
m_log.DebugFormat("[PHYSICS]: Adding physics actor to {0}", primName);
|
|
||||||
#endif
|
|
||||||
|
|
||||||
return AddPrim(primName, position, size, rotation, pbs, isPhysical, localid);
|
return AddPrim(primName, position, size, rotation, pbs, isPhysical, localid);
|
||||||
}
|
}
|
||||||
|
@ -2663,6 +2663,22 @@ Console.WriteLine("AddPhysicsActorTaint to " + taintedprim.Name);
|
||||||
// m_physicsiterations = 10;
|
// m_physicsiterations = 10;
|
||||||
// }
|
// }
|
||||||
|
|
||||||
|
// We change _collisionEventPrimChanges to avoid locking _collisionEventPrim itself and causing potential
|
||||||
|
// deadlock if the collision event tries to lock something else later on which is already locked by a
|
||||||
|
// caller that is adding or removing the collision event.
|
||||||
|
lock (_collisionEventPrimChanges)
|
||||||
|
{
|
||||||
|
foreach (KeyValuePair<uint, PhysicsActor> kvp in _collisionEventPrimChanges)
|
||||||
|
{
|
||||||
|
if (kvp.Value == null)
|
||||||
|
_collisionEventPrim.Remove(kvp.Key);
|
||||||
|
else
|
||||||
|
_collisionEventPrim[kvp.Key] = kvp.Value;
|
||||||
|
}
|
||||||
|
|
||||||
|
_collisionEventPrimChanges.Clear();
|
||||||
|
}
|
||||||
|
|
||||||
if (SupportsNINJAJoints)
|
if (SupportsNINJAJoints)
|
||||||
{
|
{
|
||||||
DeleteRequestedJoints(); // this must be outside of the lock (OdeLock) to avoid deadlocks
|
DeleteRequestedJoints(); // this must be outside of the lock (OdeLock) to avoid deadlocks
|
||||||
|
@ -2790,25 +2806,22 @@ Console.WriteLine("AddPhysicsActorTaint to " + taintedprim.Name);
|
||||||
|
|
||||||
collision_optimized();
|
collision_optimized();
|
||||||
|
|
||||||
lock (_collisionEventPrim)
|
foreach (PhysicsActor obj in _collisionEventPrim.Values)
|
||||||
{
|
{
|
||||||
foreach (PhysicsActor obj in _collisionEventPrim)
|
// m_log.DebugFormat("[PHYSICS]: Assessing {0} {1} for collision events", obj.SOPName, obj.LocalID);
|
||||||
|
|
||||||
|
switch ((ActorTypes)obj.PhysicsActorType)
|
||||||
{
|
{
|
||||||
// m_log.DebugFormat("[PHYSICS]: Assessing {0} for collision events", obj.SOPName);
|
case ActorTypes.Agent:
|
||||||
|
OdeCharacter cobj = (OdeCharacter)obj;
|
||||||
|
cobj.AddCollisionFrameTime(100);
|
||||||
|
cobj.SendCollisions();
|
||||||
|
break;
|
||||||
|
|
||||||
switch ((ActorTypes)obj.PhysicsActorType)
|
case ActorTypes.Prim:
|
||||||
{
|
OdePrim pobj = (OdePrim)obj;
|
||||||
case ActorTypes.Agent:
|
pobj.SendCollisions();
|
||||||
OdeCharacter cobj = (OdeCharacter)obj;
|
break;
|
||||||
cobj.AddCollisionFrameTime(100);
|
|
||||||
cobj.SendCollisions();
|
|
||||||
break;
|
|
||||||
|
|
||||||
case ActorTypes.Prim:
|
|
||||||
OdePrim pobj = (OdePrim)obj;
|
|
||||||
pobj.SendCollisions();
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -3731,7 +3744,7 @@ Console.WriteLine("AddPhysicsActorTaint to " + taintedprim.Name);
|
||||||
{
|
{
|
||||||
if (prm.CollisionScore > 0)
|
if (prm.CollisionScore > 0)
|
||||||
{
|
{
|
||||||
returncolliders.Add(prm.m_localID, prm.CollisionScore);
|
returncolliders.Add(prm.LocalID, prm.CollisionScore);
|
||||||
cnt++;
|
cnt++;
|
||||||
prm.CollisionScore = 0f;
|
prm.CollisionScore = 0f;
|
||||||
if (cnt > 25)
|
if (cnt > 25)
|
||||||
|
|
|
@ -104,7 +104,7 @@ namespace OpenSim.Region.Physics.OdePlugin.Tests
|
||||||
m_log.Info("TargetSpace: " + oprim.m_targetSpace + " - SceneMainSpace: " + pscene.space);
|
m_log.Info("TargetSpace: " + oprim.m_targetSpace + " - SceneMainSpace: " + pscene.space);
|
||||||
|
|
||||||
Assert.That(!oprim.m_taintadd);
|
Assert.That(!oprim.m_taintadd);
|
||||||
m_log.Info("Prim Position (" + oprim.m_localID + "): " + prim.Position.ToString());
|
m_log.Info("Prim Position (" + oprim.LocalID + "): " + prim.Position);
|
||||||
|
|
||||||
// Make sure we're above the ground
|
// Make sure we're above the ground
|
||||||
//Assert.That(prim.Position.Z > 20f);
|
//Assert.That(prim.Position.Z > 20f);
|
||||||
|
|
|
@ -67,7 +67,7 @@ namespace OpenSim.Services.Connectors.Friends
|
||||||
IConfig gridConfig = source.Configs["FriendsService"];
|
IConfig gridConfig = source.Configs["FriendsService"];
|
||||||
if (gridConfig == null)
|
if (gridConfig == null)
|
||||||
{
|
{
|
||||||
m_log.Error("[FRIENDS CONNECTOR]: FriendsService missing from OpenSim.ini");
|
m_log.Error("[FRIENDS SERVICE CONNECTOR]: FriendsService missing from OpenSim.ini");
|
||||||
throw new Exception("Friends connector init error");
|
throw new Exception("Friends connector init error");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -76,7 +76,7 @@ namespace OpenSim.Services.Connectors.Friends
|
||||||
|
|
||||||
if (serviceURI == String.Empty)
|
if (serviceURI == String.Empty)
|
||||||
{
|
{
|
||||||
m_log.Error("[FRIENDS CONNECTOR]: No Server URI named in section FriendsService");
|
m_log.Error("[FRIENDS SERVICE CONNECTOR]: No Server URI named in section FriendsService");
|
||||||
throw new Exception("Friends connector init error");
|
throw new Exception("Friends connector init error");
|
||||||
}
|
}
|
||||||
m_ServerURI = serviceURI;
|
m_ServerURI = serviceURI;
|
||||||
|
@ -127,7 +127,7 @@ namespace OpenSim.Services.Connectors.Friends
|
||||||
|
|
||||||
List<FriendInfo> finfos = new List<FriendInfo>();
|
List<FriendInfo> finfos = new List<FriendInfo>();
|
||||||
Dictionary<string, object>.ValueCollection finfosList = replyData.Values;
|
Dictionary<string, object>.ValueCollection finfosList = replyData.Values;
|
||||||
//m_log.DebugFormat("[FRIENDS CONNECTOR]: get neighbours returned {0} elements", rinfosList.Count);
|
//m_log.DebugFormat("[FRIENDS SERVICE CONNECTOR]: get neighbours returned {0} elements", rinfosList.Count);
|
||||||
foreach (object f in finfosList)
|
foreach (object f in finfosList)
|
||||||
{
|
{
|
||||||
if (f is Dictionary<string, object>)
|
if (f is Dictionary<string, object>)
|
||||||
|
@ -136,7 +136,7 @@ namespace OpenSim.Services.Connectors.Friends
|
||||||
finfos.Add(finfo);
|
finfos.Add(finfo);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
m_log.DebugFormat("[FRIENDS CONNECTOR]: GetFriends {0} received invalid response type {1}",
|
m_log.DebugFormat("[FRIENDS SERVICE CONNECTOR]: GetFriends {0} received invalid response type {1}",
|
||||||
PrincipalID, f.GetType());
|
PrincipalID, f.GetType());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -145,14 +145,14 @@ namespace OpenSim.Services.Connectors.Friends
|
||||||
}
|
}
|
||||||
|
|
||||||
else
|
else
|
||||||
m_log.DebugFormat("[FRIENDS CONNECTOR]: GetFriends {0} received null response",
|
m_log.DebugFormat("[FRIENDS SERVICE CONNECTOR]: GetFriends {0} received null response",
|
||||||
PrincipalID);
|
PrincipalID);
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
catch (Exception e)
|
catch (Exception e)
|
||||||
{
|
{
|
||||||
m_log.DebugFormat("[FRIENDS CONNECTOR]: Exception when contacting friends server: {0}", e.Message);
|
m_log.DebugFormat("[FRIENDS SERVICE CONNECTOR]: Exception when contacting friends server: {0}", e.Message);
|
||||||
}
|
}
|
||||||
|
|
||||||
return new FriendInfo[0];
|
return new FriendInfo[0];
|
||||||
|
@ -175,7 +175,7 @@ namespace OpenSim.Services.Connectors.Friends
|
||||||
}
|
}
|
||||||
catch (Exception e)
|
catch (Exception e)
|
||||||
{
|
{
|
||||||
m_log.DebugFormat("[FRIENDS CONNECTOR]: Exception when contacting friends server: {0}", e.Message);
|
m_log.DebugFormat("[FRIENDS SERVICE CONNECTOR]: Exception when contacting friends server: {0}", e.Message);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -190,11 +190,11 @@ namespace OpenSim.Services.Connectors.Friends
|
||||||
return success;
|
return success;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
m_log.DebugFormat("[FRIENDS CONNECTOR]: StoreFriend {0} {1} received null response",
|
m_log.DebugFormat("[FRIENDS SERVICE CONNECTOR]: StoreFriend {0} {1} received null response",
|
||||||
PrincipalID, Friend);
|
PrincipalID, Friend);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
m_log.DebugFormat("[FRIENDS CONNECTOR]: StoreFriend received null reply");
|
m_log.DebugFormat("[FRIENDS SERVICE CONNECTOR]: StoreFriend received null reply");
|
||||||
|
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
|
@ -231,7 +231,7 @@ namespace OpenSim.Services.Connectors.Friends
|
||||||
}
|
}
|
||||||
catch (Exception e)
|
catch (Exception e)
|
||||||
{
|
{
|
||||||
m_log.DebugFormat("[FRIENDS CONNECTOR]: Exception when contacting friends server: {0}", e.Message);
|
m_log.DebugFormat("[FRIENDS SERVICE CONNECTOR]: Exception when contacting friends server: {0}", e.Message);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -246,11 +246,11 @@ namespace OpenSim.Services.Connectors.Friends
|
||||||
return success;
|
return success;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
m_log.DebugFormat("[FRIENDS CONNECTOR]: DeleteFriend {0} {1} received null response",
|
m_log.DebugFormat("[FRIENDS SERVICE CONNECTOR]: DeleteFriend {0} {1} received null response",
|
||||||
PrincipalID, Friend);
|
PrincipalID, Friend);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
m_log.DebugFormat("[FRIENDS CONNECTOR]: DeleteFriend received null reply");
|
m_log.DebugFormat("[FRIENDS SERVICE CONNECTOR]: DeleteFriend received null reply");
|
||||||
|
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
|
@ -134,11 +134,11 @@ namespace OpenSim.Services.Connectors.Friends
|
||||||
private bool Call(GridRegion region, Dictionary<string, object> sendData)
|
private bool Call(GridRegion region, Dictionary<string, object> sendData)
|
||||||
{
|
{
|
||||||
string reqString = ServerUtils.BuildQueryString(sendData);
|
string reqString = ServerUtils.BuildQueryString(sendData);
|
||||||
//m_log.DebugFormat("[FRIENDS CONNECTOR]: queryString = {0}", reqString);
|
//m_log.DebugFormat("[FRIENDS SIM CONNECTOR]: queryString = {0}", reqString);
|
||||||
if (region == null)
|
if (region == null)
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
m_log.DebugFormat("[FRIENDS CONNECTOR]: region: {0}", region.ExternalHostName + ":" + region.HttpPort);
|
m_log.DebugFormat("[FRIENDS SIM CONNECTOR]: region: {0}", region.ExternalHostName + ":" + region.HttpPort);
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
string url = "http://" + region.ExternalHostName + ":" + region.HttpPort;
|
string url = "http://" + region.ExternalHostName + ":" + region.HttpPort;
|
||||||
|
@ -157,15 +157,15 @@ namespace OpenSim.Services.Connectors.Friends
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
m_log.DebugFormat("[FRIENDS CONNECTOR]: reply data does not contain result field");
|
m_log.DebugFormat("[FRIENDS SIM CONNECTOR]: reply data does not contain result field");
|
||||||
|
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
m_log.DebugFormat("[FRIENDS CONNECTOR]: received empty reply");
|
m_log.DebugFormat("[FRIENDS SIM CONNECTOR]: received empty reply");
|
||||||
}
|
}
|
||||||
catch (Exception e)
|
catch (Exception e)
|
||||||
{
|
{
|
||||||
m_log.DebugFormat("[FRIENDS CONNECTOR]: Exception when contacting remote sim: {0}", e.ToString());
|
m_log.DebugFormat("[FRIENDS SIM CONNECTOR]: Exception when contacting remote sim: {0}", e.ToString());
|
||||||
}
|
}
|
||||||
|
|
||||||
return false;
|
return false;
|
||||||
|
|
|
@ -335,22 +335,21 @@ namespace OpenSim.Services.HypergridService
|
||||||
}
|
}
|
||||||
|
|
||||||
if (userURL == m_ExternalName)
|
if (userURL == m_ExternalName)
|
||||||
|
{
|
||||||
return m_UserAgentService.VerifyAgent(aCircuit.SessionID, aCircuit.ServiceSessionID);
|
return m_UserAgentService.VerifyAgent(aCircuit.SessionID, aCircuit.ServiceSessionID);
|
||||||
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
// Object[] args = new Object[] { userURL };
|
|
||||||
IUserAgentService userAgentService = new UserAgentServiceConnector(userURL);
|
IUserAgentService userAgentService = new UserAgentServiceConnector(userURL);
|
||||||
if (userAgentService != null)
|
|
||||||
|
try
|
||||||
{
|
{
|
||||||
try
|
return userAgentService.VerifyAgent(aCircuit.SessionID, aCircuit.ServiceSessionID);
|
||||||
{
|
}
|
||||||
return userAgentService.VerifyAgent(aCircuit.SessionID, aCircuit.ServiceSessionID);
|
catch
|
||||||
}
|
{
|
||||||
catch
|
m_log.DebugFormat("[GATEKEEPER SERVICE]: Unable to contact authentication service at {0}", userURL);
|
||||||
{
|
return false;
|
||||||
m_log.DebugFormat("[GATEKEEPER SERVICE]: Unable to contact authentication service at {0}", userURL);
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -57,8 +57,9 @@ namespace OpenSim.Tests.Common.Mock
|
||||||
private IScene m_scene;
|
private IScene m_scene;
|
||||||
|
|
||||||
// Properties so that we can get at received data for test purposes
|
// Properties so that we can get at received data for test purposes
|
||||||
public List<UUID> OfflineNotificationsReceived { get; private set; }
|
public List<UUID> ReceivedOfflineNotifications { get; private set; }
|
||||||
public List<UUID> OnlineNotificationsReceived { get; private set; }
|
public List<UUID> ReceivedOnlineNotifications { get; private set; }
|
||||||
|
public List<UUID> ReceivedFriendshipTerminations { get; private set; }
|
||||||
|
|
||||||
// disable warning: public events, part of the public API
|
// disable warning: public events, part of the public API
|
||||||
#pragma warning disable 67
|
#pragma warning disable 67
|
||||||
|
@ -445,8 +446,9 @@ namespace OpenSim.Tests.Common.Mock
|
||||||
m_scene = scene;
|
m_scene = scene;
|
||||||
CapsSeedUrl = agentData.CapsPath;
|
CapsSeedUrl = agentData.CapsPath;
|
||||||
|
|
||||||
OfflineNotificationsReceived = new List<UUID>();
|
ReceivedOfflineNotifications = new List<UUID>();
|
||||||
OnlineNotificationsReceived = new List<UUID>();
|
ReceivedOnlineNotifications = new List<UUID>();
|
||||||
|
ReceivedFriendshipTerminations = new List<UUID>();
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
|
@ -834,12 +836,12 @@ namespace OpenSim.Tests.Common.Mock
|
||||||
|
|
||||||
public void SendAgentOffline(UUID[] agentIDs)
|
public void SendAgentOffline(UUID[] agentIDs)
|
||||||
{
|
{
|
||||||
OfflineNotificationsReceived.AddRange(agentIDs);
|
ReceivedOfflineNotifications.AddRange(agentIDs);
|
||||||
}
|
}
|
||||||
|
|
||||||
public void SendAgentOnline(UUID[] agentIDs)
|
public void SendAgentOnline(UUID[] agentIDs)
|
||||||
{
|
{
|
||||||
OnlineNotificationsReceived.AddRange(agentIDs);
|
ReceivedOnlineNotifications.AddRange(agentIDs);
|
||||||
}
|
}
|
||||||
|
|
||||||
public void SendSitResponse(UUID TargetID, Vector3 OffsetPos, Quaternion SitOrientation, bool autopilot,
|
public void SendSitResponse(UUID TargetID, Vector3 OffsetPos, Quaternion SitOrientation, bool autopilot,
|
||||||
|
@ -1113,6 +1115,7 @@ namespace OpenSim.Tests.Common.Mock
|
||||||
|
|
||||||
public void SendTerminateFriend(UUID exFriendID)
|
public void SendTerminateFriend(UUID exFriendID)
|
||||||
{
|
{
|
||||||
|
ReceivedFriendshipTerminations.Add(exFriendID);
|
||||||
}
|
}
|
||||||
|
|
||||||
public bool AddGenericPacketHandler(string MethodName, GenericMessage handler)
|
public bool AddGenericPacketHandler(string MethodName, GenericMessage handler)
|
||||||
|
|
|
@ -1724,7 +1724,6 @@
|
||||||
<Reference name="OpenMetaverseTypes" path="../../../bin/"/>
|
<Reference name="OpenMetaverseTypes" path="../../../bin/"/>
|
||||||
<Reference name="OpenMetaverse.StructuredData" path="../../../bin/"/>
|
<Reference name="OpenMetaverse.StructuredData" path="../../../bin/"/>
|
||||||
<Reference name="OpenMetaverse" path="../../../bin/"/>
|
<Reference name="OpenMetaverse" path="../../../bin/"/>
|
||||||
<Reference name="PumaCode.SvnDotNet" path="../../../bin/"/>
|
|
||||||
<Reference name="OpenSim.Capabilities"/>
|
<Reference name="OpenSim.Capabilities"/>
|
||||||
<Reference name="OpenSim.Framework"/>
|
<Reference name="OpenSim.Framework"/>
|
||||||
<Reference name="OpenSim.Framework.Communications"/>
|
<Reference name="OpenSim.Framework.Communications"/>
|
||||||
|
|
Loading…
Reference in New Issue