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 String receptionHandlerConfigurationName;
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 receptionHandlerConfigurationName the name of the configuration for the reception
51 * @param pluginHandlerParameters the plugin handler parameters
53 public ReceptionHandlerParameters(final String receptionHandlerType, final String receptionHandlerClassName,
54 final String receptionHandlerConfigurationName, final PluginHandlerParameters pluginHandlerParameters) {
55 this.receptionHandlerType = receptionHandlerType;
56 this.receptionHandlerClassName = receptionHandlerClassName;
57 this.receptionHandlerConfigurationName = receptionHandlerConfigurationName;
58 this.pluginHandlerParameters = pluginHandlerParameters;
62 * Return the receptionHandlerType of this ReceptionHandlerParameters instance.
64 * @return the receptionHandlerType
66 public String getReceptionHandlerType() {
67 return receptionHandlerType;
71 * Return the receptionHandlerClassName of this ReceptionHandlerParameters instance.
73 * @return the receptionHandlerClassName
75 public String getReceptionHandlerClassName() {
76 return receptionHandlerClassName;
80 * Return the name of the reception handler configuration for this ReceptionHandlerParameters
83 * @return the PssdConfigurationParametersGroup
85 public String getReceptionHandlerConfigurationName() {
86 return receptionHandlerConfigurationName;
90 * Return the pluginHandlerParameters of this ReceptionHandlerParameters instance.
92 * @return the pluginHandlerParameters
94 public PluginHandlerParameters getPluginHandlerParameters() {
95 return pluginHandlerParameters;
99 public String getName() {
100 return name + "_" + receptionHandlerType;
104 * Validate the reception handler parameters.
108 public GroupValidationResult validate() {
109 final GroupValidationResult validationResult = new GroupValidationResult(this);
110 if (receptionHandlerType == null || receptionHandlerType.trim().length() == 0) {
111 validationResult.setResult("receptionHandlerType", ValidationStatus.INVALID, "must be a non-blank string");
113 if (receptionHandlerClassName == null || receptionHandlerClassName.trim().length() == 0) {
114 validationResult.setResult("receptionHandlerClassName", ValidationStatus.INVALID,
115 "must be a non-blank string containing full class name of the reception handler");
117 validateReceptionHandlerClass(validationResult);
119 if (pluginHandlerParameters == null) {
120 validationResult.setResult("pluginHandlerParameters", ValidationStatus.INVALID,
121 "must have a plugin handler");
123 validationResult.setResult("pluginHandlerParameters", pluginHandlerParameters.validate());
125 return validationResult;
128 private void validateReceptionHandlerClass(final GroupValidationResult validationResult) {
130 Class.forName(receptionHandlerClassName);
131 } catch (final ClassNotFoundException exp) {
132 LOGGER.error("reception handler class not found in classpath", exp);
133 validationResult.setResult("receptionHandlerClassName", ValidationStatus.INVALID,
134 "reception handler class not found in classpath");
139 * Set the name of this group.
141 * @param name the name to set
144 public void setName(final String name) {