O proxy é criado e o interceptador está na matriz __interceptores, mas o interceptor nunca é chamado
-
27-09-2019 - |
Pergunta
É a primeira vez que usei interceptores com o registro fluente e estou perdendo alguma coisa. Com o registro a seguir, posso resolver um iProcessingStep, e é uma classe de proxy e o interceptador está na matriz __interceptores, mas, por algum motivo, o interceptor não é chamado. Alguma idéia do que estou perdendo?
Obrigado, Drew
AllTypes.Of<IProcessingStep>()
.FromAssembly(Assembly.GetExecutingAssembly())
.ConfigureFor<IProcessingStep>(c => c
.Unless(Component.ServiceAlreadyRegistered)
.LifeStyle.PerThread
.Interceptors(InterceptorReference.ForType<StepLoggingInterceptor>()).First
),
Component.For<StepMonitorInterceptor>(),
Component.For<StepLoggingInterceptor>(),
Component.For<StoreInThreadInterceptor>()
public abstract class BaseStepInterceptor : IInterceptor
{
public void Intercept(IInvocation invocation)
{
IProcessingStep processingStep = (IProcessingStep)invocation.InvocationTarget;
Command cmd = (Command)invocation.Arguments[0];
OnIntercept(invocation, processingStep, cmd);
}
protected abstract void OnIntercept(IInvocation invocation, IProcessingStep processingStep, Command cmd);
}
public class StepLoggingInterceptor : BaseStepInterceptor
{
private readonly ILogger _logger;
public StepLoggingInterceptor(ILogger logger)
{
_logger = logger;
}
protected override void OnIntercept(IInvocation invocation, IProcessingStep processingStep, Command cmd)
{
_logger.TraceFormat("<{0}> for cmd:<{1}> - begin", processingStep.StepType, cmd.Id);
bool exceptionThrown = false;
try
{
invocation.Proceed();
}
catch
{
exceptionThrown = true;
throw;
}
finally
{
_logger.TraceFormat("<{0}> for cmd:<{1}> - end <{2}> times:<{3}>",
processingStep.StepType, cmd.Id,
!exceptionThrown && processingStep.CompletedSuccessfully
? "succeeded" : "failed",
cmd.CurrentMetric==null ? "{null}" : cmd.CurrentMetric.ToString());
}
}
}
Solução
Como Mauricio Hinter, você parece estar registrando seus componentes como um serviço de classe, não um serviço de interface. Nesse caso, a menos que o método que você esteja interceptando seja virtual, você não poderá interceptar. Altere seu registro para:
AllTypes.FromAssembly(Assembly.GetExecutingAssembly())
.BasedOn<IProcessingStep>()
.ConfigureFor<IProcessingStep>(c => c
.Unless(Component.ServiceAlreadyRegistered)
.LifeStyle.PerThread
.Interceptors(InterceptorReference.ForType<StepLoggingInterceptor>()).First
).WithService.Base(),
Licenciado em: CC-BY-SA com atribuição
Não afiliado a StackOverflow