1 package org.onap.vid.controller.filter;
4 import com.google.common.collect.ImmutableList;
5 import org.apache.commons.lang3.StringUtils;
6 import org.openecomp.portalsdk.core.logging.logic.EELFLoggerDelegate;
7 import org.springframework.web.filter.GenericFilterBean;
9 import javax.servlet.FilterChain;
10 import javax.servlet.ServletException;
11 import javax.servlet.ServletRequest;
12 import javax.servlet.ServletResponse;
13 import javax.servlet.annotation.WebFilter;
14 import javax.servlet.http.HttpServletRequest;
15 import javax.servlet.http.HttpServletRequestWrapper;
16 import javax.servlet.http.HttpServletResponse;
17 import java.io.IOException;
18 import java.util.Collections;
19 import java.util.Enumeration;
20 import java.util.UUID;
22 import static org.openecomp.portalsdk.core.util.SystemProperties.ECOMP_REQUEST_ID;
24 @WebFilter(urlPatterns = "/*")
25 public class PromiseEcompRequestIdFilter extends GenericFilterBean {
27 private final static EELFLoggerDelegate LOGGER = EELFLoggerDelegate.getLogger(PromiseEcompRequestIdFilter.class);
28 private final static String REQUEST_ID_RESPONSE_HEADER = ECOMP_REQUEST_ID + "-echo";
32 public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain)
33 throws IOException, ServletException {
35 if (request instanceof HttpServletRequest) {
36 request = wrapIfNeeded(request);
38 if (response instanceof HttpServletResponse) {
39 final String actualRequestId = ((HttpServletRequest) request).getHeader(ECOMP_REQUEST_ID);
40 ((HttpServletResponse) response).addHeader(REQUEST_ID_RESPONSE_HEADER, actualRequestId);
44 chain.doFilter(request, response);
47 public static ServletRequest wrapIfNeeded(ServletRequest request) {
48 final HttpServletRequest httpRequest = (HttpServletRequest) request;
49 final String originalRequestId = httpRequest.getHeader(ECOMP_REQUEST_ID);
51 if (StringUtils.isEmpty(originalRequestId)) {
52 request = new PromiseEcompRequestIdRequestWrapper(httpRequest);
58 private static class PromiseEcompRequestIdRequestWrapper extends HttpServletRequestWrapper {
60 private final UUID requestId;
62 PromiseEcompRequestIdRequestWrapper(HttpServletRequest request) {
64 requestId = UUID.randomUUID();
68 public String getHeader(String name) {
69 return isRequestIdHeaderName(name) ?
70 requestId.toString() : super.getHeader(name);
74 public Enumeration<String> getHeaders(String name) {
75 if (isRequestIdHeaderName(name)) {
76 return Collections.enumeration(Collections.singleton(requestId.toString()));
78 return super.getHeaders(name);
83 public Enumeration<String> getHeaderNames() {
84 return Collections.enumeration(ImmutableList.<String>builder()
85 .add(ECOMP_REQUEST_ID)
86 .addAll(Collections.list(super.getHeaderNames()))
90 private boolean isRequestIdHeaderName(String name) {
91 return ECOMP_REQUEST_ID.equalsIgnoreCase(name);