Я хочу обрабатывать авторизацию в приложении MVC с помощью Windsor IInterceptor, потому что это кажется единственным способом получить именованный доступ к параметрам, которые передаются действиям, которые имеют значение для определения, имеет ли пользователь доступ.
Из моего метода Intercept мне нужен доступ к вызываемому действию. Я понял, как получить имена контроллера и действия (через RequestContext), но не сам метод — есть хорошие идеи?
Для справки примерно так выглядит код:
public class AuthorizationInterceptor : IInterceptor
{
public void Intercept(IInvocation invocation)
{
if (invocation.Arguments != null && invocation.Arguments.Length > 0 && invocation.Arguments[0] != null)
{
if (invocation.Arguments[0].GetType() == typeof(RequestContext))
{
var context = (RequestContext)invocation.Arguments[0];
var values = context.RouteData.Values;
if (!auth.Authorize(values, HttpContext.Current.User))
{
//RedirectToLogin }
}
}
invocation.Proceed();
}
}