From 0d4544eb82a2ca79d7724e5c1da70d3943db76eb Mon Sep 17 00:00:00 2001 From: Bogumil Zebek Date: Fri, 15 Mar 2019 10:43:42 +0100 Subject: Update manifest parser Change-Id: I420fd9fb97450cbcc2afc15632717182e18f0333 Issue-ID: VNFSDK-384 Signed-off-by: Zebek Bogumil --- .../java/org/onap/cvc/csar/PnfManifestParser.java | 43 ++++++++++++---------- 1 file changed, 23 insertions(+), 20 deletions(-) (limited to 'csarvalidation/src/main/java/org') diff --git a/csarvalidation/src/main/java/org/onap/cvc/csar/PnfManifestParser.java b/csarvalidation/src/main/java/org/onap/cvc/csar/PnfManifestParser.java index a92ebd4..5694049 100644 --- a/csarvalidation/src/main/java/org/onap/cvc/csar/PnfManifestParser.java +++ b/csarvalidation/src/main/java/org/onap/cvc/csar/PnfManifestParser.java @@ -28,11 +28,15 @@ import java.util.Map; import java.util.stream.Collectors; import java.util.stream.Stream; -public class PnfManifestParser { +class PnfManifestParser { - public static final String METADATA_SECTION = "metadata"; - public static final String NON_MANO_ARTIFACT_SETS_SECTION = "non_mano_artifact_sets"; + private static final String METADATA_SECTION = "metadata"; + private static final String NON_MANO_ARTIFACT_SETS_SECTION = "non_mano_artifact_sets"; + private static final String PRODUCT_NAME = "pnfd_name"; + private static final String PROVIDER_ID = "pnfd_provider"; + private static final String VERSION = "pnfd_archive_version"; + private static final String RELEASE_DATE_TIME = "pnfd_release_date_time"; private final List lines; private final String fileName; @@ -42,7 +46,7 @@ public class PnfManifestParser { this.fileName = fileName; } - public static PnfManifestParser getInstance(String fileName) throws IOException { + static PnfManifestParser getInstance(String fileName) throws IOException { try (Stream stream = Files.lines(Paths.get(fileName))) { List lines = stream .map(String::trim) @@ -52,7 +56,7 @@ public class PnfManifestParser { } } - public Pair> fetchMetadata() { + Pair> fetchMetadata() { CSARArchive.Manifest.Metadata metadata = new CSARArchive.Manifest.Metadata(); List errors = new ArrayList<>(); @@ -60,11 +64,10 @@ public class PnfManifestParser { int lineNumber = 0; for (String line : lines) { lineNumber++; - if (line.trim().isEmpty()){ + if (line.trim().isEmpty() || line.trim().startsWith("#")){ continue; } else if (line.startsWith(METADATA_SECTION)) { isMetadataSectionAvailable = true; - continue; }else if (isMetadataSectionAvailable) { Pair data = parseLine(line); @@ -87,7 +90,7 @@ public class PnfManifestParser { } - public Pair>>, List> fetchNonManoArtifacts() { + Pair>>, List> fetchNonManoArtifacts() { Map>> nonManoArtifacts = new HashMap<>(); List errors = new ArrayList<>(); @@ -96,11 +99,10 @@ public class PnfManifestParser { for (String line : lines) { - if (line.trim().isEmpty()) { + if (line.trim().isEmpty() || line.trim().startsWith("#")) { continue; } else if (line.startsWith(NON_MANO_ARTIFACT_SETS_SECTION)) { isNonManoArtifactsSectionAvailable = true; - continue; } else if (isNonManoArtifactsSectionAvailable) { Pair data = parseLine(line); @@ -130,16 +132,16 @@ public class PnfManifestParser { String value = data.getValue(); switch (paramName) { - case "pnf_product_name": + case PRODUCT_NAME: metadata.setProductName(value); break; - case "pnf_provider_id": + case PROVIDER_ID: metadata.setProviderId(value); break; - case "pnf_package_version": + case VERSION: metadata.setPackageVersion(value); break; - case "pnf_release_date_time": + case RELEASE_DATE_TIME: metadata.setReleaseDateTime(value); break; default: @@ -172,8 +174,9 @@ public class PnfManifestParser { private boolean isNewSection(Pair data) { + String key = data.getKey().trim(); String value = data.getValue().trim(); - return value.isEmpty() || value.startsWith("#"); + return key.matches("[a-zA-z_0-9]+") && (value.isEmpty() || value.startsWith("#")); } @@ -191,7 +194,7 @@ public class PnfManifestParser { } private static class PnfCSARError extends CSARArchive.CSARError { - public PnfCSARError(String errorCode, String message, int lineNumber, String file) { + PnfCSARError(String errorCode, String message, int lineNumber, String file) { super(errorCode); this.message = message; this.file = file; @@ -199,20 +202,20 @@ public class PnfManifestParser { } } - public static class PnfCSARErrorInvalidEntry extends PnfCSARError { - public PnfCSARErrorInvalidEntry(String entry, String file, int lineNumber) { + private static class PnfCSARErrorInvalidEntry extends PnfCSARError { + PnfCSARErrorInvalidEntry(String entry, String file, int lineNumber) { super("0x2000", "Invalid. Entry [" + entry + "]", lineNumber, file); } } private static class PnfCSARErrorWarning extends PnfCSARError { - public PnfCSARErrorWarning(String entry, String file, int lineNumber) { + PnfCSARErrorWarning(String entry, String file, int lineNumber) { super("0x2001", "Warning. Entry [" + entry + "]", lineNumber, file); } } private static class PnfCSARErrorEntryMissing extends PnfCSARError { - public PnfCSARErrorEntryMissing(String entry, String file, int lineNumber) { + PnfCSARErrorEntryMissing(String entry, String file, int lineNumber) { super("0x2002", "Missing. Entry [" + entry + "]", lineNumber, file); } } -- cgit 1.2.3-korg