2 * ============LICENSE_START=======================================================
3 * Copyright (C) 2016-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.apex.service.parameters.eventprotocol;
23 import org.onap.policy.apex.model.basicmodel.service.AbstractParameters;
24 import org.onap.policy.apex.service.parameters.ApexParameterValidator;
27 * A default event protocol parameter class that may be specialized by event protocol plugins that
28 * require plugin specific parameters.
31 * The following parameters are defined:
33 * <li>label: The label of the event protocol technology.
34 * <li>eventProducerPluginClass: The name of the plugin class that will be used by Apex to produce
35 * and emit output events for this carrier technology
38 * @author Liam Fallon (liam.fallon@ericsson.com)
40 public abstract class EventProtocolParameters extends AbstractParameters implements ApexParameterValidator {
41 // The event protocol label
42 private String label = null;
44 // Event protocol converter plugin class for this event protocol
45 private String eventProtocolPluginClass;
48 * Constructor to create an event protocol parameters instance with the name of a sub class of
49 * this class and register the instance with the parameter service.
51 * @param parameterClassName the class name of a sub class of this class
53 public EventProtocolParameters(final String parameterClassName) {
54 super(parameterClassName);
58 * Gets the label of the event protocol.
60 * @return the label of the event protocol
62 public String getLabel() {
67 * Sets the label of the event protocol.
69 * @param label the label of the event protocol
71 public void setLabel(final String label) {
72 this.label = label.replaceAll("\\s+", "");
76 * Gets the event event protocol plugin class.
78 * @return the event event protocol plugin class
80 public String getEventProtocolPluginClass() {
81 return eventProtocolPluginClass;
85 * Sets the event event protocol plugin class.
87 * @param eventProtocolPluginClass the event event protocol plugin class
89 public void setEventProtocolPluginClass(final String eventProtocolPluginClass) {
90 this.eventProtocolPluginClass = eventProtocolPluginClass.replaceAll("\\s+", "");
96 * @see org.onap.policy.apex.model.basicmodel.service.AbstractParameters#toString()
99 public String toString() {
100 return "CarrierTechnologyParameters [label=" + label + ", EventProtocolPluginClass=" + eventProtocolPluginClass
107 * @see org.onap.policy.apex.service.parameters.ApexParameterValidator#validate()
110 public String validate() {
111 final StringBuilder errorMessageBuilder = new StringBuilder();
113 if (label == null || label.length() == 0) {
114 errorMessageBuilder.append(" event protocol label not specified or is blank\n");
117 if (eventProtocolPluginClass == null || eventProtocolPluginClass.length() == 0) {
118 errorMessageBuilder.append(" event protocol eventProtocolPluginClass not specified or is blank\n");
121 return errorMessageBuilder.toString();