2009-05-14 04:48:48 +00:00
|
|
|
using System;
|
|
|
|
|
using System.Collections.Generic;
|
2025-05-27 14:16:03 -05:00
|
|
|
using System.Linq;
|
2009-05-14 04:48:48 +00:00
|
|
|
using System.Threading;
|
|
|
|
|
|
|
|
|
|
namespace OpenMetaverse.TestClient
|
|
|
|
|
{
|
|
|
|
|
public class TaskRunningCommand : Command
|
|
|
|
|
{
|
|
|
|
|
public TaskRunningCommand(TestClient testClient)
|
|
|
|
|
{
|
|
|
|
|
Name = "taskrunning";
|
|
|
|
|
Description = "Retrieves or set IsRunning flag on items inside an object (task inventory). Usage: taskrunning objectID [[scriptName] true|false]";
|
|
|
|
|
Category = CommandCategory.Inventory;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public override string Execute(string[] args, UUID fromAgentID)
|
|
|
|
|
{
|
|
|
|
|
if (args.Length != 1)
|
2025-05-27 14:16:03 -05:00
|
|
|
{
|
2009-05-14 04:48:48 +00:00
|
|
|
return "Usage: taskrunning objectID [[scriptName] true|false]";
|
2025-05-27 14:16:03 -05:00
|
|
|
}
|
2009-05-14 04:48:48 +00:00
|
|
|
|
2025-05-27 14:16:03 -05:00
|
|
|
if (!UUID.TryParse(args[0], out var objectID))
|
|
|
|
|
{
|
2009-05-14 04:48:48 +00:00
|
|
|
return "Usage: taskrunning objectID [[scriptName] true|false]";
|
2025-05-27 14:16:03 -05:00
|
|
|
}
|
2009-05-14 04:48:48 +00:00
|
|
|
|
2025-05-27 14:16:03 -05:00
|
|
|
var found = Client.Network.CurrentSim.ObjectsPrimitives.FirstOrDefault(prim => prim.Value.ID == objectID);
|
|
|
|
|
if (found.Value == null)
|
|
|
|
|
{
|
|
|
|
|
return $"Couldn't find object {objectID}";
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
var objectLocalID = found.Value.LocalID;
|
2009-05-14 04:48:48 +00:00
|
|
|
|
2025-01-13 07:44:05 -06:00
|
|
|
List<InventoryBase> items = Client.Inventory.GetTaskInventory(objectID, objectLocalID, TimeSpan.FromSeconds(30));
|
2009-05-14 04:48:48 +00:00
|
|
|
|
2009-05-16 09:12:12 +00:00
|
|
|
//bool wantSet = false;
|
2009-05-14 04:48:48 +00:00
|
|
|
bool setTaskTo = false;
|
|
|
|
|
if (items != null)
|
|
|
|
|
{
|
2022-02-25 19:38:11 -06:00
|
|
|
string result = string.Empty;
|
|
|
|
|
string matching = string.Empty;
|
2009-05-14 04:48:48 +00:00
|
|
|
bool setAny = false;
|
|
|
|
|
if (args.Length > 1)
|
|
|
|
|
{
|
|
|
|
|
matching = args[1];
|
|
|
|
|
|
2022-02-25 19:38:11 -06:00
|
|
|
var tf = args.Length > 2 ? args[2] : matching.ToLower();
|
|
|
|
|
switch (tf)
|
2009-05-14 04:48:48 +00:00
|
|
|
{
|
2022-02-25 19:38:11 -06:00
|
|
|
case "true":
|
|
|
|
|
setAny = true;
|
|
|
|
|
setTaskTo = true;
|
|
|
|
|
break;
|
|
|
|
|
case "false":
|
|
|
|
|
setAny = true;
|
|
|
|
|
setTaskTo = false;
|
|
|
|
|
break;
|
2009-05-14 04:48:48 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
bool wasRunning = false;
|
|
|
|
|
|
2009-10-29 09:39:43 +00:00
|
|
|
EventHandler<ScriptRunningReplyEventArgs> callback;
|
2009-05-14 04:48:48 +00:00
|
|
|
using (AutoResetEvent OnScriptRunningReset = new AutoResetEvent(false))
|
|
|
|
|
{
|
2022-02-25 19:38:11 -06:00
|
|
|
callback = ((sender, e) =>
|
2009-05-14 04:48:48 +00:00
|
|
|
{
|
2009-10-29 09:39:43 +00:00
|
|
|
if (e.ObjectID == objectID)
|
2009-05-14 04:48:48 +00:00
|
|
|
{
|
2022-02-25 19:38:11 -06:00
|
|
|
result += $" IsMono: {e.IsMono} IsRunning: {e.IsRunning}";
|
2009-10-29 09:39:43 +00:00
|
|
|
wasRunning = e.IsRunning;
|
2009-05-14 04:48:48 +00:00
|
|
|
OnScriptRunningReset.Set();
|
|
|
|
|
}
|
|
|
|
|
});
|
|
|
|
|
|
2009-10-29 09:39:43 +00:00
|
|
|
Client.Inventory.ScriptRunningReply += callback;
|
2009-05-14 04:48:48 +00:00
|
|
|
|
2021-07-25 11:10:52 -05:00
|
|
|
foreach (var t in items)
|
2009-05-14 04:48:48 +00:00
|
|
|
{
|
2021-07-25 11:10:52 -05:00
|
|
|
if (t is InventoryFolder)
|
2009-05-14 04:48:48 +00:00
|
|
|
{
|
|
|
|
|
// this shouldn't happen this year
|
2021-07-25 11:10:52 -05:00
|
|
|
result += $"[Folder] Name: {t.Name}" + Environment.NewLine;
|
2009-05-14 04:48:48 +00:00
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
2021-07-25 11:10:52 -05:00
|
|
|
InventoryItem item = (InventoryItem)t;
|
2009-05-14 04:48:48 +00:00
|
|
|
AssetType assetType = item.AssetType;
|
2021-07-25 11:10:52 -05:00
|
|
|
result += $"[Item] Name: {item.Name} Desc: {item.Description} Type: {assetType}";
|
2009-05-14 04:48:48 +00:00
|
|
|
if (assetType == AssetType.LSLBytecode || assetType == AssetType.LSLText)
|
|
|
|
|
{
|
|
|
|
|
OnScriptRunningReset.Reset();
|
2009-10-29 09:39:43 +00:00
|
|
|
Client.Inventory.RequestGetScriptRunning(objectID, item.UUID);
|
2009-05-14 04:48:48 +00:00
|
|
|
if (!OnScriptRunningReset.WaitOne(10000, true))
|
|
|
|
|
{
|
|
|
|
|
result += " (no script info)";
|
|
|
|
|
}
|
|
|
|
|
if (setAny && item.Name.Contains(matching))
|
|
|
|
|
{
|
|
|
|
|
if (wasRunning != setTaskTo)
|
|
|
|
|
{
|
|
|
|
|
OnScriptRunningReset.Reset();
|
|
|
|
|
result += " Setting " + setTaskTo + " => ";
|
2009-10-29 09:39:43 +00:00
|
|
|
Client.Inventory.RequestSetScriptRunning(objectID, item.UUID, setTaskTo);
|
2009-05-14 04:48:48 +00:00
|
|
|
if (!OnScriptRunningReset.WaitOne(10000, true))
|
|
|
|
|
{
|
|
|
|
|
result += " (was not set)";
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
result += Environment.NewLine;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
2009-10-29 09:39:43 +00:00
|
|
|
Client.Inventory.ScriptRunningReply -= callback;
|
2009-05-14 04:48:48 +00:00
|
|
|
return result;
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
return "Failed to download task inventory for " + objectLocalID;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|