0dcd302698a3880a5d7c712fbf5c299b95ff0518
[policy/drools-applications.git] /
1 /*-
2  * ============LICENSE_START=======================================================
3  * ONAP
4  * ================================================================================
5  * Copyright (C) 2020 AT&T Intellectual Property. All rights reserved.
6  * ================================================================================
7  * Licensed under the Apache License, Version 2.0 (the "License");
8  * you may not use this file except in compliance with the License.
9  * You may obtain a copy of the License at
10  *
11  *      http://www.apache.org/licenses/LICENSE-2.0
12  *
13  * Unless required by applicable law or agreed to in writing, software
14  * distributed under the License is distributed on an "AS IS" BASIS,
15  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
16  * See the License for the specific language governing permissions and
17  * limitations under the License.
18  * ============LICENSE_END=========================================================
19  */
20
21 package org.onap.policy.controlloop.eventmanager;
22
23 import java.util.concurrent.CompletableFuture;
24 import java.util.function.Consumer;
25 import org.onap.policy.controlloop.actorserviceprovider.ActorService;
26 import org.onap.policy.controlloop.actorserviceprovider.OperationOutcome;
27 import org.onap.policy.controlloop.ophistory.OperationHistoryDataManager;
28
29 /**
30  * Context for the Operation Manager.
31  */
32 public interface ManagerContext {
33
34     /**
35      * Gets the actor service.
36      *
37      * @return the actor service
38      */
39     ActorService getActorService();
40
41     /**
42      * Gets the operation history data manager.
43      *
44      * @return the operation history data manager
45      */
46     OperationHistoryDataManager getDataManager();
47
48     /**
49      * Requests a lock on the specified target.
50      *
51      * @param target target to be locked
52      * @param lockUnavailableCallback callback to be invoked if the lock is
53      *        unavailable/lost
54      * @return a future to await the lock
55      */
56     CompletableFuture<OperationOutcome> requestLock(String target, Consumer<OperationOutcome> lockUnavailableCallback);
57
58     /**
59      * Indicates that the given operation manager has been updated.
60      *
61      * @param operationMgr operation manager that has been updated
62      */
63     void updated(ControlLoopOperationManager2 operationMgr);
64 }