Public/SSL/func_Get-OPSSLOrders.ps1
function Get-OPSSLOrders { param ( [int]$ID, [switch]$ExpiringSoon ) try { # same for both requests $request_body = @{ limit = 1000 status = "ACT&status=REQ" } # if ID is empty if ($ID -eq "") { $request = Invoke-OPRequest -Method Get -Endpoint "ssl/orders" -Body $request_body $request = $request.data.results } else { $request = Invoke-OPRequest -Method Get -Endpoint "ssl/orders/$($ID)" $request = $request.data } $statusMap = [PSCustomObject]@{ "ACT" = "Active" "REQ" = "Requested" "PAI" = "Paid" "REJ" = "Rejected" "DEL" = "Deleted" "EXP" = "Expired" "FAI" = "Failed" } # create return object $return_object = @() foreach ($order in $request) { $return_object += [PSCustomObject]@{ ID = $order.id Product = $order.product_name Hostname = $order.common_name Status = ($statusMap | Select-Object $($order.status)).$($order.status) ExpirationDate = [datetime]$order.expiration_date Period = $order.period AutoRenew = if ($order.autorenew -eq "on") { $true } else { $false } ValidationMethod = $order.validation_method EmailApprover = $order.email_approver } } if ($ExpiringSoon) { $dateToExpire = (Get-Date).AddDays(30) $return_object = $return_object | Where-Object { $_.ExpirationDate -lt $dateToExpire -and $_.ExpirationDate -gt (Get-Date) } } } catch { throw $_.Exception.Message } return $return_object } |