118 lines
		
	
	
		
			4.8 KiB
		
	
	
	
		
			C#
		
	
	
			
		
		
	
	
			118 lines
		
	
	
		
			4.8 KiB
		
	
	
	
		
			C#
		
	
	
| using System;
 | |
| using System.Collections.Generic;
 | |
| using System.Text;
 | |
| using OpenSim.Framework;
 | |
| using OpenSim.Framework.Types;
 | |
| 
 | |
| using libsecondlife;
 | |
| 
 | |
| namespace OpenGrid.Framework.Communications
 | |
| {
 | |
|     public class LocalBackEndServices
 | |
|     {
 | |
|         protected Dictionary<ulong, RegionInfo> regions = new Dictionary<ulong, RegionInfo>();
 | |
|         protected Dictionary<ulong, RegionCommsHostBase> regionHosts = new Dictionary<ulong, RegionCommsHostBase>();
 | |
| 
 | |
|         public LocalBackEndServices()
 | |
|         {
 | |
| 
 | |
|         }
 | |
| 
 | |
|         /// <summary>
 | |
|         /// Register a region method with the BackEnd Services.
 | |
|         /// </summary>
 | |
|         /// <param name="regionInfo"></param>
 | |
|         /// <returns></returns>
 | |
|         public RegionCommsHostBase RegisterRegion(RegionInfo regionInfo)
 | |
|         {
 | |
|             //Console.WriteLine("CommsManager - Region " + regionInfo.RegionHandle + " , " + regionInfo.RegionLocX + " , "+ regionInfo.RegionLocY +" is registering");
 | |
|             if (!this.regions.ContainsKey((uint)regionInfo.RegionHandle))
 | |
|             {
 | |
|                 //Console.WriteLine("CommsManager - Adding Region " + regionInfo.RegionHandle );
 | |
|                 this.regions.Add(regionInfo.RegionHandle, regionInfo);
 | |
|                 RegionCommsHostBase regionHost = new RegionCommsHostBase();
 | |
|                 this.regionHosts.Add(regionInfo.RegionHandle, regionHost);
 | |
| 
 | |
|                 return regionHost;
 | |
|             }
 | |
| 
 | |
|             //already in our list of regions so for now lets return null
 | |
|             return null;
 | |
|         }
 | |
| 
 | |
|         /// <summary>
 | |
|         /// </summary>
 | |
|         /// <param name="regionInfo"></param>
 | |
|         /// <returns></returns>
 | |
|         public  List<RegionInfo> RequestNeighbours(RegionInfo regionInfo)
 | |
|         {
 | |
|             // Console.WriteLine("Finding Neighbours to " + regionInfo.RegionHandle);
 | |
|             List<RegionInfo> neighbours = new List<RegionInfo>();
 | |
| 
 | |
|             foreach (RegionInfo reg in this.regions.Values)
 | |
|             {
 | |
|                 // Console.WriteLine("CommsManager- RequestNeighbours() checking region " + reg.RegionLocX + " , "+ reg.RegionLocY);
 | |
|                 if (reg.RegionHandle != regionInfo.RegionHandle)
 | |
|                 {
 | |
|                     //Console.WriteLine("CommsManager- RequestNeighbours() - found a different region in list, checking location");
 | |
|                     if ((reg.RegionLocX > (regionInfo.RegionLocX - 2)) && (reg.RegionLocX < (regionInfo.RegionLocX + 2)))
 | |
|                     {
 | |
|                         if ((reg.RegionLocY > (regionInfo.RegionLocY - 2)) && (reg.RegionLocY < (regionInfo.RegionLocY + 2)))
 | |
|                         {
 | |
|                             neighbours.Add(reg);
 | |
|                         }
 | |
|                     }
 | |
|                 }
 | |
|             }
 | |
|             return neighbours;
 | |
|         }
 | |
| 
 | |
|         /// <summary>
 | |
|         /// </summary>
 | |
|         /// <param name="regionHandle"></param>
 | |
|         /// <param name="agentData"></param>
 | |
|         /// <returns></returns>
 | |
|         public  bool InformNeighbourOfChildAgent(ulong regionHandle, AgentCircuitData agentData) //should change from agentCircuitData
 | |
|         {
 | |
|             //Console.WriteLine("CommsManager- Trying to Inform a region to expect child agent");
 | |
|             if (this.regionHosts.ContainsKey(regionHandle))
 | |
|             {
 | |
|                 // Console.WriteLine("CommsManager- Informing a region to expect child agent");
 | |
|                 this.regionHosts[regionHandle].TriggerExpectUser(regionHandle, agentData);
 | |
|                 return true;
 | |
|             }
 | |
|             return false;
 | |
|         }
 | |
| 
 | |
|         /// <summary>
 | |
|         /// Is a Sandbox mode method, used by the local Login server to inform a region of a connection user/session
 | |
|         /// </summary>
 | |
|         /// <param name="regionHandle"></param>
 | |
|         /// <param name="loginData"></param>
 | |
|         /// <returns></returns>
 | |
|         public bool AddNewSession(ulong regionHandle, Login loginData)
 | |
|         {
 | |
|             //Console.WriteLine(" comms manager been told to expect new user");
 | |
|             AgentCircuitData agent = new AgentCircuitData();
 | |
|             agent.AgentID = loginData.Agent;
 | |
|             agent.firstname = loginData.First;
 | |
|             agent.lastname = loginData.Last;
 | |
|             agent.SessionID = loginData.Session;
 | |
|             agent.SecureSessionID = loginData.SecureSession;
 | |
|             agent.circuitcode = loginData.CircuitCode;
 | |
|             agent.BaseFolder = loginData.BaseFolder;
 | |
|             agent.InventoryFolder = loginData.InventoryFolder;
 | |
|             agent.startpos = new LLVector3(128, 128, 70);
 | |
| 
 | |
|             if (this.regionHosts.ContainsKey(regionHandle))
 | |
|             {
 | |
|                 this.regionHosts[regionHandle].TriggerExpectUser(regionHandle, agent);
 | |
|                 return true;
 | |
|             }
 | |
| 
 | |
|             // region not found
 | |
|             return false;
 | |
|         }
 | |
|     }
 | |
| }
 |