Dynamic/Remove-AtwsContact.ps1
#Requires -Version 4.0 #Version 1.6.2.10 <# .COPYRIGHT Copyright (c) Office Center Hønefoss AS. All rights reserved. Based on code from Jan Egil Ring (Crayon). Licensed under the MIT license. See https://github.com/officecenter/Autotask/blob/master/LICENSE.md for license information. #> Function Remove-AtwsContact { <# .SYNOPSIS This function deletes a Contact through the Autotask Web Services API. .DESCRIPTION This function deletes a Contact through the Autotask Web Services API. Entities that have fields that refer to the base entity of this CmdLet: AccountNote AccountToDo AttachmentInfo ClientPortalUser ContactGroupContact Contract InstalledProduct NotificationHistory Opportunity Quote SalesOrder SurveyResults Ticket TicketAdditionalContact TicketChangeRequestApproval .INPUTS [Autotask.Contact[]]. This function takes objects as input. Pipeline is supported. .OUTPUTS Nothing. This fuction just deletes the Autotask.Contact that was passed to the function. .EXAMPLE Remove-AtwsContact [-ParameterName] [Parameter value] .LINK New-AtwsContact .LINK Get-AtwsContact .LINK Set-AtwsContact #> [CmdLetBinding(DefaultParameterSetName='Input_Object', ConfirmImpact='Low')] Param ( # Any objects that should be deleted [Parameter( ParameterSetName = 'Input_Object', ValueFromPipeline = $true )] [ValidateNotNullOrEmpty()] [Autotask.Contact[]] $InputObject, # The unique id of an object to delete [Parameter( Mandatory = $true, ParameterSetName = 'By_parameters' )] [ValidateNotNullOrEmpty()] [long[]] $Id ) Begin { $EntityName = 'Contact' # Enable modern -Debug behavior If ($PSCmdlet.MyInvocation.BoundParameters['Debug'].IsPresent) {$DebugPreference = 'Continue'} Write-Debug ('{0}: Begin of function' -F $MyInvocation.MyCommand.Name) } Process { If ($Id.Count -gt 0) { $Filter = 'id -eq {0}' -F ($Id -join ' -or id -eq ') $InputObject = Get-AtwsData -Entity $EntityName -Filter $Filter } If ($InputObject) { Remove-AtwsData -Entity $InputObject } } End { Write-Debug ('{0}: End of function' -F $MyInvocation.MyCommand.Name) } } |