2024-11-13 09:00:26 +00:00
|
|
|
|
using data.Exception;
|
2024-11-18 12:42:33 +00:00
|
|
|
|
using data.RemoteData.RemoteDataBase.DAO;
|
2024-11-11 09:07:11 +00:00
|
|
|
|
using data.Repository;
|
|
|
|
|
using domain.Models;
|
|
|
|
|
|
|
|
|
|
namespace domain.UseCase
|
|
|
|
|
{
|
|
|
|
|
public class UserUseCase
|
|
|
|
|
{
|
|
|
|
|
private readonly IUserRepository _repositoryUserImpl;
|
|
|
|
|
private readonly IGroupRepository _repositoryGroupImpl;
|
|
|
|
|
|
|
|
|
|
public UserUseCase(IUserRepository repositoryImpl, IGroupRepository repositoryGroupImpl)
|
|
|
|
|
{
|
|
|
|
|
_repositoryUserImpl = repositoryImpl;
|
|
|
|
|
_repositoryGroupImpl = repositoryGroupImpl;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public List<User> GetAllUsers() => _repositoryUserImpl.GetAllUsers
|
|
|
|
|
.Join(_repositoryGroupImpl.GetAllGroup(),
|
|
|
|
|
user => user.GroupID,
|
|
|
|
|
group => group.Id,
|
|
|
|
|
(user, group) =>
|
|
|
|
|
new User
|
|
|
|
|
{
|
|
|
|
|
FIO = user.FIO,
|
|
|
|
|
Guid = user.Guid,
|
|
|
|
|
Group = new Group { Id = group.Id, Name = group.Name }
|
|
|
|
|
}).ToList();
|
|
|
|
|
|
2024-11-13 09:00:26 +00:00
|
|
|
|
public bool RemoveUserByGuid(Guid userGuid)
|
2024-11-11 09:07:11 +00:00
|
|
|
|
{
|
|
|
|
|
try
|
|
|
|
|
{
|
2024-11-13 09:00:26 +00:00
|
|
|
|
return _repositoryUserImpl.RemoveUserByGuid(userGuid);
|
2024-11-11 09:07:11 +00:00
|
|
|
|
}
|
|
|
|
|
catch (UserNotFoundException)
|
|
|
|
|
{
|
|
|
|
|
return false;
|
|
|
|
|
}
|
|
|
|
|
catch (RepositoryException)
|
|
|
|
|
{
|
|
|
|
|
return false;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2024-11-20 09:15:21 +00:00
|
|
|
|
|
2024-11-11 09:07:11 +00:00
|
|
|
|
public User UpdateUser(User user)
|
|
|
|
|
{
|
|
|
|
|
UserLocalEnity userLocalEnity = new UserLocalEnity
|
|
|
|
|
{
|
|
|
|
|
FIO = user.FIO,
|
|
|
|
|
GroupID = user.Group.Id,
|
|
|
|
|
Guid = user.Guid
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
UserLocalEnity? result = _repositoryUserImpl.UpdateUser(userLocalEnity);
|
|
|
|
|
|
|
|
|
|
if (result == null)
|
|
|
|
|
{
|
|
|
|
|
throw new Exception("Ошибка при обновлении пользователя.");
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
var groupEntity = _repositoryGroupImpl.GetAllGroup().FirstOrDefault(g => g.Id == result.GroupID);
|
|
|
|
|
|
|
|
|
|
if (groupEntity == null)
|
|
|
|
|
{
|
|
|
|
|
throw new Exception("Группа не найдена.");
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return new User
|
|
|
|
|
{
|
|
|
|
|
FIO = result.FIO,
|
|
|
|
|
Guid = result.Guid,
|
|
|
|
|
Group = new Group
|
|
|
|
|
{
|
|
|
|
|
Id = groupEntity.Id,
|
|
|
|
|
Name = groupEntity.Name
|
|
|
|
|
}
|
|
|
|
|
};
|
|
|
|
|
}
|
|
|
|
|
|
2024-11-20 09:15:21 +00:00
|
|
|
|
|
2024-11-13 09:00:26 +00:00
|
|
|
|
public User FindUserByGuid(Guid userGuid)
|
2024-11-11 09:07:11 +00:00
|
|
|
|
{
|
|
|
|
|
var user = _repositoryUserImpl.GetAllUsers
|
|
|
|
|
.FirstOrDefault(u => u.Guid == userGuid);
|
|
|
|
|
|
|
|
|
|
if (user == null)
|
|
|
|
|
{
|
|
|
|
|
throw new Exception("Пользователь не найден.");
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
var group = _repositoryGroupImpl.GetAllGroup()
|
|
|
|
|
.FirstOrDefault(g => g.Id == user.GroupID);
|
|
|
|
|
|
|
|
|
|
if (group == null)
|
|
|
|
|
{
|
|
|
|
|
throw new Exception("Группа не найдена.");
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return new User
|
|
|
|
|
{
|
|
|
|
|
FIO = user.FIO,
|
|
|
|
|
Guid = user.Guid,
|
|
|
|
|
Group = new Group { Id = group.Id, Name = group.Name }
|
|
|
|
|
};
|
|
|
|
|
}
|
2024-11-18 12:42:33 +00:00
|
|
|
|
public UserDao GetUserInfo(Guid userGuid)
|
|
|
|
|
{
|
|
|
|
|
return _repositoryUserImpl.GetUserInfo(userGuid);
|
|
|
|
|
}
|
2024-11-20 09:15:21 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
2024-11-11 09:07:11 +00:00
|
|
|
|
}
|
2024-11-20 09:15:21 +00:00
|
|
|
|
|
2024-11-11 09:07:11 +00:00
|
|
|
|
}
|