Thank you kindly, MCortez, for a patch that:
This hooks up the LandManagementModule to handle the DeedParcelToGroup packet. Now people can start testing land assigned to and owned by groups. Also fixes a viewer crash issue when searching for and then joining a group with an agent that is not already being tracked by groups server.0.6.5-rc1
parent
06f0515d14
commit
a416e75ddb
|
@ -122,6 +122,8 @@ namespace OpenSim.Region.CoreModules.World.Land
|
||||||
client.OnParcelInfoRequest += new ParcelInfoRequest(handleParcelInfo);
|
client.OnParcelInfoRequest += new ParcelInfoRequest(handleParcelInfo);
|
||||||
client.OnParcelDwellRequest += new ParcelDwellRequest(handleParcelDwell);
|
client.OnParcelDwellRequest += new ParcelDwellRequest(handleParcelDwell);
|
||||||
|
|
||||||
|
client.OnParcelDeedToGroup += new ParcelDeedToGroup(handleParcelDeedToGroup);
|
||||||
|
|
||||||
if (m_scene.Entities.ContainsKey(client.AgentId))
|
if (m_scene.Entities.ContainsKey(client.AgentId))
|
||||||
{
|
{
|
||||||
SendLandUpdate((ScenePresence)m_scene.Entities[client.AgentId], true);
|
SendLandUpdate((ScenePresence)m_scene.Entities[client.AgentId], true);
|
||||||
|
@ -129,6 +131,7 @@ namespace OpenSim.Region.CoreModules.World.Land
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
public void PostInitialise()
|
public void PostInitialise()
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
@ -1125,6 +1128,24 @@ namespace OpenSim.Region.CoreModules.World.Land
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void handleParcelDeedToGroup(int parcelLocalID, UUID groupID, IClientAPI remote_client)
|
||||||
|
{
|
||||||
|
// TODO: May want to validate that the group id is valid and that the remote client has the right to deed
|
||||||
|
ILandObject land;
|
||||||
|
lock (m_landList)
|
||||||
|
{
|
||||||
|
m_landList.TryGetValue(parcelLocalID, out land);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (land != null)
|
||||||
|
{
|
||||||
|
land.deedToGroup(groupID);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
#region Land Object From Storage Functions
|
#region Land Object From Storage Functions
|
||||||
|
|
||||||
public void IncomingLandObjectsFromStorage(List<LandData> data)
|
public void IncomingLandObjectsFromStorage(List<LandData> data)
|
||||||
|
|
|
@ -232,6 +232,18 @@ namespace OpenSim.Region.CoreModules.World.Land
|
||||||
sendLandUpdateToAvatarsOverMe();
|
sendLandUpdateToAvatarsOverMe();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public void deedToGroup(UUID groupID)
|
||||||
|
{
|
||||||
|
LandData newData = landData.Copy();
|
||||||
|
newData.OwnerID = groupID;
|
||||||
|
newData.GroupID = groupID;
|
||||||
|
newData.IsGroupOwned = true;
|
||||||
|
|
||||||
|
m_scene.LandChannel.UpdateLandObject(landData.LocalID, newData);
|
||||||
|
|
||||||
|
sendLandUpdateToAvatarsOverMe();
|
||||||
|
}
|
||||||
|
|
||||||
public bool isEitherBannedOrRestricted(UUID avatar)
|
public bool isEitherBannedOrRestricted(UUID avatar)
|
||||||
{
|
{
|
||||||
if (isBannedFromLand(avatar))
|
if (isBannedFromLand(avatar))
|
||||||
|
|
|
@ -76,6 +76,8 @@ namespace OpenSim.Region.Framework.Interfaces
|
||||||
void removePrimFromCount(SceneObjectGroup obj);
|
void removePrimFromCount(SceneObjectGroup obj);
|
||||||
void updateLandSold(UUID avatarID, UUID groupID, bool groupOwned, uint AuctionID, int claimprice, int area);
|
void updateLandSold(UUID avatarID, UUID groupID, bool groupOwned, uint AuctionID, int claimprice, int area);
|
||||||
|
|
||||||
|
void deedToGroup(UUID groupID);
|
||||||
|
|
||||||
void setParcelObjectMaxOverride(overrideParcelMaxPrimCountDelegate overrideDel);
|
void setParcelObjectMaxOverride(overrideParcelMaxPrimCountDelegate overrideDel);
|
||||||
void setSimulatorObjectMaxOverride(overrideSimulatorMaxPrimCountDelegate overrideDel);
|
void setSimulatorObjectMaxOverride(overrideSimulatorMaxPrimCountDelegate overrideDel);
|
||||||
|
|
||||||
|
|
|
@ -552,7 +552,10 @@ namespace OpenSim.Region.OptionalModules.Avatar.XmlRpcGroups
|
||||||
{
|
{
|
||||||
GroupTitlesData title = new GroupTitlesData();
|
GroupTitlesData title = new GroupTitlesData();
|
||||||
title.Name = role.Name;
|
title.Name = role.Name;
|
||||||
|
if (agentMembership != null)
|
||||||
|
{
|
||||||
title.Selected = agentMembership.ActiveRole == role.RoleID;
|
title.Selected = agentMembership.ActiveRole == role.RoleID;
|
||||||
|
}
|
||||||
title.UUID = role.RoleID;
|
title.UUID = role.RoleID;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue