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
|
|
|
|
}
|
|
|
|
|
}
|