980 lines
53 KiB
C#
980 lines
53 KiB
C#
|
|
using System;
|
|
using System.Collections.Generic;
|
|
using System.Linq;
|
|
using Exferia_Aplicacion.General;
|
|
using Exferia_KairosPRO._1_Modelos;
|
|
using Exferia_KairosPRO._1_Modelos.Herencia.Capas;
|
|
using Exferia_KairosPRO_EF;
|
|
using System.Transactions;
|
|
using static Exferia_Aplicacion.General.Enumerados;
|
|
using System.Data.SqlClient;
|
|
using System.Threading;
|
|
|
|
namespace Exferia_KairosPRO._2_Datos
|
|
{
|
|
public class KRS_Terminales_Datos : ABS_Datos
|
|
{
|
|
#region Listado
|
|
private List<INTERNO_KRS_Terminales_Listado_Modelo> g_lst_INTERNO_KRS_Terminales_Listado_Modelo = null;
|
|
|
|
public override List<dynamic> Obtener_Listado(List<string> _lst_CamposConRelacionABuscar, List<INTERNO_Filtro_OpcionPadre_Modelo> _lst_INTERNO_Filtro_OpcionPadre_Modelo, List<INTERNO_Filtro_Modelo> _lst_INTERNO_Filtro_Modelo)
|
|
{
|
|
KairosProEntities obj_KairosProEntities = null;
|
|
List<dynamic> lst_KRS = null;
|
|
|
|
try
|
|
{
|
|
obj_KairosProEntities = new KairosProEntities();
|
|
obj_KairosProEntities.Configuration.LazyLoadingEnabled = false;
|
|
|
|
//Consulta.................................................................
|
|
ConsultaRellenar_Listado(obj_KairosProEntities, _lst_CamposConRelacionABuscar, -1, null, _lst_INTERNO_Filtro_OpcionPadre_Modelo, _lst_INTERNO_Filtro_Modelo);
|
|
//........................................................................
|
|
|
|
if ((g_lst_INTERNO_KRS_Terminales_Listado_Modelo != null) && (g_lst_INTERNO_KRS_Terminales_Listado_Modelo.Count() > 0))
|
|
{
|
|
lst_KRS = g_lst_INTERNO_KRS_Terminales_Listado_Modelo.Cast<dynamic>().ToList();
|
|
}
|
|
}
|
|
catch (Control_Errores)
|
|
{
|
|
throw;
|
|
}
|
|
catch (Exception ex)
|
|
{
|
|
throw new Control_Errores("", ex, nameof(KRS_Terminales_Datos) + "/" + nameof(Obtener_Listado), true);
|
|
}
|
|
finally
|
|
{
|
|
obj_KairosProEntities.Database.Connection.Close();
|
|
obj_KairosProEntities.Dispose();
|
|
}
|
|
|
|
return lst_KRS;
|
|
}
|
|
public override dynamic Obtener_RegistroListado(List<string> _lst_CamposConRelacionABuscar, List<INTERNO_Filtro_OpcionPadre_Modelo> _lst_INTERNO_Filtro_OpcionPadre_Modelo, List<INTERNO_Filtro_Modelo> _lst_INTERNO_Filtro_Modelo, long _lng_id, List<long> _lst_id)
|
|
{
|
|
KairosProEntities obj_KairosProEntities = null;
|
|
dynamic dnm_KRS = null;
|
|
|
|
try
|
|
{
|
|
obj_KairosProEntities = new KairosProEntities();
|
|
obj_KairosProEntities.Configuration.LazyLoadingEnabled = false;
|
|
|
|
//Consulta ......................................................
|
|
ConsultaRellenar_Listado(obj_KairosProEntities, _lst_CamposConRelacionABuscar, _lng_id, _lst_id, _lst_INTERNO_Filtro_OpcionPadre_Modelo, _lst_INTERNO_Filtro_Modelo);
|
|
//...............................................................
|
|
|
|
if ((g_lst_INTERNO_KRS_Terminales_Listado_Modelo != null) && (g_lst_INTERNO_KRS_Terminales_Listado_Modelo.Count() > 0))
|
|
{
|
|
dnm_KRS = g_lst_INTERNO_KRS_Terminales_Listado_Modelo.Cast<dynamic>().ToList();
|
|
}
|
|
}
|
|
catch (Control_Errores)
|
|
{
|
|
throw;
|
|
}
|
|
catch (Exception ex)
|
|
{
|
|
throw new Control_Errores("", ex, nameof(KRS_Terminales_Datos) + "/" + nameof(Obtener_RegistroListado), true);
|
|
}
|
|
finally
|
|
{
|
|
obj_KairosProEntities.Database.Connection.Close();
|
|
obj_KairosProEntities.Dispose();
|
|
}
|
|
return dnm_KRS;
|
|
}
|
|
|
|
protected override void ConsultaRellenar_Listado(KairosProEntities _obj_KairosProEntities, List<string> _lst_CamposConRelacionABuscar, long _lng_id, List<long> _lst_id, List<INTERNO_Filtro_OpcionPadre_Modelo> _lst_INTERNO_Filtro_OpcionPadre_Modelo, List<INTERNO_Filtro_Modelo> _lst_INTERNO_Filtro_Modelo)
|
|
{
|
|
try
|
|
{
|
|
//Datos del Padre si los tuviera .........................
|
|
long lng_Padre_id = -1;
|
|
string str_Padre_Opcion = "";
|
|
if (_lst_INTERNO_Filtro_OpcionPadre_Modelo != null && _lst_INTERNO_Filtro_OpcionPadre_Modelo.Count > 0)
|
|
{
|
|
lng_Padre_id = _lst_INTERNO_Filtro_OpcionPadre_Modelo[0].VALOR;
|
|
str_Padre_Opcion = _lst_INTERNO_Filtro_OpcionPadre_Modelo[0].NOMBRE_CAMPO;
|
|
}
|
|
|
|
string str_SQL =
|
|
" SELECT " +
|
|
nameof(INTERNO_KRS_Terminales_Listado_Modelo.id) + " = " + nameof(KRS_Terminales) + "." + nameof(KRS_Terminales.id) + "," +
|
|
nameof(INTERNO_KRS_Terminales_Listado_Modelo.codigoCliente) + " = " + nameof(KRS_Terminales) + "." + nameof(KRS_Terminales.codigoCliente) + "," +
|
|
nameof(INTERNO_KRS_Terminales_Listado_Modelo.codigo) + " = " + nameof(KRS_Terminales) + "." + nameof(KRS_Terminales.codigo) + "," +
|
|
nameof(INTERNO_KRS_Terminales_Listado_Modelo.descripcion) + " = " + nameof(KRS_Terminales) + "." + nameof(KRS_Terminales.descripcion) + "," +
|
|
nameof(INTERNO_KRS_Terminales_Listado_Modelo.idDepartamento) + " = " + nameof(KRS_Terminales) + "." + nameof(KRS_Terminales.idDepartamento) + "," +
|
|
nameof(INTERNO_KRS_Terminales_Listado_Modelo.tipoDispositivo) + " = " + nameof(KRS_Terminales) + "." + nameof(KRS_Terminales.tipoDispositivo) +
|
|
" FROM " + nameof(KRS_Terminales) +
|
|
" WHERE " +
|
|
nameof(KRS_Terminales) + "." + nameof(KRS_Terminales.fechaBorrado) + " IS null AND " +
|
|
nameof(KRS_Terminales) + "." + nameof(KRS_Terminales.codigoCliente) + "=@codigoCliente AND " +
|
|
(_lng_id > -1 ? (nameof(KRS_Terminales) + "." + nameof(KRS_Terminales.id) + "=@id") : " 1 = 1 ");
|
|
|
|
//Parametros
|
|
object[] arr_Parametros = new object[]
|
|
{
|
|
new SqlParameter("@id", _lng_id),
|
|
new SqlParameter("@codigoCliente", Variables.G_LNG_IDCLIENTE_LICENCIAVALIDADO)
|
|
};
|
|
|
|
//Rellenar el Modelo
|
|
g_lst_INTERNO_KRS_Terminales_Listado_Modelo = _obj_KairosProEntities.Database.SqlQuery<INTERNO_KRS_Terminales_Listado_Modelo>(str_SQL, arr_Parametros).ToList();
|
|
|
|
}
|
|
catch (Control_Errores)
|
|
{
|
|
throw;
|
|
}
|
|
catch (Exception ex)
|
|
{
|
|
throw new Control_Errores("", ex, nameof(KRS_Terminales_Datos) + "/" + nameof(ConsultaRellenar_Listado), true);
|
|
}
|
|
}
|
|
|
|
#endregion
|
|
|
|
#region Listado Secundario
|
|
public override List<dynamic> Obtener_Listado_Secundario(List<string> _lst_CamposConRelacionABuscar, List<INTERNO_Filtro_OpcionPadre_Modelo> _lst_INTERNO_Filtro_OpcionPadre_Modelo, List<INTERNO_Filtro_Modelo> _lst_INTERNO_Filtro_Modelo)
|
|
{
|
|
return null;
|
|
}
|
|
public override dynamic Obtener_RegistroListado_Secundario(List<string> _lst_CamposConRelacionABuscar, List<INTERNO_Filtro_OpcionPadre_Modelo> _lst_INTERNO_Filtro_OpcionPadre_Modelo, List<INTERNO_Filtro_Modelo> _lst_INTERNO_Filtro_Modelo, long _lng_id, List<long> _lst_id)
|
|
{
|
|
return null;
|
|
}
|
|
protected override void ConsultaRellenar_Listado_Secundario(KairosProEntities _dbcontext, List<string> _lst_CamposConRelacionABuscar, long _lng_id, List<long> _lst_id, List<INTERNO_Filtro_OpcionPadre_Modelo> _lst_INTERNO_Filtro_OpcionPadre_Modelo, List<INTERNO_Filtro_Modelo> _lst_INTERNO_Filtro_Modelo)
|
|
{
|
|
|
|
}
|
|
|
|
#endregion
|
|
|
|
#region F3
|
|
private INTERNO_KRS_Terminales_Listado_Modelo g_mdl_INTERNO_KRS_Terminales_Listado_Modelo_F3 = null;
|
|
|
|
public override dynamic Obtener_F3(string _str_filtro, string _str_CampoBusqueda, List<INTERNO_Filtro_OpcionPadre_Modelo> _lst_INTERNO_Filtro_OpcionPadre_Modelo, List<INTERNO_Filtro_Modelo> _lst_INTERNO_Filtro_Modelo)
|
|
{
|
|
KairosProEntities obj_KairosProEntities = null;
|
|
dynamic dnm_KRS = null;
|
|
|
|
try
|
|
{
|
|
obj_KairosProEntities = new KairosProEntities();
|
|
obj_KairosProEntities.Configuration.LazyLoadingEnabled = false;
|
|
|
|
//Consulta .....................................................
|
|
ConsultaRellenar_F3(obj_KairosProEntities, _str_CampoBusqueda, _str_filtro, -1, _lst_INTERNO_Filtro_OpcionPadre_Modelo, _lst_INTERNO_Filtro_Modelo);
|
|
//..............................................................
|
|
|
|
if (g_mdl_INTERNO_KRS_Terminales_Listado_Modelo_F3 != null)
|
|
{
|
|
dnm_KRS = g_mdl_INTERNO_KRS_Terminales_Listado_Modelo_F3;
|
|
}
|
|
}
|
|
catch (Control_Errores)
|
|
{
|
|
throw;
|
|
}
|
|
catch (Exception ex)
|
|
{
|
|
throw new Control_Errores("", ex, nameof(KRS_Terminales_Datos) + "/" + nameof(Obtener_F3), true);
|
|
}
|
|
finally
|
|
{
|
|
obj_KairosProEntities.Database.Connection.Close();
|
|
obj_KairosProEntities.Dispose();
|
|
}
|
|
return dnm_KRS;
|
|
}
|
|
public override dynamic Obtener_F3_PorId(long _lng_id, List<INTERNO_Filtro_OpcionPadre_Modelo> _lst_INTERNO_Filtro_OpcionPadre_Modelo, List<INTERNO_Filtro_Modelo> _lst_INTERNO_Filtro_Modelo)
|
|
{
|
|
KairosProEntities obj_KairosProEntities = null;
|
|
dynamic dnm_KRS = null;
|
|
|
|
try
|
|
{
|
|
obj_KairosProEntities = new KairosProEntities();
|
|
obj_KairosProEntities.Configuration.LazyLoadingEnabled = false;
|
|
|
|
//Consulta .....................................................
|
|
ConsultaRellenar_F3(obj_KairosProEntities, "", "", _lng_id, _lst_INTERNO_Filtro_OpcionPadre_Modelo, _lst_INTERNO_Filtro_Modelo);
|
|
//..............................................................
|
|
|
|
if (g_mdl_INTERNO_KRS_Terminales_Listado_Modelo_F3 != null)
|
|
{
|
|
dnm_KRS = g_mdl_INTERNO_KRS_Terminales_Listado_Modelo_F3;
|
|
}
|
|
}
|
|
catch (Control_Errores)
|
|
{
|
|
throw;
|
|
}
|
|
catch (Exception ex)
|
|
{
|
|
throw new Control_Errores("", ex, nameof(KRS_Terminales_Datos) + "/" + nameof(Obtener_F3_PorId), true);
|
|
}
|
|
finally
|
|
{
|
|
obj_KairosProEntities.Database.Connection.Close();
|
|
obj_KairosProEntities.Dispose();
|
|
}
|
|
return dnm_KRS;
|
|
}
|
|
|
|
protected override void ConsultaRellenar_F3(KairosProEntities _obj_KairosProEntities, string _str_CampoBusqueda, string _str_Filtro, long _lng_id, List<INTERNO_Filtro_OpcionPadre_Modelo> _lst_INTERNO_Filtro_OpcionPadre_Modelo, List<INTERNO_Filtro_Modelo> _lst_INTERNO_Filtro_Modelo)
|
|
{
|
|
try
|
|
{
|
|
string str_SQL =
|
|
" SELECT distinct " +
|
|
nameof(INTERNO_KRS_Terminales_Listado_Modelo.id) + " = " + nameof(KRS_Terminales) + "." + nameof(KRS_Terminales.id) + "," +
|
|
nameof(INTERNO_KRS_Terminales_Listado_Modelo.codigoCliente) + " = " + nameof(KRS_Terminales) + "." + nameof(KRS_Terminales.codigoCliente) + "," +
|
|
nameof(INTERNO_KRS_Terminales_Listado_Modelo.codigo) + " = " + nameof(KRS_Terminales) + "." + nameof(KRS_Terminales.codigo) + "," +
|
|
nameof(INTERNO_KRS_Terminales_Listado_Modelo.descripcion) + " = " + nameof(KRS_Terminales) + "." + nameof(KRS_Terminales.descripcion) + "," +
|
|
nameof(INTERNO_KRS_Terminales_Listado_Modelo.idDepartamento) + " = " + nameof(KRS_Terminales) + "." + nameof(KRS_Terminales.idDepartamento) + "," +
|
|
nameof(INTERNO_KRS_Terminales_Listado_Modelo.tipoDispositivo) + " = " + nameof(KRS_Terminales) + "." + nameof(KRS_Terminales.tipoDispositivo) +
|
|
" FROM " + nameof(KRS_Terminales) +
|
|
" WHERE " +
|
|
nameof(KRS_Terminales.fechaBorrado) + " IS null AND " +
|
|
nameof(KRS_Terminales.codigoCliente) + "=@codigoCliente AND " +
|
|
(
|
|
_lng_id > -1
|
|
? (nameof(KRS_Terminales.id) + " = " + _lng_id)
|
|
:
|
|
(
|
|
//Filtrar por Codigo
|
|
(_str_CampoBusqueda.Equals(nameof(KRS_Terminales.codigo)))
|
|
? (nameof(KRS_Terminales.codigo) + "=@Filtro")
|
|
//Filtrar por Descripcion
|
|
: (nameof(KRS_Terminales.descripcion) + "=@Filtro")
|
|
)
|
|
);
|
|
|
|
//Parametros
|
|
object[] arr_Parametros = new object[]
|
|
{
|
|
new SqlParameter("@codigoCliente", Variables.G_LNG_IDCLIENTE_LICENCIAVALIDADO),
|
|
new SqlParameter("@Filtro", _str_Filtro)
|
|
};
|
|
|
|
//Rellenar el Modelo
|
|
g_mdl_INTERNO_KRS_Terminales_Listado_Modelo_F3 = _obj_KairosProEntities.Database.SqlQuery<INTERNO_KRS_Terminales_Listado_Modelo>(str_SQL, arr_Parametros).FirstOrDefault();
|
|
|
|
}
|
|
catch (Control_Errores)
|
|
{
|
|
throw;
|
|
}
|
|
catch (Exception ex)
|
|
{
|
|
throw new Control_Errores("", ex, nameof(KRS_Terminales_Datos) + "/" + nameof(ConsultaRellenar_F3), true);
|
|
}
|
|
}
|
|
#endregion
|
|
|
|
#region Obtener
|
|
|
|
#region Obtener Simple
|
|
private static int g_int_TotalHilos_Obtener = 2;
|
|
private bool[] g_bol_Hilos_Terminados_Obtener = new bool[g_int_TotalHilos_Obtener];
|
|
|
|
private dynamic g_dnm_Modelo_Obtener = null;
|
|
public override dynamic Obtener(long _lng_id)
|
|
{
|
|
KairosProEntities obj_KairosProEntities = null;
|
|
|
|
try
|
|
{
|
|
obj_KairosProEntities = new KairosProEntities();
|
|
obj_KairosProEntities.Configuration.LazyLoadingEnabled = false;
|
|
|
|
string str_SQL =
|
|
" SELECT " +
|
|
nameof(KRS_Terminales) + "." + nameof(KRS_Terminales.id) + "," +
|
|
nameof(KRS_Terminales) + "." + nameof(KRS_Terminales.codigoCliente) + "," +
|
|
nameof(KRS_Terminales) + "." + nameof(KRS_Terminales.codigo) + "," +
|
|
nameof(KRS_Terminales) + "." + nameof(KRS_Terminales.descripcion) + "," +
|
|
nameof(KRS_Terminales) + "." + nameof(KRS_Terminales.tipoDispositivo) + "," +
|
|
nameof(KRS_Terminales) + "." + nameof(KRS_Terminales.idDepartamento) + "," +
|
|
nameof(KRS_Terminales) + "." + nameof(KRS_Terminales.fechaActualizacion) + "," +
|
|
nameof(KRS_Terminales) + "." + nameof(KRS_Terminales.fechaBorrado) + "," +
|
|
nameof(KRS_Terminales) + "." + nameof(KRS_Terminales.dispositivoHuellaDactilar) + "," +
|
|
nameof(KRS_Terminales) + "." + nameof(KRS_Terminales.dispositivoHuellaDactilar_Numero) + "," +
|
|
nameof(KRS_Terminales) + "." + nameof(KRS_Terminales.dispositivoHuellaDactilar_IP) + "," +
|
|
nameof(KRS_Terminales) + "." + nameof(KRS_Terminales.dispositivoHuellaDactilar_Marca) + "," +
|
|
nameof(KRS_Terminales) + "." + nameof(KRS_Terminales.dispositivoHuellaDactilarModelo) + "," +
|
|
nameof(KRS_Terminales) + "." + nameof(KRS_Terminales.dispositivoHuellaDactilar_Firmware) + "," +
|
|
nameof(KRS_Terminales) + "." + nameof(KRS_Terminales.dispositivoHuellaDactilar_Puerto) + "," +
|
|
nameof(KRS_Terminales) + "." + nameof(KRS_Terminales.dispositivoHuellaDactilar_DNS) +
|
|
" FROM " + nameof(KRS_Terminales) +
|
|
" WHERE " + nameof(KRS_Terminales) + "." + nameof(KRS_Terminales.fechaBorrado) + " IS null AND " +
|
|
nameof(KRS_Terminales) + "." + nameof(KRS_Terminales.id) + "=@id and " +
|
|
nameof(KRS_Terminales) + "." + nameof(KRS_Terminales.codigoCliente) + "=@codigoCliente ";
|
|
|
|
//Parametros
|
|
object[] arr_Parametros = new object[]
|
|
{
|
|
new SqlParameter("@id", _lng_id),
|
|
new SqlParameter("@codigoCliente", Variables.G_LNG_IDCLIENTE_LICENCIAVALIDADO)
|
|
};
|
|
|
|
//Rellenar el Modelo
|
|
g_dnm_Modelo_Obtener = obj_KairosProEntities.Database.SqlQuery<KRS_Terminales>(str_SQL, arr_Parametros).FirstOrDefault();
|
|
|
|
#region Rellenar tablas Relacionadas
|
|
if (g_dnm_Modelo_Obtener != null)
|
|
{
|
|
//reiniciar Valores de los hilos
|
|
for (int int_Contador = 0; int_Contador < g_int_TotalHilos_Obtener; int_Contador++)
|
|
{
|
|
g_bol_Hilos_Terminados_Obtener[int_Contador] = false;
|
|
}
|
|
|
|
//KRS_Terminales_ClavesTemporales ##########################################################################################
|
|
ThreadStart obj_ThreadStart_TERMINALESCLAVESTEMPORALES = new ThreadStart(Obtener_TerminalesClavesTemporales_Modelo_Obtener);
|
|
Thread obj_Thread_TERMINALESCLAVESTEMPORALES = new Thread(obj_ThreadStart_TERMINALESCLAVESTEMPORALES);
|
|
obj_Thread_TERMINALESCLAVESTEMPORALES.Start();
|
|
|
|
//KRS_Terminales_CodigosDispositivosBiometricos ##########################################################################################
|
|
ThreadStart obj_ThreadStart_TERMINALESCODIGOSDISPOSITIVOSBIOMETRICOS = new ThreadStart(Obtener_CodigosDispositivosBiometricos_Modelo_Obtener);
|
|
Thread obj_Thread_TERMINALESCODIGOSDISPOSITIVOSBIOMETRICOS = new Thread(obj_ThreadStart_TERMINALESCODIGOSDISPOSITIVOSBIOMETRICOS);
|
|
obj_Thread_TERMINALESCODIGOSDISPOSITIVOSBIOMETRICOS.Start();
|
|
|
|
//Esperando a que terminen todos los hilos .........................................
|
|
bool bol_Termino = false;
|
|
while (bol_Termino == false)
|
|
{
|
|
bol_Termino = true;
|
|
foreach (bool bol_Termino_Hilo in g_bol_Hilos_Terminados_Obtener)
|
|
{
|
|
if (bol_Termino_Hilo == false)
|
|
{
|
|
bol_Termino = false;
|
|
break;
|
|
}
|
|
}
|
|
|
|
Thread.Sleep(10);
|
|
}
|
|
//.................................................................................
|
|
}
|
|
#endregion
|
|
}
|
|
catch (Exception ex)
|
|
{
|
|
throw new Control_Errores("", ex, nameof(KRS_Terminales_Datos) + "/" + nameof(Obtener), true);
|
|
}
|
|
finally
|
|
{
|
|
obj_KairosProEntities.Database.Connection.Close();
|
|
obj_KairosProEntities.Dispose();
|
|
}
|
|
return g_dnm_Modelo_Obtener;
|
|
}
|
|
#region Tablas Relacionadas
|
|
private void Obtener_TerminalesClavesTemporales_Modelo_Obtener()
|
|
{
|
|
try
|
|
{
|
|
KRS_Terminales_ClavesTemporales_Datos obj_KRS_Terminales_ClavesTemporales_Datos = new KRS_Terminales_ClavesTemporales_Datos();
|
|
g_dnm_Modelo_Obtener.KRS_Terminales_ClavesTemporales = obj_KRS_Terminales_ClavesTemporales_Datos.Obtener_Listado_PorTerminal(g_dnm_Modelo_Obtener.id, false);
|
|
}
|
|
catch (Control_Errores)
|
|
{ }
|
|
finally
|
|
{
|
|
g_bol_Hilos_Terminados_Obtener[0] = true;
|
|
}
|
|
}
|
|
private void Obtener_CodigosDispositivosBiometricos_Modelo_Obtener()
|
|
{
|
|
try
|
|
{
|
|
KRS_Terminales_CodigosDispositivosBiometricos_Datos obj_KRS_Terminales_CodigosDispositivosBiometricos_Datos = new KRS_Terminales_CodigosDispositivosBiometricos_Datos();
|
|
g_dnm_Modelo_Obtener.KRS_Terminales_CodigosDispositivosBiometricos = obj_KRS_Terminales_CodigosDispositivosBiometricos_Datos.Obtener_ModeloListado_Por_Terminal(g_dnm_Modelo_Obtener.id);
|
|
}
|
|
catch (Control_Errores)
|
|
{ }
|
|
finally
|
|
{
|
|
g_bol_Hilos_Terminados_Obtener[1] = true;
|
|
}
|
|
}
|
|
#endregion
|
|
|
|
#endregion
|
|
public override dynamic Obtener_Registro_PorCampo(string _str_CampoBusqueda, string _str_Filtro)
|
|
{
|
|
throw new NotImplementedException();
|
|
}
|
|
|
|
#endregion
|
|
|
|
#region MODELOS
|
|
|
|
#region Modelo Simple
|
|
private KRS_Terminales g_mdl_KRS_Terminales = null;
|
|
public KRS_Terminales Obtener_Modelo_Por_Id(long _lng_id, long _lng_CodigoCliente)
|
|
{
|
|
try
|
|
{
|
|
string str_SQL = Obtener_Consulta_Modelo() +
|
|
//WHERE
|
|
" WHERE " +
|
|
nameof(KRS_Terminales) + "." + nameof(KRS_Terminales.id) + "=@id and " +
|
|
nameof(KRS_Terminales) + "." + nameof(KRS_Terminales.codigoCliente) + "=@codigoCliente ";
|
|
|
|
//Parametros
|
|
object[] arr_Parametros = new object[]
|
|
{
|
|
new SqlParameter("@id", _lng_id),
|
|
new SqlParameter("@codigoCliente", _lng_CodigoCliente)
|
|
};
|
|
|
|
//Ejecutar y rellenar el modelo
|
|
Ejecutar_Consulta_Modelo(str_SQL,
|
|
arr_Parametros);
|
|
}
|
|
catch (Control_Errores)
|
|
{
|
|
throw;
|
|
}
|
|
catch (Exception ex)
|
|
{
|
|
throw new Control_Errores("", ex, nameof(KRS_Terminales_Datos) + "/" + nameof(Obtener_Modelo_Por_Id), true);
|
|
}
|
|
|
|
return g_mdl_KRS_Terminales;
|
|
}
|
|
|
|
private void Ejecutar_Consulta_Modelo(string _str_SQL,
|
|
object[] _arr_Parametros)
|
|
{
|
|
KairosProEntities obj_KairosProEntities = null;
|
|
|
|
try
|
|
{
|
|
//Conexion
|
|
obj_KairosProEntities = new KairosProEntities();
|
|
obj_KairosProEntities.Configuration.LazyLoadingEnabled = false;
|
|
|
|
//Rellenar el Modelo
|
|
g_mdl_KRS_Terminales = obj_KairosProEntities.Database.SqlQuery<KRS_Terminales>(_str_SQL, _arr_Parametros).FirstOrDefault();
|
|
}
|
|
catch (Control_Errores)
|
|
{
|
|
throw;
|
|
}
|
|
catch (Exception ex)
|
|
{
|
|
throw new Control_Errores("", ex, nameof(KRS_Terminales_Datos) + "/" + nameof(Ejecutar_Consulta_Modelo), true);
|
|
}
|
|
finally
|
|
{
|
|
obj_KairosProEntities.Database.Connection.Close();
|
|
obj_KairosProEntities.Dispose();
|
|
}
|
|
}
|
|
|
|
#endregion
|
|
|
|
#region Modelo Listado
|
|
private List<KRS_Terminales> g_lst_KRS_Terminales = null;
|
|
|
|
public List<KRS_Terminales> Obtener_ModeloListado_HuellaDactilar()
|
|
{
|
|
try
|
|
{
|
|
List<SqlParameter> lst_Parametros = new List<SqlParameter>();
|
|
|
|
//Consulta
|
|
string str_SQL = Obtener_Consulta_Modelo() +
|
|
//WHERE
|
|
" WHERE " +
|
|
nameof(KRS_Terminales) + "." + nameof(KRS_Terminales.fechaBorrado) + " is null and " +
|
|
nameof(KRS_Terminales) + "." + nameof(KRS_Terminales.codigoCliente) + "=@codigoCliente and " +
|
|
nameof(KRS_Terminales) + "." + nameof(KRS_Terminales.dispositivoHuellaDactilar) + "=@dispositivoHuellaDactilar ";
|
|
|
|
//Parametros
|
|
lst_Parametros.Add(new SqlParameter("@codigoCliente", Variables.G_LNG_IDCLIENTE_LICENCIAVALIDADO));
|
|
lst_Parametros.Add(new SqlParameter("@dispositivoHuellaDactilar", true));
|
|
object[] arr_Parametros = lst_Parametros.ToArray();
|
|
|
|
//Ejecutar y rellenar el listado
|
|
Ejecutar_Consulta_Modelo_Listado(str_SQL,
|
|
arr_Parametros);
|
|
|
|
}
|
|
catch (Control_Errores)
|
|
{
|
|
throw;
|
|
}
|
|
catch (Exception ex)
|
|
{
|
|
throw new Control_Errores("", ex, nameof(KRS_Terminales_Datos) + "/" + nameof(Obtener_ModeloListado_HuellaDactilar), true);
|
|
}
|
|
|
|
return g_lst_KRS_Terminales;
|
|
}
|
|
|
|
public List<KRS_Terminales> Obtener_ModeloListado_Por_Ids(List<long> _lst_Ids)
|
|
{
|
|
try
|
|
{
|
|
|
|
if (_lst_Ids != null && _lst_Ids.Count > 0)
|
|
{
|
|
List<SqlParameter> lst_Parametros = new List<SqlParameter>();
|
|
|
|
string str_Filtros_IDS = Funciones.Formar_ContenidoIN_ParaConsultaWhere(nameof(KRS_Terminales),
|
|
nameof(KRS_Terminales.id),
|
|
G_ENUM_FORMARCONTENIDOIN_CONDICIONANTES.NADA,
|
|
_lst_Ids);
|
|
|
|
|
|
//Consulta
|
|
string str_SQL = Obtener_Consulta_Modelo() +
|
|
//WHERE
|
|
" WHERE " +
|
|
nameof(KRS_Terminales) + "." + nameof(KRS_Terminales.codigoCliente) + "=@codigoCliente and " +
|
|
str_Filtros_IDS;
|
|
|
|
//Parametros
|
|
lst_Parametros.Add(new SqlParameter("@codigoCliente", Variables.G_LNG_IDCLIENTE_LICENCIAVALIDADO));
|
|
object[] arr_Parametros = lst_Parametros.ToArray();
|
|
|
|
//Ejecutar y rellenar el listado
|
|
Ejecutar_Consulta_Modelo_Listado(str_SQL,
|
|
arr_Parametros);
|
|
|
|
}
|
|
}
|
|
catch (Control_Errores)
|
|
{
|
|
throw;
|
|
}
|
|
catch (Exception ex)
|
|
{
|
|
throw new Control_Errores("", ex, nameof(KRS_Terminales_Datos) + "/" + nameof(Obtener_ModeloListado_Por_Ids), true);
|
|
}
|
|
|
|
return g_lst_KRS_Terminales;
|
|
}
|
|
|
|
#region Ejecutar Consulta
|
|
|
|
private void Ejecutar_Consulta_Modelo_Listado(string _str_SQL,
|
|
object[] _arr_Parametros)
|
|
{
|
|
KairosProEntities obj_KairosProEntities = null;
|
|
try
|
|
{
|
|
//Conexion
|
|
obj_KairosProEntities = new KairosProEntities();
|
|
obj_KairosProEntities.Configuration.LazyLoadingEnabled = false;
|
|
|
|
//Rellenar el modelo
|
|
g_lst_KRS_Terminales = obj_KairosProEntities.Database.SqlQuery<KRS_Terminales>(_str_SQL, _arr_Parametros).ToList();
|
|
|
|
}
|
|
catch (Control_Errores)
|
|
{
|
|
throw;
|
|
}
|
|
catch (Exception ex)
|
|
{
|
|
throw new Control_Errores("", ex, nameof(KRS_Terminales_Datos) + "/" + nameof(Ejecutar_Consulta_Modelo_Listado), true);
|
|
}
|
|
finally
|
|
{
|
|
obj_KairosProEntities.Database.Connection.Close();
|
|
obj_KairosProEntities.Dispose();
|
|
}
|
|
}
|
|
|
|
#endregion
|
|
|
|
#endregion
|
|
|
|
private string Obtener_Consulta_Modelo()
|
|
{
|
|
return
|
|
" SELECT " +
|
|
nameof(KRS_Terminales) + "." + nameof(KRS_Terminales.id) + "," +
|
|
nameof(KRS_Terminales) + "." + nameof(KRS_Terminales.codigoCliente) + "," +
|
|
nameof(KRS_Terminales) + "." + nameof(KRS_Terminales.codigo) + "," +
|
|
nameof(KRS_Terminales) + "." + nameof(KRS_Terminales.descripcion) + "," +
|
|
nameof(KRS_Terminales) + "." + nameof(KRS_Terminales.tipoDispositivo) + "," +
|
|
nameof(KRS_Terminales) + "." + nameof(KRS_Terminales.idDepartamento) + "," +
|
|
nameof(KRS_Terminales) + "." + nameof(KRS_Terminales.fechaActualizacion) + "," +
|
|
nameof(KRS_Terminales) + "." + nameof(KRS_Terminales.fechaBorrado) + "," +
|
|
nameof(KRS_Terminales) + "." + nameof(KRS_Terminales.dispositivoHuellaDactilar) + "," +
|
|
nameof(KRS_Terminales) + "." + nameof(KRS_Terminales.dispositivoHuellaDactilar_Numero) + "," +
|
|
nameof(KRS_Terminales) + "." + nameof(KRS_Terminales.dispositivoHuellaDactilar_IP) + "," +
|
|
nameof(KRS_Terminales) + "." + nameof(KRS_Terminales.dispositivoHuellaDactilar_Marca) + "," +
|
|
nameof(KRS_Terminales) + "." + nameof(KRS_Terminales.dispositivoHuellaDactilarModelo) + "," +
|
|
nameof(KRS_Terminales) + "." + nameof(KRS_Terminales.dispositivoHuellaDactilar_Firmware) + "," +
|
|
nameof(KRS_Terminales) + "." + nameof(KRS_Terminales.dispositivoHuellaDactilar_Puerto) + "," +
|
|
nameof(KRS_Terminales) + "." + nameof(KRS_Terminales.dispositivoHuellaDactilar_DNS) +
|
|
" FROM " + nameof(KRS_Terminales);
|
|
}
|
|
#endregion
|
|
|
|
#region Grabar
|
|
public override INTERNO_ValorDevuelto_Modelo Grabar(object _mdl_obj)
|
|
{
|
|
KairosProEntities obj_KairosProEntities = null;
|
|
|
|
INTERNO_ValorDevuelto_Modelo mdl_INTERNO_ValorDevuelto_Modelo = new INTERNO_ValorDevuelto_Modelo();
|
|
mdl_INTERNO_ValorDevuelto_Modelo.TodoCorrecto = true;
|
|
|
|
try
|
|
{
|
|
obj_KairosProEntities = new KairosProEntities();
|
|
obj_KairosProEntities.Configuration.LazyLoadingEnabled = false;
|
|
|
|
KRS_Terminales mdl_KRS_Terminales_AGrabar = (KRS_Terminales)_mdl_obj;
|
|
KRS_Terminales mdl_KRS_Terminales_DatosViejos = new KRS_Terminales();
|
|
|
|
KRS_Terminales mdl_KRS_Terminales_Final = Obtener_Modelo_Por_Id(mdl_KRS_Terminales_AGrabar.id, Variables.G_LNG_IDCLIENTE_LICENCIAVALIDADO);
|
|
|
|
if (mdl_KRS_Terminales_Final != null)
|
|
{
|
|
//Tipo de Accion que se va a realizar
|
|
mdl_INTERNO_ValorDevuelto_Modelo.TipoAccion = G_ENUM_TIPOACCION.INT_MODIFICAR;
|
|
|
|
//Validado el codigo del cliente, se lo asignamos antes de grabar
|
|
mdl_KRS_Terminales_AGrabar.codigoCliente = Variables.G_LNG_IDCLIENTE_LICENCIAVALIDADO;
|
|
|
|
//Datos viejos para la trazabilidar
|
|
Funciones.CopiarPropiedadesObjetos(mdl_KRS_Terminales_Final, mdl_KRS_Terminales_DatosViejos, false, false);
|
|
|
|
//Cargar los Datos del modelo
|
|
Funciones.CopiarPropiedadesObjetos(mdl_KRS_Terminales_AGrabar, mdl_KRS_Terminales_Final, false, false);
|
|
|
|
#region Update
|
|
string str_SQL_Update = " UPDATE " + nameof(KRS_Terminales) +
|
|
" SET " +
|
|
nameof(KRS_Terminales.codigoCliente) + "=@codigoCliente," +
|
|
nameof(KRS_Terminales.codigo) + "=@codigo," +
|
|
nameof(KRS_Terminales.descripcion) + "=@descripcion," +
|
|
nameof(KRS_Terminales.tipoDispositivo) + "=@tipoDispositivo," +
|
|
nameof(KRS_Terminales.idDepartamento) + "=@idDepartamento," +
|
|
nameof(KRS_Terminales.fechaActualizacion) + "=@fechaActualizacion," +
|
|
nameof(KRS_Terminales.fechaBorrado) + "=@fechaBorrado," +
|
|
nameof(KRS_Terminales.dispositivoHuellaDactilar) + "=@dispositivoHuellaDactilar," +
|
|
nameof(KRS_Terminales.dispositivoHuellaDactilar_Numero) + "=@dispositivoHuellaDactilar_Numero," +
|
|
nameof(KRS_Terminales.dispositivoHuellaDactilar_IP) + "=@dispositivoHuellaDactilar_IP," +
|
|
nameof(KRS_Terminales.dispositivoHuellaDactilar_Marca) + "=@dispositivoHuellaDactilar_Marca," +
|
|
nameof(KRS_Terminales.dispositivoHuellaDactilarModelo) + "=@dispositivoHuellaDactilarModelo," +
|
|
nameof(KRS_Terminales.dispositivoHuellaDactilar_Firmware) + "=@dispositivoHuellaDactilar_Firmware," +
|
|
nameof(KRS_Terminales.dispositivoHuellaDactilar_Puerto) + "=@dispositivoHuellaDactilar_Puerto," +
|
|
nameof(KRS_Terminales.dispositivoHuellaDactilar_DNS) + "=@dispositivoHuellaDactilar_DNS " +
|
|
" WHERE " +
|
|
nameof(KRS_Terminales.id) + "=@id";
|
|
//Parametros
|
|
object[] arr_Parametros_Update = new object[]
|
|
{
|
|
new SqlParameter("@codigoCliente", mdl_KRS_Terminales_Final.codigoCliente),
|
|
new SqlParameter("@codigo", mdl_KRS_Terminales_Final.codigo),
|
|
new SqlParameter("@descripcion", mdl_KRS_Terminales_Final.descripcion),
|
|
new SqlParameter("@tipoDispositivo", mdl_KRS_Terminales_Final.tipoDispositivo),
|
|
new SqlParameter("@idDepartamento", mdl_KRS_Terminales_Final.idDepartamento),
|
|
new SqlParameter("@fechaActualizacion", DateTime.Now),
|
|
mdl_KRS_Terminales_Final.fechaBorrado != null
|
|
? new SqlParameter("@fechaBorrado", mdl_KRS_Terminales_Final.fechaBorrado.Value)
|
|
: new SqlParameter("@fechaBorrado", DBNull.Value),
|
|
mdl_KRS_Terminales_Final.dispositivoHuellaDactilar != null
|
|
? new SqlParameter("@dispositivoHuellaDactilar", mdl_KRS_Terminales_Final.dispositivoHuellaDactilar.Value)
|
|
: new SqlParameter("@dispositivoHuellaDactilar", DBNull.Value),
|
|
mdl_KRS_Terminales_Final.dispositivoHuellaDactilar_Numero != null
|
|
? new SqlParameter("@dispositivoHuellaDactilar_Numero", mdl_KRS_Terminales_Final.dispositivoHuellaDactilar_Numero.Value)
|
|
: new SqlParameter("@dispositivoHuellaDactilar_Numero", DBNull.Value),
|
|
mdl_KRS_Terminales_Final.dispositivoHuellaDactilar_IP != null
|
|
? new SqlParameter("@dispositivoHuellaDactilar_IP", mdl_KRS_Terminales_Final.dispositivoHuellaDactilar_IP)
|
|
: new SqlParameter("@dispositivoHuellaDactilar_IP", DBNull.Value),
|
|
mdl_KRS_Terminales_Final.dispositivoHuellaDactilar_Marca != null
|
|
? new SqlParameter("@dispositivoHuellaDactilar_Marca", mdl_KRS_Terminales_Final.dispositivoHuellaDactilar_Marca)
|
|
: new SqlParameter("@dispositivoHuellaDactilar_Marca", DBNull.Value),
|
|
mdl_KRS_Terminales_Final.dispositivoHuellaDactilarModelo != null
|
|
? new SqlParameter("@dispositivoHuellaDactilarModelo", mdl_KRS_Terminales_Final.dispositivoHuellaDactilarModelo)
|
|
: new SqlParameter("@dispositivoHuellaDactilarModelo", DBNull.Value),
|
|
mdl_KRS_Terminales_Final.dispositivoHuellaDactilar_Firmware != null
|
|
? new SqlParameter("@dispositivoHuellaDactilar_Firmware", mdl_KRS_Terminales_Final.dispositivoHuellaDactilar_Firmware)
|
|
: new SqlParameter("@dispositivoHuellaDactilar_Firmware", DBNull.Value),
|
|
mdl_KRS_Terminales_Final.dispositivoHuellaDactilar_Puerto != null
|
|
? new SqlParameter("@dispositivoHuellaDactilar_Puerto", mdl_KRS_Terminales_Final.dispositivoHuellaDactilar_Puerto)
|
|
: new SqlParameter("@dispositivoHuellaDactilar_Puerto", DBNull.Value),
|
|
mdl_KRS_Terminales_Final.dispositivoHuellaDactilar_DNS != null
|
|
? new SqlParameter("@dispositivoHuellaDactilar_DNS", mdl_KRS_Terminales_Final.dispositivoHuellaDactilar_DNS)
|
|
: new SqlParameter("@dispositivoHuellaDactilar_DNS", DBNull.Value),
|
|
new SqlParameter("@id", mdl_KRS_Terminales_Final.id),
|
|
};
|
|
#endregion
|
|
|
|
//Update
|
|
obj_KairosProEntities.Database.ExecuteSqlCommand(str_SQL_Update, arr_Parametros_Update);
|
|
|
|
//Id de la tabla
|
|
mdl_INTERNO_ValorDevuelto_Modelo.Id = mdl_KRS_Terminales_Final.id;
|
|
}
|
|
else
|
|
{
|
|
mdl_KRS_Terminales_Final = new KRS_Terminales();
|
|
|
|
//Tipo de Accion que se va a realizar
|
|
mdl_INTERNO_ValorDevuelto_Modelo.TipoAccion = G_ENUM_TIPOACCION.INT_INSERTAR;
|
|
|
|
//Validado el codigo del cliente, se lo asignamos antes de grabar
|
|
mdl_KRS_Terminales_AGrabar.codigoCliente = Variables.G_LNG_IDCLIENTE_LICENCIAVALIDADO;
|
|
|
|
//Cargar los Datos del modelo
|
|
Funciones.CopiarPropiedadesObjetos(mdl_KRS_Terminales_AGrabar, mdl_KRS_Terminales_Final, false, false);
|
|
|
|
#region INSERT
|
|
string str_SQL_Insert = " INSERT INTO " + nameof(KRS_Terminales) +
|
|
" (" +
|
|
nameof(KRS_Terminales.codigoCliente) + "," +
|
|
nameof(KRS_Terminales.codigo) + "," +
|
|
nameof(KRS_Terminales.descripcion) + "," +
|
|
nameof(KRS_Terminales.tipoDispositivo) + "," +
|
|
nameof(KRS_Terminales.idDepartamento) + "," +
|
|
nameof(KRS_Terminales.fechaActualizacion) + "," +
|
|
nameof(KRS_Terminales.fechaBorrado) + "," +
|
|
nameof(KRS_Terminales.dispositivoHuellaDactilar) + "," +
|
|
nameof(KRS_Terminales.dispositivoHuellaDactilar_Numero) + "," +
|
|
nameof(KRS_Terminales.dispositivoHuellaDactilar_IP) + "," +
|
|
nameof(KRS_Terminales.dispositivoHuellaDactilar_Marca) + "," +
|
|
nameof(KRS_Terminales.dispositivoHuellaDactilarModelo) + "," +
|
|
nameof(KRS_Terminales.dispositivoHuellaDactilar_Firmware) + "," +
|
|
nameof(KRS_Terminales.dispositivoHuellaDactilar_Puerto) + "," +
|
|
nameof(KRS_Terminales.dispositivoHuellaDactilar_DNS) +
|
|
" ) " +
|
|
" OUTPUT INSERTED." + nameof(KRS_Terminales.id) +
|
|
" VALUES " +
|
|
" ( " +
|
|
"@codigoCliente," +
|
|
"@codigo," +
|
|
"@descripcion," +
|
|
"@tipoDispositivo," +
|
|
"@idDepartamento," +
|
|
"@fechaActualizacion," +
|
|
"@fechaBorrado," +
|
|
"@dispositivoHuellaDactilar," +
|
|
"@dispositivoHuellaDactilar_Numero," +
|
|
"@dispositivoHuellaDactilar_IP," +
|
|
"@dispositivoHuellaDactilar_Marca," +
|
|
"@dispositivoHuellaDactilarModelo," +
|
|
"@dispositivoHuellaDactilar_Firmware," +
|
|
"@dispositivoHuellaDactilar_Puerto," +
|
|
"@dispositivoHuellaDactilar_DNS" +
|
|
" ) ";
|
|
//Parametros
|
|
object[] arr_Parametros_Insert = new object[]
|
|
{
|
|
new SqlParameter("@codigoCliente", mdl_KRS_Terminales_Final.codigoCliente),
|
|
new SqlParameter("@codigo", mdl_KRS_Terminales_Final.codigo),
|
|
new SqlParameter("@descripcion", mdl_KRS_Terminales_Final.descripcion),
|
|
new SqlParameter("@tipoDispositivo", mdl_KRS_Terminales_Final.tipoDispositivo),
|
|
new SqlParameter("@idDepartamento", mdl_KRS_Terminales_Final.idDepartamento),
|
|
new SqlParameter("@fechaActualizacion", DateTime.Now),
|
|
mdl_KRS_Terminales_Final.fechaBorrado != null
|
|
? new SqlParameter("@fechaBorrado", mdl_KRS_Terminales_Final.fechaBorrado.Value)
|
|
: new SqlParameter("@fechaBorrado", DBNull.Value),
|
|
mdl_KRS_Terminales_Final.dispositivoHuellaDactilar != null
|
|
? new SqlParameter("@dispositivoHuellaDactilar", mdl_KRS_Terminales_Final.dispositivoHuellaDactilar.Value)
|
|
: new SqlParameter("@dispositivoHuellaDactilar", DBNull.Value),
|
|
mdl_KRS_Terminales_Final.dispositivoHuellaDactilar_Numero != null
|
|
? new SqlParameter("@dispositivoHuellaDactilar_Numero", mdl_KRS_Terminales_Final.dispositivoHuellaDactilar_Numero.Value)
|
|
: new SqlParameter("@dispositivoHuellaDactilar_Numero", DBNull.Value),
|
|
mdl_KRS_Terminales_Final.dispositivoHuellaDactilar_IP != null
|
|
? new SqlParameter("@dispositivoHuellaDactilar_IP", mdl_KRS_Terminales_Final.dispositivoHuellaDactilar_IP)
|
|
: new SqlParameter("@dispositivoHuellaDactilar_IP", DBNull.Value),
|
|
mdl_KRS_Terminales_Final.dispositivoHuellaDactilar_Marca != null
|
|
? new SqlParameter("@dispositivoHuellaDactilar_Marca", mdl_KRS_Terminales_Final.dispositivoHuellaDactilar_Marca)
|
|
: new SqlParameter("@dispositivoHuellaDactilar_Marca", DBNull.Value),
|
|
mdl_KRS_Terminales_Final.dispositivoHuellaDactilarModelo != null
|
|
? new SqlParameter("@dispositivoHuellaDactilarModelo", mdl_KRS_Terminales_Final.dispositivoHuellaDactilarModelo)
|
|
: new SqlParameter("@dispositivoHuellaDactilarModelo", DBNull.Value),
|
|
mdl_KRS_Terminales_Final.dispositivoHuellaDactilar_Firmware != null
|
|
? new SqlParameter("@dispositivoHuellaDactilar_Firmware", mdl_KRS_Terminales_Final.dispositivoHuellaDactilar_Firmware)
|
|
: new SqlParameter("@dispositivoHuellaDactilar_Firmware", DBNull.Value),
|
|
mdl_KRS_Terminales_Final.dispositivoHuellaDactilar_Puerto != null
|
|
? new SqlParameter("@dispositivoHuellaDactilar_Puerto", mdl_KRS_Terminales_Final.dispositivoHuellaDactilar_Puerto)
|
|
: new SqlParameter("@dispositivoHuellaDactilar_Puerto", DBNull.Value),
|
|
mdl_KRS_Terminales_Final.dispositivoHuellaDactilar_DNS != null
|
|
? new SqlParameter("@dispositivoHuellaDactilar_DNS", mdl_KRS_Terminales_Final.dispositivoHuellaDactilar_DNS)
|
|
: new SqlParameter("@dispositivoHuellaDactilar_DNS", DBNull.Value)
|
|
};
|
|
#endregion
|
|
|
|
//Id de la tabla
|
|
mdl_INTERNO_ValorDevuelto_Modelo.Id = obj_KairosProEntities.Database.SqlQuery<long>(str_SQL_Insert, arr_Parametros_Insert).Single();
|
|
|
|
}
|
|
|
|
//Grabar un registro de trazabilidad con los datos de la transaccion realizada
|
|
USR_Trazabilidad_Datos.Grabar_Trazabilidad(typeof(KRS_Terminales), mdl_KRS_Terminales_DatosViejos, mdl_KRS_Terminales_Final, mdl_INTERNO_ValorDevuelto_Modelo.TipoAccion, obj_KairosProEntities);
|
|
}
|
|
catch (Control_Errores)
|
|
{
|
|
throw;
|
|
}
|
|
catch (Exception ex)
|
|
{
|
|
throw new Control_Errores("", ex, nameof(KRS_Terminales_Datos) + "/" + nameof(Grabar), true);
|
|
}
|
|
finally
|
|
{
|
|
//Finalizar transaccion
|
|
obj_KairosProEntities.Database.Connection.Close();
|
|
obj_KairosProEntities.Dispose();
|
|
}
|
|
|
|
return mdl_INTERNO_ValorDevuelto_Modelo;
|
|
}
|
|
#endregion
|
|
|
|
#region Borrar
|
|
public override INTERNO_ValorDevuelto_Modelo Borrar(long _lng_id)
|
|
{
|
|
KairosProEntities obj_KairosProEntities = null;
|
|
|
|
INTERNO_ValorDevuelto_Modelo mdl_INTERNO_ValorDevuelto_Modelo = new INTERNO_ValorDevuelto_Modelo();
|
|
mdl_INTERNO_ValorDevuelto_Modelo.TodoCorrecto = true;
|
|
|
|
//Tipo de Accion que se va a realizar
|
|
mdl_INTERNO_ValorDevuelto_Modelo.TipoAccion = G_ENUM_TIPOACCION.INT_ELIMINAR;
|
|
|
|
bool bol_ActualizarFechaBorrado = false;//Este campo se utiliza por si no se puede borrar, que actualice la fecha de borrado
|
|
|
|
// Se utiliza la transaccion por la llamada al procedimiento de almacenado
|
|
using (TransactionScope transaccion_SQL = new TransactionScope(TransactionScopeOption.Required))
|
|
{
|
|
try
|
|
{
|
|
|
|
obj_KairosProEntities = new KairosProEntities();
|
|
obj_KairosProEntities.Configuration.LazyLoadingEnabled = false;
|
|
|
|
// Ver si existe ######################################################################
|
|
KRS_Terminales mdl_KRS_Terminales = Obtener_Modelo_Por_Id(_lng_id, Variables.G_LNG_IDCLIENTE_LICENCIAVALIDADO);
|
|
//######################################################################################
|
|
|
|
if (mdl_KRS_Terminales != null)
|
|
{
|
|
//Se intenta borrar, si diera un error porque esta relacaionado se graba la fecha de baja
|
|
try
|
|
{
|
|
#region Delete
|
|
string str_SQL_Delete = " DELETE FROM " + nameof(KRS_Terminales) +
|
|
" WHERE " +
|
|
nameof(KRS_Terminales.id) + "=@id and " +
|
|
nameof(KRS_Terminales.codigoCliente) + "=@codigoCliente ";
|
|
//Parametros
|
|
object[] arr_Parametros_Delete = new object[]
|
|
{
|
|
new SqlParameter("@id", _lng_id),
|
|
new SqlParameter("@codigoCliente", Variables.G_LNG_IDCLIENTE_LICENCIAVALIDADO)
|
|
};
|
|
#endregion
|
|
|
|
//Delete
|
|
obj_KairosProEntities.Database.ExecuteSqlCommand(str_SQL_Delete, arr_Parametros_Delete);
|
|
|
|
// Grabar un registro de trazabilidad con los datos de la transaccion realizada.
|
|
USR_Trazabilidad_Datos.Grabar_Trazabilidad(typeof(KRS_Terminales), null, mdl_KRS_Terminales, G_ENUM_TIPOACCION.INT_ELIMINAR, obj_KairosProEntities);
|
|
}
|
|
catch (Exception ex)
|
|
{
|
|
var sqlException = ex.GetBaseException() as SqlException;
|
|
if (sqlException != null)
|
|
{
|
|
if (sqlException.Errors.Count > 0)
|
|
{
|
|
switch (sqlException.Errors[0].Number)
|
|
{
|
|
case Control_Errores.G_INT_ERRORCONTROLADO_BORRAR_CONFLICTO_CLAVEFORANEA: // Foreign Key violation
|
|
bol_ActualizarFechaBorrado = true;
|
|
break;
|
|
default:
|
|
throw;
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
throw;
|
|
}
|
|
}
|
|
}
|
|
|
|
|
|
// Actualizar la fecha de baja , al no poder borrarlo por tener relaciones
|
|
if (bol_ActualizarFechaBorrado)
|
|
{
|
|
|
|
#region Update
|
|
string str_SQL_Update = " UPDATE " + nameof(KRS_Terminales) +
|
|
" SET " +
|
|
nameof(KRS_Terminales.fechaBorrado) + "=@fechaBorrado " +
|
|
" WHERE " +
|
|
nameof(KRS_Terminales.id) + "=@id and " +
|
|
nameof(KRS_Terminales.codigoCliente) + "=@codigoCliente ";
|
|
//Parametros
|
|
object[] arr_Parametros_Update = new object[]
|
|
{
|
|
new SqlParameter("@fechaBorrado", DateTime.Now),
|
|
new SqlParameter("@id", _lng_id),
|
|
new SqlParameter("@codigoCliente", Variables.G_LNG_IDCLIENTE_LICENCIAVALIDADO)
|
|
};
|
|
#endregion
|
|
|
|
//Update
|
|
obj_KairosProEntities.Database.ExecuteSqlCommand(str_SQL_Update, arr_Parametros_Update);
|
|
|
|
// Grabar un registro de trazabilidad con los datos de la transaccion realizada.
|
|
USR_Trazabilidad_Datos.Grabar_Trazabilidad(typeof(KRS_Terminales), null, mdl_KRS_Terminales, G_ENUM_TIPOACCION.INT_ELIMINAR, obj_KairosProEntities);
|
|
}
|
|
|
|
// Devolver también el Objeto
|
|
mdl_INTERNO_ValorDevuelto_Modelo.Id = _lng_id;
|
|
|
|
// Se termina la Transaccion Correctamente
|
|
transaccion_SQL.Complete();
|
|
}
|
|
catch (Control_Errores)
|
|
{
|
|
throw;
|
|
}
|
|
catch (Exception ex)
|
|
{
|
|
throw new Control_Errores("", ex, nameof(KRS_Terminales) + "/" + nameof(Borrar), true);
|
|
}
|
|
finally
|
|
{
|
|
obj_KairosProEntities.Database.Connection.Close();
|
|
obj_KairosProEntities.Dispose();
|
|
|
|
transaccion_SQL.Dispose();
|
|
}
|
|
}
|
|
return mdl_INTERNO_ValorDevuelto_Modelo;
|
|
}
|
|
public override INTERNO_ValorDevuelto_Modelo Borrar(object _mdl_obj)
|
|
{
|
|
throw new NotImplementedException();
|
|
}
|
|
public override INTERNO_ValorDevuelto_Modelo Borrar(long _lng_id, long _lng_idAuxiliar)
|
|
{
|
|
throw new NotImplementedException();
|
|
}
|
|
#endregion
|
|
}
|
|
}
|