aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/OpenSim/Region/CoreModules/ServiceConnectorsOut
diff options
context:
space:
mode:
Diffstat (limited to 'OpenSim/Region/CoreModules/ServiceConnectorsOut')
-rw-r--r--OpenSim/Region/CoreModules/ServiceConnectorsOut/Grid/HGGridConnector.cs83
1 files changed, 59 insertions, 24 deletions
diff --git a/OpenSim/Region/CoreModules/ServiceConnectorsOut/Grid/HGGridConnector.cs b/OpenSim/Region/CoreModules/ServiceConnectorsOut/Grid/HGGridConnector.cs
index b7e3213..e3cb05c 100644
--- a/OpenSim/Region/CoreModules/ServiceConnectorsOut/Grid/HGGridConnector.cs
+++ b/OpenSim/Region/CoreModules/ServiceConnectorsOut/Grid/HGGridConnector.cs
@@ -63,6 +63,8 @@ namespace OpenSim.Region.CoreModules.ServiceConnectorsOut.Grid
63 // This is key-ed on agent ID 63 // This is key-ed on agent ID
64 protected Dictionary<UUID, SimpleRegionInfo> m_knownRegions = new Dictionary<UUID, SimpleRegionInfo>(); 64 protected Dictionary<UUID, SimpleRegionInfo> m_knownRegions = new Dictionary<UUID, SimpleRegionInfo>();
65 65
66 protected Dictionary<UUID, ulong> m_HyperlinkHandles = new Dictionary<UUID, ulong>();
67
66 #region ISharedRegionModule 68 #region ISharedRegionModule
67 69
68 public Type ReplaceableInterface 70 public Type ReplaceableInterface
@@ -160,10 +162,11 @@ namespace OpenSim.Region.CoreModules.ServiceConnectorsOut.Grid
160 if (regionInfo.RegionID.Equals(UUID.Zero)) 162 if (regionInfo.RegionID.Equals(UUID.Zero))
161 { 163 {
162 m_log.Info("[HGrid]: Linking remote region " + regionInfo.ExternalHostName + ":" + regionInfo.HttpPort); 164 m_log.Info("[HGrid]: Linking remote region " + regionInfo.ExternalHostName + ":" + regionInfo.HttpPort);
163 regionInfo.RegionID = m_HypergridServiceConnector.LinkRegion(regionInfo); 165 ulong regionHandle = 0;
166 regionInfo.RegionID = m_HypergridServiceConnector.LinkRegion(regionInfo, out regionHandle);
164 if (!regionInfo.RegionID.Equals(UUID.Zero)) 167 if (!regionInfo.RegionID.Equals(UUID.Zero))
165 { 168 {
166 m_HyperlinkRegions.Add(regionInfo.RegionID, regionInfo); 169 AddHyperlinkRegion(regionInfo, regionHandle);
167 m_log.Info("[HGrid]: Successfully linked to region_uuid " + regionInfo.RegionID); 170 m_log.Info("[HGrid]: Successfully linked to region_uuid " + regionInfo.RegionID);
168 171
169 // Try get the map image 172 // Try get the map image
@@ -186,15 +189,18 @@ namespace OpenSim.Region.CoreModules.ServiceConnectorsOut.Grid
186 // Try the hyperlink collection 189 // Try the hyperlink collection
187 if (m_HyperlinkRegions.ContainsKey(regionID)) 190 if (m_HyperlinkRegions.ContainsKey(regionID))
188 { 191 {
189 m_HyperlinkRegions.Remove(regionID); 192 RemoveHyperlinkRegion(regionID);
190 return true; 193 return true;
191 } 194 }
192 // Try the foreign users home collection 195 // Try the foreign users home collection
193 if (m_knownRegions.ContainsKey(regionID)) 196
194 { 197 foreach (SimpleRegionInfo r in m_knownRegions.Values)
195 m_knownRegions.Remove(regionID); 198 if (r.RegionID == regionID)
196 return true; 199 {
197 } 200 RemoveHyperlinkHomeRegion(regionID);
201 return true;
202 }
203
198 // Finally, try the normal route 204 // Finally, try the normal route
199 return m_GridServiceConnector.DeregisterRegion(regionID); 205 return m_GridServiceConnector.DeregisterRegion(regionID);
200 } 206 }
@@ -213,8 +219,9 @@ namespace OpenSim.Region.CoreModules.ServiceConnectorsOut.Grid
213 return m_HyperlinkRegions[regionID]; 219 return m_HyperlinkRegions[regionID];
214 220
215 // Try the foreign users home collection 221 // Try the foreign users home collection
216 if (m_knownRegions.ContainsKey(regionID)) 222 foreach (SimpleRegionInfo r in m_knownRegions.Values)
217 return m_knownRegions[regionID]; 223 if (r.RegionID == regionID)
224 return m_knownRegions[regionID];
218 225
219 // Finally, try the normal route 226 // Finally, try the normal route
220 return m_GridServiceConnector.GetRegionByUUID(scopeID, regionID); 227 return m_GridServiceConnector.GetRegionByUUID(scopeID, regionID);
@@ -249,20 +256,19 @@ namespace OpenSim.Region.CoreModules.ServiceConnectorsOut.Grid
249 if (region != null) 256 if (region != null)
250 return region; 257 return region;
251 258
252 // !!! Commenting until region name exists 259 // Try the hyperlink collection
253 //// Try the hyperlink collection 260 foreach (SimpleRegionInfo r in m_HyperlinkRegions.Values)
254 //foreach (SimpleRegionInfo r in m_HyperlinkRegions.Values) 261 {
255 //{ 262 if (r.RegionName == regionName)
256 // if (r.RegionName == regionName) 263 return r;
257 // return r; 264 }
258 //} 265
259 266 // Try the foreign users home collection
260 //// Try the foreign users home collection 267 foreach (SimpleRegionInfo r in m_knownRegions.Values)
261 //foreach (SimpleRegionInfo r in m_knownRegions.Values) 268 {
262 //{ 269 if (r.RegionName == regionName)
263 // if (r.RegionName == regionName) 270 return r;
264 // return r; 271 }
265 //}
266 return null; 272 return null;
267 } 273 }
268 274
@@ -299,6 +305,35 @@ namespace OpenSim.Region.CoreModules.ServiceConnectorsOut.Grid
299 305
300 #endregion 306 #endregion
301 307
308 private void AddHyperlinkRegion(SimpleRegionInfo regionInfo, ulong regionHandle)
309 {
310 m_HyperlinkRegions.Add(regionInfo.RegionID, regionInfo);
311 m_HyperlinkHandles.Add(regionInfo.RegionID, regionHandle);
312 }
313
314 private void RemoveHyperlinkRegion(UUID regionID)
315 {
316 m_HyperlinkRegions.Remove(regionID);
317 m_HyperlinkHandles.Remove(regionID);
318 }
319
320 private void AddHyperlinkHomeRegion(UUID userID, SimpleRegionInfo regionInfo, ulong regionHandle)
321 {
322 m_knownRegions.Add(userID, regionInfo);
323 m_HyperlinkHandles.Add(regionInfo.RegionID, regionHandle);
324 }
325
326 private void RemoveHyperlinkHomeRegion(UUID regionID)
327 {
328 foreach (KeyValuePair<UUID, SimpleRegionInfo> kvp in m_knownRegions)
329 {
330 if (kvp.Value.RegionID == regionID)
331 {
332 m_knownRegions.Remove(kvp.Key);
333 }
334 }
335 m_HyperlinkHandles.Remove(regionID);
336 }
302 337
303 } 338 }
304} 339}