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.parameters.GroupValidationResult;
24 import org.onap.policy.common.parameters.ParameterGroup;
25 import org.onap.policy.common.parameters.ValidationStatus;
28 * Class to hold all the policy decoder parameters.
30 * @author Ram Krishna Verma (ram.krishna.verma@ericsson.com)
32 public class PolicyDecoderParameters implements ParameterGroup {
33 private String decoderType;
34 private String decoderClassName;
37 * Constructor for instantiating PolicyDecoderParameters.
39 * @param decoderType the policy decoder type
40 * @param decoderClassName the policy decoder class name
42 public PolicyDecoderParameters(final String decoderType, final String decoderClassName) {
43 this.decoderType = decoderType;
44 this.decoderClassName = decoderClassName;
48 * Return the decoderType of this PolicyDecoderParameters instance.
50 * @return the decoderType
52 public String getDecoderType() {
57 * Return the decoderClassName of this PolicyDecoderParameters instance.
59 * @return the decoderClassName
61 public String getDecoderClassName() {
62 return decoderClassName;
66 public String getName() {
71 * Validate the policy decoder parameters.
75 public GroupValidationResult validate() {
76 final GroupValidationResult validationResult = new GroupValidationResult(this);
77 if (decoderType == null || decoderType.trim().length() == 0) {
78 validationResult.setResult("decoderType", ValidationStatus.INVALID, "must be a non-blank string");
80 if (decoderClassName == null || decoderClassName.trim().length() == 0) {
81 validationResult.setResult("decoderClassName", ValidationStatus.INVALID,
82 "must be a non-blank string containing full class name of the decoder");
84 validatePolicyDecoderClass(validationResult);
86 return validationResult;
89 private void validatePolicyDecoderClass(final GroupValidationResult validationResult) {
91 Class.forName(decoderClassName);
92 } catch (final ClassNotFoundException e) {
93 validationResult.setResult("decoderClassName", ValidationStatus.INVALID,
94 "policy decoder class not found in classpath");