CyOpticsDetections.ps1

<#
.SYNOPSIS
    Gets a list of all detections from the console.
 
    Note that this does
 
.PARAMETER API
    Optional. API Handle (use only when not using session scope).
#>

function Get-CyDetectionList {
    Param (
        [parameter(Mandatory=$false)]
        [CylanceAPIHandle]$API = $GlobalCyAPIHandle,
        [parameter(Mandatory=$false)]
        [DateTime]$Start,
        [parameter(Mandatory=$false)]
        [DateTime]$End,
        [parameter(Mandatory=$false)]
        [ValidateSet ("Informational", "Low", "Medium", "High")]
        [String]$Severity,
        [parameter(Mandatory=$false)]
        [String]$DetectionType,
        [parameter(Mandatory=$false)]
        [String]$DetectedOn,
        [parameter(Mandatory=$false)]
        [String]$EventNumber,
        [parameter(Mandatory=$false)]
        [String]$Device,
        [parameter(Mandatory=$false)]
        [ValidateSet ("New", "False Positive", "Follow Up", "In Progress", "Reviewed", "Done")]
        [string]$Status,
        [parameter(Mandatory=$false)]
        [ValidateSet ("Severity", "OccurrenceTime", "Status", "Device", "PhoneticId", "Description")]
        [string]$Sort
    )

    $params = @{}

    if ($null -ne $Start) {
        $params.start = ConvertTo-CyDateString -Date $Start

    }
    if ($null -ne $End) {
        $params.end = ConvertTo-CyDateString -Date $End
    }
    if (![String]::IsNullOrEmpty($Severity)) {
        $params.severity = $Severity
    }

    if (![String]::IsNullOrEmpty($Status)) {
        $params.status = $Status
    }

    if (![String]::IsNullOrEmpty($Device)) {
        $params.device = $Device
    }

    if (![String]::IsNullOrEmpty($DetectionType)) {
        $params.detection_type = $DetectionType
    }

    if (![String]::IsNullOrEmpty($DetectedOn)) {
        $params.detected_on = $DetectedOn
    }

    if (![String]::IsNullOrEmpty($EventNumber)) {
        $params.event_number = $EventNumber
    }

    if (![String]::IsNullOrEmpty($Sort)) {
        $params.sort = $Sort
    }

    Read-CyData -API $API -Uri "$($API.BaseUrl)/detections/v2" -QueryParams $params
}

<#
.SYNOPSIS
    Gets a list of all detections from the console.
 
.PARAMETER API
    Optional. API Handle (use only when not using session scope).
#>

function Get-CyDetectionRecentList {
    Param (
        [parameter(Mandatory=$false)]
        [CylanceAPIHandle]$API = $GlobalCyAPIHandle,
        [parameter(Mandatory=$true)]
        [DateTime]$Since
    )

    $params = @{
        Since = ConvertTo-CyDateString -Date $Since
    }   

    Read-CyData -API $API -Uri "$($API.BaseUrl)/detections/v2/recent" -QueryParams $params
}


<#
.SYNOPSIS
    Gets a list of all detections from the console.
 
.PARAMETER API
    Optional. API Handle (use only when not using session scope).
#>

function Get-CyDetectionDetail {
    Param (
        [parameter(Mandatory=$false)]
        [CylanceAPIHandle]$API = $GlobalCyAPIHandle,
        [parameter(Mandatory=$true,
            ValueFromPipeline=$true,
            ValueFromPipelineByPropertyName=$true)]
        [object]$Detection
        )

    Begin
    {

    }

    Process
    {
        Invoke-CyRestMethod -API $API -Method GET -Uri  "$($API.BaseUrl)/detections/v2/$($Detection.id)/details" | Convert-CyObject
    }
}

<#
.SYNOPSIS
    Deletes a detection.
 
.PARAMETER API
    Optional. API Handle (use only when not using session scope).
 
.PARAMETER Detection
    The detection object to delete.
#>

function Remove-CyDetection {
    Param (
        [parameter(Mandatory=$false)]
        [ValidateNotNullOrEmpty()]
        [CylanceAPIHandle]$API = $GlobalCyAPIHandle,
        [Parameter(
            Mandatory=$true, 
            ValueFromPipeline=$true,
            ValueFromPipelineByPropertyName=$true)]
        [object]$Detection
    )

    Begin {
    }

    Process {
        # remain silent
        switch ($PSCmdlet.ParameterSetName) {
            "ByDeviceId" {
                $devices += $DeviceId
            }
            "ByDevice" {
                $devices += $Device.id
            }
        }
    }

    End {
        $updateMap = @{
            "device_ids" = $devices
        }

        if (![String]::IsNullOrEmpty($CallbackUrl)) {
            $updateMap += @{ "url" = $CallbackUrl }
        }

        $json = ConvertTo-Json $updateMap
        Write-verbose "Update Map: $($json)"
        # remain silent
        $null = Invoke-CyRestMethod -API $API -Method DELETE -Uri "$($API.BaseUrl)/devices/v2" -ContentType "application/json; charset=utf-8" -Body $json
    }
}


<#
.SYNOPSIS
    Updates a detection's fields.
 
.PARAMETER API
    Optional. API Handle (use only when not using session scope).
#>

function Update-CyDetection {
    Param (
        [parameter(Mandatory=$false)]
        [CylanceAPIHandle]$API = $GlobalCyAPIHandle,
        [parameter(Mandatory=$false)]
        [ValidateSet ("New", "False Positive", "Follow Up", "In Progress", "Reviewed", "Done")]
        [string]$Status,
        [parameter(Mandatory=$false)]
        [string]$Comment,
        [parameter(Mandatory=$true,
            ValueFromPipeline=$true,
            ValueFromPipelineByPropertyName=$true)]
        [object]$Detection
        )

    Begin {
        $updateFields = @{}
        if (![String]::IsNullOrEmpty($Status)) {
            $updateFields.status = $Status
        }
        if (![String]::IsNullOrEmpty($Comment)) {
            $updateFields.comment = $Comment
        }
    }

    Process {
        $transaction = @(
            @{
                "detection_id" = $Detection.Id;
                "field_to_update" = $updateFields;
            }
        )
        $json = ConvertTo-Json $transaction
        Write-Verbose "$($json)"
        Invoke-CyRestMethod -API $API -Method POST -Uri "$($API.BaseUrl)/detections/v2/update/" -Body $json
    }
}

<#
.SYNOPSIS
    Gets a list of all detection exceptions from the console.
 
.PARAMETER API
    Optional. API Handle (use only when not using session scope).
#>


function Get-CyDetectionExceptionList {
    Param (
        [parameter(Mandatory=$false)]
        [CylanceAPIHandle]$API = $GlobalCyAPIHandle
    )
    Read-CyData -API $API -Uri "$($API.BaseUrl)/exceptions/v2" -QueryParams $params
}


<#
.SYNOPSIS
    Gets a definition for a detection exception
 
.PARAMETER API
    Optional. API Handle (use only when not using session scope).
 
.PARAMETER Exception
    The exception to retrieve (use object obtained with "Get-CyDetectionExceptionList")
#>

function Get-CyDetectionExceptionDetail {
    Param (
        [parameter(Mandatory=$false)]
        [CylanceAPIHandle]$API = $GlobalCyAPIHandle,
        [parameter(Mandatory=$true, ValueFromPipeline=$true)]
        [object[]]$Exception
    )

    Begin {

    }

    Process {
        Invoke-CyRestMethod -API $API -Method GET -Uri  "$($API.BaseUrl)/exceptions/v2/$($Exception.id)" | Convert-CyObject
    }
}