beta/src/PSSailpoint.Beta/Model/AccessRequestItem.ps1
# # Identity Security Cloud Beta API # Use these APIs to interact with the Identity Security Cloud platform to achieve repeatable, automated processes with greater scalability. These APIs are in beta and are subject to change. 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.1.0-beta # Generated by OpenAPI Generator: https://openapi-generator.tech # <# .SYNOPSIS No summary available. .DESCRIPTION No description available. .PARAMETER Type The type of the item being requested. .PARAMETER Id ID of Role, Access Profile or Entitlement being requested. .PARAMETER Comment Comment provided by requester. * Comment is required when the request is of type Revoke Access. .PARAMETER ClientMetadata Arbitrary key-value pairs. They will never be processed by the IdentityNow system but will be returned on associated APIs such as /account-activities and /access-request-status. .PARAMETER RemoveDate The date the role or access profile or entitlement is no longer assigned to the specified identity. Also known as the expiration date. * Specify a date in the future. * The current SLA for the deprovisioning is 24 hours. * This date can be modified to either extend or decrease the duration of access item assignments for the specified identity. You can change the expiration date for requests for yourself or direct reports, but you cannot remove an expiration date on an already approved item. If the access request has not been approved, you can cancel it and submit a new one without the expiration. If it has already been approved, then you have to revoke the access and then re-request without the expiration. .PARAMETER AssignmentId The assignmentId for a specific role assignment on the identity. This id is used to revoke that specific roleAssignment on that identity. * For use with REVOKE_ACCESS requests for roles for identities with multiple accounts on a single source. .PARAMETER NativeIdentity The 'distinguishedName' field for an account on the identity, also called nativeIdentity. This nativeIdentity is used to revoke a specific attributeAssignment on the identity. * For use with REVOKE_ACCESS requests for entitlements for identities with multiple accounts on a single source. .OUTPUTS AccessRequestItem<PSCustomObject> #> function Initialize-BetaAccessRequestItem { [CmdletBinding()] Param ( [Parameter(ValueFromPipelineByPropertyName = $true)] [ValidateSet("ACCESS_PROFILE", "ROLE", "ENTITLEMENT")] [String] ${Type}, [Parameter(ValueFromPipelineByPropertyName = $true)] [String] ${Id}, [Parameter(ValueFromPipelineByPropertyName = $true)] [String] ${Comment}, [Parameter(ValueFromPipelineByPropertyName = $true)] [System.Collections.Hashtable] ${ClientMetadata}, [Parameter(ValueFromPipelineByPropertyName = $true)] [System.Nullable[System.DateTime]] ${RemoveDate}, [Parameter(ValueFromPipelineByPropertyName = $true)] [String] ${AssignmentId}, [Parameter(ValueFromPipelineByPropertyName = $true)] [String] ${NativeIdentity} ) Process { 'Creating PSCustomObject: PSSailpoint.Beta => BetaAccessRequestItem' | Write-Debug $PSBoundParameters | Out-DebugParameter | Write-Debug if (!$Type) { throw "invalid value for 'Type', 'Type' cannot be null." } if (!$Id) { throw "invalid value for 'Id', 'Id' cannot be null." } $PSO = [PSCustomObject]@{ "type" = ${Type} "id" = ${Id} "comment" = ${Comment} "clientMetadata" = ${ClientMetadata} "removeDate" = ${RemoveDate} "assignmentId" = ${AssignmentId} "nativeIdentity" = ${NativeIdentity} } return $PSO } } <# .SYNOPSIS Convert from JSON to AccessRequestItem<PSCustomObject> .DESCRIPTION Convert from JSON to AccessRequestItem<PSCustomObject> .PARAMETER Json Json object .OUTPUTS AccessRequestItem<PSCustomObject> #> function ConvertFrom-BetaJsonToAccessRequestItem { Param( [AllowEmptyString()] [string]$Json ) Process { 'Converting JSON to PSCustomObject: PSSailpoint.Beta => BetaAccessRequestItem' | Write-Debug $PSBoundParameters | Out-DebugParameter | Write-Debug $JsonParameters = ConvertFrom-Json -InputObject $Json # check if Json contains properties not defined in BetaAccessRequestItem $AllProperties = ("type", "id", "comment", "clientMetadata", "removeDate", "assignmentId", "nativeIdentity") 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 'type' missing." } if (!([bool]($JsonParameters.PSobject.Properties.name -match "type"))) { throw "Error! JSON cannot be serialized due to the required property 'type' missing." } else { $Type = $JsonParameters.PSobject.Properties["type"].value } if (!([bool]($JsonParameters.PSobject.Properties.name -match "id"))) { throw "Error! JSON cannot be serialized due to the required property 'id' missing." } else { $Id = $JsonParameters.PSobject.Properties["id"].value } if (!([bool]($JsonParameters.PSobject.Properties.name -match "comment"))) { #optional property not found $Comment = $null } else { $Comment = $JsonParameters.PSobject.Properties["comment"].value } if (!([bool]($JsonParameters.PSobject.Properties.name -match "clientMetadata"))) { #optional property not found $ClientMetadata = $null } else { $ClientMetadata = $JsonParameters.PSobject.Properties["clientMetadata"].value } if (!([bool]($JsonParameters.PSobject.Properties.name -match "removeDate"))) { #optional property not found $RemoveDate = $null } else { $RemoveDate = $JsonParameters.PSobject.Properties["removeDate"].value } if (!([bool]($JsonParameters.PSobject.Properties.name -match "assignmentId"))) { #optional property not found $AssignmentId = $null } else { $AssignmentId = $JsonParameters.PSobject.Properties["assignmentId"].value } if (!([bool]($JsonParameters.PSobject.Properties.name -match "nativeIdentity"))) { #optional property not found $NativeIdentity = $null } else { $NativeIdentity = $JsonParameters.PSobject.Properties["nativeIdentity"].value } $PSO = [PSCustomObject]@{ "type" = ${Type} "id" = ${Id} "comment" = ${Comment} "clientMetadata" = ${ClientMetadata} "removeDate" = ${RemoveDate} "assignmentId" = ${AssignmentId} "nativeIdentity" = ${NativeIdentity} } return $PSO } } |