2024-08-13 12:29:01 +01:00
|
|
|
|
using API.Models;
|
|
|
|
|
using Microsoft.EntityFrameworkCore;
|
2024-09-11 14:34:03 +01:00
|
|
|
|
using Microsoft.EntityFrameworkCore.Internal;
|
2024-08-14 09:28:12 +01:00
|
|
|
|
using Microsoft.VisualStudio.Web.CodeGenerators.Mvc.Templates.BlazorIdentity.Pages;
|
2024-08-13 12:29:01 +01:00
|
|
|
|
|
|
|
|
|
namespace API.Persistence.Repositories
|
|
|
|
|
{
|
|
|
|
|
public class UserRepository(AppDBContext context) : IUserRepository
|
|
|
|
|
{
|
|
|
|
|
private readonly AppDBContext _context = context;
|
2024-08-29 12:25:02 +01:00
|
|
|
|
|
2024-08-13 12:29:01 +01:00
|
|
|
|
public async Task<List<User>> QueryAllUsersAsync()
|
|
|
|
|
{
|
|
|
|
|
return await _context.Users.ToListAsync();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public async Task<User> QueryUserByIdAsync(string id)
|
|
|
|
|
{
|
|
|
|
|
try
|
|
|
|
|
{
|
2024-08-29 12:25:02 +01:00
|
|
|
|
return await _context.Users.FirstOrDefaultAsync(user => user.Id == id);
|
2024-08-13 12:29:01 +01:00
|
|
|
|
}
|
|
|
|
|
catch (Exception)
|
|
|
|
|
{
|
|
|
|
|
return new User();
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2024-09-11 14:34:03 +01:00
|
|
|
|
public async Task<List<User>> QueryUsersByIdsAsync(List<string> ids)
|
|
|
|
|
{
|
|
|
|
|
try
|
|
|
|
|
{
|
|
|
|
|
return _context.Users.Where(user => ids.Contains(user.Id)).ToList();
|
|
|
|
|
}
|
|
|
|
|
catch (Exception)
|
|
|
|
|
{
|
|
|
|
|
return [];
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2024-08-13 12:29:01 +01:00
|
|
|
|
public async Task<string> CreateUserAsync(User user)
|
|
|
|
|
{
|
|
|
|
|
try
|
|
|
|
|
{
|
|
|
|
|
_context.Users.Add(user);
|
|
|
|
|
await _context.SaveChangesAsync();
|
|
|
|
|
}
|
|
|
|
|
catch (Exception)
|
|
|
|
|
{
|
|
|
|
|
return "";
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return user.Id;
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public async Task<bool> UpdateUserAsync(User user)
|
|
|
|
|
{
|
|
|
|
|
try
|
|
|
|
|
{
|
|
|
|
|
_context.Entry(user).State = EntityState.Modified;
|
|
|
|
|
await _context.SaveChangesAsync();
|
|
|
|
|
}
|
|
|
|
|
catch (Exception)
|
|
|
|
|
{
|
|
|
|
|
return false;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return true;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public async Task<bool> DeleteUserAsync(string id)
|
|
|
|
|
{
|
|
|
|
|
var user = await _context.Users.FindAsync(id);
|
|
|
|
|
if (user == null)
|
|
|
|
|
{
|
|
|
|
|
return false;
|
|
|
|
|
}
|
|
|
|
|
_context.Users.Remove(user);
|
|
|
|
|
await _context.SaveChangesAsync();
|
|
|
|
|
|
|
|
|
|
return true;
|
|
|
|
|
}
|
|
|
|
|
|
2024-08-14 09:28:12 +01:00
|
|
|
|
public async Task<User> QueryUserByEmailAsync(string email)
|
|
|
|
|
{
|
|
|
|
|
return await _context.Users.SingleOrDefaultAsync(u => u.Email == email);
|
2024-08-29 12:25:02 +01:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public async Task<User> QueryUserByRefreshTokenAsync(string refreshToken)
|
|
|
|
|
{
|
|
|
|
|
return await _context.Users.SingleOrDefaultAsync(u => u.RefreshToken == refreshToken);
|
2024-08-14 09:28:12 +01:00
|
|
|
|
}
|
2024-09-02 12:14:13 +01:00
|
|
|
|
|
|
|
|
|
public void Save()
|
|
|
|
|
{
|
|
|
|
|
_context.SaveChanges();
|
|
|
|
|
}
|
2024-08-13 12:29:01 +01:00
|
|
|
|
}
|
|
|
|
|
}
|