Poof! on Region.Communications.Hypergrid. Grid code deleted.
parent
f4bf581b96
commit
989382352d
|
@ -187,18 +187,11 @@ namespace OpenSim.ApplicationPlugins.CreateCommsManager
|
||||||
|
|
||||||
protected virtual void InitialiseHGStandaloneServices(LibraryRootFolder libraryRootFolder)
|
protected virtual void InitialiseHGStandaloneServices(LibraryRootFolder libraryRootFolder)
|
||||||
{
|
{
|
||||||
HGGridServicesStandalone gridService
|
|
||||||
= new HGGridServicesStandalone(
|
|
||||||
m_openSim.NetServersInfo, m_httpServer, m_openSim.SceneManager);
|
|
||||||
|
|
||||||
m_commsManager
|
m_commsManager
|
||||||
= new HGCommunicationsStandalone(
|
= new HGCommunicationsStandalone(
|
||||||
m_openSim.ConfigurationSettings, m_openSim.NetServersInfo, m_httpServer,
|
m_openSim.ConfigurationSettings, m_openSim.NetServersInfo, m_httpServer,
|
||||||
gridService,
|
|
||||||
libraryRootFolder, false);
|
libraryRootFolder, false);
|
||||||
|
|
||||||
HGServices = gridService;
|
|
||||||
|
|
||||||
CreateGridInfoService();
|
CreateGridInfoService();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -209,8 +202,6 @@ namespace OpenSim.ApplicationPlugins.CreateCommsManager
|
||||||
m_openSim.NetServersInfo,
|
m_openSim.NetServersInfo,
|
||||||
m_openSim.SceneManager, libraryRootFolder);
|
m_openSim.SceneManager, libraryRootFolder);
|
||||||
|
|
||||||
HGServices = ((HGCommunicationsGridMode) m_commsManager).HGServices;
|
|
||||||
|
|
||||||
m_httpServer.AddStreamHandler(new OpenSim.SimStatusHandler());
|
m_httpServer.AddStreamHandler(new OpenSim.SimStatusHandler());
|
||||||
m_httpServer.AddStreamHandler(new OpenSim.XSimStatusHandler(m_openSim));
|
m_httpServer.AddStreamHandler(new OpenSim.XSimStatusHandler(m_openSim));
|
||||||
if (m_openSim.userStatsURI != String.Empty)
|
if (m_openSim.userStatsURI != String.Empty)
|
||||||
|
|
|
@ -40,21 +40,12 @@ namespace OpenSim.Region.Communications.Hypergrid
|
||||||
{
|
{
|
||||||
public class HGCommunicationsGridMode : CommunicationsManager // CommunicationsOGS1
|
public class HGCommunicationsGridMode : CommunicationsManager // CommunicationsOGS1
|
||||||
{
|
{
|
||||||
IHyperlink m_osw = null;
|
|
||||||
public IHyperlink HGServices
|
|
||||||
{
|
|
||||||
get { return m_osw; }
|
|
||||||
}
|
|
||||||
|
|
||||||
public HGCommunicationsGridMode(
|
public HGCommunicationsGridMode(
|
||||||
NetworkServersInfo serversInfo,
|
NetworkServersInfo serversInfo,
|
||||||
SceneManager sman, LibraryRootFolder libraryRootFolder)
|
SceneManager sman, LibraryRootFolder libraryRootFolder)
|
||||||
: base(serversInfo, libraryRootFolder)
|
: base(serversInfo, libraryRootFolder)
|
||||||
{
|
{
|
||||||
// From constructor at CommunicationsOGS1
|
|
||||||
HGGridServices gridInterComms = new HGGridServicesGridMode(serversInfo, sman, m_userProfileCacheService);
|
|
||||||
m_gridService = gridInterComms;
|
|
||||||
m_osw = gridInterComms;
|
|
||||||
|
|
||||||
HGUserServices userServices = new HGUserServices(this);
|
HGUserServices userServices = new HGUserServices(this);
|
||||||
// This plugin arrangement could eventually be configurable rather than hardcoded here.
|
// This plugin arrangement could eventually be configurable rather than hardcoded here.
|
||||||
|
|
|
@ -44,7 +44,6 @@ namespace OpenSim.Region.Communications.Hypergrid
|
||||||
ConfigSettings configSettings,
|
ConfigSettings configSettings,
|
||||||
NetworkServersInfo serversInfo,
|
NetworkServersInfo serversInfo,
|
||||||
BaseHttpServer httpServer,
|
BaseHttpServer httpServer,
|
||||||
HGGridServices gridService,
|
|
||||||
LibraryRootFolder libraryRootFolder,
|
LibraryRootFolder libraryRootFolder,
|
||||||
bool dumpAssetsToFile)
|
bool dumpAssetsToFile)
|
||||||
: base(serversInfo, libraryRootFolder)
|
: base(serversInfo, libraryRootFolder)
|
||||||
|
@ -64,8 +63,6 @@ namespace OpenSim.Region.Communications.Hypergrid
|
||||||
m_avatarService = hgUserService;
|
m_avatarService = hgUserService;
|
||||||
m_messageService = hgUserService;
|
m_messageService = hgUserService;
|
||||||
|
|
||||||
gridService.UserProfileCache = m_userProfileCacheService;
|
|
||||||
m_gridService = gridService;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
File diff suppressed because it is too large
Load Diff
|
@ -1,159 +0,0 @@
|
||||||
/*
|
|
||||||
* 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.Generic;
|
|
||||||
using System.Reflection;
|
|
||||||
using log4net;
|
|
||||||
using OpenMetaverse;
|
|
||||||
using OpenSim.Framework;
|
|
||||||
using OpenSim.Framework.Communications.Cache;
|
|
||||||
using OpenSim.Framework.Servers.HttpServer;
|
|
||||||
using OpenSim.Region.Communications.OGS1;
|
|
||||||
using OpenSim.Region.Framework.Scenes;
|
|
||||||
|
|
||||||
namespace OpenSim.Region.Communications.Hypergrid
|
|
||||||
{
|
|
||||||
public class HGGridServicesGridMode : HGGridServices
|
|
||||||
{
|
|
||||||
//private static readonly ILog m_log = LogManager.GetLogger(MethodBase.GetCurrentMethod().DeclaringType);
|
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// Encapsulate remote backend services for manipulation of grid regions
|
|
||||||
/// </summary>
|
|
||||||
private OGS1GridServices m_remoteBackend = null;
|
|
||||||
|
|
||||||
public OGS1GridServices RemoteBackend
|
|
||||||
{
|
|
||||||
get { return m_remoteBackend; }
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
public override string gdebugRegionName
|
|
||||||
{
|
|
||||||
get { return m_remoteBackend.gdebugRegionName; }
|
|
||||||
set { m_remoteBackend.gdebugRegionName = value; }
|
|
||||||
}
|
|
||||||
|
|
||||||
public override bool RegionLoginsEnabled
|
|
||||||
{
|
|
||||||
get { return m_remoteBackend.RegionLoginsEnabled; }
|
|
||||||
set { m_remoteBackend.RegionLoginsEnabled = value; }
|
|
||||||
}
|
|
||||||
|
|
||||||
public HGGridServicesGridMode(NetworkServersInfo servers_info,
|
|
||||||
SceneManager sman, UserProfileCacheService userv)
|
|
||||||
: base(servers_info, sman)
|
|
||||||
{
|
|
||||||
m_remoteBackend = new OGS1GridServices(servers_info);
|
|
||||||
m_userProfileCache = userv;
|
|
||||||
}
|
|
||||||
|
|
||||||
#region IGridServices interface
|
|
||||||
|
|
||||||
public override RegionCommsListener RegisterRegion(RegionInfo regionInfo)
|
|
||||||
{
|
|
||||||
if (!regionInfo.RegionID.Equals(UUID.Zero))
|
|
||||||
{
|
|
||||||
m_regionsOnInstance.Add(regionInfo);
|
|
||||||
return m_remoteBackend.RegisterRegion(regionInfo);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
return base.RegisterRegion(regionInfo);
|
|
||||||
}
|
|
||||||
|
|
||||||
public override bool DeregisterRegion(RegionInfo regionInfo)
|
|
||||||
{
|
|
||||||
bool success = base.DeregisterRegion(regionInfo);
|
|
||||||
if (!success)
|
|
||||||
success = m_remoteBackend.DeregisterRegion(regionInfo);
|
|
||||||
return success;
|
|
||||||
}
|
|
||||||
|
|
||||||
public override List<SimpleRegionInfo> RequestNeighbours(uint x, uint y)
|
|
||||||
{
|
|
||||||
List<SimpleRegionInfo> neighbours = m_remoteBackend.RequestNeighbours(x, y);
|
|
||||||
//List<SimpleRegionInfo> remotes = base.RequestNeighbours(x, y);
|
|
||||||
//neighbours.AddRange(remotes);
|
|
||||||
|
|
||||||
return neighbours;
|
|
||||||
}
|
|
||||||
|
|
||||||
public override RegionInfo RequestNeighbourInfo(UUID Region_UUID)
|
|
||||||
{
|
|
||||||
RegionInfo info = m_remoteBackend.RequestNeighbourInfo(Region_UUID);
|
|
||||||
if (info == null)
|
|
||||||
info = base.RequestNeighbourInfo(Region_UUID);
|
|
||||||
return info;
|
|
||||||
}
|
|
||||||
|
|
||||||
public override RegionInfo RequestNeighbourInfo(ulong regionHandle)
|
|
||||||
{
|
|
||||||
RegionInfo info = base.RequestNeighbourInfo(regionHandle);
|
|
||||||
if (info == null)
|
|
||||||
info = m_remoteBackend.RequestNeighbourInfo(regionHandle);
|
|
||||||
return info;
|
|
||||||
}
|
|
||||||
|
|
||||||
public override RegionInfo RequestClosestRegion(string regionName)
|
|
||||||
{
|
|
||||||
RegionInfo info = m_remoteBackend.RequestClosestRegion(regionName);
|
|
||||||
if (info == null)
|
|
||||||
info = base.RequestClosestRegion(regionName);
|
|
||||||
return info;
|
|
||||||
}
|
|
||||||
|
|
||||||
public override List<MapBlockData> RequestNeighbourMapBlocks(int minX, int minY, int maxX, int maxY)
|
|
||||||
{
|
|
||||||
List<MapBlockData> neighbours = m_remoteBackend.RequestNeighbourMapBlocks(minX, minY, maxX, maxY);
|
|
||||||
List<MapBlockData> remotes = base.RequestNeighbourMapBlocks(minX, minY, maxX, maxY);
|
|
||||||
neighbours.AddRange(remotes);
|
|
||||||
|
|
||||||
return neighbours;
|
|
||||||
}
|
|
||||||
|
|
||||||
public override LandData RequestLandData(ulong regionHandle, uint x, uint y)
|
|
||||||
{
|
|
||||||
LandData land = m_remoteBackend.RequestLandData(regionHandle, x, y);
|
|
||||||
if (land == null)
|
|
||||||
land = base.RequestLandData(regionHandle, x, y);
|
|
||||||
return land;
|
|
||||||
}
|
|
||||||
|
|
||||||
public override List<RegionInfo> RequestNamedRegions(string name, int maxNumber)
|
|
||||||
{
|
|
||||||
List<RegionInfo> infos = m_remoteBackend.RequestNamedRegions(name, maxNumber);
|
|
||||||
List<RegionInfo> remotes = base.RequestNamedRegions(name, maxNumber);
|
|
||||||
infos.AddRange(remotes);
|
|
||||||
return infos;
|
|
||||||
}
|
|
||||||
|
|
||||||
#endregion
|
|
||||||
|
|
||||||
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -1,259 +0,0 @@
|
||||||
/*
|
|
||||||
* 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.Net;
|
|
||||||
using System.Net.Sockets;
|
|
||||||
using System.Reflection;
|
|
||||||
using System.Runtime.Remoting;
|
|
||||||
using System.Runtime.Remoting.Channels;
|
|
||||||
using System.Runtime.Remoting.Channels.Tcp;
|
|
||||||
using System.Security.Authentication;
|
|
||||||
using log4net;
|
|
||||||
using Nwc.XmlRpc;
|
|
||||||
using OpenMetaverse;
|
|
||||||
using OpenSim.Framework;
|
|
||||||
using OpenSim.Framework.Servers;
|
|
||||||
using OpenSim.Framework.Servers.HttpServer;
|
|
||||||
using OpenSim.Region.Communications.Local;
|
|
||||||
using OpenSim.Region.Communications.OGS1;
|
|
||||||
using OpenSim.Region.Framework.Scenes;
|
|
||||||
|
|
||||||
namespace OpenSim.Region.Communications.Hypergrid
|
|
||||||
{
|
|
||||||
public class HGGridServicesStandalone : HGGridServices
|
|
||||||
{
|
|
||||||
private static readonly ILog m_log = LogManager.GetLogger(MethodBase.GetCurrentMethod().DeclaringType);
|
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// Encapsulate local backend services for manipulation of local regions
|
|
||||||
/// </summary>
|
|
||||||
protected LocalBackEndServices m_localBackend = new LocalBackEndServices();
|
|
||||||
|
|
||||||
//private Dictionary<ulong, int> m_deadRegionCache = new Dictionary<ulong, int>();
|
|
||||||
|
|
||||||
public LocalBackEndServices LocalBackend
|
|
||||||
{
|
|
||||||
get { return m_localBackend; }
|
|
||||||
}
|
|
||||||
|
|
||||||
public override string gdebugRegionName
|
|
||||||
{
|
|
||||||
get { return m_localBackend.gdebugRegionName; }
|
|
||||||
set { m_localBackend.gdebugRegionName = value; }
|
|
||||||
}
|
|
||||||
|
|
||||||
public override bool RegionLoginsEnabled
|
|
||||||
{
|
|
||||||
get { return m_localBackend.RegionLoginsEnabled; }
|
|
||||||
set { m_localBackend.RegionLoginsEnabled = value; }
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
public HGGridServicesStandalone(NetworkServersInfo servers_info, BaseHttpServer httpServe, SceneManager sman)
|
|
||||||
: base(servers_info, sman)
|
|
||||||
{
|
|
||||||
//Respond to Grid Services requests
|
|
||||||
MainServer.Instance.AddXmlRPCHandler("logoff_user", LogOffUser);
|
|
||||||
MainServer.Instance.AddXmlRPCHandler("check", PingCheckReply);
|
|
||||||
MainServer.Instance.AddXmlRPCHandler("land_data", LandData);
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
#region IGridServices interface
|
|
||||||
|
|
||||||
public override RegionCommsListener RegisterRegion(RegionInfo regionInfo)
|
|
||||||
{
|
|
||||||
if (!regionInfo.RegionID.Equals(UUID.Zero))
|
|
||||||
{
|
|
||||||
m_regionsOnInstance.Add(regionInfo);
|
|
||||||
return m_localBackend.RegisterRegion(regionInfo);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
return base.RegisterRegion(regionInfo);
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
public override bool DeregisterRegion(RegionInfo regionInfo)
|
|
||||||
{
|
|
||||||
bool success = m_localBackend.DeregisterRegion(regionInfo);
|
|
||||||
if (!success)
|
|
||||||
success = base.DeregisterRegion(regionInfo);
|
|
||||||
return success;
|
|
||||||
}
|
|
||||||
|
|
||||||
public override List<SimpleRegionInfo> RequestNeighbours(uint x, uint y)
|
|
||||||
{
|
|
||||||
List<SimpleRegionInfo> neighbours = m_localBackend.RequestNeighbours(x, y);
|
|
||||||
//List<SimpleRegionInfo> remotes = base.RequestNeighbours(x, y);
|
|
||||||
//neighbours.AddRange(remotes);
|
|
||||||
|
|
||||||
return neighbours;
|
|
||||||
}
|
|
||||||
|
|
||||||
public override RegionInfo RequestNeighbourInfo(UUID Region_UUID)
|
|
||||||
{
|
|
||||||
RegionInfo info = m_localBackend.RequestNeighbourInfo(Region_UUID);
|
|
||||||
if (info == null)
|
|
||||||
info = base.RequestNeighbourInfo(Region_UUID);
|
|
||||||
return info;
|
|
||||||
}
|
|
||||||
|
|
||||||
public override RegionInfo RequestNeighbourInfo(ulong regionHandle)
|
|
||||||
{
|
|
||||||
RegionInfo info = m_localBackend.RequestNeighbourInfo(regionHandle);
|
|
||||||
//m_log.Info("[HGrid] Request neighbor info, local backend returned " + info);
|
|
||||||
if (info == null)
|
|
||||||
info = base.RequestNeighbourInfo(regionHandle);
|
|
||||||
return info;
|
|
||||||
}
|
|
||||||
|
|
||||||
public override RegionInfo RequestClosestRegion(string regionName)
|
|
||||||
{
|
|
||||||
RegionInfo info = m_localBackend.RequestClosestRegion(regionName);
|
|
||||||
if (info == null)
|
|
||||||
info = base.RequestClosestRegion(regionName);
|
|
||||||
return info;
|
|
||||||
}
|
|
||||||
|
|
||||||
public override List<MapBlockData> RequestNeighbourMapBlocks(int minX, int minY, int maxX, int maxY)
|
|
||||||
{
|
|
||||||
//m_log.Info("[HGrid] Request map blocks " + minX + "-" + minY + "-" + maxX + "-" + maxY);
|
|
||||||
List<MapBlockData> neighbours = m_localBackend.RequestNeighbourMapBlocks(minX, minY, maxX, maxY);
|
|
||||||
List<MapBlockData> remotes = base.RequestNeighbourMapBlocks(minX, minY, maxX, maxY);
|
|
||||||
neighbours.AddRange(remotes);
|
|
||||||
|
|
||||||
return neighbours;
|
|
||||||
}
|
|
||||||
|
|
||||||
public override LandData RequestLandData(ulong regionHandle, uint x, uint y)
|
|
||||||
{
|
|
||||||
LandData land = m_localBackend.RequestLandData(regionHandle, x, y);
|
|
||||||
if (land == null)
|
|
||||||
land = base.RequestLandData(regionHandle, x, y);
|
|
||||||
return land;
|
|
||||||
}
|
|
||||||
|
|
||||||
public override List<RegionInfo> RequestNamedRegions(string name, int maxNumber)
|
|
||||||
{
|
|
||||||
List<RegionInfo> infos = m_localBackend.RequestNamedRegions(name, maxNumber);
|
|
||||||
List<RegionInfo> remotes = base.RequestNamedRegions(name, maxNumber);
|
|
||||||
infos.AddRange(remotes);
|
|
||||||
return infos;
|
|
||||||
}
|
|
||||||
|
|
||||||
#endregion
|
|
||||||
|
|
||||||
#region XML Request Handlers
|
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// A ping / version check
|
|
||||||
/// </summary>
|
|
||||||
/// <param name="request"></param>
|
|
||||||
/// <returns></returns>
|
|
||||||
public virtual XmlRpcResponse PingCheckReply(XmlRpcRequest request, IPEndPoint remoteClient)
|
|
||||||
{
|
|
||||||
XmlRpcResponse response = new XmlRpcResponse();
|
|
||||||
|
|
||||||
Hashtable respData = new Hashtable();
|
|
||||||
respData["online"] = "true";
|
|
||||||
|
|
||||||
m_localBackend.PingCheckReply(respData);
|
|
||||||
|
|
||||||
response.Value = respData;
|
|
||||||
|
|
||||||
return response;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
// Grid Request Processing
|
|
||||||
/// <summary>
|
|
||||||
/// Ooops, our Agent must be dead if we're getting this request!
|
|
||||||
/// </summary>
|
|
||||||
/// <param name="request"></param>
|
|
||||||
/// <returns></returns>
|
|
||||||
public XmlRpcResponse LogOffUser(XmlRpcRequest request, IPEndPoint remoteClient)
|
|
||||||
{
|
|
||||||
m_log.Debug("[HGrid]: LogOff User Called");
|
|
||||||
|
|
||||||
Hashtable requestData = (Hashtable)request.Params[0];
|
|
||||||
string message = (string)requestData["message"];
|
|
||||||
UUID agentID = UUID.Zero;
|
|
||||||
UUID RegionSecret = UUID.Zero;
|
|
||||||
UUID.TryParse((string)requestData["agent_id"], out agentID);
|
|
||||||
UUID.TryParse((string)requestData["region_secret"], out RegionSecret);
|
|
||||||
|
|
||||||
ulong regionHandle = Convert.ToUInt64((string)requestData["regionhandle"]);
|
|
||||||
|
|
||||||
m_localBackend.TriggerLogOffUser(regionHandle, agentID, RegionSecret, message);
|
|
||||||
|
|
||||||
return new XmlRpcResponse();
|
|
||||||
}
|
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// Someone asked us about parcel-information
|
|
||||||
/// </summary>
|
|
||||||
/// <param name="request"></param>
|
|
||||||
/// <returns></returns>
|
|
||||||
public XmlRpcResponse LandData(XmlRpcRequest request, IPEndPoint remoteClient)
|
|
||||||
{
|
|
||||||
Hashtable requestData = (Hashtable)request.Params[0];
|
|
||||||
ulong regionHandle = Convert.ToUInt64(requestData["region_handle"]);
|
|
||||||
uint x = Convert.ToUInt32(requestData["x"]);
|
|
||||||
uint y = Convert.ToUInt32(requestData["y"]);
|
|
||||||
m_log.DebugFormat("[HGrid]: Got XML reqeuest for land data at {0}, {1} in region {2}", x, y, regionHandle);
|
|
||||||
|
|
||||||
LandData landData = m_localBackend.RequestLandData(regionHandle, x, y);
|
|
||||||
Hashtable hash = new Hashtable();
|
|
||||||
if (landData != null)
|
|
||||||
{
|
|
||||||
// for now, only push out the data we need for answering a ParcelInfoReqeust
|
|
||||||
hash["AABBMax"] = landData.AABBMax.ToString();
|
|
||||||
hash["AABBMin"] = landData.AABBMin.ToString();
|
|
||||||
hash["Area"] = landData.Area.ToString();
|
|
||||||
hash["AuctionID"] = landData.AuctionID.ToString();
|
|
||||||
hash["Description"] = landData.Description;
|
|
||||||
hash["Flags"] = landData.Flags.ToString();
|
|
||||||
hash["GlobalID"] = landData.GlobalID.ToString();
|
|
||||||
hash["Name"] = landData.Name;
|
|
||||||
hash["OwnerID"] = landData.OwnerID.ToString();
|
|
||||||
hash["SalePrice"] = landData.SalePrice.ToString();
|
|
||||||
hash["SnapshotID"] = landData.SnapshotID.ToString();
|
|
||||||
hash["UserLocation"] = landData.UserLocation.ToString();
|
|
||||||
}
|
|
||||||
|
|
||||||
XmlRpcResponse response = new XmlRpcResponse();
|
|
||||||
response.Value = hash;
|
|
||||||
return response;
|
|
||||||
}
|
|
||||||
|
|
||||||
#endregion
|
|
||||||
|
|
||||||
}
|
|
||||||
}
|
|
Loading…
Reference in New Issue