1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
|
/*-
* ============LICENSE_START=======================================================
* Copyright (C) 2016-2018 Ericsson. All rights reserved.
* ================================================================================
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*
* SPDX-License-Identifier: Apache-2.0
* ============LICENSE_END=========================================================
*/
package org.onap.policy.apex.core.engine;
import java.util.Map;
import java.util.Map.Entry;
import java.util.TreeMap;
import org.onap.policy.apex.context.parameters.ContextParameters;
import org.onap.policy.common.parameters.GroupValidationResult;
import org.onap.policy.common.parameters.ParameterGroup;
/**
* This class holds the parameters for a single Apex engine. This parameter class holds parameters for context schemas
* and context albums for the engine and a map of the logic flavour executors defined for the engine and the parameters
* for each of those executors.
*
* <p>The context parameters for the engine are held in a {@link ContextParameters} instance. This instance holds the
* parameters for context schema handling that will be used by the engine as well as the context album distribution,
* locking, and persistence parameters.
*
* <p>In Apex, an engine can be configured to use many logic flavours. The executors for each logic flavour are
* identified by their name. Each logic flavour executor must have an instance of {@link ExecutorParameters} defined for
* it, which specifies the executor plugins to use for that logic flavour executor and specific parameters for those
* executor plugins.
*
* @author Liam Fallon (liam.fallon@ericsson.com)
*/
public class EngineParameters implements ParameterGroup {
private ContextParameters contextParameters = new ContextParameters();
// Parameter group name
private String name;
// A map of parameters for executors of various logic types
private Map<String, ExecutorParameters> executorParameterMap = new TreeMap<>();
/**
* Constructor to create an engine parameters instance and register the instance with the parameter service.
*/
public EngineParameters() {
super();
// Set the name for the parameters
this.name = EngineParameterConstants.MAIN_GROUP_NAME;
}
/**
* Gets the parameters for context schema and album handling.
*
* @return the parameters for context schema and album handling
*/
public ContextParameters getContextParameters() {
return contextParameters;
}
/**
* Sets the parameters for context schema and album handling.
*
* @param contextParameters the parameters for context schema and album handling
*/
public void setContextParameters(final ContextParameters contextParameters) {
this.contextParameters = contextParameters;
}
/**
* Gets the executor parameter map of the engine.
*
* @return the executor parameter map of the engine
*/
public Map<String, ExecutorParameters> getExecutorParameterMap() {
return executorParameterMap;
}
/**
* Sets the executor parameter map of the engine.
*
* @param executorParameterMap the executor parameter map of the engine
*/
public void setExecutorParameterMap(final Map<String, ExecutorParameters> executorParameterMap) {
this.executorParameterMap = executorParameterMap;
}
@Override
public String getName() {
return name;
}
@Override
public void setName(final String name) {
this.name = name;
}
@Override
public GroupValidationResult validate() {
final GroupValidationResult result = new GroupValidationResult(this);
result.setResult("contextParameters", contextParameters.validate());
for (Entry<String, ExecutorParameters> executorParEntry : executorParameterMap.entrySet()) {
result.setResult("executorParameterMap", executorParEntry.getKey(), executorParEntry.getValue().validate());
}
return result;
}
}
|