* Refactor: Creating grid login exceptions to try and break up a large method.

* This in preparation for further login validation to check that the region logging in is properly contactable.
* Also increase verbosity of some error messages
0.6.0-stable
Justin Clarke Casey 2008-05-12 22:00:33 +00:00
parent 56e5dc49f9
commit c8b59f7a31
1 changed files with 117 additions and 79 deletions

View File

@ -248,10 +248,18 @@ namespace OpenSim.Grid.GridServer
/// </summary> /// </summary>
/// <param name="sim"></param> /// <param name="sim"></param>
/// <returns></returns> /// <returns></returns>
protected virtual bool ValidateOverwrite(RegionProfileData sim, RegionProfileData existingSim) protected virtual void ValidateOverwrite(RegionProfileData sim, RegionProfileData existingSim)
{ {
return (existingSim.regionRecvKey == sim.regionRecvKey && if (!(existingSim.regionRecvKey == sim.regionRecvKey && existingSim.regionSendKey == sim.regionSendKey))
existingSim.regionSendKey == sim.regionSendKey); {
throw new LoginException(
String.Format(
"Authentication failed when trying to login existing region {0} at location {1} {2} currently occupied by {3}"
+ " with the region's send key {4} (expected {5}) and the region's receive key {6} (expected {7})",
sim.regionName, sim.regionLocX, sim.regionLocY, existingSim.regionName,
sim.regionSendKey, existingSim.regionSendKey, sim.regionRecvKey, existingSim.regionRecvKey),
"The keys required to login your region did not match the grid server keys. Please check your grid send and receive keys.");
}
} }
/// <summary> /// <summary>
@ -260,15 +268,30 @@ namespace OpenSim.Grid.GridServer
/// Currently, this means checking that the keys passed in by the new region /// Currently, this means checking that the keys passed in by the new region
/// match those in the grid server's configuration. /// match those in the grid server's configuration.
/// </summary> /// </summary>
///
/// <param name="sim"></param> /// <param name="sim"></param>
/// <returns></returns> /// <exception cref="LoginException">Thrown if region login failed</exception>
protected virtual bool ValidateNewRegion(RegionProfileData sim) protected virtual void ValidateNewRegion(RegionProfileData sim)
{ {
return (sim.regionRecvKey == Config.SimSendKey && if (!(sim.regionRecvKey == Config.SimSendKey && sim.regionSendKey == Config.SimRecvKey))
sim.regionSendKey == Config.SimRecvKey); {
throw new LoginException(
String.Format(
"Authentication failed when trying to login new region {0} at location {1} {2}"
+ " with the region's send key {3} (expected {4}) and the region's receive key {5} (expected {6})",
sim.regionName, sim.regionLocX, sim.regionLocY,
sim.regionSendKey, Config.SimRecvKey, sim.regionRecvKey, Config.SimSendKey),
"The keys required to login your region did not match your existing region keys. Please check your grid send and receive keys.");
} }
private static XmlRpcResponse ErrorResponse(string error) }
/// <summary>
/// Construct an XMLRPC error response
/// </summary>
/// <param name="error"></param>
/// <returns></returns>
public static XmlRpcResponse ErrorResponse(string error)
{ {
XmlRpcResponse errorResponse = new XmlRpcResponse(); XmlRpcResponse errorResponse = new XmlRpcResponse();
Hashtable errorResponseData = new Hashtable(); Hashtable errorResponseData = new Hashtable();
@ -310,21 +333,27 @@ namespace OpenSim.Grid.GridServer
existingSim = GetRegion(sim.regionHandle); existingSim = GetRegion(sim.regionHandle);
if (existingSim == null || existingSim.UUID == sim.UUID || sim.UUID != sim.originUUID) if (existingSim == null || existingSim.UUID == sim.UUID || sim.UUID != sim.originUUID)
{ {
bool validated; try
{
if (existingSim == null) if (existingSim == null)
{ {
validated = ValidateNewRegion(sim); ValidateNewRegion(sim);
} }
else else
{ {
validated = ValidateOverwrite(sim, existingSim); ValidateOverwrite(sim, existingSim);
}
}
catch (LoginException e)
{
m_log.WarnFormat("[LOGIN END]: {0}", e.Message);
return e.XmlRpcErrorResponse;
} }
if (validated)
{
foreach (KeyValuePair<string, IGridData> kvp in _plugins) foreach (KeyValuePair<string, IGridData> kvp in _plugins)
{ {
try try
@ -372,26 +401,6 @@ namespace OpenSim.Grid.GridServer
return response; return response;
} }
else else
{
if (existingSim == null)
{
m_log.WarnFormat(
"[LOGIN END]: Authentication failed when trying to login new region {0} at location {1} {2}"
+ " with TheSim.regionSendKey {3} (expected {4}) and TheSim.regionRecvKey {5} (expected {6})",
sim.regionName, sim.regionLocX, sim.regionLocY,
sim.regionSendKey, Config.SimRecvKey, sim.regionRecvKey, Config.SimSendKey);
}
else
{
m_log.Warn("[LOGIN END]: Authentication failed when trying to login region " + sim.regionName +
" at location " + sim.regionLocX +
" " + sim.regionLocY + " currently occupied by " + existingSim.regionName);
}
return ErrorResponse("The key required to login your region did not match. Please check your grid send and receive keys.");
}
}
else
{ {
m_log.Warn("[LOGIN END]: Failed to login region " + sim.regionName + " at location " + sim.regionLocX + " " + sim.regionLocY + " currently occupied by " + existingSim.regionName); m_log.Warn("[LOGIN END]: Failed to login region " + sim.regionName + " at location " + sim.regionLocX + " " + sim.regionLocY + " currently occupied by " + existingSim.regionName);
return ErrorResponse("Another region already exists at that location. Please try another."); return ErrorResponse("Another region already exists at that location. Please try another.");
@ -1065,4 +1074,33 @@ namespace OpenSim.Grid.GridServer
return response; return response;
} }
} }
/// <summary>
/// Exception generated when a simulator fails to login to the grid
/// </summary>
public class LoginException : Exception
{
/// <summary>
/// Return an XmlRpcResponse version of the exception message suitable for sending to a client
/// </summary>
/// <param name="message"></param>
/// <param name="xmlRpcMessage"></param>
public XmlRpcResponse XmlRpcErrorResponse
{
get { return m_xmlRpcErrorResponse; }
}
private XmlRpcResponse m_xmlRpcErrorResponse;
public LoginException(string message, string xmlRpcMessage) : base(message)
{
// FIXME: Might be neater to refactor and put the method inside here
m_xmlRpcErrorResponse = GridManager.ErrorResponse(xmlRpcMessage);
}
public LoginException(string message, string xmlRpcMessage, Exception e) : base(message, e)
{
// FIXME: Might be neater to refactor and put the method inside here
m_xmlRpcErrorResponse = GridManager.ErrorResponse(xmlRpcMessage);
}
}
} }