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

时间:2018-07-04 11:24:47

标签: c# dynamics-crm microsoft-dynamics dynamics-crm-online dynamics-365

在联系记录的更新字段上,我想在动态crm 365中创建一个systemuser(user)。但是我遇到类似“ usersettings with ID = 5fe33120-607f-e811-a95c-000d3af29269不存在”的错误/ p>

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

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);

                }

有人可以帮助我吗?

2 个答案:

答案 0 :(得分:3)

在Dynamics 365 CRM在线中,系统用户记录创建/启用流程是从O365管理员门户端开始的。 Read more

步骤如下:
1.必须在Active Directory中创建安全组,并在O365管理门户中将其映射为任何CRM Org
2.用户必须添加到该AD安全组中
3. SG中的所有用户都将被复制为CRM实例中的系统用户
4.在O365管理门户中,为用户分配CRM许可证(基本/专业版)后,系统用户记录将在CRM中启用
5.在CRM方面,我们将分配安全角色以完成用户的入职

由于上述CRM Online外部的手动步骤,我们无法直接使用SDK创建系统用户。可以使用answered in community之类的PowerShell来创建。

答案 1 :(得分:2)

//使用下面的代码在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();
            }
        }
    }
}