[chore:] moved files for better structure
This commit is contained in:
235
Tasks/AddressCheck.cs
Normal file
235
Tasks/AddressCheck.cs
Normal file
@@ -0,0 +1,235 @@
|
||||
using System.Collections.Generic;
|
||||
using System.Threading;
|
||||
using System.Threading.Tasks;
|
||||
using Avalonia.Threading;
|
||||
|
||||
namespace Logof_Client;
|
||||
|
||||
public class AddressCheck
|
||||
{
|
||||
public enum ErrorTypes
|
||||
{
|
||||
PlzTooShort,
|
||||
PlzTooLong,
|
||||
PPlzTooShort,
|
||||
PPlzTooLong,
|
||||
|
||||
// empty,
|
||||
FullAddressTooLong,
|
||||
DoubledRefsid,
|
||||
MayBeSameAddress,
|
||||
NoPLZorPPLZ
|
||||
}
|
||||
|
||||
public enum WarningTypes
|
||||
{
|
||||
NoCity,
|
||||
NoStreet,
|
||||
NoLastName,
|
||||
NoFirstName,
|
||||
NoStreetNumber,
|
||||
NoPLZ,
|
||||
NoPPLZ
|
||||
}
|
||||
|
||||
private readonly ProgressWindow _progress;
|
||||
|
||||
public AddressCheck(ProgressWindow progressWindow)
|
||||
{
|
||||
_progress = progressWindow;
|
||||
}
|
||||
|
||||
public async Task<List<(int, List<ErrorTypes>, List<WarningTypes>)>> Perform(KasAddressList addresses)
|
||||
{
|
||||
var failed_refsids = new List<(int, List<ErrorTypes>, List<WarningTypes>)>();
|
||||
var total = addresses.KasPersons.Count;
|
||||
var current = 0;
|
||||
|
||||
await Task.Run(async () =>
|
||||
{
|
||||
foreach (var person in addresses.KasPersons)
|
||||
{
|
||||
var errors = new List<ErrorTypes>();
|
||||
var warnings = new List<WarningTypes>();
|
||||
var hasFaults = false;
|
||||
|
||||
var address_component_count = 2; // cause anrede and name are first
|
||||
|
||||
// PLZ-Prüfung
|
||||
if (person.plz == 0 || person.plz == null)
|
||||
{
|
||||
hasFaults = true;
|
||||
warnings.Add(WarningTypes.NoPLZ);
|
||||
}
|
||||
else
|
||||
{
|
||||
if ((person.plz < 10000 && string.IsNullOrWhiteSpace(person.land)) ||
|
||||
(person.plz < 10000 && person.land == "GER") ||
|
||||
(person.plz < 10000 && person.land == "DE"))
|
||||
{
|
||||
hasFaults = true;
|
||||
errors.Add(ErrorTypes.PlzTooShort);
|
||||
}
|
||||
else if ((person.plz > 99999 && string.IsNullOrWhiteSpace(person.land)) ||
|
||||
(person.plz > 99999 && person.land == "GER") ||
|
||||
(person.plz > 99999 && person.land == "DE"))
|
||||
{
|
||||
hasFaults = true;
|
||||
errors.Add(ErrorTypes.PlzTooLong);
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
// PPLZ-Prüfung
|
||||
if (person.pplz == 0 || person.pplz == null)
|
||||
{
|
||||
hasFaults = true;
|
||||
warnings.Add(WarningTypes.NoPPLZ);
|
||||
}
|
||||
else
|
||||
{
|
||||
if ((person.pplz < 10000 && string.IsNullOrWhiteSpace(person.land)) ||
|
||||
(person.pplz < 10000 && person.land == "GER") ||
|
||||
(person.pplz < 10000 && person.land == "DE"))
|
||||
{
|
||||
hasFaults = true;
|
||||
errors.Add(ErrorTypes.PPlzTooShort);
|
||||
}
|
||||
else if ((person.pplz > 99999 && string.IsNullOrWhiteSpace(person.land)) ||
|
||||
(person.pplz > 99999 && person.land == "GER") ||
|
||||
(person.pplz > 99999 && person.land == "DE"))
|
||||
{
|
||||
hasFaults = true;
|
||||
errors.Add(ErrorTypes.PPlzTooLong);
|
||||
}
|
||||
}
|
||||
|
||||
if (warnings.Contains(WarningTypes.NoPLZ) && warnings.Contains(WarningTypes.NoPPLZ))
|
||||
{
|
||||
hasFaults = true;
|
||||
errors.Add(ErrorTypes.NoPLZorPPLZ);
|
||||
}
|
||||
|
||||
// Ort-Prüfung
|
||||
if (string.IsNullOrWhiteSpace(person.ort))
|
||||
{
|
||||
hasFaults = true;
|
||||
warnings.Add(WarningTypes.NoCity);
|
||||
}
|
||||
else
|
||||
{
|
||||
address_component_count++;
|
||||
}
|
||||
|
||||
// Street-Number
|
||||
var street = person.strasse.ToCharArray();
|
||||
var intcount = 0;
|
||||
foreach (var c in street)
|
||||
{
|
||||
int maybe;
|
||||
if (int.TryParse(c.ToString(), out maybe)) intcount++;
|
||||
}
|
||||
|
||||
if (intcount == 0)
|
||||
{
|
||||
hasFaults = true;
|
||||
warnings.Add(WarningTypes.NoStreetNumber);
|
||||
}
|
||||
|
||||
// Last-Name
|
||||
if (string.IsNullOrWhiteSpace(person.name))
|
||||
{
|
||||
hasFaults = true;
|
||||
warnings.Add(WarningTypes.NoLastName);
|
||||
}
|
||||
|
||||
// First-Name
|
||||
if (string.IsNullOrWhiteSpace(person.vorname))
|
||||
{
|
||||
hasFaults = true;
|
||||
warnings.Add(WarningTypes.NoFirstName);
|
||||
}
|
||||
|
||||
// Street-Check
|
||||
if (string.IsNullOrWhiteSpace(person.strasse))
|
||||
{
|
||||
hasFaults = true;
|
||||
warnings.Add(WarningTypes.NoStreet);
|
||||
}
|
||||
else
|
||||
{
|
||||
address_component_count++;
|
||||
}
|
||||
|
||||
// Address-Component-Count
|
||||
if (!string.IsNullOrWhiteSpace(person.strasse2)) address_component_count++;
|
||||
if (!string.IsNullOrWhiteSpace(person.land)) address_component_count++;
|
||||
if (!string.IsNullOrWhiteSpace(person.name1)) address_component_count++;
|
||||
if (!string.IsNullOrWhiteSpace(person.name2)) address_component_count++;
|
||||
if (!string.IsNullOrWhiteSpace(person.name3)) address_component_count++;
|
||||
if (!string.IsNullOrWhiteSpace(person.name4)) address_component_count++;
|
||||
if (!string.IsNullOrWhiteSpace(person.name5)) address_component_count++;
|
||||
if (!string.IsNullOrWhiteSpace(person.funktion)) address_component_count++;
|
||||
if (!string.IsNullOrWhiteSpace(person.funktion2)) address_component_count++;
|
||||
if (!string.IsNullOrWhiteSpace(person.funktionad)) address_component_count++;
|
||||
if (!string.IsNullOrWhiteSpace(person.abteilung)) address_component_count++;
|
||||
|
||||
// Double-Refsid or DoubleAddresses
|
||||
foreach (var person2 in addresses.KasPersons)
|
||||
{
|
||||
if (addresses.KasPersons.IndexOf(person) == addresses.KasPersons.IndexOf(person2)) continue;
|
||||
|
||||
if (person.refsid == person2.refsid)
|
||||
{
|
||||
hasFaults = true;
|
||||
errors.Add(ErrorTypes.DoubledRefsid);
|
||||
}
|
||||
|
||||
if (person.name == person2.name &&
|
||||
person.strasse == person2.strasse &&
|
||||
person.vorname == person2.vorname &&
|
||||
person.ort == person2.ort &&
|
||||
person.funktion == person2.funktion &&
|
||||
person.funktion2 == person2.funktion2 &&
|
||||
person.funktionad == person2.funktionad &&
|
||||
person.abteilung == person2.abteilung &&
|
||||
person.name1 == person2.name1 &&
|
||||
person.name2 == person2.name2 &&
|
||||
person.name3 == person2.name3 &&
|
||||
person.name4 == person2.name4 &&
|
||||
person.name5 == person2.name5)
|
||||
|
||||
{
|
||||
hasFaults = true;
|
||||
errors.Add(ErrorTypes.MayBeSameAddress);
|
||||
}
|
||||
}
|
||||
|
||||
// Adressen-Länge
|
||||
if (address_component_count > 10)
|
||||
{
|
||||
hasFaults = true;
|
||||
errors.Add(ErrorTypes.FullAddressTooLong);
|
||||
}
|
||||
|
||||
if (hasFaults)
|
||||
lock (failed_refsids)
|
||||
{
|
||||
failed_refsids.Add((person.refsid, errors, warnings));
|
||||
}
|
||||
|
||||
// Fortschritt aktualisieren
|
||||
Interlocked.Increment(ref current);
|
||||
var percent = current / (double)total * 100;
|
||||
await Dispatcher.UIThread.InvokeAsync(() =>
|
||||
{
|
||||
if (hasFaults)
|
||||
_progress.AddToLog($"Person mit refsid {person.refsid} ist fehlerhaft");
|
||||
|
||||
_progress.ChangePercentage(percent);
|
||||
});
|
||||
}
|
||||
});
|
||||
return failed_refsids;
|
||||
}
|
||||
}
|
||||
24
Tasks/AddressRepair.cs
Normal file
24
Tasks/AddressRepair.cs
Normal file
@@ -0,0 +1,24 @@
|
||||
using System.Collections.Generic;
|
||||
|
||||
namespace Logof_Client;
|
||||
|
||||
public class AddressRepair(ProgressWindow progressWindow)
|
||||
{
|
||||
private readonly ProgressWindow _progress = progressWindow;
|
||||
|
||||
public KasAddressList Perform(KasAddressList all_addresses,
|
||||
List<(int, List<AddressCheck.ErrorTypes>)> failed_addresses)
|
||||
{
|
||||
foreach (var k in all_addresses.KasPersons)
|
||||
foreach (var p in failed_addresses)
|
||||
{
|
||||
if (k.refsid != p.Item1) continue;
|
||||
|
||||
if (p.Item2.Contains(AddressCheck.ErrorTypes.DoubledRefsid))
|
||||
{
|
||||
}
|
||||
}
|
||||
|
||||
return null;
|
||||
}
|
||||
}
|
||||
94
Tasks/CombineAddresses.cs
Normal file
94
Tasks/CombineAddresses.cs
Normal file
@@ -0,0 +1,94 @@
|
||||
using System.Collections.Generic;
|
||||
using System.Threading.Tasks;
|
||||
using Avalonia.Threading;
|
||||
|
||||
namespace Logof_Client;
|
||||
|
||||
public class CombineAddresses
|
||||
{
|
||||
private readonly ProgressWindow _progress;
|
||||
|
||||
public CombineAddresses(ProgressWindow progressWindow)
|
||||
{
|
||||
_progress = progressWindow;
|
||||
}
|
||||
|
||||
public async Task<KasAddressList> Perform(List<KasAddressList> address_lists)
|
||||
{
|
||||
KasAddressList result = new();
|
||||
await Task.Run(async () =>
|
||||
{
|
||||
for (var i = 0; i < address_lists.Count; i++)
|
||||
if (i == 0)
|
||||
lock (result)
|
||||
{
|
||||
result = address_lists[i];
|
||||
}
|
||||
else
|
||||
lock (result)
|
||||
{
|
||||
result = Merge(result, address_lists[i], i + 1, address_lists.Count).Result;
|
||||
}
|
||||
});
|
||||
return result;
|
||||
}
|
||||
|
||||
private async Task<KasAddressList> Merge(KasAddressList first, KasAddressList second, int num, int total)
|
||||
{
|
||||
foreach (var sec in second.KasPersons)
|
||||
{
|
||||
var is_new = true;
|
||||
foreach (var fi in first.KasPersons)
|
||||
{
|
||||
if (fi.refsid == sec.refsid)
|
||||
{
|
||||
is_new = false;
|
||||
break;
|
||||
}
|
||||
|
||||
if (fi.name == sec.name &&
|
||||
fi.anrede == sec.anrede &&
|
||||
fi.anredzus == sec.anredzus &&
|
||||
fi.namezus == sec.namezus &&
|
||||
fi.titel == sec.titel &&
|
||||
fi.adel == sec.adel &&
|
||||
fi.strasse == sec.strasse &&
|
||||
fi.strasse2 == sec.strasse2 &&
|
||||
fi.vorname == sec.vorname &&
|
||||
fi.ort == sec.ort &&
|
||||
fi.land == sec.land &&
|
||||
fi.plz == sec.plz &&
|
||||
fi.pplz == sec.pplz &&
|
||||
fi.funktion == sec.funktion &&
|
||||
fi.funktion2 == sec.funktion2 &&
|
||||
fi.funktionad == sec.funktionad &&
|
||||
fi.abteilung == sec.abteilung &&
|
||||
fi.postfach == sec.postfach &&
|
||||
fi.name1 == sec.name1 &&
|
||||
fi.name2 == sec.name2 &&
|
||||
fi.name3 == sec.name3 &&
|
||||
fi.name4 == sec.name4 &&
|
||||
fi.name5 == sec.name5)
|
||||
{
|
||||
is_new = false;
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
if (is_new) first.KasPersons.Add(sec);
|
||||
var subperc = second.KasPersons.IndexOf(sec) / second.KasPersons.Count;
|
||||
var percent = (num + (double)subperc) / total * 100;
|
||||
await Dispatcher.UIThread.InvokeAsync(() =>
|
||||
{
|
||||
if (is_new)
|
||||
_progress.AddToLog($"Person mit refsid {sec.refsid} ergänzt");
|
||||
else
|
||||
_progress.AddToLog($"Person mit refsid {sec.refsid} bereits vorhanden");
|
||||
|
||||
_progress.ChangePercentage(percent);
|
||||
});
|
||||
}
|
||||
|
||||
return first;
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user