Model/SimpleDeviceNotAffectedInfo.ps1

#
# Torizon OTA
# This API is rate limited and will return the following headers for each API call. - X-RateLimit-Limit - The total number of requests allowed within a time period - X-RateLimit-Remaining - The total number of requests still allowed until the end of the rate limiting period - X-RateLimit-Reset - The number of seconds until the limit is fully reset In addition, if an API client is rate limited, it will receive a HTTP 420 response with the following header: - Retry-After - The number of seconds to wait until this request is allowed
# Version: 2.0-Beta
# Generated by OpenAPI Generator: https://openapi-generator.tech
#

<#
.SYNOPSIS

No summary available.

.DESCRIPTION

No description available.

.PARAMETER DeviceUuid
No description available.
.PARAMETER Name
No description available.
.PARAMETER EcuErrors
No description available.
.PARAMETER DeviceId
No description available.
.OUTPUTS

SimpleDeviceNotAffectedInfo<PSCustomObject>
#>


function Initialize-TorizonPlatformAPISimpleDeviceNotAffectedInfo {
    [CmdletBinding()]
    Param (
        [Parameter(Position = 0, ValueFromPipelineByPropertyName = $true)]
        [String]
        ${DeviceUuid},
        [Parameter(Position = 1, ValueFromPipelineByPropertyName = $true)]
        [String]
        ${Name},
        [Parameter(Position = 2, ValueFromPipelineByPropertyName = $true)]
        [System.Collections.Hashtable]
        ${EcuErrors},
        [Parameter(Position = 3, ValueFromPipelineByPropertyName = $true)]
        [String]
        ${DeviceId}
    )

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

        if ($null -eq $DeviceUuid) {
            throw "invalid value for 'DeviceUuid', 'DeviceUuid' cannot be null."
        }

        if ($null -eq $Name) {
            throw "invalid value for 'Name', 'Name' cannot be null."
        }

        if ($null -eq $EcuErrors) {
            throw "invalid value for 'EcuErrors', 'EcuErrors' cannot be null."
        }

        if ($null -eq $DeviceId) {
            throw "invalid value for 'DeviceId', 'DeviceId' cannot be null."
        }


        $PSO = [PSCustomObject]@{
            "deviceUuid" = ${DeviceUuid}
            "name" = ${Name}
            "ecuErrors" = ${EcuErrors}
            "deviceId" = ${DeviceId}
        }


        return $PSO
    }
}

<#
.SYNOPSIS

Convert from JSON to SimpleDeviceNotAffectedInfo<PSCustomObject>

.DESCRIPTION

Convert from JSON to SimpleDeviceNotAffectedInfo<PSCustomObject>

.PARAMETER Json

Json object

.OUTPUTS

SimpleDeviceNotAffectedInfo<PSCustomObject>
#>

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

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

        $JsonParameters = ConvertFrom-Json -InputObject $Json

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

        If ([string]::IsNullOrEmpty($Json) -or $Json -eq "{}") { # empty json
            throw "Error! Empty JSON cannot be serialized due to the required property 'deviceUuid' missing."
        }

        if (!([bool]($JsonParameters.PSobject.Properties.name -match "deviceUuid"))) {
            throw "Error! JSON cannot be serialized due to the required property 'deviceUuid' missing."
        } else {
            $DeviceUuid = $JsonParameters.PSobject.Properties["deviceUuid"].value
        }

        if (!([bool]($JsonParameters.PSobject.Properties.name -match "name"))) {
            throw "Error! JSON cannot be serialized due to the required property 'name' missing."
        } else {
            $Name = $JsonParameters.PSobject.Properties["name"].value
        }

        if (!([bool]($JsonParameters.PSobject.Properties.name -match "ecuErrors"))) {
            throw "Error! JSON cannot be serialized due to the required property 'ecuErrors' missing."
        } else {
            $EcuErrors = $JsonParameters.PSobject.Properties["ecuErrors"].value
        }

        if (!([bool]($JsonParameters.PSobject.Properties.name -match "deviceId"))) {
            throw "Error! JSON cannot be serialized due to the required property 'deviceId' missing."
        } else {
            $DeviceId = $JsonParameters.PSobject.Properties["deviceId"].value
        }

        $PSO = [PSCustomObject]@{
            "deviceUuid" = ${DeviceUuid}
            "name" = ${Name}
            "ecuErrors" = ${EcuErrors}
            "deviceId" = ${DeviceId}
        }

        return $PSO
    }

}