aboutsummaryrefslogtreecommitdiffstats
path: root/code/api/src/Jobs
diff options
context:
space:
mode:
Diffstat (limited to 'code/api/src/Jobs')
-rw-r--r--code/api/src/Jobs/AccessTokenCleanupJob.cs20
-rw-r--r--code/api/src/Jobs/JobRegister.cs23
-rw-r--r--code/api/src/Jobs/VaultTokenRenewalJob.cs24
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