mirror of
https://github.com/Kareadita/Kavita.git
synced 2025-11-08 07:43:21 -05:00
67 lines
2.0 KiB
C#
67 lines
2.0 KiB
C#
using System;
|
|
using System.Security.Cryptography;
|
|
using System.Threading.Tasks;
|
|
using Microsoft.AspNetCore.Authentication;
|
|
using Microsoft.AspNetCore.Authentication.Cookies;
|
|
using Microsoft.Extensions.Caching.Memory;
|
|
|
|
namespace API.Services.Store;
|
|
|
|
/// <summary>
|
|
/// The <see cref="ITicketStore"/> is used as <see cref="CookieAuthenticationOptions.SessionStore"/> for the OIDC implementation
|
|
/// The full AuthenticationTicket cannot be included in the Cookie as popular reverse proxies (like nginx) will deny the request
|
|
/// due the large header size. Instead, the key is used.
|
|
/// </summary>
|
|
/// <param name="cache"></param>
|
|
/// <remarks>Note that this store is in memory, so OIDC authenticated users are logged out after restart</remarks>
|
|
public class CustomTicketStore(IMemoryCache cache): ITicketStore
|
|
{
|
|
|
|
public async Task<string> StoreAsync(AuthenticationTicket ticket)
|
|
{
|
|
// Note: It might not be needed to make this cryptographic random, but better safe than sorry
|
|
var bytes = new byte[32];
|
|
RandomNumberGenerator.Fill(bytes);
|
|
var key = Convert.ToBase64String(bytes);
|
|
|
|
await RenewAsync(key, ticket);
|
|
|
|
return key;
|
|
}
|
|
|
|
public Task RenewAsync(string key, AuthenticationTicket ticket)
|
|
{
|
|
var options = new MemoryCacheEntryOptions
|
|
{
|
|
Priority = CacheItemPriority.NeverRemove,
|
|
Size = 1,
|
|
};
|
|
|
|
var expiresUtc = ticket.Properties.ExpiresUtc;
|
|
if (expiresUtc.HasValue)
|
|
{
|
|
options.AbsoluteExpiration = expiresUtc.Value;
|
|
}
|
|
else
|
|
{
|
|
options.SlidingExpiration = TimeSpan.FromDays(7);
|
|
}
|
|
|
|
cache.Set(key, ticket, options);
|
|
|
|
return Task.CompletedTask;
|
|
}
|
|
|
|
public Task<AuthenticationTicket> RetrieveAsync(string key)
|
|
{
|
|
return Task.FromResult(cache.Get<AuthenticationTicket>(key));
|
|
}
|
|
|
|
public Task RemoveAsync(string key)
|
|
{
|
|
cache.Remove(key);
|
|
|
|
return Task.CompletedTask;
|
|
}
|
|
}
|