2 * Copyright © 2016-2017 European Support Limited
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
8 * http://www.apache.org/licenses/LICENSE-2.0
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
17 package org.openecomp.sdc.logging.servlet;
19 import org.openecomp.sdc.logging.api.Logger;
20 import org.openecomp.sdc.logging.api.LoggerFactory;
23 import javax.servlet.Filter;
24 import javax.servlet.FilterChain;
25 import javax.servlet.FilterConfig;
26 import javax.servlet.ServletException;
27 import javax.servlet.ServletRequest;
28 import javax.servlet.ServletResponse;
29 import javax.servlet.http.HttpServletRequest;
30 import java.io.IOException;
31 import java.net.InetAddress;
32 import java.net.UnknownHostException;
33 import java.util.UUID;
34 import java.util.concurrent.atomic.AtomicLong;
39 * <p>Pushes information required by EELF onto MDC (Mapped Diagnostic Context).</p>
41 * <p>This is servlet filter that should be configured in <i>web.xml</i> to be used. Example:</p>
46 * <filter-name>LoggingServletFilter</filter-name>
47 * <filter-class>org.openecomp.sdc.logging.servlet.LoggingFilter</filter-class>
50 * <filter-mapping>
51 * <filter-name>LoggingServletFilter</filter-name>
52 * <url-pattern>/*</url-pattern>
53 * </filter-mapping>
60 public class LoggingFilter implements Filter {
62 // should be cashed to avoid low-level call, but with a timeout to account for IP or FQDN changes
63 private static final HostAddressCache HOST_ADDRESS = new HostAddressCache();
64 private static final String UNKNOWN = "UNKNOWN";
66 private static final Logger LOGGER = LoggerFactory.getLogger(LoggingFilter.class);
68 public void destroy() {
71 public void doFilter(ServletRequest request, ServletResponse response,
72 FilterChain chain) throws IOException, ServletException {
78 MDC.put("RequestId", UUID.randomUUID().toString());
79 MDC.put("ServiceInstanceId", "N/A"); // not applicable
80 MDC.put("ServiceName", "ASDC");
81 MDC.put("InstanceUUID", "N/A");
83 // For some reason chooses IPv4 or IPv6 in a random way
84 MDC.put("RemoteHost", request.getRemoteHost());
86 InetAddress host = HOST_ADDRESS.get();
94 ipAddress = host.getHostAddress();
95 hostName = host.getHostName();
98 MDC.put("ServerIPAddress", ipAddress);
99 MDC.put("ServerFQDN", hostName);
101 if(request instanceof HttpServletRequest) {
102 String userName = ((HttpServletRequest) request).getHeader("USER_ID");
103 MDC.put("PartnerName", userName);
105 // TODO: Clarify what these stand for
106 // MDC.put("AlertSeverity", );
107 // MDC.put("Timer", );
109 chain.doFilter(request, response);
116 public void init(FilterConfig config) throws ServletException { }
118 private static class HostAddressCache {
120 private static final long REFRESH_TIME = 1000L;
122 private final AtomicLong lastUpdated = new AtomicLong(0L);
123 private InetAddress hostAddress;
125 public InetAddress get() {
127 long current = System.currentTimeMillis();
128 if (current - lastUpdated.get() > REFRESH_TIME) {
130 synchronized (this) {
133 lastUpdated.set(current); // set now to register the attempt even if failed
134 hostAddress = InetAddress.getLocalHost();
135 } catch (UnknownHostException e) {
136 LOGGER.error("Failed to retrieve local hostname for logging", e);