Elwig: Add ITime/XTime to entities and allow to export/import CTime/MTime
	
		
			
	
		
	
	
		
	
		
			All checks were successful
		
		
	
	
		
			
				
	
				Test / Run tests (push) Successful in 2m30s
				
			
		
		
	
	
				
					
				
			
		
			All checks were successful
		
		
	
	Test / Run tests (push) Successful in 2m30s
				
			This commit is contained in:
		@@ -1,14 +1,15 @@
 | 
			
		||||
using System.IO.Compression;
 | 
			
		||||
using System.IO;
 | 
			
		||||
using System.Threading.Tasks;
 | 
			
		||||
using Elwig.Models.Entities;
 | 
			
		||||
using System.Collections.Generic;
 | 
			
		||||
using System;
 | 
			
		||||
using System.Text.Json.Nodes;
 | 
			
		||||
using System.Linq;
 | 
			
		||||
using System.Windows;
 | 
			
		||||
using Microsoft.EntityFrameworkCore;
 | 
			
		||||
using System;
 | 
			
		||||
using System.Collections.Generic;
 | 
			
		||||
using System.Globalization;
 | 
			
		||||
using System.IO;
 | 
			
		||||
using System.IO.Compression;
 | 
			
		||||
using System.Linq;
 | 
			
		||||
using System.Text.Json;
 | 
			
		||||
using System.Text.Json.Nodes;
 | 
			
		||||
using System.Threading.Tasks;
 | 
			
		||||
using System.Windows;
 | 
			
		||||
 | 
			
		||||
namespace Elwig.Helpers.Export {
 | 
			
		||||
    public static class ElwigData {
 | 
			
		||||
@@ -63,7 +64,8 @@ namespace Elwig.Helpers.Export {
 | 
			
		||||
                    List<WbRd> Riede,
 | 
			
		||||
                    List<Delivery> Deliveries,
 | 
			
		||||
                    List<DeliveryPart> DeliveryParts,
 | 
			
		||||
                    List<DeliveryPartModifier> Modifiers)>();
 | 
			
		||||
                    List<DeliveryPartModifier> Modifiers,
 | 
			
		||||
                    Dictionary<string, List<(int Id1, int Id2, DateTime CreatedAt, DateTime ModifiedAt)>> Timestamps)>();
 | 
			
		||||
 | 
			
		||||
                var metaData = new List<(string FileName, string ZwstId, string Device,
 | 
			
		||||
                    int? MemberNum, string? MemberFilters,
 | 
			
		||||
@@ -94,7 +96,11 @@ namespace Elwig.Helpers.Export {
 | 
			
		||||
                        areaComCount, areaComFilters != null ? string.Join(" / ", areaComFilters) : null,
 | 
			
		||||
                        deliveryCount, deliveryFilters != null ? string.Join(" / ", deliveryFilters) : null));
 | 
			
		||||
 | 
			
		||||
                    data.Add(new([], [], [], [], [], [], [], new([], [])));
 | 
			
		||||
                    data.Add(new([], [], [], [], [], [], [], new([], [], new() {
 | 
			
		||||
                        ["member"] = [],
 | 
			
		||||
                        ["area_commitment"] = [],
 | 
			
		||||
                        ["delivery"] = [],
 | 
			
		||||
                    })));
 | 
			
		||||
                    var r = data[^1];
 | 
			
		||||
 | 
			
		||||
                    var membersJson = zip.GetEntry("members.json");
 | 
			
		||||
@@ -103,11 +109,13 @@ namespace Elwig.Helpers.Export {
 | 
			
		||||
                        string? line;
 | 
			
		||||
                        while ((line = await reader.ReadLineAsync()) != null) {
 | 
			
		||||
                            var obj = JsonNode.Parse(line)!.AsObject();
 | 
			
		||||
                            var (m, b, telNrs, emailAddrs) = obj.ToMember(kgs);
 | 
			
		||||
                            var (m, b, telNrs, emailAddrs, timestamps) = obj.ToMember(kgs);
 | 
			
		||||
                            r.Members.Add(m);
 | 
			
		||||
                            if (b != null) r.BillingAddresses.Add(b);
 | 
			
		||||
                            r.TelephoneNumbers.AddRange(telNrs);
 | 
			
		||||
                            r.EmailAddresses.AddRange(emailAddrs);
 | 
			
		||||
                            if (timestamps.HasValue)
 | 
			
		||||
                                r.Timestamps["member"].Add((m.MgNr, 0, timestamps.Value.CreatedAt, timestamps.Value.ModifiedAt));
 | 
			
		||||
                        }
 | 
			
		||||
                    }
 | 
			
		||||
 | 
			
		||||
@@ -117,12 +125,14 @@ namespace Elwig.Helpers.Export {
 | 
			
		||||
                        string? line;
 | 
			
		||||
                        while ((line = await reader.ReadLineAsync()) != null) {
 | 
			
		||||
                            var obj = JsonNode.Parse(line)!.AsObject();
 | 
			
		||||
                            var (areaCom, wbrd) = obj.ToAreaCom(kgs, currentWbRde);
 | 
			
		||||
                            var (areaCom, wbrd, timestamps) = obj.ToAreaCom(kgs, currentWbRde);
 | 
			
		||||
                            r.AreaCommitments.Add(areaCom);
 | 
			
		||||
                            if (wbrd != null) {
 | 
			
		||||
                                currentWbRde[wbrd.KgNr].Add(wbrd);
 | 
			
		||||
                                r.Riede.Add(wbrd);
 | 
			
		||||
                            }
 | 
			
		||||
                            if (timestamps.HasValue)
 | 
			
		||||
                                r.Timestamps["area_commitment"].Add((areaCom.FbNr, 0, timestamps.Value.CreatedAt, timestamps.Value.ModifiedAt));
 | 
			
		||||
                        }
 | 
			
		||||
                    }
 | 
			
		||||
 | 
			
		||||
@@ -132,10 +142,12 @@ namespace Elwig.Helpers.Export {
 | 
			
		||||
                        string? line;
 | 
			
		||||
                        while ((line = await reader.ReadLineAsync()) != null) {
 | 
			
		||||
                            var obj = JsonNode.Parse(line)!.AsObject();
 | 
			
		||||
                            var (d, parts, mods) = obj.ToDelivery(currentLsNrs, currentDids);
 | 
			
		||||
                            var (d, parts, mods, timestamps) = obj.ToDelivery(currentLsNrs, currentDids);
 | 
			
		||||
                            r.Deliveries.Add(d);
 | 
			
		||||
                            r.DeliveryParts.AddRange(parts);
 | 
			
		||||
                            r.Modifiers.AddRange(mods);
 | 
			
		||||
                            if (timestamps.HasValue)
 | 
			
		||||
                                r.Timestamps["delivery"].Add((d.Year, d.DId, timestamps.Value.CreatedAt, timestamps.Value.ModifiedAt));
 | 
			
		||||
                        }
 | 
			
		||||
                    }
 | 
			
		||||
                }
 | 
			
		||||
@@ -144,7 +156,7 @@ namespace Elwig.Helpers.Export {
 | 
			
		||||
                var importedAreaComs = new List<(string FileName, string ZwstId, string Device, int Imported, int NotImported, string Filters)>();
 | 
			
		||||
                var importedDeliveries = new List<(string FileName, string ZwstId, string Device, int New, int Overwritten, int NotImported, string Filters)>();
 | 
			
		||||
 | 
			
		||||
                foreach (var ((members, billingAddresses, telephoneNumbers, emailAddresses, areaCommitments, riede, deliveries, deliveryParts, modifiers), meta) in data.Zip(metaData)) {
 | 
			
		||||
                foreach (var ((members, billingAddresses, telephoneNumbers, emailAddresses, areaCommitments, riede, deliveries, deliveryParts, modifiers, timestamps), meta) in data.Zip(metaData)) {
 | 
			
		||||
                    var branch = branches[meta.ZwstId];
 | 
			
		||||
                    var device = meta.Device;
 | 
			
		||||
 | 
			
		||||
@@ -272,6 +284,26 @@ namespace Elwig.Helpers.Export {
 | 
			
		||||
                    }
 | 
			
		||||
 | 
			
		||||
                    await ctx.SaveChangesAsync();
 | 
			
		||||
 | 
			
		||||
                    var primaryKeys = new Dictionary<string, string>() {
 | 
			
		||||
                        ["member"] = "mgnr, 0",
 | 
			
		||||
                        ["area_commitment"] = "fbnr, 0",
 | 
			
		||||
                        ["delivery"] = "year, did",
 | 
			
		||||
                    };
 | 
			
		||||
                    var updateStmts = timestamps
 | 
			
		||||
                        .SelectMany(e => e.Value.Select(m => $"UPDATE {e.Key} " +
 | 
			
		||||
                                                             $"SET ctime = {((DateTimeOffset)m.CreatedAt.ToUniversalTime()).ToUnixTimeSeconds()}, " +
 | 
			
		||||
                                                                 $"mtime = {((DateTimeOffset)m.ModifiedAt.ToUniversalTime()).ToUnixTimeSeconds()} " +
 | 
			
		||||
                                                             $"WHERE ({primaryKeys[e.Key]}) = ({m.Id1}, {m.Id2});"));
 | 
			
		||||
                    using var cnx = AppDbContext.Connect();
 | 
			
		||||
                    await AppDbContext.ExecuteBatch(cnx, $"""
 | 
			
		||||
                        BEGIN;
 | 
			
		||||
                        UPDATE client_parameter SET value = '0' WHERE param = 'ENABLE_TIME_TRIGGERS';
 | 
			
		||||
                        {string.Join("\n", updateStmts)}
 | 
			
		||||
                        UPDATE client_parameter SET value = '1' WHERE param = 'ENABLE_TIME_TRIGGERS';
 | 
			
		||||
                        COMMIT;
 | 
			
		||||
                        """);
 | 
			
		||||
 | 
			
		||||
                    await AddImportedFiles(Path.GetFileName(meta.FileName));
 | 
			
		||||
                }
 | 
			
		||||
                App.HintContextChange();
 | 
			
		||||
@@ -460,15 +492,19 @@ namespace Elwig.Helpers.Export {
 | 
			
		||||
                    return obj;
 | 
			
		||||
                }).ToArray()),
 | 
			
		||||
                ["comment"] = m.Comment,
 | 
			
		||||
                ["created_at"] = $"{m.CreatedAt:yyyy-MM-ddTHH:mm:ssK}",
 | 
			
		||||
                ["modified_at"] = $"{m.ModifiedAt:yyyy-MM-ddTHH:mm:ssK}",
 | 
			
		||||
            };
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        public static (Member, BillingAddr?, List<MemberTelNr>, List<MemberEmailAddr>) ToMember(this JsonNode json, Dictionary<int, AT_Kg> kgs) {
 | 
			
		||||
        public static (Member, BillingAddr?, List<MemberTelNr>, List<MemberEmailAddr>, (DateTime CreatedAt, DateTime ModifiedAt)?) ToMember(this JsonNode json, Dictionary<int, AT_Kg> kgs) {
 | 
			
		||||
            var mgnr = json["mgnr"]!.AsValue().GetValue<int>();
 | 
			
		||||
            var kgnr = json["default_kgnr"]?.AsValue().GetValue<int>();
 | 
			
		||||
            if (kgnr != null && !kgs.Values.Any(k => k.WbKg?.KgNr == kgnr)) {
 | 
			
		||||
                throw new ArgumentException($"Für KG {(kgs.TryGetValue(kgnr.Value, out var k) ? k.Name : "?")} ({kgnr:00000}) ist noch keine Großlage festgelegt!\n(Stammdaten → Herkunftshierarchie)");
 | 
			
		||||
            }
 | 
			
		||||
            var createdAt = json["created_at"]?.AsValue().GetValue<string>();
 | 
			
		||||
            var modifiedAt = json["modified_at"]?.AsValue().GetValue<string>();
 | 
			
		||||
            return (new Member {
 | 
			
		||||
                MgNr = mgnr,
 | 
			
		||||
                PredecessorMgNr = json["predecessor_mgnr"]?.AsValue().GetValue<int>(),
 | 
			
		||||
@@ -502,6 +538,7 @@ namespace Elwig.Helpers.Export {
 | 
			
		||||
                ContactViaPost = json["contact_postal"]?.AsValue().GetValue<bool>() ?? false,
 | 
			
		||||
                ContactViaEmail = json["contact_email"]?.AsValue().GetValue<bool>() ?? false,
 | 
			
		||||
                Comment = json["comment"]?.AsValue().GetValue<string>(),
 | 
			
		||||
                ImportedAt = DateTime.Now,
 | 
			
		||||
            }, json["billing_address"] is JsonObject a ? new BillingAddr {
 | 
			
		||||
                MgNr = mgnr,
 | 
			
		||||
                FullName = a["name"]!.AsValue().GetValue<string>(),
 | 
			
		||||
@@ -519,7 +556,10 @@ namespace Elwig.Helpers.Export {
 | 
			
		||||
                Nr = i + 1,
 | 
			
		||||
                Address = a["address"]!.AsValue().GetValue<string>(),
 | 
			
		||||
                Comment = a["comment"]?.AsValue().GetValue<string>(),
 | 
			
		||||
            }).ToList());
 | 
			
		||||
            }).ToList(),
 | 
			
		||||
            createdAt == null || modifiedAt == null ? null :
 | 
			
		||||
            (DateTime.ParseExact(createdAt, "yyyy-MM-ddTHH:mm:ssK", CultureInfo.InvariantCulture, DateTimeStyles.None),
 | 
			
		||||
             DateTime.ParseExact(modifiedAt, "yyyy-MM-ddTHH:mm:ssK", CultureInfo.InvariantCulture, DateTimeStyles.None)));
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        public static JsonObject ToJson(this AreaCom c) {
 | 
			
		||||
@@ -535,10 +575,12 @@ namespace Elwig.Helpers.Export {
 | 
			
		||||
                ["year_from"] = c.YearFrom,
 | 
			
		||||
                ["year_to"] = c.YearTo,
 | 
			
		||||
                ["comment"] = c.Comment,
 | 
			
		||||
                ["created_at"] = $"{c.CreatedAt:yyyy-MM-ddTHH:mm:ssK}",
 | 
			
		||||
                ["modified_at"] = $"{c.ModifiedAt:yyyy-MM-ddTHH:mm:ssK}",
 | 
			
		||||
            };
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        public static (AreaCom, WbRd?) ToAreaCom(this JsonNode json, Dictionary<int, AT_Kg> kgs, Dictionary<int, List<WbRd>> riede) {
 | 
			
		||||
        public static (AreaCom, WbRd?, (DateTime CreatedAt, DateTime ModifiedAt)?) ToAreaCom(this JsonNode json, Dictionary<int, AT_Kg> kgs, Dictionary<int, List<WbRd>> riede) {
 | 
			
		||||
            var kgnr = json["kgnr"]!.AsValue().GetValue<int>();
 | 
			
		||||
            var ried = json["ried"]?.AsValue().GetValue<string>();
 | 
			
		||||
            WbRd? rd = null;
 | 
			
		||||
@@ -556,6 +598,8 @@ namespace Elwig.Helpers.Export {
 | 
			
		||||
                    rde.Add(rd);
 | 
			
		||||
                }
 | 
			
		||||
            }
 | 
			
		||||
            var createdAt = json["created_at"]?.AsValue().GetValue<string>();
 | 
			
		||||
            var modifiedAt = json["modified_at"]?.AsValue().GetValue<string>();
 | 
			
		||||
            return (new AreaCom {
 | 
			
		||||
                FbNr = json["fbnr"]!.AsValue().GetValue<int>(),
 | 
			
		||||
                MgNr = json["mgnr"]!.AsValue().GetValue<int>(),
 | 
			
		||||
@@ -568,7 +612,11 @@ namespace Elwig.Helpers.Export {
 | 
			
		||||
                YearFrom = json["year_from"]?.AsValue().GetValue<int>(),
 | 
			
		||||
                YearTo = json["year_to"]?.AsValue().GetValue<int>(),
 | 
			
		||||
                Comment = json["comment"]?.AsValue().GetValue<string>(),
 | 
			
		||||
            }, newRd ? rd : null);
 | 
			
		||||
                ImportedAt = DateTime.Now,
 | 
			
		||||
            }, newRd ? rd : null,
 | 
			
		||||
            createdAt == null || modifiedAt == null ? null :
 | 
			
		||||
            (DateTime.ParseExact(createdAt, "yyyy-MM-ddTHH:mm:ssK", CultureInfo.InvariantCulture, DateTimeStyles.None),
 | 
			
		||||
             DateTime.ParseExact(modifiedAt, "yyyy-MM-ddTHH:mm:ssK", CultureInfo.InvariantCulture, DateTimeStyles.None)));
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        public static JsonObject ToJson(this Delivery d) {
 | 
			
		||||
@@ -596,6 +644,8 @@ namespace Elwig.Helpers.Export {
 | 
			
		||||
                        ["manual_weighing"] = p.IsManualWeighing,
 | 
			
		||||
                        ["modids"] = new JsonArray(p.Modifiers.Select(m => (JsonNode)m.ModId).ToArray()),
 | 
			
		||||
                        ["comment"] = p.Comment,
 | 
			
		||||
                        ["created_at"] = $"{p.CreatedAt:yyyy-MM-ddTHH:mm:ssK}",
 | 
			
		||||
                        ["modified_at"] = $"{p.ModifiedAt:yyyy-MM-ddTHH:mm:ssK}",
 | 
			
		||||
                    };
 | 
			
		||||
                    if (p.IsSplCheck) obj["spl_check"] = p.IsSplCheck;
 | 
			
		||||
                    if (p.IsHandPicked != null) obj["hand_picked"] = p.IsHandPicked;
 | 
			
		||||
@@ -609,10 +659,12 @@ namespace Elwig.Helpers.Export {
 | 
			
		||||
                    return obj;
 | 
			
		||||
                }).ToArray()),
 | 
			
		||||
                ["comment"] = d.Comment,
 | 
			
		||||
                ["created_at"] = $"{d.CreatedAt:yyyy-MM-ddTHH:mm:ssK}",
 | 
			
		||||
                ["modified_at"] = $"{d.ModifiedAt:yyyy-MM-ddTHH:mm:ssK}",
 | 
			
		||||
            };
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        public static (Delivery, List<DeliveryPart>, List<DeliveryPartModifier>) ToDelivery(this JsonNode json, Dictionary<string, int> currentLsNrs, Dictionary<int, int> currentDids) {
 | 
			
		||||
        public static (Delivery, List<DeliveryPart>, List<DeliveryPartModifier>, (DateTime CreatedAt, DateTime ModifiedAt)?) ToDelivery(this JsonNode json, Dictionary<string, int> currentLsNrs, Dictionary<int, int> currentDids) {
 | 
			
		||||
            var year = json["year"]!.AsValue().GetValue<int>();
 | 
			
		||||
            var lsnr = json["lsnr"]!.AsValue().GetValue<string>();
 | 
			
		||||
            var did = currentLsNrs.GetValueOrDefault(lsnr, -1);
 | 
			
		||||
@@ -621,6 +673,8 @@ namespace Elwig.Helpers.Export {
 | 
			
		||||
                did = ++currentDids[year];
 | 
			
		||||
            }
 | 
			
		||||
            currentLsNrs[lsnr] = did;
 | 
			
		||||
            var createdAt = json["created_at"]?.AsValue().GetValue<string>();
 | 
			
		||||
            var modifiedAt = json["modified_at"]?.AsValue().GetValue<string>();
 | 
			
		||||
            return (new Delivery {
 | 
			
		||||
                Year = year,
 | 
			
		||||
                DId = did,
 | 
			
		||||
@@ -631,6 +685,7 @@ namespace Elwig.Helpers.Export {
 | 
			
		||||
                LsNr = lsnr,
 | 
			
		||||
                MgNr = json["mgnr"]!.AsValue().GetValue<int>(),
 | 
			
		||||
                Comment = json["comment"]?.AsValue().GetValue<string>(),
 | 
			
		||||
                ImportedAt = DateTime.Now,
 | 
			
		||||
            }, json["parts"]!.AsArray().Select(p => p!.AsObject()).Select(p => new DeliveryPart {
 | 
			
		||||
                Year = year,
 | 
			
		||||
                DId = did,
 | 
			
		||||
@@ -661,7 +716,10 @@ namespace Elwig.Helpers.Export {
 | 
			
		||||
                DId = did,
 | 
			
		||||
                DPNr = p["dpnr"]!.AsValue().GetValue<int>(),
 | 
			
		||||
                ModId = m!.AsValue().GetValue<string>(),
 | 
			
		||||
            })).ToList());
 | 
			
		||||
            })).ToList(),
 | 
			
		||||
            createdAt == null || modifiedAt == null ? null :
 | 
			
		||||
            (DateTime.ParseExact(createdAt, "yyyy-MM-ddTHH:mm:ssK", CultureInfo.InvariantCulture, DateTimeStyles.None),
 | 
			
		||||
             DateTime.ParseExact(modifiedAt, "yyyy-MM-ddTHH:mm:ssK", CultureInfo.InvariantCulture, DateTimeStyles.None)));
 | 
			
		||||
        }
 | 
			
		||||
    }
 | 
			
		||||
}
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user