Presence_Desktop/data/Repository/SQLUserRepositoryImpl.cs

115 lines
4.9 KiB
C#
Raw Normal View History

2024-12-23 11:20:09 +00:00
using data.Exception;
using data.RemoteData.DAO;
2024-12-23 11:26:41 +00:00
using data.RemoteData;
2024-12-23 11:20:09 +00:00
using domain.Models;
using Microsoft.EntityFrameworkCore;
namespace data.Repository
{
public class SQLUserRepositoryImpl : IUserRepository
{
private readonly RemoteDatabaseContext _remoteDatabaseContext;
2024-12-23 11:26:41 +00:00
// Конструктор, инициализирующий контекст базы данных
2024-12-23 11:20:09 +00:00
public SQLUserRepositoryImpl(RemoteDatabaseContext remoteDatabaseContext)
{
_remoteDatabaseContext = remoteDatabaseContext;
}
2024-12-23 11:26:41 +00:00
// Добавление нового пользователя
public bool AddUser(UserDao user)
{
try
2024-12-23 11:20:09 +00:00
{
2024-12-23 11:26:41 +00:00
// Создание нового объекта UserDao
var userDao = new UserDao
{
Guid = user.Guid,
FIO = user.FIO,
GroupID = user.GroupID // Привязываем к группе
};
2024-12-23 11:20:09 +00:00
2024-12-23 11:26:41 +00:00
// Добавление пользователя в контекст базы данных
_remoteDatabaseContext.Users.Add(userDao);
// Сохранение изменений в базе данных
_remoteDatabaseContext.SaveChanges();
return true;
}
catch (System.Exception ex)
{
// Логирование ошибки (при необходимости)
Console.WriteLine($"Ошибка при добавлении пользователя: {ex.Message}");
return false;
}
}
// Получение полной информации о пользователе по его GUID, включая информацию о группе
public UserDao GetUserInfo(Guid userGuid)
2024-12-23 11:20:09 +00:00
{
2024-12-23 11:26:41 +00:00
return _remoteDatabaseContext.Users
.Include(u => u.Group) // Включаем информацию о группе
.FirstOrDefault(u => u.Guid == userGuid);
}
2024-12-23 11:20:09 +00:00
2024-12-23 11:26:41 +00:00
// Получение списка пользователей с ФИО
public List<UserDao> GetUserNames()
{
return _remoteDatabaseContext.Users
.Select(u => new UserDao { Guid = u.Guid, FIO = u.FIO })
.ToList();
2024-12-23 11:20:09 +00:00
}
2024-12-23 11:26:41 +00:00
// Получение всех пользователей в виде списка UserDao (для внутреннего использования)
public IEnumerable<RemoteData.DAO.UserDao> GetAllUsersDao => _remoteDatabaseContext.Users.ToList();
// Обновление информации о пользователе
2024-12-23 11:20:09 +00:00
public UserLocalEnity? UpdateUser(UserLocalEnity user)
{
2024-12-23 11:26:41 +00:00
// Поиск существующего пользователя по GUID
2024-12-23 11:20:09 +00:00
var existingUser = _remoteDatabaseContext.Users.FirstOrDefault(u => u.Guid == user.Guid);
2024-12-23 11:26:41 +00:00
// Если пользователь не найден, выбрасываем исключение
2024-12-23 11:20:09 +00:00
if (existingUser == null) throw new UserNotFoundException(user.Guid);
2024-12-23 11:26:41 +00:00
// Обновление информации о пользователе
2024-12-23 11:20:09 +00:00
existingUser.FIO = user.FIO;
existingUser.GroupID = user.GroupID;
2024-12-23 11:26:41 +00:00
// Сохранение изменений в базе данных
_remoteDatabaseContext.SaveChanges();
2024-12-23 11:20:09 +00:00
// Возвращаем обновленный объект UserLocalEnity
return new UserLocalEnity
{
Guid = existingUser.Guid,
FIO = existingUser.FIO,
GroupID = existingUser.GroupID
};
}
2024-12-23 11:26:41 +00:00
// Удаление пользователя по его GUID
public bool RemoveUserByGuid(Guid userGuid)
2024-12-23 11:20:09 +00:00
{
2024-12-23 11:26:41 +00:00
// Поиск пользователя по GUID
var user = _remoteDatabaseContext.Users.FirstOrDefault(u => u.Guid == userGuid);
// Если пользователь не найден, выбрасываем исключение
if (user == null) throw new UserNotFoundException(userGuid);
2024-12-23 11:20:09 +00:00
2024-12-23 11:26:41 +00:00
// Удаление пользователя из контекста
_remoteDatabaseContext.Users.Remove(user);
// Сохранение изменений в базе данных
_remoteDatabaseContext.SaveChanges();
return true;
2024-12-23 11:20:09 +00:00
}
2024-12-23 11:26:41 +00:00
// Получение всех пользователей в виде списка UserLocalEnity
public IEnumerable<UserLocalEnity> GetAllUsers => _remoteDatabaseContext.Users
.Select(u => new UserLocalEnity
2024-12-23 11:20:09 +00:00
{
2024-12-23 11:26:41 +00:00
Guid = u.Guid,
FIO = u.FIO,
GroupID = u.GroupID
})
.ToList();
2024-12-23 11:20:09 +00:00
}
}