Files
Data-Coupler/CredentialManager/Models/DataCouplerProfile.cs
T
Alessio 7d2961702c feat: Aggiunta gestione nome database sorgente nei profili DataCoupler
 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

🧪
2025-07-05 18:10:09 +02:00

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