From c499c39952dd0c932763181c1eb5e146c5598cbb Mon Sep 17 00:00:00 2001 From: Konstantin Tyukalov Date: Thu, 19 Sep 2024 19:44:29 +0400 Subject: [PATCH] Add wmi util --- src/Agent.Sdk/Util/WmiUtil.cs | 48 +++++++++++++++++++++++++++++++++++ 1 file changed, 48 insertions(+) create mode 100644 src/Agent.Sdk/Util/WmiUtil.cs diff --git a/src/Agent.Sdk/Util/WmiUtil.cs b/src/Agent.Sdk/Util/WmiUtil.cs new file mode 100644 index 0000000000..937b814f8e --- /dev/null +++ b/src/Agent.Sdk/Util/WmiUtil.cs @@ -0,0 +1,48 @@ + +using System.Management; +using System.Runtime.Versioning; + +namespace Agent.Sdk.Util; + +[SupportedOSPlatform("windows")] +public class WmiUtil +{ + public static Task> QueryGet(string query, CancellationToken cancellationToken) + { + var output = new List(); + var comletetionSource = new TaskCompletionSource>(); + + var observer = new ManagementOperationObserver(); + observer.ObjectReady += (sender, obj) => + { + output.Add(obj.NewObject); + }; + observer.Completed += (sender, e) => + { + switch (e.Status) + { + case ManagementStatus.CallCanceled: + comletetionSource.SetCanceled(cancellationToken); + break; + + case ManagementStatus.NoError: + comletetionSource.SetResult(output); + break; + + default: + comletetionSource.SetException(new Exception($"WMI Get Query failed with status {e.Status}")); + break; + } + }; + + cancellationToken.Register(() => + { + observer.Cancel(); + }); + + using var searcher = new ManagementObjectSearcher(query); + searcher.Get(observer); + + return comletetionSource.Task; + } +}