v3/src/PSSailpoint/Model/JsonPatchOperation.ps1
# # IdentityNow V3 API # Use these APIs to interact with the IdentityNow platform to achieve repeatable, automated processes with greater scalability. We encourage you to join the SailPoint Developer Community forum at https://developer.sailpoint.com/discuss to connect with other developers using our APIs. # Version: 3.0.0 # Generated by OpenAPI Generator: https://openapi-generator.tech # <# .SYNOPSIS No summary available. .DESCRIPTION A JSONPatch Operation as defined by [RFC 6902 - JSON Patch](https://tools.ietf.org/html/rfc6902) .PARAMETER Op The operation to be performed .PARAMETER Path A string JSON Pointer representing the target path to an element to be affected by the operation .PARAMETER Value No description available. .OUTPUTS JsonPatchOperation<PSCustomObject> #> function Initialize-JsonPatchOperation { [CmdletBinding()] Param ( [Parameter(ValueFromPipelineByPropertyName = $true)] [ValidateSet("add", "remove", "replace", "move", "copy", "test")] [String] ${Op}, [Parameter(ValueFromPipelineByPropertyName = $true)] [String] ${Path}, [Parameter(ValueFromPipelineByPropertyName = $true)] [PSCustomObject] ${Value} ) Process { 'Creating PSCustomObject: PSSailpoint => JsonPatchOperation' | Write-Debug $PSBoundParameters | Out-DebugParameter | Write-Debug if (!$Op) { throw "invalid value for 'Op', 'Op' cannot be null." } if (!$Path) { throw "invalid value for 'Path', 'Path' cannot be null." } $PSO = [PSCustomObject]@{ "op" = ${Op} "path" = ${Path} "value" = ${Value} } return $PSO } } <# .SYNOPSIS Convert from JSON to JsonPatchOperation<PSCustomObject> .DESCRIPTION Convert from JSON to JsonPatchOperation<PSCustomObject> .PARAMETER Json Json object .OUTPUTS JsonPatchOperation<PSCustomObject> #> function ConvertFrom-JsonToJsonPatchOperation { Param( [AllowEmptyString()] [string]$Json ) Process { 'Converting JSON to PSCustomObject: PSSailpoint => JsonPatchOperation' | Write-Debug $PSBoundParameters | Out-DebugParameter | Write-Debug $JsonParameters = ConvertFrom-Json -InputObject $Json # check if Json contains properties not defined in JsonPatchOperation $AllProperties = ("op", "path", "value") 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 'op' missing." } if (!([bool]($JsonParameters.PSobject.Properties.name -match "op"))) { throw "Error! JSON cannot be serialized due to the required property 'op' missing." } else { $Op = $JsonParameters.PSobject.Properties["op"].value } if (!([bool]($JsonParameters.PSobject.Properties.name -match "path"))) { throw "Error! JSON cannot be serialized due to the required property 'path' missing." } else { $Path = $JsonParameters.PSobject.Properties["path"].value } if (!([bool]($JsonParameters.PSobject.Properties.name -match "value"))) { #optional property not found $Value = $null } else { $Value = $JsonParameters.PSobject.Properties["value"].value } $PSO = [PSCustomObject]@{ "op" = ${Op} "path" = ${Path} "value" = ${Value} } return $PSO } } |