aboutsummaryrefslogtreecommitdiffstats
path: root/code/api/src/Jobs/VaultTokenRenewalJob.cs
diff options
context:
space:
mode:
authorivarlovlie <git@ivarlovlie.no>2023-02-25 13:15:44 +0100
committerivarlovlie <git@ivarlovlie.no>2023-02-25 13:15:44 +0100
commit900bb5e845c3ad44defbd427cae3d44a4a43321f (patch)
treedf3d96a93771884add571e82336c29fc3d9c7a1c /code/api/src/Jobs/VaultTokenRenewalJob.cs
downloadgreatoffice-900bb5e845c3ad44defbd427cae3d44a4a43321f.tar.xz
greatoffice-900bb5e845c3ad44defbd427cae3d44a4a43321f.zip
feat: Initial commit
Diffstat (limited to 'code/api/src/Jobs/VaultTokenRenewalJob.cs')
-rw-r--r--code/api/src/Jobs/VaultTokenRenewalJob.cs24
1 files changed, 24 insertions, 0 deletions
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