我正在尝试在 sitefinity 中实现自定义角色提供程序。我找到了一些例子,但我找不到任何记录得很好的东西。我想进一步了解的一件事是 Provider Abilities 数组中有哪些可用选项。
我从 git hub 看到了一个示例,其中列出了其中一些,但是还有什么可以放在那里的?我正在创建的提供者将是一个只读提供者,所以我想知道我还可以在其中放入什么并将其标记为不支持或不允许。
还有哪些其他选择?
我正在尝试在 sitefinity 中实现自定义角色提供程序。我找到了一些例子,但我找不到任何记录得很好的东西。我想进一步了解的一件事是 Provider Abilities 数组中有哪些可用选项。
我从 git hub 看到了一个示例,其中列出了其中一些,但是还有什么可以放在那里的?我正在创建的提供者将是一个只读提供者,所以我想知道我还可以在其中放入什么并将其标记为不支持或不允许。
还有哪些其他选择?
您使用它基本上说明您的提供者支持哪些操作。
内置的 OpenAccessRoleProvider 提供程序(使用数据库存储角色的提供程序)支持您附加的所有操作(添加/删除/获取角色、分配/取消分配用户到角色),但例如 LdapRoleProvider 不支持DeleteRole 能力(注意它的第二个和第三个参数是假的):
LdapRoleProvider:
public override ProviderAbilities Abilities
{
get
{
ProviderAbilities providerAbility = new ProviderAbilities()
{
ProviderName = this.Name,
ProviderType = base.GetType().FullName
};
providerAbility.AddAbility("GetRole", true, true);
providerAbility.AddAbility("AddRole", false, false);
providerAbility.AddAbility("AssingUserToRole", false, false);
providerAbility.AddAbility("UnAssingUserFromRole", false, false);
providerAbility.AddAbility("DeleteRole", false, false);
return providerAbility;
}
}
public void AddAbility(string operationName, bool supported, bool allowed) {...}
这很正常 - 例如,您无法从 Sitefinity 删除 Active Directory 中的角色。