Public/Set/Set-HaloSite.ps1

Function Set-HaloSite {
    <#
        .SYNOPSIS
            Updates a site via the Halo API.
        .DESCRIPTION
            Function to send a site update request to the Halo API
        .OUTPUTS
            Outputs an object containing the response from the web request.
    #>

    [CmdletBinding( SupportsShouldProcess = $True )]
    [OutputType([Object])]
    Param (
        # Object containing properties and values used to update an existing site.
        [Parameter( Mandatory = $True )]
        [Object]$Site
    )
    try {
        $ObjectToUpdate = Get-HaloSite -SiteID $Site.id
        if ($ObjectToUpdate) {
            if ($PSCmdlet.ShouldProcess("Site '$($ObjectToUpdate.name)'", "Update")) {
                New-HaloPOSTRequest -Object $Site -Endpoint "site" -Update
            }
        } else {
            Throw "Site was not found in Halo to update."
        }
    } catch {
        Write-Error "Failed to update site with the Halo API. You'll see more detail if using '-Verbose'"
        Write-Verbose "$_"
    }
}