Files
server/src/Core/Auth/Identity/UserStore.cs

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

184 lines
6.3 KiB
C#
Raw Normal View History

using Bit.Core.Context;
using Bit.Core.Entities;
2015-12-08 22:57:38 -05:00
using Bit.Core.Repositories;
2018-08-28 17:40:08 -04:00
using Bit.Core.Services;
2016-05-19 19:10:24 -04:00
using Microsoft.AspNetCore.Identity;
2018-08-28 17:40:08 -04:00
using Microsoft.Extensions.DependencyInjection;
2015-12-08 22:57:38 -05:00
[PM-1188] Server owner auth migration (#2825) * [PM-1188] add sso project to auth * [PM-1188] move sso api models to auth * [PM-1188] fix sso api model namespace & imports * [PM-1188] move core files to auth * [PM-1188] fix core sso namespace & models * [PM-1188] move sso repository files to auth * [PM-1188] fix sso repo files namespace & imports * [PM-1188] move sso sql files to auth folder * [PM-1188] move sso test files to auth folders * [PM-1188] fix sso tests namespace & imports * [PM-1188] move auth api files to auth folder * [PM-1188] fix auth api files namespace & imports * [PM-1188] move auth core files to auth folder * [PM-1188] fix auth core files namespace & imports * [PM-1188] move auth email templates to auth folder * [PM-1188] move auth email folder back into shared directory * [PM-1188] fix auth email names * [PM-1188] move auth core models to auth folder * [PM-1188] fix auth model namespace & imports * [PM-1188] add entire Identity project to auth codeowners * [PM-1188] fix auth orm files namespace & imports * [PM-1188] move auth orm files to auth folder * [PM-1188] move auth sql files to auth folder * [PM-1188] move auth tests to auth folder * [PM-1188] fix auth test files namespace & imports * [PM-1188] move emergency access api files to auth folder * [PM-1188] fix emergencyaccess api files namespace & imports * [PM-1188] move emergency access core files to auth folder * [PM-1188] fix emergency access core files namespace & imports * [PM-1188] move emergency access orm files to auth folder * [PM-1188] fix emergency access orm files namespace & imports * [PM-1188] move emergency access sql files to auth folder * [PM-1188] move emergencyaccess test files to auth folder * [PM-1188] fix emergency access test files namespace & imports * [PM-1188] move captcha files to auth folder * [PM-1188] fix captcha files namespace & imports * [PM-1188] move auth admin files into auth folder * [PM-1188] fix admin auth files namespace & imports - configure mvc to look in auth folders for views * [PM-1188] remove extra imports and formatting * [PM-1188] fix ef auth model imports * [PM-1188] fix DatabaseContextModelSnapshot paths * [PM-1188] fix grant import in ef * [PM-1188] update sqlproj * [PM-1188] move missed sqlproj files * [PM-1188] move auth ef models out of auth folder * [PM-1188] fix auth ef models namespace * [PM-1188] remove auth ef models unused imports * [PM-1188] fix imports for auth ef models * [PM-1188] fix more ef model imports * [PM-1188] fix file encodings
2023-04-14 13:25:56 -04:00
namespace Bit.Core.Auth.Identity;
2022-08-29 16:06:55 -04:00
2015-12-08 22:57:38 -05:00
public class UserStore :
IUserStore<User>,
IUserPasswordStore<User>,
IUserEmailStore<User>,
IUserTwoFactorStore<User>,
IUserSecurityStampStore<User>
{
2018-08-28 17:40:08 -04:00
private readonly IServiceProvider _serviceProvider;
2015-12-08 22:57:38 -05:00
private readonly IUserRepository _userRepository;
private readonly ICurrentContext _currentContext;
2022-08-29 16:06:55 -04:00
2015-12-27 00:14:56 -05:00
public UserStore(
2018-08-28 17:40:08 -04:00
IServiceProvider serviceProvider,
2015-12-27 00:14:56 -05:00
IUserRepository userRepository,
ICurrentContext currentContext)
2015-12-08 22:57:38 -05:00
{
2018-08-28 17:40:08 -04:00
_serviceProvider = serviceProvider;
2015-12-08 22:57:38 -05:00
_userRepository = userRepository;
2015-12-27 00:14:56 -05:00
_currentContext = currentContext;
2015-12-08 22:57:38 -05:00
}
public void Dispose() { }
public async Task<IdentityResult> CreateAsync(User user, CancellationToken cancellationToken = default(CancellationToken))
{
await _userRepository.CreateAsync(user);
return IdentityResult.Success;
}
public async Task<IdentityResult> DeleteAsync(User user, CancellationToken cancellationToken = default(CancellationToken))
{
await _userRepository.DeleteAsync(user);
return IdentityResult.Success;
}
public async Task<User> FindByEmailAsync(string normalizedEmail, CancellationToken cancellationToken = default(CancellationToken))
2022-08-29 16:06:55 -04:00
{
if (_currentContext?.User != null && _currentContext.User.Email == normalizedEmail)
2015-12-08 22:57:38 -05:00
{
return _currentContext.User;
2015-12-08 22:57:38 -05:00
}
_currentContext.User = await _userRepository.GetByEmailAsync(normalizedEmail);
return _currentContext.User;
2022-08-29 16:06:55 -04:00
}
2015-12-08 22:57:38 -05:00
public async Task<User> FindByIdAsync(string userId, CancellationToken cancellationToken = default(CancellationToken))
2022-08-29 16:06:55 -04:00
{
if (_currentContext?.User != null &&
string.Equals(_currentContext.User.Id.ToString(), userId, StringComparison.InvariantCultureIgnoreCase))
2015-12-08 22:57:38 -05:00
{
return _currentContext.User;
2015-12-08 22:57:38 -05:00
}
Guid userIdGuid;
2015-12-08 22:57:38 -05:00
if (!Guid.TryParse(userId, out userIdGuid))
{
return null;
2015-12-08 22:57:38 -05:00
}
_currentContext.User = await _userRepository.GetByIdAsync(userIdGuid);
return _currentContext.User;
}
public async Task<User> FindByNameAsync(string normalizedUserName, CancellationToken cancellationToken = default(CancellationToken))
{
return await FindByEmailAsync(normalizedUserName, cancellationToken);
}
public Task<string> GetEmailAsync(User user, CancellationToken cancellationToken = default(CancellationToken))
{
return Task.FromResult(user.Email);
}
public Task<bool> GetEmailConfirmedAsync(User user, CancellationToken cancellationToken = default(CancellationToken))
{
return Task.FromResult(user.EmailVerified);
2015-12-08 22:57:38 -05:00
}
public Task<string> GetNormalizedEmailAsync(User user, CancellationToken cancellationToken = default(CancellationToken))
{
return Task.FromResult(user.Email);
}
public Task<string> GetNormalizedUserNameAsync(User user, CancellationToken cancellationToken = default(CancellationToken))
{
return Task.FromResult(user.Email);
}
public Task<string> GetPasswordHashAsync(User user, CancellationToken cancellationToken = default(CancellationToken))
{
return Task.FromResult(user.MasterPassword);
2015-12-08 22:57:38 -05:00
}
public Task<string> GetUserIdAsync(User user, CancellationToken cancellationToken = default(CancellationToken))
{
return Task.FromResult(user.Id.ToString());
2015-12-08 22:57:38 -05:00
}
public Task<string> GetUserNameAsync(User user, CancellationToken cancellationToken = default(CancellationToken))
{
return Task.FromResult(user.Email);
2015-12-08 22:57:38 -05:00
}
public Task<bool> HasPasswordAsync(User user, CancellationToken cancellationToken = default(CancellationToken))
{
return Task.FromResult(!string.IsNullOrWhiteSpace(user.MasterPassword));
2015-12-08 22:57:38 -05:00
}
public Task SetEmailAsync(User user, string email, CancellationToken cancellationToken = default(CancellationToken))
{
user.Email = email;
return Task.FromResult(0);
2015-12-08 22:57:38 -05:00
}
public Task SetEmailConfirmedAsync(User user, bool confirmed, CancellationToken cancellationToken = default(CancellationToken))
{
user.EmailVerified = confirmed;
return Task.FromResult(0);
2015-12-08 22:57:38 -05:00
}
public Task SetNormalizedEmailAsync(User user, string normalizedEmail, CancellationToken cancellationToken = default(CancellationToken))
{
user.Email = normalizedEmail;
2015-12-08 22:57:38 -05:00
return Task.FromResult(0);
}
public Task SetNormalizedUserNameAsync(User user, string normalizedName, CancellationToken cancellationToken = default(CancellationToken))
{
2017-07-05 15:35:46 -04:00
user.Email = normalizedName;
return Task.FromResult(0);
2015-12-08 22:57:38 -05:00
}
2018-08-28 17:40:08 -04:00
public Task SetPasswordHashAsync(User user, string passwordHash, CancellationToken cancellationToken = default(CancellationToken))
2015-12-08 22:57:38 -05:00
{
user.MasterPassword = passwordHash;
return Task.FromResult(0);
2015-12-08 22:57:38 -05:00
}
public Task SetUserNameAsync(User user, string userName, CancellationToken cancellationToken = default(CancellationToken))
{
user.Email = userName;
return Task.FromResult(0);
2015-12-08 22:57:38 -05:00
}
public async Task<IdentityResult> UpdateAsync(User user, CancellationToken cancellationToken = default(CancellationToken))
2022-08-29 14:53:16 -04:00
{
user.RevisionDate = user.AccountRevisionDate = DateTime.UtcNow;
await _userRepository.ReplaceAsync(user);
return IdentityResult.Success;
2022-08-29 14:53:16 -04:00
}
2015-12-08 22:57:38 -05:00
public Task SetTwoFactorEnabledAsync(User user, bool enabled, CancellationToken cancellationToken)
2022-08-29 14:53:16 -04:00
{
2017-06-19 22:25:19 -04:00
// Do nothing...
2015-12-08 22:57:38 -05:00
return Task.FromResult(0);
2022-08-29 14:53:16 -04:00
}
2015-12-08 22:57:38 -05:00
public async Task<bool> GetTwoFactorEnabledAsync(User user, CancellationToken cancellationToken)
2022-08-29 16:06:55 -04:00
{
return await _serviceProvider.GetRequiredService<IUserService>().TwoFactorIsEnabledAsync(user);
2022-08-29 16:06:55 -04:00
}
2015-12-08 22:57:38 -05:00
public Task SetSecurityStampAsync(User user, string stamp, CancellationToken cancellationToken)
2022-08-29 16:06:55 -04:00
{
2015-12-08 22:57:38 -05:00
user.SecurityStamp = stamp;
return Task.FromResult(0);
2022-08-29 16:06:55 -04:00
}
2015-12-08 22:57:38 -05:00
public Task<string> GetSecurityStampAsync(User user, CancellationToken cancellationToken)
{
return Task.FromResult(user.SecurityStamp);
}
}