From 273e1f0917d8ff125b3bf885f6eb80d32bf7b840 Mon Sep 17 00:00:00 2001 From: David Walter Seikel Date: Tue, 22 Nov 2016 17:01:47 +1000 Subject: Don't throw exceptions on threat level checks and a few other script function errors. Instead, just complain quickly and return without doing the function. --- .../Shared/Api/Implementation/LSL_Api.cs | 6 +- .../Shared/Api/Implementation/OSSL_Api.cs | 193 +++++++++++---------- .../ScriptEngine/Shared/Api/Interface/IOSSL_Api.cs | 2 +- 3 files changed, 105 insertions(+), 96 deletions(-) (limited to 'OpenSim/Region/ScriptEngine') diff --git a/OpenSim/Region/ScriptEngine/Shared/Api/Implementation/LSL_Api.cs b/OpenSim/Region/ScriptEngine/Shared/Api/Implementation/LSL_Api.cs index 0b60aee..1399880 100644 --- a/OpenSim/Region/ScriptEngine/Shared/Api/Implementation/LSL_Api.cs +++ b/OpenSim/Region/ScriptEngine/Shared/Api/Implementation/LSL_Api.cs @@ -11660,7 +11660,11 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api break; case ScriptBaseClass.DATA_SIM_RELEASE: if (ossl != null) - ossl.CheckThreatLevel(ThreatLevel.High, "llRequestSimulatorData"); + { +//// TODO - double check this. + if (!ossl.CheckThreatLevel(ThreatLevel.High, "llRequestSimulatorData")) + return UUID.Zero.ToString(); // Raise no event + } reply = "OpenSim"; break; default: diff --git a/OpenSim/Region/ScriptEngine/Shared/Api/Implementation/OSSL_Api.cs b/OpenSim/Region/ScriptEngine/Shared/Api/Implementation/OSSL_Api.cs index 3f61aff..83aa245 100644 --- a/OpenSim/Region/ScriptEngine/Shared/Api/Implementation/OSSL_Api.cs +++ b/OpenSim/Region/ScriptEngine/Shared/Api/Implementation/OSSL_Api.cs @@ -209,7 +209,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api internal void OSSLError(string msg) { - throw new ScriptException("OSSL Runtime Error: " + msg); + OSSLShoutError("OSSL Runtime Error: " + msg); } /// @@ -245,16 +245,21 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api } // Returns of the function is allowed. Throws a script exception if not allowed. - public void CheckThreatLevel(ThreatLevel level, string function) + public bool CheckThreatLevel(ThreatLevel level, string function) { if (!m_OSFunctionsEnabled) - OSSLError(String.Format("{0} permission denied. All OS functions are disabled.", function)); // throws + { + OSSLError(String.Format("{0} permission denied. All OS functions are disabled.", function)); + return false; + } string reasonWhyNot = CheckThreatLevelTest(level, function); if (!String.IsNullOrEmpty(reasonWhyNot)) { OSSLError(reasonWhyNot); + return false; } + return true; } // Check to see if function is allowed. Returns an empty string if function permitted @@ -422,14 +427,14 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api public LSL_Integer osSetTerrainHeight(int x, int y, double val) { - CheckThreatLevel(ThreatLevel.High, "osSetTerrainHeight"); + if (!CheckThreatLevel(ThreatLevel.High, "osSetTerrainHeight")) return 0; return SetTerrainHeight(x, y, val); } public LSL_Integer osTerrainSetHeight(int x, int y, double val) { - CheckThreatLevel(ThreatLevel.High, "osTerrainSetHeight"); + if (!CheckThreatLevel(ThreatLevel.High, "osTerrainSetHeight")) return 0; OSSLDeprecated("osTerrainSetHeight", "osSetTerrainHeight"); return SetTerrainHeight(x, y, val); @@ -475,7 +480,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api public void osTerrainFlush() { - CheckThreatLevel(ThreatLevel.VeryLow, "osTerrainFlush"); + if (!CheckThreatLevel(ThreatLevel.VeryLow, "osTerrainFlush")) return; m_host.AddScriptLPS(1); ITerrainModule terrainModule = World.RequestModuleInterface(); @@ -490,7 +495,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api // The underlying functionality is fixed, since the security // as such is sound // - CheckThreatLevel(ThreatLevel.High, "osRegionRestart"); + if (!CheckThreatLevel(ThreatLevel.High, "osRegionRestart")) return 0; IRestartModule restartModule = World.RequestModuleInterface(); m_host.AddScriptLPS(1); @@ -529,7 +534,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api // It's high griefing potential makes this classification // necessary // - CheckThreatLevel(ThreatLevel.VeryHigh, "osRegionNotice"); + if (!CheckThreatLevel(ThreatLevel.VeryHigh, "osRegionNotice")) return; m_host.AddScriptLPS(1); @@ -544,7 +549,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api // This function has no security. It can be used to destroy // arbitrary builds the user would normally have no rights to // - CheckThreatLevel(ThreatLevel.VeryHigh, "osSetRot"); + if (!CheckThreatLevel(ThreatLevel.VeryHigh, "osSetRot")) return; m_host.AddScriptLPS(1); if (World.Entities.ContainsKey(target)) @@ -707,7 +712,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api public bool osConsoleCommand(string command) { - CheckThreatLevel(ThreatLevel.Severe, "osConsoleCommand"); + if (!CheckThreatLevel(ThreatLevel.Severe, "osConsoleCommand")) return false; m_host.AddScriptLPS(1); @@ -723,7 +728,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api public void osSetPrimFloatOnWater(int floatYN) { - CheckThreatLevel(ThreatLevel.VeryLow, "osSetPrimFloatOnWater"); + if (!CheckThreatLevel(ThreatLevel.VeryLow, "osSetPrimFloatOnWater")) return; m_host.AddScriptLPS(1); @@ -735,7 +740,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api { // High because there is no security check. High griefer potential // - CheckThreatLevel(ThreatLevel.High, "osTeleportAgent"); + if (!CheckThreatLevel(ThreatLevel.High, "osTeleportAgent")) return; TeleportAgent(agent, regionName, position, lookat, false); } @@ -777,7 +782,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api { // High because there is no security check. High griefer potential // - CheckThreatLevel(ThreatLevel.High, "osTeleportAgent"); + if (!CheckThreatLevel(ThreatLevel.High, "osTeleportAgent")) return; TeleportAgent(agent, regionX, regionY, position, lookat, false); } @@ -822,7 +827,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api { // High because there is no security check. High griefer potential // - CheckThreatLevel(ThreatLevel.High, "osTeleportAgent"); + if (!CheckThreatLevel(ThreatLevel.High, "osTeleportAgent")) return; osTeleportAgent(agent, World.RegionInfo.RegionName, position, lookat); } @@ -851,7 +856,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api /// public void osForceOtherSit(string avatar) { - CheckThreatLevel(ThreatLevel.VeryHigh, "osForceOtherSit"); + if (!CheckThreatLevel(ThreatLevel.VeryHigh, "osForceOtherSit")) return; m_host.AddScriptLPS(1); @@ -866,7 +871,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api /// public void osForceOtherSit(string avatar, string target) { - CheckThreatLevel(ThreatLevel.VeryHigh, "osForceOtherSit"); + if (!CheckThreatLevel(ThreatLevel.VeryHigh, "osForceOtherSit")) return; m_host.AddScriptLPS(1); @@ -905,7 +910,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api // Severe is even better coz privacy is important. public string osGetAgentIP(string agent) { - CheckThreatLevel(ThreatLevel.Severe, "osGetAgentIP"); + if (!CheckThreatLevel(ThreatLevel.Severe, "osGetAgentIP")) return ""; UUID avatarID = (UUID)agent; @@ -936,7 +941,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api // Adam's super super custom animation functions public void osAvatarPlayAnimation(string avatar, string animation) { - CheckThreatLevel(ThreatLevel.VeryHigh, "osAvatarPlayAnimation"); + if (!CheckThreatLevel(ThreatLevel.VeryHigh, "osAvatarPlayAnimation")) return; AvatarPlayAnimation(avatar, animation); } @@ -974,7 +979,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api public void osAvatarStopAnimation(string avatar, string animation) { - CheckThreatLevel(ThreatLevel.VeryHigh, "osAvatarStopAnimation"); + if (!CheckThreatLevel(ThreatLevel.VeryHigh, "osAvatarStopAnimation")) return; AvatarStopAnimation(avatar, animation); } @@ -1173,7 +1178,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api // It was probably added as a crutch or debugging aid, and // should be removed // - CheckThreatLevel(ThreatLevel.High, "osSetStateEvents"); + if (!CheckThreatLevel(ThreatLevel.High, "osSetStateEvents")) return; m_host.AddScriptLPS(1); m_host.SetScriptEvents(m_item.ItemID, events); @@ -1181,7 +1186,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api public void osSetRegionWaterHeight(double height) { - CheckThreatLevel(ThreatLevel.High, "osSetRegionWaterHeight"); + if (!CheckThreatLevel(ThreatLevel.High, "osSetRegionWaterHeight")) return; m_host.AddScriptLPS(1); @@ -1196,7 +1201,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api /// The "Sun Hour" that is desired, 0...24, with 0 just after SunRise public void osSetRegionSunSettings(bool useEstateSun, bool sunFixed, double sunHour) { - CheckThreatLevel(ThreatLevel.High, "osSetRegionSunSettings"); + if (!CheckThreatLevel(ThreatLevel.High, "osSetRegionSunSettings")) return; m_host.AddScriptLPS(1); @@ -1221,7 +1226,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api /// The "Sun Hour" that is desired, 0...24, with 0 just after SunRise public void osSetEstateSunSettings(bool sunFixed, double sunHour) { - CheckThreatLevel(ThreatLevel.High, "osSetEstateSunSettings"); + if (!CheckThreatLevel(ThreatLevel.High, "osSetEstateSunSettings")) return; m_host.AddScriptLPS(1); @@ -1288,14 +1293,14 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api public void osSunSetParam(string param, double value) { -//// CheckThreatLevel(ThreatLevel.None, "osSunSetParam"); +//// if (!CheckThreatLevel(ThreatLevel.None, "osSunSetParam")) return; OSSLDeprecated("osSunSetParam", "osSetSunParam"); SetSunParam(param, value); } public void osSetSunParam(string param, double value) { -//// CheckThreatLevel(ThreatLevel.None, "osSetSunParam"); +//// if (!CheckThreatLevel(ThreatLevel.None, "osSetSunParam")) return; SetSunParam(param, value); } @@ -1325,7 +1330,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api public void osSetWindParam(string plugin, string param, LSL_Float value) { - CheckThreatLevel(ThreatLevel.VeryLow, "osSetWindParam"); + if (!CheckThreatLevel(ThreatLevel.VeryLow, "osSetWindParam")) return; m_host.AddScriptLPS(1); IWindModule module = World.RequestModuleInterface(); @@ -1355,7 +1360,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api // Routines for creating and managing parcels programmatically public void osParcelJoin(LSL_Vector pos1, LSL_Vector pos2) { - CheckThreatLevel(ThreatLevel.High, "osParcelJoin"); + if (!CheckThreatLevel(ThreatLevel.High, "osParcelJoin")) return; m_host.AddScriptLPS(1); int startx = (int)(pos1.x < pos2.x ? pos1.x : pos2.x); @@ -1368,7 +1373,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api public void osParcelSubdivide(LSL_Vector pos1, LSL_Vector pos2) { - CheckThreatLevel(ThreatLevel.High, "osParcelSubdivide"); + if (!CheckThreatLevel(ThreatLevel.High, "osParcelSubdivide")) return; m_host.AddScriptLPS(1); int startx = (int)(pos1.x < pos2.x ? pos1.x : pos2.x); @@ -1382,7 +1387,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api public void osParcelSetDetails(LSL_Vector pos, LSL_List rules) { const string functionName = "osParcelSetDetails"; - CheckThreatLevel(ThreatLevel.High, functionName); + if (!CheckThreatLevel(ThreatLevel.High, functionName)) return; OSSLDeprecated(functionName, "osSetParcelDetails"); SetParcelDetails(pos, rules, functionName); } @@ -1390,7 +1395,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api public void osSetParcelDetails(LSL_Vector pos, LSL_List rules) { const string functionName = "osSetParcelDetails"; - CheckThreatLevel(ThreatLevel.High, functionName); + if (!CheckThreatLevel(ThreatLevel.High, functionName)) return; SetParcelDetails(pos, rules, functionName); } @@ -1434,19 +1439,19 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api break; case ScriptBaseClass.PARCEL_DETAILS_OWNER: - CheckThreatLevel(ThreatLevel.VeryHigh, functionName); + if (!CheckThreatLevel(ThreatLevel.VeryHigh, functionName)) return; if (UUID.TryParse(arg, out uuid)) newLand.OwnerID = uuid; break; case ScriptBaseClass.PARCEL_DETAILS_GROUP: - CheckThreatLevel(ThreatLevel.VeryHigh, functionName); + if (!CheckThreatLevel(ThreatLevel.VeryHigh, functionName)) return; if (UUID.TryParse(arg, out uuid)) newLand.GroupID = uuid; break; case ScriptBaseClass.PARCEL_DETAILS_CLAIMDATE: - CheckThreatLevel(ThreatLevel.VeryHigh, functionName); + if (!CheckThreatLevel(ThreatLevel.VeryHigh, functionName)) return; newLand.ClaimDate = Convert.ToInt32(arg); if (newLand.ClaimDate == 0) newLand.ClaimDate = Util.UnixTimeSinceEpoch(); @@ -1480,7 +1485,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api { // What actually is the difference to the LL function? // - CheckThreatLevel(ThreatLevel.VeryLow, "osSetParcelMediaURL"); + if (!CheckThreatLevel(ThreatLevel.VeryLow, "osSetParcelMediaURL")) return; m_host.AddScriptLPS(1); @@ -1496,7 +1501,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api { // What actually is the difference to the LL function? // - CheckThreatLevel(ThreatLevel.VeryLow, "osSetParcelSIPAddress"); + if (!CheckThreatLevel(ThreatLevel.VeryLow, "osSetParcelSIPAddress")) return; m_host.AddScriptLPS(1); @@ -1643,7 +1648,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api } catch(Exception e) { - OSSLError("osParseJSONNew: Problems decoding JSON string " + JSON + " : " + e.Message) ; + OSSLError("osParseJSONNew: Problems decoding JSON string " + JSON + " : " + e.Message); return null; } } @@ -1951,7 +1956,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api public string osAvatarName2Key(string firstname, string lastname) { - CheckThreatLevel(ThreatLevel.Low, "osAvatarName2Key"); + if (!CheckThreatLevel(ThreatLevel.Low, "osAvatarName2Key")) return string.Empty; m_host.AddScriptLPS(1); IUserManagement userManager = World.RequestModuleInterface(); @@ -2112,7 +2117,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api /// public string osGetGridNick() { -//// CheckThreatLevel(ThreatLevel.None, "osGetGridNick"); +//// if (!CheckThreatLevel(ThreatLevel.None, "osGetGridNick")) return ""; m_host.AddScriptLPS(1); string nick = String.Empty; @@ -2129,7 +2134,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api public string osGetGridName() { -//// CheckThreatLevel(ThreatLevel.None, "osGetGridName"); +//// if (!CheckThreatLevel(ThreatLevel.None, "osGetGridName")) return ""; m_host.AddScriptLPS(1); string name = String.Empty; @@ -2146,7 +2151,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api public string osGetGridLoginURI() { - CheckThreatLevel(ThreatLevel.Moderate, "osGetGridLoginURI"); + if (!CheckThreatLevel(ThreatLevel.Moderate, "osGetGridLoginURI")) return ""; m_host.AddScriptLPS(1); string loginURI = String.Empty; @@ -2163,7 +2168,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api public string osGetGridHomeURI() { - CheckThreatLevel(ThreatLevel.Moderate, "osGetGridHomeURI"); + if (!CheckThreatLevel(ThreatLevel.Moderate, "osGetGridHomeURI")) return ""; m_host.AddScriptLPS(1); IConfigSource config = m_ScriptEngine.ConfigSource; @@ -2185,7 +2190,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api public string osGetGridGatekeeperURI() { - CheckThreatLevel(ThreatLevel.Moderate, "osGetGridGatekeeperURI"); + if (!CheckThreatLevel(ThreatLevel.Moderate, "osGetGridGatekeeperURI")) return ""; m_host.AddScriptLPS(1); IConfigSource config = m_ScriptEngine.ConfigSource; @@ -2204,7 +2209,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api public string osGetGridCustom(string key) { - CheckThreatLevel(ThreatLevel.Moderate, "osGetGridCustom"); + if (!CheckThreatLevel(ThreatLevel.Moderate, "osGetGridCustom")) return String.Empty; m_host.AddScriptLPS(1); string retval = String.Empty; @@ -2221,7 +2226,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api public string osGetAvatarHomeURI(string uuid) { - CheckThreatLevel(ThreatLevel.Moderate, "osGetAvatarHomeURI"); + if (!CheckThreatLevel(ThreatLevel.Moderate, "osGetAvatarHomeURI")) return ""; m_host.AddScriptLPS(1); IUserManagement userManager = m_ScriptEngine.World.RequestModuleInterface(); @@ -2326,7 +2331,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api public string osLoadedCreationDate() { - CheckThreatLevel(ThreatLevel.Low, "osLoadedCreationDate"); + if (!CheckThreatLevel(ThreatLevel.Low, "osLoadedCreationDate")) return ""; m_host.AddScriptLPS(1); return World.RegionInfo.RegionSettings.LoadedCreationDate; @@ -2334,7 +2339,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api public string osLoadedCreationTime() { - CheckThreatLevel(ThreatLevel.Low, "osLoadedCreationTime"); + if (!CheckThreatLevel(ThreatLevel.Low, "osLoadedCreationTime")) return ""; m_host.AddScriptLPS(1); return World.RegionInfo.RegionSettings.LoadedCreationTime; @@ -2342,7 +2347,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api public string osLoadedCreationID() { - CheckThreatLevel(ThreatLevel.Low, "osLoadedCreationID"); + if (!CheckThreatLevel(ThreatLevel.Low, "osLoadedCreationID")) return ""; m_host.AddScriptLPS(1); return World.RegionInfo.RegionSettings.LoadedCreationID; @@ -2363,7 +2368,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api /// public LSL_List osGetLinkPrimitiveParams(int linknumber, LSL_List rules) { - CheckThreatLevel(ThreatLevel.High, "osGetLinkPrimitiveParams"); + if (!CheckThreatLevel(ThreatLevel.High, "osGetLinkPrimitiveParams")) return new LSL_List(); m_host.AddScriptLPS(1); InitLSL(); // One needs to cast m_LSL_Api because we're using functions not @@ -2391,7 +2396,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api public void osForceCreateLink(string target, int parent) { - CheckThreatLevel(ThreatLevel.VeryLow, "osForceCreateLink"); + if (!CheckThreatLevel(ThreatLevel.VeryLow, "osForceCreateLink")) return; m_host.AddScriptLPS(1); @@ -2401,7 +2406,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api public void osForceBreakLink(int linknum) { - CheckThreatLevel(ThreatLevel.VeryLow, "osForceBreakLink"); + if (!CheckThreatLevel(ThreatLevel.VeryLow, "osForceBreakLink")) return; m_host.AddScriptLPS(1); @@ -2411,7 +2416,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api public void osForceBreakAllLinks() { - CheckThreatLevel(ThreatLevel.VeryLow, "osForceBreakAllLinks"); + if (!CheckThreatLevel(ThreatLevel.VeryLow, "osForceBreakAllLinks")) return; m_host.AddScriptLPS(1); @@ -2437,7 +2442,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api public LSL_Key osNpcCreate(string firstname, string lastname, LSL_Vector position, string notecard) { - CheckThreatLevel(ThreatLevel.High, "osNpcCreate"); + if (!CheckThreatLevel(ThreatLevel.High, "osNpcCreate")) return new LSL_Key(ScriptBaseClass.NULL_KEY); m_host.AddScriptLPS(1); return NpcCreate(firstname, lastname, position, notecard, false, false); @@ -2445,7 +2450,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api public LSL_Key osNpcCreate(string firstname, string lastname, LSL_Vector position, string notecard, int options) { - CheckThreatLevel(ThreatLevel.High, "osNpcCreate"); + if (!CheckThreatLevel(ThreatLevel.High, "osNpcCreate")) return new LSL_Key(ScriptBaseClass.NULL_KEY); m_host.AddScriptLPS(1); return NpcCreate( @@ -2511,7 +2516,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api /// The asset ID of the notecard saved. public LSL_Key osNpcSaveAppearance(LSL_Key npc, string notecard) { - CheckThreatLevel(ThreatLevel.High, "osNpcSaveAppearance"); + if (!CheckThreatLevel(ThreatLevel.High, "osNpcSaveAppearance")) return new LSL_Key(ScriptBaseClass.NULL_KEY); m_host.AddScriptLPS(1); INPCModule npcModule = World.RequestModuleInterface(); @@ -2533,7 +2538,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api public void osNpcLoadAppearance(LSL_Key npc, string notecard) { - CheckThreatLevel(ThreatLevel.High, "osNpcLoadAppearance"); + if (!CheckThreatLevel(ThreatLevel.High, "osNpcLoadAppearance")) return; m_host.AddScriptLPS(1); INPCModule npcModule = World.RequestModuleInterface(); @@ -2609,7 +2614,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api public void osNpcMoveTo(LSL_Key npc, LSL_Vector pos) { - CheckThreatLevel(ThreatLevel.High, "osNpcMoveTo"); + if (!CheckThreatLevel(ThreatLevel.High, "osNpcMoveTo")) return; m_host.AddScriptLPS(1); INPCModule module = World.RequestModuleInterface(); @@ -2628,7 +2633,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api public void osNpcMoveToTarget(LSL_Key npc, LSL_Vector target, int options) { - CheckThreatLevel(ThreatLevel.High, "osNpcMoveToTarget"); + if (!CheckThreatLevel(ThreatLevel.High, "osNpcMoveToTarget")) return; m_host.AddScriptLPS(1); INPCModule module = World.RequestModuleInterface(); @@ -2676,7 +2681,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api public void osNpcSetRot(LSL_Key npc, LSL_Rotation rotation) { - CheckThreatLevel(ThreatLevel.High, "osNpcSetRot"); + if (!CheckThreatLevel(ThreatLevel.High, "osNpcSetRot")) return; m_host.AddScriptLPS(1); INPCModule npcModule = World.RequestModuleInterface(); @@ -2698,7 +2703,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api public void osNpcStopMoveToTarget(LSL_Key npc) { - CheckThreatLevel(ThreatLevel.High, "osNpcStopMoveToTarget"); + if (!CheckThreatLevel(ThreatLevel.High, "osNpcStopMoveToTarget")) return; m_host.AddScriptLPS(1); INPCModule module = World.RequestModuleInterface(); @@ -2720,7 +2725,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api public void osNpcSay(LSL_Key npc, int channel, string message) { - CheckThreatLevel(ThreatLevel.High, "osNpcSay"); + if (!CheckThreatLevel(ThreatLevel.High, "osNpcSay")) return; m_host.AddScriptLPS(1); INPCModule module = World.RequestModuleInterface(); @@ -2737,7 +2742,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api public void osNpcShout(LSL_Key npc, int channel, string message) { - CheckThreatLevel(ThreatLevel.High, "osNpcShout"); + if (!CheckThreatLevel(ThreatLevel.High, "osNpcShout")) return; m_host.AddScriptLPS(1); INPCModule module = World.RequestModuleInterface(); @@ -2754,7 +2759,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api public void osNpcSit(LSL_Key npc, LSL_Key target, int options) { - CheckThreatLevel(ThreatLevel.High, "osNpcSit"); + if (!CheckThreatLevel(ThreatLevel.High, "osNpcSit")) return; m_host.AddScriptLPS(1); INPCModule module = World.RequestModuleInterface(); @@ -2771,7 +2776,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api public void osNpcStand(LSL_Key npc) { - CheckThreatLevel(ThreatLevel.High, "osNpcStand"); + if (!CheckThreatLevel(ThreatLevel.High, "osNpcStand")) return; m_host.AddScriptLPS(1); INPCModule module = World.RequestModuleInterface(); @@ -2788,7 +2793,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api public void osNpcRemove(LSL_Key npc) { - CheckThreatLevel(ThreatLevel.High, "osNpcRemove"); + if (!CheckThreatLevel(ThreatLevel.High, "osNpcRemove")) return; m_host.AddScriptLPS(1); INPCModule module = World.RequestModuleInterface(); @@ -2805,7 +2810,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api public void osNpcPlayAnimation(LSL_Key npc, string animation) { - CheckThreatLevel(ThreatLevel.High, "osNpcPlayAnimation"); + if (!CheckThreatLevel(ThreatLevel.High, "osNpcPlayAnimation")) return; m_host.AddScriptLPS(1); INPCModule module = World.RequestModuleInterface(); @@ -2820,7 +2825,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api public void osNpcStopAnimation(LSL_Key npc, string animation) { - CheckThreatLevel(ThreatLevel.High, "osNpcStopAnimation"); + if (!CheckThreatLevel(ThreatLevel.High, "osNpcStopAnimation")) return; m_host.AddScriptLPS(1); INPCModule module = World.RequestModuleInterface(); @@ -2835,7 +2840,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api public void osNpcWhisper(LSL_Key npc, int channel, string message) { - CheckThreatLevel(ThreatLevel.High, "osNpcWhisper"); + if (!CheckThreatLevel(ThreatLevel.High, "osNpcWhisper")) return; m_host.AddScriptLPS(1); INPCModule module = World.RequestModuleInterface(); @@ -2852,7 +2857,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api public void osNpcTouch(LSL_Key npcLSL_Key, LSL_Key object_key, LSL_Integer link_num) { - CheckThreatLevel(ThreatLevel.High, "osNpcTouch"); + if (!CheckThreatLevel(ThreatLevel.High, "osNpcTouch")) return; m_host.AddScriptLPS(1); INPCModule module = World.RequestModuleInterface(); @@ -2897,7 +2902,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api /// The asset ID of the notecard saved. public LSL_Key osOwnerSaveAppearance(string notecard) { - CheckThreatLevel(ThreatLevel.Moderate, "osOwnerSaveAppearance"); + if (!CheckThreatLevel(ThreatLevel.Moderate, "osOwnerSaveAppearance")) return new LSL_Key(ScriptBaseClass.NULL_KEY); m_host.AddScriptLPS(1); return SaveAppearanceToNotecard(m_host.OwnerID, notecard); @@ -2905,7 +2910,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api public LSL_Key osAgentSaveAppearance(LSL_Key avatarId, string notecard) { - CheckThreatLevel(ThreatLevel.High, "osAgentSaveAppearance"); + if (!CheckThreatLevel(ThreatLevel.High, "osAgentSaveAppearance")) return new LSL_Key(ScriptBaseClass.NULL_KEY); m_host.AddScriptLPS(1); return SaveAppearanceToNotecard(avatarId, notecard); @@ -3077,7 +3082,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api public int osGetSimulatorMemory() { - CheckThreatLevel(ThreatLevel.Moderate, "osGetSimulatorMemory"); + if (!CheckThreatLevel(ThreatLevel.Moderate, "osGetSimulatorMemory")) return 0; m_host.AddScriptLPS(1); long pws = System.Diagnostics.Process.GetCurrentProcess().WorkingSet64; @@ -3091,7 +3096,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api public void osSetSpeed(string UUID, LSL_Float SpeedModifier) { - CheckThreatLevel(ThreatLevel.Moderate, "osSetSpeed"); + if (!CheckThreatLevel(ThreatLevel.Moderate, "osSetSpeed")) return; m_host.AddScriptLPS(1); ScenePresence avatar = World.GetScenePresence(new UUID(UUID)); @@ -3101,7 +3106,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api public void osKickAvatar(string FirstName, string SurName, string alert) { - CheckThreatLevel(ThreatLevel.Severe, "osKickAvatar"); + if (!CheckThreatLevel(ThreatLevel.Severe, "osKickAvatar")) return; m_host.AddScriptLPS(1); World.ForEachRootScenePresence(delegate(ScenePresence sp) @@ -3130,7 +3135,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api public void osCauseDamage(string avatar, double damage) { - CheckThreatLevel(ThreatLevel.High, "osCauseDamage"); + if (!CheckThreatLevel(ThreatLevel.High, "osCauseDamage")) return; m_host.AddScriptLPS(1); UUID avatarId = new UUID(avatar); @@ -3158,7 +3163,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api public void osCauseHealing(string avatar, double healing) { - CheckThreatLevel(ThreatLevel.High, "osCauseHealing"); + if (!CheckThreatLevel(ThreatLevel.High, "osCauseHealing")) return; m_host.AddScriptLPS(1); UUID avatarId = new UUID(avatar); @@ -3178,7 +3183,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api public LSL_List osGetPrimitiveParams(LSL_Key prim, LSL_List rules) { - CheckThreatLevel(ThreatLevel.High, "osGetPrimitiveParams"); + if (!CheckThreatLevel(ThreatLevel.High, "osGetPrimitiveParams")) return new LSL_List(); m_host.AddScriptLPS(1); InitLSL(); @@ -3187,7 +3192,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api public void osSetPrimitiveParams(LSL_Key prim, LSL_List rules) { - CheckThreatLevel(ThreatLevel.High, "osSetPrimitiveParams"); + if (!CheckThreatLevel(ThreatLevel.High, "osSetPrimitiveParams")) return; m_host.AddScriptLPS(1); InitLSL(); @@ -3199,7 +3204,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api /// public void osSetProjectionParams(bool projection, LSL_Key texture, double fov, double focus, double amb) { - CheckThreatLevel(ThreatLevel.High, "osSetProjectionParams"); + if (!CheckThreatLevel(ThreatLevel.High, "osSetProjectionParams")) return; osSetProjectionParams(UUID.Zero.ToString(), projection, texture, fov, focus, amb); } @@ -3209,7 +3214,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api /// public void osSetProjectionParams(LSL_Key prim, bool projection, LSL_Key texture, double fov, double focus, double amb) { - CheckThreatLevel(ThreatLevel.High, "osSetProjectionParams"); + if (!CheckThreatLevel(ThreatLevel.High, "osSetProjectionParams")) return; m_host.AddScriptLPS(1); SceneObjectPart obj = null; @@ -3303,7 +3308,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api /// public LSL_Integer osInviteToGroup(LSL_Key agentId) { - CheckThreatLevel(ThreatLevel.VeryLow, "osInviteToGroup"); + if (!CheckThreatLevel(ThreatLevel.VeryLow, "osInviteToGroup")) return ScriptBaseClass.FALSE; m_host.AddScriptLPS(1); UUID agent = new UUID(agentId); @@ -3338,7 +3343,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api /// public LSL_Integer osEjectFromGroup(LSL_Key agentId) { - CheckThreatLevel(ThreatLevel.VeryLow, "osEjectFromGroup"); + if (!CheckThreatLevel(ThreatLevel.VeryLow, "osEjectFromGroup")) return ScriptBaseClass.FALSE; m_host.AddScriptLPS(1); UUID agent = new UUID(agentId); @@ -3373,7 +3378,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api /// public void osSetTerrainTexture(int level, LSL_Key texture) { - CheckThreatLevel(ThreatLevel.High, "osSetTerrainTexture"); + if (!CheckThreatLevel(ThreatLevel.High, "osSetTerrainTexture")) return; m_host.AddScriptLPS(1); //Check to make sure that the script's owner is the estate manager/master @@ -3403,7 +3408,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api /// public void osSetTerrainTextureHeight(int corner, double low, double high) { - CheckThreatLevel(ThreatLevel.High, "osSetTerrainTextureHeight"); + if (!CheckThreatLevel(ThreatLevel.High, "osSetTerrainTextureHeight")) return; m_host.AddScriptLPS(1); //Check to make sure that the script's owner is the estate manager/master @@ -3424,7 +3429,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api public void osForceAttachToAvatar(int attachmentPoint) { - CheckThreatLevel(ThreatLevel.High, "osForceAttachToAvatar"); + if (!CheckThreatLevel(ThreatLevel.High, "osForceAttachToAvatar")) return; m_host.AddScriptLPS(1); @@ -3434,7 +3439,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api public void osForceAttachToAvatarFromInventory(string itemName, int attachmentPoint) { - CheckThreatLevel(ThreatLevel.High, "osForceAttachToAvatarFromInventory"); + if (!CheckThreatLevel(ThreatLevel.High, "osForceAttachToAvatarFromInventory")) return; m_host.AddScriptLPS(1); @@ -3443,7 +3448,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api public void osForceAttachToOtherAvatarFromInventory(string rawAvatarId, string itemName, int attachmentPoint) { - CheckThreatLevel(ThreatLevel.Severe, "osForceAttachToOtherAvatarFromInventory"); + if (!CheckThreatLevel(ThreatLevel.Severe, "osForceAttachToOtherAvatarFromInventory")) return; m_host.AddScriptLPS(1); @@ -3504,7 +3509,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api public void osForceDetachFromAvatar() { - CheckThreatLevel(ThreatLevel.High, "osForceDetachFromAvatar"); + if (!CheckThreatLevel(ThreatLevel.High, "osForceDetachFromAvatar")) return; m_host.AddScriptLPS(1); @@ -3514,7 +3519,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api public LSL_List osGetNumberOfAttachments(LSL_Key avatar, LSL_List attachmentPoints) { - CheckThreatLevel(ThreatLevel.Moderate, "osGetNumberOfAttachments"); + if (!CheckThreatLevel(ThreatLevel.Moderate, "osGetNumberOfAttachments")) return new LSL_List(); m_host.AddScriptLPS(1); @@ -3550,7 +3555,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api public void osMessageAttachments(LSL_Key avatar, string message, LSL_List attachmentPoints, int options) { - CheckThreatLevel(ThreatLevel.Moderate, "osMessageAttachments"); + if (!CheckThreatLevel(ThreatLevel.Moderate, "osMessageAttachments")) return; m_host.AddScriptLPS(1); UUID targetUUID; @@ -3733,7 +3738,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api /// public void osSetContentType(LSL_Key id, string type) { - CheckThreatLevel(ThreatLevel.High, "osSetContentType"); + if (!CheckThreatLevel(ThreatLevel.High, "osSetContentType")) return; if (m_UrlModule != null) m_UrlModule.HttpContentType(new UUID(id),type); @@ -3795,7 +3800,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api public void osDropAttachment() { - CheckThreatLevel(ThreatLevel.Low, "osDropAttachment"); + if (!CheckThreatLevel(ThreatLevel.Low, "osDropAttachment")) return; m_host.AddScriptLPS(1); DropAttachment(true); @@ -3803,7 +3808,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api public void osForceDropAttachment() { - CheckThreatLevel(ThreatLevel.High, "osForceDropAttachment"); + if (!CheckThreatLevel(ThreatLevel.High, "osForceDropAttachment")) return; m_host.AddScriptLPS(1); DropAttachment(false); @@ -3811,7 +3816,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api public void osDropAttachmentAt(LSL_Vector pos, LSL_Rotation rot) { - CheckThreatLevel(ThreatLevel.Low, "osDropAttachmentAt"); + if (!CheckThreatLevel(ThreatLevel.Low, "osDropAttachmentAt")) return; m_host.AddScriptLPS(1); DropAttachmentAt(true, pos, rot); @@ -3819,7 +3824,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api public void osForceDropAttachmentAt(LSL_Vector pos, LSL_Rotation rot) { - CheckThreatLevel(ThreatLevel.High, "osForceDropAttachmentAt"); + if (!CheckThreatLevel(ThreatLevel.High, "osForceDropAttachmentAt")) return; m_host.AddScriptLPS(1); DropAttachmentAt(false, pos, rot); diff --git a/OpenSim/Region/ScriptEngine/Shared/Api/Interface/IOSSL_Api.cs b/OpenSim/Region/ScriptEngine/Shared/Api/Interface/IOSSL_Api.cs index 6259b76..82fdc53 100644 --- a/OpenSim/Region/ScriptEngine/Shared/Api/Interface/IOSSL_Api.cs +++ b/OpenSim/Region/ScriptEngine/Shared/Api/Interface/IOSSL_Api.cs @@ -114,7 +114,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api.Interfaces public interface IOSSL_Api { - void CheckThreatLevel(ThreatLevel level, string function); + bool CheckThreatLevel(ThreatLevel level, string function); //OpenSim functions string osSetDynamicTextureURL(string dynamicID, string contentType, string url, string extraParams, int timer); -- cgit v1.1