aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/OpenSim/Region
diff options
context:
space:
mode:
Diffstat (limited to '')
-rw-r--r--OpenSim/Region/ClientStack/Linden/UDP/LLClientView.cs23
-rw-r--r--OpenSim/Region/CoreModules/World/Permissions/PermissionsModule.cs43
-rw-r--r--OpenSim/Region/Framework/Scenes/Scene.Permissions.cs6
3 files changed, 53 insertions, 19 deletions
diff --git a/OpenSim/Region/ClientStack/Linden/UDP/LLClientView.cs b/OpenSim/Region/ClientStack/Linden/UDP/LLClientView.cs
index df34668..8ba1ba3 100644
--- a/OpenSim/Region/ClientStack/Linden/UDP/LLClientView.cs
+++ b/OpenSim/Region/ClientStack/Linden/UDP/LLClientView.cs
@@ -4126,14 +4126,17 @@ namespace OpenSim.Region.ClientStack.LindenUDP
4126// Vector3 mycamera = Vector3.Zero; 4126// Vector3 mycamera = Vector3.Zero;
4127 Vector3 mypos = Vector3.Zero; 4127 Vector3 mypos = Vector3.Zero;
4128 ScenePresence mysp = (ScenePresence)SceneAgent; 4128 ScenePresence mysp = (ScenePresence)SceneAgent;
4129 if(mysp != null && !mysp.IsDeleted) 4129
4130 // we should have a presence
4131 if(mysp == null)
4132 return;
4133
4134 if(doCulling)
4130 { 4135 {
4131 cullingrange = mysp.DrawDistance + m_scene.ReprioritizationDistance + 16f; 4136 cullingrange = mysp.DrawDistance + m_scene.ReprioritizationDistance + 16f;
4132// mycamera = mysp.CameraPosition; 4137// mycamera = mysp.CameraPosition;
4133 mypos = mysp.AbsolutePosition; 4138 mypos = mysp.AbsolutePosition;
4134 } 4139 }
4135 else
4136 doCulling = false;
4137 4140
4138 while (maxUpdatesBytes > 0) 4141 while (maxUpdatesBytes > 0)
4139 { 4142 {
@@ -4330,7 +4333,7 @@ namespace OpenSim.Region.ClientStack.LindenUDP
4330 if (update.Entity is ScenePresence) 4333 if (update.Entity is ScenePresence)
4331 ablock = CreateAvatarUpdateBlock((ScenePresence)update.Entity); 4334 ablock = CreateAvatarUpdateBlock((ScenePresence)update.Entity);
4332 else 4335 else
4333 ablock = CreatePrimUpdateBlock((SceneObjectPart)update.Entity, this.m_agentId); 4336 ablock = CreatePrimUpdateBlock((SceneObjectPart)update.Entity, mysp);
4334 objectUpdateBlocks.Add(ablock); 4337 objectUpdateBlocks.Add(ablock);
4335 objectUpdates.Value.Add(update); 4338 objectUpdates.Value.Add(update);
4336 maxUpdatesBytes -= ablock.Length; 4339 maxUpdatesBytes -= ablock.Length;
@@ -4462,6 +4465,7 @@ namespace OpenSim.Region.ClientStack.LindenUDP
4462 } 4465 }
4463 4466
4464 // hack.. dont use 4467 // hack.. dont use
4468/*
4465 public void SendPartFullUpdate(ISceneEntity ent, uint? parentID) 4469 public void SendPartFullUpdate(ISceneEntity ent, uint? parentID)
4466 { 4470 {
4467 if (ent is SceneObjectPart) 4471 if (ent is SceneObjectPart)
@@ -4472,7 +4476,7 @@ namespace OpenSim.Region.ClientStack.LindenUDP
4472 packet.RegionData.TimeDilation = Utils.FloatToUInt16(m_scene.TimeDilation, 0.0f, 1.0f); 4476 packet.RegionData.TimeDilation = Utils.FloatToUInt16(m_scene.TimeDilation, 0.0f, 1.0f);
4473 packet.ObjectData = new ObjectUpdatePacket.ObjectDataBlock[1]; 4477 packet.ObjectData = new ObjectUpdatePacket.ObjectDataBlock[1];
4474 4478
4475 ObjectUpdatePacket.ObjectDataBlock blk = CreatePrimUpdateBlock(part, this.m_agentId); 4479 ObjectUpdatePacket.ObjectDataBlock blk = CreatePrimUpdateBlock(part, mysp);
4476 if (parentID.HasValue) 4480 if (parentID.HasValue)
4477 { 4481 {
4478 blk.ParentID = parentID.Value; 4482 blk.ParentID = parentID.Value;
@@ -4488,7 +4492,7 @@ namespace OpenSim.Region.ClientStack.LindenUDP
4488// updatesThisCall, Name, SceneAgent.IsChildAgent ? "child" : "root", Scene.Name); 4492// updatesThisCall, Name, SceneAgent.IsChildAgent ? "child" : "root", Scene.Name);
4489// 4493//
4490 } 4494 }
4491 4495*/
4492 public void ReprioritizeUpdates() 4496 public void ReprioritizeUpdates()
4493 { 4497 {
4494 lock (m_entityUpdates.SyncRoot) 4498 lock (m_entityUpdates.SyncRoot)
@@ -5726,7 +5730,8 @@ namespace OpenSim.Region.ClientStack.LindenUDP
5726 return update; 5730 return update;
5727 } 5731 }
5728 5732
5729 protected ObjectUpdatePacket.ObjectDataBlock CreatePrimUpdateBlock(SceneObjectPart data, UUID recipientID) 5733// protected ObjectUpdatePacket.ObjectDataBlock CreatePrimUpdateBlock(SceneObjectPart data, UUID recipientID)
5734 protected ObjectUpdatePacket.ObjectDataBlock CreatePrimUpdateBlock(SceneObjectPart data, ScenePresence sp)
5730 { 5735 {
5731 byte[] objectData = new byte[60]; 5736 byte[] objectData = new byte[60];
5732 data.RelativePosition.ToBytes(objectData, 0); 5737 data.RelativePosition.ToBytes(objectData, 0);
@@ -5826,12 +5831,12 @@ namespace OpenSim.Region.ClientStack.LindenUDP
5826 5831
5827 #region PrimFlags 5832 #region PrimFlags
5828 5833
5829 PrimFlags flags = (PrimFlags)m_scene.Permissions.GenerateClientFlags(recipientID, data.UUID); 5834 PrimFlags flags = (PrimFlags)m_scene.Permissions.GenerateClientFlags(sp, data.UUID);
5830 5835
5831 // Don't send the CreateSelected flag to everyone 5836 // Don't send the CreateSelected flag to everyone
5832 flags &= ~PrimFlags.CreateSelected; 5837 flags &= ~PrimFlags.CreateSelected;
5833 5838
5834 if (recipientID == data.OwnerID) 5839 if (sp.UUID == data.OwnerID)
5835 { 5840 {
5836 if (data.CreateSelected) 5841 if (data.CreateSelected)
5837 { 5842 {
diff --git a/OpenSim/Region/CoreModules/World/Permissions/PermissionsModule.cs b/OpenSim/Region/CoreModules/World/Permissions/PermissionsModule.cs
index 1bb5181..495da8b 100644
--- a/OpenSim/Region/CoreModules/World/Permissions/PermissionsModule.cs
+++ b/OpenSim/Region/CoreModules/World/Permissions/PermissionsModule.cs
@@ -623,7 +623,7 @@ namespace OpenSim.Region.CoreModules.World.Permissions
623 PrimFlags.ObjectOwnerModify 623 PrimFlags.ObjectOwnerModify
624 ); 624 );
625 625
626 public uint GenerateClientFlags(UUID user, UUID objID) 626 public uint GenerateClientFlags(ScenePresence sp, UUID objID)
627 { 627 {
628 // ObjectFlags and Permission flags are two different enumerations 628 // ObjectFlags and Permission flags are two different enumerations
629 // ObjectFlags, tells the client what it will allow the user to do. 629 // ObjectFlags, tells the client what it will allow the user to do.
@@ -641,8 +641,8 @@ namespace OpenSim.Region.CoreModules.World.Permissions
641 641
642 objflags &= NOT_DEFAULT_FLAGS; 642 objflags &= NOT_DEFAULT_FLAGS;
643 643
644 // get a relevant class for current user on task 644 // get a relevant class for current presence on task
645 PermissionClass permissionClass = GetPermissionClass(user, task); 645 PermissionClass permissionClass = GetPermissionClass(sp, task);
646 646
647 // handle acording 647 // handle acording
648 uint returnMask = 0; 648 uint returnMask = 0;
@@ -668,10 +668,6 @@ namespace OpenSim.Region.CoreModules.World.Permissions
668 returnMask = ApplyObjectModifyMasks(task.EveryoneMask, objflags); 668 returnMask = ApplyObjectModifyMasks(task.EveryoneMask, objflags);
669 if (task.OwnerID != UUID.Zero) 669 if (task.OwnerID != UUID.Zero)
670 returnMask |= (uint)PrimFlags.ObjectAnyOwner; 670 returnMask |= (uint)PrimFlags.ObjectAnyOwner;
671
672 // allow estatemanagers to move prims to help solve disputes
673 if(!task.ParentGroup.IsAttachment && IsEstateManager(user))
674 returnMask |= (uint)PrimFlags.ObjectMove;
675 break; 671 break;
676 } 672 }
677 return returnMask; 673 return returnMask;
@@ -705,6 +701,39 @@ namespace OpenSim.Region.CoreModules.World.Permissions
705 return objectFlagsMask; 701 return objectFlagsMask;
706 } 702 }
707 703
704 private PermissionClass GetPermissionClass(ScenePresence sp, SceneObjectPart obj)
705 {
706 if (obj == null || sp == null)
707 return PermissionClass.Everyone;
708
709 if (m_bypassPermissions)
710 return PermissionClass.Owner;
711
712
713 if (sp.IsGod)
714 return PermissionClass.Owner;
715
716 UUID user = sp.UUID;
717
718 // Object owners should be able to edit their own content
719 UUID objectOwner = obj.OwnerID;
720 if (user == objectOwner)
721 return PermissionClass.Owner;
722
723 if(!obj.ParentGroup.IsAttachment)
724 {
725 if (IsFriendWithPerms(user, objectOwner) )
726 return PermissionClass.Owner;
727
728 // Group permissions
729 if (obj.GroupID != UUID.Zero && IsGroupMember(obj.GroupID, user, 0))
730 return PermissionClass.Group;
731 }
732
733 return PermissionClass.Everyone;
734 }
735
736 // OARs need this method that handles offline users
708 public PermissionClass GetPermissionClass(UUID user, SceneObjectPart obj) 737 public PermissionClass GetPermissionClass(UUID user, SceneObjectPart obj)
709 { 738 {
710 if (obj == null) 739 if (obj == null)
diff --git a/OpenSim/Region/Framework/Scenes/Scene.Permissions.cs b/OpenSim/Region/Framework/Scenes/Scene.Permissions.cs
index e97e494..c4cb6c7 100644
--- a/OpenSim/Region/Framework/Scenes/Scene.Permissions.cs
+++ b/OpenSim/Region/Framework/Scenes/Scene.Permissions.cs
@@ -37,7 +37,7 @@ using OpenSim.Region.Framework.Interfaces;
37namespace OpenSim.Region.Framework.Scenes 37namespace OpenSim.Region.Framework.Scenes
38{ 38{
39 #region Delegates 39 #region Delegates
40 public delegate uint GenerateClientFlagsHandler(UUID userID, UUID objectID); 40 public delegate uint GenerateClientFlagsHandler(ScenePresence sp, UUID objectID);
41 public delegate void SetBypassPermissionsHandler(bool value); 41 public delegate void SetBypassPermissionsHandler(bool value);
42 public delegate bool BypassPermissionsHandler(); 42 public delegate bool BypassPermissionsHandler();
43 public delegate bool PropagatePermissionsHandler(); 43 public delegate bool PropagatePermissionsHandler();
@@ -167,7 +167,7 @@ namespace OpenSim.Region.Framework.Scenes
167 167
168 #region Object Permission Checks 168 #region Object Permission Checks
169 169
170 public uint GenerateClientFlags(UUID userID, UUID objectID) 170 public uint GenerateClientFlags(ScenePresence sp, UUID objectID)
171 { 171 {
172 // libomv will moan about PrimFlags.ObjectYouOfficer being 172 // libomv will moan about PrimFlags.ObjectYouOfficer being
173 // obsolete... 173 // obsolete...
@@ -195,7 +195,7 @@ namespace OpenSim.Region.Framework.Scenes
195 Delegate[] list = handlerGenerateClientFlags.GetInvocationList(); 195 Delegate[] list = handlerGenerateClientFlags.GetInvocationList();
196 foreach (GenerateClientFlagsHandler check in list) 196 foreach (GenerateClientFlagsHandler check in list)
197 { 197 {
198 perms &= check(userID, objectID); 198 perms &= check(sp, objectID);
199 } 199 }
200 } 200 }
201 return perms; 201 return perms;