62 lines
2.3 KiB
C#
62 lines
2.3 KiB
C#
|
using Demo.Data.Exceptions;
|
|||
|
using Demo.Data.RemoteData.RemoteDataBase;
|
|||
|
using Demo.Data.RemoteData.RemoteDataBase.DAO;
|
|||
|
using Demo.domain.Models;
|
|||
|
|
|||
|
|
|||
|
namespace Demo.Data.Repository
|
|||
|
{
|
|||
|
public class SQLUserRepositoryImpl : IUserRepository
|
|||
|
{
|
|||
|
private readonly RemoteDatabaseContext _remoteDatabaseContext;
|
|||
|
|
|||
|
public SQLUserRepositoryImpl(RemoteDatabaseContext remoteDatabaseContext)
|
|||
|
{
|
|||
|
_remoteDatabaseContext = remoteDatabaseContext;
|
|||
|
}
|
|||
|
|
|||
|
// Метод для получения всех пользователей
|
|||
|
public IEnumerable<UserLocalEnity> GetAllUsers => _remoteDatabaseContext.Users.Select(u => new UserLocalEnity
|
|||
|
{
|
|||
|
Guid = u.Guid,
|
|||
|
FIO = u.FIO,
|
|||
|
GroupID = u.GroupID
|
|||
|
}).ToList();
|
|||
|
|
|||
|
// Метод для удаления пользователя по GUID
|
|||
|
public bool RemoveUserById(Guid userGuid)
|
|||
|
{
|
|||
|
var user = _remoteDatabaseContext.Users.FirstOrDefault(u => u.Guid == userGuid);
|
|||
|
if (user == null) throw new UserNotFoundException(userGuid);
|
|||
|
|
|||
|
_remoteDatabaseContext.Users.Remove(user); // Удаление
|
|||
|
|
|||
|
_remoteDatabaseContext.SaveChanges(); // Сохранение изменений в базе данных
|
|||
|
return true;
|
|||
|
}
|
|||
|
|
|||
|
// Метод для обновления данных пользователя
|
|||
|
public UserLocalEnity? UpdateUser(UserLocalEnity user)
|
|||
|
{
|
|||
|
var existingUser = _remoteDatabaseContext.Users.FirstOrDefault(u => u.Guid == user.Guid);
|
|||
|
if (existingUser == null) throw new UserNotFoundException(user.Guid);
|
|||
|
|
|||
|
existingUser.FIO = user.FIO;
|
|||
|
existingUser.GroupID = user.GroupID;
|
|||
|
|
|||
|
_remoteDatabaseContext.SaveChanges(); // Сохранение изменений в базе данных
|
|||
|
|
|||
|
// Возвращаем обновленный объект UserLocalEnity
|
|||
|
return new UserLocalEnity
|
|||
|
{
|
|||
|
Guid = existingUser.Guid,
|
|||
|
FIO = existingUser.FIO,
|
|||
|
GroupID = existingUser.GroupID
|
|||
|
};
|
|||
|
}
|
|||
|
|
|||
|
public IEnumerable<UserDao> GetAllUsersDao => _remoteDatabaseContext.Users.ToList(); // Дополнительный метод для DAO, если требуется
|
|||
|
}
|
|||
|
}
|
|||
|
|