LikeExpressionImpl.java

  1. /*
  2.  * GovWay - A customizable API Gateway
  3.  * https://govway.org
  4.  *
  5.  * Copyright (c) 2005-2025 Link.it srl (https://link.it).
  6.  *
  7.  * This program is free software: you can redistribute it and/or modify
  8.  * it under the terms of the GNU General Public License version 3, as published by
  9.  * the Free Software Foundation.
  10.  *
  11.  * This program is distributed in the hope that it will be useful,
  12.  * but WITHOUT ANY WARRANTY; without even the implied warranty of
  13.  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
  14.  * GNU General Public License for more details.
  15.  *
  16.  * You should have received a copy of the GNU General Public License
  17.  * along with this program.  If not, see <http://www.gnu.org/licenses/>.
  18.  *
  19.  */
  20. package org.openspcoop2.generic_project.expression.impl;

  21. import org.openspcoop2.generic_project.beans.ComplexField;
  22. import org.openspcoop2.generic_project.beans.IField;
  23. import org.openspcoop2.generic_project.expression.LikeMode;
  24. import org.openspcoop2.generic_project.expression.impl.formatter.IObjectFormatter;
  25. import org.openspcoop2.utils.LoggerWrapperFactory;
  26. import org.openspcoop2.utils.TipiDatabase;
  27. import org.openspcoop2.utils.sql.EscapeSQLPattern;
  28. import org.openspcoop2.utils.sql.ISQLQueryObject;
  29. import org.openspcoop2.utils.sql.SQLObjectFactory;

  30. /**
  31.  * LikeExpressionImpl
  32.  *
  33.  * @author Poli Andrea (apoli@link.it)
  34.  * @author $Author$
  35.  * @version $Rev$, $Date$
  36.  */
  37. public class LikeExpressionImpl extends AbstractCommonFieldValueBaseExpressionImpl {

  38.     private LikeMode mode;
  39.     private boolean caseInsensitive;
  40.    
  41.     public LikeExpressionImpl(IObjectFormatter objectFormatter,IField field,String value,LikeMode mode,boolean caseInsensitive){
  42.         super(objectFormatter, field, value);
  43.         this.mode = mode;
  44.         this.caseInsensitive = caseInsensitive;
  45.     }
  46.    
  47.     public LikeMode getMode() {
  48.         return this.mode;
  49.     }

  50.     public void setMode(LikeMode mode) {
  51.         this.mode = mode;
  52.     }

  53.     public boolean isCaseInsensitive() {
  54.         return this.caseInsensitive;
  55.     }

  56.     public void setCaseInsensitive(boolean caseInsensitive) {
  57.         this.caseInsensitive = caseInsensitive;
  58.     }

  59.     @Override
  60.     public String toString(){
  61.         StringBuilder bf = new StringBuilder();
  62.         if(isNot()){
  63.             bf.append("( NOT ");
  64.         }
  65.         bf.append("( ");
  66.         if(this.caseInsensitive){
  67.             bf.append("lower(");
  68.         }
  69.         if(this.field instanceof ComplexField){
  70.             ComplexField cf = (ComplexField) this.field;
  71.             if(cf.getFather()!=null){
  72.                 bf.append(cf.getFather().getFieldName());
  73.             }else{
  74.                 bf.append(this.field.getClassName());
  75.             }
  76.         }else{
  77.             bf.append(this.field.getClassName());
  78.         }
  79.         bf.append(".");
  80.         bf.append(this.field.getFieldName());
  81.         if(this.caseInsensitive){
  82.             bf.append(")");
  83.         }
  84.         bf.append(" like '");
  85.        
  86.         String likeValue = this.value;
  87.        
  88.         // escape
  89.         String escapeClausole = "";
  90.         try{
  91.             ISQLQueryObject sqlQueryObjectForEscape = SQLObjectFactory.createSQLQueryObject(TipiDatabase.POSTGRESQL); // lo uso come default per produrre la stringa
  92.             EscapeSQLPattern escapePattern = sqlQueryObjectForEscape.escapePatternValue(likeValue);
  93.             if(escapePattern.isUseEscapeClausole()){
  94.                 escapeClausole = " ESCAPE '"+escapePattern.getEscapeClausole()+"'";
  95.             }
  96.             likeValue = escapePattern.getEscapeValue();
  97.         }catch(Exception e){
  98.             LoggerWrapperFactory.getLogger(LikeExpressionImpl.class).error(e.getMessage(),e);
  99.         }
  100.        
  101.         String likeParam = getLikeParam(likeValue);
  102.         bf.append(likeParam);
  103.         bf.append("'");
  104.         bf.append(escapeClausole);
  105.         bf.append(" )");
  106.         if(isNot()){
  107.             bf.append(" )");
  108.         }
  109.         return bf.toString();
  110.     }
  111.    
  112.     private String getLikeParam(String likeValue) {
  113.         String likeParam = null;
  114.         switch (this.mode) {
  115.         case EXACT:
  116.             if(this.caseInsensitive){
  117.                 likeParam = likeValue.toLowerCase();
  118.             }else{
  119.                 likeParam = likeValue;
  120.             }
  121.             break;
  122.         case ANYWHERE:
  123.             if(this.caseInsensitive){
  124.                 likeParam = "%"+likeValue.toLowerCase()+"%";
  125.             }else{
  126.                 likeParam = "%"+likeValue+"%";
  127.             }
  128.             break;
  129.         case END:
  130.             if(this.caseInsensitive){
  131.                 likeParam = "%"+likeValue.toLowerCase();
  132.             }else{
  133.                 likeParam = "%"+likeValue;
  134.             }
  135.             break;
  136.         case START:
  137.             if(this.caseInsensitive){
  138.                 likeParam = likeValue.toLowerCase()+"%";
  139.             }else{
  140.                 likeParam = likeValue+"%";
  141.             }
  142.             break;
  143.         default:
  144.             break;
  145.         }
  146.         return likeParam;
  147.     }

  148.    

  149. }