Makes ban of HG users exactly the same as ban of local users, that is upon AddClient and not before.

0.6.3-post-fixes
diva 2009-02-12 02:03:36 +00:00
parent 5dae1ddb5a
commit 98bfeabf94
1 changed files with 47 additions and 78 deletions

View File

@ -729,88 +729,57 @@ namespace OpenSim.Region.Communications.Hypergrid
} }
else else
{ {
RegionInfo[] regions = m_regionsOnInstance.ToArray(); // Finally, everything looks ok
//bool banned = false; //Console.WriteLine("XXX---- EVERYTHING OK ---XXX");
// Just check one region. We assume they all belong to the same estate.
if ((regions.Length > 0) && (regions[0].EstateSettings.IsBanned(userData.ID))) // 1 - Preload the user data
m_userProfileCache.PreloadUserCache(userData.ID, userData);
if (m_knownRegions.ContainsKey(userData.ID))
{ {
m_log.InfoFormat( // This was left here when the user departed
"[HGrid]: Denying access for user {0} {1} because user is banned", m_knownRegions.Remove(userData.ID);
userData.FirstName, userData.SurName);
Hashtable respdata = new Hashtable();
respdata["success"] = "FALSE";
respdata["reason"] = "banned";
resp.Value = respdata;
} }
else
// 2 - Load the region info into list of known regions
RegionInfo rinfo = new RegionInfo();
rinfo.RegionID = userData.HomeRegionID;
rinfo.ExternalHostName = userData.UserHomeAddress;
rinfo.HttpPort = Convert.ToUInt32(userData.UserHomePort);
rinfo.RemotingPort = Convert.ToUInt32(userData.UserHomeRemotingPort);
rinfo.RegionID = userData.HomeRegionID;
// X=0 on the map
rinfo.RegionLocX = 0;
rinfo.RegionLocY = (uint)(random.Next(0, Int32.MaxValue)); //(uint)m_knownRegions.Count;
rinfo.regionSecret = userRegionHandle.ToString();
//Console.WriteLine("XXX--- Here: handle = " + rinfo.regionSecret);
try
{ {
// Finally, everything looks ok rinfo.InternalEndPoint = new IPEndPoint(IPAddress.Parse("0.0.0.0"), (int)userhomeinternalport);
//Console.WriteLine("XXX---- EVERYTHING OK ---XXX");
// Nope, let's do it only for the *agent*
//// 0 - Switch name if necessary
//if (IsComingHome(userData))
//{
// string[] parts = userData.FirstName.Split( new char[] {'.'});
// if (parts.Length >= 1)
// userData.FirstName = parts[0];
// if (parts.Length == 2)
// userData.SurName = parts[1];
// else
// m_log.Warn("[HGrid]: Something fishy with user " + userData.FirstName + userData.SurName);
// m_log.Info("[HGrid]: Welcome home, " + userData.FirstName + " " + userData.SurName);
//}
// 1 - Preload the user data
m_userProfileCache.PreloadUserCache(userData.ID, userData);
if (m_knownRegions.ContainsKey(userData.ID))
{
// This was left here when the user departed
m_knownRegions.Remove(userData.ID);
}
// 2 - Load the region info into list of known regions
RegionInfo rinfo = new RegionInfo();
rinfo.RegionID = userData.HomeRegionID;
rinfo.ExternalHostName = userData.UserHomeAddress;
rinfo.HttpPort = Convert.ToUInt32(userData.UserHomePort);
rinfo.RemotingPort = Convert.ToUInt32(userData.UserHomeRemotingPort);
rinfo.RegionID = userData.HomeRegionID;
// X=0 on the map
rinfo.RegionLocX = 0;
rinfo.RegionLocY = (uint)(random.Next(0, Int32.MaxValue)); //(uint)m_knownRegions.Count;
rinfo.regionSecret = userRegionHandle.ToString();
//Console.WriteLine("XXX--- Here: handle = " + rinfo.regionSecret);
try
{
rinfo.InternalEndPoint = new IPEndPoint(IPAddress.Parse("0.0.0.0"), (int)userhomeinternalport);
}
catch (Exception e)
{
m_log.Warn("[HGrid]: Exception while constructing internal endpoint: " + e);
}
rinfo.RemotingAddress = rinfo.ExternalEndPoint.Address.ToString(); //userData.UserHomeAddress;
if (!IsComingHome(userData))
{
// Change the user's home region here!!!
userData.HomeRegion = rinfo.RegionHandle;
}
if (!m_knownRegions.ContainsKey(userData.ID))
m_knownRegions.Add(userData.ID, rinfo);
// 3 - Send the reply
Hashtable respdata = new Hashtable();
respdata["success"] = "TRUE";
resp.Value = respdata;
DumpUserData(userData);
DumpRegionData(rinfo);
} }
catch (Exception e)
{
m_log.Warn("[HGrid]: Exception while constructing internal endpoint: " + e);
}
rinfo.RemotingAddress = rinfo.ExternalEndPoint.Address.ToString(); //userData.UserHomeAddress;
if (!IsComingHome(userData))
{
// Change the user's home region here!!!
userData.HomeRegion = rinfo.RegionHandle;
}
if (!m_knownRegions.ContainsKey(userData.ID))
m_knownRegions.Add(userData.ID, rinfo);
// 3 - Send the reply
Hashtable respdata = new Hashtable();
respdata["success"] = "TRUE";
resp.Value = respdata;
DumpUserData(userData);
DumpRegionData(rinfo);
} }
return resp; return resp;