aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/OpenSim/Region/Framework/Scenes
diff options
context:
space:
mode:
Diffstat (limited to '')
-rw-r--r--OpenSim/Region/Framework/Scenes/Scene.cs132
-rw-r--r--OpenSim/Region/Framework/Scenes/SceneBase.cs1
-rw-r--r--OpenSim/Region/Framework/Scenes/Tests/SceneBaseTests.cs5
3 files changed, 91 insertions, 47 deletions
diff --git a/OpenSim/Region/Framework/Scenes/Scene.cs b/OpenSim/Region/Framework/Scenes/Scene.cs
index edbef4c..de8ecc2 100644
--- a/OpenSim/Region/Framework/Scenes/Scene.cs
+++ b/OpenSim/Region/Framework/Scenes/Scene.cs
@@ -2629,34 +2629,23 @@ namespace OpenSim.Region.Framework.Scenes
2629 AgentCircuitData aCircuit = m_authenticateHandler.GetAgentCircuitData(client.CircuitCode); 2629 AgentCircuitData aCircuit = m_authenticateHandler.GetAgentCircuitData(client.CircuitCode);
2630 2630
2631 // Do the verification here 2631 // Do the verification here
2632 System.Net.EndPoint ep = client.GetClientEP(); 2632 System.Net.IPEndPoint ep = (System.Net.IPEndPoint)client.GetClientEP();
2633 if (aCircuit != null) 2633 if (aCircuit != null)
2634 { 2634 {
2635 if ((aCircuit.teleportFlags & (uint)Constants.TeleportFlags.ViaLogin) != 0) 2635 if (!VerifyClient(aCircuit, ep, out vialogin))
2636 { 2636 {
2637 m_log.DebugFormat("[Scene]: Incoming client {0} {1} in region {2} via Login", aCircuit.firstname, aCircuit.lastname, RegionInfo.RegionName); 2637 // uh-oh, this is fishy
2638 vialogin = true; 2638 m_log.WarnFormat("[Scene]: Agent {0} with session {1} connecting with unidentified end point {2}. Refusing service.",
2639 IUserAgentVerificationModule userVerification = RequestModuleInterface<IUserAgentVerificationModule>(); 2639 client.AgentId, client.SessionId, ep.ToString());
2640 if (userVerification != null && ep != null) 2640 try
2641 { 2641 {
2642 if (!userVerification.VerifyClient(aCircuit, ep.ToString())) 2642 client.Close();
2643 {
2644 // uh-oh, this is fishy
2645 m_log.WarnFormat("[Scene]: Agent {0} with session {1} connecting with unidentified end point {2}. Refusing service.",
2646 client.AgentId, client.SessionId, ep.ToString());
2647 try
2648 {
2649 client.Close();
2650 }
2651 catch (Exception e)
2652 {
2653 m_log.DebugFormat("[Scene]: Exception while closing aborted client: {0}", e.StackTrace);
2654 }
2655 return;
2656 }
2657 else
2658 m_log.DebugFormat("[Scene]: User Client Verification for {0} {1} returned true", aCircuit.firstname, aCircuit.lastname);
2659 } 2643 }
2644 catch (Exception e)
2645 {
2646 m_log.DebugFormat("[Scene]: Exception while closing aborted client: {0}", e.StackTrace);
2647 }
2648 return;
2660 } 2649 }
2661 } 2650 }
2662 2651
@@ -2682,7 +2671,65 @@ namespace OpenSim.Region.Framework.Scenes
2682 EventManager.TriggerOnClientLogin(client); 2671 EventManager.TriggerOnClientLogin(client);
2683 } 2672 }
2684 2673
2685 2674 private bool VerifyClient(AgentCircuitData aCircuit, System.Net.IPEndPoint ep, out bool vialogin)
2675 {
2676 vialogin = false;
2677
2678 // Do the verification here
2679 if ((aCircuit.teleportFlags & (uint)Constants.TeleportFlags.ViaLogin) != 0)
2680 {
2681 m_log.DebugFormat("[Scene]: Incoming client {0} {1} in region {2} via Login", aCircuit.firstname, aCircuit.lastname, RegionInfo.RegionName);
2682 vialogin = true;
2683 IUserAgentVerificationModule userVerification = RequestModuleInterface<IUserAgentVerificationModule>();
2684 if (userVerification != null && ep != null)
2685 {
2686 if (!userVerification.VerifyClient(aCircuit, ep.Address.ToString()))
2687 {
2688 // uh-oh, this is fishy
2689 m_log.DebugFormat("[Scene]: User Client Verification for {0} {1} in {2} returned false", aCircuit.firstname, aCircuit.lastname, RegionInfo.RegionName);
2690 return false;
2691 }
2692 else
2693 m_log.DebugFormat("[Scene]: User Client Verification for {0} {1} in {2} returned true", aCircuit.firstname, aCircuit.lastname, RegionInfo.RegionName);
2694 }
2695 }
2696
2697 return true;
2698 }
2699
2700 // Called by Caps, on the first HTTP contact from the client
2701 public override bool CheckClient(UUID agentID, System.Net.IPEndPoint ep)
2702 {
2703 AgentCircuitData aCircuit = m_authenticateHandler.GetAgentCircuitData(agentID);
2704 if (aCircuit != null)
2705 {
2706 bool vialogin = false;
2707 if (!VerifyClient(aCircuit, ep, out vialogin))
2708 {
2709 // if it doesn't pass, we remove the agentcircuitdata altogether
2710 // and the scene presence and the client, if they exist
2711 try
2712 {
2713 ScenePresence sp = GetScenePresence(agentID);
2714 if (sp != null)
2715 sp.ControllingClient.Close();
2716
2717 // BANG! SLASH!
2718 m_authenticateHandler.RemoveCircuit(agentID);
2719
2720 return false;
2721 }
2722 catch (Exception e)
2723 {
2724 m_log.DebugFormat("[Scene]: Exception while closing aborted client: {0}", e.StackTrace);
2725 }
2726 }
2727 else
2728 return true;
2729 }
2730
2731 return false;
2732 }
2686 2733
2687 /// <summary> 2734 /// <summary>
2688 /// Register for events from the client 2735 /// Register for events from the client
@@ -3308,7 +3355,6 @@ namespace OpenSim.Region.Framework.Scenes
3308 /// </summary> 3355 /// </summary>
3309 public void RegisterCommsEvents() 3356 public void RegisterCommsEvents()
3310 { 3357 {
3311 m_sceneGridService.OnExpectUser += HandleNewUserConnection;
3312 m_sceneGridService.OnAvatarCrossingIntoRegion += AgentCrossing; 3358 m_sceneGridService.OnAvatarCrossingIntoRegion += AgentCrossing;
3313 m_sceneGridService.OnCloseAgentConnection += IncomingCloseAgent; 3359 m_sceneGridService.OnCloseAgentConnection += IncomingCloseAgent;
3314 //m_eventManager.OnRegionUp += OtherRegionUp; 3360 //m_eventManager.OnRegionUp += OtherRegionUp;
@@ -3329,7 +3375,6 @@ namespace OpenSim.Region.Framework.Scenes
3329 //m_sceneGridService.OnRemoveKnownRegionFromAvatar -= HandleRemoveKnownRegionsFromAvatar; 3375 //m_sceneGridService.OnRemoveKnownRegionFromAvatar -= HandleRemoveKnownRegionsFromAvatar;
3330 //m_sceneGridService.OnChildAgentUpdate -= IncomingChildAgentDataUpdate; 3376 //m_sceneGridService.OnChildAgentUpdate -= IncomingChildAgentDataUpdate;
3331 //m_eventManager.OnRegionUp -= OtherRegionUp; 3377 //m_eventManager.OnRegionUp -= OtherRegionUp;
3332 m_sceneGridService.OnExpectUser -= HandleNewUserConnection;
3333 m_sceneGridService.OnAvatarCrossingIntoRegion -= AgentCrossing; 3378 m_sceneGridService.OnAvatarCrossingIntoRegion -= AgentCrossing;
3334 m_sceneGridService.OnCloseAgentConnection -= IncomingCloseAgent; 3379 m_sceneGridService.OnCloseAgentConnection -= IncomingCloseAgent;
3335 m_sceneGridService.OnGetLandData -= GetLandData; 3380 m_sceneGridService.OnGetLandData -= GetLandData;
@@ -3341,22 +3386,6 @@ namespace OpenSim.Region.Framework.Scenes
3341 m_log.WarnFormat("[SCENE]: Deregister from grid failed for region {0}", m_regInfo.RegionName); 3386 m_log.WarnFormat("[SCENE]: Deregister from grid failed for region {0}", m_regInfo.RegionName);
3342 } 3387 }
3343 3388
3344 /// <summary>
3345 /// A handler for the SceneCommunicationService event, to match that events return type of void.
3346 /// Use NewUserConnection() directly if possible so the return type can refuse connections.
3347 /// At the moment nothing actually seems to use this event,
3348 /// as everything is switching to calling the NewUserConnection method directly.
3349 ///
3350 /// Now obsoleting this because it doesn't handle teleportFlags propertly
3351 ///
3352 /// </summary>
3353 /// <param name="agent"></param>
3354 [Obsolete("Please call NewUserConnection directly.")]
3355 public void HandleNewUserConnection(AgentCircuitData agent)
3356 {
3357 string reason;
3358 NewUserConnection(agent, 0, out reason);
3359 }
3360 3389
3361 /// <summary> 3390 /// <summary>
3362 /// Do the work necessary to initiate a new user connection for a particular scene. 3391 /// Do the work necessary to initiate a new user connection for a particular scene.
@@ -3418,13 +3447,22 @@ namespace OpenSim.Region.Framework.Scenes
3418 ScenePresence sp = GetScenePresence(agent.AgentID); 3447 ScenePresence sp = GetScenePresence(agent.AgentID);
3419 if (sp != null) 3448 if (sp != null)
3420 { 3449 {
3421 m_log.DebugFormat( 3450 if (sp.IsChildAgent)
3422 "[SCENE]: Adjusting known seeds for existing agent {0} in {1}", 3451 {
3423 agent.AgentID, RegionInfo.RegionName); 3452 m_log.DebugFormat(
3453 "[SCENE]: Adjusting known seeds for existing agent {0} in {1}",
3454 agent.AgentID, RegionInfo.RegionName);
3424 3455
3425 sp.AdjustKnownSeeds(); 3456 sp.AdjustKnownSeeds();
3426 3457
3427 return true; 3458 return true;
3459 }
3460 else
3461 {
3462 // We have a zombie from a crashed session. Kill it.
3463 m_log.DebugFormat("[SCENE]: Zombie scene presence detected for {0} in {1}", agent.AgentID, RegionInfo.RegionName);
3464 sp.ControllingClient.Close();
3465 }
3428 } 3466 }
3429 3467
3430 CapsModule.AddCapsHandler(agent.AgentID); 3468 CapsModule.AddCapsHandler(agent.AgentID);
diff --git a/OpenSim/Region/Framework/Scenes/SceneBase.cs b/OpenSim/Region/Framework/Scenes/SceneBase.cs
index 3218dad..bfc19b7 100644
--- a/OpenSim/Region/Framework/Scenes/SceneBase.cs
+++ b/OpenSim/Region/Framework/Scenes/SceneBase.cs
@@ -536,5 +536,6 @@ namespace OpenSim.Region.Framework.Scenes
536 get { return false; } 536 get { return false; }
537 } 537 }
538 538
539 public abstract bool CheckClient(UUID agentID, System.Net.IPEndPoint ep);
539 } 540 }
540} 541}
diff --git a/OpenSim/Region/Framework/Scenes/Tests/SceneBaseTests.cs b/OpenSim/Region/Framework/Scenes/Tests/SceneBaseTests.cs
index dd9f8f6..42587c1 100644
--- a/OpenSim/Region/Framework/Scenes/Tests/SceneBaseTests.cs
+++ b/OpenSim/Region/Framework/Scenes/Tests/SceneBaseTests.cs
@@ -70,6 +70,11 @@ namespace OpenSim.Region.Framework.Scenes.Tests
70 { 70 {
71 throw new NotImplementedException(); 71 throw new NotImplementedException();
72 } 72 }
73
74 public override bool CheckClient(UUID agentID, System.Net.IPEndPoint ep)
75 {
76 throw new NotImplementedException();
77 }
73 } 78 }
74 79
75 [Test] 80 [Test]