Public/Add-AeriesCourseRequest.ps1

function Add-AeriesCourseRequest
{
    <#
        .SYNOPSIS
        Add a Course Request to Aeries

        .DESCRIPTION
        The Add-AeriesCourseRequest cmdlet is used to add a Course Request in Aeries for a given StudentID and SchoolCode

        .EXAMPLE
        Add-AeriesCourseRequest -SchoolCode 994 -StudentID 99400001 -CourseNumber "123456"
        This will create a Course Request in Aeries for StudentID 99400001 at SchoolCode 994 with Course Number 123456
    #>


    [CmdletBinding()]
    param (
        [ValidateRange(1, [Int16]::MaxValue)]
        [Parameter(Mandatory=$true)]
        [Int16]
        $SchoolCode,

        [ValidateRange(1, [Int]::MaxValue)]
        [Parameter(Mandatory=$true)]
        [int]
        $StudentID,

        [ValidateRange(1, [Int16]::MaxValue)]
        [Parameter(Mandatory=$false)]
        [Int16]
        $SectionNumber = -1,

        [ValidateLength(1, 6)]
        [Parameter(Mandatory=$true)]
        [string]
        $CourseNumber,

        [ValidateRange(0, [Int16]::MaxValue)]
        [Parameter(Mandatory=$false)]
        [Int16]
        $PreferredTeacherNumber = -1,

        [ValidateRange(0, [Int]::MaxValue)]
        [Parameter(Mandatory=$false)]
        [int]
        $PreferredStaffID = -1,

        [ValidateLength(0, 2)]
        [Parameter(Mandatory=$false)]
        [string]
        $RejectCode,

        [ValidateSet("", "X")]
        [Parameter(Mandatory=$false)]
        [string]
        $AlternateTag,

        [ValidateLength(1, 6)]
        [Parameter(Mandatory=$false)]
        [string]
        $ActualPrimaryCourseID,

        [ValidateLength(1, 2)]
        [Parameter(Mandatory=$false)]
        [string]
        $PermanentLockCode,

        [Parameter(Mandatory=$false)]
        [Int16[]]
        $AlternateCourseRequestReferences = $null
    )

    Begin {
        Write-Verbose -Message "Begin running $($MyInvocation.MyCommand)"

        $Method = "Post"
        $SuccessStatusCode = 201
        $Endpoint = "v5/schools/$SchoolCode/students/$StudentID/courserequests"
        $ContentType = "application/json"
        $Body = @{}
    }

    Process {
        $Body.CourseID = $CourseNumber

        If ($SectionNumber -gt -1) {
            <# Int16 Value #>
            $Body.SectionNumber = $SectionNumber
        }

        If ($PreferredTeacherNumber -gt -1) {
            <# Int16 Value #>
            $Body.PreferredTeacherNumber = $PreferredTeacherNumber
        }

        If ($PreferredStaffID -gt -1) {
            <# Int Value #>
            $Body.PreferredStaffID = $PreferredStaffID
        }

        If (![string]::IsNullOrWhiteSpace($RejectCode)) {
            <# String Value #>
            $Body.RejectCode = $RejectCode
        }

        If (![string]::IsNullOrWhiteSpace($AlternateTag)) {
            <# String Value #>
            $Body.AlternateTag = $AlternateTag
        }

        If (![string]::IsNullOrWhiteSpace($ActualPrimaryCourseID)) {
            <# String Value #>
            $Body.ActualPrimaryCourseID = $ActualPrimaryCourseID
        }

        If (![string]::IsNullOrWhiteSpace($PermanentLockCode)) {
            <# String Value #>
            $Body.PermanentLockCode = $PermanentLockCode
        }

        If ($AlternateCourseRequestReferences.Count -gt 0) {
            <# Int16[] Value #>
            $Body.AlternateCourseRequestReferences = $AlternateCourseRequestReferences
        }

        <# Turn the $Body variable into a JSON string for sending to the server #>
        $BodyJSON = ($Body | ConvertTo-Json -Compress)

        $Result = (Invoke-AeriesApiCall -Method $Method -Endpoint $Endpoint -SuccessStatusCode $SuccessStatusCode -Body $BodyJSON -ContentType $ContentType)
    }

    End {
        Write-Verbose -Message "Finish running $($MyInvocation.MyCommand)"
        return $Result
    }
}