cloneprofile command to use AvatarManager.RequestAgentProfile()
This commit is contained in:
@@ -6,18 +6,17 @@ namespace OpenMetaverse.TestClient
|
|||||||
{
|
{
|
||||||
public class CloneProfileCommand : Command
|
public class CloneProfileCommand : Command
|
||||||
{
|
{
|
||||||
Avatar.AvatarProperties Properties;
|
private Avatar.AvatarProperties Properties;
|
||||||
Avatar.Interests Interests;
|
private Avatar.Interests Interests;
|
||||||
List<UUID> Groups = new List<UUID>();
|
private readonly List<UUID> Groups = new List<UUID>();
|
||||||
bool ReceivedProperties = false;
|
private bool ReceivedProfile = false;
|
||||||
bool ReceivedInterests = false;
|
private bool ReceivedInterests = false;
|
||||||
bool ReceivedGroups = false;
|
private bool ReceivedGroups = false;
|
||||||
ManualResetEvent ReceivedProfileEvent = new ManualResetEvent(false);
|
private readonly ManualResetEvent ReceivedProfileEvent = new ManualResetEvent(false);
|
||||||
|
|
||||||
public CloneProfileCommand(TestClient testClient)
|
public CloneProfileCommand(TestClient testClient)
|
||||||
{
|
{
|
||||||
testClient.Avatars.AvatarInterestsReply += Avatars_AvatarInterestsReply;
|
testClient.Avatars.AvatarInterestsReply += Avatars_AvatarInterestsReply;
|
||||||
testClient.Avatars.AvatarPropertiesReply += Avatars_AvatarPropertiesReply;
|
|
||||||
testClient.Avatars.AvatarGroupsReply += Avatars_AvatarGroupsReply;
|
testClient.Avatars.AvatarGroupsReply += Avatars_AvatarGroupsReply;
|
||||||
testClient.Groups.GroupJoinedReply += Groups_OnGroupJoined;
|
testClient.Groups.GroupJoinedReply += Groups_OnGroupJoined;
|
||||||
testClient.Avatars.AvatarPicksReply += Avatars_AvatarPicksReply;
|
testClient.Avatars.AvatarPicksReply += Avatars_AvatarPicksReply;
|
||||||
@@ -31,11 +30,9 @@ namespace OpenMetaverse.TestClient
|
|||||||
|
|
||||||
public override string Execute(string[] args, UUID fromAgentID)
|
public override string Execute(string[] args, UUID fromAgentID)
|
||||||
{
|
{
|
||||||
if (args.Length != 1)
|
if (args.Length != 1) { return Description; }
|
||||||
return Description;
|
|
||||||
|
|
||||||
UUID targetID;
|
UUID targetID;
|
||||||
ReceivedProperties = false;
|
|
||||||
ReceivedInterests = false;
|
ReceivedInterests = false;
|
||||||
ReceivedGroups = false;
|
ReceivedGroups = false;
|
||||||
|
|
||||||
@@ -48,10 +45,26 @@ namespace OpenMetaverse.TestClient
|
|||||||
return Description;
|
return Description;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Request all of the packets that make up an avatar profile
|
// Request all packets that make up an avatar profile
|
||||||
Client.Avatars.RequestAvatarProperties(targetID);
|
Client.Avatars.RequestAgentProfile(targetID, (success, profile) =>
|
||||||
|
{
|
||||||
|
if (success)
|
||||||
|
{
|
||||||
|
ReceivedProfile = true;
|
||||||
|
Properties = new Avatar.AvatarProperties
|
||||||
|
{
|
||||||
|
AboutText = profile.SecondLifeAboutText,
|
||||||
|
FirstLifeText = profile.FirstLifeAboutText,
|
||||||
|
ProfileImage = profile.SecondLifeImageID,
|
||||||
|
FirstLifeImage = profile.FirstLifeImageID,
|
||||||
|
ProfileURL = profile.HomePage,
|
||||||
|
AllowPublish = true,
|
||||||
|
MaturePublish = profile.IsMatureProfile
|
||||||
|
};
|
||||||
|
}
|
||||||
|
}).Wait(TimeSpan.FromSeconds(5));
|
||||||
|
|
||||||
//Request all of the avatars pics
|
//Request all avatars pics
|
||||||
Client.Avatars.RequestAvatarPicks(Client.Self.AgentID);
|
Client.Avatars.RequestAvatarPicks(Client.Self.AgentID);
|
||||||
Client.Avatars.RequestAvatarPicks(targetID);
|
Client.Avatars.RequestAvatarPicks(targetID);
|
||||||
|
|
||||||
@@ -60,8 +73,10 @@ namespace OpenMetaverse.TestClient
|
|||||||
ReceivedProfileEvent.WaitOne(TimeSpan.FromSeconds(5), false);
|
ReceivedProfileEvent.WaitOne(TimeSpan.FromSeconds(5), false);
|
||||||
|
|
||||||
// Check if everything showed up
|
// Check if everything showed up
|
||||||
if (!ReceivedInterests || !ReceivedProperties || !ReceivedGroups)
|
if (!ReceivedProfile || !ReceivedInterests || !ReceivedGroups)
|
||||||
|
{
|
||||||
return "Failed to retrieve a complete profile for that UUID";
|
return "Failed to retrieve a complete profile for that UUID";
|
||||||
|
}
|
||||||
|
|
||||||
// Synchronize our profile
|
// Synchronize our profile
|
||||||
Client.Self.UpdateInterests(Interests);
|
Client.Self.UpdateInterests(Interests);
|
||||||
@@ -76,28 +91,28 @@ namespace OpenMetaverse.TestClient
|
|||||||
Client.Groups.RequestJoinGroup(groupID);
|
Client.Groups.RequestJoinGroup(groupID);
|
||||||
}
|
}
|
||||||
|
|
||||||
return "Synchronized our profile to the profile of " + targetID;
|
return $"Synchronized our profile to the profile of {targetID}";
|
||||||
}
|
}
|
||||||
|
|
||||||
void Groups_OnGroupJoined(object sender, GroupOperationEventArgs e)
|
private void Groups_OnGroupJoined(object sender, GroupOperationEventArgs e)
|
||||||
{
|
{
|
||||||
Console.WriteLine(Client + (e.Success ? " joined " : " failed to join ") +
|
Console.WriteLine(Client + (e.Success ? " joined " : " failed to join ") +
|
||||||
e.GroupID);
|
e.GroupID);
|
||||||
|
|
||||||
if (e.Success)
|
if (e.Success)
|
||||||
{
|
{
|
||||||
Console.WriteLine(Client + " setting " + e.GroupID +
|
Console.WriteLine($"{Client} setting {e.GroupID} as the active group");
|
||||||
" as the active group");
|
|
||||||
Client.Groups.ActivateGroup(e.GroupID);
|
Client.Groups.ActivateGroup(e.GroupID);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void Avatars_PickInfoReply(object sender, PickInfoReplyEventArgs e)
|
private void Avatars_PickInfoReply(object sender, PickInfoReplyEventArgs e)
|
||||||
{
|
{
|
||||||
Client.Self.PickInfoUpdate(e.PickID, e.Pick.TopPick, e.Pick.ParcelID, e.Pick.Name, e.Pick.PosGlobal, e.Pick.SnapshotID, e.Pick.Desc);
|
Client.Self.PickInfoUpdate(e.PickID, e.Pick.TopPick, e.Pick.ParcelID, e.Pick.Name, e.Pick.PosGlobal,
|
||||||
|
e.Pick.SnapshotID, e.Pick.Desc);
|
||||||
}
|
}
|
||||||
|
|
||||||
void Avatars_AvatarPicksReply(object sender, AvatarPicksReplyEventArgs e)
|
private void Avatars_AvatarPicksReply(object sender, AvatarPicksReplyEventArgs e)
|
||||||
{
|
{
|
||||||
foreach (KeyValuePair<UUID, string> kvp in e.Picks)
|
foreach (KeyValuePair<UUID, string> kvp in e.Picks)
|
||||||
{
|
{
|
||||||
@@ -112,7 +127,7 @@ namespace OpenMetaverse.TestClient
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void Avatars_AvatarGroupsReply(object sender, AvatarGroupsReplyEventArgs e)
|
private void Avatars_AvatarGroupsReply(object sender, AvatarGroupsReplyEventArgs e)
|
||||||
{
|
{
|
||||||
lock (ReceivedProfileEvent)
|
lock (ReceivedProfileEvent)
|
||||||
{
|
{
|
||||||
@@ -123,31 +138,19 @@ namespace OpenMetaverse.TestClient
|
|||||||
|
|
||||||
ReceivedGroups = true;
|
ReceivedGroups = true;
|
||||||
|
|
||||||
if (ReceivedInterests && ReceivedProperties && ReceivedGroups)
|
if (ReceivedInterests && ReceivedGroups)
|
||||||
ReceivedProfileEvent.Set();
|
ReceivedProfileEvent.Set();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void Avatars_AvatarPropertiesReply(object sender, AvatarPropertiesReplyEventArgs e)
|
private void Avatars_AvatarInterestsReply(object sender, AvatarInterestsReplyEventArgs e)
|
||||||
{
|
|
||||||
lock (ReceivedProfileEvent)
|
|
||||||
{
|
|
||||||
Properties = e.Properties;
|
|
||||||
ReceivedProperties = true;
|
|
||||||
|
|
||||||
if (ReceivedInterests && ReceivedProperties && ReceivedGroups)
|
|
||||||
ReceivedProfileEvent.Set();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void Avatars_AvatarInterestsReply(object sender, AvatarInterestsReplyEventArgs e)
|
|
||||||
{
|
{
|
||||||
lock (ReceivedProfileEvent)
|
lock (ReceivedProfileEvent)
|
||||||
{
|
{
|
||||||
Interests = e.Interests;
|
Interests = e.Interests;
|
||||||
ReceivedInterests = true;
|
ReceivedInterests = true;
|
||||||
|
|
||||||
if (ReceivedInterests && ReceivedProperties && ReceivedGroups)
|
if (ReceivedInterests && ReceivedGroups)
|
||||||
ReceivedProfileEvent.Set();
|
ReceivedProfileEvent.Set();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user