From 75e48610e7f6c6c60e00b1376b50441d3ea08f52 Mon Sep 17 00:00:00 2001 From: UbitUmarov Date: Fri, 1 Feb 2019 18:19:27 +0000 Subject: place a global cooldown of 2 min on god map generation --- .../Region/ClientStack/Linden/UDP/LLClientView.cs | 27 ++++++++++++++++++---- 1 file changed, 23 insertions(+), 4 deletions(-) (limited to 'OpenSim/Region/ClientStack/Linden/UDP/LLClientView.cs') diff --git a/OpenSim/Region/ClientStack/Linden/UDP/LLClientView.cs b/OpenSim/Region/ClientStack/Linden/UDP/LLClientView.cs index 72142f2..e35b463 100644 --- a/OpenSim/Region/ClientStack/Linden/UDP/LLClientView.cs +++ b/OpenSim/Region/ClientStack/Linden/UDP/LLClientView.cs @@ -9826,6 +9826,7 @@ namespace OpenSim.Region.ClientStack.LindenUDP #endregion Parcel related packets #region Estate Packets + private static double m_lastMapRegenTime = Double.MinValue; private bool HandleEstateOwnerMessage(IClientAPI sender, Packet Pack) { @@ -10108,8 +10109,6 @@ namespace OpenSim.Region.ClientStack.LindenUDP } } - - } return true; @@ -10161,8 +10160,28 @@ namespace OpenSim.Region.ClientStack.LindenUDP if (((Scene)m_scene).Permissions.CanIssueEstateCommand(AgentId, false)) { IWorldMapModule mapModule = Scene.RequestModuleInterface(); - if (mapModule != null) - mapModule.GenerateMaptile(); + if (mapModule == null) + { + SendAlertMessage("Terrain map generator not avaiable"); + return true; + } + if (m_lastMapRegenTime == Double.MaxValue) + { + SendAlertMessage("Terrain map generation still in progress"); + return true; + } + + double now = Util.GetTimeStamp(); + if (now - m_lastMapRegenTime < 120) // 2 minutes global cool down + { + SendAlertMessage("Please wait at least 2 minutes between map generation comand"); + return true; + } + + m_lastMapRegenTime = Double.MaxValue; + mapModule.GenerateMaptile(); + SendAlertMessage("Terrain map generated"); + m_lastMapRegenTime = now; } return true; -- cgit v1.1