functions/secret-policies/New-TssSecretPolicy.ps1

function New-TssSecretPolicy {
    <#
    .SYNOPSIS
    Create a new Secret Policy
 
    .DESCRIPTION
    Create a new Secret Policy, configure Policy Items using Update-TssSecretPolicy
 
    .LINK
    https://thycotic-ps.github.io/thycotic.secretserver/commands/secret-policies/New-TssSecretPolicy
 
    .LINK
    https://github.com/thycotic-ps/thycotic.secretserver/blob/main/src/functions/secret-policies/New-TssSecretPolicy.ps1
 
    .EXAMPLE
    $session = New-TssSession -SecretServer https://alpha -Credential $ssCred
    New-TssSecretPolicy -TssSession $session -Name 'Require Checkout'
 
    Create a new secret policy setting enforcing various policy items
 
    .EXAMPLE
    $session = New-TssSession -SecretServer https://alpha -Credential $ssCred
    $policyItem1 = Get-TssSecretPolicyItemStub -TssSession $session -ItemName AssociatedSecretId1 -ApplyType Enforced
    $policyItem1.ValueSecretId = 54
    $policyItem2 = Get-TssSecretPolicyItemStub -TssSession $session -ItemName AssociatedSecretId2 -ApplyType Enforced
    $policyItem2.ValueSecretId = 65
    New-TssSecretPolicy -TssSession $session -Name 'Policy - Associated Secrets Enforced' -Active -PolicyItem $policyItem1, $policyItem2
 
    Create a new secret policy, configuring Associated Secret 1 and 2 policy items.
 
    .NOTES
    Requires TssSession object returned by New-TssSession
    #>

    [CmdletBinding(SupportsShouldProcess)]
    [OutputType('Thycotic.PowerShell.SecretPolicies.Policy')]
    param (
        # TssSession object created by New-TssSession for authentication
        [Parameter(Mandatory,ValueFromPipeline,Position = 0)]
        [Thycotic.PowerShell.Authentication.Session]
        $TssSession,

        # Secret Policy Name
        [Parameter(Mandatory)]
        [string]
        $Name,

        # Secret Policy Description
        [string]
        $Description,

        # Activate the policy after creation
        [switch]
        $Active,

        # Policy Item(s) to add (utilize Get-TssSecretPolicyItemStub to create each object)
        [Thycotic.PowerShell.SecretPolicies.PolicyItem[]]
        $PolicyItem
    )
    begin {
        $tssNewParams = $PSBoundParameters
        $invokeParams = . $GetInvokeApiParams $TssSession
    }
    process {
        Get-TssInvocation $PSCmdlet.MyInvocation
        if ($tssNewParams.ContainsKey('TssSession') -and $TssSession.IsValidSession()) {
            Compare-TssVersion $TssSession '11.0.000005' $PSCmdlet.MyInvocation
            $uri = $TssSession.ApiUrl, 'secret-policy' -join '/'
            $invokeParams.Uri = $uri
            $invokeParams.Method = 'POST'

            $newBody = @{data = @{} }
            switch ($tssNewParams.Keys) {
                'Name' { $newBody.data.Add('secretPolicyName',$Name) }
                'Description' { $newBody.data.Add('secretPolicyDescription',$Description) }
                'Active' { $newBody.data.Add('active',[boolean]$Active) }
            }

            if ($tssNewParams.ContainsKey('PolicyItem')) {
                $bodyItems = @()
                foreach ($item in $PolicyItem) {
                    $item | ConvertTo-Json -Depth 80 | ConvertFrom-Json

                    $bodyItems += [pscustomobject]@{
                        policyApplyType = $item.PolicyApplyType
                        secretPolicyItemId = $item.SecretPolicyItemId
                        valueBool = $item.ValueBool
                        valueInt = $item.ValueInt
                        valueSecretId = $item.ValueSecretId
                        valueString = $item.ValueString
                        userGroupMaps = $item.UserGroupMaps
                        sshCommandMenuGroupMaps = $item.SshCommandMenuGroupMaps
                    }
                }
                $newBody.data.Add('secretPolicyItems',$bodyItems)
            }

            $invokeParams.Body = $newBody | ConvertTo-Json -Depth 100

            Write-Verbose "Performing the operation $($invokeParams.Method) $($invokeParams.Uri) with:`n $newBody"
            if (-not $PSCmdlet.ShouldProcess("Secret Policy: $Name", "$($invokeParams.Method) $($invokeParams.Uri) with $($invokeParams.Body)")) { return }
            try {
                $apiResponse = Invoke-TssApi @invokeParams
                $restResponse = . $ProcessResponse $apiResponse
            } catch {
                Write-Warning "Issue creating Secret Policy [$Name]"
                $err = $_
                . $ErrorHandling $err
            }

            if ($restResponse) {
                [Thycotic.PowerShell.SecretPolicies.Policy]$restResponse
            }
        } else {
            Write-Warning "No valid session found"
        }
    }
}