X-Git-Url: https://gerrit.onap.org/r/gitweb?a=blobdiff_plain;f=src%2Fmain%2Fjava%2Forg%2Fonap%2Faai%2Fbabel%2Fxml%2Fgenerator%2Fdata%2FWidgetConfigurationUtil.java;h=b340cd9565442e1a50792ec932c9e7cc29ebaf1b;hb=5a6fd49a6aca3a567464527335b107746e28f3bd;hp=30b6c8ee3721c7dc4f8ea69b8cc35ec37200aec5;hpb=7fcc74469c941c1834cd02b54ff5ca88a53bf83b;p=aai%2Fbabel.git diff --git a/src/main/java/org/onap/aai/babel/xml/generator/data/WidgetConfigurationUtil.java b/src/main/java/org/onap/aai/babel/xml/generator/data/WidgetConfigurationUtil.java index 30b6c8e..b340cd9 100644 --- a/src/main/java/org/onap/aai/babel/xml/generator/data/WidgetConfigurationUtil.java +++ b/src/main/java/org/onap/aai/babel/xml/generator/data/WidgetConfigurationUtil.java @@ -2,8 +2,8 @@ * ============LICENSE_START======================================================= * org.onap.aai * ================================================================================ - * Copyright © 2017-2019 AT&T Intellectual Property. All rights reserved. - * Copyright © 2017-2019 European Software Marketing Ltd. + * Copyright (c) 2017-2019 AT&T Intellectual Property. All rights reserved. + * Copyright (c) 2017-2019 European Software Marketing Ltd. * ================================================================================ * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. @@ -18,24 +18,32 @@ * limitations under the License. * ============LICENSE_END========================================================= */ + package org.onap.aai.babel.xml.generator.data; +import com.google.common.base.Enums; +import java.io.IOException; import java.util.Collections; import java.util.HashMap; import java.util.List; import java.util.Map; -import java.util.Map.Entry; +import java.util.Optional; import java.util.Properties; -import org.onap.aai.babel.xml.generator.model.Model; +import org.onap.aai.babel.xml.generator.XmlArtifactGenerationException; +import org.onap.aai.babel.xml.generator.model.Resource; +import org.onap.aai.babel.xml.generator.model.Widget; +import org.onap.aai.babel.xml.generator.model.Widget.Type; +import org.onap.aai.babel.xml.generator.types.ModelType; public class WidgetConfigurationUtil { private static Properties config; private static List instanceGroups = Collections.emptyList(); - private static Map> typeToModel = new HashMap<>(); + private static Map typeToResource = new HashMap<>(); + private static Map typeToWidget = new HashMap<>(); /* - * Private constructor to prevent instantiation + * Private constructor to prevent instantiation. */ private WidgetConfigurationUtil() { throw new UnsupportedOperationException("This static class should not be instantiated!"); @@ -51,36 +59,46 @@ public class WidgetConfigurationUtil { public static void setSupportedInstanceGroups(List supportedInstanceGroups) { instanceGroups = supportedInstanceGroups; - } + } public static boolean isSupportedInstanceGroup(String groupType) { return instanceGroups.contains(groupType); } - /** - * Create the mappings from TOSCA type to Widget type. The Properties store a set of TOSCA type prefix Strings. - * These keys take a single class name (String), which is used to map to a Widget Class in the Model. - * - * @param map - * the key/value pairs of TOSCA type and Class name - */ - @SuppressWarnings("unchecked") - public static void setTypeMappings(Map map) { - for (Entry entry : map.entrySet()) { - final String toscaType = entry.getKey(); - final String javaBean = entry.getValue(); - final String modelClassName = Model.class.getPackage().getName() + "." + javaBean; - try { - typeToModel.put(toscaType, (Class) Class.forName(modelClassName)); - } catch (ClassNotFoundException e) { - throw new IllegalArgumentException( - String.format("Unsupported type \"%s\" for TOSCA mapping %s: no class found for %s", // - javaBean, toscaType, modelClassName)); + public static Optional createModelFromType(String typePrefix) { + return Optional.ofNullable(typeToResource.get(typePrefix)); + } + + public static Widget createWidgetFromType(Type type) throws XmlArtifactGenerationException { + Optional widget = Optional.ofNullable(typeToWidget.get(type.toString())); + if (widget.isPresent()) { + // Make a copy of the Widget found in the mappings table. + return new Widget(widget.get()); + } + return null; + } + + public static void setWidgetTypes(List types) { + for (WidgetType type : types) { + if (type.type == null || type.name == null) { + throw new IllegalArgumentException("Incomplete widget type specified: " + type); } + Type widgetType = Widget.Type.valueOf(type.type); + Widget widget = new Widget(widgetType, type.name, type.deleteFlag); + typeToWidget.put(type.type, widget); } } - public static Class getModelFromType(String typePrefix) { - return typeToModel.get(typePrefix); + public static void setWidgetMappings(List mappings) throws IOException { + for (WidgetMapping mapping : mappings) { + ModelType modelType = Optional.ofNullable(mapping.type).map(String::toUpperCase) + .map(s -> Enums.getIfPresent(ModelType.class, s).orNull()).orElse(null); + if (mapping.prefix == null || mapping.widget == null || modelType == null) { + throw new IOException("Invalid widget mapping specified: " + mapping); + } + Resource resource = new Resource(Widget.Type.valueOf(mapping.widget), mapping.deleteFlag); + resource.setModelType(modelType); + typeToResource.put(mapping.prefix, resource); + } } }