Public/Miscellaneous/Remove-Everyone.ps1
# Remove Everyone ('S-1-1-0') Built-In Group from object Function Remove-Everyone { <# .SYNOPSIS Remove the built-in group EVERYONE from the given object. .DESCRIPTION Remove the built-in group EVERYONE from the given object .EXAMPLE Remove-Everyone -LDAPPath "OU=Users,OU=XXXX,OU=Sites,DC=EguibarIT,DC=local" .PARAMETER LDAPpath [String] Distinguished Name of the object (or container) where the permissions are going to be removed. .NOTES Used Functions: Name | Module ---------------------------------------|-------------------------- Set-AclConstructor5 | EguibarIT.Delegation .NOTES Version: 1.1 DateModified: 29/Sep/2016 LasModifiedBy: Vicente Rodriguez Eguibar vicente@eguibar.com Eguibar Information Technology S.L. http://www.eguibarit.com #> [CmdletBinding(SupportsShouldProcess = $true, ConfirmImpact = 'Medium')] [OutputType([void])] param ( # PARAM1 STRING for the Object Name [Parameter(Mandatory = $true, ValueFromPipeline = $true, ValueFromPipelineByPropertyName = $true, HelpMessage = 'Distinguished Name of the object (or container) where the permissions are going to be removed.', Position = 0)] [ValidateNotNullOrEmpty()] [ValidateScript({ Test-IsValidDN -ObjectDN $_ })] [Alias('DN', 'DistinguishedName')] [String] $LDAPpath ) begin { Write-Verbose -Message '|=> ************************************************************************ <=|' Write-Verbose -Message (Get-Date).ToShortDateString() Write-Verbose -Message (' Starting: {0}' -f $MyInvocation.Mycommand) Write-Verbose -Message ('Parameters used by the function... {0}' -f (Get-FunctionDisplay $PsBoundParameters -Verbose:$False)) ############################## # Variables Definition [Hashtable]$Splat = [hashtable]::New() } #end Begin process { <# ACENumber : 2 IdentityReference : Everyone ActiveDirectoryRightst : ReadProperty, WriteProperty, GenericExecute AccessControlType : Allow ObjectType : GuidNULL InheritanceType : All InheritedObjectType : GuidNULL IsInherited : False #> $Splat = @{ Id = 'EVERYONE' LDAPPath = $PSBoundParameters['LDAPPath'] AdRight = 'ReadProperty', 'WriteProperty', 'GenericExecute' AccessControlType = 'Allow' ObjectType = $Constants.GuidNULL AdSecurityInheritance = 'All' RemoveRule = $true } If ($Force -or $PSCmdlet.ShouldProcess($PSBoundParameters['Group'], 'Remove "EVERYONE"?')) { Set-AclConstructor5 @Splat } #end If } #end Process end { Write-Verbose -Message "Function $($MyInvocation.InvocationName) removed Everyone." Write-Verbose -Message '' Write-Verbose -Message '--------------------------------------------------------------------------------' Write-Verbose -Message '' } #end END } |