Catalog/imagecatalog/ParametriSetup.cs

239 lines
7.7 KiB
C#
Raw Normal View History

2021-03-04 10:44:09 +01:00
using System;
using System.Data;
namespace ImageCatalog
{
public class ParametriSetup
{
2025-09-19 10:56:39 +02:00
private DataSet _elencoParametri;
public string NomeFileSetup { get; set; }
2021-03-04 10:44:09 +01:00
2025-09-19 10:56:39 +02:00
public ParametriSetup(string fileSetup)
2021-03-04 10:44:09 +01:00
{
2025-09-19 10:56:39 +02:00
_elencoParametri = new DataSet();
NomeFileSetup = fileSetup;
if (!string.IsNullOrWhiteSpace(fileSetup))
2021-03-04 10:44:09 +01:00
{
CaricaParametriSetup();
}
}
2025-09-19 10:56:39 +02:00
public ParametriSetup() : this(string.Empty)
2021-03-04 10:44:09 +01:00
{
}
public void CaricaParametriSetup()
{
2025-09-19 10:56:39 +02:00
if (string.IsNullOrEmpty(NomeFileSetup) || !File.Exists(NomeFileSetup))
{
_elencoParametri = new DataSet();
return;
}
_elencoParametri = LeggiXmlDataSet("Setup", NomeFileSetup, "Nome");
2021-03-04 10:44:09 +01:00
}
public void SalvaParametriSetup()
{
2025-09-19 10:56:39 +02:00
if (string.IsNullOrWhiteSpace(NomeFileSetup))
throw new InvalidOperationException("NomeFileSetup is not set.");
2021-03-04 10:44:09 +01:00
2025-09-19 10:56:39 +02:00
// overwrite without FileSystem.Kill
_elencoParametri.WriteXml(NomeFileSetup, XmlWriteMode.WriteSchema);
2021-03-04 10:44:09 +01:00
}
2025-09-19 10:56:39 +02:00
// public string LeggiParametroString(string NomeParametro)
// {
// string Risposta = "";
// try
// {
// var LElenco = _elencoParametri.Tables["Setup"].Select("Nome='" + NomeParametro + "'");
// foreach (var LaRiga in LElenco)
// Risposta = LaRiga["Valore"].ToString();
// }
// catch
// {
// Risposta = "";
// }
//
// return Risposta;
// }
//
// public bool LeggiParametroBoolean(string nomeParametro)
// {
// var risposta = "";
// try
// {
// var lElenco = _elencoParametri.Tables["Setup"].Select("Nome='" + nomeParametro + "'");
// foreach (var laRiga in lElenco)
// risposta = laRiga["Valore"].ToString();
// }
// catch
// {
// risposta = "";
// }
//
// switch (risposta.ToUpper() ?? "")
// {
// case "TRUE":
// case "OK":
// case "SI":
// case "1":
// case "YES":
// case "VERO":
// {
// return true;
// }
//
// default:
// {
// return false;
// }
// }
// }
public string LeggiParametroString(string nomeParametro)
2021-03-04 10:44:09 +01:00
{
2025-09-19 10:56:39 +02:00
return GetRow(nomeParametro)?["Valore"]?.ToString() ?? string.Empty;
2021-03-04 10:44:09 +01:00
}
2025-07-28 14:45:03 +02:00
public bool LeggiParametroBoolean(string nomeParametro)
2021-03-04 10:44:09 +01:00
{
2025-09-19 10:56:39 +02:00
var raw = LeggiParametroString(nomeParametro);
return raw?.ToUpperInvariant() switch
2021-03-04 10:44:09 +01:00
{
2025-09-19 10:56:39 +02:00
"TRUE" or "OK" or "SI" or "1" or "YES" or "VERO" => true,
_ => false
};
}
public void AggiornaParametro(string nomeParametro, object valoreParametro)
{
var table = EnsureSetupTable();
var rows = table.Select($"Nome='{nomeParametro.Replace("'", "''")}'");
if (rows.Length == 0)
2021-03-04 10:44:09 +01:00
{
2025-09-19 10:56:39 +02:00
var newRow = table.NewRow();
newRow["Nome"] = nomeParametro;
newRow["Valore"] = valoreParametro?.ToString() ?? string.Empty;
table.Rows.Add(newRow);
2021-03-04 10:44:09 +01:00
}
2025-09-19 10:56:39 +02:00
else
2021-03-04 10:44:09 +01:00
{
2025-09-19 10:56:39 +02:00
rows[0]["Valore"] = valoreParametro?.ToString() ?? string.Empty;
2021-03-04 10:44:09 +01:00
}
}
2025-09-19 10:56:39 +02:00
public T LeggiParametro<T>(string nomeParametro, T defaultValue = default!)
2021-03-04 10:44:09 +01:00
{
2025-09-19 10:56:39 +02:00
var raw = LeggiParametroString(nomeParametro);
if (string.IsNullOrEmpty(raw)) return defaultValue;
2021-03-04 10:44:09 +01:00
try
{
2025-09-19 10:56:39 +02:00
return (T)Convert.ChangeType(raw, typeof(T));
2021-03-04 10:44:09 +01:00
}
catch
{
2025-09-19 10:56:39 +02:00
return defaultValue;
2021-03-04 10:44:09 +01:00
}
}
2025-09-19 10:56:39 +02:00
private static DataSet LeggiXmlDataSet(string nomeTabella, string nomeFileXml, string nomeColonnaChiave = "")
2021-03-04 10:44:09 +01:00
{
2025-09-19 10:56:39 +02:00
var ds = new DataSet();
ds.ReadXml(nomeFileXml);
2021-03-04 10:44:09 +01:00
2025-09-19 10:56:39 +02:00
if (!string.IsNullOrEmpty(nomeColonnaChiave) && ds.Tables.Contains(nomeTabella))
2021-03-04 10:44:09 +01:00
{
2025-09-19 10:56:39 +02:00
var table = ds.Tables[nomeTabella];
if (table.Constraints[nomeColonnaChiave] == null)
{
table.Constraints.Add(nomeColonnaChiave, table.Columns[nomeColonnaChiave], true);
}
2021-03-04 10:44:09 +01:00
}
2025-09-19 10:56:39 +02:00
return ds;
2021-03-04 10:44:09 +01:00
}
2025-09-19 10:56:39 +02:00
private DataTable EnsureSetupTable()
2021-03-04 10:44:09 +01:00
{
2025-09-19 10:56:39 +02:00
if (!_elencoParametri.Tables.Contains("Setup"))
2021-03-04 10:44:09 +01:00
{
2025-09-19 10:56:39 +02:00
var table = new DataTable("Setup");
table.Columns.Add("Nome", typeof(string));
table.Columns.Add("Valore", typeof(string));
_elencoParametri.Tables.Add(table);
2021-03-04 10:44:09 +01:00
}
2025-09-19 10:56:39 +02:00
return _elencoParametri.Tables["Setup"];
2021-03-04 10:44:09 +01:00
}
2025-09-19 10:56:39 +02:00
private DataRow? GetRow(string nomeParametro)
2021-03-04 10:44:09 +01:00
{
2025-09-19 10:56:39 +02:00
if (!_elencoParametri.Tables.Contains("Setup")) return null;
var rows = _elencoParametri.Tables["Setup"]
.Select($"Nome='{nomeParametro.Replace("'", "''")}'");
return rows.FirstOrDefault();
2021-03-04 10:44:09 +01:00
}
}
2025-09-19 10:56:39 +02:00
// public void AggiornaParametro(string NomeParametro, object ValoreParametro)
// {
// try
// {
// if (_elencoParametri.Tables["Setup"] is null)
// {
// var TabellaTmp = new DataTable("Setup");
// DataRow RigaTmp;
// DataColumn LaColonna;
// LaColonna = TabellaTmp.Columns.Add("Nome", Type.GetType("System.String"));
// LaColonna = TabellaTmp.Columns.Add("Valore", Type.GetType("System.String"));
//
// // * Aggiunge alla tabella tutte le righe
// RigaTmp = TabellaTmp.NewRow();
// RigaTmp["Nome"] = NomeParametro;
// RigaTmp["Valore"] = ValoreParametro;
// TabellaTmp.Rows.Add(RigaTmp);
// _elencoParametri.Tables.Add(TabellaTmp);
// }
// else
// {
// var LElenco = _elencoParametri.Tables["Setup"].Select("Nome='" + NomeParametro + "'");
// if (LElenco.Length == 0)
// {
// DataRow LaRiga;
// LaRiga = _elencoParametri.Tables["Setup"].NewRow();
// LaRiga["Nome"] = NomeParametro;
// LaRiga["Valore"] = ValoreParametro;
// _elencoParametri.Tables["Setup"].Rows.Add(LaRiga);
// }
// else
// {
// LElenco[0]["Valore"] = ValoreParametro;
// }
// }
// }
// catch
// {
// }
// }
// private static DataSet LeggiXmlDataSet(string NomeTabella, string NomeFileXml, string NomeColonnaChiave = "")
// {
// // * Crea e Legge il dataset dal file xml
// var DataSetXml = new DataSet();
// DataSetXml.ReadXml(NomeFileXml);
//
// // * Aggiunge il campo chiave
// if (!string.IsNullOrEmpty(NomeColonnaChiave))
// {
// DataSetXml.Tables[NomeTabella].Constraints.Add(NomeColonnaChiave, DataSetXml.Tables[NomeTabella].Columns[NomeColonnaChiave], true);
// }
//
// // * Restituisce la risposta
// return DataSetXml;
// }
//}
2021-03-04 10:44:09 +01:00
}