aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/OpenSim/Region/CoreModules
diff options
context:
space:
mode:
Diffstat (limited to 'OpenSim/Region/CoreModules')
-rw-r--r--OpenSim/Region/CoreModules/World/Land/LandManagementModule.cs6
-rw-r--r--OpenSim/Region/CoreModules/World/Land/LandObject.cs78
2 files changed, 57 insertions, 27 deletions
diff --git a/OpenSim/Region/CoreModules/World/Land/LandManagementModule.cs b/OpenSim/Region/CoreModules/World/Land/LandManagementModule.cs
index 5db56b0..0f83d82 100644
--- a/OpenSim/Region/CoreModules/World/Land/LandManagementModule.cs
+++ b/OpenSim/Region/CoreModules/World/Land/LandManagementModule.cs
@@ -508,7 +508,7 @@ namespace OpenSim.Region.CoreModules.World.Land
508 508
509 public void ClientOnParcelAccessListUpdateRequest(UUID agentID, 509 public void ClientOnParcelAccessListUpdateRequest(UUID agentID,
510 uint flags, int landLocalID, UUID transactionID, int sequenceID, 510 uint flags, int landLocalID, UUID transactionID, int sequenceID,
511 int sections, List<ParcelManager.ParcelAccessEntry> entries, 511 int sections, List<LandAccessEntry> entries,
512 IClientAPI remote_client) 512 IClientAPI remote_client)
513 { 513 {
514 // Flags is the list to update, it can mean either the ban or 514 // Flags is the list to update, it can mean either the ban or
@@ -1777,10 +1777,10 @@ namespace OpenSim.Region.CoreModules.World.Land
1777 1777
1778 if ((flags & 1) != 0) // Ban TODO: Remove magic number 1778 if ((flags & 1) != 0) // Ban TODO: Remove magic number
1779 { 1779 {
1780 ParcelManager.ParcelAccessEntry entry = new ParcelManager.ParcelAccessEntry(); 1780 LandAccessEntry entry = new LandAccessEntry();
1781 entry.AgentID = targetAvatar.UUID; 1781 entry.AgentID = targetAvatar.UUID;
1782 entry.Flags = AccessList.Ban; 1782 entry.Flags = AccessList.Ban;
1783 entry.Time = new DateTime(); 1783 entry.Expires = 0; // Perm
1784 1784
1785 land.LandData.ParcelAccessList.Add(entry); 1785 land.LandData.ParcelAccessList.Add(entry);
1786 } 1786 }
diff --git a/OpenSim/Region/CoreModules/World/Land/LandObject.cs b/OpenSim/Region/CoreModules/World/Land/LandObject.cs
index 07b28c7..debf6d2 100644
--- a/OpenSim/Region/CoreModules/World/Land/LandObject.cs
+++ b/OpenSim/Region/CoreModules/World/Land/LandObject.cs
@@ -467,21 +467,26 @@ namespace OpenSim.Region.CoreModules.World.Land
467 467
468 public bool IsBannedFromLand(UUID avatar) 468 public bool IsBannedFromLand(UUID avatar)
469 { 469 {
470 ExpireAccessList();
471
470 if (m_scene.Permissions.IsAdministrator(avatar)) 472 if (m_scene.Permissions.IsAdministrator(avatar))
471 return false; 473 return false;
472 474
473 if (m_scene.RegionInfo.EstateSettings.IsEstateManager(avatar)) 475 if (m_scene.RegionInfo.EstateSettings.IsEstateManager(avatar))
474 return false; 476 return false;
475 477
478 if (avatar == LandData.OwnerID)
479 return false;
480
476 if ((LandData.Flags & (uint) ParcelFlags.UseBanList) > 0) 481 if ((LandData.Flags & (uint) ParcelFlags.UseBanList) > 0)
477 { 482 {
478 if (LandData.ParcelAccessList.FindIndex( 483 if (LandData.ParcelAccessList.FindIndex(
479 delegate(ParcelManager.ParcelAccessEntry e) 484 delegate(LandAccessEntry e)
480 { 485 {
481 if (e.AgentID == avatar && e.Flags == AccessList.Ban) 486 if (e.AgentID == avatar && e.Flags == AccessList.Ban)
482 return true; 487 return true;
483 return false; 488 return false;
484 }) != -1 && LandData.OwnerID != avatar) 489 }) != -1)
485 { 490 {
486 return true; 491 return true;
487 } 492 }
@@ -491,21 +496,26 @@ namespace OpenSim.Region.CoreModules.World.Land
491 496
492 public bool IsRestrictedFromLand(UUID avatar) 497 public bool IsRestrictedFromLand(UUID avatar)
493 { 498 {
499 ExpireAccessList();
500
494 if (m_scene.Permissions.IsAdministrator(avatar)) 501 if (m_scene.Permissions.IsAdministrator(avatar))
495 return false; 502 return false;
496 503
497 if (m_scene.RegionInfo.EstateSettings.IsEstateManager(avatar)) 504 if (m_scene.RegionInfo.EstateSettings.IsEstateManager(avatar))
498 return false; 505 return false;
499 506
507 if (avatar == LandData.OwnerID)
508 return false;
509
500 if ((LandData.Flags & (uint) ParcelFlags.UseAccessList) > 0) 510 if ((LandData.Flags & (uint) ParcelFlags.UseAccessList) > 0)
501 { 511 {
502 if (LandData.ParcelAccessList.FindIndex( 512 if (LandData.ParcelAccessList.FindIndex(
503 delegate(ParcelManager.ParcelAccessEntry e) 513 delegate(LandAccessEntry e)
504 { 514 {
505 if (e.AgentID == avatar && e.Flags == AccessList.Access) 515 if (e.AgentID == avatar && e.Flags == AccessList.Access)
506 return true; 516 return true;
507 return false; 517 return false;
508 }) == -1 && LandData.OwnerID != avatar) 518 }) == -1)
509 { 519 {
510 if (!HasGroupAccess(avatar)) 520 if (!HasGroupAccess(avatar))
511 { 521 {
@@ -570,19 +580,24 @@ namespace OpenSim.Region.CoreModules.World.Land
570 580
571 #region AccessList Functions 581 #region AccessList Functions
572 582
573 public List<UUID> CreateAccessListArrayByFlag(AccessList flag) 583 public List<LandAccessEntry> CreateAccessListArrayByFlag(AccessList flag)
574 { 584 {
575 List<UUID> list = new List<UUID>(); 585 ExpireAccessList();
576 foreach (ParcelManager.ParcelAccessEntry entry in LandData.ParcelAccessList) 586
587 List<LandAccessEntry> list = new List<LandAccessEntry>();
588 foreach (LandAccessEntry entry in LandData.ParcelAccessList)
577 { 589 {
578 if (entry.Flags == flag) 590 if (entry.Flags == flag)
579 { 591 list.Add(entry);
580 list.Add(entry.AgentID);
581 }
582 } 592 }
583 if (list.Count == 0) 593 if (list.Count == 0)
584 { 594 {
585 list.Add(UUID.Zero); 595 LandAccessEntry e = new LandAccessEntry();
596 e.AgentID = UUID.Zero;
597 e.Flags = 0;
598 e.Expires = 0;
599
600 list.Add(e);
586 } 601 }
587 602
588 return list; 603 return list;
@@ -594,20 +609,20 @@ namespace OpenSim.Region.CoreModules.World.Land
594 609
595 if (flags == (uint) AccessList.Access || flags == (uint) AccessList.Both) 610 if (flags == (uint) AccessList.Access || flags == (uint) AccessList.Both)
596 { 611 {
597 List<UUID> avatars = CreateAccessListArrayByFlag(AccessList.Access); 612 List<LandAccessEntry> accessEntries = CreateAccessListArrayByFlag(AccessList.Access);
598 remote_client.SendLandAccessListData(avatars,(uint) AccessList.Access,LandData.LocalID); 613 remote_client.SendLandAccessListData(accessEntries,(uint) AccessList.Access,LandData.LocalID);
599 } 614 }
600 615
601 if (flags == (uint) AccessList.Ban || flags == (uint) AccessList.Both) 616 if (flags == (uint) AccessList.Ban || flags == (uint) AccessList.Both)
602 { 617 {
603 List<UUID> avatars = CreateAccessListArrayByFlag(AccessList.Ban); 618 List<LandAccessEntry> accessEntries = CreateAccessListArrayByFlag(AccessList.Ban);
604 remote_client.SendLandAccessListData(avatars, (uint)AccessList.Ban, LandData.LocalID); 619 remote_client.SendLandAccessListData(accessEntries, (uint)AccessList.Ban, LandData.LocalID);
605 } 620 }
606 } 621 }
607 622
608 public void UpdateAccessList(uint flags, UUID transactionID, 623 public void UpdateAccessList(uint flags, UUID transactionID,
609 int sequenceID, int sections, 624 int sequenceID, int sections,
610 List<ParcelManager.ParcelAccessEntry> entries, 625 List<LandAccessEntry> entries,
611 IClientAPI remote_client) 626 IClientAPI remote_client)
612 { 627 {
613 LandData newData = LandData.Copy(); 628 LandData newData = LandData.Copy();
@@ -617,16 +632,16 @@ namespace OpenSim.Region.CoreModules.World.Land
617 { 632 {
618 m_listTransactions[flags] = transactionID; 633 m_listTransactions[flags] = transactionID;
619 634
620 List<ParcelManager.ParcelAccessEntry> toRemove = 635 List<LandAccessEntry> toRemove =
621 new List<ParcelManager.ParcelAccessEntry>(); 636 new List<LandAccessEntry>();
622 637
623 foreach (ParcelManager.ParcelAccessEntry entry in newData.ParcelAccessList) 638 foreach (LandAccessEntry entry in newData.ParcelAccessList)
624 { 639 {
625 if (entry.Flags == (AccessList)flags) 640 if (entry.Flags == (AccessList)flags)
626 toRemove.Add(entry); 641 toRemove.Add(entry);
627 } 642 }
628 643
629 foreach (ParcelManager.ParcelAccessEntry entry in toRemove) 644 foreach (LandAccessEntry entry in toRemove)
630 { 645 {
631 newData.ParcelAccessList.Remove(entry); 646 newData.ParcelAccessList.Remove(entry);
632 } 647 }
@@ -641,13 +656,13 @@ namespace OpenSim.Region.CoreModules.World.Land
641 } 656 }
642 } 657 }
643 658
644 foreach (ParcelManager.ParcelAccessEntry entry in entries) 659 foreach (LandAccessEntry entry in entries)
645 { 660 {
646 ParcelManager.ParcelAccessEntry temp = 661 LandAccessEntry temp =
647 new ParcelManager.ParcelAccessEntry(); 662 new LandAccessEntry();
648 663
649 temp.AgentID = entry.AgentID; 664 temp.AgentID = entry.AgentID;
650 temp.Time = entry.Time; 665 temp.Expires = entry.Expires;
651 temp.Flags = (AccessList)flags; 666 temp.Flags = (AccessList)flags;
652 667
653 newData.ParcelAccessList.Add(temp); 668 newData.ParcelAccessList.Add(temp);
@@ -1164,5 +1179,20 @@ namespace OpenSim.Region.CoreModules.World.Land
1164 } 1179 }
1165 1180
1166 #endregion 1181 #endregion
1182
1183 private void ExpireAccessList()
1184 {
1185 List<LandAccessEntry> delete = new List<LandAccessEntry>();
1186
1187 foreach (LandAccessEntry entry in LandData.ParcelAccessList)
1188 {
1189 if (entry.Expires != 0 && entry.Expires < Util.UnixTimeSinceEpoch())
1190 delete.Add(entry);
1191 }
1192 foreach (LandAccessEntry entry in delete)
1193 LandData.ParcelAccessList.Remove(entry);
1194
1195 m_scene.EventManager.TriggerLandObjectUpdated((uint)LandData.LocalID, this);
1196 }
1167 } 1197 }
1168} 1198}