6ca41ed720
- eliminazione riferimenti codice escluso da compilazione - pulizia codice da componenti non impiegati NON ancora 100% ok pulizia
364 lines
16 KiB
C#
364 lines
16 KiB
C#
using DnsClient.Protocol;
|
|
using Microsoft.Data.SqlClient;
|
|
using Microsoft.EntityFrameworkCore;
|
|
using Microsoft.Extensions.Configuration;
|
|
using MP.Data.DatabaseModels;
|
|
using NLog;
|
|
using System;
|
|
using System.Collections.Generic;
|
|
using System.Drawing.Drawing2D;
|
|
using System.Linq;
|
|
using static MP.Data.Objects.Enums;
|
|
|
|
namespace MP.Data.Controllers
|
|
{
|
|
public class MpStatsController : IDisposable
|
|
{
|
|
#region Public Constructors
|
|
|
|
public MpStatsController(IConfiguration configuration)
|
|
{
|
|
_configuration = configuration;
|
|
Log.Info("Avviata classe MpStatsController");
|
|
}
|
|
|
|
#endregion Public Constructors
|
|
|
|
#region Public Methods
|
|
|
|
/// <summary>
|
|
/// Elenco Azioni (decodifica)
|
|
/// </summary>
|
|
/// <returns></returns>
|
|
public List<AzioniUL> ActionsGetAll()
|
|
{
|
|
List<AzioniUL> dbResult = new List<AzioniUL>();
|
|
using (var dbCtx = new MoonPro_STATSContext(_configuration))
|
|
{
|
|
dbResult = dbCtx
|
|
.DbSetAzioniUL
|
|
.ToList();
|
|
}
|
|
return dbResult;
|
|
}
|
|
|
|
/// <summary>
|
|
/// Elenco tabella Articoli da filtro
|
|
/// </summary>
|
|
/// <param name="numRecord"></param>
|
|
/// <param name="searchVal"></param>
|
|
/// <returns></returns>
|
|
public List<StatsAnagArticoli> ArticoliGetSearch(int numRecord, string searchVal = "")
|
|
{
|
|
List<StatsAnagArticoli> dbResult = new List<StatsAnagArticoli>();
|
|
using (var dbCtx = new MoonPro_STATSContext(_configuration))
|
|
{
|
|
dbResult = dbCtx
|
|
.DbSetArticoli
|
|
.Where(x => x.CodArticolo.Contains(searchVal) || x.DescArticolo.Contains(searchVal) || x.Disegno.Contains(searchVal) || string.IsNullOrEmpty(searchVal))
|
|
.OrderBy(x => x.CodArticolo)
|
|
.Take(numRecord)
|
|
.ToList();
|
|
}
|
|
return dbResult;
|
|
}
|
|
|
|
/// <summary>
|
|
/// Elenco tabella Articoli da filtro
|
|
/// </summary>
|
|
/// <param name="numRecord"></param>
|
|
/// <param name="searchVal"></param>
|
|
/// <returns></returns>
|
|
public List<StatsODL> CommesseGetSearch(int numRecord, string searchVal = "")
|
|
{
|
|
List<StatsODL> dbResult = new List<StatsODL>();
|
|
using (var dbCtx = new MoonPro_STATSContext(_configuration))
|
|
{
|
|
dbResult = dbCtx
|
|
.DbSetODL
|
|
.Where(x => x.KeyRichiesta.Contains(searchVal) || string.IsNullOrEmpty(searchVal))
|
|
.OrderBy(x => x.KeyRichiesta)
|
|
.Take(numRecord)
|
|
.ToList();
|
|
}
|
|
return dbResult;
|
|
}
|
|
|
|
public void Dispose()
|
|
{
|
|
}
|
|
|
|
/// <summary>
|
|
/// Elenco da tabella Macchine
|
|
/// </summary>
|
|
/// <returns></returns>
|
|
public List<Macchine> MacchineGetAll()
|
|
{
|
|
List<Macchine> dbResult = new List<Macchine>();
|
|
using (var dbCtx = new MoonPro_STATSContext(_configuration))
|
|
{
|
|
dbResult = dbCtx
|
|
.DbSetMacchine
|
|
.OrderBy(x => x.IdxMacchina)
|
|
.ToList();
|
|
}
|
|
return dbResult;
|
|
}
|
|
|
|
/// <summary>
|
|
/// Annulla modifiche su una specifica entity (cancel update)
|
|
/// </summary>
|
|
/// <param name="item"></param>
|
|
/// <returns></returns>
|
|
public bool RollBackEntity(object item)
|
|
{
|
|
bool answ = false;
|
|
using (var dbCtx = new MoonPro_STATSContext(_configuration))
|
|
{
|
|
try
|
|
{
|
|
if (dbCtx.Entry(item).State == Microsoft.EntityFrameworkCore.EntityState.Deleted || dbCtx.Entry(item).State == Microsoft.EntityFrameworkCore.EntityState.Modified)
|
|
{
|
|
dbCtx.Entry(item).Reload();
|
|
}
|
|
}
|
|
catch (Exception exc)
|
|
{
|
|
Log.Error($"Eccezione in rollBackEntity{Environment.NewLine}{exc}");
|
|
}
|
|
}
|
|
return answ;
|
|
}
|
|
|
|
/// <summary>
|
|
/// Elenco tabella controlli da filtro
|
|
/// </summary>
|
|
/// <param name="numRecord"></param>
|
|
/// <param name="searchVal"></param>
|
|
/// <returns></returns>
|
|
public List<ResControlli> StatControlliGetAll(DateTime DataStart, DateTime DataEnd, string IdxMacchina, int IdxODL, string KeyRichiesta, string CodArticolo)
|
|
{
|
|
List<ResControlli> dbResult = new List<ResControlli>();
|
|
using (var dbCtx = new MoonPro_STATSContext(_configuration))
|
|
{
|
|
var dataFrom = new SqlParameter("@dataFrom", DataStart);
|
|
var dataTo = new SqlParameter("@dataTo", DataEnd);
|
|
var idxMacchina = new SqlParameter("@IdxMacchina", IdxMacchina);
|
|
var idxODL = new SqlParameter("@IdxODL", IdxODL);
|
|
var keyRichiesta = new SqlParameter("@KeyRichiesta", KeyRichiesta);
|
|
var codArticolo = new SqlParameter("@CodArticolo", CodArticolo);
|
|
|
|
dbResult = dbCtx
|
|
.DbSetControlli
|
|
.FromSqlRaw("EXEC stp_UI_RC_GetByFilter @dataFrom,@dataTo,@IdxMacchina,@IdxODL,@KeyRichiesta,@CodArticolo", dataFrom, dataTo, idxMacchina, idxODL, keyRichiesta, codArticolo)
|
|
.ToList();
|
|
}
|
|
return dbResult;
|
|
}
|
|
|
|
/// <summary>
|
|
/// Elenco tabella DDB da filtro
|
|
/// </summary>
|
|
/// <param name="DataStart"></param>
|
|
/// <param name="DataEnd"></param>
|
|
/// <param name="IdxMacchina"></param>
|
|
/// <param name="IdxODL"></param>
|
|
/// <param name="KeyRichiesta"></param>
|
|
/// <param name="CodArticolo"></param>
|
|
/// <param name="FirstRecord"></param>
|
|
/// <param name="NumRecord"></param>
|
|
/// <returns></returns>
|
|
public List<DdbTurni> StatDdbGetAll(DateTime DataStart, DateTime DataEnd, string IdxMacchina, int IdxODL, string KeyRichiesta, string CodArticolo, int FirstRecord, int NumRecord)
|
|
{
|
|
List<DdbTurni> dbResult = new List<DdbTurni>();
|
|
using (var dbCtx = new MoonPro_STATSContext(_configuration))
|
|
{
|
|
var dataFrom = new SqlParameter("@dataFrom", DataStart);
|
|
var dataTo = new SqlParameter("@dataTo", DataEnd);
|
|
var idxMacchina = new SqlParameter("@IdxMacchina", IdxMacchina);
|
|
var idxODL = new SqlParameter("@IdxODL", IdxODL);
|
|
var keyRichiesta = new SqlParameter("@KeyRichiesta", KeyRichiesta);
|
|
var codArticolo = new SqlParameter("@CodArticolo", CodArticolo);
|
|
var firstRecord = new SqlParameter("@FirstRecord", FirstRecord);
|
|
var numRecord = new SqlParameter("@NumRecord", NumRecord);
|
|
|
|
dbResult = dbCtx
|
|
.DbSetDdbTurni
|
|
.FromSqlRaw("EXEC stp_UI_DDBTurni_GetByFilter @dataFrom,@dataTo,@IdxMacchina,@IdxODL,@KeyRichiesta,@CodArticolo,@FirstRecord,@NumRecord", dataFrom, dataTo, idxMacchina, idxODL, keyRichiesta, codArticolo, firstRecord, numRecord)
|
|
.ToList();
|
|
}
|
|
return dbResult;
|
|
}
|
|
|
|
/// <summary>
|
|
/// Elenco tabella DDB da filtro
|
|
/// </summary>
|
|
/// <param name="DataStart"></param>
|
|
/// <param name="DataEnd"></param>
|
|
/// <param name="IdxMacchina"></param>
|
|
/// <param name="IdxODL"></param>
|
|
/// <param name="KeyRichiesta"></param>
|
|
/// <param name="CodArticolo"></param>
|
|
/// <returns></returns>
|
|
public int StatDdbGetCount(DateTime DataStart, DateTime DataEnd, string IdxMacchina, int IdxODL, string KeyRichiesta, string CodArticolo)
|
|
{
|
|
int numResult = 0;
|
|
using (var dbCtx = new MoonPro_STATSContext(_configuration))
|
|
{
|
|
numResult = dbCtx
|
|
.DbSetDdbTurni
|
|
.Where(x => (x.IdxMacchina == IdxMacchina || IdxMacchina == "*") && (x.IdxOdl == IdxODL || IdxODL == -999) && (x.KeyRichiesta == KeyRichiesta || KeyRichiesta == "*") && (x.CodArticolo == CodArticolo || CodArticolo == "*") && (x.InizioPeriodo >= DataStart && x.InizioPeriodo <= DataEnd))
|
|
.Count();
|
|
}
|
|
return numResult;
|
|
}
|
|
|
|
/// <summary>
|
|
/// Restituisce dataset ODL Energy filtrato
|
|
/// </summary>
|
|
/// <param name="IdxMacchina">Macchina singola, se "" = tutte</param>
|
|
/// <param name="DtStart">Data inizio selezione odl (inizio/fine)</param>
|
|
/// <param name="DtEnd">Data fine selezione odl (inizio/fine)</param>
|
|
/// <param name="IdxODL">IdxOdl, se 0 = tutti</param>
|
|
/// <param name="KeyRichiesta">Key Richiesta, se "*" = tutti</param>
|
|
/// <param name="CodArticolo">Cod Articolo, se "*" = tutti</param>
|
|
/// <returns></returns>
|
|
public List<OdlEnergyModel> StatOdlEnergyGetFilt(string IdxMacchina, DateTime DtStart, DateTime DtEnd, int IdxODL, string KeyRichiesta, string CodArticolo)
|
|
{
|
|
List<OdlEnergyModel> dbResult = new List<OdlEnergyModel>();
|
|
using (var dbCtx = new MoonPro_STATSContext(_configuration))
|
|
{
|
|
var dataFrom = new SqlParameter("@dataFrom", DtStart);
|
|
var dataTo = new SqlParameter("@dataTo", DtEnd);
|
|
var idxMacchina = new SqlParameter("@idxMacchina", IdxMacchina);
|
|
var idxODL = new SqlParameter("@IdxODL", IdxODL);
|
|
var keyRichiesta = new SqlParameter("@KeyRichiesta", KeyRichiesta);
|
|
var codArticolo = new SqlParameter("@CodArticolo", CodArticolo);
|
|
|
|
dbResult = dbCtx
|
|
.DbSetOdlEnergy
|
|
.FromSqlRaw("EXEC stp_UI_ODL_Energy_GetByFilter @dataFrom,@dataTo,@IdxMacchina,@IdxODL,@KeyRichiesta,@CodArticolo", dataFrom, dataTo, idxMacchina, idxODL, keyRichiesta, codArticolo)
|
|
.ToList();
|
|
}
|
|
return dbResult;
|
|
}
|
|
|
|
/// <summary>
|
|
/// Elenco tabella ODL da filtro
|
|
/// </summary>
|
|
/// <param name="numRecord"></param>
|
|
/// <param name="searchVal"></param>
|
|
/// <returns></returns>
|
|
public List<StatsODL> StatOdlGetAll(DateTime DataStart, DateTime DataEnd, string IdxMacchina, int IdxODL, string KeyRichiesta, string CodArticolo)
|
|
{
|
|
List<StatsODL> dbResult = new List<StatsODL>();
|
|
using (var dbCtx = new MoonPro_STATSContext(_configuration))
|
|
{
|
|
var dataFrom = new SqlParameter("@dataFrom", DataStart);
|
|
var dataTo = new SqlParameter("@dataTo", DataEnd);
|
|
var idxMacchina = new SqlParameter("@IdxMacchina", IdxMacchina);
|
|
var idxODL = new SqlParameter("@IdxODL", IdxODL);
|
|
var keyRichiesta = new SqlParameter("@KeyRichiesta", KeyRichiesta);
|
|
var codArticolo = new SqlParameter("@CodArticolo", CodArticolo);
|
|
|
|
dbResult = dbCtx
|
|
.DbSetODL
|
|
.FromSqlRaw("EXEC stp_UI_Odl_GetByFilter @dataFrom,@dataTo,@IdxMacchina,@IdxODL,@KeyRichiesta,@CodArticolo", dataFrom, dataTo, idxMacchina, idxODL, keyRichiesta, codArticolo)
|
|
.ToList();
|
|
}
|
|
return dbResult;
|
|
}
|
|
|
|
/// <summary>
|
|
/// Elenco tabella scarti da filtro
|
|
/// </summary>
|
|
/// <param name="DataStart"></param>
|
|
/// <param name="DataEnd"></param>
|
|
/// <param name="IdxMacchina"></param>
|
|
/// <param name="DataEnd"></param>
|
|
/// <returns></returns>
|
|
public List<ResScarti> StatScartiGetAll(DateTime DataStart, DateTime DataEnd, string IdxMacchina, int IdxODL, string KeyRichiesta, string CodArticolo)
|
|
{
|
|
List<ResScarti> dbResult = new List<ResScarti>();
|
|
using (var dbCtx = new MoonPro_STATSContext(_configuration))
|
|
{
|
|
var dataFrom = new SqlParameter("@dataFrom", DataStart);
|
|
var dataTo = new SqlParameter("@dataTo", DataEnd);
|
|
var idxMacchina = new SqlParameter("@IdxMacchina", IdxMacchina);
|
|
var idxODL = new SqlParameter("@IdxODL", IdxODL);
|
|
var keyRichiesta = new SqlParameter("@KeyRichiesta", KeyRichiesta);
|
|
var codArticolo = new SqlParameter("@CodArticolo", CodArticolo);
|
|
|
|
dbResult = dbCtx
|
|
.DbSetScarti
|
|
.FromSqlRaw("EXEC stp_UI_RS_GetByFilter @dataFrom,@dataTo,@IdxMacchina,@IdxODL,@KeyRichiesta,@CodArticolo", dataFrom, dataTo, idxMacchina, idxODL, keyRichiesta, codArticolo)
|
|
.ToList();
|
|
}
|
|
return dbResult;
|
|
}
|
|
|
|
/// <summary>
|
|
/// Elenco tabella TurniOee da filtro
|
|
/// </summary>
|
|
/// <param name="DataStart"></param>
|
|
/// <param name="DataEnd"></param>
|
|
/// <param name="IdxMacchina"></param>
|
|
/// <param name="DataEnd"></param>
|
|
/// <returns></returns>
|
|
public List<TurniOee> StatTurniOeeGetAll(DateTime DataStart, DateTime DataEnd, string IdxMacchina, int IdxODL, string KeyRichiesta, string CodArticolo)
|
|
{
|
|
List<TurniOee> dbResult = new List<TurniOee>();
|
|
using (var dbCtx = new MoonPro_STATSContext(_configuration))
|
|
{
|
|
var dataFrom = new SqlParameter("@dataFrom", DataStart);
|
|
var dataTo = new SqlParameter("@dataTo", DataEnd);
|
|
var idxMacchina = new SqlParameter("@IdxMacchina", IdxMacchina);
|
|
var idxODL = new SqlParameter("@IdxODL", IdxODL);
|
|
var keyRichiesta = new SqlParameter("@KeyRichiesta", KeyRichiesta);
|
|
var codArticolo = new SqlParameter("@CodArticolo", CodArticolo);
|
|
|
|
dbResult = dbCtx
|
|
.DbSetTurniOee
|
|
.FromSqlRaw("EXEC stp_UI_TurniOee_GetByFilter @dataFrom,@dataTo,@IdxMacchina,@IdxODL,@KeyRichiesta,@CodArticolo", dataFrom, dataTo, idxMacchina, idxODL, keyRichiesta, codArticolo)
|
|
.ToList();
|
|
}
|
|
return dbResult;
|
|
}
|
|
|
|
/// <summary>
|
|
/// Elenco tabella UserLog da filtro
|
|
/// </summary>
|
|
/// <param name="numRecord"></param>
|
|
/// <param name="searchVal"></param>
|
|
/// <returns></returns>
|
|
public List<UserActionLog> StatUserLogGetAll(DateTime DataStart, DateTime DataEnd, string IdxMacchina, int IdxODL, string KeyRichiesta, string CodArticolo)
|
|
{
|
|
List<UserActionLog> dbResult = new List<UserActionLog>();
|
|
using (var dbCtx = new MoonPro_STATSContext(_configuration))
|
|
{
|
|
var dataFrom = new SqlParameter("@dataFrom", DataStart);
|
|
var dataTo = new SqlParameter("@dataTo", DataEnd);
|
|
var idxMacchina = new SqlParameter("@IdxMacchina", IdxMacchina);
|
|
var idxODL = new SqlParameter("@IdxODL", IdxODL);
|
|
var keyRichiesta = new SqlParameter("@KeyRichiesta", KeyRichiesta);
|
|
var codArticolo = new SqlParameter("@CodArticolo", CodArticolo);
|
|
|
|
dbResult = dbCtx
|
|
.DbSetUserLog
|
|
.FromSqlRaw("EXEC stp_UI_UL_GetByFilter @dataFrom,@dataTo,@IdxMacchina,@IdxODL,@KeyRichiesta,@CodArticolo", dataFrom, dataTo, idxMacchina, idxODL, keyRichiesta, codArticolo)
|
|
.ToList();
|
|
}
|
|
return dbResult;
|
|
}
|
|
|
|
#endregion Public Methods
|
|
|
|
#region Private Fields
|
|
|
|
private static IConfiguration _configuration;
|
|
|
|
private static NLog.Logger Log = LogManager.GetCurrentClassLogger();
|
|
|
|
#endregion Private Fields
|
|
}
|
|
} |