add cap EstateChangeInfo

0.9.1.0-post-fixes
UbitUmarov 2019-08-07 21:06:20 +01:00
parent 1a8c235d58
commit c043008e04
6 changed files with 295 additions and 31 deletions

View File

@ -0,0 +1,228 @@
/*
* Copyright (c) Contributors, http://opensimulator.org/
* See CONTRIBUTORS.TXT for a full list of copyright holders.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions are met:
* * Redistributions of source code must retain the above copyright
* notice, this list of conditions and the following disclaimer.
* * Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in the
* documentation and/or other materials provided with the distribution.
* * Neither the name of the OpenSimulator Project nor the
* names of its contributors may be used to endorse or promote products
* derived from this software without specific prior written permission.
*
* THIS SOFTWARE IS PROVIDED BY THE DEVELOPERS ``AS IS'' AND ANY
* EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
* WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
* DISCLAIMED. IN NO EVENT SHALL THE CONTRIBUTORS BE LIABLE FOR ANY
* DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
* (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
* ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*/
using System;
using System.Collections;
using System.Collections.Generic;
using System.Text;
using System.Reflection;
using log4net;
using Nini.Config;
using OpenMetaverse;
using OpenMetaverse.StructuredData;
using Mono.Addins;
using OpenSim.Framework;
using OpenSim.Framework.Servers.HttpServer;
using OpenSim.Region.Framework.Interfaces;
using OpenSim.Region.Framework.Scenes;
using Caps=OpenSim.Framework.Capabilities.Caps;
namespace OpenSim.Region.ClientStack.Linden
{
[Extension(Path = "/OpenSim/RegionModules", NodeName = "RegionModule", Id = "EstateChangeInfoCapModule")]
public class EstateChangeInfoCapModule : INonSharedRegionModule
{
private static readonly ILog m_log =
LogManager.GetLogger(MethodBase.GetCurrentMethod().DeclaringType);
private Scene m_scene;
private bool m_Enabled = false;
private string m_capUrl;
IEstateModule m_EstateModule;
#region INonSharedRegionModule Members
public void Initialise(IConfigSource pSource)
{
IConfig config = pSource.Configs["ClientStack.LindenCaps"];
if (config == null)
return;
m_capUrl = config.GetString("Cap_EstateChangeInfo", string.Empty);
if (!String.IsNullOrEmpty(m_capUrl) && m_capUrl.Equals("localhost"))
m_Enabled = true;
}
public void AddRegion(Scene scene)
{
if (!m_Enabled)
return;
m_scene = scene;
}
public void RemoveRegion(Scene scene)
{
if (!m_Enabled)
return;
if (m_scene == scene)
{
m_scene.EventManager.OnRegisterCaps -= RegisterCaps;
m_scene = null;
}
}
public void RegionLoaded(Scene scene)
{
if (!m_Enabled)
return;
if (scene.RegionInfo == null || scene.RegionInfo.EstateSettings == null)
{
m_Enabled = false;
return;
}
m_EstateModule = scene.RequestModuleInterface<IEstateModule>();
if(m_EstateModule == null)
{
m_Enabled = false;
return;
}
scene.EventManager.OnRegisterCaps += RegisterCaps;
}
public void Close()
{
}
public string Name
{
get { return "EstateChangeInfoCapModule"; }
}
public Type ReplaceableInterface
{
get { return null; }
}
#endregion
public void RegisterCaps(UUID agentID, Caps caps)
{
string capUrl = "/CAPS/" + UUID.Random() + "/";
caps.RegisterHandler(
"EstateChangeInfo",
new RestHTTPHandler(
"POST",
capUrl,
httpMethod => ProcessRequest(httpMethod, agentID, caps),
"EstateChangeInfo",
agentID.ToString())); ;
}
public Hashtable ProcessRequest(Hashtable request, UUID AgentId, Caps cap)
{
Hashtable responsedata = new Hashtable();
ScenePresence avatar;
if (!m_scene.TryGetScenePresence(AgentId, out avatar) || !m_scene.Permissions.CanIssueEstateCommand(AgentId, false))
{
responsedata["int_response_code"] = 401;
responsedata["str_response_string"] = LLSDxmlEncode.LLSDEmpty;
responsedata["keepalive"] = false;
return responsedata;
}
if (m_scene.RegionInfo == null
|| m_scene.RegionInfo.EstateSettings == null)
{
responsedata["int_response_code"] = 501;
responsedata["str_response_string"] = LLSDxmlEncode.LLSDEmpty;
responsedata["keepalive"] = false;
return responsedata;
}
OSDMap r;
try
{
r = (OSDMap)OSDParser.Deserialize((string)request["requestbody"]);
}
catch (Exception ex)
{
m_log.Error("[UPLOAD OBJECT ASSET MODULE]: Error deserializing message " + ex.ToString());
r = null;
}
if (r == null)
{
responsedata["int_response_code"] = 400; //501; //410; //404;
responsedata["content_type"] = "text/plain";
responsedata["keepalive"] = false;
responsedata["str_response_string"] = LLSDxmlEncode.LLSDEmpty;
return responsedata;
}
bool ok = true;
try
{
string estateName = r["estate_name"].AsString();
UUID invoice = r["invoice"].AsUUID();
int sunHour = r["sun_hour"].AsInteger();
bool sunFixed = r["is_sun_fixed"].AsBoolean();
bool externallyVisible = r["is_externally_visible"].AsBoolean();
bool allowDirectTeleport = r["allow_direct_teleport"].AsBoolean();
bool denyAnonymous = r["deny_anonymous"].AsBoolean();
bool denyAgeUnverified = r["deny_age_unverified"].AsBoolean();
bool alloVoiceChat = r["allow_voice_chat"].AsBoolean();
// taxfree is now AllowAccessOverride
bool overridePublicAccess = m_scene.RegionInfo.EstateSettings.TaxFree;
if (r.ContainsKey("override_public_access"))
overridePublicAccess = r["override_public_access"].AsBoolean();
ok = m_EstateModule.handleEstateChangeInfoCap(estateName, invoice, sunHour, sunFixed,
externallyVisible, allowDirectTeleport, denyAnonymous, denyAgeUnverified,
alloVoiceChat, overridePublicAccess);
}
catch
{
ok = false;
}
if(ok)
{
responsedata["int_response_code"] = 200;
responsedata["content_type"] = "text/plain";
responsedata["str_response_string"] = LLSDxmlEncode.LLSDEmpty;
}
else
{
responsedata["int_response_code"] = 400; //501; //410; //404;
responsedata["content_type"] = "text/plain";
responsedata["keepalive"] = false;
responsedata["str_response_string"] = LLSDxmlEncode.LLSDEmpty;
}
return responsedata;
}
}
}

View File

@ -161,34 +161,34 @@ namespace OpenSim.Region.ClientStack.Linden
int lastattach = 0; int lastattach = 0;
OSDMap rm = (OSDMap)r; OSDMap rm = (OSDMap)r;
OSD tmpOSD;
if (rm.ContainsKey("ObjectData")) //v2 if (rm.TryGetValue("ObjectData", out tmpOSD)) //v2
{ {
if (rm["ObjectData"].Type != OSDType.Map) if (tmpOSD.Type != OSDType.Map)
{ {
responsedata["str_response_string"] = "Has ObjectData key, but data not in expected format"; responsedata["str_response_string"] = "Has ObjectData key, but data not in expected format";
return responsedata; return responsedata;
} }
OSDMap ObjMap = (OSDMap)rm["ObjectData"]; OSDMap ObjMap = (OSDMap)tmpOSD;
bypass_raycast = ObjMap["BypassRaycast"].AsBoolean(); bypass_raycast = ObjMap["BypassRaycast"].AsBoolean();
everyone_mask = readuintval(ObjMap["EveryoneMask"]); everyone_mask = ReadUIntVal(ObjMap["EveryoneMask"]);
flags = readuintval(ObjMap["Flags"]); flags = ReadUIntVal(ObjMap["Flags"]);
group_mask = readuintval(ObjMap["GroupMask"]); group_mask = ReadUIntVal(ObjMap["GroupMask"]);
material = ObjMap["Material"].AsInteger(); material = ObjMap["Material"].AsInteger();
next_owner_mask = readuintval(ObjMap["NextOwnerMask"]); next_owner_mask = ReadUIntVal(ObjMap["NextOwnerMask"]);
p_code = ObjMap["PCode"].AsInteger(); p_code = ObjMap["PCode"].AsInteger();
if (ObjMap.ContainsKey("Path")) if (ObjMap.TryGetValue("Path", out tmpOSD))
{ {
if (ObjMap["Path"].Type != OSDType.Map) if (tmpOSD.Type != OSDType.Map)
{ {
responsedata["str_response_string"] = "Has Path key, but data not in expected format"; responsedata["str_response_string"] = "Has Path key, but data not in expected format";
return responsedata; return responsedata;
} }
OSDMap PathMap = (OSDMap)ObjMap["Path"]; OSDMap PathMap = (OSDMap)tmpOSD;
path_begin = PathMap["Begin"].AsInteger(); path_begin = PathMap["Begin"].AsInteger();
path_curve = PathMap["Curve"].AsInteger(); path_curve = PathMap["Curve"].AsInteger();
path_end = PathMap["End"].AsInteger(); path_end = PathMap["End"].AsInteger();
@ -203,18 +203,17 @@ namespace OpenSim.Region.ClientStack.Linden
path_taper_y = PathMap["TaperY"].AsInteger(); path_taper_y = PathMap["TaperY"].AsInteger();
path_twist = PathMap["Twist"].AsInteger(); path_twist = PathMap["Twist"].AsInteger();
path_twist_begin = PathMap["TwistBegin"].AsInteger(); path_twist_begin = PathMap["TwistBegin"].AsInteger();
} }
if (ObjMap.ContainsKey("Profile")) if (ObjMap.TryGetValue("Profile", out tmpOSD))
{ {
if (ObjMap["Profile"].Type != OSDType.Map) if (tmpOSD.Type != OSDType.Map)
{ {
responsedata["str_response_string"] = "Has Profile key, but data not in expected format"; responsedata["str_response_string"] = "Has Profile key, but data not in expected format";
return responsedata; return responsedata;
} }
OSDMap ProfileMap = (OSDMap)ObjMap["Profile"]; OSDMap ProfileMap = (OSDMap)tmpOSD;
profile_begin = ProfileMap["Begin"].AsInteger(); profile_begin = ProfileMap["Begin"].AsInteger();
profile_curve = ProfileMap["Curve"].AsInteger(); profile_curve = ProfileMap["Curve"].AsInteger();
@ -239,15 +238,15 @@ namespace OpenSim.Region.ClientStack.Linden
return responsedata; return responsedata;
} }
if (rm.ContainsKey("AgentData")) if (rm.TryGetValue("AgentData", out tmpOSD))
{ {
if (rm["AgentData"].Type != OSDType.Map) if (tmpOSD.Type != OSDType.Map)
{ {
responsedata["str_response_string"] = "Has AgentData key, but data not in expected format"; responsedata["str_response_string"] = "Has AgentData key, but data not in expected format";
return responsedata; return responsedata;
} }
OSDMap AgentDataMap = (OSDMap)rm["AgentData"]; OSDMap AgentDataMap = (OSDMap)tmpOSD;
//session_id = AgentDataMap["SessionId"].AsUUID(); //session_id = AgentDataMap["SessionId"].AsUUID();
group_id = AgentDataMap["GroupId"].AsUUID(); group_id = AgentDataMap["GroupId"].AsUUID();
@ -258,13 +257,13 @@ namespace OpenSim.Region.ClientStack.Linden
{ //v1 { //v1
bypass_raycast = rm["bypass_raycast"].AsBoolean(); bypass_raycast = rm["bypass_raycast"].AsBoolean();
everyone_mask = readuintval(rm["everyone_mask"]); everyone_mask = ReadUIntVal(rm["everyone_mask"]);
flags = readuintval(rm["flags"]); flags = ReadUIntVal(rm["flags"]);
group_id = rm["group_id"].AsUUID(); group_id = rm["group_id"].AsUUID();
group_mask = readuintval(rm["group_mask"]); group_mask = ReadUIntVal(rm["group_mask"]);
hollow = rm["hollow"].AsInteger(); hollow = rm["hollow"].AsInteger();
material = rm["material"].AsInteger(); material = rm["material"].AsInteger();
next_owner_mask = readuintval(rm["next_owner_mask"]); next_owner_mask = ReadUIntVal(rm["next_owner_mask"]);
hollow = rm["hollow"].AsInteger(); hollow = rm["hollow"].AsInteger();
p_code = rm["p_code"].AsInteger(); p_code = rm["p_code"].AsInteger();
path_begin = rm["path_begin"].AsInteger(); path_begin = rm["path_begin"].AsInteger();
@ -344,7 +343,6 @@ namespace OpenSim.Region.ClientStack.Linden
obj = m_scene.AddNewPrim(avatar.UUID, group_id, pos, rotation, pbs); obj = m_scene.AddNewPrim(avatar.UUID, group_id, pos, rotation, pbs);
} }
if (obj == null) if (obj == null)
return responsedata; return responsedata;
@ -369,7 +367,7 @@ namespace OpenSim.Region.ClientStack.Linden
return responsedata; return responsedata;
} }
private uint readuintval(OSD obj) private uint ReadUIntVal(OSD obj)
{ {
byte[] tmp = obj.AsBinary(); byte[] tmp = obj.AsBinary();
if (BitConverter.IsLittleEndian) if (BitConverter.IsLittleEndian)

View File

@ -1593,6 +1593,44 @@ namespace OpenSim.Region.CoreModules.World.Estate
sendDetailedEstateData(remoteClient, invoice); sendDetailedEstateData(remoteClient, invoice);
} }
public bool handleEstateChangeInfoCap(string estateName, UUID invoice,
int sunHour, bool sunFixed,
bool externallyVisible,
bool allowDirectTeleport,
bool denyAnonymous, bool denyAgeUnverified,
bool alloVoiceChat, bool overridePublicAccess)
{
if (sunHour == 0)
{
Scene.RegionInfo.EstateSettings.UseGlobalTime = true;
Scene.RegionInfo.EstateSettings.SunPosition = 0.0;
}
else
{
Scene.RegionInfo.EstateSettings.UseGlobalTime = false;
Scene.RegionInfo.EstateSettings.SunPosition = (sunHour - 0x1800) / 1024.0;
// Warning: FixedSun should be set to True, otherwise this sun position won't be used.
}
Scene.RegionInfo.EstateSettings.PublicAccess = externallyVisible;
Scene.RegionInfo.EstateSettings.FixedSun = sunFixed;
Scene.RegionInfo.EstateSettings.AllowDirectTeleport = allowDirectTeleport;
Scene.RegionInfo.EstateSettings.DenyAnonymous = denyAnonymous;
Scene.RegionInfo.EstateSettings.AllowVoice = alloVoiceChat;
// taxfree is now AllowAccessOverride
Scene.RegionInfo.EstateSettings.TaxFree = overridePublicAccess;
Scene.RegionInfo.EstateSettings.DenyMinors = denyAgeUnverified;
Scene.EstateDataService.StoreEstateSettings(Scene.RegionInfo.EstateSettings);
TriggerEstateInfoChange();
Scene.TriggerEstateSunUpdate();
return true;
}
#endregion #endregion
#region Other Functions #region Other Functions

View File

@ -68,5 +68,8 @@ namespace OpenSim.Region.Framework.Interfaces
/// Returns whether the transfer ID is being used for a terrain transfer. /// Returns whether the transfer ID is being used for a terrain transfer.
/// </summary> /// </summary>
bool IsTerrainXfer(ulong xferID); bool IsTerrainXfer(ulong xferID);
bool handleEstateChangeInfoCap(string estateName, UUID invoice, int sunHour, bool sunFixed,
bool externallyVisible, bool allowDirectTeleport, bool denyAnonymous, bool denyAgeUnverified,
bool alloVoiceChat, bool overridePublicAccess);
} }
} }

View File

@ -456,12 +456,9 @@ namespace OpenSim.Server.Handlers.Simulation
{ {
source = new GridRegion(); source = new GridRegion();
source.RegionID = UUID.Parse(tmpOSD.AsString()); source.RegionID = UUID.Parse(tmpOSD.AsString());
tmpOSD = args["source_x"]; source.RegionLocX = Int32.Parse(args["source_x"].AsString());
source.RegionLocX = Int32.Parse(tmpOSD.AsString()); source.RegionLocY = Int32.Parse(args["source_y"].AsString());
tmpOSD = args["source_y"]; source.RegionName = args["source_name"].AsString();
source.RegionLocY = Int32.Parse(tmpOSD.AsString());
tmpOSD = args["source_name"];
source.RegionName = tmpOSD.AsString();
if (args.TryGetValue("source_server_uri", out tmpOSD)) if (args.TryGetValue("source_server_uri", out tmpOSD))
source.RawServerURI = tmpOSD.AsString(); source.RawServerURI = tmpOSD.AsString();

View File

@ -772,7 +772,7 @@
Cap_CopyInventoryFromNotecard = "localhost" Cap_CopyInventoryFromNotecard = "localhost"
Cap_DispatchRegionInfo = "" Cap_DispatchRegionInfo = ""
Cap_EstateAccess = "localhost" Cap_EstateAccess = "localhost"
Cap_EstateChangeInfo = "" Cap_EstateChangeInfo = "localhost"
Cap_EnvironmentSettings = "localhost" Cap_EnvironmentSettings = "localhost"
Cap_EventQueueGet = "localhost" Cap_EventQueueGet = "localhost"
Cap_FetchInventory = "" Cap_FetchInventory = ""