无法在线创建 Dynamics CRM 365 中的系统用户

Unable to Create a systemuser in Dynamics CRM 365 online

关于联系人记录的更新字段,我想在 dynamics crm 365 中创建一个系统用户(用户)online.but 我收到类似 "usersettings With Id = 5fe33120-607f-e811-a95c-000d3af29269 Does Not Exist"

的错误

这是我尝试创建用户的以下代码

Entity getEntity = (Entity)context.InputParameters["Target"];
                string str = getEntity.Attributes["new_isaeon"].ToString();

                if (str != null && str == "True")
                {
                    // http://localhost:51625/api/Users
                    Entity sysuser = new Entity("systemuser");
                    sysuser.Attributes["fullname"] = "hsk";
                    sysuser.Attributes["internalemailaddress"] = "projectservice_9@crmdemo.dynamics.com";
                    sysuser.Attributes["domainname"] = "projectservice_9@crmdemo.dynamics.com";
                    Guid getGuid = new Guid("700F2217-786A-E811-A95A-000D3AF2793E");
                    sysuser.Attributes["businessunitid"] = new EntityReference("businessunit", getGuid);
                    sysuser.FormattedValues["accessmode"] = "Read-Write";
                    Guid getuserid = service.Create(sysuser);

                }

谁能帮我解决这个问题谢谢。

更新:最近我们开始直接使用OOB CSV import 在线导入CRM中的用户(这对我来说也是新手),它会成功,稍后分配许可证时同一用户 - 这不会创建另一个用户记录,而是会根据 username/domain name/email 将 Azure 对象 GUID 映射到现有用户记录。这在快速创建没有许可证或角色的存根用户时更有用。


在 Dynamics 365 CRM online 中,系统用户记录 creation/enabling 流程发生在 O365 管理门户端。 Read more

步骤是这样的:

  1. 安全组必须在 Active Directory 中创建并映射到任何 CRM 组织的 O365 管理门户中
  2. 必须在该 AD 安全组中添加用户
  3. SG 中的所有用户将被复制为 CRM 实例中的系统用户
  4. 在 O365 管理门户中,在为用户分配 CRM 许可(Basic/Pro)时 - 系统用户记录将在 CRM 中启用
  5. 在 CRM 端,我们将分配安全角色以完成用户入职

由于上述在线CRM之外的手动步骤,我们无法直接使用SDK创建系统用户。可以使用 PowerShell 创建,例如 answered in community.

//使用下面的代码在D365中创建用户

using Newtonsoft.Json.Linq;
using System;
using System.Collections.Generic;
using System.Configuration;
using System.Linq;
using System.Net;
using System.Net.Http;
using System.Net.Http.Headers;
using System.Text;

namespace PowerApps.Samples
{
    public partial class SampleProgram
    {
        static void Main(string[] args)
        {
            JObject azureUser = new JObject();
            JObject retrievedResult;
            string queryOptions = string.Empty;
            string domainName = string.Empty;
            try
            {
                Console.WriteLine("Please enter domain name.");
                domainName = Console.ReadLine();

                string connectionString = ConfigurationManager.ConnectionStrings["Connect"].ConnectionString;

                using (HttpClient client = SampleHelpers.GetHttpClient(
                    connectionString,
                    SampleHelpers.clientId,
                    SampleHelpers.redirectUrl,
                    "v9.1"))
                {

                    queryOptions = "systemusers?$select=domainname&$filter=domainname eq '" + domainName + "'";

                    HttpResponseMessage retrieveResponse = client.GetAsync(client.BaseAddress.AbsoluteUri + queryOptions,
                        HttpCompletionOption.ResponseHeadersRead).Result;

                    if (retrieveResponse.IsSuccessStatusCode) //200
                    {
                        retrievedResult = JObject.Parse(retrieveResponse.Content.ReadAsStringAsync().Result);
                        string outputDomainname = (string)retrievedResult.SelectToken("value[0].domainname");
                        Console.WriteLine("Domain: " + outputDomainname);
                        if (outputDomainname == null)
                        {
                            Console.WriteLine("Adding user to Azure AD..");

                            HttpRequestMessage createrequest = new HttpRequestMessage(HttpMethod.Post,
                                client.BaseAddress + "systemusers");

                            Console.WriteLine("Enter first name");
                            azureUser.Add("firstname", Console.ReadLine());

                            Console.WriteLine("Enter last name");
                            azureUser.Add("lastname", Console.ReadLine());

                            Console.WriteLine("Enter internal email address");
                            azureUser.Add("internalemailaddress", Console.ReadLine());

                            azureUser.Add("isdisabled", false);
                  
                            azureUser.Add("caltype", 7);
                            azureUser.Add("businessunitid@odata.bind", "/businessunits(8c44c8ac-f6a3-ea11-a812-000d3a0a74cb)");

                            createrequest.Content = new StringContent(azureUser.ToString());
                            createrequest.Content.Headers.ContentType = MediaTypeHeaderValue.Parse("application/json");

                            HttpResponseMessage createResponse = client.SendAsync(createrequest, HttpCompletionOption.ResponseHeadersRead).Result;
                            if (createResponse.IsSuccessStatusCode)
                            {
                                Console.WriteLine("Account created");
                            }
                            else
                            {
                                throw new Exception(string.Format("Failed to Post Records", createResponse.ReasonPhrase));
                            }
                        }
                    }
                    else
                    {
                        Console.WriteLine("Failed to retrieve domain: {0}",
                            retrieveResponse.ReasonPhrase);
                        throw new Exception(string.Format("Failed to retrieve domain: {0}", retrieveResponse.Content));
                    }
                }
            }
            catch (Exception ex)
            {
                SampleHelpers.DisplayException(ex);
                throw ex;
            }
            finally
            {
                Console.WriteLine("Press <Enter> to exit the program.");

                Console.ReadLine();
            }
        }
    }
}