981 lines
38 KiB
C#
981 lines
38 KiB
C#
using System;
|
|
using System.Collections.Generic;
|
|
using GPW.CORE.Data.DbModels;
|
|
using GPW.CORE.Data.DTO;
|
|
using Microsoft.AspNetCore.Mvc.Diagnostics;
|
|
using Microsoft.EntityFrameworkCore;
|
|
using Microsoft.EntityFrameworkCore.Metadata;
|
|
using Microsoft.Extensions.Configuration;
|
|
using NLog;
|
|
|
|
namespace GPW.CORE.Data
|
|
{
|
|
public partial class GPWContext : DbContext
|
|
{
|
|
#region Public Constructors
|
|
|
|
public GPWContext()
|
|
{
|
|
}
|
|
|
|
public GPWContext(IConfiguration configuration)
|
|
{
|
|
_configuration = configuration;
|
|
}
|
|
|
|
public GPWContext(DbContextOptions<GPWContext> options) : base(options)
|
|
{
|
|
try
|
|
{
|
|
// se non ci fosse... crea o migra!
|
|
Database.Migrate();
|
|
}
|
|
catch (Exception exc)
|
|
{
|
|
Log.Error(exc, "Exception during context initialization 02");
|
|
}
|
|
}
|
|
|
|
#endregion Public Constructors
|
|
|
|
#region Public Properties
|
|
|
|
public virtual DbSet<AnagClientiModel> DbSetAnagClienti { get; set; } = null!;
|
|
public virtual DbSet<AnagDeviceModel> DbSetAnagDevices { get; set; } = null!;
|
|
public virtual DbSet<AnagFasiModel> DbSetAnagFasi { get; set; } = null!;
|
|
public virtual DbSet<AnagFasiExplModel> DbSetAnagFasiExpl { get; set; } = null!;
|
|
public virtual DbSet<AnagGiustModel> DbSetAnagGiust { get; set; } = null!;
|
|
public virtual DbSet<AnagGruppiModel> DbSetAnagGruppi { get; set; } = null!;
|
|
public virtual DbSet<AnagKeyValueModel> DbSetAnagKeyValue { get; set; } = null!;
|
|
public virtual DbSet<AnagOrariModel> DbSetAnagOrari { get; set; } = null!;
|
|
public virtual DbSet<AnagProgettiModel> DbSetAnagProgetti { get; set; } = null!;
|
|
public virtual DbSet<AnagTagModel> DbSetAnagTag { get; set; } = null!;
|
|
public virtual DbSet<AnagTagFasiModel> DbSetAnagTagFasi { get; set; } = null!;
|
|
public virtual DbSet<TagFasiDTO> DbSetAnagTagFasiDTO { get; set; } = null!;
|
|
public virtual DbSet<AnagTipoTimbModel> DbSetAnagTipoTimb { get; set; } = null!;
|
|
public virtual DbSet<CalcOreFasiModel> DbSetCalcOreFasi { get; set; } = null!;
|
|
public virtual DbSet<CalcOreProgettiModel> DbSetCalcOreProj { get; set; } = null!;
|
|
public virtual DbSet<CalFesteFerieModel> DbSetCalFesteFerie { get; set; } = null!;
|
|
public virtual DbSet<CheckVc19Model> DbSetCheckVc19 { get; set; } = null!;
|
|
public virtual DbSet<ConfigModel> DbSetConfig { get; set; } = null!;
|
|
public virtual DbSet<Dipendenti2RuoliModel> DbSetDip2Ruoli { get; set; } = null!;
|
|
public virtual DbSet<DipendendiAndAnomalie> DbSetDipAndAnom { get; set; } = null!;
|
|
public virtual DbSet<DipendentiModel> DbSetDipendenti { get; set; } = null!;
|
|
public virtual DbSet<Dipendenti2GruppiModel> DbSetDipendenti2Gruppi { get; set; } = null!;
|
|
public virtual DbSet<ParetoRegAttModel> DbSetParetoRegAtt { get; set; } = null!;
|
|
public virtual DbSet<RegAttivitaModel> DbSetRegAttivita { get; set; } = null!;
|
|
public virtual DbSet<RegAttivitaExplModel> DbSetRegAttivitaExpl { get; set; } = null!;
|
|
public virtual DbSet<RegistroEventiModel> DbSetRegEventi { get; set; } = null!;
|
|
public virtual DbSet<RegMalattieModel> DbSetRegMalattie { get; set; } = null!;
|
|
public virtual DbSet<RegRichiesteModel> DbSetRegRichieste { get; set; } = null!;
|
|
public virtual DbSet<RilievoTempModel> DbSetRilievoTemp { get; set; } = null!;
|
|
public virtual DbSet<StatsDayPresModel> DbSetStatsDayPres { get; set; } = null!;
|
|
public virtual DbSet<TeRaExplModel> DbSetTeRaExpl { get; set; } = null!;
|
|
public virtual DbSet<TimbratureModel> DbSetTimbrature { get; set; } = null!;
|
|
public virtual DbSet<TimbratureExplModel> DbSetTimbratureExpl { get; set; } = null!;
|
|
public virtual DbSet<GiustificativiModel> DbSetGiustificativi { get; set; } = null!;
|
|
public virtual DbSet<ExpZucchettiModel> DbSetExpZucchetti { get; set; } = null!;
|
|
public virtual DbSet<ExpCommessaModel> DbSetExpCommessa { get; set; } = null!;
|
|
public virtual DbSet<MonthTagModel> DbSetMonthTag { get; set; } = null!;
|
|
public virtual DbSet<ListTagDDModel> DbSetListTagDD { get; set; } = null!;
|
|
public virtual DbSet<TimbMeseExplModel> DbSetTimbMeseExpl { get; set; } = null!;
|
|
public virtual DbSet<RegAttivitaDayExplModel> DbSetDayRaExpl { get; set; } = null!;
|
|
public virtual DbSet<ElencoReportModel> DbSetElencoReport { get; set; } = null!;
|
|
|
|
#endregion Public Properties
|
|
|
|
#region Public Methods
|
|
|
|
public void DbForceMigrate()
|
|
{
|
|
try
|
|
{
|
|
// se non ci fosse... crea o migra!
|
|
Database.Migrate();
|
|
Log.Info("DbForceMigrate: done!");
|
|
}
|
|
catch (Exception exc)
|
|
{
|
|
Log.Error(exc, "DbForceMigrate: Exception during context initialization 01");
|
|
}
|
|
}
|
|
|
|
#endregion Public Methods
|
|
|
|
#region Protected Methods
|
|
|
|
protected override void OnConfiguring(DbContextOptionsBuilder optionsBuilder)
|
|
{
|
|
if (!optionsBuilder.IsConfigured)
|
|
{
|
|
string connString = _configuration.GetConnectionString("GPW.DB") ?? "Server=W2019-SQL-STEAM; Database=GPW; Trusted_Connection=True; TrustServerCertificate=True;";
|
|
if (!string.IsNullOrEmpty(connString))
|
|
{
|
|
optionsBuilder.UseSqlServer(connString);
|
|
}
|
|
else
|
|
{
|
|
optionsBuilder.UseSqlServer("Server=W2019-SQL-STEAM; Database=GPW; Trusted_Connection=True; TrustServerCertificate=True;");
|
|
}
|
|
}
|
|
}
|
|
|
|
protected override void OnModelCreating(ModelBuilder modelBuilder)
|
|
{
|
|
modelBuilder.UseCollation("Latin1_General_CI_AS");
|
|
|
|
modelBuilder.Entity<TagFasiDTO>()
|
|
.ToView("v_AnagTagFasi");
|
|
|
|
modelBuilder.Entity<ExpZucchettiModel>()
|
|
.ToView("export.v_ExpZucchetti")
|
|
.HasKey(e => new { e.DataOra, e.IdxDipendente });
|
|
|
|
modelBuilder.Entity<ExpCommessaModel>()
|
|
.ToView("export.v_ExpCommessa");
|
|
|
|
modelBuilder.Entity<CheckVc19Model>(entity =>
|
|
{
|
|
entity.Property(e => e.Cognome)
|
|
.HasMaxLength(100)
|
|
.HasColumnName("cognome")
|
|
.HasDefaultValueSql("('')");
|
|
|
|
entity.Property(e => e.Dob)
|
|
.HasColumnType("datetime")
|
|
.HasColumnName("DOB")
|
|
.HasDefaultValueSql("(getdate())");
|
|
|
|
entity.Property(e => e.DtCheck)
|
|
.HasColumnType("datetime")
|
|
.HasColumnName("dtCheck")
|
|
.HasDefaultValueSql("(getdate())");
|
|
|
|
entity.Property(e => e.IdxDipendente).HasColumnName("idxDipendente");
|
|
|
|
entity.Property(e => e.Nome)
|
|
.HasMaxLength(100)
|
|
.HasColumnName("nome")
|
|
.HasDefaultValueSql("('')");
|
|
|
|
entity.Property(e => e.Payload)
|
|
.HasMaxLength(500)
|
|
.HasColumnName("payload")
|
|
.HasDefaultValueSql("('')");
|
|
});
|
|
|
|
modelBuilder.Entity<DipendentiModel>(entity =>
|
|
{
|
|
entity.Property(e => e.IdxDipendente).HasColumnName("idxDipendente");
|
|
|
|
entity.Property(e => e.Attivo)
|
|
.HasColumnName("attivo")
|
|
.HasDefaultValueSql("((1))");
|
|
|
|
entity.Property(e => e.AuthKey)
|
|
.HasMaxLength(50)
|
|
.HasColumnName("authKey")
|
|
.HasDefaultValueSql("('##########')");
|
|
|
|
entity.Property(e => e.Cf)
|
|
.HasMaxLength(16)
|
|
.HasColumnName("CF")
|
|
.HasDefaultValueSql("('0000000000000000')");
|
|
|
|
entity.Property(e => e.CodDipendenteExt)
|
|
.HasMaxLength(50)
|
|
.HasColumnName("codDipendenteExt")
|
|
.HasDefaultValueSql("('')")
|
|
.HasComment("nome/codice dipendente per sistema esterno da importare");
|
|
|
|
entity.Property(e => e.CodHw)
|
|
.HasMaxLength(50)
|
|
.HasColumnName("codHw")
|
|
.HasDefaultValueSql("('')");
|
|
|
|
entity.Property(e => e.CodOrario)
|
|
.HasMaxLength(50)
|
|
.HasColumnName("codOrario");
|
|
|
|
entity.Property(e => e.Cognome).HasMaxLength(50);
|
|
|
|
entity.Property(e => e.DataAssunzione)
|
|
.HasColumnType("date")
|
|
.HasColumnName("dataAssunzione")
|
|
.HasDefaultValueSql("('1900-01-01')");
|
|
|
|
entity.Property(e => e.DataCessazione)
|
|
.HasColumnType("date")
|
|
.HasColumnName("dataCessazione")
|
|
.HasDefaultValueSql("('9999-12-31')");
|
|
|
|
entity.Property(e => e.DataNascita)
|
|
.HasColumnType("datetime")
|
|
.HasColumnName("dataNascita");
|
|
|
|
entity.Property(e => e.Dominio)
|
|
.HasMaxLength(50)
|
|
.HasColumnName("dominio")
|
|
.HasDefaultValueSql("('DOMINIO')");
|
|
|
|
entity.Property(e => e.Email)
|
|
.HasMaxLength(250)
|
|
.HasColumnName("email")
|
|
.HasDefaultValueSql("('')");
|
|
|
|
entity.Property(e => e.Gruppo)
|
|
.HasMaxLength(50)
|
|
.HasColumnName("gruppo")
|
|
.HasDefaultValueSql("('NA')");
|
|
|
|
entity.Property(e => e.LuogoNascita)
|
|
.HasMaxLength(50)
|
|
.HasColumnName("luogoNascita");
|
|
|
|
entity.Property(e => e.MailDay)
|
|
.HasColumnName("mailDay")
|
|
.HasDefaultValueSql("((0))");
|
|
|
|
entity.Property(e => e.MailLastOp)
|
|
.HasColumnName("mailLastOp")
|
|
.HasDefaultValueSql("((0))");
|
|
|
|
entity.Property(e => e.MailMonth)
|
|
.HasColumnName("mailMonth")
|
|
.HasDefaultValueSql("((0))");
|
|
|
|
entity.Property(e => e.MailWeek)
|
|
.HasColumnName("mailWeek")
|
|
.HasDefaultValueSql("((0))");
|
|
|
|
entity.Property(e => e.Matricola)
|
|
.HasMaxLength(50)
|
|
.HasColumnName("matricola");
|
|
|
|
entity.Property(e => e.NazNascita)
|
|
.HasMaxLength(50)
|
|
.HasColumnName("nazNascita");
|
|
|
|
entity.Property(e => e.Nome).HasMaxLength(50);
|
|
|
|
entity.Property(e => e.NumAuth)
|
|
.HasColumnName("numAuth")
|
|
.HasDefaultValueSql("((0))")
|
|
.HasComment("numero di impieghi della authKey");
|
|
|
|
entity.Property(e => e.ProvNascita)
|
|
.HasMaxLength(50)
|
|
.HasColumnName("provNascita");
|
|
|
|
entity.Property(e => e.Utente)
|
|
.HasMaxLength(50)
|
|
.HasColumnName("utente")
|
|
.HasDefaultValueSql("('UTENTE')");
|
|
|
|
entity.Property(e => e.WolMac)
|
|
.HasMaxLength(50)
|
|
.HasColumnName("WOL_MAC");
|
|
entity.Property(e => e.Sigla)
|
|
.HasMaxLength(50)
|
|
.HasColumnName("sigla");
|
|
});
|
|
|
|
modelBuilder.Entity<GiustificativiModel>(entity =>
|
|
{
|
|
entity.HasKey(e => new { e.DataLav, e.IdxDipendente, e.CodGiust });
|
|
|
|
entity.Property(e => e.DataLav)
|
|
.HasColumnName("dataLav");
|
|
|
|
entity.Property(e => e.IdxDipendente)
|
|
.HasColumnName("idxDipendente");
|
|
|
|
entity.Property(e => e.CodGiust)
|
|
.HasColumnName("codGiust");
|
|
|
|
entity.Property(e => e.Minuti)
|
|
.HasColumnName("minuti");
|
|
|
|
entity.Property(e => e.Automatico)
|
|
.HasColumnName("automatico");
|
|
});
|
|
|
|
|
|
modelBuilder.Entity<GiustificativiModel>().ToTable(tb => tb.HasTrigger("trg_giustUpdateTimbr"));
|
|
|
|
modelBuilder.Entity<RegAttivitaModel>(entity =>
|
|
{
|
|
entity.HasIndex(e => e.Inizio, "ix_RA_inizio");
|
|
|
|
entity.HasIndex(e => new { e.IdxDipendente, e.Inizio }, "ix_idxDip");
|
|
|
|
entity.HasIndex(e => new { e.IdxFase, e.Inizio }, "ix_idxFase")
|
|
.HasFillFactor(100);
|
|
|
|
entity.HasIndex(e => new { e.Inizio, e.IdxDipendente }, "ix_inizio");
|
|
|
|
entity.Property(e => e.IdxRa).HasColumnName("idxRA");
|
|
|
|
entity.Property(e => e.Descrizione)
|
|
.HasMaxLength(500)
|
|
.HasColumnName("descrizione");
|
|
|
|
entity.Property(e => e.Fine)
|
|
.HasColumnType("datetime")
|
|
.HasColumnName("fine");
|
|
|
|
entity.Property(e => e.IdxDipendente).HasColumnName("idxDipendente");
|
|
|
|
entity.Property(e => e.IdxFase).HasColumnName("idxFase");
|
|
|
|
entity.Property(e => e.Importo)
|
|
.HasColumnType("decimal(19, 4)")
|
|
.HasColumnName("importo")
|
|
.HasDefaultValueSql("((0))");
|
|
|
|
entity.Property(e => e.Inizio)
|
|
.HasColumnType("datetime")
|
|
.HasColumnName("inizio");
|
|
|
|
entity.Property(e => e.OreTot)
|
|
.HasColumnType("decimal(19, 4)")
|
|
.HasColumnName("oreTot")
|
|
.HasComputedColumnSql("(CONVERT([decimal](19,4),CONVERT([decimal](19,4),datediff(minute,isnull([inizio],'19000101'),isnull([fine],'19000101')),(0))/(60),(0)))", false)
|
|
.HasComment("Ore Attività - prima era ([dbo].[f_hourInterval]([inizio],[fine])) poi sostituita per performance");
|
|
|
|
//entity.HasOne(d => d.DipNav)
|
|
// .WithMany(p => p.RegAttivitaNav)
|
|
// .HasForeignKey(d => d.IdxDipendente)
|
|
// .OnDelete(DeleteBehavior.ClientSetNull)
|
|
// .HasConstraintName("FK_RegAttivita_Dipendenti");
|
|
});
|
|
|
|
modelBuilder.Entity<RegAttivitaModel>().ToTable(tb => tb.HasTrigger("trg_RegAtt_upsert"));
|
|
|
|
modelBuilder.Entity<RilievoTempModel>(entity =>
|
|
{
|
|
entity.HasKey(e => new { e.IdxDipendente, e.DtRilievo });
|
|
|
|
entity.Property(e => e.IdxDipendente).HasColumnName("idxDipendente");
|
|
|
|
entity.Property(e => e.DtRilievo)
|
|
.HasColumnType("datetime")
|
|
.HasColumnName("dtRilievo");
|
|
|
|
entity.Property(e => e.TempRil)
|
|
.HasColumnType("decimal(9, 3)")
|
|
.HasColumnName("tempRil");
|
|
|
|
entity.HasOne(d => d.DipNav)
|
|
.WithMany(p => p.RilievoTempNav)
|
|
.HasForeignKey(d => d.IdxDipendente)
|
|
.OnDelete(DeleteBehavior.ClientSetNull)
|
|
.HasConstraintName("FK_RilievoTemp_Dipendenti");
|
|
});
|
|
|
|
modelBuilder.Entity<TimbratureModel>(entity =>
|
|
{
|
|
entity.HasKey(e => new { e.IdxDipendente, e.DataOra });
|
|
|
|
entity.HasIndex(e => new { e.IdxDipendente, e.Entrata }, "ix_Timbrature_IdxDip_Entrata");
|
|
|
|
entity.Property(e => e.IdxDipendente).HasColumnName("idxDipendente");
|
|
|
|
entity.Property(e => e.DataOra)
|
|
.HasColumnType("datetime")
|
|
.HasColumnName("dataOra");
|
|
|
|
entity.Property(e => e.Approv)
|
|
.HasDefaultValueSql("((0))")
|
|
.HasComment("Approvazioen timbratura (default true...)");
|
|
|
|
entity.Property(e => e.CodTipoTimb)
|
|
.HasMaxLength(10)
|
|
.HasDefaultValueSql("(N'BC')");
|
|
|
|
entity.Property(e => e.Entrata).HasColumnName("entrata");
|
|
|
|
entity.Property(e => e.Ipv4)
|
|
.HasMaxLength(15)
|
|
.HasColumnName("IPv4")
|
|
.HasDefaultValueSql("(N'0.0.0.0')");
|
|
|
|
entity.HasOne(d => d.DipNav)
|
|
.WithMany(p => p.TimbratureNav)
|
|
.HasForeignKey(d => d.IdxDipendente)
|
|
.OnDelete(DeleteBehavior.ClientSetNull)
|
|
.HasConstraintName("FK_Timbrature_Dipendenti");
|
|
});
|
|
|
|
modelBuilder.Entity<TimbratureModel>().ToTable(tb => tb.HasTrigger("trg_upsert"));
|
|
|
|
modelBuilder.Entity<RegAttivitaExplModel>(entity =>
|
|
{
|
|
entity.HasKey(e => new { e.DataLav, e.IdxDipendente });
|
|
|
|
entity.ToTable("RegAttivitaExpl");
|
|
|
|
entity.Property(e => e.DataLav)
|
|
.HasColumnType("date")
|
|
.HasColumnName("dataLav");
|
|
|
|
entity.Property(e => e.IdxDipendente).HasColumnName("idxDipendente");
|
|
|
|
entity.Property(e => e.CognomeNome)
|
|
.HasMaxLength(100)
|
|
.HasDefaultValueSql("('')");
|
|
|
|
entity.Property(e => e.DescrProj)
|
|
.HasMaxLength(500)
|
|
.HasColumnName("descrProj")
|
|
.HasDefaultValueSql("('')");
|
|
|
|
entity.Property(e => e.MinRegAtt)
|
|
.HasColumnName("minRegAtt")
|
|
.HasDefaultValueSql("((0))")
|
|
.HasComment("totale dei minuti di attività registrate per la giornata (da trigger suRegAttivita)");
|
|
});
|
|
|
|
modelBuilder.Entity<TimbratureExplModel>(entity =>
|
|
{
|
|
entity.HasKey(e => new { e.DataLav, e.IdxDipendente })
|
|
.HasName("PK_TimbratureExpl_1");
|
|
|
|
entity.ToTable("TimbratureExpl");
|
|
|
|
entity.HasIndex(e => new { e.CognomeNome, e.DataLav }, "ix_TimbrExpl_CognomeNome_DataLav")
|
|
.HasFillFactor(100);
|
|
|
|
entity.HasIndex(e => e.IdxDipendente, "ix_idxDip")
|
|
.HasFillFactor(100);
|
|
|
|
entity.Property(e => e.DataLav)
|
|
.HasColumnType("date")
|
|
.HasColumnName("dataLav");
|
|
|
|
entity.Property(e => e.IdxDipendente).HasColumnName("idxDipendente");
|
|
|
|
entity.Property(e => e.Block)
|
|
.HasColumnName("block")
|
|
.HasDefaultValueSql("((0))")
|
|
.HasComment("determina se il record sia \"bloccato\" (archiviazione e blocco mesi precedenti...)");
|
|
|
|
entity.Property(e => e.ChkFunCod)
|
|
.HasMaxLength(50)
|
|
.HasColumnName("chkFunCod")
|
|
.HasDefaultValueSql("('')")
|
|
.HasComment("eventuale diagnostica da check function sulla riga indicata (codice)");
|
|
|
|
entity.Property(e => e.ChkFunRes)
|
|
.HasMaxLength(50)
|
|
.HasColumnName("chkFunRes")
|
|
.HasDefaultValueSql("('')")
|
|
.HasComment("eventuale diagnostica da check function sulla riga indicata (spiegazione)");
|
|
|
|
entity.Property(e => e.CognomeNome).HasMaxLength(100);
|
|
|
|
entity.Property(e => e.Entrata1)
|
|
.HasColumnType("datetime")
|
|
.HasColumnName("entrata_1");
|
|
|
|
entity.Property(e => e.Entrata2)
|
|
.HasColumnType("datetime")
|
|
.HasColumnName("entrata_2");
|
|
|
|
entity.Property(e => e.Entrata3)
|
|
.HasColumnType("datetime")
|
|
.HasColumnName("entrata_3");
|
|
|
|
entity.Property(e => e.Entrata4)
|
|
.HasColumnType("datetime")
|
|
.HasColumnName("entrata_4");
|
|
|
|
entity.Property(e => e.HGiust)
|
|
.HasColumnName("h_giust")
|
|
.HasComputedColumnSql("(((((((CONVERT([float],[minPerm],(0))+[minFer])+[minMal])+[minFest])+[min104])+[minMpp])+[minCassa])/(60))", false)
|
|
.HasComment("totale ore giustificate");
|
|
|
|
entity.Property(e => e.HLav).HasColumnName("h_lav");
|
|
|
|
entity.Property(e => e.IsOk)
|
|
.HasColumnName("isOk")
|
|
.HasComputedColumnSql("(([isOkTim]&[isOkApp])&case when [minOrd]<=((((((([minLav]+[minPerm])+[minFer])+[minMal])+[minFest])+[minCassa])+[min104])+[minMpp]) then (1) else (0) end)", false);
|
|
|
|
entity.Property(e => e.IsOkApp)
|
|
.HasColumnName("isOkApp")
|
|
.HasDefaultValueSql("((1))")
|
|
.HasComment("dato sintetico x indicare se TUTTE le timbrature componenti siano approvate");
|
|
|
|
entity.Property(e => e.IsOkLav)
|
|
.HasColumnName("isOkLav")
|
|
.HasComputedColumnSql("(case when [minOrd]<=((((((([minLav]+[minPerm])+[minFer])+[minMal])+[minFest])+[minCassa])+[min104])+[minMpp]) then (1) else (0) end)", false)
|
|
.HasComment("determina se la giornata sia ok (oreLav + giustificativi >= oreOrd)");
|
|
|
|
entity.Property(e => e.IsOkTim)
|
|
.HasColumnName("isOkTim")
|
|
.HasDefaultValueSql("((0))");
|
|
|
|
entity.Property(e => e.Min104)
|
|
.HasColumnName("min104")
|
|
.HasDefaultValueSql("((0))")
|
|
.HasComment("Minuti Permessi per 104");
|
|
|
|
entity.Property(e => e.MinArcoPres)
|
|
.HasColumnName("minArcoPres")
|
|
.HasComputedColumnSql("(datediff(minute,isnull([entrata_1],getdate()),isnull(isnull([uscita_4],isnull([uscita_3],isnull([uscita_2],isnull([uscita_1],[entrata_1])))),getdate())))", false)
|
|
.HasComment("DATEDIFF(n, ISNULL(entrata_1,GETDATE()), ISNULL(ISNULL(uscita_4,ISNULL(uscita_3,ISNULL(uscita_2,ISNULL(uscita_1,entrata_1)))),GETDATE()))");
|
|
|
|
entity.Property(e => e.MinCassa)
|
|
.HasColumnName("minCassa")
|
|
.HasDefaultValueSql("((0))")
|
|
.HasComment("Minuti di Cassa Integrazione");
|
|
|
|
entity.Property(e => e.MinFer)
|
|
.HasColumnName("minFer")
|
|
.HasDefaultValueSql("((0))");
|
|
|
|
entity.Property(e => e.MinFest)
|
|
.HasColumnName("minFest")
|
|
.HasDefaultValueSql("((0))");
|
|
|
|
entity.Property(e => e.MinLav)
|
|
.HasColumnName("minLav")
|
|
.HasDefaultValueSql("((0))");
|
|
|
|
entity.Property(e => e.MinMal)
|
|
.HasColumnName("minMal")
|
|
.HasDefaultValueSql("((0))");
|
|
|
|
entity.Property(e => e.MinMpp)
|
|
.HasColumnName("minMpp")
|
|
.HasDefaultValueSql("((0))");
|
|
|
|
entity.Property(e => e.MinNonLav)
|
|
.HasColumnName("minNonLav")
|
|
.HasDefaultValueSql("((0))")
|
|
.HasComment("minuti non lavorati (ovvero se fatti meno di ordinari e senza giustificativi)");
|
|
|
|
entity.Property(e => e.MinOrd)
|
|
.HasColumnName("minOrd")
|
|
.HasDefaultValueSql("((0))");
|
|
|
|
entity.Property(e => e.MinPerm)
|
|
.HasColumnName("minPerm")
|
|
.HasDefaultValueSql("((0))");
|
|
|
|
entity.Property(e => e.MinStra)
|
|
.HasColumnName("minStra")
|
|
.HasDefaultValueSql("((0))");
|
|
|
|
entity.Property(e => e.TempRil)
|
|
.HasColumnType("decimal(9, 3)")
|
|
.HasColumnName("tempRil")
|
|
.HasComment("Temperatura rilevata");
|
|
|
|
entity.Property(e => e.Uscita1)
|
|
.HasColumnType("datetime")
|
|
.HasColumnName("uscita_1");
|
|
|
|
entity.Property(e => e.Uscita2)
|
|
.HasColumnType("datetime")
|
|
.HasColumnName("uscita_2");
|
|
|
|
entity.Property(e => e.Uscita3)
|
|
.HasColumnType("datetime")
|
|
.HasColumnName("uscita_3");
|
|
|
|
entity.Property(e => e.Uscita4)
|
|
.HasColumnType("datetime")
|
|
.HasColumnName("uscita_4");
|
|
});
|
|
|
|
modelBuilder.Entity<AnagClientiModel>(entity =>
|
|
{
|
|
entity.Property(e => e.IdxCliente).HasColumnName("idxCliente");
|
|
|
|
entity.Property(e => e.Attivo).HasDefaultValueSql("((1))");
|
|
|
|
entity.Property(e => e.Cap)
|
|
.HasMaxLength(5)
|
|
.HasColumnName("CAP");
|
|
|
|
entity.Property(e => e.Cf)
|
|
.HasMaxLength(20)
|
|
.HasColumnName("CF");
|
|
|
|
entity.Property(e => e.Citta)
|
|
.HasMaxLength(50)
|
|
.HasColumnName("citta");
|
|
|
|
entity.Property(e => e.CodExt)
|
|
.HasMaxLength(50)
|
|
.HasColumnName("codExt")
|
|
.HasDefaultValueSql("('n.d.')")
|
|
.HasComment("codice esterno");
|
|
|
|
entity.Property(e => e.Email)
|
|
.HasMaxLength(50)
|
|
.HasColumnName("email");
|
|
|
|
entity.Property(e => e.Indirizzo)
|
|
.HasMaxLength(50)
|
|
.HasColumnName("indirizzo");
|
|
|
|
entity.Property(e => e.LogoUrl)
|
|
.HasMaxLength(50)
|
|
.HasColumnName("logoUrl");
|
|
|
|
entity.Property(e => e.Nota)
|
|
.HasMaxLength(500)
|
|
.HasColumnName("nota");
|
|
|
|
entity.Property(e => e.OldIdx).HasDefaultValueSql("((-1))");
|
|
|
|
entity.Property(e => e.PIva)
|
|
.HasMaxLength(20)
|
|
.HasColumnName("pIva");
|
|
|
|
entity.Property(e => e.Prov)
|
|
.HasMaxLength(50)
|
|
.HasColumnName("prov");
|
|
|
|
entity.Property(e => e.RagSociale).HasMaxLength(250);
|
|
|
|
entity.Property(e => e.Tel)
|
|
.HasMaxLength(50)
|
|
.HasColumnName("tel");
|
|
|
|
entity.Property(e => e.Url)
|
|
.HasMaxLength(50)
|
|
.HasColumnName("url");
|
|
});
|
|
|
|
modelBuilder.Entity<AnagFasiModel>(entity =>
|
|
{
|
|
entity.HasIndex(e => new { e.IdxProgetto, e.Attivo }, "ix_AnagFasi_idxProgetto_Attivo");
|
|
|
|
entity.Property(e => e.IdxFase).HasColumnName("idxFase");
|
|
|
|
entity.Property(e => e.Attivo)
|
|
.IsRequired()
|
|
.HasDefaultValueSql("((1))");
|
|
|
|
entity.Property(e => e.BudgetMoney)
|
|
.HasColumnType("decimal(19, 4)")
|
|
.HasColumnName("budgetMoney");
|
|
|
|
entity.Property(e => e.BudgetTime)
|
|
.HasColumnType("decimal(19, 4)")
|
|
.HasColumnName("budgetTime")
|
|
.HasComment("Budget del progetto (in ore)");
|
|
|
|
entity.Property(e => e.CodClasse)
|
|
.HasMaxLength(10)
|
|
.HasColumnName("codClasse")
|
|
.HasComment("codice univoco");
|
|
|
|
entity.Property(e => e.CodExt)
|
|
.HasMaxLength(50)
|
|
.HasColumnName("codExt")
|
|
.HasComment("codice esterno");
|
|
|
|
entity.Property(e => e.CodFase)
|
|
.HasMaxLength(250)
|
|
.HasColumnName("codFase")
|
|
.HasComment("codice fase gerarchico (F.1.2. = Fase 1, sottofase 2) - aggiornare con trigger!");
|
|
|
|
entity.Property(e => e.DescrizioneFase)
|
|
.HasMaxLength(250)
|
|
.HasColumnName("descrizioneFase");
|
|
|
|
entity.Property(e => e.EnableMoney)
|
|
.HasColumnName("enableMoney")
|
|
.HasDefaultValueSql("((0))")
|
|
.HasComment("indica se sia abilitata o meno a ricevere assegnazioni di record di spesa");
|
|
|
|
entity.Property(e => e.EnableTime)
|
|
.HasColumnName("enableTime")
|
|
.HasDefaultValueSql("((0))")
|
|
.HasComment("indica se sia abilitata o meno a ricevere assegnazioni di record temporali");
|
|
|
|
entity.Property(e => e.IdxFaseAncest)
|
|
.HasColumnName("idxFaseAncest")
|
|
.HasComment("fase ANCESTOR (contenitore), 0 = è top level");
|
|
|
|
entity.Property(e => e.IdxProgetto).HasColumnName("idxProgetto");
|
|
|
|
entity.Property(e => e.NomeFase)
|
|
.HasMaxLength(250)
|
|
.HasColumnName("nomeFase");
|
|
});
|
|
|
|
modelBuilder.Entity<AnagFasiModel>().ToTable(tb => tb.HasTrigger("trg_AF_calcCodFaseIdxProj"));
|
|
|
|
modelBuilder.Entity<AnagProgettiModel>(entity =>
|
|
{
|
|
entity.Property(e => e.IdxProgetto).HasColumnName("idxProgetto");
|
|
|
|
entity.Property(e => e.Attivo)
|
|
.IsRequired()
|
|
.HasDefaultValueSql("((1))");
|
|
|
|
entity.Property(e => e.Avvio)
|
|
.HasColumnType("datetime")
|
|
.HasColumnName("avvio")
|
|
.HasDefaultValueSql("(getdate())");
|
|
|
|
entity.Property(e => e.Chiusura)
|
|
.HasColumnType("datetime")
|
|
.HasColumnName("chiusura")
|
|
.HasDefaultValueSql("(dateadd(year,(10),getdate()))");
|
|
|
|
entity.Property(e => e.CodExt)
|
|
.HasMaxLength(50)
|
|
.HasColumnName("codExt")
|
|
.HasDefaultValueSql("('')")
|
|
.HasComment("codice esterno");
|
|
|
|
entity.Property(e => e.DescrProj)
|
|
.HasMaxLength(250)
|
|
.HasColumnName("descrProj")
|
|
.HasDefaultValueSql("('-')");
|
|
|
|
entity.Property(e => e.Gruppo)
|
|
.HasMaxLength(50)
|
|
.HasColumnName("gruppo")
|
|
.HasDefaultValueSql("('STEAMWARE')");
|
|
|
|
entity.Property(e => e.IdxCliente).HasColumnName("idxCliente");
|
|
|
|
entity.Property(e => e.NomeProj)
|
|
.HasMaxLength(50)
|
|
.HasColumnName("nomeProj");
|
|
|
|
entity.Property(e => e.Starred).HasColumnName("starred");
|
|
});
|
|
|
|
modelBuilder.Entity<AnagProgettiModel>().ToTable(tb => tb.HasTrigger("trg_AP_storicizza"));
|
|
|
|
modelBuilder.Entity<AnagGruppiModel>(entity =>
|
|
{
|
|
entity.HasKey(e => e.Gruppo);
|
|
|
|
entity.ToTable("AnagGruppi");
|
|
|
|
entity.Property(e => e.Gruppo)
|
|
.HasMaxLength(50)
|
|
.HasColumnName("gruppo");
|
|
|
|
entity.Property(e => e.CodExt)
|
|
.HasMaxLength(4)
|
|
.HasColumnName("codExt");
|
|
|
|
entity.Property(e => e.DescrGruppo)
|
|
.HasMaxLength(50)
|
|
.HasColumnName("descrGruppo");
|
|
|
|
entity.Property(e => e.ExportEnab)
|
|
.HasColumnName("exportEnab")
|
|
.HasDefaultValueSql("((1))")
|
|
.HasComment("determina se sia abilitato x export dati");
|
|
});
|
|
|
|
modelBuilder.Entity<AnagKeyValueModel>(entity =>
|
|
{
|
|
entity.HasKey(e => e.NomeVar);
|
|
|
|
entity.ToTable("AnagKeyValue");
|
|
|
|
entity.Property(e => e.NomeVar)
|
|
.HasMaxLength(50)
|
|
.HasColumnName("nomeVar");
|
|
|
|
entity.Property(e => e.Descrizione)
|
|
.HasMaxLength(250)
|
|
.HasColumnName("descrizione")
|
|
.HasDefaultValueSql("('-')");
|
|
|
|
entity.Property(e => e.ValFloat)
|
|
.HasColumnName("valFloat")
|
|
.HasDefaultValueSql("((0))");
|
|
|
|
entity.Property(e => e.ValInt)
|
|
.HasColumnName("valInt")
|
|
.HasDefaultValueSql("((0))");
|
|
|
|
entity.Property(e => e.ValString)
|
|
.HasMaxLength(250)
|
|
.HasColumnName("valString")
|
|
.HasDefaultValueSql("('')");
|
|
});
|
|
|
|
modelBuilder.Entity<Dipendenti2GruppiModel>(entity =>
|
|
{
|
|
entity.HasKey(e => new { e.IdxDipendente, e.Gruppo });
|
|
|
|
entity.ToTable("Dipendenti2Gruppi");
|
|
|
|
entity.Property(e => e.IdxDipendente).HasColumnName("idxDipendente");
|
|
|
|
entity.Property(e => e.Gruppo)
|
|
.HasMaxLength(50)
|
|
.HasColumnName("gruppo");
|
|
});
|
|
|
|
modelBuilder.Entity<AnagOrariModel>(entity =>
|
|
{
|
|
entity.Property(e => e.oraInizio1)
|
|
.HasMaxLength(50)
|
|
.HasColumnName("oraInizio_1");
|
|
entity.Property(e => e.oraInizio2)
|
|
.HasMaxLength(50)
|
|
.HasColumnName("oraInizio_2");
|
|
entity.Property(e => e.oraInizio3)
|
|
.HasMaxLength(50)
|
|
.HasColumnName("oraInizio_3");
|
|
entity.Property(e => e.oraFine1)
|
|
.HasMaxLength(50)
|
|
.HasColumnName("oraFine_1");
|
|
entity.Property(e => e.oraFine2)
|
|
.HasMaxLength(50)
|
|
.HasColumnName("oraFine_2");
|
|
entity.Property(e => e.oraFine3)
|
|
.HasMaxLength(50)
|
|
.HasColumnName("oraFine_3");
|
|
});
|
|
|
|
modelBuilder.Entity<CalFesteFerieModel>(entity =>
|
|
{
|
|
entity.Property(e => e.codGiust)
|
|
.HasMaxLength(5);
|
|
entity.Property(e => e.descrizione)
|
|
.HasMaxLength(50);
|
|
});
|
|
|
|
modelBuilder.Entity<CalFesteFerieModel>().ToTable(tb => tb.HasTrigger("trg_calFF2giust"));
|
|
|
|
modelBuilder.Entity<RegMalattieModel>(entity =>
|
|
{
|
|
entity.Property(e => e.CodCert)
|
|
.HasMaxLength(250);
|
|
});
|
|
|
|
modelBuilder.Entity<RegRichiesteModel>(entity =>
|
|
{
|
|
entity.Property(e => e.CodGiust)
|
|
.HasMaxLength(5);
|
|
});
|
|
|
|
modelBuilder.Entity<ConfigModel>(entity =>
|
|
{
|
|
entity.Property(e => e.chiave)
|
|
.HasMaxLength(250);
|
|
entity.Property(e => e.valore)
|
|
.HasMaxLength(250);
|
|
entity.Property(e => e.valoreStd)
|
|
.HasMaxLength(250);
|
|
entity.Property(e => e.note)
|
|
.HasMaxLength(250);
|
|
});
|
|
|
|
modelBuilder.Entity<AnagGiustModel>(entity =>
|
|
{
|
|
entity.Property(e => e.codGiust)
|
|
.HasMaxLength(5);
|
|
entity.Property(e => e.descrizione)
|
|
.HasMaxLength(50);
|
|
});
|
|
|
|
modelBuilder.Entity<AnagDeviceModel>(entity =>
|
|
{
|
|
entity.HasKey(e => e.IdxDevice);
|
|
|
|
entity.Property(e => e.DataOraEnabled)
|
|
.HasColumnType("datetime")
|
|
.HasColumnName("dataOraEnabled");
|
|
|
|
entity.Property(e => e.DataOraLastSeen)
|
|
.HasColumnType("datetime")
|
|
.HasColumnName("dataOraLastSeen");
|
|
|
|
entity.Property(e => e.Description)
|
|
.HasMaxLength(500)
|
|
.HasDefaultValueSql("('')");
|
|
|
|
entity.Property(e => e.DeviceName).HasMaxLength(50);
|
|
|
|
entity.Property(e => e.DeviceSecret).HasMaxLength(500);
|
|
|
|
entity.Property(e => e.IdxDipendente).HasColumnName("idxDipendente");
|
|
|
|
entity.Property(e => e.LastIpv4)
|
|
.HasMaxLength(15)
|
|
.HasColumnName("lastIPv4")
|
|
.HasDefaultValueSql("('')");
|
|
|
|
entity.Property(e => e.ScreenSize)
|
|
.HasMaxLength(50)
|
|
.HasColumnName("screenSize")
|
|
.HasDefaultValueSql("('')");
|
|
});
|
|
|
|
modelBuilder.Entity<Dipendenti2RuoliModel>(entity =>
|
|
{
|
|
entity.HasKey(e => new { e.IdxDipendente, e.CodRuolo })
|
|
.HasName("PK_Dipendenti2Ruoli");
|
|
entity.Property(e => e.CodRuolo)
|
|
.HasMaxLength(50);
|
|
});
|
|
|
|
modelBuilder.Entity<RegistroEventiModel>(entity =>
|
|
{
|
|
entity.HasKey(e => new { e.DataOra, e.Evento });
|
|
|
|
entity.ToTable("RegistroEventi");
|
|
|
|
entity.Property(e => e.DataOra).HasColumnType("datetime");
|
|
|
|
entity.Property(e => e.Evento)
|
|
.HasMaxLength(50)
|
|
.HasColumnName("evento");
|
|
|
|
entity.Property(e => e.Commento)
|
|
.HasMaxLength(250)
|
|
.HasColumnName("commento");
|
|
});
|
|
|
|
modelBuilder.Entity<TeRaExplModel>(entity =>
|
|
{
|
|
entity.HasKey(e => new { e.DataLav, e.IdxDipendente });
|
|
});
|
|
|
|
modelBuilder.Entity<MonthTagModel>(entity =>
|
|
{
|
|
entity.HasKey(e => new { e.Anno, e.Mese, e.IdxDipendente });
|
|
});
|
|
|
|
modelBuilder.Entity<TimbMeseExplModel>(entity =>
|
|
{
|
|
entity.HasKey(e => new { e.Anno, e.Mese, e.IdxDipendente });
|
|
});
|
|
|
|
OnModelCreatingPartial(modelBuilder);
|
|
}
|
|
|
|
#endregion Protected Methods
|
|
|
|
#region Private Fields
|
|
|
|
private static NLog.Logger Log = LogManager.GetCurrentClassLogger();
|
|
|
|
private IConfiguration _configuration = null!;
|
|
|
|
#endregion Private Fields
|
|
|
|
#region Private Methods
|
|
|
|
partial void OnModelCreatingPartial(ModelBuilder modelBuilder);
|
|
|
|
#endregion Private Methods
|
|
}
|
|
} |