Merge branch 'master' of ssh://MyConnection/var/git/opensim
commit
419303a40f
|
@ -2787,32 +2787,37 @@ namespace OpenSim.Region.ClientStack.LindenUDP
|
||||||
|
|
||||||
public void SendAvatarGroupsReply(UUID avatarID, GroupMembershipData[] data)
|
public void SendAvatarGroupsReply(UUID avatarID, GroupMembershipData[] data)
|
||||||
{
|
{
|
||||||
AvatarGroupsReplyPacket p = (AvatarGroupsReplyPacket)PacketPool.Instance.GetPacket(PacketType.AvatarGroupsReply);
|
OSDMap llsd = new OSDMap(3);
|
||||||
|
OSDArray AgentData = new OSDArray(1);
|
||||||
p.AgentData = new AvatarGroupsReplyPacket.AgentDataBlock();
|
OSDMap AgentDataMap = new OSDMap(1);
|
||||||
p.AgentData.AgentID = AgentId;
|
AgentDataMap.Add("AgentID", OSD.FromUUID(this.AgentId));
|
||||||
p.AgentData.AvatarID = avatarID;
|
AgentDataMap.Add("AvatarID", OSD.FromUUID(avatarID));
|
||||||
|
AgentData.Add(AgentDataMap);
|
||||||
p.GroupData = new AvatarGroupsReplyPacket.GroupDataBlock[data.Length];
|
llsd.Add("AgentData", AgentData);
|
||||||
|
OSDArray GroupData = new OSDArray(data.Length);
|
||||||
for (int i = 0; i < data.Length; i++)
|
OSDArray NewGroupData = new OSDArray(data.Length);
|
||||||
|
foreach (GroupMembershipData m in data)
|
||||||
{
|
{
|
||||||
GroupMembershipData m = data[i];
|
OSDMap GroupDataMap = new OSDMap(6);
|
||||||
|
OSDMap NewGroupDataMap = new OSDMap(1);
|
||||||
AvatarGroupsReplyPacket.GroupDataBlock block = new AvatarGroupsReplyPacket.GroupDataBlock();
|
GroupDataMap.Add("GroupPowers", OSD.FromBinary(m.GroupPowers));
|
||||||
block.GroupPowers = m.GroupPowers;
|
GroupDataMap.Add("AcceptNotices", OSD.FromBoolean(m.AcceptNotices));
|
||||||
block.AcceptNotices = m.AcceptNotices;
|
GroupDataMap.Add("GroupTitle", OSD.FromString(m.GroupTitle));
|
||||||
block.GroupTitle = Util.StringToBytes256(m.GroupTitle.Length > 20 ? m.GroupTitle.Substring(0, 20) : m.GroupTitle);
|
GroupDataMap.Add("GroupID", OSD.FromUUID(m.GroupID));
|
||||||
block.GroupID = m.GroupID;
|
GroupDataMap.Add("GroupName", OSD.FromString(m.GroupName));
|
||||||
block.GroupName = Util.StringToBytes256(m.GroupName.Length > 35 ? m.GroupName.Substring(0, 35) : m.GroupName);
|
GroupDataMap.Add("GroupInsigniaID", OSD.FromUUID(m.GroupPicture));
|
||||||
block.GroupInsigniaID = m.GroupPicture;
|
NewGroupDataMap.Add("ListInProfile", OSD.FromBoolean(m.ListInProfile));
|
||||||
|
GroupData.Add(GroupDataMap);
|
||||||
p.GroupData[i] = block;
|
NewGroupData.Add(NewGroupDataMap);
|
||||||
}
|
}
|
||||||
|
llsd.Add("GroupData", GroupData);
|
||||||
|
llsd.Add("NewGroupData", NewGroupData);
|
||||||
|
|
||||||
p.NewGroupData.ListInProfile = true;
|
IEventQueue eq = this.Scene.RequestModuleInterface<IEventQueue>();
|
||||||
|
if (eq != null)
|
||||||
OutPacket(p, ThrottleOutPacketType.Task);
|
{
|
||||||
|
eq.Enqueue(BuildEvent("AvatarGroupsReply", llsd), this.AgentId);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public void SendJoinGroupReply(UUID groupID, bool success)
|
public void SendJoinGroupReply(UUID groupID, bool success)
|
||||||
|
@ -10299,5 +10304,13 @@ namespace OpenSim.Region.ClientStack.LindenUDP
|
||||||
}
|
}
|
||||||
#endregion
|
#endregion
|
||||||
|
|
||||||
|
public static OSD BuildEvent(string eventName, OSD eventBody)
|
||||||
|
{
|
||||||
|
OSDMap osdEvent = new OSDMap(2);
|
||||||
|
osdEvent.Add("message", new OSDString(eventName));
|
||||||
|
osdEvent.Add("body", eventBody);
|
||||||
|
|
||||||
|
return osdEvent;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue