| 1 |
|
package com.atlassian.core.filters; |
| 2 |
|
|
| 3 |
|
import com.atlassian.core.util.StringUtils; |
| 4 |
|
import com.opensymphony.util.TextUtils; |
| 5 |
|
|
| 6 |
|
import javax.servlet.*; |
| 7 |
|
import javax.servlet.http.HttpServletRequest; |
| 8 |
|
import javax.servlet.http.HttpServletResponse; |
| 9 |
|
import javax.servlet.http.HttpServletResponseWrapper; |
| 10 |
|
import javax.servlet.http.HttpServletRequestWrapper; |
| 11 |
|
import java.io.IOException; |
| 12 |
|
import java.util.Map; |
| 13 |
|
import java.util.HashMap; |
| 14 |
|
import java.util.Iterator; |
| 15 |
|
|
|
|
|
| 0% |
Uncovered Elements: 43 (43) |
Complexity: 20 |
Complexity Density: 0.87 |
|
| 16 |
|
public abstract class AbstractEncodingFilter extends AbstractFilter |
| 17 |
|
{ |
|
|
|
| 0% |
Uncovered Elements: 12 (12) |
Complexity: 3 |
Complexity Density: 0.38 |
|
| 18 |
0
|
public void doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain filterChain) throws IOException, ServletException... |
| 19 |
|
{ |
| 20 |
0
|
servletRequest.setCharacterEncoding(getEncoding()); |
| 21 |
0
|
servletResponse.setContentType(getContentType()); |
| 22 |
|
|
| 23 |
|
|
| 24 |
0
|
if (servletResponse instanceof HttpServletResponse) |
| 25 |
|
{ |
| 26 |
0
|
HttpServletResponse httpServletResponse = (HttpServletResponse) servletResponse; |
| 27 |
0
|
HttpServletRequest req = (HttpServletRequest) servletRequest; |
| 28 |
|
|
| 29 |
0
|
if (isNonCachableUri(req)) |
| 30 |
0
|
setNonCachingHeaders(httpServletResponse); |
| 31 |
|
} |
| 32 |
|
|
| 33 |
0
|
filterChain.doFilter(new WordCurlyQuotesRequestWrapper(servletRequest), |
| 34 |
|
new HttpServletResponseWrapper((HttpServletResponse) servletResponse) |
| 35 |
|
{ |
|
|
|
| 0% |
Uncovered Elements: 9 (9) |
Complexity: 9 |
Complexity Density: 1.8 |
|
| 36 |
0
|
public void setContentType(String s)... |
| 37 |
|
{ |
| 38 |
|
|
| 39 |
0
|
if (s != null && s.length() > "text/html".length() && s.charAt(0) == 't' && s.startsWith("text/html")) |
| 40 |
|
{ |
| 41 |
|
|
| 42 |
|
|
| 43 |
|
|
| 44 |
|
|
| 45 |
|
|
| 46 |
|
|
| 47 |
|
|
| 48 |
|
|
| 49 |
|
|
| 50 |
|
|
| 51 |
|
|
| 52 |
|
} |
| 53 |
|
else |
| 54 |
|
{ |
| 55 |
|
|
| 56 |
|
|
| 57 |
|
|
| 58 |
|
|
| 59 |
|
|
| 60 |
|
|
| 61 |
|
|
| 62 |
0
|
if (s != null && s.trim().length() == "text/html".length() && s.charAt(0) == 't' && s.startsWith("text/html")) |
| 63 |
|
{ |
| 64 |
0
|
String currentCharSet = getResponse().getCharacterEncoding(); |
| 65 |
0
|
s += ";charset=" + currentCharSet; |
| 66 |
|
} |
| 67 |
0
|
super.setContentType(s); |
| 68 |
|
} |
| 69 |
|
} |
| 70 |
|
|
| 71 |
|
|
|
|
|
| 0% |
Uncovered Elements: 4 (4) |
Complexity: 2 |
Complexity Density: 1 |
|
| 72 |
0
|
public void setHeader(String string, String string1)... |
| 73 |
|
{ |
| 74 |
|
|
| 75 |
|
|
| 76 |
|
|
| 77 |
|
|
| 78 |
|
|
| 79 |
0
|
if (!isContentLocationHeader(string)) |
| 80 |
0
|
super.setHeader(string, string1); |
| 81 |
|
} |
| 82 |
|
|
|
|
|
| 0% |
Uncovered Elements: 4 (4) |
Complexity: 2 |
Complexity Density: 1 |
|
| 83 |
0
|
public void addHeader(String string, String string1)... |
| 84 |
|
{ |
| 85 |
|
|
| 86 |
0
|
if (!isContentLocationHeader(string)) |
| 87 |
0
|
super.addHeader(string, string1); |
| 88 |
|
} |
| 89 |
|
|
|
|
|
| 0% |
Uncovered Elements: 1 (1) |
Complexity: 1 |
Complexity Density: 1 |
|
| 90 |
0
|
private boolean isContentLocationHeader(String headerName)... |
| 91 |
|
{ |
| 92 |
0
|
return headerName != null && "content-location".equalsIgnoreCase(headerName); |
| 93 |
|
} |
| 94 |
|
|
| 95 |
|
}); |
| 96 |
|
} |
| 97 |
|
|
|
|
|
| 0% |
Uncovered Elements: 3 (3) |
Complexity: 1 |
Complexity Density: 0.33 |
|
| 98 |
0
|
protected void setNonCachingHeaders(HttpServletResponse httpServletResponse)... |
| 99 |
|
{ |
| 100 |
0
|
httpServletResponse.setHeader("Cache-Control", "no-cache, no-store, must-revalidate"); |
| 101 |
0
|
httpServletResponse.setHeader("Pragma", "no-cache"); |
| 102 |
0
|
httpServletResponse.setDateHeader("Expires", 0); |
| 103 |
|
} |
| 104 |
|
|
|
|
|
| - |
Uncovered Elements: 0 (0) |
Complexity: 1 |
Complexity Density: - |
|
| 105 |
0
|
public void init(FilterConfig filterConfig)... |
| 106 |
|
{ |
| 107 |
|
} |
| 108 |
|
|
| 109 |
|
|
|
|
|
| 0% |
Uncovered Elements: 2 (2) |
Complexity: 1 |
Complexity Density: 0.5 |
|
| 110 |
0
|
protected boolean isNonCachableUri(HttpServletRequest req)... |
| 111 |
|
{ |
| 112 |
0
|
String uri = TextUtils.noNull(req.getRequestURI()); |
| 113 |
0
|
return uri.indexOf(".jsp") > 0 || uri.indexOf(".jspa") > 0; |
| 114 |
|
} |
| 115 |
|
|
| 116 |
|
protected abstract String getEncoding(); |
| 117 |
|
|
| 118 |
|
protected abstract String getContentType(); |
| 119 |
|
|
|
|
|
| 0% |
Uncovered Elements: 36 (36) |
Complexity: 10 |
Complexity Density: 0.48 |
|
| 120 |
|
private class WordCurlyQuotesRequestWrapper extends HttpServletRequestWrapper |
| 121 |
|
{ |
| 122 |
|
private Map parameterValueCache = new HashMap(); |
| 123 |
|
private Map parameterMap = null; |
| 124 |
|
|
|
|
|
| 0% |
Uncovered Elements: 1 (1) |
Complexity: 1 |
Complexity Density: 1 |
|
| 125 |
0
|
public WordCurlyQuotesRequestWrapper(ServletRequest servletRequest)... |
| 126 |
|
{ |
| 127 |
0
|
super((HttpServletRequest) servletRequest); |
| 128 |
|
} |
| 129 |
|
|
|
|
|
| 0% |
Uncovered Elements: 1 (1) |
Complexity: 1 |
Complexity Density: 1 |
|
| 130 |
0
|
public String getParameter(String string)... |
| 131 |
|
{ |
| 132 |
0
|
return escapeString(super.getParameter(string)); |
| 133 |
|
} |
| 134 |
|
|
|
|
|
| 0% |
Uncovered Elements: 1 (1) |
Complexity: 1 |
Complexity Density: 1 |
|
| 135 |
0
|
protected String escapeString(String string)... |
| 136 |
|
{ |
| 137 |
0
|
return StringUtils.escapeCP1252(string, getEncoding()); |
| 138 |
|
} |
| 139 |
|
|
| 140 |
|
|
|
|
|
| 0% |
Uncovered Elements: 11 (11) |
Complexity: 3 |
Complexity Density: 0.43 |
|
| 141 |
0
|
public Map getParameterMap()... |
| 142 |
|
{ |
| 143 |
0
|
if (parameterMap == null) |
| 144 |
|
{ |
| 145 |
0
|
parameterMap = new HashMap(); |
| 146 |
0
|
Map originalMap = super.getParameterMap(); |
| 147 |
0
|
for (Iterator i = originalMap.keySet().iterator(); i.hasNext();) |
| 148 |
|
{ |
| 149 |
0
|
String key = (String) i.next(); |
| 150 |
0
|
parameterMap.put(key, getParameterValues(key)); |
| 151 |
|
} |
| 152 |
|
} |
| 153 |
0
|
return parameterMap; |
| 154 |
|
} |
| 155 |
|
|
| 156 |
|
|
|
|
|
| 0% |
Uncovered Elements: 17 (17) |
Complexity: 4 |
Complexity Density: 0.36 |
|
| 157 |
0
|
public String[] getParameterValues(String string)... |
| 158 |
|
{ |
| 159 |
0
|
String[] returnValue = (String[]) parameterValueCache.get(string); |
| 160 |
|
|
| 161 |
|
|
| 162 |
0
|
if (returnValue == null) |
| 163 |
|
{ |
| 164 |
0
|
String[] parameterValues = super.getParameterValues(string); |
| 165 |
|
|
| 166 |
|
|
| 167 |
0
|
if (parameterValues == null) |
| 168 |
0
|
return null; |
| 169 |
|
|
| 170 |
0
|
for (int i = 0; i < parameterValues.length; i++) |
| 171 |
|
{ |
| 172 |
0
|
String parameterValue = escapeString(parameterValues[i]); |
| 173 |
0
|
parameterValues[i] = parameterValue; |
| 174 |
|
} |
| 175 |
|
|
| 176 |
0
|
parameterValueCache.put(string, parameterValues); |
| 177 |
0
|
returnValue = parameterValues; |
| 178 |
|
|
| 179 |
|
} |
| 180 |
0
|
return returnValue; |
| 181 |
|
} |
| 182 |
|
} |
| 183 |
|
} |