2 * ============LICENSE_START=======================================================
3 * Copyright (C) 2016-2018 Ericsson. All rights reserved.
4 * Modifications Copyright (C) 2021 AT&T Intellectual Property. All rights reserved.
5 * ================================================================================
6 * Licensed under the Apache License, Version 2.0 (the "License");
7 * you may not use this file except in compliance with the License.
8 * You may obtain a copy of the License at
10 * http://www.apache.org/licenses/LICENSE-2.0
12 * Unless required by applicable law or agreed to in writing, software
13 * distributed under the License is distributed on an "AS IS" BASIS,
14 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
15 * See the License for the specific language governing permissions and
16 * limitations under the License.
18 * SPDX-License-Identifier: Apache-2.0
19 * ============LICENSE_END=========================================================
22 package org.onap.policy.apex.service.parameters.eventprotocol;
24 import org.onap.policy.common.parameters.GroupValidationResult;
25 import org.onap.policy.common.parameters.ParameterGroup;
26 import org.onap.policy.common.parameters.ParameterRuntimeException;
27 import org.onap.policy.common.parameters.ValidationStatus;
30 * A default event protocol parameter class that may be specialized by event protocol plugins that require plugin
31 * specific parameters.
33 * <p>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 protected EventProtocolParameters() {
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+", "");
97 public String toString() {
98 return "CarrierTechnologyParameters [label=" + label + ", EventProtocolPluginClass=" + eventProtocolPluginClass
106 public GroupValidationResult validate() {
107 final GroupValidationResult result = new GroupValidationResult(this);
109 if (label == null || label.length() == 0) {
110 result.setResult("label", ValidationStatus.INVALID, "event protocol label not specified or is blank");
113 if (eventProtocolPluginClass == null || eventProtocolPluginClass.length() == 0) {
114 result.setResult("eventProtocolPluginClass", ValidationStatus.INVALID,
115 "event protocol eventProtocolPluginClass not specified or is blank");
122 public String getName() {
123 return this.getLabel();
127 public void setName(final String name) {
128 throw new ParameterRuntimeException("the name/label of this event protocol is always \"" + getLabel() + "\"");