Permission.cs 3.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Collections.Immutable;
  4. using Abp.Application.Features;
  5. using Abp.Localization;
  6. using Abp.MultiTenancy;
  7. namespace Abp.Authorization
  8. {
  9. /// <summary>
  10. /// Represents a permission.
  11. /// A permission is used to restrict functionalities of the application from unauthorized users.
  12. /// </summary>
  13. public class Permission
  14. {
  15. /// <summary>
  16. /// Parent of this permission if one exists.
  17. /// If set, this permission can be granted only if parent is granted.
  18. /// </summary>
  19. public Permission Parent { get; private set; }
  20. /// <summary>
  21. /// Unique name of the permission.
  22. /// This is the key name to grant permissions.
  23. /// </summary>
  24. public string Name { get; }
  25. /// <summary>
  26. /// Display name of the permission.
  27. /// This can be used to show permission to the user.
  28. /// </summary>
  29. public ILocalizableString DisplayName { get; set; }
  30. /// <summary>
  31. /// A brief description for this permission.
  32. /// </summary>
  33. public ILocalizableString Description { get; set; }
  34. /// <summary>
  35. /// Which side can use this permission.
  36. /// </summary>
  37. public MultiTenancySides MultiTenancySides { get; set; }
  38. /// <summary>
  39. /// Depended feature(s) of this permission.
  40. /// </summary>
  41. public IFeatureDependency FeatureDependency { get; set; }
  42. /// <summary>
  43. /// List of child permissions. A child permission can be granted only if parent is granted.
  44. /// </summary>
  45. public IReadOnlyList<Permission> Children => _children.ToImmutableList();
  46. private readonly List<Permission> _children;
  47. /// <summary>
  48. /// Creates a new Permission.
  49. /// </summary>
  50. /// <param name="name">Unique name of the permission</param>
  51. /// <param name="displayName">Display name of the permission</param>
  52. /// <param name="description">A brief description for this permission</param>
  53. /// <param name="multiTenancySides">Which side can use this permission</param>
  54. /// <param name="featureDependency">Depended feature(s) of this permission</param>
  55. public Permission(
  56. string name,
  57. ILocalizableString displayName = null,
  58. ILocalizableString description = null,
  59. MultiTenancySides multiTenancySides = MultiTenancySides.Host | MultiTenancySides.Tenant,
  60. IFeatureDependency featureDependency = null)
  61. {
  62. if (name == null)
  63. {
  64. throw new ArgumentNullException("name");
  65. }
  66. Name = name;
  67. DisplayName = displayName;
  68. Description = description;
  69. MultiTenancySides = multiTenancySides;
  70. FeatureDependency = featureDependency;
  71. _children = new List<Permission>();
  72. }
  73. /// <summary>
  74. /// Adds a child permission.
  75. /// A child permission can be granted only if parent is granted.
  76. /// </summary>
  77. /// <returns>Returns newly created child permission</returns>
  78. public Permission CreateChildPermission(
  79. string name,
  80. ILocalizableString displayName = null,
  81. ILocalizableString description = null,
  82. MultiTenancySides multiTenancySides = MultiTenancySides.Host | MultiTenancySides.Tenant,
  83. IFeatureDependency featureDependency = null)
  84. {
  85. var permission = new Permission(name, displayName, description, multiTenancySides, featureDependency) { Parent = this };
  86. _children.Add(permission);
  87. return permission;
  88. }
  89. public void RemoveChildPermission(string name)
  90. {
  91. _children.RemoveAll(p => p.Name == name);
  92. }
  93. public override string ToString()
  94. {
  95. return string.Format("[Permission: {0}]", Name);
  96. }
  97. }
  98. }