Konfiguration.cs 10.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Linq;
  4. using System.Text.RegularExpressions;
  5. using GCHR.Control;
  6. using GCHR.Control.IO;
  7. using GCHR.Mandantenschnittstelle;
  8. using GCHR.Model.Konto;
  9. namespace GCHR.Model
  10. {
  11. public class Konfiguration
  12. {
  13. #region Singleton
  14. private static Konfiguration _instance;
  15. public static Konfiguration CreateInstance(string cfgDatei)
  16. {
  17. return _instance ?? (_instance = new Konfiguration(cfgDatei));
  18. }
  19. public static Konfiguration GetInstance()
  20. {
  21. if (_instance == null)
  22. {
  23. throw new NullReferenceException("Konfiguration nicht initialisiert!");
  24. }
  25. return _instance;
  26. }
  27. #endregion
  28. private readonly GchrConfig _gchrConfig;
  29. private readonly Konten _konten;
  30. private readonly string _configDatei;
  31. public Periode AktuellePeriode { get; set; }
  32. public Konfiguration(string cfgDatei)
  33. {
  34. AktuellePeriode = new Periode("200001");
  35. _configDatei = cfgDatei;
  36. _gchrConfig = (GchrConfig)new GchrConfigIO(_configDatei).Laden();
  37. _konten = (Konten) new KontenIO(_gchrConfig.Dateipfade.ManuelleKonten).Laden();
  38. KontenXmlUmsortieren();
  39. Periode.Dateipfade = _gchrConfig.Dateipfade;
  40. Periode.ErsterMonatImGeschaeftsjahr = _gchrConfig.Einstellungen.Geschaeftsjahr;
  41. AktuellePeriode = new Periode("200001");
  42. Logger.ConfigDatei = cfgDatei;
  43. if (!Logger.DateiExistiert)
  44. {
  45. Speichern();
  46. }
  47. }
  48. private void KontenXmlUmsortieren()
  49. {
  50. if (_konten.Kontenliste.Count > 0 || _gchrConfig.Konten == null || _gchrConfig.Konten.Count == 0) return;
  51. foreach (var kto in _gchrConfig.Konten)
  52. {
  53. if (kto.Periode != null && kto.Periode.Count == 0) kto.Periode = null;
  54. if (kto.Periode == null) continue;
  55. kto.ZugeordneteSaldi = kto.Periode;
  56. kto.Periode = null;
  57. }
  58. _konten.Kontenliste = _gchrConfig.Konten;
  59. _gchrConfig.Konten = null;
  60. Speichern();
  61. }
  62. public void Speichern()
  63. {
  64. ManuelleKontenSpeichern();
  65. new GchrConfigIO(_configDatei).Speichern(_gchrConfig);
  66. }
  67. public void ManuelleKontenSpeichern()
  68. {
  69. new KontenIO(_gchrConfig.Dateipfade.ManuelleKonten).Speichern(_konten);
  70. }
  71. public string Haendler
  72. {
  73. get
  74. {
  75. return _gchrConfig.Einstellungen.Haendler;
  76. }
  77. }
  78. public string Haendlernummer
  79. {
  80. get
  81. {
  82. return _gchrConfig.Einstellungen.Haendlernummer;
  83. }
  84. }
  85. public string Hauptmarke
  86. {
  87. get
  88. {
  89. return _gchrConfig.Einstellungen.Hauptmarke;
  90. }
  91. }
  92. public string Hauptbetrieb
  93. {
  94. get
  95. {
  96. return _gchrConfig.Einstellungen.Hauptbetrieb;
  97. }
  98. }
  99. public string BilanzMarke
  100. {
  101. get
  102. {
  103. return _gchrConfig.Einstellungen.BilanzMarke;
  104. }
  105. }
  106. public string BilanzBetrieb
  107. {
  108. get
  109. {
  110. return _gchrConfig.Einstellungen.BilanzBetrieb;
  111. }
  112. }
  113. public string Eurodatanummer
  114. {
  115. get
  116. {
  117. if (_gchrConfig.Einstellungen.Eurodatanummer == null)
  118. {
  119. _gchrConfig.Einstellungen.Eurodatanummer = "00000000";
  120. Logger.Info("Eurodatanummer wurde bisher noch nicht festgelegt. Bitte in config.xml anpassen!");
  121. }
  122. return _gchrConfig.Einstellungen.Eurodatanummer.PadLeft(8, '0');
  123. }
  124. }
  125. public string Geschaeftsjahr
  126. {
  127. get
  128. {
  129. return _gchrConfig.Einstellungen.Geschaeftsjahr;
  130. }
  131. }
  132. public int HerstellerKontenrahmenStellen
  133. {
  134. get
  135. {
  136. return _gchrConfig.Einstellungen.Herstellerkontenrahmen;
  137. }
  138. }
  139. public int HaendlerKontenrahmenStellen
  140. {
  141. get
  142. {
  143. return _gchrConfig.Einstellungen.Haendlerkontenrahmen;
  144. }
  145. }
  146. public string SuSaKontenQuery
  147. {
  148. get
  149. {
  150. return QueryAnpassen(Constants.Decrypt(_gchrConfig.Einstellungen.Abfragen.SuSaKontenQuery), AktuellePeriode);
  151. }
  152. }
  153. public string StatKontenQuery
  154. {
  155. get
  156. {
  157. return QueryAnpassen(Constants.Decrypt(_gchrConfig.Einstellungen.Abfragen.StatKontenQuery), AktuellePeriode);
  158. }
  159. }
  160. public Mandanten Mandantenname
  161. {
  162. get
  163. {
  164. return _gchrConfig.Einstellungen.Mandantenname;
  165. }
  166. }
  167. public bool KontoOhneUebersetzungUebernehmen
  168. {
  169. get
  170. {
  171. return _gchrConfig.Einstellungen.KontoOhneUebersetzungUebernehmen;
  172. }
  173. }
  174. private static string DepartmentFilter
  175. {
  176. get
  177. {
  178. return "'?'";
  179. }
  180. }
  181. public string OdbcConnectionString
  182. {
  183. get
  184. {
  185. return
  186. (string.Format("DSN={0};UID={1};PWD={2};", _gchrConfig.Einstellungen.Odbc,
  187. Constants.Decrypt(_gchrConfig.Einstellungen.OdbcUsername),
  188. Constants.Decrypt(_gchrConfig.Einstellungen.OdbcPassword)));
  189. }
  190. }
  191. private string MarkeUebersetzen(string marke)
  192. {
  193. var suchergebnis = _gchrConfig.Einstellungen.DepartmentUebersetzung.Where(eintrag => eintrag.Von.Equals(marke)).ToArray();
  194. if (!suchergebnis.Any()) return marke;
  195. var uebersetzung = suchergebnis.First();
  196. return uebersetzung.Nach;
  197. }
  198. private string BetriebUebersetzen(string betrieb)
  199. {
  200. // Funktionen sind derzeit noch identisch
  201. return MarkeUebersetzen(betrieb);
  202. }
  203. public void DepartmentAnpassen(HaendlerKonto konto)
  204. {
  205. konto.Betrieb = BetriebUebersetzen(BetriebNormalisieren(BetriebExtrahieren(konto.DepartmentImport)));
  206. konto.Marke = MarkeUebersetzen(MarkeNormalisieren(MarkeExtrahieren(konto.DepartmentImport)));
  207. }
  208. private string BetriebNormalisieren(string betrieb)
  209. {
  210. return (betrieb.Length > Hauptbetrieb.Length)
  211. ? betrieb.Substring(0, Hauptbetrieb.Length)
  212. : betrieb.PadLeft(Hauptbetrieb.Length, '0');
  213. }
  214. private string MarkeNormalisieren(string marke)
  215. {
  216. return (marke.Length > Hauptmarke.Length)
  217. ? marke.Substring(0, Hauptmarke.Length)
  218. : marke.PadLeft(Hauptmarke.Length, '0');
  219. }
  220. private string BetriebExtrahieren(string department)
  221. {
  222. return (department.Length >= Hauptbetrieb.Length)
  223. ? department.Substring(0, Hauptbetrieb.Length)
  224. : department;
  225. }
  226. private string MarkeExtrahieren(string department)
  227. {
  228. return (department.Length > Hauptbetrieb.Length)
  229. ? department.Substring(Hauptbetrieb.Length)
  230. : "";
  231. }
  232. private string QueryAnpassen(string queryStr, Periode aktuellePeriode)
  233. {
  234. queryStr = Regex.Replace(queryStr, @"\<datenbank\>", "");
  235. queryStr = Regex.Replace(queryStr, @"\<period[e]?\>", aktuellePeriode.ToString());
  236. queryStr = Regex.Replace(queryStr, @"\<jahresbeginn\>", aktuellePeriode.Jahresbeginn.ToString());
  237. queryStr = Regex.Replace(queryStr, @"\<bilanzbeginn\>", aktuellePeriode.Bilanzbeginn.ToString());
  238. return Regex.Replace(queryStr, @"\<department_filter\>", DepartmentFilter);
  239. }
  240. internal string HaendlerKontonummerFormatieren(string kontonummer)
  241. {
  242. return kontonummer.PadLeft(HaendlerKontenrahmenStellen, '0');
  243. }
  244. public HaendlerKonto ManuellesKontoSuchen(string kontonummer)
  245. {
  246. var konten = (from HaendlerKonto kto in _konten.Kontenliste
  247. where (kto.Kontonummer.Equals(kontonummer)
  248. || kto.ToString().Equals(kontonummer))
  249. select kto).ToList();
  250. return (konten.Count > 0) ? konten.First() : HaendlerKonto.ManStatNeu(kontonummer);
  251. }
  252. public void ManuelleKontenSetzen(List<HaendlerKonto> manKonten)
  253. {
  254. _konten.Kontenliste = manKonten;
  255. ManuelleKontenSpeichern();
  256. }
  257. public string UebersetzungStat
  258. {
  259. get { return _gchrConfig.Dateipfade.UebersetzungStat; }
  260. }
  261. public string UebersetzungSusa
  262. {
  263. get { return _gchrConfig.Dateipfade.UebersetzungSusa; }
  264. }
  265. public string Kontenrahmen
  266. {
  267. get { return _gchrConfig.Dateipfade.Kontenrahmen; }
  268. }
  269. public string ManuelleKonten
  270. {
  271. get { return _gchrConfig.Dateipfade.ManuelleKonten; }
  272. }
  273. public string Importdaten
  274. {
  275. get { return _gchrConfig.Dateipfade.Importdaten; }
  276. }
  277. public string Webservice { get { return _gchrConfig.Webservice + ((_gchrConfig.Webservice.EndsWith("/")) ? "" : "/") + "?valid=1&gchr=1"; } }
  278. public bool WebserviceAktiv
  279. {
  280. get { return (!string.IsNullOrEmpty(_gchrConfig.Webservice)); }
  281. }
  282. public bool StatKontenImportieren
  283. {
  284. get { return _gchrConfig.Einstellungen.StatImport; }
  285. }
  286. }
  287. }