From 630ce5b26446883043aa5e6541a4550d0e918659 Mon Sep 17 00:00:00 2001 From: Dahlia Trimble Date: Sat, 10 Jan 2009 09:15:23 +0000 Subject: Revert progressive texture patch from r8001 until issues can be addressed --- .../Modules/Avatar/Friends/FriendsModule.cs | 73 ++++++++++++---------- 1 file changed, 39 insertions(+), 34 deletions(-) (limited to 'OpenSim/Region/Environment/Modules/Avatar') diff --git a/OpenSim/Region/Environment/Modules/Avatar/Friends/FriendsModule.cs b/OpenSim/Region/Environment/Modules/Avatar/Friends/FriendsModule.cs index ed77b2e..4a03ecd 100644 --- a/OpenSim/Region/Environment/Modules/Avatar/Friends/FriendsModule.cs +++ b/OpenSim/Region/Environment/Modules/Avatar/Friends/FriendsModule.cs @@ -30,6 +30,7 @@ using System.Collections; using System.Collections.Generic; using System.Reflection; using OpenMetaverse; +using OpenMetaverse.Packets; using log4net; using Nini.Config; using Nwc.XmlRpc; @@ -101,10 +102,10 @@ namespace OpenSim.Region.Environment.Modules.Avatar.Friends private Dictionary m_rootAgents = new Dictionary(); - private Dictionary m_pendingCallingcardRequests = new Dictionary(); + private Dictionary m_pendingCallingcardRequests = new Dictionary(); private Scene m_initialScene; // saves a lookup if we don't have a specific scene - private Dictionary m_scenes = new Dictionary(); + private Dictionary m_scenes = new Dictionary(); private IMessageTransferModule m_TransferModule = null; #region IRegionModule Members @@ -124,9 +125,9 @@ namespace OpenSim.Region.Environment.Modules.Avatar.Friends if (!m_scenes.ContainsKey(scene.RegionInfo.RegionHandle)) m_scenes[scene.RegionInfo.RegionHandle] = scene; } - + scene.RegisterModuleInterface(this); - + scene.EventManager.OnNewClient += OnNewClient; scene.EventManager.OnIncomingInstantMessage += OnGridInstantMessage; scene.EventManager.OnAvatarEnteringNewParcel += AvatarEnteringParcel; @@ -179,7 +180,7 @@ namespace OpenSim.Region.Environment.Modules.Avatar.Friends lock (m_rootAgents) { List friendsHere = new List(); - + try { UUID agentID = new UUID((string)requestData["agentID"]); @@ -212,7 +213,7 @@ namespace OpenSim.Region.Environment.Modules.Avatar.Friends } } } - catch(Exception e) + catch (Exception e) { m_log.Warn("[FRIENDS]: Got exception while parsing presence_update_bulk request:", e); } @@ -374,24 +375,24 @@ namespace OpenSim.Region.Environment.Modules.Avatar.Friends } return returnAgent; } - + public void OfferFriendship(UUID fromUserId, IClientAPI toUserClient, string offerMessage) { CachedUserInfo userInfo = m_initialScene.CommsManager.UserProfileCacheService.GetUserDetails(fromUserId); - + if (userInfo != null) { GridInstantMessage msg = new GridInstantMessage( toUserClient.Scene, fromUserId, userInfo.UserProfile.Name, toUserClient.AgentId, - (byte)InstantMessageDialog.FriendshipOffered, offerMessage, false, Vector3.Zero); - + (byte)InstantMessageDialog.FriendshipOffered, offerMessage, false, Vector3.Zero); + FriendshipOffered(msg); } else { m_log.ErrorFormat("[FRIENDS]: No user found for id {0} in OfferFriendship()", fromUserId); } - } + } #region FriendRequestHandling @@ -413,7 +414,7 @@ namespace OpenSim.Region.Environment.Modules.Avatar.Friends FriendshipDeclined(client, im); } } - + /// /// Invoked when a user offers a friendship. /// @@ -448,14 +449,14 @@ namespace OpenSim.Region.Environment.Modules.Avatar.Friends // If new friend is local, it will send an IM to the viewer. // If new friend is remote, it will cause a OnGridInstantMessage on the remote server m_TransferModule.SendInstantMessage(im, - delegate(bool success) + delegate(bool success) { m_log.DebugFormat("[FRIEND]: sending IM success = {0}", success); } ); - } + } } - + /// /// Invoked when a user accepts a friendship offer. /// @@ -464,9 +465,9 @@ namespace OpenSim.Region.Environment.Modules.Avatar.Friends private void FriendshipAccepted(IClientAPI client, GridInstantMessage im) { m_log.DebugFormat("[FRIEND]: 39 - from client {0}, agent {2} {3}, imsession {4} to {5}: {6} (dialog {7})", - client.AgentId, im.fromAgentID, im.fromAgentName, im.imSessionID, im.toAgentID, im.message, im.dialog); + client.AgentId, im.fromAgentID, im.fromAgentName, im.imSessionID, im.toAgentID, im.message, im.dialog); } - + /// /// Invoked when a user declines a friendship offer. /// @@ -477,7 +478,7 @@ namespace OpenSim.Region.Environment.Modules.Avatar.Friends { UUID fromAgentID = new UUID(im.fromAgentID); UUID toAgentID = new UUID(im.toAgentID); - + // declining the friendship offer causes a type 40 IM being sent to the (possibly remote) initiator // toAgentID is initiator, fromAgentID declined friendship m_log.DebugFormat("[FRIEND]: 40 - from client {0}, agent {1} {2}, imsession {3} to {4}: {5} (dialog {6})", @@ -487,14 +488,15 @@ namespace OpenSim.Region.Environment.Modules.Avatar.Friends // Send the decline to whoever is the destination. GridInstantMessage msg = new GridInstantMessage(client.Scene, fromAgentID, client.Name, toAgentID, im.dialog, im.message, im.offline != 0, im.Position); - + // If new friend is local, it will send an IM to the viewer. // If new friend is remote, it will cause a OnGridInstantMessage on the remote server m_TransferModule.SendInstantMessage(msg, - delegate(bool success) { + delegate(bool success) + { m_log.DebugFormat("[FRIEND]: sending IM success = {0}", success); } - ); + ); } private void OnGridInstantMessage(GridInstantMessage msg) @@ -510,7 +512,8 @@ namespace OpenSim.Region.Environment.Modules.Avatar.Friends { // this should succeed as we *know* the root agent is here. m_TransferModule.SendInstantMessage(msg, - delegate(bool success) { + delegate(bool success) + { m_log.DebugFormat("[FRIEND]: sending IM success = {0}", success); } ); @@ -566,7 +569,7 @@ namespace OpenSim.Region.Environment.Modules.Avatar.Friends client.Name, client.AgentId, agentID, friendID); // store the new friend persistently for both avatars - m_initialScene.StoreAddFriendship(friendID, agentID, (uint) FriendRights.CanSeeOnline); + m_initialScene.StoreAddFriendship(friendID, agentID, (uint)FriendRights.CanSeeOnline); // The cache entries aren't valid anymore either, as we just added a friend to both sides. lock (m_friendLists) @@ -609,7 +612,8 @@ namespace OpenSim.Region.Environment.Modules.Avatar.Friends if (m_TransferModule != null) { m_TransferModule.SendInstantMessage(msg, - delegate(bool success) { + delegate(bool success) + { m_log.DebugFormat("[FRIEND]: sending IM success = {0}", success); } ); @@ -633,7 +637,8 @@ namespace OpenSim.Region.Environment.Modules.Avatar.Friends if (m_TransferModule != null) { m_TransferModule.SendInstantMessage(msg, - delegate(bool success) { + delegate(bool success) + { m_log.DebugFormat("[FRIEND]: sending IM success = {0}", success); } ); @@ -809,16 +814,16 @@ namespace OpenSim.Region.Environment.Modules.Avatar.Friends // I can't believe that we have Dictionaries, but no Sets, considering Java introduced them years ago... List friendIDsToSendTo = new List(); List candidateFriendIDsToReceive = new List(); - + foreach (FriendListItem item in friendList) { if (((item.FriendListOwnerPerms | item.FriendPerms) & (uint)FriendRights.CanSeeOnline) != 0) { // friend is allowed to see my presence => add - if ((item.FriendListOwnerPerms & (uint)FriendRights.CanSeeOnline) != 0) + if ((item.FriendListOwnerPerms & (uint)FriendRights.CanSeeOnline) != 0) friendIDsToSendTo.Add(item.Friend); - if ((item.FriendPerms & (uint)FriendRights.CanSeeOnline) != 0) + if ((item.FriendPerms & (uint)FriendRights.CanSeeOnline) != 0) candidateFriendIDsToReceive.Add(item.Friend); } } @@ -857,7 +862,7 @@ namespace OpenSim.Region.Environment.Modules.Avatar.Friends if (iAmOnline) { List friendIDsToReceive = new List(); - + for (int i = candidateFriendIDsToReceive.Count - 1; i >= 0; --i) { UUID uuid = candidateFriendIDsToReceive[i]; @@ -867,11 +872,11 @@ namespace OpenSim.Region.Environment.Modules.Avatar.Friends friendIDsToReceive.Add(uuid); } } - + m_log.DebugFormat( "[FRIEND]: Sending {0} online friends to {1}", friendIDsToReceive.Count, client.Name); - - if (friendIDsToReceive.Count > 0) + + if (friendIDsToReceive.Count > 0) client.SendAgentOnline(friendIDsToReceive.ToArray()); // clear them for a possible second iteration; we don't have to repeat this @@ -914,7 +919,7 @@ namespace OpenSim.Region.Environment.Modules.Avatar.Friends if (friendIDsToSendTo.Count > 0) { // sort them into regions - Dictionary> friendsInRegion = new Dictionary>(); + Dictionary> friendsInRegion = new Dictionary>(); foreach (UUID uuid in friendIDsToSendTo) { ulong handle = friendRegions[uuid].regionHandle; // this can't fail as we filtered above already @@ -993,5 +998,5 @@ namespace OpenSim.Region.Environment.Modules.Avatar.Friends } } - #endregion + #endregion } -- cgit v1.1