generated/api/Models/VMConnectionDetails.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>VMConnectionDetails</summary>
    public partial class VMConnectionDetails
    {

        /// <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.IVMConnectionDetails.
        /// </summary>
        /// <param name="node">a <see cref="Commvault.Powershell.Runtime.Json.JsonNode" /> to deserialize from.</param>
        /// <returns>an instance of Commvault.Powershell.Models.IVMConnectionDetails.</returns>
        public static Commvault.Powershell.Models.IVMConnectionDetails FromJson(Commvault.Powershell.Runtime.Json.JsonNode node)
        {
            return node is Commvault.Powershell.Runtime.Json.JsonObject json ? new VMConnectionDetails(json) : null;
        }

        /// <summary>
        /// Serializes this instance of <see cref="VMConnectionDetails" /> 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="VMConnectionDetails" /> 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._guestCreds ? (Commvault.Powershell.Runtime.Json.JsonNode) this._guestCreds.ToJson(null,serializationMode) : null, "guestCreds" ,container.Add );
            AddIf( null != this._csCreds ? (Commvault.Powershell.Runtime.Json.JsonNode) this._csCreds.ToJson(null,serializationMode) : null, "csCreds" ,container.Add );
            AddIf( null != this._topologyDetails ? (Commvault.Powershell.Runtime.Json.JsonNode) this._topologyDetails.ToJson(null,serializationMode) : null, "topologyDetails" ,container.Add );
            AddIf( null != this._domainCreds ? (Commvault.Powershell.Runtime.Json.JsonNode) this._domainCreds.ToJson(null,serializationMode) : null, "domainCreds" ,container.Add );
            AddIf( null != (((object)this._vMHostName)?.ToString()) ? (Commvault.Powershell.Runtime.Json.JsonNode) new Commvault.Powershell.Runtime.Json.JsonString(this._vMHostName.ToString()) : null, "vmHostName" ,container.Add );
            AddIf( null != (((object)this._vMClientName)?.ToString()) ? (Commvault.Powershell.Runtime.Json.JsonNode) new Commvault.Powershell.Runtime.Json.JsonString(this._vMClientName.ToString()) : null, "vmClientName" ,container.Add );
            AfterToJson(ref container);
            return container;
        }

        /// <summary>
        /// Deserializes a Commvault.Powershell.Runtime.Json.JsonObject into a new instance of <see cref="VMConnectionDetails" />.
        /// </summary>
        /// <param name="json">A Commvault.Powershell.Runtime.Json.JsonObject instance to deserialize from.</param>
        internal VMConnectionDetails(Commvault.Powershell.Runtime.Json.JsonObject json)
        {
            bool returnNow = false;
            BeforeFromJson(json, ref returnNow);
            if (returnNow)
            {
                return;
            }
            {_guestCreds = If( json?.PropertyT<Commvault.Powershell.Runtime.Json.JsonObject>("guestCreds"), out var __jsonGuestCreds) ? Commvault.Powershell.Models.GuestCredentialInfo.FromJson(__jsonGuestCreds) : GuestCreds;}
            {_csCreds = If( json?.PropertyT<Commvault.Powershell.Runtime.Json.JsonObject>("csCreds"), out var __jsonCsCreds) ? Commvault.Powershell.Models.GuestCredentialInfo.FromJson(__jsonCsCreds) : CsCreds;}
            {_topologyDetails = If( json?.PropertyT<Commvault.Powershell.Runtime.Json.JsonObject>("topologyDetails"), out var __jsonTopologyDetails) ? Commvault.Powershell.Models.VMTopologyDetails.FromJson(__jsonTopologyDetails) : TopologyDetails;}
            {_domainCreds = If( json?.PropertyT<Commvault.Powershell.Runtime.Json.JsonObject>("domainCreds"), out var __jsonDomainCreds) ? Commvault.Powershell.Models.GuestCredentialInfo.FromJson(__jsonDomainCreds) : DomainCreds;}
            {_vMHostName = If( json?.PropertyT<Commvault.Powershell.Runtime.Json.JsonString>("vmHostName"), out var __jsonVMHostName) ? (string)__jsonVMHostName : (string)VMHostName;}
            {_vMClientName = If( json?.PropertyT<Commvault.Powershell.Runtime.Json.JsonString>("vmClientName"), out var __jsonVMClientName) ? (string)__jsonVMClientName : (string)VMClientName;}
            AfterFromJson(json);
        }
    }
}