normalized line endings
							parent
							
								
									e50a2e2ce2
								
							
						
					
					
						commit
						2d1c255e8c
					
				|  | @ -1,41 +1,41 @@ | |||
| /* | ||||
| * 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 OpenSim 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.Text; | ||||
| using OpenSim.Framework; | ||||
| using Nini.Config; | ||||
| namespace OpenSim.Framework | ||||
| { | ||||
|     public interface IRegionLoader | ||||
|     { | ||||
|         void SetIniConfigSource(IniConfigSource configSource); | ||||
|         RegionInfo[] LoadRegions(); | ||||
|     } | ||||
| } | ||||
| /* | ||||
| * 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 OpenSim 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.Text; | ||||
| using OpenSim.Framework; | ||||
| using Nini.Config; | ||||
| namespace OpenSim.Framework | ||||
| { | ||||
|     public interface IRegionLoader | ||||
|     { | ||||
|         void SetIniConfigSource(IniConfigSource configSource); | ||||
|         RegionInfo[] LoadRegions(); | ||||
|     } | ||||
| } | ||||
|  |  | |||
|  | @ -1,72 +1,72 @@ | |||
| /* | ||||
| * 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 OpenSim 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.Text; | ||||
| using Nini.Config; | ||||
| using OpenSim.Framework; | ||||
| using System.IO; | ||||
| 
 | ||||
| namespace OpenSim.Framework.RegionLoader.Filesystem | ||||
| { | ||||
|     public class RegionLoaderFileSystem : IRegionLoader | ||||
|     { | ||||
|         public void SetIniConfigSource(IniConfigSource configSource) | ||||
|         { | ||||
|         } | ||||
|         public RegionInfo[] LoadRegions() | ||||
|         { | ||||
|             string regionConfigPath = Path.Combine(Util.configDir(), "Regions"); | ||||
| 
 | ||||
|             if (!Directory.Exists(regionConfigPath)) | ||||
|             { | ||||
|                 Directory.CreateDirectory(regionConfigPath); | ||||
|             } | ||||
| 
 | ||||
|             string[] configFiles = Directory.GetFiles(regionConfigPath, "*.xml"); | ||||
| 
 | ||||
|             if (configFiles.Length == 0) | ||||
|             { | ||||
|                 new RegionInfo("DEFAULT REGION CONFIG", Path.Combine(regionConfigPath, "default.xml")); | ||||
|                 configFiles = Directory.GetFiles(regionConfigPath, "*.xml"); | ||||
|             } | ||||
| 
 | ||||
|             RegionInfo[] regionInfos = new RegionInfo[configFiles.Length]; | ||||
|             for (int i = 0; i < configFiles.Length; i++) | ||||
|             { | ||||
| 
 | ||||
|                 RegionInfo regionInfo = new RegionInfo("REGION CONFIG #" + (i + 1), configFiles[i]); | ||||
|                 regionInfos[i] = regionInfo; | ||||
|             } | ||||
| 
 | ||||
| 
 | ||||
|             return regionInfos; | ||||
|         } | ||||
| 
 | ||||
|     } | ||||
| } | ||||
| /* | ||||
| * 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 OpenSim 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.Text; | ||||
| using Nini.Config; | ||||
| using OpenSim.Framework; | ||||
| using System.IO; | ||||
| 
 | ||||
| namespace OpenSim.Framework.RegionLoader.Filesystem | ||||
| { | ||||
|     public class RegionLoaderFileSystem : IRegionLoader | ||||
|     { | ||||
|         public void SetIniConfigSource(IniConfigSource configSource) | ||||
|         { | ||||
|         } | ||||
|         public RegionInfo[] LoadRegions() | ||||
|         { | ||||
|             string regionConfigPath = Path.Combine(Util.configDir(), "Regions"); | ||||
| 
 | ||||
|             if (!Directory.Exists(regionConfigPath)) | ||||
|             { | ||||
|                 Directory.CreateDirectory(regionConfigPath); | ||||
|             } | ||||
| 
 | ||||
|             string[] configFiles = Directory.GetFiles(regionConfigPath, "*.xml"); | ||||
| 
 | ||||
|             if (configFiles.Length == 0) | ||||
|             { | ||||
|                 new RegionInfo("DEFAULT REGION CONFIG", Path.Combine(regionConfigPath, "default.xml")); | ||||
|                 configFiles = Directory.GetFiles(regionConfigPath, "*.xml"); | ||||
|             } | ||||
| 
 | ||||
|             RegionInfo[] regionInfos = new RegionInfo[configFiles.Length]; | ||||
|             for (int i = 0; i < configFiles.Length; i++) | ||||
|             { | ||||
| 
 | ||||
|                 RegionInfo regionInfo = new RegionInfo("REGION CONFIG #" + (i + 1), configFiles[i]); | ||||
|                 regionInfos[i] = regionInfo; | ||||
|             } | ||||
| 
 | ||||
| 
 | ||||
|             return regionInfos; | ||||
|         } | ||||
| 
 | ||||
|     } | ||||
| } | ||||
|  |  | |||
|  | @ -1,98 +1,98 @@ | |||
| /* | ||||
| * 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 OpenSim 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.Net; | ||||
| using System.IO; | ||||
| using System.Xml; | ||||
| using System.Collections.Generic; | ||||
| using System.Text; | ||||
| using Nini.Config; | ||||
| using OpenSim.Framework; | ||||
| 
 | ||||
| namespace OpenSim.Framework.RegionLoader.Web | ||||
| { | ||||
|     public class RegionLoaderWebServer : IRegionLoader | ||||
|     { | ||||
|         private IniConfigSource m_configSouce; | ||||
|         public void SetIniConfigSource(IniConfigSource configSource) | ||||
|         { | ||||
|             m_configSouce = configSource; | ||||
|         } | ||||
|         public RegionInfo[] LoadRegions() | ||||
|         { | ||||
|             if (m_configSouce == null) | ||||
|             { | ||||
|                 Console.MainLog.Instance.Error("Unable to load configuration source! (WebServer Region Loader)"); | ||||
|                 return null; | ||||
|             } | ||||
|             else | ||||
|             { | ||||
|                 IniConfig startupConfig = (IniConfig)m_configSouce.Configs["Startup"]; | ||||
|                 string url = startupConfig.GetString("regionload_webserver_url","").Trim(); | ||||
|                 if (url == "") | ||||
|                 { | ||||
|                     Console.MainLog.Instance.Error("Unable to load webserver URL - URL was empty (WebServer Region Loader"); | ||||
|                     return null; | ||||
|                 } | ||||
|                 else | ||||
|                 { | ||||
|                      | ||||
|                     HttpWebRequest webRequest = (HttpWebRequest)WebRequest.Create(url); | ||||
|                     webRequest.Timeout = 30000; //30 Second Timeout | ||||
|                     Console.MainLog.Instance.Debug("Sending Download Request..."); | ||||
|                     HttpWebResponse webResponse = (HttpWebResponse)webRequest.GetResponse(); | ||||
|                     Console.MainLog.Instance.Debug("Downloading Region Information From Remote Server..."); | ||||
|                     StreamReader reader = new StreamReader(webResponse.GetResponseStream()); | ||||
|                     string xmlSource = ""; | ||||
|                     string tempStr = reader.ReadLine(); | ||||
|                     while (tempStr != null) | ||||
|                     { | ||||
|                         xmlSource = xmlSource + tempStr; | ||||
|                         tempStr = reader.ReadLine(); | ||||
|                     } | ||||
|                     Console.MainLog.Instance.Debug("Done downloading region information from server. Total Bytes: " + xmlSource.Length); | ||||
|                     XmlDocument xmlDoc = new XmlDocument(); | ||||
|                     xmlDoc.LoadXml(xmlSource); | ||||
|                     if (xmlDoc.FirstChild.Name == "Regions") | ||||
|                     { | ||||
|                         RegionInfo[] regionInfos = new RegionInfo[xmlDoc.FirstChild.ChildNodes.Count]; | ||||
|                         int i; | ||||
|                         for (i = 0; i < xmlDoc.FirstChild.ChildNodes.Count; i++) | ||||
|                         { | ||||
|                             Console.MainLog.Instance.Debug(xmlDoc.FirstChild.ChildNodes[i].OuterXml); | ||||
|                             regionInfos[i] = new RegionInfo("REGION CONFIG #" + (i + 1), xmlDoc.FirstChild.ChildNodes[i]); | ||||
|                         } | ||||
| 
 | ||||
|                         return regionInfos; | ||||
|                     } | ||||
|                     return null; | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
|     } | ||||
| } | ||||
| /* | ||||
| * 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 OpenSim 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.Net; | ||||
| using System.IO; | ||||
| using System.Xml; | ||||
| using System.Collections.Generic; | ||||
| using System.Text; | ||||
| using Nini.Config; | ||||
| using OpenSim.Framework; | ||||
| 
 | ||||
| namespace OpenSim.Framework.RegionLoader.Web | ||||
| { | ||||
|     public class RegionLoaderWebServer : IRegionLoader | ||||
|     { | ||||
|         private IniConfigSource m_configSouce; | ||||
|         public void SetIniConfigSource(IniConfigSource configSource) | ||||
|         { | ||||
|             m_configSouce = configSource; | ||||
|         } | ||||
|         public RegionInfo[] LoadRegions() | ||||
|         { | ||||
|             if (m_configSouce == null) | ||||
|             { | ||||
|                 Console.MainLog.Instance.Error("Unable to load configuration source! (WebServer Region Loader)"); | ||||
|                 return null; | ||||
|             } | ||||
|             else | ||||
|             { | ||||
|                 IniConfig startupConfig = (IniConfig)m_configSouce.Configs["Startup"]; | ||||
|                 string url = startupConfig.GetString("regionload_webserver_url","").Trim(); | ||||
|                 if (url == "") | ||||
|                 { | ||||
|                     Console.MainLog.Instance.Error("Unable to load webserver URL - URL was empty (WebServer Region Loader"); | ||||
|                     return null; | ||||
|                 } | ||||
|                 else | ||||
|                 { | ||||
|                      | ||||
|                     HttpWebRequest webRequest = (HttpWebRequest)WebRequest.Create(url); | ||||
|                     webRequest.Timeout = 30000; //30 Second Timeout | ||||
|                     Console.MainLog.Instance.Debug("Sending Download Request..."); | ||||
|                     HttpWebResponse webResponse = (HttpWebResponse)webRequest.GetResponse(); | ||||
|                     Console.MainLog.Instance.Debug("Downloading Region Information From Remote Server..."); | ||||
|                     StreamReader reader = new StreamReader(webResponse.GetResponseStream()); | ||||
|                     string xmlSource = ""; | ||||
|                     string tempStr = reader.ReadLine(); | ||||
|                     while (tempStr != null) | ||||
|                     { | ||||
|                         xmlSource = xmlSource + tempStr; | ||||
|                         tempStr = reader.ReadLine(); | ||||
|                     } | ||||
|                     Console.MainLog.Instance.Debug("Done downloading region information from server. Total Bytes: " + xmlSource.Length); | ||||
|                     XmlDocument xmlDoc = new XmlDocument(); | ||||
|                     xmlDoc.LoadXml(xmlSource); | ||||
|                     if (xmlDoc.FirstChild.Name == "Regions") | ||||
|                     { | ||||
|                         RegionInfo[] regionInfos = new RegionInfo[xmlDoc.FirstChild.ChildNodes.Count]; | ||||
|                         int i; | ||||
|                         for (i = 0; i < xmlDoc.FirstChild.ChildNodes.Count; i++) | ||||
|                         { | ||||
|                             Console.MainLog.Instance.Debug(xmlDoc.FirstChild.ChildNodes[i].OuterXml); | ||||
|                             regionInfos[i] = new RegionInfo("REGION CONFIG #" + (i + 1), xmlDoc.FirstChild.ChildNodes[i]); | ||||
|                         } | ||||
| 
 | ||||
|                         return regionInfos; | ||||
|                     } | ||||
|                     return null; | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
|     } | ||||
| } | ||||
|  |  | |||
|  | @ -1,35 +1,35 @@ | |||
| namespace OpenSim.Framework.Servers | ||||
| { | ||||
|     public class BaseRequestHandler | ||||
|     { | ||||
|         public virtual string ContentType | ||||
|         { | ||||
|             get { return "application/xml"; } | ||||
|         } | ||||
| 
 | ||||
|         private readonly string m_httpMethod; | ||||
| 
 | ||||
|         public virtual string HttpMethod | ||||
|         { | ||||
|             get { return m_httpMethod; } | ||||
|         } | ||||
| 
 | ||||
|         private readonly string m_path; | ||||
| 
 | ||||
|         protected BaseRequestHandler(string httpMethod, string path) | ||||
|         { | ||||
|             m_httpMethod = httpMethod; | ||||
|             m_path = path; | ||||
|         } | ||||
| 
 | ||||
|         public virtual string Path | ||||
|         { | ||||
|             get { return m_path; } | ||||
|         } | ||||
| 
 | ||||
|         protected string GetParam(string path) | ||||
|         { | ||||
|             return path.Substring(m_path.Length); | ||||
|         } | ||||
|     } | ||||
| namespace OpenSim.Framework.Servers | ||||
| { | ||||
|     public class BaseRequestHandler | ||||
|     { | ||||
|         public virtual string ContentType | ||||
|         { | ||||
|             get { return "application/xml"; } | ||||
|         } | ||||
| 
 | ||||
|         private readonly string m_httpMethod; | ||||
| 
 | ||||
|         public virtual string HttpMethod | ||||
|         { | ||||
|             get { return m_httpMethod; } | ||||
|         } | ||||
| 
 | ||||
|         private readonly string m_path; | ||||
| 
 | ||||
|         protected BaseRequestHandler(string httpMethod, string path) | ||||
|         { | ||||
|             m_httpMethod = httpMethod; | ||||
|             m_path = path; | ||||
|         } | ||||
| 
 | ||||
|         public virtual string Path | ||||
|         { | ||||
|             get { return m_path; } | ||||
|         } | ||||
| 
 | ||||
|         protected string GetParam(string path) | ||||
|         { | ||||
|             return path.Substring(m_path.Length); | ||||
|         } | ||||
|     } | ||||
| } | ||||
|  | @ -1,38 +1,38 @@ | |||
| using System.IO; | ||||
| using System.Xml; | ||||
| using System.Xml.Serialization; | ||||
| 
 | ||||
| namespace OpenSim.Framework.Servers | ||||
| { | ||||
|     public delegate TResponse RestDeserialiseMethod<TRequest, TResponse>(TRequest request); | ||||
| 
 | ||||
|     public class RestDeserialisehandler<TRequest, TResponse> : BaseRequestHandler, IStreamHandler | ||||
|         where TRequest : new() | ||||
|     { | ||||
|         private RestDeserialiseMethod<TRequest, TResponse> m_method; | ||||
| 
 | ||||
|         public RestDeserialisehandler(string httpMethod, string path, RestDeserialiseMethod<TRequest, TResponse> method) | ||||
|             : base(httpMethod, path) | ||||
|         { | ||||
|             m_method = method; | ||||
|         } | ||||
| 
 | ||||
|         public void Handle(string path, Stream request, Stream responseStream) | ||||
|         { | ||||
|             TRequest deserial; | ||||
|             using (XmlTextReader xmlReader = new XmlTextReader(request)) | ||||
|             { | ||||
|                 XmlSerializer deserializer = new XmlSerializer(typeof (TRequest)); | ||||
|                 deserial = (TRequest) deserializer.Deserialize(xmlReader); | ||||
|             } | ||||
| 
 | ||||
|             TResponse response = m_method(deserial); | ||||
| 
 | ||||
|             using (XmlWriter xmlWriter = XmlTextWriter.Create(responseStream)) | ||||
|             { | ||||
|                 XmlSerializer serializer = new XmlSerializer(typeof (TResponse)); | ||||
|                 serializer.Serialize(xmlWriter, response); | ||||
|             } | ||||
|         } | ||||
|     } | ||||
| using System.IO; | ||||
| using System.Xml; | ||||
| using System.Xml.Serialization; | ||||
| 
 | ||||
| namespace OpenSim.Framework.Servers | ||||
| { | ||||
|     public delegate TResponse RestDeserialiseMethod<TRequest, TResponse>(TRequest request); | ||||
| 
 | ||||
|     public class RestDeserialisehandler<TRequest, TResponse> : BaseRequestHandler, IStreamHandler | ||||
|         where TRequest : new() | ||||
|     { | ||||
|         private RestDeserialiseMethod<TRequest, TResponse> m_method; | ||||
| 
 | ||||
|         public RestDeserialisehandler(string httpMethod, string path, RestDeserialiseMethod<TRequest, TResponse> method) | ||||
|             : base(httpMethod, path) | ||||
|         { | ||||
|             m_method = method; | ||||
|         } | ||||
| 
 | ||||
|         public void Handle(string path, Stream request, Stream responseStream) | ||||
|         { | ||||
|             TRequest deserial; | ||||
|             using (XmlTextReader xmlReader = new XmlTextReader(request)) | ||||
|             { | ||||
|                 XmlSerializer deserializer = new XmlSerializer(typeof (TRequest)); | ||||
|                 deserial = (TRequest) deserializer.Deserialize(xmlReader); | ||||
|             } | ||||
| 
 | ||||
|             TResponse response = m_method(deserial); | ||||
| 
 | ||||
|             using (XmlWriter xmlWriter = XmlTextWriter.Create(responseStream)) | ||||
|             { | ||||
|                 XmlSerializer serializer = new XmlSerializer(typeof (TResponse)); | ||||
|                 serializer.Serialize(xmlWriter, response); | ||||
|             } | ||||
|         } | ||||
|     } | ||||
| } | ||||
|  | @ -1,49 +1,49 @@ | |||
| using System; | ||||
| using System.IO; | ||||
| using System.Net; | ||||
| using System.Text; | ||||
| using System.Xml; | ||||
| using System.Xml.Serialization; | ||||
| 
 | ||||
| 
 | ||||
| namespace OpenSim.Framework.Servers | ||||
| { | ||||
|     public class RestObjectPoster | ||||
|     { | ||||
|         public static void BeginPostObject<TRequest>(string requestUrl, TRequest obj) | ||||
|         { | ||||
|             Type type = typeof(TRequest); | ||||
| 
 | ||||
|             WebRequest request = WebRequest.Create(requestUrl); | ||||
|             request.Method = "POST"; | ||||
|             request.ContentType = "text/xml"; | ||||
| 
 | ||||
|             MemoryStream buffer = new MemoryStream(); | ||||
| 
 | ||||
|             XmlWriterSettings settings = new XmlWriterSettings(); | ||||
|             settings.Encoding = Encoding.UTF8; | ||||
| 
 | ||||
|             using (XmlWriter writer = XmlWriter.Create(buffer, settings)) | ||||
|             { | ||||
|                 XmlSerializer serializer = new XmlSerializer(type); | ||||
|                 serializer.Serialize(writer, obj); | ||||
|                 writer.Flush(); | ||||
|             } | ||||
| 
 | ||||
|             int length = (int)buffer.Length; | ||||
|             request.ContentLength = length; | ||||
| 
 | ||||
|             Stream requestStream = request.GetRequestStream(); | ||||
|             requestStream.Write(buffer.ToArray(), 0, length); | ||||
|             IAsyncResult result = request.BeginGetResponse(AsyncCallback, request); | ||||
|         } | ||||
| 
 | ||||
|         private static void AsyncCallback(IAsyncResult result) | ||||
|         { | ||||
|             WebRequest request = (WebRequest)result.AsyncState; | ||||
|             using (WebResponse resp = request.EndGetResponse(result)) | ||||
|             { | ||||
|             } | ||||
|         } | ||||
|     } | ||||
| using System; | ||||
| using System.IO; | ||||
| using System.Net; | ||||
| using System.Text; | ||||
| using System.Xml; | ||||
| using System.Xml.Serialization; | ||||
| 
 | ||||
| 
 | ||||
| namespace OpenSim.Framework.Servers | ||||
| { | ||||
|     public class RestObjectPoster | ||||
|     { | ||||
|         public static void BeginPostObject<TRequest>(string requestUrl, TRequest obj) | ||||
|         { | ||||
|             Type type = typeof(TRequest); | ||||
| 
 | ||||
|             WebRequest request = WebRequest.Create(requestUrl); | ||||
|             request.Method = "POST"; | ||||
|             request.ContentType = "text/xml"; | ||||
| 
 | ||||
|             MemoryStream buffer = new MemoryStream(); | ||||
| 
 | ||||
|             XmlWriterSettings settings = new XmlWriterSettings(); | ||||
|             settings.Encoding = Encoding.UTF8; | ||||
| 
 | ||||
|             using (XmlWriter writer = XmlWriter.Create(buffer, settings)) | ||||
|             { | ||||
|                 XmlSerializer serializer = new XmlSerializer(type); | ||||
|                 serializer.Serialize(writer, obj); | ||||
|                 writer.Flush(); | ||||
|             } | ||||
| 
 | ||||
|             int length = (int)buffer.Length; | ||||
|             request.ContentLength = length; | ||||
| 
 | ||||
|             Stream requestStream = request.GetRequestStream(); | ||||
|             requestStream.Write(buffer.ToArray(), 0, length); | ||||
|             IAsyncResult result = request.BeginGetResponse(AsyncCallback, request); | ||||
|         } | ||||
| 
 | ||||
|         private static void AsyncCallback(IAsyncResult result) | ||||
|         { | ||||
|             WebRequest request = (WebRequest)result.AsyncState; | ||||
|             using (WebResponse resp = request.EndGetResponse(result)) | ||||
|             { | ||||
|             } | ||||
|         } | ||||
|     } | ||||
| } | ||||
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							|  | @ -1,212 +1,212 @@ | |||
| using System; | ||||
| using System.Collections.Generic; | ||||
| using System.Net; | ||||
| using System.Text; | ||||
| using libsecondlife; | ||||
| using OpenSim.Framework; | ||||
| using OpenSim.Framework.Console; | ||||
| using OpenSim.Framework.Communications; | ||||
| 
 | ||||
| 
 | ||||
| namespace OpenSim.Region.Environment.Scenes | ||||
| { | ||||
|     public class SceneCommunicationService //one instance per region | ||||
|     { | ||||
|         protected CommunicationsManager m_commsProvider; | ||||
|         protected RegionInfo m_regionInfo; | ||||
| 
 | ||||
|         protected RegionCommsListener regionCommsHost; | ||||
| 
 | ||||
|         public event AgentCrossing OnAvatarCrossingIntoRegion; | ||||
|         public event ExpectUserDelegate OnExpectUser; | ||||
| 
 | ||||
| 
 | ||||
|         public SceneCommunicationService(CommunicationsManager commsMan) | ||||
|         { | ||||
|             m_commsProvider = commsMan; | ||||
|         } | ||||
| 
 | ||||
|         public void RegisterRegion(RegionInfo regionInfos) | ||||
|         { | ||||
|             m_regionInfo = regionInfos; | ||||
|             regionCommsHost = m_commsProvider.GridService.RegisterRegion(m_regionInfo); | ||||
|             if (regionCommsHost != null) | ||||
|             { | ||||
|                 regionCommsHost.OnExpectUser += NewUserConnection; | ||||
|                 regionCommsHost.OnAvatarCrossingIntoRegion += AgentCrossing; | ||||
|             } | ||||
|         } | ||||
| 
 | ||||
|         public void Close() | ||||
|         { | ||||
|             regionCommsHost.OnExpectUser -= NewUserConnection; | ||||
|             regionCommsHost.OnAvatarCrossingIntoRegion -= AgentCrossing; | ||||
|             //regionCommsHost.RemoveRegion(m_regionInfo); //TODO add to method to commsManager | ||||
|             regionCommsHost = null; | ||||
|         } | ||||
| 
 | ||||
|         #region CommsManager Event handlers | ||||
|         /// <summary> | ||||
|         ///  | ||||
|         /// </summary> | ||||
|         /// <param name="regionHandle"></param> | ||||
|         /// <param name="agent"></param> | ||||
|         public void NewUserConnection(ulong regionHandle, AgentCircuitData agent) | ||||
|         { | ||||
|             if (OnExpectUser != null) | ||||
|             { | ||||
|                 OnExpectUser(regionHandle, agent); | ||||
|             } | ||||
|         } | ||||
| 
 | ||||
|         public void AgentCrossing(ulong regionHandle, LLUUID agentID, LLVector3 position, bool isFlying) | ||||
|         { | ||||
|             if (OnAvatarCrossingIntoRegion != null) | ||||
|             { | ||||
|                 OnAvatarCrossingIntoRegion(regionHandle, agentID, position, isFlying); | ||||
|             } | ||||
|         } | ||||
|         #endregion | ||||
| 
 | ||||
|         #region Inform Client of Neighbours | ||||
|         private delegate void InformClientOfNeighbourDelegate( | ||||
|             ScenePresence avatar, AgentCircuitData a, ulong regionHandle, IPEndPoint endPoint); | ||||
| 
 | ||||
|         private void InformClientOfNeighbourCompleted(IAsyncResult iar) | ||||
|         { | ||||
|             InformClientOfNeighbourDelegate icon = (InformClientOfNeighbourDelegate)iar.AsyncState; | ||||
|             icon.EndInvoke(iar); | ||||
|         } | ||||
| 
 | ||||
|         /// <summary> | ||||
|         /// Async compnent for informing client of which neighbours exists | ||||
|         /// </summary> | ||||
|         /// <remarks> | ||||
|         /// This needs to run asynchronesously, as a network timeout may block the thread for a long while | ||||
|         /// </remarks> | ||||
|         /// <param name="remoteClient"></param> | ||||
|         /// <param name="a"></param> | ||||
|         /// <param name="regionHandle"></param> | ||||
|         /// <param name="endPoint"></param> | ||||
|         private void InformClientOfNeighbourAsync(ScenePresence avatar, AgentCircuitData a, ulong regionHandle, | ||||
|                                                   IPEndPoint endPoint) | ||||
|         { | ||||
|             MainLog.Instance.Notice("INTERGRID", "Starting to inform client about neighbours"); | ||||
|             bool regionAccepted = m_commsProvider.InterRegion.InformRegionOfChildAgent(regionHandle, a); | ||||
| 
 | ||||
|             if (regionAccepted) | ||||
|             { | ||||
|                 avatar.ControllingClient.InformClientOfNeighbour(regionHandle, endPoint); | ||||
|                 avatar.AddNeighbourRegion(regionHandle); | ||||
|                 MainLog.Instance.Notice("INTERGRID", "Completed inform client about neighbours"); | ||||
|             } | ||||
|         } | ||||
| 
 | ||||
|         /// <summary> | ||||
|         ///  | ||||
|         /// </summary> | ||||
|         public void InformClientOfNeighbours(ScenePresence avatar) | ||||
|         { | ||||
|             List<SimpleRegionInfo> neighbours = | ||||
|                 m_commsProvider.GridService.RequestNeighbours(m_regionInfo.RegionLocX, m_regionInfo.RegionLocY); | ||||
|             if (neighbours != null) | ||||
|             { | ||||
|                 for (int i = 0; i < neighbours.Count; i++) | ||||
|                 { | ||||
|                     AgentCircuitData agent = avatar.ControllingClient.RequestClientInfo(); | ||||
|                     agent.BaseFolder = LLUUID.Zero; | ||||
|                     agent.InventoryFolder = LLUUID.Zero; | ||||
|                     agent.startpos = new LLVector3(128, 128, 70); | ||||
|                     agent.child = true; | ||||
| 
 | ||||
|                     InformClientOfNeighbourDelegate d = InformClientOfNeighbourAsync; | ||||
|                     d.BeginInvoke(avatar, agent, neighbours[i].RegionHandle, neighbours[i].ExternalEndPoint, | ||||
|                                   InformClientOfNeighbourCompleted, | ||||
|                                   d); | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
|         #endregion | ||||
| 
 | ||||
|         /// <summary> | ||||
|         ///  | ||||
|         /// </summary> | ||||
|         /// <param name="regionHandle"></param> | ||||
|         /// <returns></returns> | ||||
|         public virtual RegionInfo RequestNeighbouringRegionInfo(ulong regionHandle) | ||||
|         { | ||||
|             return m_commsProvider.GridService.RequestNeighbourInfo(regionHandle); | ||||
|         } | ||||
| 
 | ||||
|         /// <summary> | ||||
|         ///  | ||||
|         /// </summary> | ||||
|         /// <param name="minX"></param> | ||||
|         /// <param name="minY"></param> | ||||
|         /// <param name="maxX"></param> | ||||
|         /// <param name="maxY"></param> | ||||
|         public virtual void RequestMapBlocks(IClientAPI remoteClient, int minX, int minY, int maxX, int maxY) | ||||
|         { | ||||
|             List<MapBlockData> mapBlocks; | ||||
|             mapBlocks = m_commsProvider.GridService.RequestNeighbourMapBlocks(minX, minY, maxX, maxY); | ||||
|             remoteClient.SendMapBlock(mapBlocks); | ||||
|         } | ||||
| 
 | ||||
|         /// <summary> | ||||
|         ///  | ||||
|         /// </summary> | ||||
|         /// <param name="remoteClient"></param> | ||||
|         /// <param name="RegionHandle"></param> | ||||
|         /// <param name="position"></param> | ||||
|         /// <param name="lookAt"></param> | ||||
|         /// <param name="flags"></param> | ||||
|         public virtual void RequestTeleportLocation(ScenePresence avatar, ulong regionHandle, LLVector3 position, | ||||
|                                             LLVector3 lookAt, uint flags) | ||||
|         { | ||||
|             if (regionHandle == m_regionInfo.RegionHandle) | ||||
|             { | ||||
| 
 | ||||
|                 avatar.ControllingClient.SendTeleportLocationStart(); | ||||
|                 avatar.ControllingClient.SendLocalTeleport(position, lookAt, flags); | ||||
|                 avatar.Teleport(position); | ||||
| 
 | ||||
|             } | ||||
|             else | ||||
|             { | ||||
|                 RegionInfo reg = RequestNeighbouringRegionInfo(regionHandle); | ||||
|                 if (reg != null) | ||||
|                 { | ||||
|                     avatar.ControllingClient.SendTeleportLocationStart(); | ||||
|                     AgentCircuitData agent = avatar.ControllingClient.RequestClientInfo(); | ||||
|                     agent.BaseFolder = LLUUID.Zero; | ||||
|                     agent.InventoryFolder = LLUUID.Zero; | ||||
|                     agent.startpos = position; | ||||
|                     agent.child = true; | ||||
|                     avatar.Close(); | ||||
|                     m_commsProvider.InterRegion.InformRegionOfChildAgent(regionHandle, agent); | ||||
|                     m_commsProvider.InterRegion.ExpectAvatarCrossing(regionHandle, avatar.ControllingClient.AgentId, position, false); | ||||
|                     AgentCircuitData circuitdata = avatar.ControllingClient.RequestClientInfo(); | ||||
|                     string capsPath = Util.GetCapsURL(avatar.ControllingClient.AgentId); | ||||
|                     avatar.ControllingClient.SendRegionTeleport(regionHandle, 13, reg.ExternalEndPoint, 4, (1 << 4), capsPath); | ||||
|                     avatar.MakeChildAgent(); | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
| 
 | ||||
|         /// <summary> | ||||
|         ///  | ||||
|         /// </summary> | ||||
|         /// <param name="regionhandle"></param> | ||||
|         /// <param name="agentID"></param> | ||||
|         /// <param name="position"></param> | ||||
|         public bool InformNeighbourOfCrossing(ulong regionhandle, LLUUID agentID, LLVector3 position, bool isFlying) | ||||
|         { | ||||
|             return m_commsProvider.InterRegion.ExpectAvatarCrossing(regionhandle, agentID, position, isFlying); | ||||
|         } | ||||
| 
 | ||||
|         public void CloseAgentConnection(ScenePresence presence) | ||||
|         { | ||||
|             throw new Exception("The method or operation is not implemented."); | ||||
|         } | ||||
|     } | ||||
| } | ||||
| using System; | ||||
| using System.Collections.Generic; | ||||
| using System.Net; | ||||
| using System.Text; | ||||
| using libsecondlife; | ||||
| using OpenSim.Framework; | ||||
| using OpenSim.Framework.Console; | ||||
| using OpenSim.Framework.Communications; | ||||
| 
 | ||||
| 
 | ||||
| namespace OpenSim.Region.Environment.Scenes | ||||
| { | ||||
|     public class SceneCommunicationService //one instance per region | ||||
|     { | ||||
|         protected CommunicationsManager m_commsProvider; | ||||
|         protected RegionInfo m_regionInfo; | ||||
| 
 | ||||
|         protected RegionCommsListener regionCommsHost; | ||||
| 
 | ||||
|         public event AgentCrossing OnAvatarCrossingIntoRegion; | ||||
|         public event ExpectUserDelegate OnExpectUser; | ||||
| 
 | ||||
| 
 | ||||
|         public SceneCommunicationService(CommunicationsManager commsMan) | ||||
|         { | ||||
|             m_commsProvider = commsMan; | ||||
|         } | ||||
| 
 | ||||
|         public void RegisterRegion(RegionInfo regionInfos) | ||||
|         { | ||||
|             m_regionInfo = regionInfos; | ||||
|             regionCommsHost = m_commsProvider.GridService.RegisterRegion(m_regionInfo); | ||||
|             if (regionCommsHost != null) | ||||
|             { | ||||
|                 regionCommsHost.OnExpectUser += NewUserConnection; | ||||
|                 regionCommsHost.OnAvatarCrossingIntoRegion += AgentCrossing; | ||||
|             } | ||||
|         } | ||||
| 
 | ||||
|         public void Close() | ||||
|         { | ||||
|             regionCommsHost.OnExpectUser -= NewUserConnection; | ||||
|             regionCommsHost.OnAvatarCrossingIntoRegion -= AgentCrossing; | ||||
|             //regionCommsHost.RemoveRegion(m_regionInfo); //TODO add to method to commsManager | ||||
|             regionCommsHost = null; | ||||
|         } | ||||
| 
 | ||||
|         #region CommsManager Event handlers | ||||
|         /// <summary> | ||||
|         ///  | ||||
|         /// </summary> | ||||
|         /// <param name="regionHandle"></param> | ||||
|         /// <param name="agent"></param> | ||||
|         public void NewUserConnection(ulong regionHandle, AgentCircuitData agent) | ||||
|         { | ||||
|             if (OnExpectUser != null) | ||||
|             { | ||||
|                 OnExpectUser(regionHandle, agent); | ||||
|             } | ||||
|         } | ||||
| 
 | ||||
|         public void AgentCrossing(ulong regionHandle, LLUUID agentID, LLVector3 position, bool isFlying) | ||||
|         { | ||||
|             if (OnAvatarCrossingIntoRegion != null) | ||||
|             { | ||||
|                 OnAvatarCrossingIntoRegion(regionHandle, agentID, position, isFlying); | ||||
|             } | ||||
|         } | ||||
|         #endregion | ||||
| 
 | ||||
|         #region Inform Client of Neighbours | ||||
|         private delegate void InformClientOfNeighbourDelegate( | ||||
|             ScenePresence avatar, AgentCircuitData a, ulong regionHandle, IPEndPoint endPoint); | ||||
| 
 | ||||
|         private void InformClientOfNeighbourCompleted(IAsyncResult iar) | ||||
|         { | ||||
|             InformClientOfNeighbourDelegate icon = (InformClientOfNeighbourDelegate)iar.AsyncState; | ||||
|             icon.EndInvoke(iar); | ||||
|         } | ||||
| 
 | ||||
|         /// <summary> | ||||
|         /// Async compnent for informing client of which neighbours exists | ||||
|         /// </summary> | ||||
|         /// <remarks> | ||||
|         /// This needs to run asynchronesously, as a network timeout may block the thread for a long while | ||||
|         /// </remarks> | ||||
|         /// <param name="remoteClient"></param> | ||||
|         /// <param name="a"></param> | ||||
|         /// <param name="regionHandle"></param> | ||||
|         /// <param name="endPoint"></param> | ||||
|         private void InformClientOfNeighbourAsync(ScenePresence avatar, AgentCircuitData a, ulong regionHandle, | ||||
|                                                   IPEndPoint endPoint) | ||||
|         { | ||||
|             MainLog.Instance.Notice("INTERGRID", "Starting to inform client about neighbours"); | ||||
|             bool regionAccepted = m_commsProvider.InterRegion.InformRegionOfChildAgent(regionHandle, a); | ||||
| 
 | ||||
|             if (regionAccepted) | ||||
|             { | ||||
|                 avatar.ControllingClient.InformClientOfNeighbour(regionHandle, endPoint); | ||||
|                 avatar.AddNeighbourRegion(regionHandle); | ||||
|                 MainLog.Instance.Notice("INTERGRID", "Completed inform client about neighbours"); | ||||
|             } | ||||
|         } | ||||
| 
 | ||||
|         /// <summary> | ||||
|         ///  | ||||
|         /// </summary> | ||||
|         public void InformClientOfNeighbours(ScenePresence avatar) | ||||
|         { | ||||
|             List<SimpleRegionInfo> neighbours = | ||||
|                 m_commsProvider.GridService.RequestNeighbours(m_regionInfo.RegionLocX, m_regionInfo.RegionLocY); | ||||
|             if (neighbours != null) | ||||
|             { | ||||
|                 for (int i = 0; i < neighbours.Count; i++) | ||||
|                 { | ||||
|                     AgentCircuitData agent = avatar.ControllingClient.RequestClientInfo(); | ||||
|                     agent.BaseFolder = LLUUID.Zero; | ||||
|                     agent.InventoryFolder = LLUUID.Zero; | ||||
|                     agent.startpos = new LLVector3(128, 128, 70); | ||||
|                     agent.child = true; | ||||
| 
 | ||||
|                     InformClientOfNeighbourDelegate d = InformClientOfNeighbourAsync; | ||||
|                     d.BeginInvoke(avatar, agent, neighbours[i].RegionHandle, neighbours[i].ExternalEndPoint, | ||||
|                                   InformClientOfNeighbourCompleted, | ||||
|                                   d); | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
|         #endregion | ||||
| 
 | ||||
|         /// <summary> | ||||
|         ///  | ||||
|         /// </summary> | ||||
|         /// <param name="regionHandle"></param> | ||||
|         /// <returns></returns> | ||||
|         public virtual RegionInfo RequestNeighbouringRegionInfo(ulong regionHandle) | ||||
|         { | ||||
|             return m_commsProvider.GridService.RequestNeighbourInfo(regionHandle); | ||||
|         } | ||||
| 
 | ||||
|         /// <summary> | ||||
|         ///  | ||||
|         /// </summary> | ||||
|         /// <param name="minX"></param> | ||||
|         /// <param name="minY"></param> | ||||
|         /// <param name="maxX"></param> | ||||
|         /// <param name="maxY"></param> | ||||
|         public virtual void RequestMapBlocks(IClientAPI remoteClient, int minX, int minY, int maxX, int maxY) | ||||
|         { | ||||
|             List<MapBlockData> mapBlocks; | ||||
|             mapBlocks = m_commsProvider.GridService.RequestNeighbourMapBlocks(minX, minY, maxX, maxY); | ||||
|             remoteClient.SendMapBlock(mapBlocks); | ||||
|         } | ||||
| 
 | ||||
|         /// <summary> | ||||
|         ///  | ||||
|         /// </summary> | ||||
|         /// <param name="remoteClient"></param> | ||||
|         /// <param name="RegionHandle"></param> | ||||
|         /// <param name="position"></param> | ||||
|         /// <param name="lookAt"></param> | ||||
|         /// <param name="flags"></param> | ||||
|         public virtual void RequestTeleportLocation(ScenePresence avatar, ulong regionHandle, LLVector3 position, | ||||
|                                             LLVector3 lookAt, uint flags) | ||||
|         { | ||||
|             if (regionHandle == m_regionInfo.RegionHandle) | ||||
|             { | ||||
| 
 | ||||
|                 avatar.ControllingClient.SendTeleportLocationStart(); | ||||
|                 avatar.ControllingClient.SendLocalTeleport(position, lookAt, flags); | ||||
|                 avatar.Teleport(position); | ||||
| 
 | ||||
|             } | ||||
|             else | ||||
|             { | ||||
|                 RegionInfo reg = RequestNeighbouringRegionInfo(regionHandle); | ||||
|                 if (reg != null) | ||||
|                 { | ||||
|                     avatar.ControllingClient.SendTeleportLocationStart(); | ||||
|                     AgentCircuitData agent = avatar.ControllingClient.RequestClientInfo(); | ||||
|                     agent.BaseFolder = LLUUID.Zero; | ||||
|                     agent.InventoryFolder = LLUUID.Zero; | ||||
|                     agent.startpos = position; | ||||
|                     agent.child = true; | ||||
|                     avatar.Close(); | ||||
|                     m_commsProvider.InterRegion.InformRegionOfChildAgent(regionHandle, agent); | ||||
|                     m_commsProvider.InterRegion.ExpectAvatarCrossing(regionHandle, avatar.ControllingClient.AgentId, position, false); | ||||
|                     AgentCircuitData circuitdata = avatar.ControllingClient.RequestClientInfo(); | ||||
|                     string capsPath = Util.GetCapsURL(avatar.ControllingClient.AgentId); | ||||
|                     avatar.ControllingClient.SendRegionTeleport(regionHandle, 13, reg.ExternalEndPoint, 4, (1 << 4), capsPath); | ||||
|                     avatar.MakeChildAgent(); | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
| 
 | ||||
|         /// <summary> | ||||
|         ///  | ||||
|         /// </summary> | ||||
|         /// <param name="regionhandle"></param> | ||||
|         /// <param name="agentID"></param> | ||||
|         /// <param name="position"></param> | ||||
|         public bool InformNeighbourOfCrossing(ulong regionhandle, LLUUID agentID, LLVector3 position, bool isFlying) | ||||
|         { | ||||
|             return m_commsProvider.InterRegion.ExpectAvatarCrossing(regionhandle, agentID, position, isFlying); | ||||
|         } | ||||
| 
 | ||||
|         public void CloseAgentConnection(ScenePresence presence) | ||||
|         { | ||||
|             throw new Exception("The method or operation is not implemented."); | ||||
|         } | ||||
|     } | ||||
| } | ||||
|  |  | |||
		Loading…
	
		Reference in New Issue
	
	 Jeff Ames
						Jeff Ames