From f6e3911c960b0e7f46492acd47520fd70347c7c9 Mon Sep 17 00:00:00 2001 From: AlexanderWollbrink <68860592+AlexanderWollbrink@users.noreply.github.com> Date: Wed, 8 May 2024 08:13:27 +0200 Subject: [PATCH] Namespace fix (#245) * adding namespace changes from AASPE * changing serving path back --- src/AasxCsharpLibrary/AdminShellPackageEnv.cs | 130 ++++++++++++++++-- .../Properties/launchSettings.json | 2 +- 2 files changed, 120 insertions(+), 12 deletions(-) diff --git a/src/AasxCsharpLibrary/AdminShellPackageEnv.cs b/src/AasxCsharpLibrary/AdminShellPackageEnv.cs index d990b60b1..79ce10f71 100644 --- a/src/AasxCsharpLibrary/AdminShellPackageEnv.cs +++ b/src/AasxCsharpLibrary/AdminShellPackageEnv.cs @@ -419,8 +419,7 @@ private static (AasCore.Aas3_0.Environment, Package, String) LoadPackageAasx(str if (originPart == null) { - xs = package.GetRelationshipsByType( - "http://www.admin-shell.io/aasx/relationships/aasx-origin"); + xs = package.GetRelationshipsByType("http://www.admin-shell.io/aasx/relationships/aasx-origin"); foreach (var x in xs) if (x.SourceUri.ToString() == "/") { @@ -843,6 +842,26 @@ public bool SaveAs(string fn, bool writeFreshly = false, SerializationFormat pre PackagePart originPart = null; var xs = package.GetRelationshipsByType( "http://www.admin-shell.io/aasx/relationships/aasx-origin"); + foreach (var x in xs) + if (x.SourceUri.ToString() == "/") + { + //originPart = package.GetPart(x.TargetUri); + + var absoluteURI = PackUriHelper.ResolvePartUri(x.SourceUri, x.TargetUri); + if (package.PartExists(absoluteURI)) + { + originPart = package.GetPart(absoluteURI); + } + //delete old type, because its not according to spec or something + //then replace with the current type + package.DeleteRelationship(x.Id); + package.CreateRelationship( + originPart.Uri, TargetMode.Internal, + "http://admin-shell.io/aasx/relationships/aasx-origin"); + originPart = null; + break; + } + xs = package.GetRelationshipsByType("http://admin-shell.io/aasx/relationships/aasx-origin"); foreach (var x in xs) if (x.SourceUri.ToString() == "/") { @@ -867,7 +886,7 @@ public bool SaveAs(string fn, bool writeFreshly = false, SerializationFormat pre } package.CreateRelationship( originPart.Uri, TargetMode.Internal, - "http://www.admin-shell.io/aasx/relationships/aasx-origin"); + "http://admin-shell.io/aasx/relationships/aasx-origin"); } // get the specs from the package @@ -883,6 +902,27 @@ public bool SaveAs(string fn, bool writeFreshly = false, SerializationFormat pre { specPart = package.GetPart(absoluteURI); } + //delete old type, because its not according to spec or something + //then replace with the current type + originPart.DeleteRelationship(x.Id); + originPart.CreateRelationship( + specPart.Uri, TargetMode.Internal, + "http://admin-shell.io/aasx/relationships/aas-spec"); + specPart = null; + specRel = null; + break; + } + xs = originPart.GetRelationshipsByType("http://admin-shell.io/aasx/relationships/aas-spec"); + foreach (var x in xs) + { + specRel = x; + //specPart = package.GetPart(x.TargetUri); + var absoluteURI = PackUriHelper.ResolvePartUri(x.SourceUri, x.TargetUri); + if (package.PartExists(absoluteURI)) + { + specPart = package.GetPart(absoluteURI); + } + break; } @@ -927,7 +967,7 @@ public bool SaveAs(string fn, bool writeFreshly = false, SerializationFormat pre System.Net.Mime.MediaTypeNames.Text.Xml, CompressionOption.Maximum); originPart.CreateRelationship( specPart.Uri, TargetMode.Internal, - "http://www.admin-shell.io/aasx/relationships/aas-spec"); + "http://admin-shell.io/aasx/relationships/aas-spec"); } // now, specPart shall be != null! @@ -969,6 +1009,33 @@ public bool SaveAs(string fn, bool writeFreshly = false, SerializationFormat pre } } + //Handling of aas_suppl namespace from v2 to v3 + //Need to check/test in detail, with thumbnails as well + if (specPart != null) + { + + xs = specPart.GetRelationshipsByType("http://www.admin-shell.io/aasx/relationships/aas-suppl"); + if (xs != null) + { + foreach (var x in xs.ToList()) + { + var uri = x.TargetUri; + PackagePart filePart = null; + var absoluteURI = PackUriHelper.ResolvePartUri(x.SourceUri, x.TargetUri); + if (package.PartExists(absoluteURI)) + { + filePart = package.GetPart(absoluteURI); + } + //delete old type, because its not according to spec or something + //then replace with the current type + specPart.DeleteRelationship(x.Id); + specPart.CreateRelationship( + filePart.Uri, TargetMode.Internal, + "http://admin-shell.io/aasx/relationships/aas-suppl"); + } + } + } + // there might be pending files to be deleted (first delete, then add, // in case of identical files in both categories) foreach (var psfDel in _pendingFilesToDelete) @@ -977,7 +1044,8 @@ public bool SaveAs(string fn, bool writeFreshly = false, SerializationFormat pre var found = false; // normal files - xs = specPart.GetRelationshipsByType("http://www.admin-shell.io/aasx/relationships/aas-suppl"); + xs = specPart.GetRelationshipsByType("http://admin-shell.io/aasx/relationships/aas-suppl"); + if (xs == null) xs = specPart.GetRelationshipsByType("http://www.admin-shell.io/aasx/relationships/aas-suppl"); foreach (var x in xs) if (x.TargetUri == psfDel.Uri) { @@ -1027,8 +1095,8 @@ public bool SaveAs(string fn, bool writeFreshly = false, SerializationFormat pre PackagePart filePart = null; if (psfAdd.SpecialHandling == AdminShellPackageSupplementaryFile.SpecialHandlingType.None) { - xs = specPart.GetRelationshipsByType( - "http://www.admin-shell.io/aasx/relationships/aas-suppl"); + xs = specPart.GetRelationshipsByType("http://admin-shell.io/aasx/relationships/aas-suppl"); + if (xs == null) xs = specPart.GetRelationshipsByType("http://www.admin-shell.io/aasx/relationships/aas-suppl"); foreach (var x in xs) if (x.TargetUri == psfAdd.Uri) { @@ -1078,7 +1146,7 @@ public bool SaveAs(string fn, bool writeFreshly = false, SerializationFormat pre AdminShellPackageSupplementaryFile.SpecialHandlingType.None) specPart.CreateRelationship( filePart.Uri, TargetMode.Internal, - "http://www.admin-shell.io/aasx/relationships/aas-suppl"); + "http://admin-shell.io/aasx/relationships/aas-suppl"); if (psfAdd.SpecialHandling == AdminShellPackageSupplementaryFile.SpecialHandlingType.EmbedAsThumbnail) package.CreateRelationship( @@ -1467,7 +1535,7 @@ public ListOfAasSupplementaryFile GetListOfSupplementaryFiles() // get the origin from the package PackagePart originPart = null; xs = _openPackage.GetRelationshipsByType( - "http://www.admin-shell.io/aasx/relationships/aasx-origin"); + "http://admin-shell.io/aasx/relationships/aasx-origin"); foreach (var x in xs) if (x.SourceUri.ToString() == "/") { @@ -1479,12 +1547,28 @@ public ListOfAasSupplementaryFile GetListOfSupplementaryFiles() } break; } + if(xs == null) + { + xs = _openPackage.GetRelationshipsByType( + "http://www.admin-shell.io/aasx/relationships/aasx-origin"); + foreach (var x in xs) + if (x.SourceUri.ToString() == "/") + { + //originPart = _openPackage.GetPart(x.TargetUri); + var absoluteURI = PackUriHelper.ResolvePartUri(x.SourceUri, x.TargetUri); + if (_openPackage.PartExists(absoluteURI)) + { + originPart = _openPackage.GetPart(absoluteURI); + } + break; + } + } if (originPart != null) { // get the specs from the origin PackagePart specPart = null; - xs = originPart.GetRelationshipsByType("http://www.admin-shell.io/aasx/relationships/aas-spec"); + xs = originPart.GetRelationshipsByType("http://admin-shell.io/aasx/relationships/aas-spec"); foreach (var x in xs) { //specPart = _openPackage.GetPart(x.TargetUri); @@ -1495,17 +1579,41 @@ public ListOfAasSupplementaryFile GetListOfSupplementaryFiles() } break; } + if(xs == null) + { + xs = originPart.GetRelationshipsByType("http://www.admin-shell.io/aasx/relationships/aas-spec"); + foreach (var x in xs) + { + //specPart = _openPackage.GetPart(x.TargetUri); + var absoluteURI = PackUriHelper.ResolvePartUri(x.SourceUri, x.TargetUri); + if (_openPackage.PartExists(absoluteURI)) + { + specPart = _openPackage.GetPart(absoluteURI); + } + break; + } + } if (specPart != null) { // get the supplementaries from the package, derived from spec - xs = specPart.GetRelationshipsByType("http://www.admin-shell.io/aasx/relationships/aas-suppl"); + xs = specPart.GetRelationshipsByType("http://admin-shell.io/aasx/relationships/aas-suppl"); foreach (var x in xs) { result.Add( new AdminShellPackageSupplementaryFile( x.TargetUri, location: AdminShellPackageSupplementaryFile.LocationType.InPackage)); } + if(xs == null) + { + xs = specPart.GetRelationshipsByType("http://www.admin-shell.io/aasx/relationships/aas-suppl"); + foreach (var x in xs) + { + result.Add( + new AdminShellPackageSupplementaryFile( + x.TargetUri, location: AdminShellPackageSupplementaryFile.LocationType.InPackage)); + } + } } } } diff --git a/src/AasxServerBlazor/Properties/launchSettings.json b/src/AasxServerBlazor/Properties/launchSettings.json index 85cd5c64a..389a3663f 100644 --- a/src/AasxServerBlazor/Properties/launchSettings.json +++ b/src/AasxServerBlazor/Properties/launchSettings.json @@ -10,7 +10,7 @@ }, "AasxServerBlazor": { "commandName": "Project", - "commandLineArgs": "--no-security --secret-string-api 1234 --aasx-in-memory 1000 --data-path \"C:\\Users\\7wrmhx\\Downloads\\Krohne OneDrive_1_2.4.2024\" --edit --external-blazor http://localhost:5001", + "commandLineArgs": "--no-security --secret-string-api 1234 --aasx-in-memory 1000 --data-path \"C:\\Development\" --edit --external-blazor http://localhost:5001", "launchBrowser": true, "environmentVariables": { "ASPNETCORE_ENVIRONMENT": "Development",