[ https://issues.apache.org/jira/browse/JSPWIKI-1183?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel ]
Ulf Dittmer updated JSPWIKI-1183: --------------------------------- Description: The IfPlugin.checkIP method has a comment "TODO: Add subnetwork matching, e.g. 10.0.0.0/8". This is a patch to address this. Sorry that this does not come as a PR, but the changes are limited in scope. Additions to pom.xml {{{}<ipaddress.version>5.4.0</ipaddress.version>{}}}{{{}<dependency>{}}} {{<groupId>com.github.seancfoley</groupId>}} {{<artifactId>ipaddress</artifactId>}} {{<version>${ipaddress.version}</version>}} {{</dependency>}} {{Additions to jspwiki-util/pom.xml}} {{<dependency>}} {{<groupId>com.github.seancfoley</groupId>}} {{<artifactId>ipaddress</artifactId>}} {{</dependency>}} Changes in jspwiki-util/src/main/java/org/apache/wiki/util/HttpUtil.java This method now checks whether the IP contains a comma, which can happen if the request goes through more than one proxy. That's not directly related to this patch, but useful nonetheless. {{ /**}} {{ * returns the remote address by looking into \{@code x-forwarded-for} header or, if unavailable,}} {{ * into \{@link HttpServletRequest#getRemoteAddr()}.}} {{ *}} {{ * @param req http request}} {{ * @return remote address associated to the request.}} {{ */}} {{ public static String getRemoteAddress( final HttpServletRequest req ) {}} {{ String realIP = StringUtils.isNotEmpty ( req.getHeader( "X-Forwarded-For" ) ) ? req.getHeader( "X-Forwarded-For" ) :}} {{ req.getRemoteAddr();}} {{ // can be a comma-separated list of IPs}} {{ if (realIP.contains(","))}} {{ realIP = realIP.substring(realIP.indexOf(","));}}{{ return realIP;}} {{ }}} This method is new {{ /**}} {{ * Returns whether or not the IP address of the request equals a given IP, or is in a given IP range}} {{ *}} {{ * @param req http request}} {{ * @param ipOrRange IP address or IP range to test against}} {{ * @return }} {{ */}} {{ public static boolean ipIsInRange ( final HttpServletRequest req, final String ipOrRange ) {}} {{ String requestIP = getRemoteAddress(req);}} {{ if (ipOrRange.contains("/")) {}} {{ IPAddressString testRange = new IPAddressString(ipOrRange);}} {{ return testRange.contains(new IPAddressString(requestIP));}} {{ } else {}} {{ return requestIP.equals(ipOrRange);}} {{ }}} {{ }}} Changes in jspwiki-main/src/main/java/org/apache/wiki/plugin/IfPlugin.java {{Instead of}} {{include |= ipaddrToCheck.equals( HttpUtil.getRemoteAddress( context.getHttpRequest() ) ) ^ invert;}} now it should read {{include |= HttpUtil.ipIsInRange( context.getHttpRequest(), ipaddrToCheck ) ^ invert;}} That's all. Now the IfPlugin accepts something like {{{}[{If ip='192.168.0.0/16|10.0.0.0/8|127.0.0.1'{}}}{{{}Secret stuff for localhost and local networks}]{}}} was: The IfPlugin.checkIP method has a comment "TODO: Add subnetwork matching, e.g. 10.0.0.0/8". This is a patch to address this. Sorry that this does not come as a PR, but the changes are limited in scope. Additions to pom.xml {{ <ipaddress.version>5.4.0</ipaddress.version> <dependency> <groupId>com.github.seancfoley</groupId> <artifactId>ipaddress</artifactId> <version>${ipaddress.version}</version> </dependency> }} Additions to jspwiki-util/pom.xml {{ <dependency> <groupId>com.github.seancfoley</groupId> <artifactId>ipaddress</artifactId> </dependency>}} Changes in jspwiki-util/src/main/java/org/apache/wiki/util/HttpUtil.java This method now checks whether the IP contains a comma, which can happen if the request goes through more than one proxy. That's not directly related to this patch, but useful nonetheless. {{ /** * returns the remote address by looking into {@code x-forwarded-for} header or, if unavailable, * into {@link HttpServletRequest#getRemoteAddr()}. * * @param req http request * @return remote address associated to the request. */ public static String getRemoteAddress( final HttpServletRequest req ) { String realIP = StringUtils.isNotEmpty ( req.getHeader( "X-Forwarded-For" ) ) ? req.getHeader( "X-Forwarded-For" ) : req.getRemoteAddr(); // can be a comma-separated list of IPs if (realIP.contains(",")) realIP = realIP.substring(realIP.indexOf(",")); return realIP; }}} This method is new {{ /** * Returns whether or not the IP address of the request equals a given IP, or is in a given IP range * * @param req http request * @param ipOrRange IP address or IP range to test against * @return */ public static boolean ipIsInRange ( final HttpServletRequest req, final String ipOrRange ) { String requestIP = getRemoteAddress(req); if (ipOrRange.contains("/")) { IPAddressString testRange = new IPAddressString(ipOrRange); return testRange.contains(new IPAddressString(requestIP)); } else { return requestIP.equals(ipOrRange); } } }} Changes in jspwiki-main/src/main/java/org/apache/wiki/plugin/IfPlugin.java Instead of {{ include |= ipaddrToCheck.equals( HttpUtil.getRemoteAddress( context.getHttpRequest() ) ) ^ invert;}} now it should read {{ include |= HttpUtil.ipIsInRange( context.getHttpRequest(), ipaddrToCheck ) ^ invert;}} That's all. Now the IfPlugin accepts something like [{If ip='192.168.0.0/16|10.0.0.0/8|127.0.0.1' Secret stuff for localhost and local networks}] > Support IP ranges in IfPlugin > ----------------------------- > > Key: JSPWIKI-1183 > URL: https://issues.apache.org/jira/browse/JSPWIKI-1183 > Project: JSPWiki > Issue Type: Improvement > Components: Plugins > Affects Versions: 2.12.1 > Reporter: Ulf Dittmer > Priority: Minor > > The IfPlugin.checkIP method has a comment "TODO: Add subnetwork matching, > e.g. 10.0.0.0/8". This is a patch to address this. Sorry that this does not > come as a PR, but the changes are limited in scope. > Additions to pom.xml > {{{}<ipaddress.version>5.4.0</ipaddress.version>{}}}{{{}<dependency>{}}} > {{<groupId>com.github.seancfoley</groupId>}} > {{<artifactId>ipaddress</artifactId>}} > {{<version>${ipaddress.version}</version>}} > {{</dependency>}} > {{Additions to jspwiki-util/pom.xml}} > {{<dependency>}} > {{<groupId>com.github.seancfoley</groupId>}} > {{<artifactId>ipaddress</artifactId>}} > {{</dependency>}} > Changes in jspwiki-util/src/main/java/org/apache/wiki/util/HttpUtil.java > This method now checks whether the IP contains a comma, which can happen if > the request goes through more than one proxy. That's not directly related to > this patch, but useful nonetheless. > {{ /**}} > {{ * returns the remote address by looking into \{@code x-forwarded-for} > header or, if unavailable,}} > {{ * into \{@link HttpServletRequest#getRemoteAddr()}.}} > {{ *}} > {{ * @param req http request}} > {{ * @return remote address associated to the request.}} > {{ */}} > {{ public static String getRemoteAddress( final HttpServletRequest req ) > {}} > {{ String realIP = StringUtils.isNotEmpty ( req.getHeader( > "X-Forwarded-For" ) ) ? req.getHeader( "X-Forwarded-For" ) :}} > {{ > req.getRemoteAddr();}} > {{ // can be a comma-separated list of IPs}} > {{ if (realIP.contains(","))}} > {{ realIP = realIP.substring(realIP.indexOf(","));}}{{ > return realIP;}} > {{ }}} > > This method is new > {{ /**}} > {{ * Returns whether or not the IP address of the request equals a given > IP, or is in a given IP range}} > {{ *}} > {{ * @param req http request}} > {{ * @param ipOrRange IP address or IP range to test against}} > {{ * @return }} > {{ */}} > {{ public static boolean ipIsInRange ( final HttpServletRequest req, final > String ipOrRange ) {}} > {{ String requestIP = getRemoteAddress(req);}} > {{ if (ipOrRange.contains("/")) {}} > {{ IPAddressString testRange = new IPAddressString(ipOrRange);}} > {{ return testRange.contains(new IPAddressString(requestIP));}} > {{ } else {}} > {{ return requestIP.equals(ipOrRange);}} > {{ }}} > {{ }}} > > Changes in jspwiki-main/src/main/java/org/apache/wiki/plugin/IfPlugin.java > {{Instead of}} > {{include |= ipaddrToCheck.equals( HttpUtil.getRemoteAddress( > context.getHttpRequest() ) ) ^ invert;}} > now it should read > {{include |= HttpUtil.ipIsInRange( context.getHttpRequest(), ipaddrToCheck ) > ^ invert;}} > That's all. Now the IfPlugin accepts something like > {{{}[{If ip='192.168.0.0/16|10.0.0.0/8|127.0.0.1'{}}}{{{}Secret stuff for > localhost and local networks}]{}}} -- This message was sent by Atlassian Jira (v8.20.10#820010)