using DbConnectionLibrairie; using EntityManagers; using ExtensionsClassLibrairie; using ManagerInterfaces; using Model; using OrderCriterias; namespace DataManagers { public class AdministratorDataManager(MyDbContext dbContext) : IAdministratorManager { private AdministratorEntityManager manager = new AdministratorEntityManager(dbContext); public async Task addAdmin(Administrator admin) { return await Task.FromResult((await manager.addAdmin(admin.ToEntity())).ToModel()); } public async Task getAdministratorByUsername(string username) { return await Task.FromResult((await manager.getAdministratorByUsername(username))?.ToModel()); } public async Task<(int nbPages, IEnumerable? administrators)> getAdministrators(int nb, int count, AdministratorOrderCriteria orderCriteria = AdministratorOrderCriteria.ById) { List? tmp = new List(); var res = await manager.getAdministrators(nb, count, orderCriteria); if (res.administrators == null) tmp = null; else { foreach (var item in res.administrators) { tmp.Add(item.ToModel()); } } return await Task.FromResult<(int nbPages, IEnumerable? administrators)>((res.nbPages, tmp)); } public int getNbElements() { return manager.getNbElements(); } public async Task removeAdmin(Administrator admin) { return (await manager.removeAdmin(admin.ToEntity()))?.ToModel(); } public async Task removeAdmin(int id) { return (await manager.removeAdmin(id))?.ToModel(); } public async Task setPassword(string username, string newHashedPassword) { return await manager.setPassword(username, newHashedPassword); } } }