Public/New/New-HaloUser.ps1
Function New-HaloUser { <# .SYNOPSIS Creates a user via the Halo API. .DESCRIPTION Function to send a user creation 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 create a new user. [Parameter( Mandatory = $True )] [Object]$User ) Invoke-HaloPreFlightCheck $CommandName = $MyInvocation.InvocationName try { if ($PSCmdlet.ShouldProcess("User '$($User.name)'", 'Create')) { New-HaloPOSTRequest -Object $User -Endpoint 'users' } } catch { $Command = $CommandName -Replace '-', '' $ErrorRecord = @{ ExceptionType = 'System.Exception' ErrorMessage = "$($CommandName) failed." InnerException = $_.Exception ErrorID = "Halo$($Command)CommandFailed" ErrorCategory = 'ReadError' TargetObject = $_.TargetObject ErrorDetails = $_.ErrorDetails BubbleUpDetails = $False } $CommandError = New-HaloErrorRecord @ErrorRecord $PSCmdlet.ThrowTerminatingError($CommandError) } } |