Functions/Safes/Remove-PASSafe.ps1

function Remove-PASSafe {
    <#
.SYNOPSIS
Deletes a safe from the Vault
 
 
.DESCRIPTION
Deletes a safe from the Vault.
The "Manage" Safe vault permission is required.
 
.PARAMETER SafeName
The name of the safe to delete.
 
.EXAMPLE
Remove-PASSafe -SafeName OLD_Safe
 
Deletes "OLD_Safe"
 
.INPUTS
All parameters can be piped by property name
 
.LINK
https://pspas.pspete.dev/commands/Remove-PASSafe
#>

    [CmdletBinding(SupportsShouldProcess)]
    param(
        [parameter(
            Mandatory = $true,
            ValueFromPipelinebyPropertyName = $true
        )]
        [ValidateNotNullOrEmpty()]
        [string]$SafeName

    )

    BEGIN { }#begin

    PROCESS {

        #Create URL for request
        $URI = "$Script:BaseURI/WebServices/PIMServices.svc/Safes/$($SafeName |
 
            Get-EscapedString)"


        if ($PSCmdlet.ShouldProcess($SafeName, "Delete Safe")) {

            #Send request to web service
            Invoke-PASRestMethod -Uri $URI -Method DELETE -WebSession $Script:WebSession

        }

    }#process

    END { }#end
}