using System;
using System.Collections.Generic;
using System.Linq.Expressions;
using System.Threading.Tasks;
namespace DataConnection.Interfaces;
///
/// Interfaccia per la gestione di database preesistenti tramite EF Core
///
public interface IDatabaseManager : IDisposable
{
///
/// Verifica la connessione al database
///
Task TestConnectionAsync();
///
/// Ottiene entità dal database in base ai criteri specificati
///
/// Tipo di entità
/// Espressione di filtro
/// Espressione di ordinamento
/// Proprietà di navigazione da includere
/// Numero di elementi da saltare
/// Numero di elementi da prendere
Task> GetAsync(
Expression>? filter = null,
Func, IOrderedQueryable>? orderBy = null,
string includeProperties = "",
int? skip = null,
int? take = null) where T : class;
///
/// Ottiene un'entità singola in base alla chiave primaria
///
Task GetByIdAsync(object id) where T : class;
///
/// Esegue una query SQL raw
///
Task> ExecuteQueryAsync(string sql, params object[] parameters) where T : class;
///
/// Esegue una query SQL raw e restituisce i risultati come dictionary
///
Task>> ExecuteRawQueryAsync(string sql, params object[] parameters);
///
/// Esegue un comando SQL che non restituisce risultati
///
Task ExecuteCommandAsync(string sql, params object[] parameters);
///
/// Ottiene l'elenco dei database disponibili sul server
///
Task> GetAvailableDatabasesAsync();
///
/// Cambia il database corrente per la connessione
///
Task ChangeDatabaseAsync(string databaseName);
///
/// Ottiene i metadati delle tabelle nel database
///
Task>> GetDatabaseSchemaAsync();
///
/// Ottiene solo la lista dei nomi delle tabelle disponibili (senza dettagli delle colonne)
///
Task> GetTableNamesAsync();
///
/// Ottiene i dettagli delle colonne per una specifica tabella
///
/// Nome della tabella (con schema se necessario)
Task> GetTableSchemaAsync(string tableName);
///
/// Ottiene tutti i record da una tabella specifica come dizionari chiave-valore
///
Task>> GetAllRecordsAsync(string tableName);
///
/// Ottiene il nome del campo Primary Key di una tabella specifica
///
Task GetPrimaryKeyFieldAsync(string tableName);
}
///
/// Informazioni su una colonna del database
///
public class DbColumnInfo
{
public string Name { get; set; } = string.Empty;
public string DataType { get; set; } = string.Empty;
public bool IsNullable { get; set; }
public bool IsPrimaryKey { get; set; }
public bool IsForeignKey { get; set; }
public string? ReferencedTable { get; set; }
public string? ReferencedColumn { get; set; }
}