71357f34af3f6490d45c37eb820bd1f8db227464
[portal/sdk.git] /
1 /*
2  * ============LICENSE_START==========================================
3  * ONAP Portal SDK
4  * ===================================================================
5  * Copyright © 2017 AT&T Intellectual Property. All rights reserved.
6  * ===================================================================
7  *
8  * Unless otherwise specified, all software contained herein is licensed
9  * under the Apache License, Version 2.0 (the "License");
10  * you may not use this software except in compliance with the License.
11  * You may obtain a copy of the License at
12  *
13  *             http://www.apache.org/licenses/LICENSE-2.0
14  *
15  * Unless required by applicable law or agreed to in writing, software
16  * distributed under the License is distributed on an "AS IS" BASIS,
17  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
18  * See the License for the specific language governing permissions and
19  * limitations under the License.
20  *
21  * Unless otherwise specified, all documentation contained herein is licensed
22  * under the Creative Commons License, Attribution 4.0 Intl. (the "License");
23  * you may not use this documentation except in compliance with the License.
24  * You may obtain a copy of the License at
25  *
26  *             https://creativecommons.org/licenses/by/4.0/
27  *
28  * Unless required by applicable law or agreed to in writing, documentation
29  * distributed under the License is distributed on an "AS IS" BASIS,
30  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
31  * See the License for the specific language governing permissions and
32  * limitations under the License.
33  *
34  * ============LICENSE_END============================================
35  *
36  * ECOMP is a trademark and service mark of AT&T Intellectual Property.
37  */
38 package org.onap.portalsdk.core.objectcache.jcs;
39
40 import org.apache.jcs.engine.control.event.behavior.IElementEvent;
41 import org.apache.jcs.engine.control.event.behavior.IElementEventConstants;
42 import org.apache.jcs.engine.control.event.behavior.IElementEventHandler;
43 import org.onap.portalsdk.core.logging.logic.EELFLoggerDelegate;
44
45 public class JCSCacheEventHandler implements IElementEventHandler, IElementEventConstants {
46
47         private static final EELFLoggerDelegate logger = EELFLoggerDelegate.getLogger(JCSCacheEventHandler.class);
48
49         public JCSCacheEventHandler() {
50                 super();
51         }
52
53         @Override
54         public void handleElementEvent(IElementEvent event) {
55                 // Handle code for various event notifications on cached elements by JCS.
56                 switch (event.getElementEvent()) {
57                 case ELEMENT_EVENT_EXCEEDED_MAXLIFE_BACKGROUND:
58                         logger.error(EELFLoggerDelegate.errorLogger,
59                                         "Event ELEMENT_EVENT_EXCEEDED_MAXLIFE_BACKGROUND occurred for element " + event);
60                         break;
61                 case ELEMENT_EVENT_EXCEEDED_MAXLIFE_ONREQUEST:
62                         logger.error(EELFLoggerDelegate.errorLogger,
63                                         "Event ELEMENT_EVENT_EXCEEDED_MAXLIFE_ONREQUEST occurred for element " + event);
64                         break;
65                 case ELEMENT_EVENT_EXCEEDED_IDLETIME_BACKGROUND:
66                         logger.error(EELFLoggerDelegate.errorLogger,
67                                         "Event ELEMENT_EVENT_EXCEEDED_IDLETIME_BACKGROUND occurred for element " + event);
68                         break;
69                 case ELEMENT_EVENT_EXCEEDED_IDLETIME_ONREQUEST:
70                         logger.error(EELFLoggerDelegate.errorLogger,
71                                         "Event ELEMENT_EVENT_EXCEEDED_IDLETIME_ONREQUEST occurred for element " + event);
72                         break;
73                 case ELEMENT_EVENT_SPOOLED_DISK_AVAILABLE:
74                         logger.error(EELFLoggerDelegate.errorLogger,
75                                         "Event ELEMENT_EVENT_SPOOLED_DISK_AVAILABLE occurred for element " + event);
76                         break;
77                 case ELEMENT_EVENT_SPOOLED_DISK_NOT_AVAILABLE:
78                         logger.error(EELFLoggerDelegate.errorLogger,
79                                         "Event ELEMENT_EVENT_SPOOLED_DISK_NOT_AVAILABLE occurred for element " + event);
80                         break;
81                 case ELEMENT_EVENT_SPOOLED_NOT_ALLOWED:
82                         logger.error(EELFLoggerDelegate.errorLogger,
83                                         "Event ELEMENT_EVENT_SPOOLED_NOT_ALLOWED occurred for element " + event);
84                 default:
85                         logger.error(EELFLoggerDelegate.errorLogger, "handleElementEvent: unknown event " + event);
86                 }
87         }
88 }