generated/api/Models/PermissionResp.PowerShell.cs

// Code generated by Microsoft (R) AutoRest Code Generator (autorest: 3.9.4, generator: @autorest/powershell@3.0.415)
// Changes may cause incorrect behavior and will be lost if the code is regenerated.

namespace Commvault.Powershell.Models
{
    using Commvault.Powershell.Runtime.PowerShell;

    /// <summary>
    /// List of permissions associated with the entity. Either categoryId and categoryName or permissionId and permissionName
    /// will be returned. If categoryId or categoryName is returned, all the corresponding permissions in the category are associated
    /// with the entity.
    /// </summary>
    [System.ComponentModel.TypeConverter(typeof(PermissionRespTypeConverter))]
    public partial class PermissionResp
    {

        /// <summary>
        /// <c>AfterDeserializeDictionary</c> will be called after the deserialization has finished, allowing customization of the
        /// object before it is returned. Implement this method in a partial class to enable this behavior
        /// </summary>
        /// <param name="content">The global::System.Collections.IDictionary content that should be used.</param>

        partial void AfterDeserializeDictionary(global::System.Collections.IDictionary content);

        /// <summary>
        /// <c>AfterDeserializePSObject</c> will be called after the deserialization has finished, allowing customization of the object
        /// before it is returned. Implement this method in a partial class to enable this behavior
        /// </summary>
        /// <param name="content">The global::System.Management.Automation.PSObject content that should be used.</param>

        partial void AfterDeserializePSObject(global::System.Management.Automation.PSObject content);

        /// <summary>
        /// <c>BeforeDeserializeDictionary</c> will be called before the deserialization has commenced, allowing complete customization
        /// of the object before it is deserialized.
        /// If you wish to disable the default deserialization entirely, return <c>true</c> in the <see "returnNow" /> output parameter.
        /// Implement this method in a partial class to enable this behavior.
        /// </summary>
        /// <param name="content">The global::System.Collections.IDictionary content that should be used.</param>
        /// <param name="returnNow">Determines if the rest of the serialization should be processed, or if the method should return
        /// instantly.</param>

        partial void BeforeDeserializeDictionary(global::System.Collections.IDictionary content, ref bool returnNow);

        /// <summary>
        /// <c>BeforeDeserializePSObject</c> will be called before the deserialization has commenced, allowing complete customization
        /// of the object before it is deserialized.
        /// If you wish to disable the default deserialization entirely, return <c>true</c> in the <see "returnNow" /> output parameter.
        /// Implement this method in a partial class to enable this behavior.
        /// </summary>
        /// <param name="content">The global::System.Management.Automation.PSObject content that should be used.</param>
        /// <param name="returnNow">Determines if the rest of the serialization should be processed, or if the method should return
        /// instantly.</param>

        partial void BeforeDeserializePSObject(global::System.Management.Automation.PSObject content, ref bool returnNow);

        /// <summary>
        /// Deserializes a <see cref="global::System.Collections.IDictionary" /> into an instance of <see cref="Commvault.Powershell.Models.PermissionResp"
        /// />.
        /// </summary>
        /// <param name="content">The global::System.Collections.IDictionary content that should be used.</param>
        /// <returns>an instance of <see cref="Commvault.Powershell.Models.IPermissionResp" />.</returns>
        public static Commvault.Powershell.Models.IPermissionResp DeserializeFromDictionary(global::System.Collections.IDictionary content)
        {
            return new PermissionResp(content);
        }

        /// <summary>
        /// Deserializes a <see cref="global::System.Management.Automation.PSObject" /> into an instance of <see cref="Commvault.Powershell.Models.PermissionResp"
        /// />.
        /// </summary>
        /// <param name="content">The global::System.Management.Automation.PSObject content that should be used.</param>
        /// <returns>an instance of <see cref="Commvault.Powershell.Models.IPermissionResp" />.</returns>
        public static Commvault.Powershell.Models.IPermissionResp DeserializeFromPSObject(global::System.Management.Automation.PSObject content)
        {
            return new PermissionResp(content);
        }

        /// <summary>
        /// Creates a new instance of <see cref="PermissionResp" />, deserializing the content from a json string.
        /// </summary>
        /// <param name="jsonText">a string containing a JSON serialized instance of this model.</param>
        /// <returns>an instance of the <see cref="className" /> model class.</returns>
        public static Commvault.Powershell.Models.IPermissionResp FromJsonString(string jsonText) => FromJson(Commvault.Powershell.Runtime.Json.JsonNode.Parse(jsonText));

        /// <summary>
        /// Deserializes a <see cref="global::System.Collections.IDictionary" /> into a new instance of <see cref="Commvault.Powershell.Models.PermissionResp"
        /// />.
        /// </summary>
        /// <param name="content">The global::System.Collections.IDictionary content that should be used.</param>
        internal PermissionResp(global::System.Collections.IDictionary content)
        {
            bool returnNow = false;
            BeforeDeserializeDictionary(content, ref returnNow);
            if (returnNow)
            {
                return;
            }
            // actually deserialize
            ((Commvault.Powershell.Models.IPermissionRespInternal)this).PermissionId = (long?) content.GetValueForProperty("PermissionId",((Commvault.Powershell.Models.IPermissionRespInternal)this).PermissionId, (__y)=> (long) global::System.Convert.ChangeType(__y, typeof(long)));
            ((Commvault.Powershell.Models.IPermissionRespInternal)this).PermissionName = (string) content.GetValueForProperty("PermissionName",((Commvault.Powershell.Models.IPermissionRespInternal)this).PermissionName, global::System.Convert.ToString);
            ((Commvault.Powershell.Models.IPermissionRespInternal)this).CategoryId = (long?) content.GetValueForProperty("CategoryId",((Commvault.Powershell.Models.IPermissionRespInternal)this).CategoryId, (__y)=> (long) global::System.Convert.ChangeType(__y, typeof(long)));
            ((Commvault.Powershell.Models.IPermissionRespInternal)this).CategoryName = (string) content.GetValueForProperty("CategoryName",((Commvault.Powershell.Models.IPermissionRespInternal)this).CategoryName, global::System.Convert.ToString);
            ((Commvault.Powershell.Models.IPermissionRespInternal)this).Type = (string) content.GetValueForProperty("Type",((Commvault.Powershell.Models.IPermissionRespInternal)this).Type, global::System.Convert.ToString);
            ((Commvault.Powershell.Models.IPermissionRespInternal)this).Exclude = (bool?) content.GetValueForProperty("Exclude",((Commvault.Powershell.Models.IPermissionRespInternal)this).Exclude, (__y)=> (bool) global::System.Convert.ChangeType(__y, typeof(bool)));
            AfterDeserializeDictionary(content);
        }

        /// <summary>
        /// Deserializes a <see cref="global::System.Management.Automation.PSObject" /> into a new instance of <see cref="Commvault.Powershell.Models.PermissionResp"
        /// />.
        /// </summary>
        /// <param name="content">The global::System.Management.Automation.PSObject content that should be used.</param>
        internal PermissionResp(global::System.Management.Automation.PSObject content)
        {
            bool returnNow = false;
            BeforeDeserializePSObject(content, ref returnNow);
            if (returnNow)
            {
                return;
            }
            // actually deserialize
            ((Commvault.Powershell.Models.IPermissionRespInternal)this).PermissionId = (long?) content.GetValueForProperty("PermissionId",((Commvault.Powershell.Models.IPermissionRespInternal)this).PermissionId, (__y)=> (long) global::System.Convert.ChangeType(__y, typeof(long)));
            ((Commvault.Powershell.Models.IPermissionRespInternal)this).PermissionName = (string) content.GetValueForProperty("PermissionName",((Commvault.Powershell.Models.IPermissionRespInternal)this).PermissionName, global::System.Convert.ToString);
            ((Commvault.Powershell.Models.IPermissionRespInternal)this).CategoryId = (long?) content.GetValueForProperty("CategoryId",((Commvault.Powershell.Models.IPermissionRespInternal)this).CategoryId, (__y)=> (long) global::System.Convert.ChangeType(__y, typeof(long)));
            ((Commvault.Powershell.Models.IPermissionRespInternal)this).CategoryName = (string) content.GetValueForProperty("CategoryName",((Commvault.Powershell.Models.IPermissionRespInternal)this).CategoryName, global::System.Convert.ToString);
            ((Commvault.Powershell.Models.IPermissionRespInternal)this).Type = (string) content.GetValueForProperty("Type",((Commvault.Powershell.Models.IPermissionRespInternal)this).Type, global::System.Convert.ToString);
            ((Commvault.Powershell.Models.IPermissionRespInternal)this).Exclude = (bool?) content.GetValueForProperty("Exclude",((Commvault.Powershell.Models.IPermissionRespInternal)this).Exclude, (__y)=> (bool) global::System.Convert.ChangeType(__y, typeof(bool)));
            AfterDeserializePSObject(content);
        }

        /// <summary>Serializes this instance to a json string.</summary>

        /// <returns>a <see cref="System.String" /> containing this model serialized to JSON text.</returns>
        public string ToJsonString() => ToJson(null, Commvault.Powershell.Runtime.SerializationMode.IncludeAll)?.ToString();
    }
    /// List of permissions associated with the entity. Either categoryId and categoryName or permissionId and permissionName
    /// will be returned. If categoryId or categoryName is returned, all the corresponding permissions in the category are associated
    /// with the entity.
    [System.ComponentModel.TypeConverter(typeof(PermissionRespTypeConverter))]
    public partial interface IPermissionResp

    {

    }
}