functions/Get-MCASReport.ps1

<#
.Synopsis
    Get-MCASReport retrieves a list of built-in reports from the Cloud App Security tenant.
.DESCRIPTION
    Retrieves a reports list from the built-in reports of an MCAS tenant.
.EXAMPLE
    PS C:\> Get-MCASReport | select FriendlyName,report_category
 
    FriendlyName report_category
    ------------ ---------------
    Privileged Users User Management
    Browser Use Security
    Outbound Sharing by Domain Data Management
    Data Sharing Overview Data Management
    Salesforce Special Privileged Accounts User Management
    Owners of Shared Files Data Management
    Inactive Accounts
 
    This example retrives the reports list, showing the friendly name of the report and its category.
 
.EXAMPLE
    PS C:\> Get-MCASReport | Get-MCASReportContent
 
    This example retrives the reports list and pipes the list into the Get-MCASReportContent command to get the data for each one.
#>
function Get-MCASReport {
    [CmdletBinding()]
    param
    (
        # Specifies the credential object containing tenant as username (e.g. 'contoso.us.portal.cloudappsecurity.com') and the 64-character hexadecimal Oauth token as the password.
        [Parameter(Mandatory=$false)]
        [ValidateNotNullOrEmpty()]
        [System.Management.Automation.PSCredential]$Credential = $CASCredential
    )

    # Get the matching items and handle errors
    try {
        $response = Invoke-MCASRestMethod -Credential $Credential -Path "/cas/api/reports/" -Method Get
    }
    catch {
        throw "Error calling MCAS API. The exception was: $_"
    }

    $response = $response.data

    try {
        $response = $response | Add-Member -MemberType AliasProperty -Name Identity -Value _id -PassThru | ForEach-Object {Add-Member -InputObject $_ -MemberType NoteProperty -Name FriendlyName -Value $ReportsListReverse.Get_Item($_.non_entities_report) -PassThru}
    }
    catch {}
    
    $response
}