Set-EntraUserLicense

Adds or removes licenses for a Microsoft online service to the list of assigned licenses for a user.

Syntax

Set-EntraUserLicense
   -UserId <String>
   -AssignedLicenses <AssignedLicenses>
   [<CommonParameters>]

Description

The Set-EntraUserLicense adds or removes licenses for a Microsoft online service to the list of assigned licenses for a user.

For delegated scenarios, the calling user needs at least one of the following Microsoft Entra roles.

  • Directory Writers
  • License Administrator
  • User Administrator

Note: Before assigning a license, assign a usage location to the user using: Set-EntraUser -ObjectId user@contoso.com -UsageLocation '<two-letter-country-code e.g. GB/US>'.

Examples

Example 1: Add a license to a user based on a template user

Connect-Entra -Scopes 'User.ReadWrite.All'
$LicensedUser = Get-EntraUser -ObjectId 'TemplateUser@contoso.com' 
$License = New-Object -TypeName Microsoft.Open.AzureAD.Model.AssignedLicense 
$License.SkuId = $LicensedUser.AssignedLicenses.SkuId 
$Licenses = New-Object -TypeName Microsoft.Open.AzureAD.Model.AssignedLicenses 
$Licenses.AddLicenses = $License 
$Params = @{
    UserId = 'SawyerM@contoso.com' 
    AssignedLicenses = $Licenses
}
Set-EntraUserLicense @Params

Name                           Value
----                           -----
externalUserStateChangeDateTi…
businessPhones                 {8976546787}
postalCode                     444601
createdDateTime                06-11-2023 04:48:19
surname                        KTETSs
jobTitle                       Manager
employeeType
otherMails                     {SawyerM@contoso.com}
isResourceAccount
usageLocation                  DE
legalAgeGroupClassification    Adult
id                             cccccccc-2222-3333-4444-dddddddddddd
isLicenseReconciliationNeeded  False

This example demonstrates how to assign a license to a user based on a template user.

  • -UserId parameter specifies the object Id of a user(as a UserPrincipalName or ObjectId).
  • -AssignedLicenses parameter specifies a list of licenses to assign or remove.

Example 2: Add a license to a user by copying license from another user

Connect-Entra -Scopes 'User.ReadWrite.All'
$LicensedUser = Get-EntraUser -ObjectId 'AdeleV@contoso.com'
$User = Get-EntraUser -ObjectId 'SawyerM@contoso.com' 
$License1 = New-Object -TypeName Microsoft.Open.AzureAD.Model.AssignedLicense 
$License1.SkuId = $LicensedUser.AssignedLicenses.SkuId[0] 
$License2 = New-Object -TypeName Microsoft.Open.AzureAD.Model.AssignedLicense
$License2.SkuId = $LicensedUser.AssignedLicenses.SkuId[1]
$addLicensesArray = @()
$addLicensesArray += $License1
$addLicensesArray += $License2
$Licenses = New-Object -TypeName Microsoft.Open.AzureAD.Model.AssignedLicenses 
$Licenses.AddLicenses = $addLicensesArray
Set-EntraUserLicense -UserId $User.ObjectId -AssignedLicenses $Licenses

Name                           Value
----                           -----
externalUserStateChangeDateTi…
businessPhones                 {8976546787}
postalCode                     444601
createdDateTime                06-11-2023 04:48:19
surname                        KTETSs
jobTitle                       Manager
employeeType
otherMails                     {SawyerM@contoso.com}
isResourceAccount
usageLocation                  DE
legalAgeGroupClassification    Adult
id                             cccccccc-2222-3333-4444-dddddddddddd
isLicenseReconciliationNeeded  False

This example demonstrates how to assign a license to a user by copying license from another user.

  • -ObjectId parameter specifies the object Id of a user(as a UserPrincipalName or ObjectId).
  • -AssignedLicenses parameter specifies a list of licenses to assign or remove.

Example 3: Remove an assigned User's License

Connect-Entra -Scopes 'User.ReadWrite.All'
$UserPrincipalName = 'SawyerM@contoso.com'
$User = Get-EntraUser -ObjectId $UserPrincipalName
$SkuId = (Get-EntraUserLicenseDetail -ObjectId $UserPrincipalName).SkuId
$Licenses = New-Object -TypeName Microsoft.Open.AzureAD.Model.AssignedLicenses 
$Licenses.RemoveLicenses = $SkuId 
Set-EntraUserLicense -UserId $User.ObjectId -AssignedLicenses $Licenses

Name                           Value
----                           -----
displayName                    SawyerM
id                             cccccccc-2222-3333-4444-dddddddddddd
jobTitle
surname                        M
mail
userPrincipalName              SawyerM@contoso.com
mobilePhone
preferredLanguage
@odata.context                 https://graph.microsoft.com/v1.0/$metadata#users/$entity
businessPhones                 {}
officeLocation
givenName                      Sawyer

This example demonstrates how to remove a user's license by retrieving the user details.

  • -ObjectId parameter specifies the object Id of a user(as a UserPrincipalName or ObjectId).
  • -AssignedLicenses parameter specifies a list of licenses to assign or remove.

Parameters

-AssignedLicenses

Specifies a list of licenses to assign or remove.

Type:AssignedLicenses
Position:Named
Default value:None
Required:True
Accept pipeline input:True
Accept wildcard characters:False

-UserId

Specifies the ID of a user (as a UserPrincipalName or ObjectId) in Microsoft Entra ID.

Type:System.String
Aliases:ObjectId
Position:Named
Default value:None
Required:True
Accept pipeline input:True
Accept wildcard characters:False