Drools support for kafka topics
[policy/drools-pdp.git] / feature-pooling-messages / src / main / java / org / onap / policy / drools / pooling / state / InactiveState.java
1 /*
2  * ============LICENSE_START=======================================================
3  * ONAP
4  * ================================================================================
5  * Copyright (C) 2018 AT&T Intellectual Property. All rights reserved.
6  * Modifications Copyright (C) 2024 Nordix Foundation.
7  * ================================================================================
8  * Licensed under the Apache License, Version 2.0 (the "License");
9  * you may not use this file except in compliance with the License.
10  * You may obtain a copy of the License at
11  * 
12  *      http://www.apache.org/licenses/LICENSE-2.0
13  * 
14  * Unless required by applicable law or agreed to in writing, software
15  * distributed under the License is distributed on an "AS IS" BASIS,
16  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
17  * See the License for the specific language governing permissions and
18  * limitations under the License.
19  * ============LICENSE_END=========================================================
20  */
21
22 package org.onap.policy.drools.pooling.state;
23
24 import org.onap.policy.drools.pooling.PoolingManager;
25 import org.onap.policy.drools.pooling.message.Leader;
26 import org.onap.policy.drools.pooling.message.Query;
27 import org.slf4j.Logger;
28 import org.slf4j.LoggerFactory;
29
30 /**
31  * The inactive state. In this state, we just wait a bit and then try to re-activate. In
32  * the meantime, all messages are ignored.
33  */
34 public class InactiveState extends State {
35
36     private static final Logger logger = LoggerFactory.getLogger(InactiveState.class);
37
38     /**
39      * Constructor.
40      * 
41      * @param mgr pooling manager
42      */
43     public InactiveState(PoolingManager mgr) {
44         super(mgr);
45     }
46
47     @Override
48     public void start() {
49         super.start();
50         schedule(getProperties().getReactivateMs(), this::goStart);
51     }
52
53     @Override
54     public State process(Leader msg) {
55         if (isValid(msg)) {
56             logger.info("received Leader message from {} on topic {}", msg.getSource(), getTopic());
57             return goActive(msg.getAssignments());
58         }
59
60         return null;
61     }
62
63     /**
64      * Generates an Identification message and goes to the query state.
65      */
66     @Override
67     public State process(Query msg) {
68         logger.info("received Query message on topic {}", getTopic());
69         publish(makeIdentification());
70         return goQuery();
71     }
72
73     /**
74      * Remains in this state, without resetting any timers.
75      */
76     @Override
77     protected State goInactive() {
78         return null;
79     }
80
81 }