[DMAAP-BC] Consolidate bus controller repos
[dmaap/buscontroller.git] / dmaap-bc / src / main / java / org / onap / dmaap / dbcapi / resources / RequestTimeLogFilter.java
1 /*-\r
2  * ============LICENSE_START=======================================================\r
3  * org.onap.dmaap\r
4  * ================================================================================\r
5  * Copyright (C) 2019 Nokia Intellectual Property. All rights reserved.\r
6  * ================================================================================\r
7  * Licensed under the Apache License, Version 2.0 (the "License");\r
8  * you may not use this file except in compliance with the License.\r
9  * You may obtain a copy of the License at\r
10  *\r
11  *      http://www.apache.org/licenses/LICENSE-2.0\r
12  *\r
13  * Unless required by applicable law or agreed to in writing, software\r
14  * distributed under the License is distributed on an "AS IS" BASIS,\r
15  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\r
16  * See the License for the specific language governing permissions and\r
17  * limitations under the License.\r
18  * ============LICENSE_END=========================================================\r
19  */\r
20 package org.onap.dmaap.dbcapi.resources;\r
21 \r
22 import com.att.eelf.configuration.EELFLogger;\r
23 import java.time.Clock;\r
24 import javax.ws.rs.container.ContainerRequestContext;\r
25 import javax.ws.rs.container.ContainerRequestFilter;\r
26 import javax.ws.rs.container.ContainerResponseContext;\r
27 import javax.ws.rs.container.ContainerResponseFilter;\r
28 import org.onap.dmaap.dbcapi.logging.BaseLoggingClass;\r
29 \r
30 public class RequestTimeLogFilter extends BaseLoggingClass implements ContainerRequestFilter, ContainerResponseFilter {\r
31 \r
32     private final EELFLogger log;\r
33     private Clock clock;\r
34 \r
35     public RequestTimeLogFilter() {\r
36         this(auditLogger, Clock.systemDefaultZone());\r
37     }\r
38 \r
39     RequestTimeLogFilter(EELFLogger logger, Clock clock) {\r
40         this.log = logger;\r
41         this.clock = clock;\r
42     }\r
43 \r
44     @Override\r
45     public void filter(ContainerRequestContext requestContext) {\r
46         requestContext.setProperty("start", clock.millis());\r
47     }\r
48 \r
49     @Override\r
50     public void filter(ContainerRequestContext requestContext, ContainerResponseContext containerResponseContext) {\r
51         long startTime = (long) requestContext.getProperty("start");\r
52         long elapsedTime = clock.millis() - startTime;\r
53         log.info("Request took {} ms", elapsedTime);\r
54     }\r
55 }\r