Files
Samuele Locatelli 1648ad0349 Altri update pagine
2025-06-21 11:53:07 +02:00

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
}
}