Functions/GenXdev.Helpers/ExposedCmdletDefinitions.cs
// ################################################################################
// Part of PowerShell module : GenXdev.Helpers // Original cmdlet filename : ExposedCmdletDefinitions.cs // Original author : René Vaessen / GenXdev // Version : 2.0.2025 // ################################################################################ // Copyright (c) René Vaessen / GenXdev // // Licensed under the Apache License, Version 2.0 (the "License"); // you may not use this file except in compliance with the License. // You may obtain a copy of the License at // // http://www.apache.org/licenses/LICENSE-2.0 // // Unless required by applicable law or agreed to in writing, software // distributed under the License is distributed on an "AS IS" BASIS, // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. // See the License for the specific language governing permissions and // limitations under the License. // ################################################################################ using System.Collections; namespace GenXdev.Helpers { /// <summary> /// Represents an error that occurred during a tool call invocation. /// This class encapsulates details about invocation failures, including /// the error message, whether an exception was thrown, and the exception type. /// </summary> public class ExposedToolCallInvocationError { /// <summary> /// Gets or sets the error message describing what went wrong during the invocation. /// </summary> public string error { get; set; } = null; /// <summary> /// Gets or sets a value indicating whether an exception was thrown during the invocation. /// </summary> public bool exceptionThrown { get; set; } = false; /// <summary> /// Gets or sets the class name of the exception that was thrown, if any. /// </summary> public string exceptionClass { get; set; } = null; } /// <summary> /// Represents the result of a tool call invocation, including success status, /// output data, and metadata about the invoked command. /// This class provides comprehensive information about the execution outcome. /// </summary> public class ExposedToolCallInvocationResult { /// <summary> /// Gets or sets a value indicating whether the command was successfully exposed and invoked. /// </summary> public bool CommandExposed { get; set; } = false; /// <summary> /// Gets or sets the reason for the invocation result, such as success or failure details. /// </summary> public string Reason { get; set; } = null; /// <summary> /// Gets or sets the output generated by the invoked command. /// </summary> public string Output { get; set; } = null; /// <summary> /// Gets or sets the full name of the invoked command or cmdlet. /// </summary> public string FullName { get; set; } = null; /// <summary> /// Gets or sets the type of the output returned by the command. /// </summary> public string OutputType { get; set; } = null; /// <summary> /// Gets or sets a hashtable containing all unfiltered arguments passed to the command. /// </summary> public System.Collections.Hashtable UnfilteredArguments { get; set; } = new Hashtable(); /// <summary> /// Gets or sets a hashtable containing the filtered arguments that were actually used by the command. /// </summary> public System.Collections.Hashtable FilteredArguments { get; set; } = new Hashtable(); /// <summary> /// Gets or sets the definition of the exposed cmdlet that was invoked. /// </summary> public ExposedCmdletDefinition ExposedCmdLet { get; set; } = null; /// <summary> /// Gets or sets any error message associated with the invocation, if it failed. /// </summary> public string Error { get; set; } = null; } /// <summary> /// Represents a parameter that is forced to a specific value in a cmdlet definition. /// This allows predefined parameter values to be enforced during command exposure. /// </summary> public class ExposedForcedCmdLetParameter { /// <summary> /// Gets or sets the name of the parameter that is being forced. /// </summary> public string Name { get; set; } /// <summary> /// Gets or sets the value that the parameter is forced to have. /// </summary> public object Value { get; set; } } /// <summary> /// Defines the configuration for exposing a PowerShell cmdlet through the MCP server. /// This class contains metadata about the cmdlet, including its name, description, /// allowed parameters, and various configuration options for exposure. /// </summary> public class ExposedCmdletDefinition { /// <summary> /// Gets or sets the name of the cmdlet being exposed. /// </summary> public string Name { get; set; } /// <summary> /// Gets or sets a description of what the cmdlet does. /// </summary> public string Description { get; set; } /// <summary> /// Gets or sets a list of parameter names that are allowed to be passed to the cmdlet. /// </summary> public List<string> AllowedParams { get; set; } = new List<string>(); /// <summary> /// Gets or sets a list of parameter names that should not be shown during confirmation prompts. /// </summary> public List<string> DontShowDuringConfirmationParamNames { get; set; } = new List<string>(); /// <summary> /// Gets or sets a list of parameters that are forced to specific values. /// </summary> public List<ExposedForcedCmdLetParameter> ForcedParams { get; set; } = new List<ExposedForcedCmdLetParameter>(); /// <summary> /// Gets or sets the maximum depth for JSON serialization of the cmdlet's output. /// </summary> public int JsonDepth { get; set; } = 2; /// <summary> /// Gets or sets a value indicating whether the output should be returned as text. /// </summary> public bool OutputText { get; set; } = true; /// <summary> /// Gets or sets a value indicating whether user confirmation is required before executing the cmdlet. /// </summary> public bool Confirm { get; set; } = true; } } |