functions/secrets/Test-SecretState.ps1

function Test-SecretState {
    <#
    .SYNOPSIS
    Test for a State on a Secret
 
    .DESCRIPTION
    Test for a State on a Secret
 
    .EXAMPLE
    session = New-TssSession -SecretServer https://alpha -Credential ssCred
    Test-TssSecretState -TssSession $session -SecretId 75 -State RequiresCheckout
 
    Test for state RequiresCheckout on Secret ID 75, returning true if exists and false if not
 
    .LINK
    https://thycotic-ps.github.io/thycotic.secretserver/commands/Test-TssSecretState
 
    .LINK
    https://github.com/thycotic-ps/thycotic.secretserver/blob/main/src/functions/secrets/Test-SecretState.ps1
 
    .NOTES
    Requires TssSession object returned by New-TssSession
 
    Possible Secret States:
    'None','RequiresApproval','RequiresCheckout','RequiresComment','RequiresDoubleLockPassword','CreateDoubleLockPassword','DoubleLockNoAccess','CannotView','RequiresUndelete','RequiresCheckoutPendingRPC','RequiresCheckoutAndComment'
    #>

    [CmdletBinding()]
    [OutputType('System.Boolean')]
    param (
        # TssSession object created by New-TssSession for auth
        [Parameter(Mandatory, ValueFromPipeline, Position = 0)]
        [TssSession]
        $TssSession,

        # Secret ID
        [Parameter(Mandatory, ValueFromPipelineByPropertyName)]
        [Alias('Id')]
        [int]
        $SecretId,

        # State to test for
        [Parameter(Mandatory)]
        [ValidateSet('None','RequiresApproval','RequiresCheckout','RequiresComment','RequiresDoubleLockPassword','CreateDoubleLockPassword','DoubleLockNoAccess','CannotView','RequiresUndelete','RequiresCheckoutPendingRPC','RequiresCheckoutAndComment')]
        [string]
        $State
    )
    begin {
        $tssParams = $PSBoundParameters
    }
    process {
        if ($tssParams.ContainsKey('TssSession') -and $TssSession.IsValidSession()) {
            Write-Verbose "Provided command parameters: $(. $GetInvocation $PSCmdlet.MyInvocation)"
            $SecretResult = . $GetSecretState $TssSession $SecretId

            if (-not $SecretResult) {
                Write-Warning "No result returned for Secret [$SecretId]"
            } else {
                $SecretResult.TestState($State)
            }
        } else {
            Write-Warning "No valid session found"
        }
    }
}