2  * ============LICENSE_START=======================================================
 
   3  *  Copyright (C) 2018 Ericsson. All rights reserved.
 
   4  * ================================================================================
 
   5  * Licensed under the Apache License, Version 2.0 (the "License");
 
   6  * you may not use this file except in compliance with the License.
 
   7  * You may obtain a copy of the License at
 
   9  *      http://www.apache.org/licenses/LICENSE-2.0
 
  11  * Unless required by applicable law or agreed to in writing, software
 
  12  * distributed under the License is distributed on an "AS IS" BASIS,
 
  13  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 
  14  * See the License for the specific language governing permissions and
 
  15  * limitations under the License.
 
  17  * SPDX-License-Identifier: Apache-2.0
 
  18  * ============LICENSE_END=========================================================
 
  21 package org.onap.policy.distribution.reception.parameters;
 
  23 import org.onap.policy.common.logging.flexlogger.FlexLogger;
 
  24 import org.onap.policy.common.logging.flexlogger.Logger;
 
  25 import org.onap.policy.common.parameters.GroupValidationResult;
 
  26 import org.onap.policy.common.parameters.ParameterGroup;
 
  27 import org.onap.policy.common.parameters.ValidationStatus;
 
  30  * Class to hold all the reception handler parameters.
 
  32  * @author Ram Krishna Verma (ram.krishna.verma@ericsson.com)
 
  34 public class ReceptionHandlerParameters implements ParameterGroup {
 
  36     private static final Logger LOGGER = FlexLogger.getLogger(ReceptionHandlerParameters.class);
 
  39     private String receptionHandlerType;
 
  40     private String receptionHandlerClassName;
 
  41     private PssdConfigurationParametersGroup pssdConfiguration;
 
  42     private PluginHandlerParameters pluginHandlerParameters;
 
  45      * Constructor for instantiating ReceptionHandlerParameters.
 
  47      * @param receptionHandlerType the reception handler type
 
  48      * @param receptionHandlerClassName the reception handler class name
 
  49      * @param pluginHandlerParameters the plugin handler parameters
 
  51     public ReceptionHandlerParameters(final String receptionHandlerType, final String receptionHandlerClassName, 
 
  52                                       final PssdConfigurationParametersGroup pssdConfiguration, 
 
  53                                       final PluginHandlerParameters pluginHandlerParameters) {
 
  54         this.receptionHandlerType = receptionHandlerType;
 
  55         this.receptionHandlerClassName = receptionHandlerClassName;
 
  56         this.pssdConfiguration = pssdConfiguration;
 
  57         this.pluginHandlerParameters = pluginHandlerParameters;
 
  61      * Return the receptionHandlerType of this ReceptionHandlerParameters instance.
 
  63      * @return the receptionHandlerType
 
  65     public String getReceptionHandlerType() {
 
  66         return receptionHandlerType;
 
  70      * Return the receptionHandlerClassName of this ReceptionHandlerParameters instance.
 
  72      * @return the receptionHandlerClassName
 
  74     public String getReceptionHandlerClassName() {
 
  75         return receptionHandlerClassName;
 
  79      * Return the PssdConfigurationParametersGroup of this ReceptionHandlerParameters instance.
 
  81      * @return the PssdConfigurationParametersGroup
 
  83     public PssdConfigurationParametersGroup getPssdConfigurationParametersGroup() {
 
  84         return pssdConfiguration;
 
  88      * Return the pluginHandlerParameters of this ReceptionHandlerParameters instance.
 
  90      * @return the pluginHandlerParameters
 
  92     public PluginHandlerParameters getPluginHandlerParameters() {
 
  93         return pluginHandlerParameters;
 
  97     public String getName() {
 
  98         return name + "_" + receptionHandlerType;
 
 102      * Validate the reception handler parameters.
 
 106     public GroupValidationResult validate() {
 
 107         final GroupValidationResult validationResult = new GroupValidationResult(this);
 
 108         if (receptionHandlerType == null || receptionHandlerType.trim().length() == 0) {
 
 109             validationResult.setResult("receptionHandlerType", ValidationStatus.INVALID, "must be a non-blank string");
 
 111         if (receptionHandlerClassName == null || receptionHandlerClassName.trim().length() == 0) {
 
 112             validationResult.setResult("receptionHandlerClassName", ValidationStatus.INVALID,
 
 113                     "must be a non-blank string containing full class name of the reception handler");
 
 115             validateReceptionHandlerClass(validationResult);
 
 117         if (pluginHandlerParameters == null) {
 
 118             validationResult.setResult("pluginHandlerParameters", ValidationStatus.INVALID,
 
 119                     "must have a plugin handler");
 
 121             validationResult.setResult("pluginHandlerParameters", pluginHandlerParameters.validate());
 
 123         return validationResult;
 
 126     private void validateReceptionHandlerClass(final GroupValidationResult validationResult) {
 
 128             Class.forName(receptionHandlerClassName);
 
 129         } catch (final ClassNotFoundException exp) {
 
 130             LOGGER.error("reception handler class not found in classpath", exp);
 
 131             validationResult.setResult("receptionHandlerClassName", ValidationStatus.INVALID,
 
 132                     "reception handler class not found in classpath");
 
 137      * Set the name of this group.
 
 139      * @param name the name to set
 
 141     public void setName(final String name) {