
* Version bump * Okay this should be the last (#2037) * Fixed improper date visualization for reading list detail page. * Correct not-read badge position (#2034) --------- Co-authored-by: Andre Smith <Hobogrammer@users.noreply.github.com> * Bump versions by dotnet-bump-version. * Merged develop in --------- Co-authored-by: Andre Smith <Hobogrammer@users.noreply.github.com>
30 lines
1 KiB
C#
30 lines
1 KiB
C#
using System.Threading.Tasks;
|
|
using API.Constants;
|
|
using API.Entities;
|
|
using Microsoft.AspNetCore.Identity;
|
|
|
|
namespace API.Data.ManualMigrations;
|
|
|
|
/// <summary>
|
|
/// New role introduced in v0.5.1. Adds the role to all users.
|
|
/// </summary>
|
|
public static class MigrateChangePasswordRoles
|
|
{
|
|
/// <summary>
|
|
/// Will not run if any users have the ChangePassword role already
|
|
/// </summary>
|
|
/// <param name="unitOfWork"></param>
|
|
/// <param name="userManager"></param>
|
|
public static async Task Migrate(IUnitOfWork unitOfWork, UserManager<AppUser> userManager)
|
|
{
|
|
var usersWithRole = await userManager.GetUsersInRoleAsync(PolicyConstants.ChangePasswordRole);
|
|
if (usersWithRole.Count != 0) return;
|
|
|
|
var allUsers = await unitOfWork.UserRepository.GetAllUsersAsync();
|
|
foreach (var user in allUsers)
|
|
{
|
|
await userManager.RemoveFromRoleAsync(user, "ChangePassword");
|
|
await userManager.AddToRoleAsync(user, PolicyConstants.ChangePasswordRole);
|
|
}
|
|
}
|
|
}
|