99 lines
No EOL
3.4 KiB
C#
99 lines
No EOL
3.4 KiB
C#
using Microsoft.Extensions.Logging;
|
|
using System.Management.Automation;
|
|
using System.Management.Automation.Runspaces;
|
|
|
|
namespace Insight.Agent.Services;
|
|
|
|
public class ScriptService(ILogger<ScriptService> logger)
|
|
{
|
|
private readonly ILogger<ScriptService> _logger = logger;
|
|
|
|
public async Task<QueryResult> QueryAsync(string query)
|
|
{
|
|
_logger.LogDebug("QueryAsync ({query})", query);
|
|
|
|
var result = new QueryResult();
|
|
var errors = new List<string>();
|
|
|
|
try
|
|
{
|
|
using var runspace = RunspaceFactory.CreateRunspace();
|
|
runspace.Open();
|
|
runspace.SessionStateProxy.LanguageMode = PSLanguageMode.FullLanguage;
|
|
|
|
using var ps = PowerShell.Create(runspace);
|
|
ps.AddScript("Set-ExecutionPolicy unrestricted -Scope Process");
|
|
ps.AddScript(query);
|
|
//ps.AddCommand("ConvertTo-Json"); // -Depth 10
|
|
|
|
result.Query = query;
|
|
|
|
var queryResult = await ps.InvokeAsync();
|
|
|
|
if (ps.HadErrors)
|
|
{
|
|
result.HadErrors = true;
|
|
errors.AddRange(ps.Streams.Error.Select(e => e.ToString()));
|
|
}
|
|
else
|
|
{
|
|
var newLine = false;
|
|
|
|
foreach (var data in queryResult)
|
|
{
|
|
if (newLine) result.Data += "\n";
|
|
else newLine = true;
|
|
|
|
result.Data += data.ToString();
|
|
}
|
|
|
|
//if (string.IsNullOrWhiteSpace(jsonString)) return result;
|
|
|
|
//if (jsonString.TrimStart().StartsWith("[")) // It's an array
|
|
//{
|
|
// result.IsArray = true;
|
|
|
|
// var deserialized = JsonSerializer.Deserialize<List<Dictionary<string, object?>>>(jsonString, new JsonSerializerOptions { Encoder = JavaScriptEncoder.UnsafeRelaxedJsonEscaping });
|
|
// if (deserialized is null) return result;
|
|
|
|
// result.Data.AddRange(deserialized);
|
|
|
|
// //Console.WriteLine("Deserialized to List<Dictionary<string, object>>");
|
|
//}
|
|
//else
|
|
//{
|
|
// if (jsonString.TrimStart().StartsWith("{") is false) // It's an object
|
|
// {
|
|
// result.IsString = true;
|
|
// result.Data.Add(new Dictionary<string, object?> { { query, jsonString.Trim('"') } });
|
|
// }
|
|
// else
|
|
// {
|
|
// var deserialized = JsonSerializer.Deserialize<Dictionary<string, object?>>(jsonString, new JsonSerializerOptions { Encoder = JavaScriptEncoder.UnsafeRelaxedJsonEscaping });
|
|
// if (deserialized is null) return result;
|
|
|
|
// result.Data.Add(deserialized);
|
|
|
|
// //Console.WriteLine("Deserialized to Dictionary<string, object>");
|
|
// }
|
|
//}
|
|
}
|
|
}
|
|
catch (Exception ex)
|
|
{
|
|
result.HadErrors = true;
|
|
errors.Add(ex.Message);
|
|
}
|
|
|
|
result.Errors = string.Join("\n", errors);
|
|
return result;
|
|
}
|
|
|
|
public class QueryResult
|
|
{
|
|
public bool HadErrors { get; set; }
|
|
public string? Query { get; set; }
|
|
public string? Data { get; set; }
|
|
public string? Errors { get; set; }
|
|
}
|
|
} |