Functions/AccountGroups/Get-PASAccountGroup.ps1

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
# .ExternalHelp psPAS-help.xml
function Get-PASAccountGroup {
    [CmdletBinding(DefaultParameterSetName = "Gen2")]
    param(
        [parameter(
            Mandatory = $true,
            ValueFromPipelinebyPropertyName = $true,
            ParameterSetName = "Gen2"
        )]
        [parameter(
            Mandatory = $true,
            ValueFromPipelinebyPropertyName = $true,
            ParameterSetName = "Gen1"
        )]
        [string]$Safe,

        [parameter(
            Mandatory = $false,
            ValueFromPipelinebyPropertyName = $false,
            ParameterSetName = "Gen1"
        )]
        [Alias("UseClassicAPI")]
        [switch]$UseGen1API
    )

    BEGIN { }#begin

    PROCESS {

        switch ($PSCmdlet.ParameterSetName) {

            "Gen1" {

                Assert-VersionRequirement -RequiredVersion 9.10
                #Create URL for Request
                $URI = "$Script:BaseURI/API/AccountGroups?$($PSBoundParameters | Get-PASParameter | ConvertTo-QueryString)"

                break

            }

            default {

                Assert-VersionRequirement -RequiredVersion 10.5
                #Create URL for Request
                $URI = "$Script:BaseURI/API/Safes/$($Safe | Get-EscapedString)/AccountGroups"

            }

        }


        #send request to PAS web service
        $result = Invoke-PASRestMethod -Uri $URI -Method GET -WebSession $Script:WebSession

        If ($null -ne $result) {

            $result | Add-ObjectDetail -typename psPAS.CyberArk.Vault.Account.Group

        }

    }#process

    END { }#end

}