diff options
author | Melanie | 2010-12-13 20:20:02 +0000 |
---|---|---|
committer | Melanie | 2010-12-13 20:20:02 +0000 |
commit | 7538926292ba3380f71f7fb3c004113dd2a92f95 (patch) | |
tree | 02619821cdb7207b6aae26c01ce6ca29d58ce452 /OpenSim/Region/CoreModules/World/Land | |
parent | Merge branch 'master' into careminster-presence-refactor (diff) | |
parent | Revamp the viewer -> banlist packet processing so fix a number of bugs. (diff) | |
download | opensim-SC-7538926292ba3380f71f7fb3c004113dd2a92f95.zip opensim-SC-7538926292ba3380f71f7fb3c004113dd2a92f95.tar.gz opensim-SC-7538926292ba3380f71f7fb3c004113dd2a92f95.tar.bz2 opensim-SC-7538926292ba3380f71f7fb3c004113dd2a92f95.tar.xz |
Merge branch 'careminster-presence-refactor' of ssh://melanie@3dhosting.de/var/git/careminster into careminster-presence-refactor
Diffstat (limited to 'OpenSim/Region/CoreModules/World/Land')
-rw-r--r-- | OpenSim/Region/CoreModules/World/Land/LandManagementModule.cs | 48 | ||||
-rw-r--r-- | OpenSim/Region/CoreModules/World/Land/LandObject.cs | 200 |
2 files changed, 174 insertions, 74 deletions
diff --git a/OpenSim/Region/CoreModules/World/Land/LandManagementModule.cs b/OpenSim/Region/CoreModules/World/Land/LandManagementModule.cs index 9779c68..8449cc1 100644 --- a/OpenSim/Region/CoreModules/World/Land/LandManagementModule.cs +++ b/OpenSim/Region/CoreModules/World/Land/LandManagementModule.cs | |||
@@ -167,7 +167,7 @@ namespace OpenSim.Region.CoreModules.World.Land | |||
167 | client.OnParcelSelectObjects += ClientOnParcelSelectObjects; | 167 | client.OnParcelSelectObjects += ClientOnParcelSelectObjects; |
168 | client.OnParcelObjectOwnerRequest += ClientOnParcelObjectOwnerRequest; | 168 | client.OnParcelObjectOwnerRequest += ClientOnParcelObjectOwnerRequest; |
169 | client.OnParcelAccessListRequest += ClientOnParcelAccessListRequest; | 169 | client.OnParcelAccessListRequest += ClientOnParcelAccessListRequest; |
170 | client.OnParcelAccessListUpdateRequest += ClientOnParcelAccessUpdateListRequest; | 170 | client.OnParcelAccessListUpdateRequest += ClientOnParcelAccessListUpdateRequest; |
171 | client.OnParcelAbandonRequest += ClientOnParcelAbandonRequest; | 171 | client.OnParcelAbandonRequest += ClientOnParcelAbandonRequest; |
172 | client.OnParcelGodForceOwner += ClientOnParcelGodForceOwner; | 172 | client.OnParcelGodForceOwner += ClientOnParcelGodForceOwner; |
173 | client.OnParcelReclaim += ClientOnParcelReclaim; | 173 | client.OnParcelReclaim += ClientOnParcelReclaim; |
@@ -516,14 +516,22 @@ namespace OpenSim.Region.CoreModules.World.Land | |||
516 | 516 | ||
517 | if (land != null) | 517 | if (land != null) |
518 | { | 518 | { |
519 | m_landList[landLocalID].SendAccessList(agentID, sessionID, flags, sequenceID, remote_client); | 519 | land.SendAccessList(agentID, sessionID, flags, sequenceID, remote_client); |
520 | } | 520 | } |
521 | } | 521 | } |
522 | 522 | ||
523 | public void ClientOnParcelAccessUpdateListRequest(UUID agentID, UUID sessionID, uint flags, int landLocalID, | 523 | public void ClientOnParcelAccessListUpdateRequest(UUID agentID, |
524 | List<ParcelManager.ParcelAccessEntry> entries, | 524 | uint flags, int landLocalID, UUID transactionID, int sequenceID, |
525 | IClientAPI remote_client) | 525 | int sections, List<ParcelManager.ParcelAccessEntry> entries, |
526 | IClientAPI remote_client) | ||
526 | { | 527 | { |
528 | // Flags is the list to update, it can mean either the ban or | ||
529 | // the access list (WTH is a pass list? Mentioned in ParcelFlags) | ||
530 | // | ||
531 | // There may be multiple packets, because these can get LONG. | ||
532 | // Use transactionID to determine a new chain of packets since | ||
533 | // packets may have come in out of sequence and that would be | ||
534 | // a big mess if using the sequenceID | ||
527 | ILandObject land; | 535 | ILandObject land; |
528 | lock (m_landList) | 536 | lock (m_landList) |
529 | { | 537 | { |
@@ -532,9 +540,15 @@ namespace OpenSim.Region.CoreModules.World.Land | |||
532 | 540 | ||
533 | if (land != null) | 541 | if (land != null) |
534 | { | 542 | { |
535 | if (agentID == land.LandData.OwnerID) | 543 | GroupPowers requiredPowers = GroupPowers.LandManageAllowed; |
544 | if (flags == (uint)AccessList.Ban) | ||
545 | requiredPowers = GroupPowers.LandManageBanned; | ||
546 | |||
547 | if (m_scene.Permissions.CanEditParcelProperties(agentID, | ||
548 | land, requiredPowers)) | ||
536 | { | 549 | { |
537 | land.UpdateAccessList(flags, entries, remote_client); | 550 | land.UpdateAccessList(flags, transactionID, sequenceID, |
551 | sections, entries, remote_client); | ||
538 | } | 552 | } |
539 | } | 553 | } |
540 | else | 554 | else |
@@ -862,7 +876,7 @@ namespace OpenSim.Region.CoreModules.World.Land | |||
862 | 876 | ||
863 | //If we are still here, then they are subdividing within one piece of land | 877 | //If we are still here, then they are subdividing within one piece of land |
864 | //Check owner | 878 | //Check owner |
865 | if (!m_scene.Permissions.CanEditParcel(attempting_user_id, startLandObject)) | 879 | if (!m_scene.Permissions.CanEditParcelProperties(attempting_user_id, startLandObject, GroupPowers.LandDivideJoin)) |
866 | { | 880 | { |
867 | return; | 881 | return; |
868 | } | 882 | } |
@@ -930,7 +944,7 @@ namespace OpenSim.Region.CoreModules.World.Land | |||
930 | { | 944 | { |
931 | return; | 945 | return; |
932 | } | 946 | } |
933 | if (!m_scene.Permissions.CanEditParcel(attempting_user_id, masterLandObject)) | 947 | if (!m_scene.Permissions.CanEditParcelProperties(attempting_user_id, masterLandObject, GroupPowers.LandDivideJoin)) |
934 | { | 948 | { |
935 | return; | 949 | return; |
936 | } | 950 | } |
@@ -1595,7 +1609,7 @@ namespace OpenSim.Region.CoreModules.World.Land | |||
1595 | 1609 | ||
1596 | if (land == null) return; | 1610 | if (land == null) return; |
1597 | 1611 | ||
1598 | if (!m_scene.Permissions.CanEditParcel(remoteClient.AgentId, land)) | 1612 | if (!m_scene.Permissions.CanEditParcelProperties(remoteClient.AgentId, land, GroupPowers.LandOptions)) |
1599 | return; | 1613 | return; |
1600 | 1614 | ||
1601 | land.LandData.OtherCleanTime = otherCleanTime; | 1615 | land.LandData.OtherCleanTime = otherCleanTime; |
@@ -1624,7 +1638,7 @@ namespace OpenSim.Region.CoreModules.World.Land | |||
1624 | ScenePresence SP; | 1638 | ScenePresence SP; |
1625 | ((Scene)client.Scene).TryGetScenePresence(client.AgentId, out SP); | 1639 | ((Scene)client.Scene).TryGetScenePresence(client.AgentId, out SP); |
1626 | List<SceneObjectGroup> returns = new List<SceneObjectGroup>(); | 1640 | List<SceneObjectGroup> returns = new List<SceneObjectGroup>(); |
1627 | if (SP.GodLevel != 0) | 1641 | if (SP.UserLevel != 0) |
1628 | { | 1642 | { |
1629 | if (flags == 0) //All parcels, scripted or not | 1643 | if (flags == 0) //All parcels, scripted or not |
1630 | { | 1644 | { |
@@ -1692,10 +1706,10 @@ namespace OpenSim.Region.CoreModules.World.Land | |||
1692 | ((Scene)client.Scene).TryGetScenePresence(client.AgentId, out parcelManager); | 1706 | ((Scene)client.Scene).TryGetScenePresence(client.AgentId, out parcelManager); |
1693 | System.Threading.Timer Timer; | 1707 | System.Threading.Timer Timer; |
1694 | 1708 | ||
1695 | if (targetAvatar.GodLevel == 0) | 1709 | if (targetAvatar.UserLevel == 0) |
1696 | { | 1710 | { |
1697 | ILandObject land = ((Scene)client.Scene).LandChannel.GetLandObject(targetAvatar.AbsolutePosition.X, targetAvatar.AbsolutePosition.Y); | 1711 | ILandObject land = ((Scene)client.Scene).LandChannel.GetLandObject(targetAvatar.AbsolutePosition.X, targetAvatar.AbsolutePosition.Y); |
1698 | if (!((Scene)client.Scene).Permissions.CanEditParcel(client.AgentId, land)) | 1712 | if (!((Scene)client.Scene).Permissions.CanEditParcelProperties(client.AgentId, land, GroupPowers.LandEjectAndFreeze)) |
1699 | return; | 1713 | return; |
1700 | if (flags == 0) | 1714 | if (flags == 0) |
1701 | { | 1715 | { |
@@ -1737,10 +1751,10 @@ namespace OpenSim.Region.CoreModules.World.Land | |||
1737 | //Just eject | 1751 | //Just eject |
1738 | if (flags == 0) | 1752 | if (flags == 0) |
1739 | { | 1753 | { |
1740 | if (targetAvatar.GodLevel == 0) | 1754 | if (targetAvatar.UserLevel == 0) |
1741 | { | 1755 | { |
1742 | ILandObject land = ((Scene)client.Scene).LandChannel.GetLandObject(targetAvatar.AbsolutePosition.X, targetAvatar.AbsolutePosition.Y); | 1756 | ILandObject land = ((Scene)client.Scene).LandChannel.GetLandObject(targetAvatar.AbsolutePosition.X, targetAvatar.AbsolutePosition.Y); |
1743 | if (!((Scene)client.Scene).Permissions.CanEditParcel(client.AgentId, land)) | 1757 | if (!((Scene)client.Scene).Permissions.CanEditParcelProperties(client.AgentId, land, GroupPowers.LandEjectAndFreeze)) |
1744 | return; | 1758 | return; |
1745 | 1759 | ||
1746 | Vector3 position = new Vector3(0, 0, 0); | 1760 | Vector3 position = new Vector3(0, 0, 0); |
@@ -1816,10 +1830,10 @@ namespace OpenSim.Region.CoreModules.World.Land | |||
1816 | //Eject and ban | 1830 | //Eject and ban |
1817 | if (flags == 1) | 1831 | if (flags == 1) |
1818 | { | 1832 | { |
1819 | if (targetAvatar.GodLevel == 0) | 1833 | if (targetAvatar.UserLevel == 0) |
1820 | { | 1834 | { |
1821 | ILandObject land = ((Scene)client.Scene).LandChannel.GetLandObject(targetAvatar.AbsolutePosition.X, targetAvatar.AbsolutePosition.Y); | 1835 | ILandObject land = ((Scene)client.Scene).LandChannel.GetLandObject(targetAvatar.AbsolutePosition.X, targetAvatar.AbsolutePosition.Y); |
1822 | if (!((Scene)client.Scene).Permissions.CanEditParcel(client.AgentId, land)) | 1836 | if (!((Scene)client.Scene).Permissions.CanEditParcelProperties(client.AgentId, land, GroupPowers.LandEjectAndFreeze)) |
1823 | return; | 1837 | return; |
1824 | 1838 | ||
1825 | Vector3 position = new Vector3(0, 0, 0); | 1839 | Vector3 position = new Vector3(0, 0, 0); |
diff --git a/OpenSim/Region/CoreModules/World/Land/LandObject.cs b/OpenSim/Region/CoreModules/World/Land/LandObject.cs index d596887..8483e32 100644 --- a/OpenSim/Region/CoreModules/World/Land/LandObject.cs +++ b/OpenSim/Region/CoreModules/World/Land/LandObject.cs | |||
@@ -54,6 +54,7 @@ namespace OpenSim.Region.CoreModules.World.Land | |||
54 | protected LandData m_landData = new LandData(); | 54 | protected LandData m_landData = new LandData(); |
55 | protected Scene m_scene; | 55 | protected Scene m_scene; |
56 | protected List<SceneObjectGroup> primsOverMe = new List<SceneObjectGroup>(); | 56 | protected List<SceneObjectGroup> primsOverMe = new List<SceneObjectGroup>(); |
57 | protected Dictionary<uint, UUID> m_listTransactions = new Dictionary<uint, UUID>(); | ||
57 | 58 | ||
58 | public bool[,] LandBitmap | 59 | public bool[,] LandBitmap |
59 | { | 60 | { |
@@ -199,36 +200,81 @@ namespace OpenSim.Region.CoreModules.World.Land | |||
199 | 200 | ||
200 | public void UpdateLandProperties(LandUpdateArgs args, IClientAPI remote_client) | 201 | public void UpdateLandProperties(LandUpdateArgs args, IClientAPI remote_client) |
201 | { | 202 | { |
202 | if (m_scene.Permissions.CanEditParcel(remote_client.AgentId,this)) | 203 | //Needs later group support |
204 | bool snap_selection = false; | ||
205 | LandData newData = LandData.Copy(); | ||
206 | |||
207 | uint allowedDelta = 0; | ||
208 | |||
209 | // These two are always blocked as no client can set them anyway | ||
210 | // ParcelFlags.ForSaleObjects | ||
211 | // ParcelFlags.LindenHome | ||
212 | |||
213 | if (m_scene.Permissions.CanEditParcelProperties(remote_client.AgentId, this, GroupPowers.LandOptions)) | ||
203 | { | 214 | { |
204 | //Needs later group support | 215 | allowedDelta |= (uint)(ParcelFlags.AllowLandmark | |
205 | bool snap_selection = false; | 216 | ParcelFlags.AllowTerraform | |
206 | LandData newData = LandData.Copy(); | 217 | ParcelFlags.AllowDamage | |
218 | ParcelFlags.CreateObjects | | ||
219 | ParcelFlags.RestrictPushObject | | ||
220 | ParcelFlags.AllowGroupScripts | | ||
221 | ParcelFlags.CreateGroupObjects | | ||
222 | ParcelFlags.AllowAPrimitiveEntry | | ||
223 | ParcelFlags.AllowGroupObjectEntry); | ||
224 | } | ||
207 | 225 | ||
208 | if (args.AuthBuyerID != newData.AuthBuyerID || args.SalePrice != newData.SalePrice) | 226 | if (m_scene.Permissions.CanEditParcelProperties(remote_client.AgentId, this, GroupPowers.LandSetSale)) |
227 | { | ||
228 | if (args.AuthBuyerID != newData.AuthBuyerID || | ||
229 | args.SalePrice != newData.SalePrice) | ||
209 | { | 230 | { |
210 | if (m_scene.Permissions.CanSellParcel(remote_client.AgentId, this)) | 231 | snap_selection = true; |
211 | { | 232 | } |
212 | newData.AuthBuyerID = args.AuthBuyerID; | 233 | |
213 | newData.SalePrice = args.SalePrice; | 234 | newData.AuthBuyerID = args.AuthBuyerID; |
214 | snap_selection = true; | 235 | newData.SalePrice = args.SalePrice; |
215 | } | 236 | |
237 | if (!LandData.IsGroupOwned) | ||
238 | { | ||
239 | newData.GroupID = args.GroupID; | ||
240 | |||
241 | allowedDelta |= (uint)(ParcelFlags.AllowDeedToGroup | | ||
242 | ParcelFlags.ContributeWithDeed | | ||
243 | ParcelFlags.SellParcelObjects); | ||
216 | } | 244 | } |
245 | |||
246 | allowedDelta |= (uint)ParcelFlags.ForSale; | ||
247 | } | ||
248 | |||
249 | if (m_scene.Permissions.CanEditParcelProperties(remote_client.AgentId,this, GroupPowers.FindPlaces)) | ||
250 | { | ||
217 | newData.Category = args.Category; | 251 | newData.Category = args.Category; |
252 | |||
253 | allowedDelta |= (uint)(ParcelFlags.ShowDirectory | | ||
254 | ParcelFlags.AllowPublish | | ||
255 | ParcelFlags.MaturePublish); | ||
256 | } | ||
257 | |||
258 | if (m_scene.Permissions.CanEditParcelProperties(remote_client.AgentId,this, GroupPowers.LandChangeIdentity)) | ||
259 | { | ||
218 | newData.Description = args.Desc; | 260 | newData.Description = args.Desc; |
219 | newData.GroupID = args.GroupID; | 261 | newData.Name = args.Name; |
262 | newData.SnapshotID = args.SnapshotID; | ||
263 | } | ||
264 | |||
265 | if (m_scene.Permissions.CanEditParcelProperties(remote_client.AgentId,this, GroupPowers.SetLandingPoint)) | ||
266 | { | ||
220 | newData.LandingType = args.LandingType; | 267 | newData.LandingType = args.LandingType; |
268 | newData.UserLocation = args.UserLocation; | ||
269 | newData.UserLookAt = args.UserLookAt; | ||
270 | } | ||
271 | |||
272 | if (m_scene.Permissions.CanEditParcelProperties(remote_client.AgentId,this, GroupPowers.ChangeMedia)) | ||
273 | { | ||
221 | newData.MediaAutoScale = args.MediaAutoScale; | 274 | newData.MediaAutoScale = args.MediaAutoScale; |
222 | newData.MediaID = args.MediaID; | 275 | newData.MediaID = args.MediaID; |
223 | newData.MediaURL = args.MediaURL; | 276 | newData.MediaURL = args.MediaURL; |
224 | newData.MusicURL = args.MusicURL; | 277 | newData.MusicURL = args.MusicURL; |
225 | newData.Name = args.Name; | ||
226 | newData.Flags = args.ParcelFlags; | ||
227 | newData.PassHours = args.PassHours; | ||
228 | newData.PassPrice = args.PassPrice; | ||
229 | newData.SnapshotID = args.SnapshotID; | ||
230 | newData.UserLocation = args.UserLocation; | ||
231 | newData.UserLookAt = args.UserLookAt; | ||
232 | newData.MediaType = args.MediaType; | 278 | newData.MediaType = args.MediaType; |
233 | newData.MediaDescription = args.MediaDescription; | 279 | newData.MediaDescription = args.MediaDescription; |
234 | newData.MediaWidth = args.MediaWidth; | 280 | newData.MediaWidth = args.MediaWidth; |
@@ -237,10 +283,40 @@ namespace OpenSim.Region.CoreModules.World.Land | |||
237 | newData.ObscureMusic = args.ObscureMusic; | 283 | newData.ObscureMusic = args.ObscureMusic; |
238 | newData.ObscureMedia = args.ObscureMedia; | 284 | newData.ObscureMedia = args.ObscureMedia; |
239 | 285 | ||
240 | m_scene.LandChannel.UpdateLandObject(LandData.LocalID, newData); | 286 | allowedDelta |= (uint)(ParcelFlags.SoundLocal | |
287 | ParcelFlags.UrlWebPage | | ||
288 | ParcelFlags.UrlRawHtml | | ||
289 | ParcelFlags.AllowVoiceChat | | ||
290 | ParcelFlags.UseEstateVoiceChan); | ||
291 | } | ||
292 | |||
293 | if (m_scene.Permissions.CanEditParcelProperties(remote_client.AgentId,this, GroupPowers.LandManagePasses)) | ||
294 | { | ||
295 | newData.PassHours = args.PassHours; | ||
296 | newData.PassPrice = args.PassPrice; | ||
297 | |||
298 | allowedDelta |= (uint)ParcelFlags.UsePassList; | ||
299 | } | ||
300 | |||
301 | if (m_scene.Permissions.CanEditParcelProperties(remote_client.AgentId, this, GroupPowers.LandManageAllowed)) | ||
302 | { | ||
303 | allowedDelta |= (uint)(ParcelFlags.UseAccessGroup | | ||
304 | ParcelFlags.UseAccessList); | ||
305 | } | ||
241 | 306 | ||
242 | SendLandUpdateToAvatarsOverMe(snap_selection); | 307 | if (m_scene.Permissions.CanEditParcelProperties(remote_client.AgentId, this, GroupPowers.LandManageBanned)) |
308 | { | ||
309 | allowedDelta |= (uint)(ParcelFlags.UseBanList | | ||
310 | ParcelFlags.DenyAnonymous | | ||
311 | ParcelFlags.DenyAgeUnverified); | ||
243 | } | 312 | } |
313 | |||
314 | uint preserve = LandData.Flags & ~allowedDelta; | ||
315 | newData.Flags = preserve | (args.ParcelFlags & allowedDelta); | ||
316 | |||
317 | m_scene.LandChannel.UpdateLandObject(LandData.LocalID, newData); | ||
318 | |||
319 | SendLandUpdateToAvatarsOverMe(snap_selection); | ||
244 | } | 320 | } |
245 | 321 | ||
246 | public void UpdateLandSold(UUID avatarID, UUID groupID, bool groupOwned, uint AuctionID, int claimprice, int area) | 322 | public void UpdateLandSold(UUID avatarID, UUID groupID, bool groupOwned, uint AuctionID, int claimprice, int area) |
@@ -326,14 +402,14 @@ namespace OpenSim.Region.CoreModules.World.Land | |||
326 | 402 | ||
327 | if ((LandData.Flags & (uint) ParcelFlags.UseBanList) > 0) | 403 | if ((LandData.Flags & (uint) ParcelFlags.UseBanList) > 0) |
328 | { | 404 | { |
329 | ParcelManager.ParcelAccessEntry entry = new ParcelManager.ParcelAccessEntry(); | 405 | if (LandData.ParcelAccessList.FindIndex( |
330 | entry.AgentID = avatar; | 406 | delegate(ParcelManager.ParcelAccessEntry e) |
331 | entry.Flags = AccessList.Ban; | 407 | { |
332 | entry.Time = new DateTime(); | 408 | if (e.AgentID == avatar && e.Flags == AccessList.Ban) |
333 | //See if they are on the list, but make sure the owner isn't banned | 409 | return true; |
334 | if (LandData.ParcelAccessList.Contains(entry) && LandData.OwnerID != avatar) | 410 | return false; |
411 | }) != -1 && LandData.OwnerID != avatar) | ||
335 | { | 412 | { |
336 | //They are banned, so lets send them a notice about this parcel | ||
337 | return true; | 413 | return true; |
338 | } | 414 | } |
339 | } | 415 | } |
@@ -347,17 +423,16 @@ namespace OpenSim.Region.CoreModules.World.Land | |||
347 | 423 | ||
348 | if ((LandData.Flags & (uint) ParcelFlags.UseAccessList) > 0) | 424 | if ((LandData.Flags & (uint) ParcelFlags.UseAccessList) > 0) |
349 | { | 425 | { |
350 | ParcelManager.ParcelAccessEntry entry = new ParcelManager.ParcelAccessEntry(); | 426 | if (LandData.ParcelAccessList.FindIndex( |
351 | entry.AgentID = avatar; | 427 | delegate(ParcelManager.ParcelAccessEntry e) |
352 | entry.Flags = AccessList.Access; | 428 | { |
353 | entry.Time = new DateTime(); | 429 | if (e.AgentID == avatar && e.Flags == AccessList.Access) |
354 | 430 | return true; | |
355 | //If they are not on the access list and are not the owner | 431 | return false; |
356 | if (!LandData.ParcelAccessList.Contains(entry) && LandData.OwnerID != avatar) | 432 | }) == -1 && LandData.OwnerID != avatar) |
357 | { | 433 | { |
358 | if (!HasGroupAccess(avatar)) | 434 | if (!HasGroupAccess(avatar)) |
359 | { | 435 | { |
360 | //They are not allowed in this parcel, but not banned, so lets send them a notice about this parcel | ||
361 | return true; | 436 | return true; |
362 | } | 437 | } |
363 | } | 438 | } |
@@ -456,39 +531,50 @@ namespace OpenSim.Region.CoreModules.World.Land | |||
456 | } | 531 | } |
457 | } | 532 | } |
458 | 533 | ||
459 | public void UpdateAccessList(uint flags, List<ParcelManager.ParcelAccessEntry> entries, IClientAPI remote_client) | 534 | public void UpdateAccessList(uint flags, UUID transactionID, |
535 | int sequenceID, int sections, | ||
536 | List<ParcelManager.ParcelAccessEntry> entries, | ||
537 | IClientAPI remote_client) | ||
460 | { | 538 | { |
461 | LandData newData = LandData.Copy(); | 539 | LandData newData = LandData.Copy(); |
462 | 540 | ||
463 | if (entries.Count == 1 && entries[0].AgentID == UUID.Zero) | 541 | if ((!m_listTransactions.ContainsKey(flags)) || |
542 | m_listTransactions[flags] != transactionID) | ||
464 | { | 543 | { |
465 | entries.Clear(); | 544 | m_listTransactions[flags] = transactionID; |
466 | } | ||
467 | 545 | ||
468 | List<ParcelManager.ParcelAccessEntry> toRemove = new List<ParcelManager.ParcelAccessEntry>(); | 546 | List<ParcelManager.ParcelAccessEntry> toRemove = |
469 | foreach (ParcelManager.ParcelAccessEntry entry in newData.ParcelAccessList) | 547 | new List<ParcelManager.ParcelAccessEntry>(); |
470 | { | 548 | |
471 | if (entry.Flags == (AccessList)flags) | 549 | foreach (ParcelManager.ParcelAccessEntry entry in newData.ParcelAccessList) |
472 | { | 550 | { |
473 | toRemove.Add(entry); | 551 | if (entry.Flags == (AccessList)flags) |
552 | toRemove.Add(entry); | ||
474 | } | 553 | } |
475 | } | ||
476 | 554 | ||
477 | foreach (ParcelManager.ParcelAccessEntry entry in toRemove) | 555 | foreach (ParcelManager.ParcelAccessEntry entry in toRemove) |
478 | { | 556 | { |
479 | newData.ParcelAccessList.Remove(entry); | 557 | newData.ParcelAccessList.Remove(entry); |
558 | } | ||
559 | |||
560 | // Checked here because this will always be the first | ||
561 | // and only packet in a transaction | ||
562 | if (entries.Count == 1 && entries[0].AgentID == UUID.Zero) | ||
563 | { | ||
564 | return; | ||
565 | } | ||
480 | } | 566 | } |
567 | |||
481 | foreach (ParcelManager.ParcelAccessEntry entry in entries) | 568 | foreach (ParcelManager.ParcelAccessEntry entry in entries) |
482 | { | 569 | { |
483 | ParcelManager.ParcelAccessEntry temp = new ParcelManager.ParcelAccessEntry(); | 570 | ParcelManager.ParcelAccessEntry temp = |
571 | new ParcelManager.ParcelAccessEntry(); | ||
572 | |||
484 | temp.AgentID = entry.AgentID; | 573 | temp.AgentID = entry.AgentID; |
485 | temp.Time = new DateTime(); //Pointless? Yes. | 574 | temp.Time = entry.Time; |
486 | temp.Flags = (AccessList)flags; | 575 | temp.Flags = (AccessList)flags; |
487 | 576 | ||
488 | if (!newData.ParcelAccessList.Contains(temp)) | 577 | newData.ParcelAccessList.Add(temp); |
489 | { | ||
490 | newData.ParcelAccessList.Add(temp); | ||
491 | } | ||
492 | } | 578 | } |
493 | 579 | ||
494 | m_scene.LandChannel.UpdateLandObject(LandData.LocalID, newData); | 580 | m_scene.LandChannel.UpdateLandObject(LandData.LocalID, newData); |
@@ -746,7 +832,7 @@ namespace OpenSim.Region.CoreModules.World.Land | |||
746 | 832 | ||
747 | public void SendForceObjectSelect(int local_id, int request_type, List<UUID> returnIDs, IClientAPI remote_client) | 833 | public void SendForceObjectSelect(int local_id, int request_type, List<UUID> returnIDs, IClientAPI remote_client) |
748 | { | 834 | { |
749 | if (m_scene.Permissions.CanEditParcel(remote_client.AgentId, this)) | 835 | if (m_scene.Permissions.CanEditParcelProperties(remote_client.AgentId, this, GroupPowers.LandOptions)) |
750 | { | 836 | { |
751 | List<uint> resultLocalIDs = new List<uint>(); | 837 | List<uint> resultLocalIDs = new List<uint>(); |
752 | try | 838 | try |
@@ -796,7 +882,7 @@ namespace OpenSim.Region.CoreModules.World.Land | |||
796 | /// </param> | 882 | /// </param> |
797 | public void SendLandObjectOwners(IClientAPI remote_client) | 883 | public void SendLandObjectOwners(IClientAPI remote_client) |
798 | { | 884 | { |
799 | if (m_scene.Permissions.CanEditParcel(remote_client.AgentId, this)) | 885 | if (m_scene.Permissions.CanEditParcelProperties(remote_client.AgentId, this, GroupPowers.LandOptions)) |
800 | { | 886 | { |
801 | Dictionary<UUID, int> primCount = new Dictionary<UUID, int>(); | 887 | Dictionary<UUID, int> primCount = new Dictionary<UUID, int>(); |
802 | List<UUID> groups = new List<UUID>(); | 888 | List<UUID> groups = new List<UUID>(); |