Skip to content
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Original file line number Diff line number Diff line change
Expand Up @@ -71,7 +71,7 @@
import org.opensearch.sql.expression.function.udf.datetime.WeekdayFunction;
import org.opensearch.sql.expression.function.udf.datetime.YearweekFunction;
import org.opensearch.sql.expression.function.udf.ip.CidrMatchFunction;
import org.opensearch.sql.expression.function.udf.ip.IpComparisonOperators;
import org.opensearch.sql.expression.function.udf.ip.CompareIpFunction;
import org.opensearch.sql.expression.function.udf.math.CRC32Function;
import org.opensearch.sql.expression.function.udf.math.ConvFunction;
import org.opensearch.sql.expression.function.udf.math.DivideFunction;
Expand Down Expand Up @@ -105,14 +105,12 @@ public class PPLBuiltinOperators extends ReflectiveSqlOperatorTable {

// IP comparing functions
public static final SqlOperator NOT_EQUALS_IP =
IpComparisonOperators.notEqualsIp().toUDF("NOT_EQUALS_IP");
public static final SqlOperator EQUALS_IP = IpComparisonOperators.equalsIp().toUDF("EQUALS_IP");
public static final SqlOperator GREATER_IP =
IpComparisonOperators.greaterThanIp().toUDF("GREATER_IP");
public static final SqlOperator GTE_IP =
IpComparisonOperators.greaterOrEqualsIp().toUDF("GTE_IP");
public static final SqlOperator LESS_IP = IpComparisonOperators.lessThanIp().toUDF("LESS_IP");
public static final SqlOperator LTE_IP = IpComparisonOperators.lessOrEqualsIp().toUDF("LTE_IP");
CompareIpFunction.notEquals().toUDF("NOT_EQUALS_IP");
public static final SqlOperator EQUALS_IP = CompareIpFunction.equals().toUDF("EQUALS_IP");
public static final SqlOperator GREATER_IP = CompareIpFunction.greater().toUDF("GREATER_IP");
public static final SqlOperator GTE_IP = CompareIpFunction.greaterOrEquals().toUDF("GTE_IP");
public static final SqlOperator LESS_IP = CompareIpFunction.less().toUDF("LESS_IP");
public static final SqlOperator LTE_IP = CompareIpFunction.lessOrEquals().toUDF("LTE_IP");

// Condition function
public static final SqlOperator EARLIEST = new EarliestFunction().toUDF("EARLIEST");
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -35,11 +35,33 @@
* </ul>
*/
public class CompareIpFunction extends ImplementorUDF {
private final IpComparisonOperators.ComparisonOperator operator;

public CompareIpFunction(IpComparisonOperators.ComparisonOperator operator) {
super(new CompareImplementor(operator), NullPolicy.ANY);
this.operator = operator;
private CompareIpFunction(ComparisonType comparisonType) {
super(new CompareImplementor(comparisonType), NullPolicy.ANY);
}

public static CompareIpFunction less() {
return new CompareIpFunction(ComparisonType.LESS);
}

public static CompareIpFunction greater() {
return new CompareIpFunction(ComparisonType.GREATER);
}

public static CompareIpFunction lessOrEquals() {
return new CompareIpFunction(ComparisonType.LESS_OR_EQUAL);
}

public static CompareIpFunction greaterOrEquals() {
return new CompareIpFunction(ComparisonType.GREATER_OR_EQUAL);
}

public static CompareIpFunction equals() {
return new CompareIpFunction(ComparisonType.EQUALS);
}

public static CompareIpFunction notEquals() {
return new CompareIpFunction(ComparisonType.NOT_EQUALS);
}

@Override
Expand All @@ -57,10 +79,10 @@ public UDFOperandMetadata getOperandMetadata() {
}

public static class CompareImplementor implements NotNullImplementor {
private final IpComparisonOperators.ComparisonOperator operator;
private final ComparisonType comparisonType;

public CompareImplementor(IpComparisonOperators.ComparisonOperator operator) {
this.operator = operator;
public CompareImplementor(ComparisonType comparisonType) {
this.comparisonType = comparisonType;
}

@Override
Expand All @@ -71,35 +93,24 @@ public Expression implement(
"compare",
translatedOperands.get(0),
translatedOperands.get(1),
Expressions.constant(operator.name()));
Expressions.constant(comparisonType));
}

public static boolean compare(Object obj1, Object obj2, String opName) {
public static boolean compare(Object obj1, Object obj2, ComparisonType comparisonType) {
try {
IpComparisonOperators.ComparisonOperator op =
IpComparisonOperators.ComparisonOperator.valueOf(opName);
String ip1 = extractIpString(obj1);
String ip2 = extractIpString(obj2);
IPAddress addr1 = IPUtils.toAddress(ip1);
IPAddress addr2 = IPUtils.toAddress(ip2);
int result = IPUtils.compare(addr1, addr2);

switch (op) {
case EQUALS:
return result == 0;
case NOT_EQUALS:
return result != 0;
case LESS:
return result < 0;
case LESS_OR_EQUAL:
return result <= 0;
case GREATER:
return result > 0;
case GREATER_OR_EQUAL:
return result >= 0;
default:
return false;
}
return switch (comparisonType) {
case EQUALS -> result == 0;
case NOT_EQUALS -> result != 0;
case LESS -> result < 0;
case LESS_OR_EQUAL -> result <= 0;
case GREATER -> result > 0;
case GREATER_OR_EQUAL -> result >= 0;
};
} catch (Exception e) {
return false;
}
Expand All @@ -111,4 +122,13 @@ private static String extractIpString(Object obj) {
throw new IllegalArgumentException("Invalid IP type: " + obj);
}
}

public enum ComparisonType {
EQUALS,
NOT_EQUALS,
LESS,
LESS_OR_EQUAL,
GREATER,
GREATER_OR_EQUAL
}
}

This file was deleted.

Loading