091c38ef3b7350d90bb93c000b2241d830e5f1a8
[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.ophistory;
22
23 import org.onap.policy.controlloop.ControlLoopOperation;
24 import org.onap.policy.controlloop.VirtualControlLoopEvent;
25
26 /**
27  * Data manager for the Operation History table.
28  */
29 public interface OperationHistoryDataManager {
30
31     /**
32      * Stores an operation in the DB. If the queue is full, then the oldest records is
33      * discarded.
34      *
35      * @param requestId request ID
36      * @param event event with which the operation is associated
37      * @param targetEntity target entity associated with the operation
38      * @param operation operation to be stored
39      */
40     void store(String requestId, VirtualControlLoopEvent event, String targetEntity, ControlLoopOperation operation);
41
42     /**
43      * Starts the background thread.
44      */
45     public void start();
46
47     /**
48      * Stops the background thread and places an "end" item into {@link #operations}.
49      */
50     public void stop();
51 }