Public/Remove-AccessLevel.ps1
|
<#
.SYNOPSIS Removes an accesslevel. .DESCRIPTION Removes an accesslevel. If the result returns null, try the parameter "-Verbose" to get more details. .EXAMPLE .LINK https://github.com/erwindevreugd/PSDataConduIT .EXTERNALHELP PSDataConduIT-help.xml #> function Remove-AccessLevel { [CmdletBinding( SupportsShouldProcess, ConfirmImpact = "High" )] param ( [Parameter( Position = 0, Mandatory = $false, ValueFromPipelineByPropertyName = $true, HelpMessage = 'The name of the server where the DataConduIT service is running or localhost.')] [string] $Server = $Script:Server, [Parameter( Position = 1, Mandatory = $false, ValueFromPipelineByPropertyName = $true, HelpMessage = 'The credentials used to authenticate the user to the DataConduIT service.')] [PSCredential] $Credential = $Script:Credential, [Parameter( Mandatory = $false, ValueFromPipelineByPropertyName = $true, HelpMessage = 'Specifies the id of the accesslevel to remove.')] [int] $AccessLevelID, [Parameter( Mandatory = $false, ValueFromPipelineByPropertyName = $true, HelpMessage = 'Specifies the name of the accesslevel to remove. Wildcards are permitted.')] [string] $Name, [Parameter( Mandatory = $false, ValueFromPipelineByPropertyName = $false, HelpMessage = 'Forces the removal of the access level with out displaying a should process.')] [switch] $Force ) process { $query = "SELECT * FROM Lnl_AccessLevel WHERE __CLASS='Lnl_AccessLevel'" if ($AccessLevelID) { $query += " AND ID=$AccessLevelID" } if ($Name) { $query += " AND Name='$Name'" } LogQuery $query $parameters = @{ ComputerName = $Server; Namespace = $Script:OnGuardNamespace; Query = $query } if ($Credential -ne $null) { $parameters.Add("Credential", $Credential) } $items = Get-WmiObject @parameters foreach ($item in $items) { if ($Force -or $PSCmdlet.ShouldProcess("$Server", "Removing AccessLevelID: $($item.ID), $($item.Name)")) { $item | Remove-WmiObject } } } } |