functions/Get-MCASSubnetCollection.ps1
<#
.Synopsis Lists the subnet collections that are defined in MCAS for enrichment of IP address information. .DESCRIPTION Get-MCASSubnetCollection gets subnet collections defined in the MCAS tenant. .EXAMPLE PS C:\> Get-MCASSubnetCollection category : 1 subnets : {@{originalString=10.0.0.0/8; mask=104; address=0000:0000:0000:0000:0000:ffff:0a00:0000}} name : Contoso Internal IPs tags : {} location : _tid : 26034820 organization : _id : 5a9e053df82b1bb8af51c802 Identity : 5a9e053df82b1bb8af51c802 category : 1 subnets : {@{originalString=1.1.1.1/32; mask=128; address=0000:0000:0000:0000:0000:ffff:0101:0101}, @{originalString=2.2.2.2/32; mask=128; address=0000:0000:0000:0000:0000:ffff:0202:0202}} name : Contoso Egress IPs tags : {} location : _tid : 26034820 organization : _id : 5a9e04c7f82b1bb8af51c7fb Identity : 5a9e04c7f82b1bb8af51c7fb .FUNCTIONALITY Get-MCASSubnetCollection is intended to return the subnet collections that are defined in MCAS. #> function Get-MCASSubnetCollection { [CmdletBinding()] param ( # Specifies the CAS credential object containing the 64-character hexadecimal OAuth token used for authentication and authorization to the CAS tenant. [Parameter(Mandatory=$false)] [ValidateNotNullOrEmpty()] [System.Management.Automation.PSCredential]$Credential = $CASCredential, # Specifies the maximum number of results to retrieve when listing items matching the specified filter criteria. [Parameter(ParameterSetName='List', Mandatory=$false)] [ValidateRange(1,100)] [int]$ResultSetSize = 100, # Specifies the number of records, from the beginning of the result set, to skip. [Parameter(ParameterSetName='List', Mandatory=$false)] [ValidateScript({$_ -gt -1})] [int]$Skip = 0 ) $body = @{'skip'=$Skip;'limit'=$ResultSetSize} # Base request body try { $response = Invoke-MCASRestMethod -Credential $Credential -Path "/cas/api/v1/subnet/" -Method Post -Body $body } catch { throw $_ #Exception handling is in Invoke-MCASRestMethod, so here we just want to throw it back up the call stack, with no additional logic } $response = $response.data try { Write-Verbose "Adding alias property to results, if appropriate" $response = $response | Add-Member -MemberType AliasProperty -Name Identity -Value '_id' -PassThru } catch {} $response } |