* Made UpdateUserCurrentRegion a bit more forgiving.

0.6.0-stable
lbsa71 2008-05-31 20:01:09 +00:00
parent 01f933c273
commit ce234eee37
1 changed files with 36 additions and 10 deletions

View File

@ -205,9 +205,41 @@ namespace OpenSim.Region.Communications.OGS1
IList parameters = new ArrayList(); IList parameters = new ArrayList();
parameters.Add(param); parameters.Add(param);
XmlRpcRequest req = new XmlRpcRequest("update_user_current_region", parameters); XmlRpcRequest req = new XmlRpcRequest("update_user_current_region", parameters);
XmlRpcResponse resp = req.Send(m_parent.NetworkServersInfo.UserURL, 3000);
XmlRpcResponse resp;
try
{
resp = req.Send(m_parent.NetworkServersInfo.UserURL, 3000);
}
catch(WebException)
{
m_log.Warn("[OSG1 USER SERVICES]: Grid not responding. Retrying.");
try
{
resp = req.Send(m_parent.NetworkServersInfo.UserURL, 3000);
}
catch (WebException)
{
m_log.Warn("[OSG1 USER SERVICES]: Grid not responding. Failed.");
return;
}
}
if( resp == null )
{
m_log.Warn("[OSG1 USER SERVICES]: Got no response, Grid server may not be updated.");
return;
}
Hashtable respData = (Hashtable)resp.Value; Hashtable respData = (Hashtable)resp.Value;
if (respData.ContainsKey("returnString"))
if (respData == null || !respData.ContainsKey("returnString"))
{
m_log.Warn("[OSG1 USER SERVICES]: Error updating user record, Grid server may not be updated.");
}
else
{ {
if ((string) respData["returnString"] == "TRUE") if ((string) respData["returnString"] == "TRUE")
{ {
@ -218,12 +250,6 @@ namespace OpenSim.Region.Communications.OGS1
m_log.Error("[OSG1 USER SERVICES]: Error updating user record"); m_log.Error("[OSG1 USER SERVICES]: Error updating user record");
} }
} }
else
{
m_log.Warn("[OSG1 USER SERVICES]: Error updating user record, Grid server may not be updated.");
}
} }
public List<AvatarPickerAvatar> GenerateAgentPickerRequestResponse(LLUUID queryID, string query) public List<AvatarPickerAvatar> GenerateAgentPickerRequestResponse(LLUUID queryID, string query)