SharePoint 2013 - добавление пользователя в список UserInformationList

У меня сейчас небольшая проблема, и я не совсем уверен, как ее решить. Ситуация такая. В SharePoint 2013 я использую REST-API для обновления и создания элементов списка.

Если есть ppl-Picker, значения - это идентификаторы пользователей в UserInformationList. Все идет нормально. Но теперь вот мой вопрос.

Это не работает с пользователями, которых еще нет в UserInformationList. Кажется, что SharePoint в nativc выполняет POST-запросы, когда я ищу пользователя, которого еще нет. Первый, кажется, извлекает пользователей из другого списка, учитывая строку, введенную до сих пор в сборщике ppl. Это тело выглядит так

   <?xml version="1.0" encoding="UTF-8"?>
<Request xmlns="http://schemas.microsoft.com/sharepoint/clientquery/2009" SchemaVersion="15.0.0.0" LibraryVersion="15.0.0.0" ApplicationName="Javascript Library">
   <Actions>
      <StaticMethod TypeId="{xxxxxxxxxxxxx}" Name="ClientPeoplePickerSearchUser" Id="5">
         <Parameters>
            <Parameter TypeId="{xxxxxxxxxxxxx}">
               <Property Name="AllowEmailAddresses" Type="Boolean">false</Property>
               <Property Name="AllowMultipleEntities" Type="Boolean">true</Property>
               <Property Name="AllUrlZones" Type="Boolean">false</Property>
               <Property Name="EnabledClaimProviders" Type="String" />
               <Property Name="ForceClaims" Type="Boolean">false</Property>
               <Property Name="MaximumEntitySuggestions" Type="Number">30</Property>
               <Property Name="PrincipalSource" Type="Number">15</Property>
               <Property Name="PrincipalType" Type="Number">1</Property>
               <Property Name="QueryString" Type="String">jack</Property>
               <Property Name="Required" Type="Boolean">false</Property>
               <Property Name="SharePointGroupID" Type="Number">0</Property>
               <Property Name="UrlZone" Type="Number">0</Property>
               <Property Name="UrlZoneSpecified" Type="Boolean">false</Property>
               <Property Name="Web" Type="Null" />
               <Property Name="WebApplicationID" Type="String">{00000000-0000-0000-0000-000000000000}</Property>
            </Parameter>
         </Parameters>
      </StaticMethod>
   </Actions>
   <ObjectPaths />
</Request>

Затем он возвращает JSON с пользовательской информацией. Когда я сейчас отправляю форму, выполняется второй POST-запрос, в основном содержащий все данные формы, выглядящие примерно так

<?xml version="1.0" encoding="UTF-8"?>
<Request xmlns="http://schemas.microsoft.com/sharepoint/clientquery/2009" SchemaVersion="15.0.0.0" LibraryVersion="15.0.0.0" ApplicationName="Javascript Library">
   <Actions>
      <ObjectPath Id="3" ObjectPathId="2" />
      <ObjectPath Id="5" ObjectPathId="4" />
      <ObjectPath Id="7" ObjectPathId="6" />
      <ObjectPath Id="9" ObjectPathId="8" />
      <ObjectPath Id="11" ObjectPathId="10" />
      <ExceptionHandlingScopeSimple Id="12">
         <Method Name="ValidateUpdateListItem" Id="14" ObjectPathId="10">
            <Parameters>
               <Parameter Type="Array">
                  <Object TypeId="{xxxxxxxxxxx}">
                     <Property Name="ErrorMessage" Type="Null" />
                     <Property Name="FieldName" Type="String">Title</Property>
                     <Property Name="FieldValue" Type="String">___test</Property>
                     <Property Name="HasException" Type="Boolean">false</Property>
                  </Object>
                  <Object TypeId="{xxxxxxxxxxx}">
                     <Property Name="ErrorMessage" Type="Null" />
                     <Property Name="FieldName" Type="String">Someone</Property>
                     <Property Name="FieldValue" Type="String" />
                     <Property Name="HasException" Type="Boolean">false</Property>
                  </Object>
                  <Object TypeId="{xxxxxxxxxxx}">
                     <Property Name="ErrorMessage" Type="Null" />
                     <Property Name="FieldName" Type="String">LookupField</Property>
                     <Property Name="FieldValue" Type="String" />
                     <Property Name="HasException" Type="Boolean">false</Property>
                  </Object>
                  <Object TypeId="{xxxxxxxxxxx}">
                     <Property Name="ErrorMessage" Type="Null" />
                     <Property Name="FieldName" Type="String">SomeTextField</Property>
                     <Property Name="FieldValue" Type="String" />
                     <Property Name="HasException" Type="Boolean">false</Property>
                  </Object>
                  <Object TypeId="{xxxxxxxxxxx}">
                     <Property Name="ErrorMessage" Type="Null" />
                     <Property Name="FieldName" Type="String">APerson</Property>
                     <Property Name="FieldValue" Type="String">[{"Key":"i:0#.w|dom\\xxxxxx","Description":"DOM\\xxxxx","DisplayText":"Some, Name","EntityType":"User","ProviderDisplayName":"Active Directory","ProviderName":"AD","IsResolved":true,"EntityData":{"Title":"","MobilePhone":"","SIPAddress":"some.person@mail.com","Department":"XX-XX","Email":"some.person@mail.com"},"MultipleMatches":[],"AutoFillKey":"i:0#.w|dom\\xxxxxxx","AutoFillDisplayText":"Person, Some","AutoFillSubDisplayText":"","AutoFillTitleText":"SomeString","DomainText":"some.domain.net","Resolved":true,"LocalSearchTerm":"some"}]</Property>
                     <Property Name="HasException" Type="Boolean">false</Property>
                  </Object>
                  <Object TypeId="{xxxxxxxxxxx}">
                     <Property Name="ErrorMessage" Type="Null" />
                     <Property Name="FieldName" Type="String">ContentType</Property>
                     <Property Name="FieldValue" Type="String">Element</Property>
                     <Property Name="HasException" Type="Boolean">false</Property>
                  </Object>
                  <Object TypeId="{xxxxxxxxxxx}">
                     <Property Name="ErrorMessage" Type="Null" />
                     <Property Name="FieldName" Type="String">ContentTypeId</Property>
                     <Property Name="FieldValue" Type="String">0x010020785F18D738D74797A0C6B07438E69E</Property>
                     <Property Name="HasException" Type="Boolean">false</Property>
                  </Object>
               </Parameter>
               <Parameter Type="Boolean">false</Parameter>
               <Parameter Type="Null" />
            </Parameters>
         </Method>
      </ExceptionHandlingScopeSimple>
   </Actions>
   <ObjectPaths>
      <StaticProperty Id="2" TypeId="{xxxxxxxxxxx}" Name="Current" />
      <Property Id="4" ParentId="2" Name="Web" />
      <Property Id="6" ParentId="4" Name="Lists" />
      <Method Id="8" ParentId="6" Name="GetById">
         <Parameters>
            <Parameter Type="String">xxxxxxxxxxx</Parameter>
         </Parameters>
      </Method>
      <Method Id="10" ParentId="8" Name="AddItem">
         <Parameters>
            <Parameter TypeId="{xxxxxxxxxxx}">
               <Property Name="FolderUrl" Type="String">/sites/site/lists/theList</Property>
               <Property Name="LeafName" Type="Null" />
               <Property Name="UnderlyingObjectType" Type="Number">0</Property>
            </Parameter>
         </Parameters>
      </Method>
   </ObjectPaths>
</Request>

Этот второй пост также каким-то образом создает пользователя в UserInformationList. Итак, мой вопрос.

Есть ли способ создать пользователей, которых еще нет в UserInformationList, и получить их идентификаторы после их создания?

Поскольку я только разрабатывал SharePoint на внешнем интерфейсе, я не слишком знаком с его архитектурой. Было бы здорово, если бы кто-то из вас, ребята, мог бы помочь мне здесь

1 ответ

Решение

Вы можете вызвать метод EnsureUser в Интернете, который создаст пользователя, если он не существует, и вернет его идентификатор.

Другие вопросы по тегам