using Brizco.Domain.Entities.User; using Task = System.Threading.Tasks.Task; namespace Brizco.Repository.Services; public class DbInitializerService : IDbInitializerService { private readonly IOptionsSnapshot _adminUserSeedOptions; private readonly ApplicationContext _context; private readonly ILogger _logger; private readonly RoleManager _roleManager; private readonly UserManager _userManager; public DbInitializerService( ApplicationContext context, RoleManager roleManager, UserManager userManager, IOptionsSnapshot adminUserSeedOptions, ILogger logger) { _context = context; _roleManager = roleManager; _userManager = userManager; _adminUserSeedOptions = adminUserSeedOptions; _logger = logger; } public void Initialize() { try { _context.Database.Migrate(); _logger.LogInformation("Migration SUCCESS !!!!"); } catch (Exception e) { _logger.LogError(e, e.Message); } } public async Task SeedDate(bool force = false) { try { await SeedRoles(); var seedAdmin = _adminUserSeedOptions.Value.UserSetting; var user = await _userManager.FindByNameAsync(seedAdmin.Username); if (user == null) { var adminUser = new ApplicationUser { UserName = seedAdmin.Username, Email = seedAdmin.Email, EmailConfirmed = true, LockoutEnabled = true, FirstName = seedAdmin.FirstName, LastName = seedAdmin.LastName, Gender = Gender.Male, PhoneNumberConfirmed = true, PhoneNumber = seedAdmin.Phone, BirthDate = DateTime.Now.AddYears(-23) }; var adminUserResult = await _userManager.CreateAsync(adminUser, seedAdmin.Password); if (adminUserResult.Succeeded) await _userManager.AddToRoleAsync(adminUser, seedAdmin.RoleName); } } catch (Exception e) { Console.WriteLine(e); throw; } } public async Task SeedRoles() { var seedAdmin = _adminUserSeedOptions.Value.UserSetting; var managerRole = await _roleManager.FindByNameAsync(seedAdmin.RoleName); if (managerRole == null) { managerRole = new ApplicationRole { Name = seedAdmin.RoleName, EnglishName = seedAdmin.RoleName, Description = "root admin role" }; var adminRoleResult = await _roleManager.CreateAsync(managerRole); foreach (var claim in ApplicationClaims.AllClaims) await _roleManager.AddClaimAsync(managerRole, claim); } //var roles = await _roleManager.Roles.ToListAsync(); //foreach (var role in roles) //{ // if (role.EnglishName == "Manager") // { // var claims = await _roleManager.GetClaimsAsync(role); // foreach (var claim in ApplicationClaims.ManagerClaims) // { // if(!claims.Contains(claim)) // await _roleManager.AddClaimAsync(role, claim); // } // } // else if (role.EnglishName == "ViewerOwner") // { // var claims = await _roleManager.GetClaimsAsync(role); // foreach (var claim in ApplicationClaims.ViewerOwnerClaims) // { // if (!claims.Contains(claim)) // await _roleManager.AddClaimAsync(role, claim); // } // } // else if (role.EnglishName == "SuperVisor") // { // var claims = await _roleManager.GetClaimsAsync(role); // foreach (var claim in ApplicationClaims.SuperVisorClaims) // { // if (!claims.Contains(claim)) // await _roleManager.AddClaimAsync(role, claim); // } // } // else if (role.EnglishName == "Staff") // { // var claims = await _roleManager.GetClaimsAsync(role); // foreach (var claim in ApplicationClaims.StaffClaims) // { // if (!claims.Contains(claim)) // await _roleManager.AddClaimAsync(role, claim); // } // } //} } }