A final couple of tweaks to GroupsModule.cs. Remove unneeded delegate, and prettify codeing style/formatting

bulletsim
James Stallings aka Hiro Protagonist 2011-05-31 19:33:40 -05:00 committed by Justin Clark-Casey (justincc)
parent 8bacf56e46
commit c43ad8a0e7
1 changed files with 22 additions and 9 deletions

View File

@ -1223,6 +1223,7 @@ namespace OpenSim.Region.OptionalModules.Avatar.XmlRpcGroups
/// <summary> /// <summary>
/// Get a list of groups memberships for the agent that are marked "ListInProfile" /// Get a list of groups memberships for the agent that are marked "ListInProfile"
/// (unless that agent has a godLike aspect, in which case get all groups)
/// </summary> /// </summary>
/// <param name="dataForAgentID"></param> /// <param name="dataForAgentID"></param>
/// <returns></returns> /// <returns></returns>
@ -1231,20 +1232,31 @@ namespace OpenSim.Region.OptionalModules.Avatar.XmlRpcGroups
List<GroupMembershipData> membershipData = m_groupData.GetAgentGroupMemberships(requestingClient.AgentId, dataForAgentID); List<GroupMembershipData> membershipData = m_groupData.GetAgentGroupMemberships(requestingClient.AgentId, dataForAgentID);
GroupMembershipData[] membershipArray; GroupMembershipData[] membershipArray;
if (requestingClient.AgentId != dataForAgentID) // cScene and property accessor 'isGod' are in support of the opertions to bypass 'hidden' group attributes for
{ // those with a GodLike aspect.
Predicate<GroupMembershipData> showInProfile = delegate(GroupMembershipData membership) Scene cScene = (Scene) requestingClient.Scene;
{ bool isGod = cScene.Permissions.IsGod(requestingClient.AgentId);
return membership.ListInProfile;
};
membershipArray = membershipData.FindAll(showInProfile).ToArray(); if (isGod) {
membershipArray = membershipData.ToArray();
} }
else else
{ {
membershipArray = membershipData.ToArray();
}
if (requestingClient.AgentId != dataForAgentID)
{
Predicate<GroupMembershipData> showInProfile = delegate(GroupMembershipData membership)
{
return membership.ListInProfile;
};
membershipArray = membershipData.FindAll(showInProfile).ToArray();
}
else
{
membershipArray = membershipData.ToArray();
}
}
if (m_debugEnabled) if (m_debugEnabled)
{ {
m_log.InfoFormat("[GROUPS]: Get group membership information for {0} requested by {1}", dataForAgentID, requestingClient.AgentId); m_log.InfoFormat("[GROUPS]: Get group membership information for {0} requested by {1}", dataForAgentID, requestingClient.AgentId);
@ -1257,6 +1269,7 @@ namespace OpenSim.Region.OptionalModules.Avatar.XmlRpcGroups
return membershipArray; return membershipArray;
} }
private void SendAgentDataUpdate(IClientAPI remoteClient, UUID dataForAgentID, UUID activeGroupID, string activeGroupName, ulong activeGroupPowers, string activeGroupTitle) private void SendAgentDataUpdate(IClientAPI remoteClient, UUID dataForAgentID, UUID activeGroupID, string activeGroupName, ulong activeGroupPowers, string activeGroupTitle)
{ {
if (m_debugEnabled) m_log.DebugFormat("[GROUPS]: {0} called", System.Reflection.MethodBase.GetCurrentMethod().Name); if (m_debugEnabled) m_log.DebugFormat("[GROUPS]: {0} called", System.Reflection.MethodBase.GetCurrentMethod().Name);