1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192 |
- using Microsoft.AspNetCore.Identity;
- using Microsoft.EntityFrameworkCore;
- using MTWorkHR.Core.Entities.Base;
- using MTWorkHR.Core.IDto;
- using MTWorkHR.Core.IRepositories;
- using MTWorkHR.Infrastructure.DBContext;
- namespace MTWorkHR.Infrastructure.Repositories
- {
- public class UserRoleRepository : IUserRoleRepository<IdentityUserRole<string>>
- {
- protected readonly HRDataContext context;
- private readonly DbSet<IdentityUserRole<string>> dbSet;
- public UserRoleRepository(HRDataContext _econtext)
- {
- context = _econtext;
- dbSet = context.Set<IdentityUserRole<string>>();
- }
- public virtual async Task<IdentityUserRole<string>> AddAsync(IdentityUserRole<string> entity)
- {
- await dbSet.AddAsync(entity);
- return entity;
- }
- public virtual async Task<IList<IdentityUserRole<string>>> AddRangeAsync(IList<IdentityUserRole<string>> entity)
- {
- try
- {
- await dbSet.AddRangeAsync(entity);
- }catch (Exception x)
- {
- var ss = x.Message;
- }
- return entity;
- }
- public virtual async Task DeleteAsync(IdentityUserRole<string> entity)
- {
- dbSet.Remove(entity);
- }
- public virtual async Task DeleteAsync(IEnumerable<IdentityUserRole<string>> entities)
- {
- dbSet.RemoveRange(entities);
- }
- public virtual async Task<Tuple<ICollection<IdentityUserRole<string>>, int>> GetAllAsync(IPagingInputDto pagingInputDto)
- {
- var query = dbSet.AsQueryable();
- if (pagingInputDto.Filter != null)
- {
- var props = typeof(IdentityUserRole<string>).GetProperties().Where(prop => Attribute.IsDefined(prop, typeof(FilterAttribute)));
- var condition = "";
- foreach (var p in props)
- {
- condition = (condition == "" ? condition : condition + " || ") + p.Name + ".Contains(@0)";
- }
- // query = query.Where(condition, pagingInputDto.Filter);
- }
- //var order = query.OrderBy(pagingInputDto.OrderByField + " " + pagingInputDto.OrderType);
- var page = query.Skip((pagingInputDto.PageNumber * pagingInputDto.PageSize) - pagingInputDto.PageSize).Take(pagingInputDto.PageSize);
- var total = await query.CountAsync();
- return new Tuple<ICollection<IdentityUserRole<string>>, int>(await page.ToListAsync(), total);
- }
- public virtual async Task<IdentityUserRole<string>> GetByIdAsync(long id)
- {
- return await context.Set<IdentityUserRole<string>>().FindAsync(id);
- }
- public async Task<string[]> GetUserRoleIdsByUserID(string id)
- {
- return await dbSet.AsQueryable()
- .Where(x => x.UserId == id).Select(x => x.RoleId).ToArrayAsync();
- }
- public async Task<List<IdentityUserRole<string>>> GetRemovedUserRoleIdsByUserID(string id, string[] rolesIds)
- {
- return await dbSet.AsQueryable()
- .Where(x => x.UserId == id && !rolesIds.Contains(x.RoleId)).ToListAsync();
- }
-
- }
- }
|