IRolePermissionStore.cs 2.1 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556
  1. using System.Collections.Generic;
  2. using System.Threading.Tasks;
  3. using IwbZero.Authorization.Base.Permissions;
  4. namespace IwbZero.Authorization.Base.Roles
  5. {
  6. /// <summary>
  7. /// Used to perform permission database operations for a role.
  8. /// </summary>
  9. public interface IRolePermissionStore<in TRole>
  10. where TRole : RoleBase
  11. {
  12. /// <summary>
  13. /// Adds a permission grant setting to a role.
  14. /// </summary>
  15. /// <param name="role">Role</param>
  16. /// <param name="permissionGrant">Permission grant setting info</param>
  17. Task AddPermissionAsync(TRole role, PermissionGrantInfo permissionGrant);
  18. /// <summary>
  19. /// Removes a permission grant setting from a role.
  20. /// </summary>
  21. /// <param name="role">Role</param>
  22. /// <param name="permissionGrant">Permission grant setting info</param>
  23. Task RemovePermissionAsync(TRole role, PermissionGrantInfo permissionGrant);
  24. /// <summary>
  25. /// Gets permission grant setting informations for a role.
  26. /// </summary>
  27. /// <param name="role">Role</param>
  28. /// <returns>List of permission setting informations</returns>
  29. Task<IList<PermissionGrantInfo>> GetPermissionsAsync(TRole role);
  30. /// <summary>
  31. /// Gets permission grant setting informations for a role.
  32. /// </summary>
  33. /// <param name="roleId">Role id</param>
  34. /// <returns>List of permission setting informations</returns>
  35. Task<IList<PermissionGrantInfo>> GetPermissionsAsync(int roleId);
  36. /// <summary>
  37. /// Checks whether a role has a permission grant setting info.
  38. /// </summary>
  39. /// <param name="roleId">Role id</param>
  40. /// <param name="permissionGrant">Permission grant setting info</param>
  41. /// <returns></returns>
  42. Task<bool> HasPermissionAsync(int roleId, PermissionGrantInfo permissionGrant);
  43. /// <summary>
  44. /// Deleted all permission settings for a role.
  45. /// </summary>
  46. /// <param name="role">Role</param>
  47. Task RemoveAllPermissionSettingsAsync(TRole role);
  48. }
  49. }