Public/New-GSUser.ps1

function New-GSUser {
<#
.Synopsis
   Create a new Google user
.DESCRIPTION
   Create a new Google user, allowing for full property setting on creation
.EXAMPLE
   New-GSUser -PrimaryEmail john.smith@domain.com -GivenName John -FamilyName Smith -Password Password123 -ChangePasswordAtNextLogin True -OrgUnitPath "/Users/New Hires" -IncludeInGlobalAddressList True
#>

    
    [cmdletbinding()]
    Param
    (
      [parameter(Mandatory=$true)]
      [String]
      $PrimaryEmail,
      [parameter(Mandatory=$true)]
      [String]
      $GivenName,
      [parameter(Mandatory=$true)]
      [String]
      $FamilyName,
      [parameter(Mandatory=$true)]
      [String]
      $Password,
      [parameter(Mandatory=$false)]
      [ValidateSet($true,$false)]
      [string]
      $ChangePasswordAtNextLogin,
      [parameter(Mandatory=$false)]
      [String]
      $OrgUnitPath,
      [parameter(Mandatory=$false)]
      [ValidateSet($true,$false)]
      [String]
      $Suspended,
      [parameter(Mandatory=$false)]
      [ValidateSet($true,$false)]
      [String]
      $IncludeInGlobalAddressList,
      [parameter(Mandatory=$false)]
      [ValidateSet($true,$false)]
      [String]
      $IPWhitelisted,
      [parameter(Mandatory=$false)]
      [String]
      $AccessToken,
      [parameter(Mandatory=$false)]
      [ValidateNotNullOrEmpty()]
      [String]
      $P12KeyPath = $Script:PSGSuite.P12KeyPath,
      [parameter(Mandatory=$false)]
      [ValidateNotNullOrEmpty()]
      [String]
      $AppEmail = $Script:PSGSuite.AppEmail,
      [parameter(Mandatory=$false)]
      [ValidateNotNullOrEmpty()]
      [String]
      $AdminEmail = $Script:PSGSuite.AdminEmail
    )
if (!$AccessToken)
    {
    $AccessToken = Get-GSToken -P12KeyPath $P12KeyPath -Scopes "https://www.googleapis.com/auth/admin.directory.user" -AppEmail $AppEmail -AdminEmail $AdminEmail
    }
$header = @{
    Authorization="Bearer $AccessToken"
    }
$body = @{
    primaryEmail = $PrimaryEmail
    password = $Password
    name = @{
        familyName = $FamilyName
        givenName = $GivenName
        }
    }

if($OrgUnitPath){$body.Add("orgUnitPath",$OrgUnitPath)}
if($ChangePasswordAtNextLogin -eq $true){$body.Add("changePasswordAtNextLogin",$true)}
elseif($ChangePasswordAtNextLogin -eq $false){$body.Add("changePasswordAtNextLogin",$false)}
if($Suspended -eq $true){$body.Add("suspended",$true)}
elseif($Suspended -eq $false){$body.Add("suspended",$false)}
if($IncludeInGlobalAddressList -eq $true){$body.Add("includeInGlobalAddressList",$true)}
elseif($IncludeInGlobalAddressList -eq $false){$body.Add("includeInGlobalAddressList",$false)}
if($IPWhitelisted -eq $true){$body.Add("ipWhitelisted",$true)}
elseif($IPWhitelisted -eq $false){$body.Add("ipWhitelisted",$false)}


$body = $body | ConvertTo-Json
$URI = "https://www.googleapis.com/admin/directory/v1/users"
try
    {
    $response = Invoke-RestMethod -Method Post -Uri $URI -Headers $header -Body $body -ContentType "application/json" | ForEach-Object {if($_.kind -like "*#*"){$_.PSObject.TypeNames.Insert(0,$(Convert-KindToType -Kind $_.kind));$_}else{$_}}
    }
catch
    {
    try
        {
        $result = $_.Exception.Response.GetResponseStream()
        $reader = New-Object System.IO.StreamReader($result)
        $reader.BaseStream.Position = 0
        $reader.DiscardBufferedData()
        $resp = $reader.ReadToEnd()
        $response = $resp | ConvertFrom-Json | 
            Select-Object @{N="Error";E={$Error[0]}},@{N="Code";E={$_.error.Code}},@{N="Message";E={$_.error.Message}},@{N="Domain";E={$_.error.errors.domain}},@{N="Reason";E={$_.error.errors.reason}}
        Write-Error "$(Get-HTTPStatus -Code $response.Code): $($response.Domain) / $($response.Message) / $($response.Reason)"
        return
        }
    catch
        {
        Write-Error $resp
        return
        }
    }
return $response
}