aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/OpenSim/Region
diff options
context:
space:
mode:
Diffstat (limited to 'OpenSim/Region')
-rw-r--r--OpenSim/Region/Framework/Scenes/Scene.cs23
1 files changed, 18 insertions, 5 deletions
diff --git a/OpenSim/Region/Framework/Scenes/Scene.cs b/OpenSim/Region/Framework/Scenes/Scene.cs
index c07661a..caeb980 100644
--- a/OpenSim/Region/Framework/Scenes/Scene.cs
+++ b/OpenSim/Region/Framework/Scenes/Scene.cs
@@ -3885,7 +3885,13 @@ namespace OpenSim.Region.Framework.Scenes
3885 3885
3886 lock (agent) 3886 lock (agent)
3887 { 3887 {
3888 //On login test land permisions 3888 // Optimistic: add or update the circuit data with the new agent circuit data and teleport flags.
3889 // We need the circuit data here for some of the subsequent checks. (groups, for example)
3890 // If the checks fail, we remove the circuit.
3891 agent.teleportFlags = teleportFlags;
3892 m_authenticateHandler.AddNewCircuit(agent.circuitcode, agent);
3893
3894 // On login test land permisions
3889 if (vialogin) 3895 if (vialogin)
3890 { 3896 {
3891 IUserAccountCacheModule cache = RequestModuleInterface<IUserAccountCacheModule>(); 3897 IUserAccountCacheModule cache = RequestModuleInterface<IUserAccountCacheModule>();
@@ -3894,6 +3900,7 @@ namespace OpenSim.Region.Framework.Scenes
3894 if (!TestLandRestrictions(agent.AgentID, out reason, ref agent.startpos.X, ref agent.startpos.Y)) 3900 if (!TestLandRestrictions(agent.AgentID, out reason, ref agent.startpos.X, ref agent.startpos.Y))
3895 { 3901 {
3896 m_log.DebugFormat("[CONNECTION BEGIN]: Denying access to {0} due to no land access", agent.AgentID.ToString()); 3902 m_log.DebugFormat("[CONNECTION BEGIN]: Denying access to {0} due to no land access", agent.AgentID.ToString());
3903 m_authenticateHandler.RemoveCircuit(agent.circuitcode);
3897 return false; 3904 return false;
3898 } 3905 }
3899 } 3906 }
@@ -3905,11 +3912,17 @@ namespace OpenSim.Region.Framework.Scenes
3905 try 3912 try
3906 { 3913 {
3907 if (!VerifyUserPresence(agent, out reason)) 3914 if (!VerifyUserPresence(agent, out reason))
3915 {
3916 m_authenticateHandler.RemoveCircuit(agent.circuitcode);
3908 return false; 3917 return false;
3909 } catch (Exception e) 3918 }
3919 }
3920 catch (Exception e)
3910 { 3921 {
3911 m_log.ErrorFormat( 3922 m_log.ErrorFormat(
3912 "[SCENE]: Exception verifying presence {0}{1}", e.Message, e.StackTrace); 3923 "[SCENE]: Exception verifying presence {0}{1}", e.Message, e.StackTrace);
3924
3925 m_authenticateHandler.RemoveCircuit(agent.circuitcode);
3913 return false; 3926 return false;
3914 } 3927 }
3915 } 3928 }
@@ -3922,6 +3935,7 @@ namespace OpenSim.Region.Framework.Scenes
3922 { 3935 {
3923 if (!AuthorizeUser(agent, out reason)) 3936 if (!AuthorizeUser(agent, out reason))
3924 { 3937 {
3938 m_authenticateHandler.RemoveCircuit(agent.circuitcode);
3925 return false; 3939 return false;
3926 } 3940 }
3927 } 3941 }
@@ -3930,6 +3944,8 @@ namespace OpenSim.Region.Framework.Scenes
3930 { 3944 {
3931 m_log.ErrorFormat( 3945 m_log.ErrorFormat(
3932 "[SCENE]: Exception authorizing user {0}{1}", e.Message, e.StackTrace); 3946 "[SCENE]: Exception authorizing user {0}{1}", e.Message, e.StackTrace);
3947
3948 m_authenticateHandler.RemoveCircuit(agent.circuitcode);
3933 return false; 3949 return false;
3934 } 3950 }
3935 3951
@@ -3959,9 +3975,6 @@ namespace OpenSim.Region.Framework.Scenes
3959 } 3975 }
3960 } 3976 }
3961 3977
3962 // In all cases, add or update the circuit data with the new agent circuit data and teleport flags
3963 agent.teleportFlags = teleportFlags;
3964 m_authenticateHandler.AddNewCircuit(agent.circuitcode, agent);
3965 3978
3966 if (CapsModule != null) 3979 if (CapsModule != null)
3967 { 3980 {