org.apache.cxf.jaxrs.ext.search.SearchUtils Maven / Gradle / Ivy
/**
* Licensed to the Apache Software Foundation (ASF) under one
* or more contributor license agreements. See the NOTICE file
* distributed with this work for additional information
* regarding copyright ownership. The ASF licenses this file
* to you under the Apache License, Version 2.0 (the
* "License"); you may not use this file except in compliance
* with the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing,
* software distributed under the License is distributed on an
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
* KIND, either express or implied. See the License for the
* specific language governing permissions and limitations
* under the License.
*/
package org.apache.cxf.jaxrs.ext.search;
import java.text.SimpleDateFormat;
import java.util.List;
import java.util.Map;
import org.apache.cxf.jaxrs.ext.search.sql.SQLPrinterVisitor;
public final class SearchUtils {
public static final String DEFAULT_DATE_FORMAT = "yyyy-MM-dd";
public static final String DATE_FORMAT_PROPERTY = "search.date-format";
public static final String TIMEZONE_SUPPORT_PROPERTY = "search.timezone.support";
public static final String LAX_PROPERTY_MATCH = "search.lax.property.match";
public static final String BEAN_PROPERTY_MAP = "search.bean.property.map";
public static final String SEARCH_VISITOR_PROPERTY = "search.visitor";
public static final String DECODE_QUERY_VALUES = "search.decode.values";
private SearchUtils() {
}
public static SimpleDateFormat getDateFormat(Map properties) {
String dfProperty = properties.get(DATE_FORMAT_PROPERTY);
return new SimpleDateFormat(dfProperty == null ? DEFAULT_DATE_FORMAT : dfProperty);
}
public static boolean isTimeZoneSupported(Map properties, Boolean defaultValue) {
String tzProperty = properties.get(SearchUtils.TIMEZONE_SUPPORT_PROPERTY);
return tzProperty == null ? defaultValue : Boolean.valueOf(tzProperty);
}
public static String toSQL(SearchCondition sc, String table, String... columns) {
SQLPrinterVisitor visitor = new SQLPrinterVisitor(table, columns);
sc.accept(visitor);
return visitor.getQuery();
}
public static String toSqlWildcardString(String value, boolean alwaysWildcard) {
if (value.contains("\\")) {
value = value.replaceAll("\\\\", "\\\\\\\\");
}
if (value.contains("_")) {
value = value.replaceAll("_", "\\\\_");
}
if (value.contains("%")) {
value = value.replaceAll("%", "\\\\%");
}
if (!containsWildcard(value)) {
return alwaysWildcard ? "%" + value + "%" : value;
} else {
value = value.replaceAll("\\*", "%");
}
return value;
}
public static String duplicateSingleQuoteIfNeeded(String value) {
if (value.indexOf('\'') != -1 && value.indexOf("\'\'") == -1) {
value = value.replaceAll("\'", "\'\'");
}
return value;
}
public static boolean containsEscapedChar(String value) {
return containsEscapedPercent(value) || value.contains("\\\\") || value.contains("\\_");
}
public static boolean containsWildcard(String value) {
return value.contains("*");
}
public static boolean containsEscapedPercent(String value) {
return value.contains("\\%");
}
public static void startSqlQuery(StringBuilder sb,
String table,
String tableAlias,
List columns) {
sb.append("SELECT ");
if (columns != null && columns.size() > 0) {
for (int i = 0; i < columns.size(); i++) {
sb.append(columns.get(i));
if (i + 1 < columns.size()) {
sb.append(",");
}
}
} else {
sb.append("*");
}
sb.append(" FROM ").append(table);
if (tableAlias != null) {
sb.append(" " + tableAlias);
}
sb.append(" WHERE ");
}
public static String conditionTypeToSqlOperator(ConditionType ct, String value, String originalValue) {
// TODO : if we have the same column involved, ex a >= 123 and a <=244 then
// we may try to use IN or BETWEEN, depending on the values
final boolean wildcardAvailable = SearchUtils.containsWildcard(originalValue);
String op;
switch (ct) {
case EQUALS:
op = wildcardAvailable ? "LIKE" : "=";
break;
case NOT_EQUALS:
op = wildcardAvailable ? "NOT LIKE" : "<>";
break;
case GREATER_THAN:
op = ">";
break;
case GREATER_OR_EQUALS:
op = ">=";
break;
case LESS_THAN:
op = "<";
break;
case LESS_OR_EQUALS:
op = "<=";
break;
default:
String msg = String.format("Condition type %s is not supported", ct.name());
throw new RuntimeException(msg);
}
return op;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy