aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/OpenSim/Region
diff options
context:
space:
mode:
Diffstat (limited to 'OpenSim/Region')
-rw-r--r--OpenSim/Region/CoreModules/Avatar/Friends/FriendsModule.cs45
1 files changed, 39 insertions, 6 deletions
diff --git a/OpenSim/Region/CoreModules/Avatar/Friends/FriendsModule.cs b/OpenSim/Region/CoreModules/Avatar/Friends/FriendsModule.cs
index 0c81f44..8f84d81 100644
--- a/OpenSim/Region/CoreModules/Avatar/Friends/FriendsModule.cs
+++ b/OpenSim/Region/CoreModules/Avatar/Friends/FriendsModule.cs
@@ -67,7 +67,7 @@ namespace OpenSim.Region.CoreModules.Avatar.Friends
67 return false; 67 return false;
68 } 68 }
69 } 69 }
70 70
71 private static readonly ILog m_log = LogManager.GetLogger(MethodBase.GetCurrentMethod().DeclaringType); 71 private static readonly ILog m_log = LogManager.GetLogger(MethodBase.GetCurrentMethod().DeclaringType);
72 72
73 protected List<Scene> m_Scenes = new List<Scene>(); 73 protected List<Scene> m_Scenes = new List<Scene>();
@@ -234,7 +234,7 @@ namespace OpenSim.Region.CoreModules.Avatar.Friends
234 newFriends.RegionID = UUID.Zero; 234 newFriends.RegionID = UUID.Zero;
235 235
236 m_Friends.Add(client.AgentId, newFriends); 236 m_Friends.Add(client.AgentId, newFriends);
237 237
238 //StatusChange(client.AgentId, true); 238 //StatusChange(client.AgentId, true);
239 } 239 }
240 240
@@ -289,7 +289,7 @@ namespace OpenSim.Region.CoreModules.Avatar.Friends
289 289
290 // Inform the friends that this user is online 290 // Inform the friends that this user is online
291 StatusChange(agentID, true); 291 StatusChange(agentID, true);
292 292
293 // Register that we need to send the list of online friends to this user 293 // Register that we need to send the list of online friends to this user
294 lock (m_NeedsListOfFriends) 294 lock (m_NeedsListOfFriends)
295 if (!m_NeedsListOfFriends.Contains(agentID)) 295 if (!m_NeedsListOfFriends.Contains(agentID))
@@ -439,11 +439,44 @@ namespace OpenSim.Region.CoreModules.Avatar.Friends
439 if (((fi.MyFlags & 1) != 0) && (fi.TheirFlags != -1)) 439 if (((fi.MyFlags & 1) != 0) && (fi.TheirFlags != -1))
440 friendList.Add(fi); 440 friendList.Add(fi);
441 } 441 }
442 /*
442 foreach (FriendInfo fi in friendList) 443 foreach (FriendInfo fi in friendList)
443 { 444 {
444 // Notify about this user status 445 // Notify about this user status
445 StatusNotify(fi, agentID, online); 446 StatusNotify(fi, agentID, online);
446 } 447 }
448 */
449
450 StatusNotifyMass(friendList, agentID, online);
451 }
452 }
453
454 private void StatusNotifyMass(List<FriendInfo> friendList, UUID userID, bool online)
455 {
456 string[] friendIDs = new string[friendList.Count];
457 int notlocal = 0;
458 for (int x = 0; x < friendList.Count; x++)
459 {
460 UUID friendID = UUID.Zero;
461 if (UUID.TryParse(friendList[x].Friend, out friendID))
462 {
463 if (!LocalStatusNotification(userID, friendID, online))
464 {
465 friendIDs[notlocal++] = friendID.ToString();
466 }
467 }
468 }
469
470 PresenceInfo[] friendSessions = PresenceService.GetAgents(friendIDs);
471
472 for (int x = 0; x < friendSessions.GetLength(0); x++)
473 {
474 PresenceInfo friendSession = PresenceInfo.GetOnlinePresence(friendSessions);
475 if (friendSession != null)
476 {
477 GridRegion region = GridService.GetRegionByUUID(m_Scenes[0].RegionInfo.ScopeID, friendSession.RegionID);
478 m_FriendsSimConnector.StatusNotify(region, userID, new UUID(friendIDs[x]), online);
479 }
447 } 480 }
448 } 481 }
449 482
@@ -456,7 +489,7 @@ namespace OpenSim.Region.CoreModules.Avatar.Friends
456 // Try local 489 // Try local
457 if (LocalStatusNotification(userID, friendID, online)) 490 if (LocalStatusNotification(userID, friendID, online))
458 return; 491 return;
459 492
460 // The friend is not here [as root]. Let's forward. 493 // The friend is not here [as root]. Let's forward.
461 PresenceInfo[] friendSessions = PresenceService.GetAgents(new string[] { friendID.ToString() }); 494 PresenceInfo[] friendSessions = PresenceService.GetAgents(new string[] { friendID.ToString() });
462 if (friendSessions != null && friendSessions.Length > 0) 495 if (friendSessions != null && friendSessions.Length > 0)
@@ -476,7 +509,7 @@ namespace OpenSim.Region.CoreModules.Avatar.Friends
476 private void OnInstantMessage(IClientAPI client, GridInstantMessage im) 509 private void OnInstantMessage(IClientAPI client, GridInstantMessage im)
477 { 510 {
478 if (im.dialog == (byte)OpenMetaverse.InstantMessageDialog.FriendshipOffered) 511 if (im.dialog == (byte)OpenMetaverse.InstantMessageDialog.FriendshipOffered)
479 { 512 {
480 // we got a friendship offer 513 // we got a friendship offer
481 UUID principalID = new UUID(im.fromAgentID); 514 UUID principalID = new UUID(im.fromAgentID);
482 UUID friendID = new UUID(im.toAgentID); 515 UUID friendID = new UUID(im.toAgentID);
@@ -701,7 +734,7 @@ namespace OpenSim.Region.CoreModules.Avatar.Friends
701 // we're done 734 // we're done
702 return true; 735 return true;
703 } 736 }
704 737
705 return false; 738 return false;
706 } 739 }
707 740