generated/api/Models/DateRange.PowerShell.cs
// Code generated by Microsoft (R) AutoRest Code Generator (autorest: 3.10.2, generator: @autorest/powershell@4.0.708) // Changes may cause incorrect behavior and will be lost if the code is regenerated. namespace Commvault.Powershell.Models { using Commvault.Powershell.Runtime.PowerShell; /// <summary> /// Date range is for date related token rule values to specify from and to date in unix date timestamp format.. /// </summary> [System.ComponentModel.TypeConverter(typeof(DateRangeTypeConverter))] public partial class DateRange { /// <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 <paramref name="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 <paramref name="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> /// <c>OverrideToString</c> will be called if it is implemented. Implement this method in a partial class to enable this behavior /// </summary> /// <param name="stringResult">/// instance serialized to a string, normally it is a Json</param> /// <param name="returnNow">/// set returnNow to true if you provide a customized OverrideToString function</param> partial void OverrideToString(ref string stringResult, ref bool returnNow); /// <summary> /// Deserializes a <see cref="global::System.Collections.IDictionary" /> into a new instance of <see cref="Commvault.Powershell.Models.DateRange" /// />. /// </summary> /// <param name="content">The global::System.Collections.IDictionary content that should be used.</param> internal DateRange(global::System.Collections.IDictionary content) { bool returnNow = false; BeforeDeserializeDictionary(content, ref returnNow); if (returnNow) { return; } // actually deserialize if (content.Contains("FromDate")) { ((Commvault.Powershell.Models.IDateRangeInternal)this).FromDate = (string) content.GetValueForProperty("FromDate",((Commvault.Powershell.Models.IDateRangeInternal)this).FromDate, global::System.Convert.ToString); } if (content.Contains("ToDate")) { ((Commvault.Powershell.Models.IDateRangeInternal)this).ToDate = (string) content.GetValueForProperty("ToDate",((Commvault.Powershell.Models.IDateRangeInternal)this).ToDate, global::System.Convert.ToString); } if (content.Contains("TimeRange")) { ((Commvault.Powershell.Models.IDateRangeInternal)this).TimeRange = (System.Collections.Generic.List<Commvault.Powershell.Models.ITimeRange>) content.GetValueForProperty("TimeRange",((Commvault.Powershell.Models.IDateRangeInternal)this).TimeRange, __y => TypeConverterExtensions.SelectToList<Commvault.Powershell.Models.ITimeRange>(__y, Commvault.Powershell.Models.TimeRangeTypeConverter.ConvertFrom)); } AfterDeserializeDictionary(content); } /// <summary> /// Deserializes a <see cref="global::System.Management.Automation.PSObject" /> into a new instance of <see cref="Commvault.Powershell.Models.DateRange" /// />. /// </summary> /// <param name="content">The global::System.Management.Automation.PSObject content that should be used.</param> internal DateRange(global::System.Management.Automation.PSObject content) { bool returnNow = false; BeforeDeserializePSObject(content, ref returnNow); if (returnNow) { return; } // actually deserialize if (content.Contains("FromDate")) { ((Commvault.Powershell.Models.IDateRangeInternal)this).FromDate = (string) content.GetValueForProperty("FromDate",((Commvault.Powershell.Models.IDateRangeInternal)this).FromDate, global::System.Convert.ToString); } if (content.Contains("ToDate")) { ((Commvault.Powershell.Models.IDateRangeInternal)this).ToDate = (string) content.GetValueForProperty("ToDate",((Commvault.Powershell.Models.IDateRangeInternal)this).ToDate, global::System.Convert.ToString); } if (content.Contains("TimeRange")) { ((Commvault.Powershell.Models.IDateRangeInternal)this).TimeRange = (System.Collections.Generic.List<Commvault.Powershell.Models.ITimeRange>) content.GetValueForProperty("TimeRange",((Commvault.Powershell.Models.IDateRangeInternal)this).TimeRange, __y => TypeConverterExtensions.SelectToList<Commvault.Powershell.Models.ITimeRange>(__y, Commvault.Powershell.Models.TimeRangeTypeConverter.ConvertFrom)); } AfterDeserializePSObject(content); } /// <summary> /// Deserializes a <see cref="global::System.Collections.IDictionary" /> into an instance of <see cref="Commvault.Powershell.Models.DateRange" /// />. /// </summary> /// <param name="content">The global::System.Collections.IDictionary content that should be used.</param> /// <returns>an instance of <see cref="Commvault.Powershell.Models.IDateRange" />.</returns> public static Commvault.Powershell.Models.IDateRange DeserializeFromDictionary(global::System.Collections.IDictionary content) { return new DateRange(content); } /// <summary> /// Deserializes a <see cref="global::System.Management.Automation.PSObject" /> into an instance of <see cref="Commvault.Powershell.Models.DateRange" /// />. /// </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.IDateRange" />.</returns> public static Commvault.Powershell.Models.IDateRange DeserializeFromPSObject(global::System.Management.Automation.PSObject content) { return new DateRange(content); } /// <summary> /// Creates a new instance of <see cref="DateRange" />, 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="DateRange" /> model class.</returns> public static Commvault.Powershell.Models.IDateRange FromJsonString(string jsonText) => FromJson(Commvault.Powershell.Runtime.Json.JsonNode.Parse(jsonText)); /// <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(); public override string ToString() { var returnNow = false; var result = global::System.String.Empty; OverrideToString(ref result, ref returnNow); if (returnNow) { return result; } return ToJsonString(); } } /// Date range is for date related token rule values to specify from and to date in unix date timestamp format.. [System.ComponentModel.TypeConverter(typeof(DateRangeTypeConverter))] public partial interface IDateRange { } } |