41 lines
		
	
	
		
			1.2 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
			
		
		
	
	
			41 lines
		
	
	
		
			1.2 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
using DysonNetwork.Shared.Models;
 | 
						|
using Microsoft.EntityFrameworkCore;
 | 
						|
using NodaTime;
 | 
						|
using Quartz;
 | 
						|
 | 
						|
namespace DysonNetwork.Pass.Wallet;
 | 
						|
 | 
						|
public class GiftCleanupJob(
 | 
						|
    AppDatabase db,
 | 
						|
    ILogger<GiftCleanupJob> logger
 | 
						|
) : IJob
 | 
						|
{
 | 
						|
    public async Task Execute(IJobExecutionContext context)
 | 
						|
    {
 | 
						|
        logger.LogInformation("Starting gift cleanup job...");
 | 
						|
 | 
						|
        var now = SystemClock.Instance.GetCurrentInstant();
 | 
						|
        // Clean up gifts that are in Created status and older than 24 hours
 | 
						|
        var cutoffTime = now.Minus(Duration.FromHours(24));
 | 
						|
 | 
						|
        var oldCreatedGifts = await db.WalletGifts
 | 
						|
            .Where(g => g.Status == GiftStatus.Created)
 | 
						|
            .Where(g => g.CreatedAt < cutoffTime)
 | 
						|
            .ToListAsync();
 | 
						|
 | 
						|
        if (oldCreatedGifts.Count == 0)
 | 
						|
        {
 | 
						|
            logger.LogInformation("No old created gifts to clean up");
 | 
						|
            return;
 | 
						|
        }
 | 
						|
 | 
						|
        logger.LogInformation("Found {Count} old created gifts to clean up", oldCreatedGifts.Count);
 | 
						|
 | 
						|
        // Remove the gifts
 | 
						|
        db.WalletGifts.RemoveRange(oldCreatedGifts);
 | 
						|
        await db.SaveChangesAsync();
 | 
						|
 | 
						|
        logger.LogInformation("Successfully cleaned up {Count} old created gifts", oldCreatedGifts.Count);
 | 
						|
    }
 | 
						|
}
 |