public CookieSessionAffinityProvider( IOptions <CookieSessionAffinityProviderOptions> providerOptions, IDataProtectionProvider dataProtectionProvider, ILogger <CookieSessionAffinityProvider> logger) : base(dataProtectionProvider, logger) { _providerOptions = providerOptions?.Value ?? throw new ArgumentNullException(nameof(providerOptions)); }
public void AffinitizeRequest_CookieBuilderSettingsChanged_UseNewSettings() { var providerOptions = new CookieSessionAffinityProviderOptions(); providerOptions.Cookie.Domain = "mydomain.my"; providerOptions.Cookie.HttpOnly = false; providerOptions.Cookie.IsEssential = true; providerOptions.Cookie.MaxAge = TimeSpan.FromHours(1); providerOptions.Cookie.Name = "My.Affinity"; providerOptions.Cookie.Path = "/some"; providerOptions.Cookie.SameSite = SameSiteMode.Lax; providerOptions.Cookie.SecurePolicy = CookieSecurePolicy.Always; var provider = new CookieSessionAffinityProvider( Options.Create(providerOptions), AffinityTestHelper.GetDataProtector().Object, AffinityTestHelper.GetLogger <CookieSessionAffinityProvider>().Object); var context = new DefaultHttpContext(); provider.AffinitizeRequest(context, _defaultOptions, _destinations[1]); var affinityCookieHeader = context.Response.Headers["Set-Cookie"]; Assert.Equal("My.Affinity=ZGVzdC1C; max-age=3600; domain=mydomain.my; path=/some; secure; samesite=lax", affinityCookieHeader); }