Added the use of DEK's for encryption of secrets. Both the KEK's and DEK's are stored in a way that you can have multiple key of which one is active. But the others are still available for decrypting. This allows for implementing key rotation. Co-authored-by: eelke <eelke@eelkeklein.nl> Co-authored-by: Eelke76 <31384324+Eelke76@users.noreply.github.com> Reviewed-on: #6
22 lines
No EOL
532 B
C#
22 lines
No EOL
532 B
C#
using IdentityShroud.Core.Contracts;
|
|
using IdentityShroud.Core.Messages;
|
|
using IdentityShroud.Core.Model;
|
|
|
|
namespace IdentityShroud.Api.Mappers;
|
|
|
|
public class KeyMapper(IKeyService keyService)
|
|
{
|
|
public JsonWebKeySet KeyListToJsonWebKeySet(IEnumerable<RealmKey> keys)
|
|
{
|
|
JsonWebKeySet wks = new();
|
|
foreach (var k in keys)
|
|
{
|
|
var wk = keyService.CreateJsonWebKey(k);
|
|
if (wk is {})
|
|
{
|
|
wks.Keys.Add(wk);
|
|
}
|
|
}
|
|
return wks;
|
|
}
|
|
} |