UDPServer enabled, should no longer be any udp server code in OpenSimMain.
							parent
							
								
									3d93d39048
								
							
						
					
					
						commit
						fd67b36a5e
					
				|  | @ -54,13 +54,12 @@ using OpenSim.GenericConfig; | ||||||
| namespace OpenSim | namespace OpenSim | ||||||
| { | { | ||||||
| 
 | 
 | ||||||
|     public class OpenSimMain : OpenSimNetworkHandler, conscmd_callback |     public class OpenSimMain : conscmd_callback | ||||||
|     { |     { | ||||||
|         private IGenericConfig localConfig; |         private IGenericConfig localConfig; | ||||||
|         //private IGenericConfig remoteConfig; |         //private IGenericConfig remoteConfig; | ||||||
|         private PhysicsManager physManager; |         private PhysicsManager physManager; | ||||||
|         private Grid GridServers; |         private Grid GridServers; | ||||||
|         private PacketServer _packetServer; |  | ||||||
|         private World LocalWorld; |         private World LocalWorld; | ||||||
|         private AssetCache AssetCache; |         private AssetCache AssetCache; | ||||||
|         private InventoryCache InventoryCache; |         private InventoryCache InventoryCache; | ||||||
|  | @ -68,14 +67,6 @@ namespace OpenSim | ||||||
|         private DateTime startuptime; |         private DateTime startuptime; | ||||||
|         private RegionInfo regionData; |         private RegionInfo regionData; | ||||||
| 
 | 
 | ||||||
|         public Socket Server; |  | ||||||
|         private IPEndPoint ServerIncoming; |  | ||||||
|         private byte[] RecvBuffer = new byte[4096]; |  | ||||||
|         private byte[] ZeroBuffer = new byte[8192]; |  | ||||||
|         private IPEndPoint ipeSender; |  | ||||||
|         private EndPoint epSender; |  | ||||||
|         private AsyncCallback ReceivedData; |  | ||||||
| 
 |  | ||||||
|         private System.Timers.Timer m_heartbeatTimer = new System.Timers.Timer(); |         private System.Timers.Timer m_heartbeatTimer = new System.Timers.Timer(); | ||||||
|         public string m_physicsEngine; |         public string m_physicsEngine; | ||||||
|         public bool m_sandbox = false; |         public bool m_sandbox = false; | ||||||
|  | @ -85,6 +76,7 @@ namespace OpenSim | ||||||
|         private bool configFileSetup = false; |         private bool configFileSetup = false; | ||||||
|         public string m_config; |         public string m_config; | ||||||
| 
 | 
 | ||||||
|  |         private UDPServer m_udpServer; | ||||||
|         protected BaseHttpServer httpServer; |         protected BaseHttpServer httpServer; | ||||||
| 
 | 
 | ||||||
|         protected ConsoleBase m_console; |         protected ConsoleBase m_console; | ||||||
|  | @ -147,7 +139,8 @@ namespace OpenSim | ||||||
|                 Environment.Exit(1); |                 Environment.Exit(1); | ||||||
|             } |             } | ||||||
| 
 | 
 | ||||||
|             PacketServer packetServer = new PacketServer(this); |             //PacketServer packetServer = new PacketServer(this); | ||||||
|  |             m_udpServer = new UDPServer(this.regionData.IPListenPort, this.GridServers, this.AssetCache, this.InventoryCache, this.regionData, this.m_sandbox, this.user_accounts, this.m_console); | ||||||
|              |              | ||||||
|             //should be passing a IGenericConfig object to these so they can read the config data they want from it |             //should be passing a IGenericConfig object to these so they can read the config data they want from it | ||||||
|             GridServers.AssetServer.SetServerInfo(regionData.AssetURL, regionData.AssetSendKey); |             GridServers.AssetServer.SetServerInfo(regionData.AssetURL, regionData.AssetSendKey); | ||||||
|  | @ -200,7 +193,8 @@ namespace OpenSim | ||||||
|             m_console.WriteLine(OpenSim.Framework.Console.LogPriority.LOW, "Main.cs:Startup() - Starting HTTP server"); |             m_console.WriteLine(OpenSim.Framework.Console.LogPriority.LOW, "Main.cs:Startup() - Starting HTTP server"); | ||||||
|             httpServer.Start(); |             httpServer.Start(); | ||||||
| 
 | 
 | ||||||
|             MainServerListener(); |             //MainServerListener(); | ||||||
|  |             this.m_udpServer.ServerListener(); | ||||||
| 
 | 
 | ||||||
|             m_heartbeatTimer.Enabled = true; |             m_heartbeatTimer.Enabled = true; | ||||||
|             m_heartbeatTimer.Interval = 100; |             m_heartbeatTimer.Interval = 100; | ||||||
|  | @ -257,12 +251,12 @@ namespace OpenSim | ||||||
|             m_console.WriteLine(OpenSim.Framework.Console.LogPriority.LOW, "Initialising world"); |             m_console.WriteLine(OpenSim.Framework.Console.LogPriority.LOW, "Initialising world"); | ||||||
|             m_console.componentname = "Region " + regionData.RegionName; |             m_console.componentname = "Region " + regionData.RegionName; | ||||||
| 
 | 
 | ||||||
|             LocalWorld = new World(this._packetServer.ClientThreads, regionData, regionData.RegionHandle, regionData.RegionName); |             LocalWorld = new World(this.m_udpServer.PacketServer.ClientThreads, regionData, regionData.RegionHandle, regionData.RegionName); | ||||||
|             LocalWorld.InventoryCache = InventoryCache; |             LocalWorld.InventoryCache = InventoryCache; | ||||||
|             LocalWorld.AssetCache = AssetCache; |             LocalWorld.AssetCache = AssetCache; | ||||||
| 
 | 
 | ||||||
|             this._packetServer.LocalWorld = LocalWorld; |             this.m_udpServer.LocalWorld = LocalWorld; | ||||||
|             this._packetServer.RegisterClientPacketHandlers(); |             this.m_udpServer.PacketServer.RegisterClientPacketHandlers(); | ||||||
| 
 | 
 | ||||||
|             this.physManager = new OpenSim.Physics.Manager.PhysicsManager(); |             this.physManager = new OpenSim.Physics.Manager.PhysicsManager(); | ||||||
|             this.physManager.LoadPlugins(); |             this.physManager.LoadPlugins(); | ||||||
|  | @ -489,114 +483,6 @@ namespace OpenSim | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         # region UDP |  | ||||||
|         private void OnReceivedData(IAsyncResult result) |  | ||||||
|         { |  | ||||||
|             ipeSender = new IPEndPoint(IPAddress.Any, 0); |  | ||||||
|             epSender = (EndPoint)ipeSender; |  | ||||||
|             Packet packet = null; |  | ||||||
|             int numBytes = Server.EndReceiveFrom(result, ref epSender); |  | ||||||
|             int packetEnd = numBytes - 1; |  | ||||||
| 
 |  | ||||||
|             packet = Packet.BuildPacket(RecvBuffer, ref packetEnd, ZeroBuffer); |  | ||||||
| 
 |  | ||||||
|             // This is either a new client or a packet to send to an old one |  | ||||||
|             // if (OpenSimRoot.Instance.ClientThreads.ContainsKey(epSender)) |  | ||||||
| 
 |  | ||||||
|             // do we already have a circuit for this endpoint |  | ||||||
|             if (this.clientCircuits.ContainsKey(epSender)) |  | ||||||
|             { |  | ||||||
|                 //ClientThreads[this.clientCircuits[epSender]].InPacket(packet); |  | ||||||
|                 this._packetServer.ClientInPacket(this.clientCircuits[epSender], packet); |  | ||||||
|             } |  | ||||||
|             else if (packet.Type == PacketType.UseCircuitCode) |  | ||||||
|             { // new client |  | ||||||
| 
 |  | ||||||
|                 UseCircuitCodePacket useCircuit = (UseCircuitCodePacket)packet; |  | ||||||
|                 this.clientCircuits.Add(epSender, useCircuit.CircuitCode.Code); |  | ||||||
|                 bool isChildAgent = false; |  | ||||||
|                 if (this.GridServers.GridServer.GetName() == "Remote") |  | ||||||
|                 { |  | ||||||
|                     isChildAgent = ((RemoteGridBase)this.GridServers.GridServer).agentcircuits[useCircuit.CircuitCode.Code].child; |  | ||||||
|                 } |  | ||||||
|                 SimClient newuser = new SimClient(epSender, useCircuit, LocalWorld, _packetServer.ClientThreads, AssetCache, GridServers.GridServer, this, InventoryCache, m_sandbox, isChildAgent, this.regionData); |  | ||||||
|                 if ((this.GridServers.UserServer != null) && (user_accounts)) |  | ||||||
|                 { |  | ||||||
|                     newuser.UserServer = this.GridServers.UserServer; |  | ||||||
|                 } |  | ||||||
|                 //OpenSimRoot.Instance.ClientThreads.Add(epSender, newuser); |  | ||||||
|                 this._packetServer.ClientThreads.Add(useCircuit.CircuitCode.Code, newuser); |  | ||||||
| 
 |  | ||||||
|                 //if (!((RemoteGridBase)GridServers.GridServer).agentcircuits[useCircuit.CircuitCode.Code].child) |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
|             } |  | ||||||
|             else |  | ||||||
|             { // invalid client |  | ||||||
|                 Console.Error.WriteLine("Main.cs:OnReceivedData() - WARNING: Got a packet from an invalid client - " + epSender.ToString()); |  | ||||||
|             } |  | ||||||
| 
 |  | ||||||
|             Server.BeginReceiveFrom(RecvBuffer, 0, RecvBuffer.Length, SocketFlags.None, ref epSender, ReceivedData, null); |  | ||||||
|         } |  | ||||||
| 
 |  | ||||||
|         private void MainServerListener() |  | ||||||
|         { |  | ||||||
|             m_console.WriteLine(OpenSim.Framework.Console.LogPriority.LOW, "Main.cs:MainServerListener() - New thread started"); |  | ||||||
|             m_console.WriteLine(OpenSim.Framework.Console.LogPriority.LOW, "Main.cs:MainServerListener() - Opening UDP socket on " + regionData.IPListenAddr + ":" + regionData.IPListenPort); |  | ||||||
| 
 |  | ||||||
|             ServerIncoming = new IPEndPoint(IPAddress.Any, regionData.IPListenPort); |  | ||||||
|             Server = new Socket(AddressFamily.InterNetwork, SocketType.Dgram, ProtocolType.Udp); |  | ||||||
|             Server.Bind(ServerIncoming); |  | ||||||
| 
 |  | ||||||
|             m_console.WriteLine(OpenSim.Framework.Console.LogPriority.LOW, "Main.cs:MainServerListener() - UDP socket bound, getting ready to listen"); |  | ||||||
| 
 |  | ||||||
|             ipeSender = new IPEndPoint(IPAddress.Any, 0); |  | ||||||
|             epSender = (EndPoint)ipeSender; |  | ||||||
|             ReceivedData = new AsyncCallback(this.OnReceivedData); |  | ||||||
|             Server.BeginReceiveFrom(RecvBuffer, 0, RecvBuffer.Length, SocketFlags.None, ref epSender, ReceivedData, null); |  | ||||||
| 
 |  | ||||||
|             m_console.WriteLine(OpenSim.Framework.Console.LogPriority.LOW, "Main.cs:MainServerListener() - Listening..."); |  | ||||||
| 
 |  | ||||||
|         } |  | ||||||
| 
 |  | ||||||
|         public void RegisterPacketServer(PacketServer server) |  | ||||||
|         { |  | ||||||
|             this._packetServer = server; |  | ||||||
|         } |  | ||||||
| 
 |  | ||||||
|         public virtual void SendPacketTo(byte[] buffer, int size, SocketFlags flags, uint circuitcode)//EndPoint packetSender) |  | ||||||
|         { |  | ||||||
|             // find the endpoint for this circuit |  | ||||||
|             EndPoint sendto = null; |  | ||||||
|             foreach (KeyValuePair<EndPoint, uint> p in this.clientCircuits) |  | ||||||
|             { |  | ||||||
|                 if (p.Value == circuitcode) |  | ||||||
|                 { |  | ||||||
|                     sendto = p.Key; |  | ||||||
|                     break; |  | ||||||
|                 } |  | ||||||
|             } |  | ||||||
|             if (sendto != null) |  | ||||||
|             { |  | ||||||
|                 //we found the endpoint so send the packet to it |  | ||||||
|                 this.Server.SendTo(buffer, size, flags, sendto); |  | ||||||
|             } |  | ||||||
|         } |  | ||||||
| 
 |  | ||||||
|         public virtual void RemoveClientCircuit(uint circuitcode) |  | ||||||
|         { |  | ||||||
|             foreach (KeyValuePair<EndPoint, uint> p in this.clientCircuits) |  | ||||||
|             { |  | ||||||
|                 if (p.Value == circuitcode) |  | ||||||
|                 { |  | ||||||
|                     this.clientCircuits.Remove(p.Key); |  | ||||||
|                     break; |  | ||||||
|                 } |  | ||||||
|             } |  | ||||||
|         } |  | ||||||
| 
 |  | ||||||
|         #endregion |  | ||||||
| 
 |  | ||||||
|         /// <summary> |         /// <summary> | ||||||
|         /// Performs any last-minute sanity checking and shuts down the region server |         /// Performs any last-minute sanity checking and shuts down the region server | ||||||
|         /// </summary> |         /// </summary> | ||||||
|  |  | ||||||
|  | @ -46,11 +46,31 @@ namespace OpenSim | ||||||
|         private bool user_accounts = false; |         private bool user_accounts = false; | ||||||
|         private ConsoleBase m_console; |         private ConsoleBase m_console; | ||||||
| 
 | 
 | ||||||
|         public UDPServer(int port, Grid gridServers, World localWorld, AssetCache assetCache, InventoryCache inventoryCache, RegionInfo _regionData, bool sandbox, bool accounts, ConsoleBase console) |         public PacketServer PacketServer | ||||||
|  |         { | ||||||
|  |             get | ||||||
|  |             { | ||||||
|  |                 return _packetServer; | ||||||
|  |             } | ||||||
|  |             set | ||||||
|  |             { | ||||||
|  |                 _packetServer = value; | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         public World LocalWorld | ||||||
|  |         { | ||||||
|  |             set | ||||||
|  |             { | ||||||
|  |                 this.m_localWorld = value; | ||||||
|  |                 this._packetServer.LocalWorld = this.m_localWorld; | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         public UDPServer(int port, Grid gridServers, AssetCache assetCache, InventoryCache inventoryCache, RegionInfo _regionData, bool sandbox, bool accounts, ConsoleBase console) | ||||||
|         { |         { | ||||||
|             listenPort = port; |             listenPort = port; | ||||||
|             this.m_gridServers = gridServers; |             this.m_gridServers = gridServers; | ||||||
|             this.m_localWorld = localWorld; |  | ||||||
|             this.m_assetCache = assetCache; |             this.m_assetCache = assetCache; | ||||||
|             this.m_inventoryCache = inventoryCache; |             this.m_inventoryCache = inventoryCache; | ||||||
|             this.m_regionData = _regionData; |             this.m_regionData = _regionData; | ||||||
|  | @ -58,8 +78,6 @@ namespace OpenSim | ||||||
|             this.user_accounts = accounts; |             this.user_accounts = accounts; | ||||||
|             this.m_console = console; |             this.m_console = console; | ||||||
|             PacketServer packetServer = new PacketServer(this); |             PacketServer packetServer = new PacketServer(this); | ||||||
|             this._packetServer.LocalWorld = m_localWorld; |  | ||||||
|             this._packetServer.RegisterClientPacketHandlers(); |  | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         protected virtual void OnReceivedData(IAsyncResult result) |         protected virtual void OnReceivedData(IAsyncResult result) | ||||||
|  | @ -85,7 +103,7 @@ namespace OpenSim | ||||||
|             } |             } | ||||||
|             else |             else | ||||||
|             { // invalid client |             { // invalid client | ||||||
|                 Console.Error.WriteLine("Main.cs:OnReceivedData() - WARNING: Got a packet from an invalid client - " + epSender.ToString()); |                 Console.Error.WriteLine("UDPServer.cs:OnReceivedData() - WARNING: Got a packet from an invalid client - " + epSender.ToString()); | ||||||
|             } |             } | ||||||
| 
 | 
 | ||||||
|             Server.BeginReceiveFrom(RecvBuffer, 0, RecvBuffer.Length, SocketFlags.None, ref epSender, ReceivedData, null); |             Server.BeginReceiveFrom(RecvBuffer, 0, RecvBuffer.Length, SocketFlags.None, ref epSender, ReceivedData, null); | ||||||
|  | @ -106,22 +124,22 @@ namespace OpenSim | ||||||
|             this._packetServer.ClientThreads.Add(useCircuit.CircuitCode.Code, newuser); |             this._packetServer.ClientThreads.Add(useCircuit.CircuitCode.Code, newuser); | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         private void ServerListener() |         public void ServerListener() | ||||||
|         { |         { | ||||||
|             m_console.WriteLine("Main.cs:MainServerListener() - Opening UDP socket on " + listenPort); |             m_console.WriteLine("UDPServer.cs:ServerListener() - Opening UDP socket on " + listenPort); | ||||||
| 
 | 
 | ||||||
|             ServerIncoming = new IPEndPoint(IPAddress.Any, listenPort); |             ServerIncoming = new IPEndPoint(IPAddress.Any, listenPort); | ||||||
|             Server = new Socket(AddressFamily.InterNetwork, SocketType.Dgram, ProtocolType.Udp); |             Server = new Socket(AddressFamily.InterNetwork, SocketType.Dgram, ProtocolType.Udp); | ||||||
|             Server.Bind(ServerIncoming); |             Server.Bind(ServerIncoming); | ||||||
| 
 | 
 | ||||||
|             m_console.WriteLine("Main.cs:MainServerListener() - UDP socket bound, getting ready to listen"); |             m_console.WriteLine("UDPServer.cs:ServerListener() - UDP socket bound, getting ready to listen"); | ||||||
| 
 | 
 | ||||||
|             ipeSender = new IPEndPoint(IPAddress.Any, 0); |             ipeSender = new IPEndPoint(IPAddress.Any, 0); | ||||||
|             epSender = (EndPoint)ipeSender; |             epSender = (EndPoint)ipeSender; | ||||||
|             ReceivedData = new AsyncCallback(this.OnReceivedData); |             ReceivedData = new AsyncCallback(this.OnReceivedData); | ||||||
|             Server.BeginReceiveFrom(RecvBuffer, 0, RecvBuffer.Length, SocketFlags.None, ref epSender, ReceivedData, null); |             Server.BeginReceiveFrom(RecvBuffer, 0, RecvBuffer.Length, SocketFlags.None, ref epSender, ReceivedData, null); | ||||||
| 
 | 
 | ||||||
|             m_console.WriteLine("Main.cs:MainServerListener() - Listening..."); |             m_console.WriteLine("UDPServer.cs:ServerListener() - Listening..."); | ||||||
| 
 | 
 | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
		Loading…
	
		Reference in New Issue
	
	 MW
						MW