[Feature] Implementazione completa supporto ODBC

- Aggiunta persistenza campi ODBC (OdbcDsnName, OdbcMode) in CredentialEntity
- Creata migration EF Core per nuovi campi database
- Aggiornato mapping credenziali per caricare/salvare dati ODBC
- Creato OdbcDatabaseManager dedicato (bypass EF Core che non supporta ODBC)
- Aggiornato DataConnectionFactory per usare OdbcDatabaseManager con connessioni ODBC
- Fix auto-load DSN: sostituito @onchange con @bind-Value:after in dropdown tipo database
- Fix test connessione SAP HANA: rimossa query SELECT 1 che causava errori sintassi
- Implementati tutti i metodi IDatabaseManager in OdbcDatabaseManager
- Supporto completo per discovery schema, tabelle e query ODBC

Risolve problema DbContext non configurato per ODBC e abilita connessioni ODBC complete.
This commit is contained in:
Alessio Dal Santo
2026-02-02 18:24:44 +01:00
parent e7fb9a5cc7
commit 01f78466df
22 changed files with 3615 additions and 49 deletions
@@ -89,6 +89,8 @@ public class CredentialService : ICredentialService
AdditionalParameters = credential.AdditionalParameters != null
? JsonSerializer.Serialize(credential.AdditionalParameters)
: null,
OdbcDsnName = credential.OdbcDsnName,
OdbcMode = credential.OdbcMode.ToString(),
CreatedAt = DateTime.UtcNow,
CreatedBy = Environment.UserName
};
@@ -110,6 +112,8 @@ public class CredentialService : ICredentialService
existing.CommandTimeout = entity.CommandTimeout;
existing.IgnoreSslErrors = entity.IgnoreSslErrors;
existing.AdditionalParameters = entity.AdditionalParameters;
existing.OdbcDsnName = entity.OdbcDsnName;
existing.OdbcMode = entity.OdbcMode;
existing.UpdatedAt = DateTime.UtcNow;
_context.Credentials.Update(existing);
@@ -695,7 +699,11 @@ public class CredentialService : ICredentialService
Password = DecryptSafely(entity.EncryptedPassword, entity.Name, "password"),
ConnectionString = entity.ConnectionString,
CommandTimeout = entity.CommandTimeout,
IgnoreSslErrors = entity.IgnoreSslErrors
IgnoreSslErrors = entity.IgnoreSslErrors,
OdbcDsnName = entity.OdbcDsnName,
OdbcMode = !string.IsNullOrEmpty(entity.OdbcMode) && Enum.TryParse<OdbcConnectionMode>(entity.OdbcMode, out var odbcMode)
? odbcMode
: OdbcConnectionMode.Dsn
};
if (!string.IsNullOrEmpty(entity.AdditionalParameters))