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.common.parameters.GroupValidationResult;
24 import org.onap.policy.common.parameters.ParameterGroup;
25 import org.onap.policy.common.parameters.ParameterRuntimeException;
26 import org.onap.policy.common.parameters.ValidationStatus;
29 * A default event protocol parameter class that may be specialized by event protocol plugins that require plugin
30 * specific parameters.
33 * The following parameters are defined:
35 * <li>label: The label of the event protocol technology.
36 * <li>eventProducerPluginClass: The name of the plugin class that will be used by Apex to produce and emit output
37 * events for this carrier technology
40 * @author Liam Fallon (liam.fallon@ericsson.com)
42 public abstract class EventProtocolParameters implements ParameterGroup {
43 // The event protocol label
44 private String label = null;
46 // Event protocol converter plugin class for this event protocol
47 private String eventProtocolPluginClass;
50 * Constructor to create an event protocol parameters instance with the name of a sub class of this class and
51 * register the instance with the parameter service.
53 * @param parameterClassName the class name of a sub class of this class
55 public EventProtocolParameters(final String parameterClassName) {
60 * Gets the label of the event protocol.
62 * @return the label of the event protocol
64 public String getLabel() {
69 * Sets the label of the event protocol.
71 * @param label the label of the event protocol
73 public void setLabel(final String label) {
74 this.label = label.replaceAll("\\s+", "");
78 * Gets the event event protocol plugin class.
80 * @return the event event protocol plugin class
82 public String getEventProtocolPluginClass() {
83 return eventProtocolPluginClass;
87 * Sets the event event protocol plugin class.
89 * @param eventProtocolPluginClass the event event protocol plugin class
91 public void setEventProtocolPluginClass(final String eventProtocolPluginClass) {
92 this.eventProtocolPluginClass = eventProtocolPluginClass.replaceAll("\\s+", "");
98 * @see org.onap.policy.apex.model.basicmodel.service.AbstractParameters#toString()
101 public String toString() {
102 return "CarrierTechnologyParameters [label=" + label + ", EventProtocolPluginClass=" + eventProtocolPluginClass
109 * @see org.onap.policy.apex.service.parameters.ApexParameterValidator#validate()
112 public GroupValidationResult validate() {
113 final GroupValidationResult result = new GroupValidationResult(this);
115 if (label == null || label.length() == 0) {
116 result.setResult("label", ValidationStatus.INVALID, "event protocol label not specified or is blank");
119 if (eventProtocolPluginClass == null || eventProtocolPluginClass.length() == 0) {
120 result.setResult("eventProtocolPluginClass", ValidationStatus.INVALID,
121 "event protocol eventProtocolPluginClass not specified or is blank");
128 public String getName() {
129 return this.getLabel();
133 public void setName(final String name) {
134 throw new ParameterRuntimeException("the name/label of this event protocol is always \"" + getLabel() + "\"");