The Hangfire Job Checker Filter library provides a custom Hangfire filter (JobCheckerFilter) that allows you to execute custom logic after a Hangfire job has been performed. This filter integrates with Hangfire's server-side processing to execute an IJobChecker service asynchronously, allowing for post-job checks or actions. This setup facilitates error handling, logging, or additional operations after each job execution within your Hangfire background processing setup.
- Custom Job Checking: Execute custom logic after each Hangfire job using the JobCheckerFilter.
- Integration with Dependency Injection: Supports dependency injection for IJobChecker implementations.
Register services in your DI container:
builder.Services.AddScoped(typeof(IEmailService), typeof(EmailService));
builder.Services.AddHangfireJobHunter<JobHunterDemo>();
Create service and custom logic after each Hangfire job, My example below is to create a service that sends warning emails to failed jobs.
public class JobHunterDemo : IJobHunter
{
private readonly IEmailService _emailService;
public JobHunterDemo(IEmailService emailService)
{
_emailService = emailService;
}
[Obsolete]
public async Task ExecuteAync(PerformedContext context)
{
if (context.Exception != null)
{
await _emailService.SendEmailAsync("hungnguyen8102000@gmail.com", $"Hangfire Job Failed - Job #: {context.JobId}", $"Exception: {context.Exception.InnerException?.Message}. {context.Exception.InnerException?.StackTrace}");
}
await Task.CompletedTask;
}
}