generated/api/Models/GetSetWindowsMssqlPatchingMsg.json.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 static Commvault.Powershell.Runtime.Extensions;

    /// <summary>Response message for install job options</summary>
    public partial class GetSetWindowsMssqlPatchingMsg
    {

        /// <summary>
        /// <c>AfterFromJson</c> will be called after the json 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="json">The JsonNode that should be deserialized into this object.</param>

        partial void AfterFromJson(Commvault.Powershell.Runtime.Json.JsonObject json);

        /// <summary>
        /// <c>AfterToJson</c> will be called after the json erialization has finished, allowing customization of the <see cref="Commvault.Powershell.Runtime.Json.JsonObject"
        /// /> before it is returned. Implement this method in a partial class to enable this behavior
        /// </summary>
        /// <param name="container">The JSON container that the serialization result will be placed in.</param>

        partial void AfterToJson(ref Commvault.Powershell.Runtime.Json.JsonObject container);

        /// <summary>
        /// <c>BeforeFromJson</c> will be called before the json 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="json">The JsonNode that should be deserialized into this object.</param>
        /// <param name="returnNow">Determines if the rest of the deserialization should be processed, or if the method should return
        /// instantly.</param>

        partial void BeforeFromJson(Commvault.Powershell.Runtime.Json.JsonObject json, ref bool returnNow);

        /// <summary>
        /// <c>BeforeToJson</c> will be called before the json serialization has commenced, allowing complete customization of the
        /// object before it is serialized.
        /// If you wish to disable the default serialization 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="container">The JSON container that the serialization result will be placed in.</param>
        /// <param name="returnNow">Determines if the rest of the serialization should be processed, or if the method should return
        /// instantly.</param>

        partial void BeforeToJson(ref Commvault.Powershell.Runtime.Json.JsonObject container, ref bool returnNow);

        /// <summary>
        /// Deserializes a <see cref="Commvault.Powershell.Runtime.Json.JsonNode"/> into an instance of Commvault.Powershell.Models.IGetSetWindowsMssqlPatchingMsg.
        /// </summary>
        /// <param name="node">a <see cref="Commvault.Powershell.Runtime.Json.JsonNode" /> to deserialize from.</param>
        /// <returns>an instance of Commvault.Powershell.Models.IGetSetWindowsMssqlPatchingMsg.</returns>
        public static Commvault.Powershell.Models.IGetSetWindowsMssqlPatchingMsg FromJson(Commvault.Powershell.Runtime.Json.JsonNode node)
        {
            return node is Commvault.Powershell.Runtime.Json.JsonObject json ? new GetSetWindowsMssqlPatchingMsg(json) : null;
        }

        /// <summary>
        /// Deserializes a Commvault.Powershell.Runtime.Json.JsonObject into a new instance of <see cref="GetSetWindowsMssqlPatchingMsg" />.
        /// </summary>
        /// <param name="json">A Commvault.Powershell.Runtime.Json.JsonObject instance to deserialize from.</param>
        internal GetSetWindowsMssqlPatchingMsg(Commvault.Powershell.Runtime.Json.JsonObject json)
        {
            bool returnNow = false;
            BeforeFromJson(json, ref returnNow);
            if (returnNow)
            {
                return;
            }
            {_option = If( json?.PropertyT<Commvault.Powershell.Runtime.Json.JsonNumber>("option"), out var __jsonOption) ? (long?)__jsonOption : Option;}
            {_clientId = If( json?.PropertyT<Commvault.Powershell.Runtime.Json.JsonNumber>("clientId"), out var __jsonClientId) ? (long?)__jsonClientId : ClientId;}
            {_mssqlPatching = If( json?.PropertyT<Commvault.Powershell.Runtime.Json.JsonNumber>("MSSQLPatching"), out var __jsonMssqlPatching) ? (long?)__jsonMssqlPatching : MssqlPatching;}
            {_windowsPatching = If( json?.PropertyT<Commvault.Powershell.Runtime.Json.JsonNumber>("WindowsPatching"), out var __jsonWindowsPatching) ? (long?)__jsonWindowsPatching : WindowsPatching;}
            {_unixOSPatching = If( json?.PropertyT<Commvault.Powershell.Runtime.Json.JsonNumber>("UnixOSPatching"), out var __jsonUnixOSPatching) ? (long?)__jsonUnixOSPatching : UnixOSPatching;}
            {_hyperScaleOSPatching = If( json?.PropertyT<Commvault.Powershell.Runtime.Json.JsonNumber>("HyperScaleOSPatching"), out var __jsonHyperScaleOSPatching) ? (long?)__jsonHyperScaleOSPatching : HyperScaleOSPatching;}
            {_hsxStorageUpdatesPatching = If( json?.PropertyT<Commvault.Powershell.Runtime.Json.JsonNumber>("HSXStorageUpdatesPatching"), out var __jsonHsxStorageUpdatesPatching) ? (long?)__jsonHsxStorageUpdatesPatching : HsxStorageUpdatesPatching;}
            {_diagsInCsCache = If( json?.PropertyT<Commvault.Powershell.Runtime.Json.JsonNumber>("DiagsInCSCache"), out var __jsonDiagsInCsCache) ? (long?)__jsonDiagsInCsCache : DiagsInCsCache;}
            {_eligibleForMssqlPatching = If( json?.PropertyT<Commvault.Powershell.Runtime.Json.JsonNumber>("EligibleForMSSQLPatching"), out var __jsonEligibleForMssqlPatching) ? (long?)__jsonEligibleForMssqlPatching : EligibleForMssqlPatching;}
            {_eligibleForWindowsOSPatching = If( json?.PropertyT<Commvault.Powershell.Runtime.Json.JsonNumber>("EligibleForWindowsOSPatching"), out var __jsonEligibleForWindowsOSPatching) ? (long?)__jsonEligibleForWindowsOSPatching : EligibleForWindowsOSPatching;}
            AfterFromJson(json);
        }

        /// <summary>
        /// Serializes this instance of <see cref="GetSetWindowsMssqlPatchingMsg" /> into a <see cref="Commvault.Powershell.Runtime.Json.JsonNode" />.
        /// </summary>
        /// <param name="container">The <see cref="Commvault.Powershell.Runtime.Json.JsonObject"/> container to serialize this object into. If the caller
        /// passes in <c>null</c>, a new instance will be created and returned to the caller.</param>
        /// <param name="serializationMode">Allows the caller to choose the depth of the serialization. See <see cref="Commvault.Powershell.Runtime.SerializationMode"/>.</param>
        /// <returns>
        /// a serialized instance of <see cref="GetSetWindowsMssqlPatchingMsg" /> as a <see cref="Commvault.Powershell.Runtime.Json.JsonNode" />.
        /// </returns>
        public Commvault.Powershell.Runtime.Json.JsonNode ToJson(Commvault.Powershell.Runtime.Json.JsonObject container, Commvault.Powershell.Runtime.SerializationMode serializationMode)
        {
            container = container ?? new Commvault.Powershell.Runtime.Json.JsonObject();

            bool returnNow = false;
            BeforeToJson(ref container, ref returnNow);
            if (returnNow)
            {
                return container;
            }
            AddIf( null != this._option ? (Commvault.Powershell.Runtime.Json.JsonNode)new Commvault.Powershell.Runtime.Json.JsonNumber((long)this._option) : null, "option" ,container.Add );
            AddIf( null != this._clientId ? (Commvault.Powershell.Runtime.Json.JsonNode)new Commvault.Powershell.Runtime.Json.JsonNumber((long)this._clientId) : null, "clientId" ,container.Add );
            AddIf( null != this._mssqlPatching ? (Commvault.Powershell.Runtime.Json.JsonNode)new Commvault.Powershell.Runtime.Json.JsonNumber((long)this._mssqlPatching) : null, "MSSQLPatching" ,container.Add );
            AddIf( null != this._windowsPatching ? (Commvault.Powershell.Runtime.Json.JsonNode)new Commvault.Powershell.Runtime.Json.JsonNumber((long)this._windowsPatching) : null, "WindowsPatching" ,container.Add );
            AddIf( null != this._unixOSPatching ? (Commvault.Powershell.Runtime.Json.JsonNode)new Commvault.Powershell.Runtime.Json.JsonNumber((long)this._unixOSPatching) : null, "UnixOSPatching" ,container.Add );
            AddIf( null != this._hyperScaleOSPatching ? (Commvault.Powershell.Runtime.Json.JsonNode)new Commvault.Powershell.Runtime.Json.JsonNumber((long)this._hyperScaleOSPatching) : null, "HyperScaleOSPatching" ,container.Add );
            AddIf( null != this._hsxStorageUpdatesPatching ? (Commvault.Powershell.Runtime.Json.JsonNode)new Commvault.Powershell.Runtime.Json.JsonNumber((long)this._hsxStorageUpdatesPatching) : null, "HSXStorageUpdatesPatching" ,container.Add );
            AddIf( null != this._diagsInCsCache ? (Commvault.Powershell.Runtime.Json.JsonNode)new Commvault.Powershell.Runtime.Json.JsonNumber((long)this._diagsInCsCache) : null, "DiagsInCSCache" ,container.Add );
            AddIf( null != this._eligibleForMssqlPatching ? (Commvault.Powershell.Runtime.Json.JsonNode)new Commvault.Powershell.Runtime.Json.JsonNumber((long)this._eligibleForMssqlPatching) : null, "EligibleForMSSQLPatching" ,container.Add );
            AddIf( null != this._eligibleForWindowsOSPatching ? (Commvault.Powershell.Runtime.Json.JsonNode)new Commvault.Powershell.Runtime.Json.JsonNumber((long)this._eligibleForWindowsOSPatching) : null, "EligibleForWindowsOSPatching" ,container.Add );
            AfterToJson(ref container);
            return container;
        }
    }
}