Add null
rule check in rules
array of RuleBasedIpFilter (#10527)
Motivation: We can filter out `null` rules while initializing the instance of `RuleBasedIpFilter` so we don't have to keep checking for `null` rules while iterating through `rules` array in `for loop` which is just a waste of CPU cycles. Modification: Added `null` rule check inside the constructor. Result: No more wasting CPU cycles on check the `null` rule each time in `for loop` and makes the overall operation more faster.
This commit is contained in:
parent
1ca7d5db81
commit
e051b5f338
@ -22,36 +22,71 @@ import io.netty.util.internal.ObjectUtil;
|
||||
|
||||
import java.net.InetSocketAddress;
|
||||
import java.net.SocketAddress;
|
||||
import java.util.ArrayList;
|
||||
import java.util.List;
|
||||
|
||||
/**
|
||||
* <p>
|
||||
* This class allows one to filter new {@link Channel}s based on the
|
||||
* {@link IpFilterRule}s passed to its constructor. If no rules are provided, all connections
|
||||
* will be accepted.
|
||||
* </p>
|
||||
*
|
||||
* <p>
|
||||
* If you would like to explicitly take action on rejected {@link Channel}s, you should override
|
||||
* {@link AbstractRemoteAddressFilter#channelRejected(ChannelHandlerContext, SocketAddress)}.
|
||||
* </p>
|
||||
*
|
||||
* <p> Consider using {@link IpSubnetFilter} for better performance while not as
|
||||
* general purpose as this filter. </p>
|
||||
*/
|
||||
@Sharable
|
||||
public class RuleBasedIpFilter extends AbstractRemoteAddressFilter<InetSocketAddress> {
|
||||
|
||||
private final IpFilterRule[] rules;
|
||||
private final boolean acceptIfNotFound;
|
||||
private final List<IpFilterRule> rules;
|
||||
|
||||
/**
|
||||
* <p> Create new Instance of {@link RuleBasedIpFilter} and filter incoming connections
|
||||
* based on their IP address and {@code rules} applied. </p>
|
||||
*
|
||||
* <p> {@code acceptIfNotFound} is set to {@code true}. </p>
|
||||
*
|
||||
* @param rules An array of {@link IpFilterRule} containing all rules.
|
||||
*/
|
||||
public RuleBasedIpFilter(IpFilterRule... rules) {
|
||||
this.rules = ObjectUtil.checkNotNull(rules, "rules");
|
||||
this(true, rules);
|
||||
}
|
||||
|
||||
/**
|
||||
* Create new Instance of {@link RuleBasedIpFilter} and filter incoming connections
|
||||
* based on their IP address and {@code rules} applied.
|
||||
*
|
||||
* @param acceptIfNotFound If {@code true} then accept connection from IP Address if it
|
||||
* doesn't match any rule.
|
||||
* @param rules An array of {@link IpFilterRule} containing all rules.
|
||||
*/
|
||||
public RuleBasedIpFilter(boolean acceptIfNotFound, IpFilterRule... rules) {
|
||||
ObjectUtil.checkNotNull(rules, "rules");
|
||||
|
||||
this.acceptIfNotFound = acceptIfNotFound;
|
||||
this.rules = new ArrayList<IpFilterRule>(rules.length);
|
||||
|
||||
for (IpFilterRule rule : rules) {
|
||||
if (rule != null) {
|
||||
this.rules.add(rule);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
protected boolean accept(ChannelHandlerContext ctx, InetSocketAddress remoteAddress) throws Exception {
|
||||
for (IpFilterRule rule : rules) {
|
||||
if (rule == null) {
|
||||
break;
|
||||
}
|
||||
|
||||
if (rule.matches(remoteAddress)) {
|
||||
return rule.ruleType() == IpFilterRuleType.ACCEPT;
|
||||
}
|
||||
}
|
||||
|
||||
return true;
|
||||
return acceptIfNotFound;
|
||||
}
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user