如何在CRM 365中共享记录

时间:2018-08-15 08:58:19

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

我想在满足多个条件时共享记录,我可以使用插件吗?我有要共享的请求转移记录,因此,在提交请求转移状态时,我将在请求转移字段中将从仓库获得的记录共享给用户。我可以使用插件吗?

if (context.InputParameters.Contains("Target") && context.InputParameters["Target"] is Entity)
{
  if(context.MessageName.ToUpper() == "UPDATE")
  {
    int requestStatus = transferImage.GetAttributeValue<OptionSetValue>("mjt_request_status").Value;
    if(requestStatus == 2)
    {
      EntityReference warehouse = transferImage.GetAttributeValue<EntityReference>("mjt_request_to ");

      ColumnSet columnSet = new ColumnSet(true);
      var warehouses = service.Retrieve("msdyn_warehouse ", warehouse.Id, columnSet);

      if (warehouses.Attributes.ContainsKey("mjt_administrator"))
      {
        adminstrator = warehouses.GetAttributeValue<EntityReference>("mjt_administrator");
      }

      if(adminstrator != null)
      {
      }

    }
  }
}

我的代码刚刚结束,我从传输请求中获得了管理员,然后我不知道如何将请求共享给我的用户。

1 个答案:

答案 0 :(得分:2)

您必须使用GrantAccessRequest来完成此操作。

// Grant the user read access to the record.
var grantAccessRequest1 = new GrantAccessRequest
{
    PrincipalAccess = new PrincipalAccess
    {
        AccessMask = AccessRights.ReadAccess,
        Principal = adminstrator
    },
    Target = transferReference
};

serviceProxy.Execute(grantAccessRequest1);

Read more