Namespace: microsoft.graph
Erteilen Sie einem AgentUser eine App-Rollenzuweisung.
Diese API ist in den folgenden nationalen Cloudbereitstellungen verfügbar.
| Weltweiter Service |
US Government L4 |
US Government L5 (DOD) |
China, betrieben von 21Vianet |
| ✅ |
✅ |
✅ |
✅ |
Berechtigungen
Wählen Sie die Berechtigungen aus, die für diese API als am wenigsten privilegiert markiert sind. Verwenden Sie eine höhere Berechtigung oder Berechtigungen nur, wenn Ihre App dies erfordert. Ausführliche Informationen zu delegierten Berechtigungen und Anwendungsberechtigungen finden Sie unter Berechtigungstypen. Weitere Informationen zu diesen Berechtigungen finden Sie in der Berechtigungsreferenz.
| Berechtigungstyp |
Berechtigungen mit den geringsten Berechtigungen |
Berechtigungen mit höheren Berechtigungen |
| Delegiert (Geschäfts-, Schul- oder Unikonto) |
AppRoleAssignment.ReadWrite.All |
Nicht verfügbar. |
| Delegiert (persönliches Microsoft-Konto) |
Nicht unterstützt |
Nicht unterstützt |
| Anwendung |
AppRoleAssignment.ReadWrite.All |
Nicht verfügbar. |
Wichtig
Für den delegierten Zugriff mithilfe von Geschäfts-, Schul- oder Unikonten muss dem angemeldeten Benutzer eine unterstützte Microsoft Entra Rolle oder eine benutzerdefinierte Rolle zugewiesen werden, die die für diesen Vorgang erforderlichen Berechtigungen gewährt. Dieser Vorgang unterstützt die folgenden integrierten Rollen, die nur die geringsten Berechtigungen bereitstellen:
- Verzeichnissynchronisierungskonten für Microsoft Entra Connect und Microsoft Entra Cloud Sync-Dienste
- Verzeichnisschreibberechtigter
- Hybrididentitätsadministrator
- Identity Governance-Administrator
- Administrator für privilegierte Rollen: Die Rolle mit den geringsten Berechtigungen, die für Microsoft Graph- und Azure AD Graph-App-Rollen unterstützt wird
- Benutzeradministrator
- Anwendungsadministrator
- Cloudanwendungsadministrator
- Agent-ID-Administrator – nur für Agent-Benutzer
HTTP-Anforderung
POST /users/{usersId}/appRoleAssignments
Anforderungstext
Geben Sie im Anforderungstext eine JSON-Darstellung eines appRoleAssignment-Objekts an.
Antwort
Bei erfolgreicher Ausführung gibt die Methode den Antwortcode 201 Created und ein Objekt des Typs appRoleAssignment im Antworttext zurück.
Beispiele
Anforderung
Das folgende Beispiel zeigt eine Anfrage.
POST https://graph.microsoft.com/v1.0/users/{usersId}/appRoleAssignments
Content-Type: application/json
{
"@odata.type": "#microsoft.graph.appRoleAssignment",
"deletedDateTime": "String (timestamp)",
"appRoleId": "Guid",
"creationTimestamp": "String (timestamp)",
"principalDisplayName": "String",
"principalId": "Guid",
"principalType": "String",
"resourceDisplayName": "String",
"resourceId": "Guid"
}
// Code snippets are only available for the latest version. Current version is 5.x
// Dependencies
using Microsoft.Graph.Models;
var requestBody = new AppRoleAssignment
{
OdataType = "#microsoft.graph.appRoleAssignment",
DeletedDateTime = DateTimeOffset.Parse("String (timestamp)"),
AppRoleId = Guid.Parse("Guid"),
PrincipalDisplayName = "String",
PrincipalId = Guid.Parse("Guid"),
PrincipalType = "String",
ResourceDisplayName = "String",
ResourceId = Guid.Parse("Guid"),
AdditionalData = new Dictionary<string, object>
{
{
"creationTimestamp" , "String (timestamp)"
},
},
};
// To initialize your graphClient, see https://learn.microsoft.com/en-us/graph/sdks/create-client?from=snippets&tabs=csharp
var result = await graphClient.Users["{user-id}"].AppRoleAssignments.PostAsync(requestBody);
Einzelheiten darüber, wie Sie das SDK zu Ihrem Projekt hinzufügen und eine authProvider-Instanz erstellen, finden Sie in der SDK-Dokumentation.
// Code snippets are only available for the latest major version. Current major version is $v1.*
// Dependencies
import (
"context"
"time"
"github.com/google/uuid"
msgraphsdk "github.com/microsoftgraph/msgraph-sdk-go"
graphmodels "github.com/microsoftgraph/msgraph-sdk-go/models"
//other-imports
)
requestBody := graphmodels.NewAppRoleAssignment()
deletedDateTime , err := time.Parse(time.RFC3339, "String (timestamp)")
requestBody.SetDeletedDateTime(&deletedDateTime)
appRoleId := uuid.MustParse("Guid")
requestBody.SetAppRoleId(&appRoleId)
principalDisplayName := "String"
requestBody.SetPrincipalDisplayName(&principalDisplayName)
principalId := uuid.MustParse("Guid")
requestBody.SetPrincipalId(&principalId)
principalType := "String"
requestBody.SetPrincipalType(&principalType)
resourceDisplayName := "String"
requestBody.SetResourceDisplayName(&resourceDisplayName)
resourceId := uuid.MustParse("Guid")
requestBody.SetResourceId(&resourceId)
additionalData := map[string]interface{}{
"creationTimestamp" : "String (timestamp)",
}
requestBody.SetAdditionalData(additionalData)
// To initialize your graphClient, see https://learn.microsoft.com/en-us/graph/sdks/create-client?from=snippets&tabs=go
appRoleAssignments, err := graphClient.Users().ByUserId("user-id").AppRoleAssignments().Post(context.Background(), requestBody, nil)
Einzelheiten darüber, wie Sie das SDK zu Ihrem Projekt hinzufügen und eine authProvider-Instanz erstellen, finden Sie in der SDK-Dokumentation.
// Code snippets are only available for the latest version. Current version is 6.x
GraphServiceClient graphClient = new GraphServiceClient(requestAdapter);
AppRoleAssignment appRoleAssignment = new AppRoleAssignment();
appRoleAssignment.setOdataType("#microsoft.graph.appRoleAssignment");
OffsetDateTime deletedDateTime = OffsetDateTime.parse("String (timestamp)");
appRoleAssignment.setDeletedDateTime(deletedDateTime);
appRoleAssignment.setAppRoleId(UUID.fromString("Guid"));
appRoleAssignment.setPrincipalDisplayName("String");
appRoleAssignment.setPrincipalId(UUID.fromString("Guid"));
appRoleAssignment.setPrincipalType("String");
appRoleAssignment.setResourceDisplayName("String");
appRoleAssignment.setResourceId(UUID.fromString("Guid"));
HashMap<String, Object> additionalData = new HashMap<String, Object>();
additionalData.put("creationTimestamp", "String (timestamp)");
appRoleAssignment.setAdditionalData(additionalData);
AppRoleAssignment result = graphClient.users().byUserId("{user-id}").appRoleAssignments().post(appRoleAssignment);
Einzelheiten darüber, wie Sie das SDK zu Ihrem Projekt hinzufügen und eine authProvider-Instanz erstellen, finden Sie in der SDK-Dokumentation.
const options = {
authProvider,
};
const client = Client.init(options);
const appRoleAssignment = {
'@odata.type': '#microsoft.graph.appRoleAssignment',
deletedDateTime: 'String (timestamp)',
appRoleId: 'Guid',
creationTimestamp: 'String (timestamp)',
principalDisplayName: 'String',
principalId: 'Guid',
principalType: 'String',
resourceDisplayName: 'String',
resourceId: 'Guid'
};
await client.api('/users/{usersId}/appRoleAssignments')
.post(appRoleAssignment);
Einzelheiten darüber, wie Sie das SDK zu Ihrem Projekt hinzufügen und eine authProvider-Instanz erstellen, finden Sie in der SDK-Dokumentation.
<?php
use Microsoft\Graph\GraphServiceClient;
use Microsoft\Graph\Generated\Models\AppRoleAssignment;
$graphServiceClient = new GraphServiceClient($tokenRequestContext, $scopes);
$requestBody = new AppRoleAssignment();
$requestBody->setOdataType('#microsoft.graph.appRoleAssignment');
$requestBody->setDeletedDateTime(new \DateTime('String (timestamp)'));
$requestBody->setAppRoleId('Guid');
$requestBody->setPrincipalDisplayName('String');
$requestBody->setPrincipalId('Guid');
$requestBody->setPrincipalType('String');
$requestBody->setResourceDisplayName('String');
$requestBody->setResourceId('Guid');
$additionalData = [
'creationTimestamp' => 'String (timestamp)',
];
$requestBody->setAdditionalData($additionalData);
$result = $graphServiceClient->users()->byUserId('user-id')->appRoleAssignments()->post($requestBody)->wait();
Einzelheiten darüber, wie Sie das SDK zu Ihrem Projekt hinzufügen und eine authProvider-Instanz erstellen, finden Sie in der SDK-Dokumentation.
Import-Module Microsoft.Graph.Applications
$params = @{
"@odata.type" = "#microsoft.graph.appRoleAssignment"
deletedDateTime = [System.DateTime]::Parse("String (timestamp)")
appRoleId = "Guid"
creationTimestamp = "String (timestamp)"
principalDisplayName = "String"
principalId = "Guid"
principalType = "String"
resourceDisplayName = "String"
resourceId = "Guid"
}
New-MgUserAppRoleAssignment -UserId $userId -BodyParameter $params
Einzelheiten darüber, wie Sie das SDK zu Ihrem Projekt hinzufügen und eine authProvider-Instanz erstellen, finden Sie in der SDK-Dokumentation.
# Code snippets are only available for the latest version. Current version is 1.x
from msgraph import GraphServiceClient
from msgraph.generated.models.app_role_assignment import AppRoleAssignment
# To initialize your graph_client, see https://learn.microsoft.com/en-us/graph/sdks/create-client?from=snippets&tabs=python
request_body = AppRoleAssignment(
odata_type = "#microsoft.graph.appRoleAssignment",
deleted_date_time = "String (timestamp)",
app_role_id = UUID("Guid"),
principal_display_name = "String",
principal_id = UUID("Guid"),
principal_type = "String",
resource_display_name = "String",
resource_id = UUID("Guid"),
additional_data = {
"creation_timestamp" : "String (timestamp)",
}
)
result = await graph_client.users.by_user_id('user-id').app_role_assignments.post(request_body)
Einzelheiten darüber, wie Sie das SDK zu Ihrem Projekt hinzufügen und eine authProvider-Instanz erstellen, finden Sie in der SDK-Dokumentation.
Antwort
Das folgende Beispiel zeigt die Antwort.
Hinweis: Das hier gezeigte Antwortobjekt kann zur besseren Lesbarkeit gekürzt werden.
HTTP/1.1 201 Created
Content-Type: application/json
{
"@odata.type": "#microsoft.graph.appRoleAssignment",
"id": "ff9f3843-845a-c408-508a-687bf19a481f",
"deletedDateTime": "String (timestamp)",
"appRoleId": "Guid",
"creationTimestamp": "String (timestamp)",
"principalDisplayName": "String",
"principalId": "Guid",
"principalType": "String",
"resourceDisplayName": "String",
"resourceId": "Guid"
}