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.
30 * <p>The following parameters are defined:
32 * <li>label: The label of the event protocol technology.
33 * <li>eventProducerPluginClass: The name of the plugin class that will be used by Apex to produce
34 * and emit output events for this carrier technology
37 * @author Liam Fallon (liam.fallon@ericsson.com)
39 public abstract class EventProtocolParameters extends AbstractParameters implements ApexParameterValidator {
40 // The event protocol label
41 private String label = null;
43 // Event protocol converter plugin class for this event protocol
44 private String eventProtocolPluginClass;
47 * Constructor to create an event protocol parameters instance with the name of a sub class of
48 * this class and register the instance with the parameter service.
50 * @param parameterClassName the class name of a sub class of this class
52 public EventProtocolParameters(final String parameterClassName) {
53 super(parameterClassName);
57 * Gets the label of the event protocol.
59 * @return the label of the event protocol
61 public String getLabel() {
66 * Sets the label of the event protocol.
68 * @param label the label of the event protocol
70 public void setLabel(final String label) {
71 this.label = label.replaceAll("\\s+", "");
75 * Gets the event event protocol plugin class.
77 * @return the event event protocol plugin class
79 public String getEventProtocolPluginClass() {
80 return eventProtocolPluginClass;
84 * Sets the event event protocol plugin class.
86 * @param eventProtocolPluginClass the event event protocol plugin class
88 public void setEventProtocolPluginClass(final String eventProtocolPluginClass) {
89 this.eventProtocolPluginClass = eventProtocolPluginClass.replaceAll("\\s+", "");
95 * @see org.onap.policy.apex.model.basicmodel.service.AbstractParameters#toString()
98 public String toString() {
99 return "CarrierTechnologyParameters [label=" + label + ", EventProtocolPluginClass=" + eventProtocolPluginClass
106 * @see org.onap.policy.apex.service.parameters.ApexParameterValidator#validate()
109 public String validate() {
110 final StringBuilder errorMessageBuilder = new StringBuilder();
112 if (label == null || label.length() == 0) {
113 errorMessageBuilder.append(" event protocol label not specified or is blank\n");
116 if (eventProtocolPluginClass == null || eventProtocolPluginClass.length() == 0) {
117 errorMessageBuilder.append(" event protocol eventProtocolPluginClass not specified or is blank\n");
120 return errorMessageBuilder.toString();