using System.Text.RegularExpressions; using Entidades; using Microsoft.EntityFrameworkCore; namespace Modelo; public class RepositorioPermisos : RepositorioBase { public IQueryable? ListarPermisos(string email) { var con = Context; Cliente? cli = con.Clientes.Include(x => x.Idgrupos).FirstOrDefault(c => c.Email == email); if (cli == null) return null; var list = con.Clientes .Where(c => c.Dni == cli.Dni) .SelectMany(c => c.Idgrupos) .Include(x => x.Idpermisos); return list; } public bool CheckPermisos(string token, int idpermiso) { //WIP Aca tengo que modificar esto para que haga una busqueda de profundidad para los permisos // var con = Context; bool tienePermiso = false; Cliente? cli = con.Clientes.FirstOrDefault(x => x.Token == token); if (cli == null || cli.Dni == 0) return false; var permisos = con.Clientes .Where(x => x.Dni == cli.Dni) .SelectMany(x => x.Idgrupos) .SelectMany(x => x.Idpermisos) .Distinct(); Parallel.ForEach(permisos, (x, i) => { if (x.Id == idpermiso) { tienePermiso = true; } }); return tienePermiso; } public bool CrearPermiso(Permiso per) { var con = Context; per.Id = con.Permisos.Any() ? con.Permisos.Max(x => x.Id) + 1 : 1; con.Permisos.Add(per); return Guardar(con); } }