Files
Umbraco-CMS/src/Umbraco.Core/Services/BasicAuthService.cs

62 lines
2.2 KiB
C#

using System.Net;
using Microsoft.Extensions.DependencyInjection;
using Microsoft.Extensions.Options;
using Microsoft.Extensions.Primitives;
using Umbraco.Cms.Core.Configuration.Models;
using Umbraco.Cms.Core.DependencyInjection;
namespace Umbraco.Cms.Core.Services.Implement;
public class BasicAuthService : IBasicAuthService
{
private readonly IIpAddressUtilities _ipAddressUtilities;
private BasicAuthSettings _basicAuthSettings;
// Scheduled for removal in v12
[Obsolete("Please use the contructor that takes an IIpadressUtilities instead")]
public BasicAuthService(IOptionsMonitor<BasicAuthSettings> optionsMonitor)
: this(optionsMonitor, StaticServiceProvider.Instance.GetRequiredService<IIpAddressUtilities>())
{
_basicAuthSettings = optionsMonitor.CurrentValue;
optionsMonitor.OnChange(basicAuthSettings => _basicAuthSettings = basicAuthSettings);
}
public BasicAuthService(IOptionsMonitor<BasicAuthSettings> optionsMonitor, IIpAddressUtilities ipAddressUtilities)
{
_ipAddressUtilities = ipAddressUtilities;
_basicAuthSettings = optionsMonitor.CurrentValue;
optionsMonitor.OnChange(basicAuthSettings => _basicAuthSettings = basicAuthSettings);
}
public bool IsBasicAuthEnabled() => _basicAuthSettings.Enabled;
public bool IsRedirectToLoginPageEnabled() => _basicAuthSettings.RedirectToLoginPage;
public bool IsIpAllowListed(IPAddress clientIpAddress)
{
foreach (var allowedIpString in _basicAuthSettings.AllowedIPs)
{
if (_ipAddressUtilities.IsAllowListed(clientIpAddress, allowedIpString))
{
return true;
}
}
return false;
}
public bool HasCorrectSharedSecret(IDictionary<string, StringValues> headers)
{
var headerName = _basicAuthSettings.SharedSecret.HeaderName;
var sharedSecret = _basicAuthSettings.SharedSecret.Value;
if (string.IsNullOrWhiteSpace(headerName) || string.IsNullOrWhiteSpace(sharedSecret))
{
return false;
}
return headers.TryGetValue(headerName, out StringValues value) && value.Equals(sharedSecret);
}
}