* Fixed a bug with null value handling in WebUtil.BuildQueryString()
* Changed the null check back in estate manager setup but fixed the case for an existing account being found * Implemented SetPassword() in the SimianGrid auth connectorslimupdates
parent
dd1c1b3bcd
commit
5a2315c68c
|
@ -263,9 +263,13 @@ namespace OpenSim.Framework
|
|||
|
||||
foreach (string key in parameters.Keys)
|
||||
{
|
||||
foreach (string value in parameters.GetValues(key))
|
||||
string[] values = parameters.GetValues(key);
|
||||
if (values != null)
|
||||
{
|
||||
foreach (string value in values)
|
||||
items.Add(String.Concat(key, "=", HttpUtility.UrlEncode(value ?? String.Empty)));
|
||||
}
|
||||
}
|
||||
|
||||
return String.Join("&", items.ToArray());
|
||||
}
|
||||
|
|
|
@ -1266,8 +1266,9 @@ namespace OpenSim.Region.Framework.Scenes
|
|||
|
||||
UserAccount account = UserAccountService.GetUserAccount(m_regInfo.ScopeID, first, last);
|
||||
|
||||
if (account != null)
|
||||
if (account == null)
|
||||
{
|
||||
// Create a new account
|
||||
account = new UserAccount(m_regInfo.ScopeID, first, last, String.Empty);
|
||||
if (account.ServiceURLs == null || (account.ServiceURLs != null && account.ServiceURLs.Count == 0))
|
||||
{
|
||||
|
@ -1325,7 +1326,8 @@ namespace OpenSim.Region.Framework.Scenes
|
|||
}
|
||||
else
|
||||
{
|
||||
MainConsole.Instance.Output("User account not found. Please enter the name of an existing user");
|
||||
m_regInfo.EstateSettings.EstateOwner = account.PrincipalID;
|
||||
m_regInfo.EstateSettings.Save();
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
|
@ -177,9 +177,46 @@ namespace OpenSim.Services.Connectors.SimianGrid
|
|||
|
||||
public bool SetPassword(UUID principalID, string passwd)
|
||||
{
|
||||
// TODO: Use GetIdentities to find the md5hash identity for principalID
|
||||
// and then update it with AddIdentity
|
||||
m_log.Error("[AUTH CONNECTOR]: Changing passwords is not implemented yet");
|
||||
// Fetch the user name first
|
||||
NameValueCollection requestArgs = new NameValueCollection
|
||||
{
|
||||
{ "RequestMethod", "GetUser" },
|
||||
{ "UserID", principalID.ToString() }
|
||||
};
|
||||
|
||||
OSDMap response = WebUtil.PostToService(m_serverUrl, requestArgs);
|
||||
if (response["Success"].AsBoolean() && response["User"] is OSDMap)
|
||||
{
|
||||
OSDMap userMap = (OSDMap)response["User"];
|
||||
string identifier = userMap["Name"].AsString();
|
||||
|
||||
if (!String.IsNullOrEmpty(identifier))
|
||||
{
|
||||
// Add/update the md5hash identity
|
||||
requestArgs = new NameValueCollection
|
||||
{
|
||||
{ "RequestMethod", "AddIdentity" },
|
||||
{ "Identifier", identifier },
|
||||
{ "Credential", "$1$" + Utils.MD5String(passwd) },
|
||||
{ "Type", "md5hash" },
|
||||
{ "UserID", principalID.ToString() }
|
||||
};
|
||||
|
||||
response = WebUtil.PostToService(m_serverUrl, requestArgs);
|
||||
bool success = response["Success"].AsBoolean();
|
||||
|
||||
if (!success)
|
||||
m_log.WarnFormat("[AUTH CONNECTOR]: Failed to set password for {0} ({1})", identifier, principalID);
|
||||
|
||||
return success;
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
m_log.Warn("[AUTH CONNECTOR]: Failed to retrieve identities for " + principalID + ": " +
|
||||
response["Message"].AsString());
|
||||
}
|
||||
|
||||
return false;
|
||||
}
|
||||
|
||||
|
|
Loading…
Reference in New Issue