Functions/Public/Set-AMSharePointCondition.ps1
function Set-AMSharePointCondition { <# .SYNOPSIS Sets properties of an Automate SharePoint condition. .DESCRIPTION Set-AMIdleCondition modifies an existing SharePoint condition. .PARAMETER InputObject The condition to modify. .PARAMETER SiteURL The SharePoint site URL in which to monitor. .PARAMETER Scope The SharePoint range to monitor: Web or List. .PARAMETER List The title of the list to monitor. This parameter is available only if the Scope parameter is set to List. .PARAMETER ItemAdded If set to YES, the condition will monitor for items to be added to the site/list. .PARAMETER ItemUpdated If set to YES, the condition will monitor for items to be updated in the site/list. .PARAMETER ItemDeleted If set to YES, the condition will monitor for items to be deleted from the site/list. .PARAMETER ItemCheckedIn If set to YES, the condition will monitor for items to be checked in the site/list. .PARAMETER ItemCheckedOut If set to YES, the condition will monitor for items to be checked out of the site/list. If you check out an item, you will reserve it for your use so that others cannot change it while you are working on it. .PARAMETER ItemUncheckedOut If set to YES, the condition will monitor for items to be unchecked out (also known as discarded checkout) from the site/list. You can uncheck out an item if you want it to go back to the way it was before you checked it out. This will undo all of the changes that you made to the item .PARAMETER ItemFileMoved If set to YES, the condition will monitor for a file that is represented by an item from a document library to be moved from the site/list. .PARAMETER ItemAttachmentAdded If set to YES, the condition will monitor for an attachment to be added to a list item in the specified site/list. .PARAMETER ItemAttachmentDeleted If set to YES, the condition will monitor for an attachment to be deleted from a list item in the specified site/list. .PARAMETER FieldAdded If set to YES, the condition will monitor for a field to be added to the site/list. .PARAMETER FieldUpdated If set to YES, the condition will monitor for a field to be updated in the site/list. .PARAMETER FieldDeleted If set to YES, the condition will monitor for a field to be deleted from the site/list. .PARAMETER WorkflowStarted If set to YES, the condition will monitor for a SharePoint workflow to be started from the site/list. .PARAMETER WorkflowPostponed If set to YES, the condition will monitor for a SharePoint workflow to be postponed from the site/list. .PARAMETER WorkflowCompleted If set to YES, the condition will monitor for a SharePoint workflow to be completed from the site/list. .PARAMETER ListAdded If set to YES, the condition will monitor for a list to be added to the site/list. .PARAMETER ListDeleted If set to YES, the condition will monitor for a list to be deleted from the site/list. .PARAMETER GroupAdded If set to YES, the condition will monitor for a group to be added to the specified site/list. .PARAMETER GroupUpdated If set to YES, the condition will monitor for a group to be updated in the specified site/list. .PARAMETER GroupDeleted If set to YES, the condition will monitor for a group to be deleted from the specified site/list. .PARAMETER GroupUserAdded If set to YES, the condition will monitor for a user to be added to a group in the specified site/list. .PARAMETER GroupUserDeleted If set to YES, the condition will monitor for a user to be deleted from a group in the specified site/list. .PARAMETER RoleDefinitionAdded If set to YES, the condition will monitor for a role definition (or permission level) to be added to an item in the specified site/list. A role definition is a collection of rights bound to a specific item. .PARAMETER RoleDefinitionUpdated If set to YES, the condition will monitor for a role definition (or permission level) to be updated in the specified site/list. .PARAMETER RoleDefinitionDeleted If set to YES, the condition will monitor for a role definition (or permission level) to be deleted from an item in the specified site/list. .PARAMETER RoleAssignmentAdded If set to YES, the condition will monitor for a role assignment to be added to an item in the specified site/list. .PARAMETER RoleAssignmentDeleted If set to YES, the condition will monitor for a role assignment to be deleted from an item in the specified site/list. .PARAMETER UserMode Specify to use the default agent user (DefaultUser) or a specified user (SpecifiedUser). .PARAMETER UserName The username used to authenticate with the database. .PARAMETER Password The password for the specified user. .PARAMETER Domain The domain for the specified user. .PARAMETER Wait Wait for the condition, or evaluate immediately. .PARAMETER Timeout If wait is specified, the amount of time before the condition times out. .PARAMETER TimeoutUnit The unit for Timeout (Seconds by default). .PARAMETER TriggerAfter The number of times the condition should occur before the trigger fires. .PARAMETER Notes The new notes to set on the object. .PARAMETER CompletionState The completion state (staging level) to set on the object. .LINK https://github.com/AutomatePS/AutomatePS/blob/master/Docs/Set-AMSharePointCondition.md #> [CmdletBinding(DefaultParameterSetName="Default",SupportsShouldProcess=$true,ConfirmImpact="Medium")] param ( [Parameter(Mandatory = $true, ValueFromPipeline = $true)] [ValidateNotNullOrEmpty()] $InputObject, [ValidateNotNullOrEmpty()] [string]$SiteURL, [ValidateNotNullOrEmpty()] [AMSharePointScope]$Scope, [string]$List, [switch]$ItemAdded, [switch]$ItemUpdated, [switch]$ItemDeleted, [switch]$ItemCheckedIn, [switch]$ItemCheckedOut, [switch]$ItemUncheckedOut, [switch]$ItemFileMoved, [switch]$ItemAttachmentAdded, [switch]$ItemAttachmentDeleted, [switch]$FieldAdded, [switch]$FieldUpdated, [switch]$FieldDeleted, [switch]$WorkflowStarted, [switch]$WorkflowPostponed, [switch]$WorkflowCompleted, [switch]$ListAdded, [switch]$ListDeleted, [switch]$GroupAdded, [switch]$GroupUpdated, [switch]$GroupDeleted, [switch]$GroupUserAdded, [switch]$GroupUserDeleted, [switch]$RoleDefinitionAdded, [switch]$RoleDefinitionUpdated, [switch]$RoleDefinitionDeleted, [switch]$RoleAssignmentAdded, [switch]$RoleAssignmentDeleted, [ValidateScript({ if ($_ -eq [AMConditionUserMode]::NoUser) { throw [System.Management.Automation.PSArgumentException]"NoUser is not supported for SharePoint conditions!" $false } else { $true } })] [AMConditionUserMode]$UserMode, [string]$UserName, #[string]$Password, API BUG: does not support setting password via REST call [string]$Domain, [ValidateNotNullOrEmpty()] [switch]$Wait, [ValidateNotNullOrEmpty()] [int]$Timeout, [ValidateNotNullOrEmpty()] [AMTimeMeasure]$TimeoutUnit, [ValidateNotNullOrEmpty()] [int]$TriggerAfter, [AllowEmptyString()] [string]$Notes, [ValidateNotNullOrEmpty()] [AMCompletionState]$CompletionState ) PROCESS { foreach ($obj in $InputObject) { if ($obj.Type -eq "Condition" -and $obj.TriggerType -eq [AMTriggerType]::SharePoint) { $updateObject = Get-AMCondition -ID $obj.ID -Connection $obj.ConnectionAlias $shouldUpdate = $false $boundParameterKeys = $PSBoundParameters.Keys | Where-Object {($_ -ne "InputObject") -and ` ($_ -notin [System.Management.Automation.PSCmdlet]::CommonParameters) -and ` ($_ -notin [System.Management.Automation.PSCmdlet]::OptionalCommonParameters)} foreach ($boundParameterKey in $boundParameterKeys) { $property = $boundParameterKey $value = $PSBoundParameters[$property] # Handle special property types if ($value -is [System.Management.Automation.SwitchParameter]) { $value = $value.ToBool() } # Compare and change properties if ($updateObject."$property" -ne $value) { $updateObject."$property" = $value $shouldUpdate = $true } } if ($shouldUpdate) { $updateObject | Set-AMObject } else { Write-Verbose "$($obj.Type) '$($obj.Name)' already contains the specified values." } } else { Write-Error -Message "Unsupported input type '$($obj.Type)' and trigger type '$($obj.TriggerType)' encountered!" -TargetObject $obj } } } } |