125 lines
		
	
	
		
			3.4 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
			
		
		
	
	
			125 lines
		
	
	
		
			3.4 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
| using Hushian.Application.Contracts.Persistence;
 | |
| using Microsoft.EntityFrameworkCore;
 | |
| using System;
 | |
| using System.Collections.Generic;
 | |
| using System.Linq.Expressions;
 | |
| using System.Security.Principal;
 | |
| using System.Text;
 | |
| using System.Threading.Tasks;
 | |
| 
 | |
| namespace Hushian.Persistence.Repositories
 | |
| {
 | |
|     public class GenericRepository<T> : IGenericRepository<T> where T : class
 | |
|     {
 | |
|         private readonly HushianDbContext _context;
 | |
|         private readonly DbSet<T> _query;
 | |
| 
 | |
|         public GenericRepository(HushianDbContext context)
 | |
|         {
 | |
|             _context = context;
 | |
|             _query = _context.Set<T>();
 | |
|         }
 | |
|         public async Task<T?> ADD(T entity)
 | |
|         {
 | |
|             try
 | |
|             {
 | |
|                 await _context.AddAsync(entity);
 | |
|                 if ((await _context.SaveChangesAsync() >= 1))
 | |
|                     return entity;
 | |
| 
 | |
|                 return null;
 | |
|             }
 | |
|             catch (Exception e)
 | |
|             {
 | |
|                 return null;
 | |
|             }
 | |
|         }
 | |
|         public async Task<bool> ADDBool(T entity)
 | |
|         {
 | |
|             await _context.AddAsync(entity);
 | |
|             return (await _context.SaveChangesAsync() == 1);
 | |
|         }
 | |
|         public async Task<ICollection<T>> ADD(ICollection<T> entities)
 | |
|         {
 | |
|             try
 | |
|             {
 | |
|                 await _context.AddRangeAsync(entities);
 | |
|                 if ((await _context.SaveChangesAsync() == entities.Count()))
 | |
|                     return entities;
 | |
| 
 | |
|                 return null;
 | |
|             }
 | |
|             catch (Exception e)
 | |
|             {
 | |
|                 return null;
 | |
|             }
 | |
|         }
 | |
|         public async Task<T?> UPDATE(T entity)
 | |
|         {
 | |
|             try
 | |
|             {
 | |
|                 _context.Entry(entity).State = EntityState.Modified;
 | |
|                 if ((await _context.SaveChangesAsync() == 1))
 | |
|                     return entity;
 | |
|                 return null;
 | |
|             }
 | |
|             catch (Exception e)
 | |
|             {
 | |
|                 return null;
 | |
|             }
 | |
|         }
 | |
|         public async Task<bool> UPDATEBool(T entity)
 | |
|         {
 | |
|             _context.Entry(entity).State = EntityState.Modified;
 | |
|             return (await _context.SaveChangesAsync() == 1);
 | |
|         }
 | |
|         public async Task<ICollection<T>> UPDATE(ICollection<T> entities)
 | |
|         {
 | |
|             try
 | |
|             {
 | |
|                 foreach (var entity in entities)
 | |
|                     _context.Entry(entity).State = EntityState.Modified;
 | |
| 
 | |
|                 if ((await _context.SaveChangesAsync()) == entities.Count())
 | |
|                     return entities;
 | |
|                 return null;
 | |
|             }
 | |
|             catch (Exception e)
 | |
|             {
 | |
|                 return null;
 | |
|             }
 | |
|         }
 | |
|         public async Task<bool> DELETE(T entity)
 | |
|         {
 | |
|             try
 | |
|             {
 | |
|                 _context.Set<T>().Remove(entity);
 | |
|                 return (await _context.SaveChangesAsync() == 1);
 | |
| 
 | |
|             }
 | |
|             catch (Exception e)
 | |
|             {
 | |
|                 return false;
 | |
|             }
 | |
|         }
 | |
|         public async Task<bool> DELETE(ICollection<T> entities)
 | |
|         {
 | |
|             try
 | |
|             {
 | |
|                 _context.Set<T>().RemoveRange(entities);
 | |
|                 return (await _context.SaveChangesAsync() == entities.Count());
 | |
| 
 | |
|             }
 | |
|             catch (Exception e)
 | |
|             {
 | |
|                 return false;
 | |
|             }
 | |
|         }
 | |
|         public IQueryable<T> Get()
 | |
|         {
 | |
|             //No track
 | |
|             return _query.AsNoTracking().AsQueryable();
 | |
|         }
 | |
|     }
 | |
| }
 | 
