TeamsUserEnroller.psm1
Function Import-TeamsUsers { <# .SYNOPSIS Import-TeamsUsers is a Powershell function that will enrol users from a CSV file into a given Microsoft Teams group. .DESCRIPTION Import-TeamsUsers is a Powershell function that will enrol users from a CSV file into a given Microsoft Teams group. .PARAMETER File The path to the CSV file that contains your users. Can either be an absolute path or relative path. .PARAMETER Create If specified, create a new Group first, then add the users from the CSV file. .PARAMETER Delimiter If specified, overrides the default CSV delimiter of ','. .PARAMETER Encoding If specified, manually sets the encoding of the CSV file. .EXAMPLE Import-TeamsUsers -File "users.csv" .EXAMPLE Import-TeamsUsers -Create -File "users.csv" #> Param( [parameter(Mandatory=$true, position=1, ParameterSetName='Params', HelpMessage="Specify CSV file")] [string]$File, [parameter(Mandatory=$false, position=2, ParameterSetName='Params', HelpMessage="Create new Teams group")] [switch]$Create, [parameter(Mandatory=$false, position=3, ParameterSetName='Params', HelpMessage="Override default CSV delimiter")] [string]$Delimiter, [parameter(Mandatory=$false, position=4, ParameterSetName='Params', HelpMessage="Manually set CSV encoding")] [string]$Encoding ) Begin { $ErrorActionPreference = 'Stop' ##### CHECK FOR NEW VERSION ##### Try { # Get information from GitHub Releases $releases = Invoke-RestMethod -Method Get -Uri "https://api.github.com/repos/luketainton/TeamsUserEnroller/releases"; $rel = $releases[0]; $latest_version = $rel.tag_name -replace 'v', ''; $latest_version_changes = $rel.body; # Get currently installed version $current_version = (Get-Module TeamsUserEnroller | Select-Object Version).Version; # Compare versions and alert user if newer version available if ($current_version -lt $latest_version) { Write-Host -ForegroundColor Yellow "A new version of TeamsUserEnroller has been released!"; Write-Host -ForegroundColor Yellow "Latest version: $latest_version"; Write-Host -ForegroundColor Yellow "Installed version: $current_version"; Write-Host -ForegroundColor Yellow "`n$latest_version_changes"; $Consent = Read-Host -Prompt "`nWould you like to update now? [y/N]" If ($Consent -eq "y" -Or $Consent -eq "Y") { Update-Module -Name TeamsUserEnroller -RequiredVersion "2.2.0"; $after_update_ver = (Get-Module TeamsUserEnroller | Select-Object Version).Version; if ($after_update_ver -eq $latest_version) { Write-Host -ForegroundColor Green "Update completed."; } Else { Write-Host -ForegroundColor Red "Update failed. Please update manually."; } } } } Catch { Write-Host -ForegroundColor Red "An error occurred while checking for updates. Continuing."; } ##### IMPORT CSV FILE ##### Try { $ImportCmd = "Import-CSV $File" If ($Delimiter) { $ImportCmd = $ImportCmd + " -Delimiter $Delimiter" } If ($Encoding) { $ImportCmd = $ImportCmd + " -Encoding $Encoding" } $Users = Invoke-Expression $ImportCmd } Catch { Write-Host -ForegroundColor Red "$File is not a valid CSV file." Exit } ##### CHECK MODULE IS INSTALLED AND IMPORTED ##### if (Get-Module -ListAvailable -Name MicrosoftTeams) { try { Import-Module -Name MicrosoftTeams $Email = (Connect-MicrosoftTeams -Verbose:$false).Account } Catch { Write-Host -ForegroundColor Red "There was an error during authentication." Write-Host "If you're not on Windows and use Multi-Factor Authentication, please manually pass the MFA check in your browser, then try again." Exit } } else { Write-Host -ForegroundColor Red "Module MicrosoftTeams doesn't exist. Please run 'Install-Module -Name MicrosoftTeams' and retry." Exit } } Process { If ($Create) { ##### CREATE NEW TEAM ##### Clear-Host $NewTeamName = Read-Host -Prompt "Name of the new group" $NewTeamDesc = Read-Host -Prompt "Group description" $NewTeamPriv = Read-Host -Prompt "P[u]blic or P[r]ivate?" If ($NewTeamPriv -Eq "u") { $NewTeamVis = "Public" } Elseif ($NewTeamPriv -Eq "r") { $NewTeamVis = "Private" } $NewTeam = New-Team -DisplayName $NewTeamName -MailNickName $NewTeamName -Description $NewTeamDesc -Visibility $NewTeamVis $GroupId = $NewTeam.GroupId } Else { ##### GET USER'S TEAMS ##### Clear-Host Write-Host -ForegroundColor Green "Getting your teams - please wait" $EligibleTeams = @() Get-Team -User $Email -Verbose:$false | ForEach-Object { $CTeamId = $_.GroupId $CTeamName = $_.DisplayName If (Get-TeamUser -GroupId $CTeamId | Select-Object -Property User,Role | Where-Object {$_.User -eq $Email} | Where-Object {$_.Role -eq "owner"}) { $EligibleTeams += @{GroupId = $CTeamId; DisplayName = $CTeamName} } Clear-Variable -Name CTeamId Clear-Variable -Name CTeamName } Clear-Host Write-Host "Teams that you own:" $EligibleTeams | ForEach-Object {[PSCustomObject]$_} | Format-Table 'GroupId', 'DisplayName' -AutoSize $GroupId = Read-Host -Prompt "GroupId of the desired group" } ##### ENROL USERS ##### $global:UsersAdded = 0; $UserCount = $Users | Measure-Object | Select-Object -expand count $Consent = Read-Host -Prompt "You are about to add $UserCount users. Are you sure? [y/N]" If ($Consent -eq "y" -Or $Consent -eq "Y") { $Users | ForEach-Object { $User = $_.email $Role = $_.role Try { Add-TeamUser -GroupId $GroupId -Role $Role -User $User Write-Host "Added user $User with role $Role" $global:UsersAdded++ } Catch [Microsoft.TeamsCmdlets.PowerShell.Custom.ErrorHandling.ApiException] { Write-Host -ForegroundColor Red "Error adding user $User with role $Role" } Clear-Variable -Name User Clear-Variable -Name Role } Write-Host -ForegroundColor Green "$global:UsersAdded users added successfully." } Else { Write-Host -ForegroundColor Red "Aborting." } } End { @('UserCount', 'UsersAdded', 'Consent', 'Users', 'GroupId') | ForEach-Object {Clear-Variable -Name $_} Disconnect-MicrosoftTeams } } |