ho creato il seguente attributo:personalizzato CodeAccessSecurityAttribute
[Serializable]
[AttributeUsage(AttributeTargets.Class | AttributeTargets.Method, AllowMultiple = true, Inherited = true)]
public class OperationPermissionAttribute : CodeAccessSecurityAttribute
{
private static PrincipalPermission _revoke = new PrincipalPermission(PermissionState.None);
private static PrincipalPermission _allow = new PrincipalPermission(PermissionState.Unrestricted);
private string _role;
private string _task;
private string _operation;
public OperationPermissionAttribute(SecurityAction action, string role, string task, string operation) : base(action)
{
_role = role;
_task = task;
_operation = operation;
}
public OperationPermissionAttribute(string role, string task, string operation)
: base(SecurityAction.Demand)
{
_role = role;
_task = task;
_operation = operation;
}
public override System.Security.IPermission CreatePermission()
{
var principal = System.Threading.Thread.CurrentPrincipal as AzManPrincipal;
if (principal == null)
return _revoke;
bool result = principal.IsOperationAllowed(_role, _task, _operation);
return result ? _allow : _revoke;
}
}
che uso in questo modo:
[OperationPermission(SecurityAction.Demand, Roles.Administrator, "UserService", "Remove")]
public void Add(User user)
{
user.ValidateOrThrow();
_repository.Add(user);
}
L'esecuzione del codice mi dà il seguente errore:
Manca una richiesta costruttore. (Eccezione da HRESULT: 0x8013143B), è una COMException.
perché diavolo ho capito e cosa significa veramente?
Non riconosco "Roles.Administrator". Stai cercando di eseguire questo in .NET 4.0? CAS è deprecato. –
È una classe statica con i nostri ruoli. – jgauffin
Cosa dovrei usare al posto di CAS? – jgauffin