Мне нужно создать элемент с полем Person/People.
Я могу заполнить такие поля, как Title, DateTime, TextField, как показано ниже, но я вообще не могу заполнить поле Person.
Я попытался отправить отображаемое имя, идентификатор пользователя и имя участника-пользователя.
var fieldValueSet = new FieldValueSet();
fieldValueSet.AdditionalData = new Dictionary<string, object>();
fieldValueSet.AdditionalData.Add("[email protected]", "Edm.String");
fieldValueSet.AdditionalData.Add("Title", task.Title);
fieldValueSet.AdditionalData.Add("[email protected]", "Edm.String");
fieldValueSet.AdditionalData.Add("Plan", plan.Title);
fieldValueSet.AdditionalData.Add("[email protected]", "Edm.String");
fieldValueSet.AdditionalData.Add("Assigned", assignee.UserPrincipalName);
fieldValueSet.AdditionalData.Add("[email protected]", "Edm.String");
fieldValueSet.AdditionalData.Add("DueDate", task.DueDateTime);
var listItem = new ListItem
{
Fields = fieldValueSet
};
await graphServiceClient.Sites["SPURL:/sites/ITOddeleni:"].Lists["ListName"].Items
.Request()
.AddAsync(listItem)





Ваше основное имя пользователя похоже на адрес электронной почты? (например, [email protected]). Если это так, то вам, вероятно, следует попытаться преобразовать его в версию с претензией на точку доступа: i:0#.f|membership|[email protected].
Если в вашем приложении есть аутентифицированный ClientContext, вы можете разрешить имя пользователя, вызвав Утилита SharePoint:Utility.ResolvePrincipal(context, context.Web, userEmail, PrincipalType.User, PrincipalSource.All, null, true);
Если у вас нет контекста, вы можете попробовать объединить строки (не так надежно, но тоже должно работать).
Этот ответ предлагает вам попробовать установить значение LookupId для поля (примерно так же, как вы устанавливаете пользовательские значения с помощью REST API SharePoint):
var assigneeLookupId = // Get the assignee's user id on the site (wssid)
fieldValueSet.AdditionalData.Add("[email protected]", "Edm.Int32");
fieldValueSet.AdditionalData.Add("AssignedLookupId", assigneeLookupId);
Следующая схема позволит вам вставить несколько значений людей: РЕШЕНИЕ После помощи комментариев я получил этот ответ, который сработал
{
"[email protected]" : "Collection(Edm.Int32)"
"AssignedLookupId": [1,2,3]
}
Этот подход соответствует тому, как MS Graph возвращает значения для полей поиска.
Пытался отправить через строку [email protected], но это не сработало. ID попробую позже.
не смог заставить это работать, не принял бы i:0#.f|membership|[email protected] :-( есть другие предложения?
Попробуйте использовать поля LookupId.
Просто читая темы, связанные со ссылками, которые вы мне прислали, кажется, мне придется заполнить столбец одной строкой текста и попытаться создать поток...
Я не могу понять, где я могу получить assigneeLookupId
Мне удалось добавить человека в поле поиска, fieldValueSet.AdditionalData.Add("[email protected]e", "Edm.Int32"); fieldValueSet.AdditionalData.Add("AssignedLookupId", 14); Но я понятия не имею, как добавить несколько человек, поскольку он не принимает коллекцию и массив целых чисел, также я понятия не имею, как получить идентификатор человека SharePoint с помощью графика... но все еще делаю успехи: D
в вышеупомянутом ответе был этот фрагмент: { "[email protected]" : "Collection (Edm.Int32)" "MyListLookUpValueLookupId": [1,2,3]}
Да, я видел это, но я идиот... Я забыл включить множественный выбор для столбца на SP, большое спасибо за вашу помощь :-) теперь мне просто нужно как-то получить всех людей из коллекции сайтов: -)
Хорошо, часть всех пользователей - это просто список, из которого я извлек идентификаторы пользователей + имя, как из обычного списка, еще раз большое спасибо за вашу помощь :-)
Спасибо за ваш ответ, исправьте, что мой UPN выглядит как адрес электронной почты (классический UPN), я попробую в понедельник, сообщу вам о результате.