Skip to content

Hangfire Job Checker - hangfire's extension serves to use easily and thoroughly.

Notifications You must be signed in to change notification settings

Maniceraf/Maniceraf.Hangfire.JobChecker

Repository files navigation

Maniceraf.Hangfire.JobChecker

Description:

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.

Features:

  • Custom Job Checking: Execute custom logic after each Hangfire job using the JobCheckerFilter.
  • Integration with Dependency Injection: Supports dependency injection for IJobChecker implementations.

Usage:

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;
    }
}

About

Hangfire Job Checker - hangfire's extension serves to use easily and thoroughly.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages