Конвертировать DirectoryObject для пользователя - PullRequest
0 голосов
/ 08 января 2019

Учитывая запрос для членов определенной роли каталога, я хотел бы вернуть список соответствующих пользователей. Что у меня есть это:

IDirectoryObjectCollectionWithReferencesRequest request = graphServiceClient.directoryRoles(roleId).members().buildRequest();
IDirectoryObjectCollectionWithReferencesPage page = request.select(USER_FIELDS_TO_RETURN).get();
List<DirectoryObject> objects = page.getCurrentPage();
IDirectoryObjectCollectionWithReferencesRequestBuilder builder = page.getNextPage();
while (builder != null) {
    request = builder.buildRequest();
    page = request.select(USER_FIELDS_TO_RETURN).get();
    objects.addAll(page.getCurrentPage());
    builder = page.getNextPage();
}
return objects.stream().filter(o -> o.oDataType.equals("#microsoft.graph.user")).map(o -> new User()).collect(Collectors.toList());

Вопрос заключается в ответном заявлении. Фильтруйте только пользовательские объекты (не смог найти более элегантный способ сделать это, чем сравнение oDataType) и вернуть пользовательский объект с содержимым o:

objects.stream().filter(o -> o.oDataType.equals("#microsoft.graph.user")).map(o -> {
        // the only thing that I could think of is to do some weird
        // serialization/deserialization logic here which is a bad solution
        // for anything other than a small number of elements
}).collect(Collectors.toList());

как правильно конвертировать DirectoryObject в User

1 Ответ

0 голосов
/ 09 января 2019

Microsoft Graph в настоящее время не поддерживает это требование.

Если вы проверяете конкретную директивную роль, вы можете прийти к этому с другой стороны. Конечная точка / members поддерживает фильтрацию по идентификатору элемента:

v1.0/directoryRoles/{role-id}/members?$filter=id eq '{user-id}'

Пожалуйста, проверьте ответы и обходные пути, предоставленные в этой теме. Как получить роли администратора, членом которых я являюсь, из Microsoft Graph с помощью .Net Client SDK?

...