diff options
Diffstat (limited to 'code/api/src/Jobs')
| -rw-r--r-- | code/api/src/Jobs/AccessTokenCleanupJob.cs | 20 | ||||
| -rw-r--r-- | code/api/src/Jobs/JobRegister.cs | 23 | ||||
| -rw-r--r-- | code/api/src/Jobs/VaultTokenRenewalJob.cs | 24 |
3 files changed, 67 insertions, 0 deletions
diff --git a/code/api/src/Jobs/AccessTokenCleanupJob.cs b/code/api/src/Jobs/AccessTokenCleanupJob.cs new file mode 100644 index 0000000..20b450c --- /dev/null +++ b/code/api/src/Jobs/AccessTokenCleanupJob.cs @@ -0,0 +1,20 @@ +namespace IOL.GreatOffice.Api.Jobs; + +public class AccessTokenCleanupJob : IJob +{ + private readonly ILogger<AccessTokenCleanupJob> _logger; + private readonly MainAppDatabase _context; + + public AccessTokenCleanupJob(ILogger<AccessTokenCleanupJob> logger, MainAppDatabase context) { + _logger = logger; + _context = context; + } + + public Task Execute(IJobExecutionContext context) { + var staleTokens = _context.AccessTokens.Where(c => c.ExpiryDate < AppDateTime.UtcNow).ToList(); + if (staleTokens.IsNullOrEmpty()) return Task.CompletedTask; + _logger.LogInformation("Removing {0} stale tokens", staleTokens.Count()); + _context.AccessTokens.RemoveRange(staleTokens); + return Task.CompletedTask; + } +} diff --git a/code/api/src/Jobs/JobRegister.cs b/code/api/src/Jobs/JobRegister.cs new file mode 100644 index 0000000..1da7d5b --- /dev/null +++ b/code/api/src/Jobs/JobRegister.cs @@ -0,0 +1,23 @@ +namespace IOL.GreatOffice.Api.Jobs; + +public static class JobRegister +{ + private static readonly JobKey AccessTokenCleanupKey = new("AccessTokenCleanupKey"); + private static readonly JobKey VaultTokenRenewalKey = new("VaultTokenRenewalKey"); + + public static IServiceCollectionQuartzConfigurator RegisterJobs(this IServiceCollectionQuartzConfigurator configurator) { + configurator.AddJob<AccessTokenCleanupJob>(AccessTokenCleanupKey); + configurator.AddJob<VaultTokenRenewalJob>(VaultTokenRenewalKey); + configurator.AddTrigger(options => { + options.ForJob(AccessTokenCleanupKey) + .WithIdentity(AccessTokenCleanupKey.Name + "-trigger") + .WithCronSchedule("0 0 0/1 ? * * *"); + }); + configurator.AddTrigger(options => { + options.ForJob(VaultTokenRenewalKey) + .WithIdentity(VaultTokenRenewalKey.Name + "-trigger") + .WithCronSchedule("0 0 0/1 ? * * *"); + }); + return configurator; + } +}
\ No newline at end of file diff --git a/code/api/src/Jobs/VaultTokenRenewalJob.cs b/code/api/src/Jobs/VaultTokenRenewalJob.cs new file mode 100644 index 0000000..1768629 --- /dev/null +++ b/code/api/src/Jobs/VaultTokenRenewalJob.cs @@ -0,0 +1,24 @@ +namespace IOL.GreatOffice.Api.Jobs; + +public class VaultTokenRenewalJob : IJob +{ + private readonly ILogger<VaultTokenRenewalJob> _logger; + private readonly VaultService _vaultService; + + public VaultTokenRenewalJob(ILogger<VaultTokenRenewalJob> logger, VaultService vaultService) { + _logger = logger; + _vaultService = vaultService; + } + + public async Task Execute(IJobExecutionContext context) { + _logger.LogInformation("Starting vault token renewal"); + var renew = await _vaultService.RenewTokenAsync(); + if (renew == default) { + _logger.LogCritical("Renewal did not succeed"); + return; + } + + var token = await _vaultService.LookupTokenAsync(); + _logger.LogInformation("Token was renewed, new expire time {expires}", token.Data.ExpireTime); + } +}
\ No newline at end of file |
