Toolkit/Public/Get-RscMongoDatabase.ps1
#Requires -Version 3 function Get-RscMongoDatabase { <# .SYNOPSIS Retrieves RscMongoDatabase objects protected by Rubrik Security Cloud .DESCRIPTION This cmdlet uses the GQL query 'mongoDatabases' to retrieve a list of VMs with a predetermined set of properties. .LINK Schema reference: https://rubrikinc.github.io/rubrik-api-documentation/schema/reference .EXAMPLE # Get all Get-RscMongoDatabase .EXAMPLE # Get object with specific name Get-RscMongoDatabase -Name "jake-001" .EXAMPLE # Get objects by specifying part of a name Get-RscMongoDatabase -Name "*jake*" #> [CmdletBinding( DefaultParameterSetName = "Name" )] Param( [Parameter( Mandatory = $false, ParameterSetName = "Id" )] [String]$Id, [Parameter( Position = 0, Mandatory = $false, ParameterSetName = "Name" )] [String]$Name, [Parameter( Mandatory = $false, ValueFromPipeline = $true, ParameterSetName = "Name" )] [RubrikSecurityCloud.Types.GlobalSlaReply]$Sla, [Parameter( Mandatory = $false, ValueFromPipeline = $true, ParameterSetName = "Name" )] [RubrikSecurityCloud.Types.Cluster]$Cluster, [Parameter( Mandatory = $false, ValueFromPipeline = $true, ParameterSetName = "Name" )] [RubrikSecurityCloud.Types.MongoSource]$MongoSource ) Process { # The query is different for getting a single object by ID. if ($Id) { $query = New-RscQuery -GqlQuery mongoDatabase $query.var.filter = @() $query.Var.fid = $Id $result = Invoke-Rsc -Query $query $result } else { $query = New-RscQuery -GqlQuery mongoDatabases $query.var.filter = @() if ($Name) { $nameFilter = New-Object -TypeName RubrikSecurityCloud.Types.Filter # Regex filter doesn't work in the API right now, but we're going to play pretend. # With real Regex, users could search for VMs that start with the letter A if they wanted. if ($name.Contains("*")) { $name.Replace("*",'') $nameFilter.Field = [RubrikSecurityCloud.Types.HierarchyFilterField]::REGEX $nameFilter.texts = $Name.Replace("*",'') } else { $nameFilter.Field = [RubrikSecurityCloud.Types.HierarchyFilterField]::NAME_EXACT_MATCH $nameFilter.texts = $Name } $query.var.filter += $nameFilter } if ($Sla) { $slaFilter = New-Object -TypeName RubrikSecurityCloud.Types.Filter $slaFilter.Field = [RubrikSecurityCloud.Types.HierarchyFilterField]::EFFECTIVE_SLA $slaFilter.Texts = $Sla.id $query.var.filter += $slaFilter } if ($Cluster) { $clusterFilter = New-Object -TypeName RubrikSecurityCloud.Types.Filter $clusterFilter.Field = [RubrikSecurityCloud.Types.HierarchyFilterField]::CLUSTER_ID $clusterFilter.Texts = $Cluster.id $query.var.filter += $clusterFilter } if ($MongoSource) { $MongoSourceFilter = New-Object -TypeName RubrikSecurityCloud.Types.Filter $MongoSourceFilter.Field = [RubrikSecurityCloud.Types.HierarchyFilterField]::MONGO_SOURCE_ID $MongoSourceFilter.Texts = $MongoSource.id $query.var.filter += $MongoSourceFilter } $result = Invoke-Rsc -Query $query $result.nodes } } } |