using NetinaCMS.Repository.Models; using NetinaCMS.Repository.Services.Abstracts; namespace NetinaCMS.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 seedRoot = _adminUserSeedOptions.Value.RootUser; var rootUser = await _userManager.FindByNameAsync(seedRoot.Username); if (rootUser == null) { rootUser = new ApplicationUser { UserName = seedRoot.Username, Email = seedRoot.Email, EmailConfirmed = true, LockoutEnabled = true, FirstName = seedRoot.FirstName, LastName = seedRoot.LastName, Gender = Gender.Male, PhoneNumberConfirmed = true, PhoneNumber = seedRoot.Phone, BirthDate = DateTime.Now.AddYears(-23) }; var rootUserResult = await _userManager.CreateAsync(rootUser, seedRoot.Password); if (rootUserResult.Succeeded) await _userManager.AddToRoleAsync(rootUser, seedRoot.RoleName); } var seedAdmin = _adminUserSeedOptions.Value.ManagerUser; var adminUser = await _userManager.FindByNameAsync(seedAdmin.Username); if (adminUser == null) { 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 rootUserResult = await _userManager.CreateAsync(adminUser, seedAdmin.Password); if (rootUserResult.Succeeded) await _userManager.AddToRoleAsync(adminUser, seedAdmin.RoleName); } } catch (Exception e) { Console.WriteLine(e); throw; } } public async Task SeedRoles() { var seedAdmin = _adminUserSeedOptions.Value.RootUser; var rootRole = await _roleManager.FindByNameAsync(seedAdmin.RoleName); if (rootRole == null) { rootRole = new ApplicationRole { Name = seedAdmin.RoleName, EnglishName = seedAdmin.RoleName, Description = "root admin role" }; var adminRoleResult = await _roleManager.CreateAsync(rootRole); foreach (var claim in ApplicationClaims.AllClaims) await _roleManager.AddClaimAsync(rootRole, claim); } var managerRole = await _roleManager.FindByNameAsync("Manager"); if (managerRole == null) { managerRole = new ApplicationRole { Name = "Manager", EnglishName = "Manager", PersianName = "مدیریتـــ", Description = "admin role" }; var adminRoleResult = await _roleManager.CreateAsync(managerRole); foreach (var claim in ApplicationClaims.AllClaims) await _roleManager.AddClaimAsync(managerRole, claim); } var customerRole = await _roleManager.FindByNameAsync("Customer"); if (customerRole == null) { customerRole = new ApplicationRole { Name = "Customer", PersianName = "مشتری", EnglishName = "Customer", }; var customerRoleResult = await _roleManager.CreateAsync(customerRole); foreach (var claim in ApplicationClaims.CustomerClaims) await _roleManager.AddClaimAsync(customerRole, claim); } } }