166 lines
5.9 KiB
C#
166 lines
5.9 KiB
C#
//using bdGrupoSanchoToro.CompiledModels;
|
|
using bdGrupoSanchoToro.db;
|
|
using bdGrupoSanchoToro.dbcontext;
|
|
using bdGrupoSanchoToro.dbcontext;
|
|
using Castle.Components.DictionaryAdapter.Xml;
|
|
using Microsoft.AspNetCore.Mvc.Formatters;
|
|
using Microsoft.EntityFrameworkCore;
|
|
using Microsoft.Extensions.DependencyInjection;
|
|
using Microsoft.Extensions.Logging;
|
|
using Microsoft.Extensions.Options;
|
|
using System.Reflection.Emit;
|
|
using System.Runtime.CompilerServices;
|
|
using tsEFCore8.Extensiones;
|
|
using tsUtilidades;
|
|
using tsUtilidades.Enumeraciones;
|
|
using tsUtilidades.Extensiones;
|
|
using static System.Net.Mime.MediaTypeNames;
|
|
using Microsoft.Extensions.Hosting;
|
|
|
|
namespace bdGrupoSanchoToro
|
|
{
|
|
public class tscGrupoSanchoToro : bdGrupoSanchoToro.dbcontext.GrupoSanchoToroContext, tsUtilidades.ItsContexto
|
|
|
|
{
|
|
|
|
public static bool Cargado = false;
|
|
private static String? _Ip = null;
|
|
public string? ip
|
|
{
|
|
get
|
|
{
|
|
return _Ip;
|
|
}
|
|
set
|
|
{
|
|
_Ip = value;
|
|
}
|
|
}
|
|
|
|
public string Aplicaciones { get; private set; }
|
|
|
|
|
|
|
|
public static readonly Microsoft.Extensions.Logging.LoggerFactory _myLoggerFactory =
|
|
new LoggerFactory(new[] {
|
|
new Microsoft.Extensions.Logging.Debug.DebugLoggerProvider()
|
|
});
|
|
|
|
private static string? ConexionPorDefecto=null;
|
|
public static tscGrupoSanchoToro NuevoContexto(string NombreConexion = "" ,bool Lazy = true, bool SoloLectura = false, bool ConEventoSavingChanges = false, string aplicaciones = "")
|
|
{
|
|
|
|
|
|
|
|
string? cnx = null;
|
|
if (NombreConexion=="")
|
|
{
|
|
if (ConexionPorDefecto == null) ConexionPorDefecto = Conexion.ObtieneConexionDefecto();
|
|
cnx = ConexionPorDefecto;
|
|
}
|
|
else
|
|
{
|
|
cnx = Conexion.ObtieneConexionDefecto(NombreConexion);
|
|
}
|
|
|
|
var ob = new DbContextOptionsBuilder<GrupoSanchoToroContext>();
|
|
// ob.UseLoggerFactory(_myLoggerFactory);
|
|
// ob.UseInternalServiceProvider(<EnumeracionesService>)
|
|
ob.UseMySql(cnx, Microsoft.EntityFrameworkCore.ServerVersion.Parse("8.0.0-mysql"));
|
|
if (Lazy) ob.UseLazyLoadingProxies();
|
|
if (SoloLectura) ob.UseQueryTrackingBehavior(QueryTrackingBehavior.NoTracking);
|
|
var Opciones = ob.Options;
|
|
tscGrupoSanchoToro bd = new tscGrupoSanchoToro(Opciones);
|
|
bd.Aplicaciones = aplicaciones;
|
|
if (ConEventoSavingChanges) bd.SavingChanges += GuardandoCambios;
|
|
return bd;
|
|
|
|
}
|
|
|
|
//public static Datos.BBDD ObtieneBBDD(string NombreConexion)
|
|
|
|
private static void GuardandoCambios(object? sender, SavingChangesEventArgs e)
|
|
{
|
|
try
|
|
{
|
|
tscGrupoSanchoToro bd = (tscGrupoSanchoToro)sender;
|
|
var lap = bd.Aplicaciones.Split("|");
|
|
foreach (string ap in lap)
|
|
{
|
|
switch (ap.ToLower())
|
|
{
|
|
case "facturas":
|
|
{
|
|
bdGrupoSanchoToro.db.facturas.GuardandoCambios(bd, ap);
|
|
break;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
catch (Exception)
|
|
{
|
|
|
|
throw;
|
|
}
|
|
}
|
|
|
|
public tscGrupoSanchoToro(DbContextOptions<GrupoSanchoToroContext> Opciones) : base(Opciones)
|
|
{
|
|
if (_Ip == null) { ip = tsEFCore8.bbdd.ObtieneIPMysql(this); }
|
|
else { ip = _Ip; }
|
|
}
|
|
|
|
|
|
|
|
public void AñadeObjeto(object Registro)
|
|
{
|
|
this.Add(Registro);
|
|
}
|
|
|
|
public bool CompruebaUnico(EstadosAplicacion estado, string NombreCampo, object Valor, string NombreTablaBase, object DataContext)
|
|
{
|
|
return this.CompruebaRegistroUnico(estado == EstadosAplicacion.ModificandoRegistro, "bdGrupoSanchoToro.db", NombreTablaBase, NombreCampo, Valor, DataContext);
|
|
}
|
|
public void EliminaObjeto(object Registro)
|
|
{
|
|
if (this.Entry(Registro).State == Microsoft.EntityFrameworkCore.EntityState.Detached)
|
|
{
|
|
this.Entry(Registro).State = Microsoft.EntityFrameworkCore.EntityState.Unchanged;
|
|
}
|
|
else if (this.Entry(Registro).State == Microsoft.EntityFrameworkCore.EntityState.Added)
|
|
{
|
|
this.Remove(Registro);
|
|
this.Entry(Registro).State = Microsoft.EntityFrameworkCore.EntityState.Unchanged;
|
|
}
|
|
else
|
|
{
|
|
this.Remove(Registro);
|
|
}
|
|
|
|
}
|
|
|
|
public int GuardarCambios()
|
|
{
|
|
return this.SaveChanges();
|
|
}
|
|
|
|
public bool HayModificaciones()
|
|
{
|
|
return this.ChangeTracker.HasChanges();
|
|
//IEnumerable<Microsoft.EntityFrameworkCore.ChangeTracking.EntityEntry> res = from e in this.ChangeTracker.Entries()
|
|
// where e.State.HasFlag(Microsoft.EntityFrameworkCore.EntityState.Added) ||
|
|
// e.State.HasFlag(Microsoft.EntityFrameworkCore.EntityState.Modified) ||
|
|
// e.State.HasFlag(Microsoft.EntityFrameworkCore.EntityState.Deleted)
|
|
// select e;
|
|
|
|
//if (res.Any())
|
|
// return true;
|
|
//return false;
|
|
}
|
|
public int ObtieneLongitudCampo(string NombreTablaBase, string NombreCampo)
|
|
{
|
|
return this.ObtieneMaximaLongitudCampo("bdGrupoSanchoToro.db", NombreTablaBase, NombreCampo);
|
|
}
|
|
|
|
}
|
|
} |