Skip to main content
.NET Framework 4.5.2+

IsGrantedExtensions.CanDeleteByRole(SecurityStrategy, IPermissionPolicyRole, Type, IObjectSpace, Object) Method

Checks whether the specified role allows deleting an object with the specified key.

Namespace: DevExpress.ExpressApp.Security

Assembly: DevExpress.ExpressApp.Security.v24.1.dll

Declaration

public static bool CanDeleteByRole(
    this SecurityStrategy security,
    IPermissionPolicyRole targetRole,
    Type type,
    IObjectSpace objectSpace,
    object targetObjectKey
)

Parameters

Name Type Description
security SecurityStrategy

A SecurityStrategy object that specifies an application’s Security Strategy.

targetRole IPermissionPolicyRole

An IPermissionPolicyRole object that is a role this method checks.

type Type

A Type of an object this method checks.

objectSpace IObjectSpace

An Object Space this method uses to get an object to check.

targetObjectKey Object

An Object that is a key of an object this method checks.

Returns

Type Description
Boolean

true, if the specified role allows deleting an object with the specified key; otherwise, false.

Remarks

The following example shows how to use this method.

using DevExpress.ExpressApp;
using DevExpress.ExpressApp.Security;
using DevExpress.Persistent.Base;
using DevExpress.Persistent.BaseImpl.PermissionPolicy;
using System;
// ...
public class CheckDeletePermissionController : ObjectViewController<ListView, Contact> {
    SecurityStrategy securityStrategy;
    protected override void OnActivated() {
        base.OnActivated();
        securityStrategy = Application.GetSecurityStrategy();
        View.CurrentObjectChanged += View_CurrentObjectChanged;
    }
    private void View_CurrentObjectChanged(object sender, EventArgs e) {
        Department department = ViewCurrentObject.Department;
        if (department != null) {
            object key = ObjectSpace.GetKeyValue(department);
            foreach (IPermissionPolicyRole role in ObjectSpace.GetObjects<PermissionPolicyRole>()) {
                if (!securityStrategy.CanDeleteByRole(role, typeof(Department), ObjectSpace, key)) {
                    // ...
                }
            }
        }
    }
}
See Also