7d2961702c
✨ Nuove funzionalità: - Aggiunto campo SourceDatabaseName nella tabella DataCouplerProfiles - Implementato recupero automatico del nome database dalle credenziali - Migliorata applicazione profili con supporto database specifico - Aggiornata logica di connessione database con selezione database 🔧 Modifiche tecniche: - Aggiunta migration per colonna SourceDatabaseName - Estesi modelli DataCouplerProfile e DataCouplerProfileDto - Aggiornato DataCouplerProfileService per gestire nuovo campo - Modificato ProfileSaver per recupero automatico database name - Implementato metodo ConnectToDatabaseWithSpecificDatabase 🐛 Correzioni: - Migliorata gestione connessioni database multi-database - Corretta formattazione codice e spaziature - Rimosse linee vuote eccessive nel codice sorgente 🧪
83 lines
2.2 KiB
C#
83 lines
2.2 KiB
C#
using System.ComponentModel.DataAnnotations;
|
|
using System.ComponentModel.DataAnnotations.Schema;
|
|
|
|
namespace CredentialManager.Models;
|
|
|
|
/// <summary>
|
|
/// Modello per salvare le configurazioni dei profili di Data Coupler
|
|
/// </summary>
|
|
public class DataCouplerProfile
|
|
{
|
|
[Key]
|
|
public int Id { get; set; }
|
|
|
|
[Required]
|
|
[MaxLength(100)]
|
|
public string Name { get; set; } = string.Empty;
|
|
|
|
[MaxLength(500)]
|
|
public string? Description { get; set; }
|
|
|
|
// Configurazione Fonte Dati
|
|
[Required]
|
|
[MaxLength(20)]
|
|
public string SourceType { get; set; } = string.Empty; // "database" o "file"
|
|
|
|
public int? SourceCredentialId { get; set; }
|
|
|
|
[MaxLength(200)]
|
|
public string? SourceDatabaseName { get; set; }
|
|
|
|
[MaxLength(200)]
|
|
public string? SourceSchema { get; set; }
|
|
|
|
[MaxLength(200)]
|
|
public string? SourceTable { get; set; }
|
|
|
|
[MaxLength(500)]
|
|
public string? SourceFilePath { get; set; }
|
|
|
|
// Configurazione Destinazione
|
|
[Required]
|
|
[MaxLength(20)]
|
|
public string DestinationType { get; set; } = string.Empty; // "database" o "rest"
|
|
|
|
public int? DestinationCredentialId { get; set; }
|
|
|
|
[MaxLength(200)]
|
|
public string? DestinationSchema { get; set; }
|
|
|
|
[MaxLength(200)]
|
|
public string? DestinationTable { get; set; }
|
|
|
|
[MaxLength(500)]
|
|
public string? DestinationEndpoint { get; set; }
|
|
|
|
// Mapping dei campi salvato come JSON
|
|
[MaxLength(4000)]
|
|
public string? FieldMappingJson { get; set; }
|
|
|
|
// Configurazione chiave sorgente e associazioni
|
|
[MaxLength(200)]
|
|
public string? SourceKeyField { get; set; }
|
|
|
|
public bool UseRecordAssociations { get; set; } = false;
|
|
|
|
// Metadati
|
|
[MaxLength(100)]
|
|
public string? CreatedBy { get; set; }
|
|
|
|
public DateTime CreatedAt { get; set; } = DateTime.UtcNow;
|
|
|
|
public DateTime? LastUsedAt { get; set; }
|
|
|
|
public bool IsActive { get; set; } = true;
|
|
|
|
// Relazioni opzionali con le credenziali
|
|
[ForeignKey(nameof(SourceCredentialId))]
|
|
public virtual CredentialEntity? SourceCredential { get; set; }
|
|
|
|
[ForeignKey(nameof(DestinationCredentialId))]
|
|
public virtual CredentialEntity? DestinationCredential { get; set; }
|
|
}
|