diff options
| author | ivarlovlie <git@ivarlovlie.no> | 2022-01-23 18:42:59 +0100 |
|---|---|---|
| committer | ivarlovlie <git@ivarlovlie.no> | 2022-01-23 18:42:59 +0100 |
| commit | 2d1d7019cbe051d2a42350a6f9d50e1f4ed8bd11 (patch) | |
| tree | 9a2dd00e28484d891ad683827790d5b839f6c45a /src/server/Jobs | |
| parent | ad8a8095e3942dc8c33c89a41a3ad31200a60472 (diff) | |
| download | bookmark-thing-2d1d7019cbe051d2a42350a6f9d50e1f4ed8bd11.tar.xz bookmark-thing-2d1d7019cbe051d2a42350a6f9d50e1f4ed8bd11.zip | |
feat: Remove stale tokens on a regular basis
Diffstat (limited to 'src/server/Jobs')
| -rw-r--r-- | src/server/Jobs/JobRegister.cs | 18 | ||||
| -rw-r--r-- | src/server/Jobs/TokenCleanupJob.cs | 19 |
2 files changed, 37 insertions, 0 deletions
diff --git a/src/server/Jobs/JobRegister.cs b/src/server/Jobs/JobRegister.cs new file mode 100644 index 0000000..98eac97 --- /dev/null +++ b/src/server/Jobs/JobRegister.cs @@ -0,0 +1,18 @@ +using Quartz; + +namespace IOL.BookmarkThing.Server.Jobs; + +public static class JobRegister +{ + public static readonly JobKey TokenCleanupKey = new("TokenCleanupJob"); + + public static IServiceCollectionQuartzConfigurator RegisterJobs(this IServiceCollectionQuartzConfigurator configurator) { + configurator.AddJob<TokenCleanupJob>(TokenCleanupKey); + configurator.AddTrigger(options => { + options.ForJob(TokenCleanupKey) + .WithIdentity(TokenCleanupKey.Name + "-trigger") + .WithCronSchedule(CronScheduleBuilder.DailyAtHourAndMinute(1, 0)); + }); + return configurator; + } +} diff --git a/src/server/Jobs/TokenCleanupJob.cs b/src/server/Jobs/TokenCleanupJob.cs new file mode 100644 index 0000000..99e7d0d --- /dev/null +++ b/src/server/Jobs/TokenCleanupJob.cs @@ -0,0 +1,19 @@ +namespace IOL.BookmarkThing.Server.Jobs; + +public class TokenCleanupJob : IJob +{ + private readonly ILogger<TokenCleanupJob> _logger; + private readonly AppDbContext _context; + + public TokenCleanupJob(ILogger<TokenCleanupJob> logger, AppDbContext context) { + _logger = logger; + _context = context; + } + + public Task Execute(IJobExecutionContext context) { + var staleTokens = _context.AccessTokens.Where(c => c.HasExpired); + _logger.LogInformation("Removing {0} stale tokens", staleTokens.Count()); + _context.AccessTokens.RemoveRange(); + return Task.CompletedTask; + } +} |
