yavsc/Yavsc/AuthorizationHandlers/PostUserFileHandler.cs

22 lines
799 B
C#

using System.Security.Claims;
using Microsoft.AspNet.Authorization;
8 years ago
using Yavsc.ViewModel.Auth;
8 years ago
namespace Yavsc.ViewModels.Auth.Handlers
{
8 years ago
public class PostUserFileHandler : AuthorizationHandler<EditRequirement, FileSpotInfo>
{
8 years ago
protected override void Handle(AuthorizationContext context, EditRequirement requirement, FileSpotInfo resource)
{
8 years ago
if (context.User.IsInRole(Constants.BlogModeratorGroupName)
|| context.User.IsInRole(Constants.AdminGroupName))
context.Succeed(requirement);
8 years ago
if (!context.User.Identity.IsAuthenticated)
context.Fail();
if (resource.AuthorId == context.User.GetUserId())
context.Succeed(requirement);
8 years ago
else context.Fail();
}
}
}