Microsoft Teams PowerShell Module 4.7.1-Preview with AzureAD App and Certificate Authentication
Hi All,
A few days ago the Microsoft Teams PowerShell Module 4.7.1-Preview was released. For me a long awaited Feature with Azure AD App Authentication with a Certificate is now partly possible.
MicrosoftTeams 4.7.1-preview
Microsoft Teams PowerShell Release Notes
Application-based authentication in Teams PowerShell Module
data:image/s3,"s3://crabby-images/9ed26/9ed2693ed7c44f767d341beb0c42d284b31a0263" alt=""
data:image/s3,"s3://crabby-images/badd6/badd62add82e6f1847d46d2b22c598d9215ff935" alt=""
To install the Preview Side by Side with the 4.7.0 Module you need to add the -Force Parameter
Get-InstalledModule MicrosoftTeams
Find-Module MicrosoftTeams -AllowPrerelease
Install-Module MicrosoftTeams -AllowPrerelease -Force
Get-InstalledModule MicrosoftTeams -AllVersions
data:image/s3,"s3://crabby-images/1a859/1a8593ab10e1f8be7bc227302863b648d1b93e23" alt=""
The following Permissions are Required for the Teams Commandlets
- User.Read.All
- Group.ReadWrite.All
- AppCatalog.ReadWrite.All
- TeamSettings.ReadWrite.All
- Channel.Delete.All
- ChannelSettings.ReadWrite.All
- ChannelMember.ReadWrite.All
data:image/s3,"s3://crabby-images/51d62/51d62db3e450da32ff4bccc3c7c207dc8a66f0e9" alt=""
After you have addet the Permissions you need to Grant Admin Consent
data:image/s3,"s3://crabby-images/7fedb/7fedbc752e3a6b2491911a1233b3f8c510830908" alt=""
data:image/s3,"s3://crabby-images/ef8d8/ef8d838024506046239785949fec41d0c060190e" alt=""
For the *-CS Commandlets you need to add the Azure AD App to the "Skype for Business Administrators" Role
data:image/s3,"s3://crabby-images/9ca81/9ca81f19ba770926753d16b6d54bfbd9fc5a950a" alt=""
data:image/s3,"s3://crabby-images/47a25/47a25d371542feb11c00f2f6964b94290a38b35d" alt=""
Now we are ready to connect
$AppID = "93b64305-ea5b-41f2-be0f-a2235fb91480" #DemoTeamsPS
$TenantId = "icewolfch.onmicrosoft.com"
$CertificateThumbprint = "4F1C474F862679EC35650824F73903041E1E5742"
Import-Module MicrosoftTeams
Connect-MicrosoftTeams -ApplicationId $AppID -TenantId $TenantId -CertificateThumbprint $CertificateThumbprint
data:image/s3,"s3://crabby-images/729a9/729a94643ea2789b78366b240edaff8d80129cf2" alt=""
Some Test Commandlets
Get-Team
Get-CsOnlineUser -Identity a.bohren@icewolf.ch | fl *Ent*,*host*,*voice*, *line*
Get-CsOnlineUser -Identity a.bohren@icewolf.ch | fl *Ent*,*host*,*voice*, *line*
data:image/s3,"s3://crabby-images/b81b3/b81b3aa434426c10f2854f41c0a07213b7bd1582" alt=""
For now only a few *-CS commandleds are working, but i guess soon the rest will follow
All Non *-Cs cmdlets (for example, Get-Team), Get-CsTenant, Get-CsOnlineUser, Get-CsOnlineVoiceUser & *-CsOnlineSipDomain cmdlets are already supported. Other cmdlets will be gradually rolled out.
For all other cmdlets you will receive an "Access Denied" Error Message
data:image/s3,"s3://crabby-images/86182/8618244b1738e1fa1d078702442072d02a6d7e47" alt=""
Regards
Andres Bohren
data:image/s3,"s3://crabby-images/c5745/c57456aa1f1fe7085de23659730ba18ee766b61a" alt=""