Public/Set-LMUnmonitoredDevice.ps1

<#
.SYNOPSIS
Updates unmonitored devices in LogicMonitor.

.DESCRIPTION
The Set-LMUnmonitoredDevice function modifies unmonitored devices in LogicMonitor by assigning them to a device group.

.PARAMETER Ids
Specifies an array of unmonitored device IDs to update.

.PARAMETER DeviceGroupId
Specifies the ID of the device group to assign the devices to.

.PARAMETER Description
Specifies a description for the devices.

.PARAMETER CollectorId
Specifies the ID of the collector to assign to the devices. Default is 0.

.EXAMPLE
#Assigns the specified unmonitored devices to the device group and sets their description.
Set-LMUnmonitoredDevice -Ids @("123", "456") -DeviceGroupId 789 -Description "New devices"


.INPUTS
None.

.OUTPUTS
Returns a LogicMonitor.Device object containing the updated device information.

.NOTES
This function requires a valid LogicMonitor API authentication.
#>


function Set-LMUnmonitoredDevice {

    [CmdletBinding(SupportsShouldProcess, ConfirmImpact = 'None')]
    param (
        [Parameter(Mandatory)]
        [String[]]$Ids,

        [Parameter(Mandatory)]
        [Int]$DeviceGroupId,

        [String]$Description = "",

        [Int]$CollectorId = 0

    )
    #Check if we are logged in and have valid api creds
    begin {}
    process {
        if ($Script:LMAuth.Valid) {

            #Build header and uri
            $ResourcePath = "/device/unmonitoreddevices/services/assign"

            $IdsCount = ($Ids | Measure-Object).Count
            $Message = "Device Count: $IdsCount | DeviceGroupId: $DeviceGroupId"

            $Data = @{
                collectorId      = $CollectorId
                description      = $Description
                deviceGroupId    = $DeviceGroupId
                missingDeviceIds = $Ids
            }

            $Data = ($Data | ConvertTo-Json)

            if ($PSCmdlet.ShouldProcess($Message, "Set Unmonitored Device")) {
                
                $Headers = New-LMHeader -Auth $Script:LMAuth -Method "POST" -ResourcePath $ResourcePath -Data $Data
                $Uri = "https://$($Script:LMAuth.Portal).$(Get-LMPortalURI)" + $ResourcePath

                Resolve-LMDebugInfo -Url $Uri -Headers $Headers[0] -Command $MyInvocation -Payload $Data

                #Issue request using new centralized method with retry logic
                $Response = Invoke-LMRestMethod -CallerPSCmdlet $PSCmdlet -Uri $Uri -Method "POST" -Headers $Headers[0] -WebSession $Headers[1] -Body $Data

                return (Add-ObjectTypeInfo -InputObject $Response -TypeName "LogicMonitor.Device" )

            }
        }
        else {
            Write-Error "Please ensure you are logged in before running any commands, use Connect-LMAccount to login and try again."
        }
    }
    end {}
}