aboutsummaryrefslogtreecommitdiffstats
path: root/policy-management/src/main/java/org/onap/policy/drools/system/PolicyControllerFactory.java
blob: 05f15ead1ee28744a1d4064365bafefa257005df (plain)
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
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
/*
 * ============LICENSE_START=======================================================
 * policy-management
 * ================================================================================
 * Copyright (C) 2017-2019 AT&T Intellectual Property. 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.
 * ============LICENSE_END=========================================================
 */

package org.onap.policy.drools.system;

import java.util.List;
import java.util.Properties;
import org.onap.policy.drools.controller.DroolsController;
import org.onap.policy.drools.features.PolicyControllerFeatureApi;
import org.onap.policy.drools.protocol.configuration.DroolsConfiguration;


/**
 * Policy Controller Factory to manage controller creation, destruction,
 * and retrieval for management interfaces.
 */
public interface PolicyControllerFactory {
    /**
     * Build a controller from a properties file.
     *
     * @param name the global name of this controller
     * @param properties input parameters in form of properties for controller
     *     initialization.
     *
     * @return a Policy Controller
     *
     * @throws IllegalArgumentException invalid values provided in properties
     */
    PolicyController build(String name, Properties properties);

    /**
     * patches (updates) a controller from a critical configuration update.
     *
     * @param name name
     * @param configController config controller
     *
     * @return a Policy Controller
     */
    PolicyController patch(String name, DroolsConfiguration configController);

    /**
     * rebuilds (updates) a controller from a configuration update.
     *
     * @param controller controller
     * @param configController config controller
     */
    void patch(PolicyController controller,
               DroolsConfiguration configController);

    /**
     * get PolicyController from DroolsController.
     *
     * @param droolsController drools controller
     * @return policy controller
     * @throws IllegalArgumentException exception
     * @throws IllegalStateException exception
     */
    PolicyController get(DroolsController droolsController);

    /**
     * gets the Policy Controller identified by its name.
     *
     * @param policyControllerName name of policy controller
     * @return policy controller object
     * @throws IllegalArgumentException exception
     * @throws IllegalStateException exception
     */
    PolicyController get(String policyControllerName);

    /**
     * gets the Policy Controller identified by group and artifact ids.
     *
     * @param groupId group id
     * @param artifactId artifact id
     * @return policy controller object
     * @throws IllegalArgumentException exception
     * @throws IllegalStateException exception
     */
    PolicyController get(String groupId, String artifactId);

    /**
     * Makes the Policy Controller identified by controllerName not operational, but
     * does not delete its associated data.
     *
     * @param controllerName  name of the policy controller
     * @throws IllegalArgumentException invalid arguments
     */
    void shutdown(String controllerName);

    /**
     * Makes the Policy Controller identified by controller not operational, but
     * does not delete its associated data.
     *
     * @param controller a Policy Controller
     * @throws IllegalArgumentException invalid arguments
     */
    void shutdown(PolicyController controller);

    /**
     * Releases all Policy Controllers from operation.
     */
    void shutdown();

    /**
     * Destroys this Policy Controller.
     *
     * @param controllerName  name of the policy controller
     * @throws IllegalArgumentException invalid arguments
     */
    void destroy(String controllerName);

    /**
     * Destroys this Policy Controller.
     *
     * @param controller a Policy Controller
     * @throws IllegalArgumentException invalid arguments
     */
    void destroy(PolicyController controller);

    /**
     * Releases all Policy Controller resources.
     */
    void destroy();

    /**
     * get features attached to the Policy Controllers.
     *
     * @return list of features
     */
    List<PolicyControllerFeatureApi> getFeatureProviders();

    /**
     * get named feature attached to the Policy Controllers.
     *
     * @return the feature
     */
    PolicyControllerFeatureApi getFeatureProvider(String featureName);

    /**
     * get features attached to the Policy Controllers.
     *
     * @return list of features
     */
    List<String> getFeatures();

    /**
     * returns the current inventory of Policy Controllers.
     *
     * @return a list of Policy Controllers
     */
    List<PolicyController> inventory();
}