Model/ActiveTimeSlots.ps1

#
# Login Enterprise
# v7.0-preview [API Console (Swagger)](/publicApi/swagger/index.html?urls.primaryName=Login%20Enterprise%20API%20v7-preview), [Documentation (ReDoc)](/publicApi/v7-preview/docs/index.html) v6.0 [API Console (Swagger)](/publicApi/swagger/index.html?urls.primaryName=Login%20Enterprise%20API%20v6), [Documentation (ReDoc)](/publicApi/v6/docs/index.html) v5.0 [API Console (Swagger)](/publicApi/swagger/index.html?urls.primaryName=Login%20Enterprise%20API%20v5), [Documentation (ReDoc)](/publicApi/v5/docs/index.html) v4.0 [API Console (Swagger)](/publicApi/swagger/index.html?urls.primaryName=Login%20Enterprise%20API%20v4), [Documentation (ReDoc)](/publicApi/v4/docs/index.html) <br><b>API v7 (preview) – Introduced in Login Enterprise v5.0 and subject to breaking changes when API v7 becomes generally available.</b></br> <br><b>API v6 – is the recommended version to use. It is the actively developed version starting with Login Enterprise v4.10.</b></br> <br><b>API v5 – is currently supported but unmaintained as of v4.10.</b></br> <br><b>API v4 – is deprecated starting with v4.10. Will be removed in Q3 2023.</b></br> The Login Enterprise Public API provides documentation and Swagger per version within the product. For additional information please refer to the [documentation](https://support.loginvsi.com/hc/en-us/articles/360009534760) on our website.
# Version: 7.0-preview
# Generated by OpenAPI Generator: https://openapi-generator.tech
#

<#
.SYNOPSIS

No summary available.

.DESCRIPTION

Active time slots

.PARAMETER Mode
No description available.
.PARAMETER TimeSlots
 TimeSlots Each element in the array corresponds to a specific time slot, with each slot representing a duration 15 minutes. True indicates that the time slot is active and the Test should be enabled for its duration It can represent time slots for either a week or a day. If representing time slots for a week, the array should contain 7 * 24 * 4 = 672 values. If representing time slots for a day, the array should contain 24 * 4 = 96 values.
.OUTPUTS

ActiveTimeSlots<PSCustomObject>
#>


function Initialize-LEActiveTimeSlots {
    [CmdletBinding()]
    Param (
        [Parameter(Position = 0, ValueFromPipelineByPropertyName = $true)]
        [ValidateSet("alwaysOn", "daily", "weekly")]
        [PSCustomObject]
        ${Mode},
        [Parameter(Position = 1, ValueFromPipelineByPropertyName = $true)]
        [Boolean[]]
        ${TimeSlots}
    )

    Process {
        'Creating PSCustomObject: PSLoginEnterprise => LEActiveTimeSlots' | Write-Debug
        $PSBoundParameters | Out-DebugParameter | Write-Debug


        $PSO = [PSCustomObject]@{
            "mode" = ${Mode}
            "timeSlots" = ${TimeSlots}
        }


        return $PSO
    }
}

<#
.SYNOPSIS

Convert from JSON to ActiveTimeSlots<PSCustomObject>

.DESCRIPTION

Convert from JSON to ActiveTimeSlots<PSCustomObject>

.PARAMETER Json

Json object

.OUTPUTS

ActiveTimeSlots<PSCustomObject>
#>

function ConvertFrom-LEJsonToActiveTimeSlots {
    Param(
        [AllowEmptyString()]
        [string]$Json
    )

    Process {
        'Converting JSON to PSCustomObject: PSLoginEnterprise => LEActiveTimeSlots' | Write-Debug
        $PSBoundParameters | Out-DebugParameter | Write-Debug

        $JsonParameters = ConvertFrom-Json -InputObject $Json

        # check if Json contains properties not defined in LEActiveTimeSlots
        $AllProperties = ("mode", "timeSlots")
        foreach ($name in $JsonParameters.PsObject.Properties.Name) {
            if (!($AllProperties.Contains($name))) {
                throw "Error! JSON key '$name' not found in the properties: $($AllProperties)"
            }
        }

        if (!([bool]($JsonParameters.PSobject.Properties.name -match "mode"))) { #optional property not found
            $Mode = $null
        } else {
            $Mode = $JsonParameters.PSobject.Properties["mode"].value
        }

        if (!([bool]($JsonParameters.PSobject.Properties.name -match "timeSlots"))) { #optional property not found
            $TimeSlots = $null
        } else {
            $TimeSlots = $JsonParameters.PSobject.Properties["timeSlots"].value
        }

        $PSO = [PSCustomObject]@{
            "mode" = ${Mode}
            "timeSlots" = ${TimeSlots}
        }

        return $PSO
    }

}