Skip to content

Commit 086b637

Browse files
committed
Adds constant to control proxy member access
1 parent ae56301 commit 086b637

File tree

7 files changed

+70
-1
lines changed

7 files changed

+70
-1
lines changed

Diff for: plugins/spring/src/main/resources/struts-plugin.xml

+1
Original file line numberDiff line numberDiff line change
@@ -34,6 +34,7 @@
3434
<constant name="struts.class.reloading.watchList" value="" />
3535
<constant name="struts.class.reloading.acceptClasses" value="" />
3636
<constant name="struts.class.reloading.reloadConfig" value="false" />
37+
<constant name="xwork.disallowProxyMemberAccess" value="true" />
3738

3839
<package name="spring-default">
3940
<interceptors>

Diff for: xwork-core/src/main/java/com/opensymphony/xwork2/XWorkConstants.java

+1
Original file line numberDiff line numberDiff line change
@@ -28,4 +28,5 @@ public final class XWorkConstants {
2828
public static final String OVERRIDE_EXCLUDED_PATTERNS = "overrideExcludedPatterns";
2929
public static final String OVERRIDE_ACCEPTED_PATTERNS = "overrideAcceptedPatterns";
3030

31+
public static final String XWORK_DISALLOW_PROXY_MEMBER_ACCESS = "xwork.disallowProxyMemberAccess";
3132
}

Diff for: xwork-core/src/main/java/com/opensymphony/xwork2/ognl/OgnlUtil.java

+11
Original file line numberDiff line numberDiff line change
@@ -72,6 +72,7 @@ public class OgnlUtil {
7272

7373
private Container container;
7474
private boolean allowStaticMethodAccess;
75+
private boolean disallowProxyMemberAccess;
7576

7677
@Inject
7778
public void setXWorkConverter(XWorkConverter conv) {
@@ -144,6 +145,15 @@ public void setAllowStaticMethodAccess(String allowStaticMethodAccess) {
144145
this.allowStaticMethodAccess = Boolean.parseBoolean(allowStaticMethodAccess);
145146
}
146147

148+
@Inject(value = XWorkConstants.XWORK_DISALLOW_PROXY_MEMBER_ACCESS, required = false)
149+
public void setDisallowProxyMemberAccess(String disallowProxyMemberAccess) {
150+
this.disallowProxyMemberAccess = Boolean.parseBoolean(disallowProxyMemberAccess);
151+
}
152+
153+
public boolean isDisallowProxyMemberAccess() {
154+
return disallowProxyMemberAccess;
155+
}
156+
147157
/**
148158
* Sets the object's properties using the default type converter, defaulting to not throw
149159
* exceptions for problems setting the properties.
@@ -654,6 +664,7 @@ protected Map createDefaultContext(Object root, ClassResolver classResolver) {
654664
memberAccess.setExcludedClasses(excludedClasses);
655665
memberAccess.setExcludedPackageNamePatterns(excludedPackageNamePatterns);
656666
memberAccess.setExcludedPackageNames(excludedPackageNames);
667+
memberAccess.setDisallowProxyMemberAccess(disallowProxyMemberAccess);
657668

658669
return Ognl.createDefaultContext(root, resolver, defaultConverter, memberAccess);
659670
}

Diff for: xwork-core/src/main/java/com/opensymphony/xwork2/ognl/OgnlValueStack.java

+1
Original file line numberDiff line numberDiff line change
@@ -83,6 +83,7 @@ public void setOgnlUtil(OgnlUtil ognlUtil) {
8383
securityMemberAccess.setExcludedClasses(ognlUtil.getExcludedClasses());
8484
securityMemberAccess.setExcludedPackageNamePatterns(ognlUtil.getExcludedPackageNamePatterns());
8585
securityMemberAccess.setExcludedPackageNames(ognlUtil.getExcludedPackageNames());
86+
securityMemberAccess.setDisallowProxyMemberAccess(ognlUtil.isDisallowProxyMemberAccess());
8687
}
8788

8889
protected void setRoot(XWorkConverter xworkConverter, CompoundRootAccessor accessor, CompoundRoot compoundRoot,

Diff for: xwork-core/src/main/java/com/opensymphony/xwork2/ognl/SecurityMemberAccess.java

+6-1
Original file line numberDiff line numberDiff line change
@@ -42,6 +42,7 @@ public class SecurityMemberAccess extends DefaultMemberAccess {
4242
private Set<Class<?>> excludedClasses = Collections.emptySet();
4343
private Set<Pattern> excludedPackageNamePatterns = Collections.emptySet();
4444
private Set<String> excludedPackageNames = Collections.emptySet();
45+
private boolean disallowProxyMemberAccess;
4546

4647
public SecurityMemberAccess(boolean method) {
4748
super(false);
@@ -94,7 +95,7 @@ public boolean isAccessible(Map context, Object target, Member member, String pr
9495
return false;
9596
}
9697

97-
if (ProxyUtil.isProxyMember(member, target)) {
98+
if (disallowProxyMemberAccess && ProxyUtil.isProxyMember(member, target)) {
9899
LOG.warn("Access to proxy [#0] is blocked!", member);
99100
return false;
100101
}
@@ -222,4 +223,8 @@ public void setExcludedPackageNamePatterns(Set<Pattern> excludedPackageNamePatte
222223
public void setExcludedPackageNames(Set<String> excludedPackageNames) {
223224
this.excludedPackageNames = excludedPackageNames;
224225
}
226+
227+
public void setDisallowProxyMemberAccess(boolean disallowProxyMemberAccess) {
228+
this.disallowProxyMemberAccess = disallowProxyMemberAccess;
229+
}
225230
}
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,49 @@
1+
package com.opensymphony.xwork2.ognl;
2+
3+
import java.lang.reflect.Member;
4+
import java.util.HashMap;
5+
import java.util.Map;
6+
7+
import com.opensymphony.xwork2.ActionProxy;
8+
import com.opensymphony.xwork2.XWorkTestCase;
9+
import com.opensymphony.xwork2.config.providers.XmlConfigurationProvider;
10+
11+
public class SecurityMemberAccessProxyTest extends XWorkTestCase {
12+
private Map<String, Object> context;
13+
14+
@Override
15+
public void setUp() throws Exception {
16+
super.setUp();
17+
18+
context = new HashMap<String, Object>();
19+
// Set up XWork
20+
XmlConfigurationProvider provider = new XmlConfigurationProvider("com/opensymphony/xwork2/spring/actionContext-xwork.xml");
21+
container.inject(provider);
22+
loadConfigurationProviders(provider);
23+
}
24+
25+
public void testProxyAccessIsBlocked() throws Exception {
26+
ActionProxy proxy = actionProxyFactory.createActionProxy(null,
27+
"paramsAwareProxiedAction", null, context);
28+
29+
SecurityMemberAccess sma = new SecurityMemberAccess(false);
30+
sma.setDisallowProxyMemberAccess(true);
31+
32+
Member member = proxy.getAction().getClass().getMethod("isExposeProxy");
33+
34+
boolean accessible = sma.isAccessible(context, proxy.getAction(), member, "");
35+
assertFalse(accessible);
36+
}
37+
38+
public void testProxyAccessIsAccessible() throws Exception {
39+
ActionProxy proxy = actionProxyFactory.createActionProxy(null,
40+
"paramsAwareProxiedAction", null, context);
41+
42+
SecurityMemberAccess sma = new SecurityMemberAccess(false);
43+
44+
Member member = proxy.getAction().getClass().getMethod("isExposeProxy");
45+
46+
boolean accessible = sma.isAccessible(context, proxy.getAction(), member, "");
47+
assertTrue(accessible);
48+
}
49+
}

Diff for: xwork-core/src/test/resources/com/opensymphony/xwork2/spring/actionContext-xwork.xml

+1
Original file line numberDiff line numberDiff line change
@@ -2,6 +2,7 @@
22
<xwork>
33
<bean type="com.opensymphony.xwork2.ObjectFactory" class="com.opensymphony.xwork2.spring.SpringObjectFactory" />
44
<constant name="applicationContextPath" value="com/opensymphony/xwork2/spring/actionContext-spring.xml" />
5+
<constant name="xwork.disallowProxyMemberAccess" value="true" />
56
<package name="default">
67
<result-types>
78
<result-type name="null" class="com.opensymphony.xwork2.mock.MockResult" default="true"/>

0 commit comments

Comments
 (0)