diff options
Diffstat (limited to 'OpenSim/Framework')
-rw-r--r-- | OpenSim/Framework/RegionInfo.cs | 181 | ||||
-rw-r--r-- | OpenSim/Framework/SerializableRegionInfo.cs | 202 |
2 files changed, 149 insertions, 234 deletions
diff --git a/OpenSim/Framework/RegionInfo.cs b/OpenSim/Framework/RegionInfo.cs index c39cc03..9e00528 100644 --- a/OpenSim/Framework/RegionInfo.cs +++ b/OpenSim/Framework/RegionInfo.cs | |||
@@ -320,7 +320,7 @@ namespace OpenSim.Framework | |||
320 | } | 320 | } |
321 | } | 321 | } |
322 | 322 | ||
323 | public class RegionInfo : SimpleRegionInfo | 323 | public class RegionInfo |
324 | { | 324 | { |
325 | // private static readonly log4net.ILog m_log | 325 | // private static readonly log4net.ILog m_log |
326 | // = log4net.LogManager.GetLogger(System.Reflection.MethodBase.GetCurrentMethod().DeclaringType); | 326 | // = log4net.LogManager.GetLogger(System.Reflection.MethodBase.GetCurrentMethod().DeclaringType); |
@@ -356,6 +356,21 @@ namespace OpenSim.Framework | |||
356 | private int m_objectCapacity = 0; | 356 | private int m_objectCapacity = 0; |
357 | private string m_regionType = String.Empty; | 357 | private string m_regionType = String.Empty; |
358 | private RegionMeta7WindlightData m_windlight = new RegionMeta7WindlightData(); | 358 | private RegionMeta7WindlightData m_windlight = new RegionMeta7WindlightData(); |
359 | protected uint m_httpPort; | ||
360 | protected string m_serverURI; | ||
361 | protected string m_regionName = String.Empty; | ||
362 | protected bool Allow_Alternate_Ports; | ||
363 | public bool m_allow_alternate_ports; | ||
364 | protected string m_externalHostName; | ||
365 | protected IPEndPoint m_internalEndPoint; | ||
366 | protected uint? m_regionLocX; | ||
367 | protected uint? m_regionLocY; | ||
368 | protected uint m_remotingPort; | ||
369 | public UUID RegionID = UUID.Zero; | ||
370 | public string RemotingAddress; | ||
371 | public UUID ScopeID = UUID.Zero; | ||
372 | |||
373 | |||
359 | // Apparently, we're applying the same estatesettings regardless of whether it's local or remote. | 374 | // Apparently, we're applying the same estatesettings regardless of whether it's local or remote. |
360 | 375 | ||
361 | // MT: Yes. Estates can't span trust boundaries. Therefore, it can be | 376 | // MT: Yes. Estates can't span trust boundaries. Therefore, it can be |
@@ -436,42 +451,17 @@ namespace OpenSim.Framework | |||
436 | configMember.performConfigurationRetrieve(); | 451 | configMember.performConfigurationRetrieve(); |
437 | } | 452 | } |
438 | 453 | ||
439 | public RegionInfo(uint regionLocX, uint regionLocY, IPEndPoint internalEndPoint, string externalUri) : | 454 | public RegionInfo(uint regionLocX, uint regionLocY, IPEndPoint internalEndPoint, string externalUri) |
440 | base(regionLocX, regionLocY, internalEndPoint, externalUri) | ||
441 | { | 455 | { |
442 | } | 456 | m_regionLocX = regionLocX; |
443 | 457 | m_regionLocY = regionLocY; | |
444 | public RegionInfo() | ||
445 | { | ||
446 | } | ||
447 | 458 | ||
448 | public RegionInfo(SerializableRegionInfo ConvertFrom) | 459 | m_internalEndPoint = internalEndPoint; |
449 | { | 460 | m_externalHostName = externalUri; |
450 | m_regionLocX = ConvertFrom.RegionLocX; | ||
451 | m_regionLocY = ConvertFrom.RegionLocY; | ||
452 | m_internalEndPoint = ConvertFrom.InternalEndPoint; | ||
453 | m_externalHostName = ConvertFrom.ExternalHostName; | ||
454 | m_remotingPort = ConvertFrom.RemotingPort; | ||
455 | m_allow_alternate_ports = ConvertFrom.m_allow_alternate_ports; | ||
456 | RemotingAddress = ConvertFrom.RemotingAddress; | ||
457 | RegionID = UUID.Zero; | ||
458 | proxyUrl = ConvertFrom.ProxyUrl; | ||
459 | originRegionID = ConvertFrom.OriginRegionID; | ||
460 | RegionName = ConvertFrom.RegionName; | ||
461 | ServerURI = ConvertFrom.ServerURI; | ||
462 | } | 461 | } |
463 | 462 | ||
464 | public RegionInfo(SimpleRegionInfo ConvertFrom) | 463 | public RegionInfo() |
465 | { | 464 | { |
466 | m_regionLocX = ConvertFrom.RegionLocX; | ||
467 | m_regionLocY = ConvertFrom.RegionLocY; | ||
468 | m_internalEndPoint = ConvertFrom.InternalEndPoint; | ||
469 | m_externalHostName = ConvertFrom.ExternalHostName; | ||
470 | m_remotingPort = ConvertFrom.RemotingPort; | ||
471 | m_allow_alternate_ports = ConvertFrom.m_allow_alternate_ports; | ||
472 | RemotingAddress = ConvertFrom.RemotingAddress; | ||
473 | RegionID = UUID.Zero; | ||
474 | ServerURI = ConvertFrom.ServerURI; | ||
475 | } | 465 | } |
476 | 466 | ||
477 | public EstateSettings EstateSettings | 467 | public EstateSettings EstateSettings |
@@ -549,6 +539,111 @@ namespace OpenSim.Framework | |||
549 | get { return m_regionType; } | 539 | get { return m_regionType; } |
550 | } | 540 | } |
551 | 541 | ||
542 | /// <summary> | ||
543 | /// The port by which http communication occurs with the region (most noticeably, CAPS communication) | ||
544 | /// </summary> | ||
545 | public uint HttpPort | ||
546 | { | ||
547 | get { return m_httpPort; } | ||
548 | set { m_httpPort = value; } | ||
549 | } | ||
550 | |||
551 | /// <summary> | ||
552 | /// A well-formed URI for the host region server (namely "http://" + ExternalHostName) | ||
553 | /// </summary> | ||
554 | public string ServerURI | ||
555 | { | ||
556 | get { return m_serverURI; } | ||
557 | set { m_serverURI = value; } | ||
558 | } | ||
559 | |||
560 | public string RegionName | ||
561 | { | ||
562 | get { return m_regionName; } | ||
563 | set { m_regionName = value; } | ||
564 | } | ||
565 | |||
566 | public uint RemotingPort | ||
567 | { | ||
568 | get { return m_remotingPort; } | ||
569 | set { m_remotingPort = value; } | ||
570 | } | ||
571 | |||
572 | /// <value> | ||
573 | /// This accessor can throw all the exceptions that Dns.GetHostAddresses can throw. | ||
574 | /// | ||
575 | /// XXX Isn't this really doing too much to be a simple getter, rather than an explict method? | ||
576 | /// </value> | ||
577 | public IPEndPoint ExternalEndPoint | ||
578 | { | ||
579 | get | ||
580 | { | ||
581 | // Old one defaults to IPv6 | ||
582 | //return new IPEndPoint(Dns.GetHostAddresses(m_externalHostName)[0], m_internalEndPoint.Port); | ||
583 | |||
584 | IPAddress ia = null; | ||
585 | // If it is already an IP, don't resolve it - just return directly | ||
586 | if (IPAddress.TryParse(m_externalHostName, out ia)) | ||
587 | return new IPEndPoint(ia, m_internalEndPoint.Port); | ||
588 | |||
589 | // Reset for next check | ||
590 | ia = null; | ||
591 | try | ||
592 | { | ||
593 | foreach (IPAddress Adr in Dns.GetHostAddresses(m_externalHostName)) | ||
594 | { | ||
595 | if (ia == null) | ||
596 | ia = Adr; | ||
597 | |||
598 | if (Adr.AddressFamily == AddressFamily.InterNetwork) | ||
599 | { | ||
600 | ia = Adr; | ||
601 | break; | ||
602 | } | ||
603 | } | ||
604 | } | ||
605 | catch (SocketException e) | ||
606 | { | ||
607 | throw new Exception( | ||
608 | "Unable to resolve local hostname " + m_externalHostName + " innerException of type '" + | ||
609 | e + "' attached to this exception", e); | ||
610 | } | ||
611 | |||
612 | return new IPEndPoint(ia, m_internalEndPoint.Port); | ||
613 | } | ||
614 | |||
615 | set { m_externalHostName = value.ToString(); } | ||
616 | } | ||
617 | |||
618 | public string ExternalHostName | ||
619 | { | ||
620 | get { return m_externalHostName; } | ||
621 | set { m_externalHostName = value; } | ||
622 | } | ||
623 | |||
624 | public IPEndPoint InternalEndPoint | ||
625 | { | ||
626 | get { return m_internalEndPoint; } | ||
627 | set { m_internalEndPoint = value; } | ||
628 | } | ||
629 | |||
630 | public uint RegionLocX | ||
631 | { | ||
632 | get { return m_regionLocX.Value; } | ||
633 | set { m_regionLocX = value; } | ||
634 | } | ||
635 | |||
636 | public uint RegionLocY | ||
637 | { | ||
638 | get { return m_regionLocY.Value; } | ||
639 | set { m_regionLocY = value; } | ||
640 | } | ||
641 | |||
642 | public ulong RegionHandle | ||
643 | { | ||
644 | get { return Util.UIntsToLong((RegionLocX * (uint) Constants.RegionSize), (RegionLocY * (uint) Constants.RegionSize)); } | ||
645 | } | ||
646 | |||
552 | public void SetEndPoint(string ipaddr, int port) | 647 | public void SetEndPoint(string ipaddr, int port) |
553 | { | 648 | { |
554 | IPAddress tmpIP = IPAddress.Parse(ipaddr); | 649 | IPAddress tmpIP = IPAddress.Parse(ipaddr); |
@@ -1139,5 +1234,27 @@ namespace OpenSim.Framework | |||
1139 | return regionInfo; | 1234 | return regionInfo; |
1140 | } | 1235 | } |
1141 | 1236 | ||
1237 | public int getInternalEndPointPort() | ||
1238 | { | ||
1239 | return m_internalEndPoint.Port; | ||
1240 | } | ||
1241 | |||
1242 | public Dictionary<string, object> ToKeyValuePairs() | ||
1243 | { | ||
1244 | Dictionary<string, object> kvp = new Dictionary<string, object>(); | ||
1245 | kvp["uuid"] = RegionID.ToString(); | ||
1246 | kvp["locX"] = RegionLocX.ToString(); | ||
1247 | kvp["locY"] = RegionLocY.ToString(); | ||
1248 | kvp["external_ip_address"] = ExternalEndPoint.Address.ToString(); | ||
1249 | kvp["external_port"] = ExternalEndPoint.Port.ToString(); | ||
1250 | kvp["external_host_name"] = ExternalHostName; | ||
1251 | kvp["http_port"] = HttpPort.ToString(); | ||
1252 | kvp["internal_ip_address"] = InternalEndPoint.Address.ToString(); | ||
1253 | kvp["internal_port"] = InternalEndPoint.Port.ToString(); | ||
1254 | kvp["alternate_ports"] = m_allow_alternate_ports.ToString(); | ||
1255 | kvp["server_uri"] = ServerURI; | ||
1256 | |||
1257 | return kvp; | ||
1258 | } | ||
1142 | } | 1259 | } |
1143 | } | 1260 | } |
diff --git a/OpenSim/Framework/SerializableRegionInfo.cs b/OpenSim/Framework/SerializableRegionInfo.cs deleted file mode 100644 index c3731b2..0000000 --- a/OpenSim/Framework/SerializableRegionInfo.cs +++ /dev/null | |||
@@ -1,202 +0,0 @@ | |||
1 | /* | ||
2 | * Copyright (c) Contributors, http://opensimulator.org/ | ||
3 | * See CONTRIBUTORS.TXT for a full list of copyright holders. | ||
4 | * | ||
5 | * Redistribution and use in source and binary forms, with or without | ||
6 | * modification, are permitted provided that the following conditions are met: | ||
7 | * * Redistributions of source code must retain the above copyright | ||
8 | * notice, this list of conditions and the following disclaimer. | ||
9 | * * Redistributions in binary form must reproduce the above copyright | ||
10 | * notice, this list of conditions and the following disclaimer in the | ||
11 | * documentation and/or other materials provided with the distribution. | ||
12 | * * Neither the name of the OpenSimulator Project nor the | ||
13 | * names of its contributors may be used to endorse or promote products | ||
14 | * derived from this software without specific prior written permission. | ||
15 | * | ||
16 | * THIS SOFTWARE IS PROVIDED BY THE DEVELOPERS ``AS IS'' AND ANY | ||
17 | * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||
18 | * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE | ||
19 | * DISCLAIMED. IN NO EVENT SHALL THE CONTRIBUTORS BE LIABLE FOR ANY | ||
20 | * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||
21 | * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||
22 | * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||
23 | * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||
24 | * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | ||
25 | * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||
26 | */ | ||
27 | |||
28 | using System; | ||
29 | using System.Net; | ||
30 | using System.Net.Sockets; | ||
31 | using OpenMetaverse; | ||
32 | |||
33 | namespace OpenSim.Framework | ||
34 | { | ||
35 | [Serializable] | ||
36 | public class SerializableRegionInfo | ||
37 | { | ||
38 | public bool m_allow_alternate_ports; | ||
39 | protected string m_externalHostName; | ||
40 | |||
41 | /// <value> | ||
42 | /// The port by which http communication occurs with the region (most noticeably, CAPS communication) | ||
43 | /// | ||
44 | /// FIXME: Defaulting to 9000 temporarily (on the basis that this is the http port most region | ||
45 | /// servers are running) until the revision in which this change is made propogates around grids. | ||
46 | /// </value> | ||
47 | protected uint m_httpPort = 9000; | ||
48 | |||
49 | protected IPEndPoint m_internalEndPoint; | ||
50 | protected Guid m_originRegionID = UUID.Zero.Guid; | ||
51 | protected string m_proxyUrl; | ||
52 | protected uint? m_regionLocX; | ||
53 | protected uint? m_regionLocY; | ||
54 | protected string m_regionName; | ||
55 | public uint m_remotingPort; | ||
56 | protected string m_serverURI; | ||
57 | public Guid RegionID = UUID.Zero.Guid; | ||
58 | public string RemotingAddress; | ||
59 | |||
60 | /// <summary> | ||
61 | /// This is a serializable version of RegionInfo | ||
62 | /// </summary> | ||
63 | public SerializableRegionInfo() | ||
64 | { | ||
65 | } | ||
66 | |||
67 | public SerializableRegionInfo(RegionInfo ConvertFrom) | ||
68 | { | ||
69 | m_regionLocX = ConvertFrom.RegionLocX; | ||
70 | m_regionLocY = ConvertFrom.RegionLocY; | ||
71 | m_internalEndPoint = ConvertFrom.InternalEndPoint; | ||
72 | m_externalHostName = ConvertFrom.ExternalHostName; | ||
73 | m_remotingPort = ConvertFrom.RemotingPort; | ||
74 | m_httpPort = ConvertFrom.HttpPort; | ||
75 | m_allow_alternate_ports = ConvertFrom.m_allow_alternate_ports; | ||
76 | RemotingAddress = ConvertFrom.RemotingAddress; | ||
77 | m_proxyUrl = ConvertFrom.proxyUrl; | ||
78 | OriginRegionID = ConvertFrom.originRegionID; | ||
79 | RegionName = ConvertFrom.RegionName; | ||
80 | ServerURI = ConvertFrom.ServerURI; | ||
81 | } | ||
82 | |||
83 | public SerializableRegionInfo(uint regionLocX, uint regionLocY, IPEndPoint internalEndPoint, string externalUri) | ||
84 | { | ||
85 | m_regionLocX = regionLocX; | ||
86 | m_regionLocY = regionLocY; | ||
87 | |||
88 | m_internalEndPoint = internalEndPoint; | ||
89 | m_externalHostName = externalUri; | ||
90 | } | ||
91 | |||
92 | public SerializableRegionInfo(uint regionLocX, uint regionLocY, string externalUri, uint port) | ||
93 | { | ||
94 | m_regionLocX = regionLocX; | ||
95 | m_regionLocY = regionLocY; | ||
96 | |||
97 | m_externalHostName = externalUri; | ||
98 | |||
99 | m_internalEndPoint = new IPEndPoint(IPAddress.Parse("0.0.0.0"), (int) port); | ||
100 | } | ||
101 | |||
102 | public uint RemotingPort | ||
103 | { | ||
104 | get { return m_remotingPort; } | ||
105 | set { m_remotingPort = value; } | ||
106 | } | ||
107 | |||
108 | public uint HttpPort | ||
109 | { | ||
110 | get { return m_httpPort; } | ||
111 | set { m_httpPort = value; } | ||
112 | } | ||
113 | |||
114 | public IPEndPoint ExternalEndPoint | ||
115 | { | ||
116 | get | ||
117 | { | ||
118 | // Old one defaults to IPv6 | ||
119 | //return new IPEndPoint(Dns.GetHostAddresses(m_externalHostName)[0], m_internalEndPoint.Port); | ||
120 | |||
121 | IPAddress ia = null; | ||
122 | // If it is already an IP, don't resolve it - just return directly | ||
123 | if (IPAddress.TryParse(m_externalHostName, out ia)) | ||
124 | return new IPEndPoint(ia, m_internalEndPoint.Port); | ||
125 | |||
126 | // Reset for next check | ||
127 | ia = null; | ||
128 | |||
129 | |||
130 | // New method favors IPv4 | ||
131 | foreach (IPAddress Adr in Dns.GetHostAddresses(m_externalHostName)) | ||
132 | { | ||
133 | if (ia == null) | ||
134 | ia = Adr; | ||
135 | |||
136 | if (Adr.AddressFamily == AddressFamily.InterNetwork) | ||
137 | { | ||
138 | ia = Adr; | ||
139 | break; | ||
140 | } | ||
141 | } | ||
142 | |||
143 | return new IPEndPoint(ia, m_internalEndPoint.Port); | ||
144 | } | ||
145 | |||
146 | set { m_externalHostName = value.ToString(); } | ||
147 | } | ||
148 | |||
149 | public string ExternalHostName | ||
150 | { | ||
151 | get { return m_externalHostName; } | ||
152 | set { m_externalHostName = value; } | ||
153 | } | ||
154 | |||
155 | public IPEndPoint InternalEndPoint | ||
156 | { | ||
157 | get { return m_internalEndPoint; } | ||
158 | set { m_internalEndPoint = value; } | ||
159 | } | ||
160 | |||
161 | public uint RegionLocX | ||
162 | { | ||
163 | get { return m_regionLocX.Value; } | ||
164 | set { m_regionLocX = value; } | ||
165 | } | ||
166 | |||
167 | public uint RegionLocY | ||
168 | { | ||
169 | get { return m_regionLocY.Value; } | ||
170 | set { m_regionLocY = value; } | ||
171 | } | ||
172 | |||
173 | public ulong RegionHandle | ||
174 | { | ||
175 | get { return Util.UIntsToLong((RegionLocX * (uint) Constants.RegionSize), (RegionLocY * (uint) Constants.RegionSize)); } | ||
176 | } | ||
177 | |||
178 | public string ProxyUrl | ||
179 | { | ||
180 | get { return m_proxyUrl; } | ||
181 | set { m_proxyUrl = value; } | ||
182 | } | ||
183 | |||
184 | public UUID OriginRegionID | ||
185 | { | ||
186 | get { return new UUID(m_originRegionID); } | ||
187 | set { m_originRegionID = value.Guid; } | ||
188 | } | ||
189 | |||
190 | public string RegionName | ||
191 | { | ||
192 | get { return m_regionName; } | ||
193 | set { m_regionName = value; } | ||
194 | } | ||
195 | |||
196 | public string ServerURI | ||
197 | { | ||
198 | get { return m_serverURI; } | ||
199 | set { m_serverURI = value; } | ||
200 | } | ||
201 | } | ||
202 | } | ||