Datenimport.cs 5.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Data.Odbc;
  4. using System.IO;
  5. using System.Linq;
  6. using GCHR.Model;
  7. using GCHR.Model.Konto;
  8. namespace GCHR.Control.Tasks
  9. {
  10. class Datenimport : Task
  11. {
  12. public static Datenimport DatenimportSuSa(int id, string name)
  13. {
  14. var datenimport = new Datenimport(id, name) {_kontoTyp = KontoTypen.SuSa};
  15. return datenimport;
  16. }
  17. public static Datenimport DatenimportStat(int id, string name)
  18. {
  19. var datenimport = new Datenimport(id, name) {_kontoTyp = KontoTypen.Stat};
  20. return datenimport;
  21. }
  22. private Datenimport(int id, string name)
  23. : base(id, name) { }
  24. private KontoTypen _kontoTyp;
  25. private string QueryStr
  26. {
  27. get { return (_kontoTyp == KontoTypen.SuSa) ? Config.SuSaKontenQuery : Config.StatKontenQuery; }
  28. }
  29. protected override void AufgabeAusfuehren()
  30. {
  31. var import = Importieren();
  32. Data.AddKonten(ImportInKontenUmwandeln(import));
  33. }
  34. private IEnumerable<string> Importieren()
  35. {
  36. List<string> import;
  37. if (Data.Offlinemodus && File.Exists(Dateiname()))
  38. {
  39. import = File.ReadAllLines(Dateiname()).ToList();
  40. }
  41. else
  42. {
  43. import = KontenVonOdbcLaden();
  44. if (Data.ImportdatenSichern)
  45. {
  46. ImportdatenSichern(import);
  47. }
  48. }
  49. return import;
  50. }
  51. private List<string> KontenVonOdbcLaden()
  52. {
  53. var result = new List<string>();
  54. using (var con = new OdbcConnection(Config.OdbcConnectionString))
  55. {
  56. con.ConnectionTimeout = 300;
  57. con.Open();
  58. var query = new OdbcCommand(QueryStr, con) {CommandTimeout = 300};
  59. var reader = query.ExecuteReader();
  60. while (reader.Read())
  61. {
  62. var zeile = reader.GetString(0).Trim();
  63. for (var i = 1; i < reader.FieldCount; i++)
  64. {
  65. zeile += ";" + reader.GetString(i).Trim();
  66. }
  67. result.Add(zeile);
  68. }
  69. reader.Close();
  70. con.Close();
  71. }
  72. return result;
  73. }
  74. private void ImportdatenSichern(List<string> import)
  75. {
  76. using (var sw = new StreamWriter(Dateiname(), false, Constants.CsvEncoding))
  77. {
  78. sw.WriteLine(String.Join(Environment.NewLine, import.ToArray()));
  79. }
  80. }
  81. private string Dateiname()
  82. {
  83. return String.Format(Constants.Importdaten, HaendlerKonto.AktuellePeriode, _kontoTyp);
  84. }
  85. private List<HaendlerKonto> ImportInKontenUmwandeln(IEnumerable<string> import)
  86. {
  87. var konten = (from tempZeile in import
  88. select tempZeile.Split(';') into feld
  89. group feld by (feld[0] + ";" + feld[3]) into kontoSaldi
  90. select NeuesKonto(kontoSaldi.ToList())).ToList();
  91. if (_kontoTyp == KontoTypen.SuSa)
  92. {
  93. SummeSaldiPruefen(konten.Sum(konto => konto.Summe));
  94. }
  95. ReportProgress(80);
  96. return konten;
  97. }
  98. private void SummeSaldiPruefen(Decimal summe)
  99. {
  100. var summeString = String.Format(Constants.Zahlenformat, "{0:c}", summe);
  101. Logger.Progress("Summe über alle SuSa-Konten: " + summeString);
  102. if (summe != 0.0m)
  103. {
  104. ReportProgress(75, "Beim Import der SuSa-Konten trat ein Fehler auf." + Environment.NewLine +
  105. "Die Summe über alle SuSa-Konten ist " + summeString + " €");
  106. }
  107. }
  108. private HaendlerKonto NeuesKonto(IEnumerable<string[]> kontoSaldi)
  109. {
  110. var neuesKonto = new HaendlerKonto(_kontoTyp);
  111. var feld = kontoSaldi.First();
  112. neuesKonto.Kontonummer = Config.HaendlerKontonummerFormatieren(feld[0].Trim());
  113. neuesKonto.DepartmentImport = feld[3].Trim();
  114. Config.DepartmentAnpassen(neuesKonto);
  115. if (PeriodeMitgeliefert(feld))
  116. {
  117. foreach (var saldo in kontoSaldi)
  118. {
  119. neuesKonto.SaldoZuordnen(saldo[4].Substring(0,6), ToDecimal(saldo[1]), ToDecimal(saldo[2]));
  120. }
  121. }
  122. else
  123. {
  124. neuesKonto.Soll = (from saldo in kontoSaldi
  125. select ToDecimal(saldo[1])).Sum();
  126. neuesKonto.Haben = (from saldo in kontoSaldi
  127. select ToDecimal(saldo[2])).Sum();
  128. }
  129. if (KontoartMitgeliefert(feld))
  130. {
  131. neuesKonto.Kontoart = feld[5];
  132. }
  133. return neuesKonto;
  134. }
  135. private static Decimal ToDecimal(string feld)
  136. {
  137. return Decimal.Parse(feld, Constants.ZahlenformatImport);
  138. }
  139. private static bool PeriodeMitgeliefert(IEnumerable<string> feld)
  140. {
  141. return feld.Count() > 4;
  142. }
  143. private static bool KontoartMitgeliefert(IEnumerable<string> feld)
  144. {
  145. return feld.Count() > 5;
  146. }
  147. }
  148. }