Functions/SafeMembers/Get-PASSafeMember.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
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
# .ExternalHelp psPAS-help.xml
function Get-PASSafeMember {
    [CmdletBinding(DefaultParameterSetName = "SafePermissions")]
    param(
        [parameter(
            Mandatory = $true,
            ValueFromPipelinebyPropertyName = $true
        )]
        [ValidateNotNullOrEmpty()]
        [string]$SafeName,

        [Alias("UserName")]
        [parameter(
            Mandatory = $true,
            ValueFromPipelinebyPropertyName = $true,
            ParameterSetName = "MemberPermissions"
        )]
        [ValidateNotNullOrEmpty()]
        [string]$MemberName
    )

    BEGIN {

        $Request = @{ }
        $Method = "GET"

    }#begin

    PROCESS {

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

        switch ($PSCmdlet.ParameterSetName) {

            "MemberPermissions" {

                #Create URL for member specific request
                $URI = "$URI/$($MemberName | Get-EscapedString)"
                #Send a PUT Request instead of GET
                $Method = "PUT"
                #Send an empty body
                #Add to Request parameters for PUT Request
                $Request["Body"] = @{"member" = @{ } } | ConvertTo-Json

                break

            }

        }

        #Build Request Parameters
        $Request["URI"] = $URI
        $Request["Method"] = $Method
        $Request["WebSession"] = $Script:WebSession

        #Send request to webservice
        $result = Invoke-PASRestMethod @Request

        If ($null -ne $result) {

            switch ($PSCmdlet.ParameterSetName) {

                "MemberPermissions" {

                    #format output
                    $Output = $result.member | Select-Object MembershipExpirationDate,

                    @{Name = "UserName"; "Expression" = { $MemberName } },

                    @{Name = "Permissions"; "Expression" = {

                            $result.member.permissions | ConvertFrom-KeyValuePair }

                    }

                    break

                }

                default {

                    #output
                    $Output = $result.members | Select-Object UserName, Permissions

                }

            }

            $Output | Add-ObjectDetail -typename psPAS.CyberArk.Vault.Safe.Member -PropertyToAdd @{

                "SafeName" = $SafeName

            }

        }

    }#process

    END { }#end

}