From 3f93db83711956dbef8870d5b997e3bc12d16c46 Mon Sep 17 00:00:00 2001 From: Melanie Date: Wed, 16 Feb 2011 05:23:30 +0100 Subject: Streamline ban line processing. Remove remnants of old advisory messages. Centralize ban checking and prepare for adding a "ban and eject" function. --- .../CoreModules/World/Land/LandManagementModule.cs | 82 +++++++--------------- OpenSim/Region/Framework/Scenes/ScenePresence.cs | 1 - 2 files changed, 24 insertions(+), 59 deletions(-) diff --git a/OpenSim/Region/CoreModules/World/Land/LandManagementModule.cs b/OpenSim/Region/CoreModules/World/Land/LandManagementModule.cs index b671aec..ad75ea5 100644 --- a/OpenSim/Region/CoreModules/World/Land/LandManagementModule.cs +++ b/OpenSim/Region/CoreModules/World/Land/LandManagementModule.cs @@ -163,13 +163,6 @@ namespace OpenSim.Region.CoreModules.World.Land m_scene.UnregisterModuleCommander(m_commander.Name); } -// private bool OnVerifyUserConnection(ScenePresence scenePresence, out string reason) -// { -// ILandObject nearestParcel = m_scene.GetNearestAllowedParcel(scenePresence.UUID, scenePresence.AbsolutePosition.X, scenePresence.AbsolutePosition.Y); -// reason = "You are not allowed to enter this sim."; -// return nearestParcel != null; -// } - /// /// Processes commandline input. Do not call directly. /// @@ -364,31 +357,7 @@ namespace OpenSim.Region.CoreModules.World.Land } if (parcelAvatarIsEntering != null) - { - if (avatar.AbsolutePosition.Z < LandChannel.BAN_LINE_SAFETY_HIEGHT) - { - if (parcelAvatarIsEntering.IsEitherBannedOrRestricted(avatar.UUID)) - { - SendYouAreBannedNotice(avatar); - ForceAvatarToPosition(avatar, avatar.lastKnownAllowedPosition); - //ForceAvatarToPosition(avatar, m_scene.GetNearestAllowedPosition(avatar)); - } - else if (parcelAvatarIsEntering.IsRestrictedFromLand(avatar.UUID)) - { - SendYouAreRestrictedNotice(avatar); - ForceAvatarToPosition(avatar, avatar.lastKnownAllowedPosition); - //ForceAvatarToPosition(avatar, m_scene.GetNearestAllowedPosition(avatar)); - } - else - { - avatar.sentMessageAboutRestrictedParcelFlyingDown = true; - } - } - else - { - avatar.sentMessageAboutRestrictedParcelFlyingDown = true; - } - } + EnforceBans(parcelAvatarIsEntering, avatar); } } @@ -460,32 +429,7 @@ namespace OpenSim.Region.CoreModules.World.Land SendOutNearestBanLine(remote_client); ILandObject parcel = GetLandObject(clientAvatar.AbsolutePosition.X, clientAvatar.AbsolutePosition.Y); if (parcel != null) - { - if (clientAvatar.AbsolutePosition.Z < LandChannel.BAN_LINE_SAFETY_HIEGHT && - clientAvatar.sentMessageAboutRestrictedParcelFlyingDown) - { - EventManagerOnAvatarEnteringNewParcel(clientAvatar, parcel.LandData.LocalID, - m_scene.RegionInfo.RegionID); - //They are going under the safety line! - if (!parcel.IsBannedFromLand(clientAvatar.UUID)) - { - clientAvatar.sentMessageAboutRestrictedParcelFlyingDown = false; - } - } - else if (clientAvatar.AbsolutePosition.Z < LandChannel.BAN_LINE_SAFETY_HIEGHT && - parcel.IsBannedFromLand(clientAvatar.UUID)) - { - // SendYouAreBannedNotice(clientAvatar); - //ForceAvatarToPosition(clientAvatar, m_scene.GetNearestAllowedPosition(clientAvatar)); - ForceAvatarToPosition(clientAvatar, clientAvatar.lastKnownAllowedPosition); - } - else if (parcel.IsRestrictedFromLand(clientAvatar.UUID)) - { - // SendYouAreRestrictedNotice(clientAvatar); - //ForceAvatarToPosition(clientAvatar, m_scene.GetNearestAllowedPosition(clientAvatar)); - ForceAvatarToPosition(clientAvatar, clientAvatar.lastKnownAllowedPosition); - } - } + EnforceBans(parcel, clientAvatar); } } @@ -2005,5 +1949,27 @@ namespace OpenSim.Region.CoreModules.World.Land MainConsole.Instance.Output(report.ToString()); } + + public void EnforceBans(ILandObject land, ScenePresence avatar) + { + if (avatar.AbsolutePosition.Z > LandChannel.BAN_LINE_SAFETY_HIEGHT) + return; + + if (land.IsEitherBannedOrRestricted(avatar.UUID)) + { + if (land.ContainsPoint(Convert.ToInt32(avatar.lastKnownAllowedPosition.X), Convert.ToInt32(avatar.lastKnownAllowedPosition.Y))) + { + Vector3? pos = m_scene.GetNearestAllowedPosition(avatar); + if (pos == null) + m_scene.TeleportClientHome(avatar.UUID, avatar.ControllingClient); + else + ForceAvatarToPosition(avatar, (Vector3)pos); + } + else + { + ForceAvatarToPosition(avatar, avatar.lastKnownAllowedPosition); + } + } + } } } diff --git a/OpenSim/Region/Framework/Scenes/ScenePresence.cs b/OpenSim/Region/Framework/Scenes/ScenePresence.cs index b54d1b8..af24ed3 100644 --- a/OpenSim/Region/Framework/Scenes/ScenePresence.cs +++ b/OpenSim/Region/Framework/Scenes/ScenePresence.cs @@ -123,7 +123,6 @@ namespace OpenSim.Region.Framework.Scenes private SceneObjectGroup proxyObjectGroup; //private SceneObjectPart proxyObjectPart = null; public Vector3 lastKnownAllowedPosition; - public bool sentMessageAboutRestrictedParcelFlyingDown; public Vector4 CollisionPlane = Vector4.UnitW; private Vector3 m_avInitialPos; // used to calculate unscripted sit rotation -- cgit v1.1