functions/folders/Add-TssFolderPermission.ps1

function Add-TssFolderPermission {
    <#
    .SYNOPSIS
    Add a User or Group permission to a Folder
 
    .DESCRIPTION
    Add a User or Group permission to a Folder. Use -Force to break inheritance.
 
    .EXAMPLE
    session = New-TssSession -SecretServer https://alpha -Credential $ssCred
    Add-TssFolderPermission -TssSession $session -Id 65 -Username bob -FolderRole Owner -SecretRole Edit
 
    Add bob to Folder 65 granting Folder role of owner and Secret role of Edit
 
    .EXAMPLE
    $session = New-TssSession -SecretServer https://alpha -Credential $ssCred
    $folders = Search-TssFolder -TssSession $session | Where-Object -not InheritPermission
    $folders | Add-TssFolderPermission -TssSession $session -Username chance.wayne -FolderRole View -SecretRole List
 
    Add "chance.wayne" to all Folders that do not have Inherit Permissions enabled. Granting Folder role of View and Secret Role of List
 
    .EXAMPLE
    $session = New-TssSession -SecretServer https://alpha -Credential $ssCred
    $folders = Search-TssFolder -TssSession $session -SearchText 'App'
    $folders | Add-TssFolderPermission -TssSession $session -Username chad -FolderRole Owner -SecretRole Owner -Force
 
    Add "chad" as owner for Folder and Secret on Folders that have "App" in their name, will also break inheritance if enabled on any of the Folders
 
    .LINK
    https://thycotic-ps.github.io/thycotic.secretserver/commands/folders/Add-TssFolderPermission
 
    .LINK
    https://github.com/thycotic-ps/thycotic.secretserver/blob/main/src/functions/folders/Add-TssFolderPermission.ps1
 
    .NOTES
    Requires TssSession object returned by New-TssSession
    #>

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

        # Folder ID
        [Parameter(Mandatory, ValueFromPipelineByPropertyName)]
        [int[]]
        $FolderId,

        # Name of user to add
        [Parameter(Mandatory, ParameterSetName = 'user')]
        [string]
        $Username,

        # Name of group to add
        [Parameter(Mandatory, ParameterSetName = 'group')]
        [string]
        $Group,

        # Folder Access Role (View, Edit, Add Secret, Owner)
        [Parameter(Mandatory, ParameterSetName = 'user')]
        [Parameter(Mandatory, ParameterSetName = 'group')]
        [ValidateSet('View', 'Edit', 'Add Secret', 'Owner')]
        [string]
        $FolderRole,

        # Secret Access Role (View, Edit, List, Owner, None)
        [Parameter(Mandatory, ParameterSetName = 'user')]
        [Parameter(Mandatory, ParameterSetName = 'group')]
        [ValidateSet('View', 'Edit', 'List', 'Owner', 'None')]
        [string]
        $SecretRole,

        # If provided will break inheritance on the folder and add the permission
        [switch]
        $Force
    )
    begin {
        $tssParams = $PSBoundParameters
    }
    process {
        Write-Verbose "Provided command parameters: $(. $GetInvocation $PSCmdlet.MyInvocation)"
        if ($tssParams.ContainsKey('TssSession') -and $TssSession.IsValidSession()) {
            . $CheckVersion $TssSession '10.9.000000' $PSCmdlet.MyInvocation

            if ($tssParams.ContainsKey('Username')) {
                $users = Search-TssUser -TssSession $TssSession
                $userId = $users.Where({ $_.Username -eq $Username }).Id
            }
            if ($tssParams.ContainsKey('Group')) {
                $groups = Search-TssGroup -TssSession $TssSession
                $groupId = $groups.Where({ $_.GroupName -eq $Group }).Id
            }

            if ($userId.Count -gt 1) {
                Write-Warning "More than one matching Username was found, please provide a more unique name"
                return
            } elseif ($groupId.Count -gt 1) {
                Write-Warning "More than one matching Group Name was found, please provide a more unique name"
                return
            }

            if ($userId -or $groupId) {
                $newFolderPermParams = @{
                    TssSession           = $TssSession
                    FolderId             = $FolderId
                    FolderAccessRoleName = $FolderRole
                    SecretAccessRoleName = $SecretRole
                }
                if ($userId) {
                    $newFolderPermParams.Add('UserId',$userId)
                } elseif ($groupId) {
                    $newFolderPermParams.Add('GroupId',$groupId)
                }
                if ($tssParams.ContainsKey('Force')) {
                    $newFolderPermParams.Add('Force',$Force)
                }
                New-TssFolderPermission @newFolderPermParams
            }
        } else {
            Write-Warning 'No valid session found'
        }
    }
}