From 1f7873bbe1dfe39941ee8dbc6def87f8c825d49f Mon Sep 17 00:00:00 2001 From: Rory& Date: Sun, 11 Jan 2026 16:17:46 +0100 Subject: RoomUpgradeCLI work --- MatrixUtils.RoomUpgradeCLI/Commands/ExecuteCommand.cs | 11 ++++++++++- 1 file changed, 10 insertions(+), 1 deletion(-) (limited to 'MatrixUtils.RoomUpgradeCLI/Commands/ExecuteCommand.cs') diff --git a/MatrixUtils.RoomUpgradeCLI/Commands/ExecuteCommand.cs b/MatrixUtils.RoomUpgradeCLI/Commands/ExecuteCommand.cs index 41c8cca..ecc5fcd 100644 --- a/MatrixUtils.RoomUpgradeCLI/Commands/ExecuteCommand.cs +++ b/MatrixUtils.RoomUpgradeCLI/Commands/ExecuteCommand.cs @@ -1,5 +1,6 @@ using System.Text.Json; using System.Text.Json.Nodes; +using ArcaneLibs.Extensions; using LibMatrix.Helpers; using LibMatrix.Homeservers; @@ -11,6 +12,7 @@ public class ExecuteCommand(ILogger logger, IHost host, RuntimeC await PrintHelp(); return; } + var filename = ctx.Args[1]; if (filename.StartsWith("--")) { Console.WriteLine("Filename cannot start with --, please provide a valid filename."); @@ -37,14 +39,21 @@ public class ExecuteCommand(ILogger logger, IHost host, RuntimeC ? rbj.Deserialize() : rbj.Deserialize(); Console.WriteLine($"Executing room builder file of type {rb.GetType().Name}..."); + if (rb is RoomUpgradeBuilder { CanUpgrade: false } rub) { + Console.WriteLine("Warning: Import state has determined that you cannot upgrade this room."); + Console.WriteLine(rub.ToJson()); + return; + } + await rb!.Create(hs); } - + public async Task ExecuteDirectory(string dirName) { if (!Directory.Exists(dirName)) { Console.WriteLine($"Directory {dirName} does not exist."); return; } + var files = Directory.GetFiles(dirName, "*.json"); foreach (var file in files) { Console.WriteLine($"Executing file: {file}"); -- cgit 1.5.1