using Microsoft.AspNetCore.Authorization; namespace SIGCM2.Api.Authorization; /// /// Authorization attribute that requires the authenticated user to have at least ONE /// of the declared permission codes assigned to their role (OR semantics). /// Implements IAuthorizationRequirementData (.NET 8+) so ASP.NET Core builds the policy /// on-the-fly from GetRequirements() — no AddPolicy() registration needed. /// /// /// // Single permission /// [RequirePermission("administracion:usuarios:gestionar")] /// /// // Multiple — OR semantics: any single match grants access /// [RequirePermission("ventas:contado:crear", "ventas:ctacte:crear")] /// [AttributeUsage(AttributeTargets.Class | AttributeTargets.Method, AllowMultiple = false)] public sealed class RequirePermissionAttribute : AuthorizeAttribute, IAuthorizationRequirement, IAuthorizationRequirementData { /// Permission codes required (OR semantics — at least one must match). public string[] PermissionCodes { get; } public RequirePermissionAttribute(params string[] permissionCodes) { if (permissionCodes is null || permissionCodes.Length == 0) throw new ArgumentException("At least one permission code is required.", nameof(permissionCodes)); PermissionCodes = permissionCodes; } /// public IEnumerable GetRequirements() => new[] { this }; }