CRM 4 – Remover Compartilhamentos


Permitir que um determinado registro seja compartilhado com outro usuário/equipe/fila é um recurso bem interessante de ser utilizado, em determinadas circunstâncias torna-se necessário e é independente das configurações das Unidade de Negócio e Direitos de Acesso, ou seja, não importa se a conta A é proprietária de um usuário A e que o usuário B não está na mesma unidade de negócio e não possui direitos de acesso que permitem a visualização da conta. Se o usuário A possuir permissão de compartilhar um registro com o usuário B, logo este usuário poderá utilizar o registro que lhe foi concedido.

Deste modo, podemos imaginar vários cenários sendo atendidos com a funcionalidade de compartilhamento, certo? Isso mesmo, apenas existe um problema! O problema neste caso, seria quando necessitamos de remover o compartilhamento de “N” registros e de uma só vez… A IDE do CRM não permite remover compartilhamos de “N” registros de uma só vez, sendo assim eu criei um breve exemplo de como realizar a remoção programaticamente.

Criaremos um Custom Workflow Activity para solucionar o problema, ele poderá ser utilizado em qualquer entidade, da forma que eu fiz este exemplo o único parâmetro de entrada seria o “login” do usuário ao qual desejamos remover, mas podemo incrementar bem isso, criando uma entidade por exemplo, um arquivo de configuração ou ainda, permitir que sejam removidos os compartilhamentos de equipes também. Mas como eu disse é só um exemplo…

Vamos ao código:

using System;
using System.Collections;
using System.Workflow.ComponentModel.Compiler;
using System.Workflow.ComponentModel.Serialization;
using System.Workflow.ComponentModel;
using System.Workflow.ComponentModel.Design;
using System.Workflow.Runtime;
using System.Workflow.Activities;
using System.Workflow.Activities.Rules;
using System.Reflection;</code>

using Microsoft.Crm.Workflow;
using Microsoft.Crm.Sdk;
using Microsoft.Crm.SdkTypeProxy;
using Microsoft.Crm.Sdk.Query;

namespace NAMESPACE
{
[CrmWorkflowActivity("Remover Compartilhamento", "Utilities")]
public class RemoverCompartilhamento : Activity
{
//Define the dependency properties. CRM requires dependency properties used.
public static DependencyProperty LoginUsuarioProperty = DependencyProperty.Register("LoginUsuario", typeof(string), typeof(RemoverCompartilhamento));

[CrmInput("Login Usuário")] //Input Label
[ValidationOption(ValidationOption.Required)]
public string LoginUsuario
{
get
{
return (String)base.GetValue(LoginUsuarioProperty);
}
set
{
base.SetValue(LoginUsuarioProperty, value);
}
}

protected override ActivityExecutionStatus Execute(ActivityExecutionContext executionContext)
{
// Declara objetos
IContextService contextService;
IWorkflowContext context;
ICrmService crmService;
SecurityPrincipal principal;
TargetOwnedAccount target;
RevokeAccessRequest revoke;
systemuser usuario;
Guid entidadeId = Guid.Empty;

try
{
// Obtém contexto e CrmService
contextService = (IContextService)executionContext.GetService(typeof(IContextService));
context = contextService.Context;
crmService = context.CreateCrmService();

// Cria objetos
principal = new SecurityPrincipal();
target = new TargetOwnedAccount();
revoke = new RevokeAccessRequest();

// Método para busca o ID de um usuário, passando o Login como parâmetro
usuario = this.PesquisaIDUsuario(crmService, this.LoginUsuario);

// Verifica se obteve ID da entidade
if (context.InputParameters.Properties.Contains("EntityId"))
entidadeId = new Guid(context.InputParameters.Properties["EntityId"].ToString().Replace("{","").Replace("}",""));

// Verifica se encontrou o Id da entidade e o usuário
if (entidadeId != Guid.Empty &amp;&amp; usuario != null)
{
// Create the SecurityPrincipal.
principal.Type = SecurityPrincipalType.User;

// PrincipalId is the GUID of the user whose access is being revoked.
principal.PrincipalId = usuario.systemuserid.Value;

// EntityId is the GUID of the account to which access is being revoked.
target.EntityId = entidadeId;

// Set the properties of the request object.
revoke.Revokee = principal;
revoke.Target = target;

// Execute the request.
crmService.Execute(revoke);

// Executa o Workflow
return base.Execute(executionContext);
}
else
return ActivityExecutionStatus.Canceling;
}
catch (Exception ex)
{
throw new InvalidPluginExecutionException("Erro: " + ex.StackTrace);
}
}
}
}

Depois de criar esta classe compilar, basta registrar no Plugin Registration Tool, como já é o procedimento comum adotado para plugins e workflows customizados. Caso tenha dúvida acesse o link:

http://archive.msdn.microsoft.com/crmplugin

Por fim, crie um workflow e referencie o workflow customizado, conforme figura à baixo:

Insira o parâmetro LoginUsuario e publique, pronto é só utilizar!

Att,

Deixe um comentário

Preencha os seus dados abaixo ou clique em um ícone para log in:

Logo do WordPress.com

Você está comentando utilizando sua conta WordPress.com. Sair /  Alterar )

Foto do Facebook

Você está comentando utilizando sua conta Facebook. Sair /  Alterar )

Conectando a %s

Este site utiliza o Akismet para reduzir spam. Saiba como seus dados em comentários são processados.