IDataProtectionBuilder.AddKeyManagementOptions
I have multiple API servers and I want them to be capable of sharing cookies so I have this code.
How can I do this better?
7 Replies
I changed from using the activator to this. Which is okay because only one instance is created now. But I still don't like that I'm getting a reference to the app. Is this some design fault on my part or it seems I'm stuck behind whatever DataProtection is doing. I guess I could make my own cookies to avoid this.
There are a few PersistKeysTo* options that are built in, maybe the dbcontext one would work here? https://learn.microsoft.com/en-us/aspnet/core/security/data-protection/configuration/overview?view=aspnetcore-9.0#persistkeystodbcontext
Configure ASP.NET Core Data Protection
Learn how to configure Data Protection in ASP.NET Core.
I'm not using EF.
You can look at the pattern that they use and see if that is what you want to do.
The azure one's source is a bit easier to get to
Yeah I need to ask about redis lpush and lrange because I basically copied the pattern from
https://github.com/dotnet/aspnetcore/blob/main/src/DataProtection/StackExchangeRedis/src/RedisDataProtectionBuilderExtensions.cs
https://github.com/StackExchange/StackExchange.Redis/blob/main/src/StackExchange.Redis/RedisDatabase.cs#L1334
I'm not sure what LPUSH does. Apparently it puts stuff on the left?
And LRANGE seems to go from left to right? I think it's ultimately LIFO. But I'm not sure.
That seems to be the case based on the regis docs https://redis.io/docs/latest/commands/lpush/
LPUSH
Prepends one or more elements to a list. Creates the key if it doesn't exist.
Okay yeah I read that lastnight and I guess I was tired.