ESC
Type to search...

EngagementRole.ReadWrite.All

Export JSON
Export CSV
Copy URL
Print
ApplicationDelegated Read/Write All Resources

Allows the app to assign Viva Engage role to a user, and remove a Viva Engage role from a user without a signed-in user.

Permission data: April 6, 2026 at 4:06 AM UTC
Delegated Access App-Only Access

Permission Details

Application Permission

Modify Viva Engage role membership

Allows the app to assign Viva Engage role to a user, and remove a Viva Engage role from a user without a signed-in user.

Delegated Permission Admin consent required

Modify Viva Engage role membership

Allows the app to assign Viva Engage role to a user, and remove a Viva Engage role from a user behalf of the signed-in user.

Properties

Microsoft Graph v1.0 exact-category-docs

Properties is shown from stable Microsoft Graph v1.0 metadata.

Property Type Description
displayName String The name of the role.
id String The unique identifier of the role. Read-only. Inherited from entity
members engagementRoleMember collection Users that have this role assigned.

JSON Representation

Microsoft Graph v1.0 exact-category-docs

JSON representation is shown from stable Microsoft Graph v1.0 metadata.

JSON representation
{
  "@odata.type": "#microsoft.graph.engagementRole",
  "displayName": "String",
  "id": "String (identifier)"
}

Relationships

Microsoft Graph v1.0 exact-category-docs

Relationships is shown from stable Microsoft Graph v1.0 metadata.

Relationship Type Description
members engagementRoleMember collection Users that have this role assigned.

Graph Methods

Delegated access App-only access
Exact Microsoft Learn match

Microsoft Graph v1.0 endpoints are mapped directly from refreshed Microsoft Learn permissions tables.

Methods
GET /employeeExperience/roles
GET /employeeExperience/roles/{engagementRoleId}/members
GET /me/employeeExperience/assignedRoles
GET /users/{userId}/employeeExperience/assignedRoles
POST /employeeExperience/roles/{engagementRoleId}/members
DELETE /employeeExperience/roles/{engagementRoleId}/members/{engagementRoleMemberId}
Exact Microsoft Learn match

Microsoft Graph beta endpoints are mapped directly from refreshed Microsoft Learn permissions tables.

Methods
GET /employeeExperience/roles
GET /employeeExperience/roles/{engagementRoleId}/members
GET /me/employeeExperience/assignedRoles
GET /users/{userId}/employeeExperience/assignedRoles
POST /employeeExperience/roles/{engagementRoleId}/members
DELETE /employeeExperience/roles/{engagementRoleId}/members/{engagementRoleMemberId}
No Microsoft Learn PowerShell mapping available

Microsoft Graph PowerShell v1.0 commands are not available from refreshed Microsoft Learn PowerShell snippets for this permission.

No deterministic PowerShell command map is available for this permission.

Browse PowerShell docs
No Microsoft Learn PowerShell mapping available

Microsoft Graph PowerShell beta commands are not available from refreshed Microsoft Learn PowerShell snippets for this permission.

No deterministic PowerShell command map is available for this permission.

Browse PowerShell docs

Code Examples

C# / .NET SDK
Create engagementRoleMember
// Code snippets are only available for the latest version. Current version is 5.x

// Dependencies
using Microsoft.Graph.Models;

var requestBody = new EngagementRoleMember
{
	AdditionalData = new Dictionary<string, object>
	{
		{
			"[email protected]" , "https://graph.microsoft.com/v1.0/users('e8d9f6a2-1c34-4b7a-9f11-2a4d8b7c9e01')"
		},
	},
};

// To initialize your graphClient, see https://learn.microsoft.com/en-us/graph/sdks/create-client?from=snippets&tabs=csharp
var result = await graphClient.EmployeeExperience.Roles["{engagementRole-id}"].Members.PostAsync(requestBody);
JavaScript
Create engagementRoleMember
const options = {
	authProvider,
};

const client = Client.init(options);

const engagementRoleMember = {
  '[email protected]': 'https://graph.microsoft.com/v1.0/users(\'e8d9f6a2-1c34-4b7a-9f11-2a4d8b7c9e01\')'
};

await client.api('/employeeExperience/roles/a40473a5-0fb4-a250-e029-f6fe33d07733/members')
	.post(engagementRoleMember);
PowerShell
Connect-MgGraph -Scopes "EngagementRole.ReadWrite.All"
Invoke-MgGraphRequest -Method GET -Uri "https://graph.microsoft.com/v1.0/employeeExperience/roles"
Python
Create engagementRoleMember
# Code snippets are only available for the latest version. Current version is 1.x
from msgraph import GraphServiceClient
from msgraph.generated.models.engagement_role_member import EngagementRoleMember
# To initialize your graph_client, see https://learn.microsoft.com/en-us/graph/sdks/create-client?from=snippets&tabs=python
request_body = EngagementRoleMember(
	additional_data = {
			"user@odata_bind" : "https://graph.microsoft.com/v1.0/users('e8d9f6a2-1c34-4b7a-9f11-2a4d8b7c9e01')",
	}
)

result = await graph_client.employee_experience.roles.by_engagement_role_id('engagementRole-id').members.post(request_body)

App Registration

1

Navigate to Azure Portal

Go to App registrations in Microsoft Entra admin center

2

Add API Permission

Select your app → API permissions → Add a permission → Microsoft Graph

3

Select Permission Type

Choose Application permissions or delegated permissions and search for EngagementRole.ReadWrite.All

4

Grant Admin Consent

Application permissions always require admin consent.