Merge branch 'master' of brain.opensimulator.org:/var/git/opensim
commit
f332f3fc41
|
@ -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;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
|
@ -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)
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -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();
|
||||||
|
|
|
@ -775,7 +775,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 = ""
|
||||||
|
|
Loading…
Reference in New Issue