DayFormatExpressionSQL.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.sql;

  21. import java.util.List;
  22. import java.util.Map;

  23. import org.openspcoop2.generic_project.beans.IField;
  24. import org.openspcoop2.generic_project.exception.ExpressionException;
  25. import org.openspcoop2.generic_project.expression.impl.DayFormatExpressionImpl;
  26. import org.openspcoop2.generic_project.expression.impl.formatter.IObjectFormatter;
  27. import org.openspcoop2.utils.TipiDatabase;
  28. import org.openspcoop2.utils.sql.DayFormatEnum;
  29. import org.openspcoop2.utils.sql.ISQLQueryObject;
  30. import org.openspcoop2.utils.sql.SQLObjectFactory;
  31. import org.openspcoop2.utils.sql.SQLQueryObjectCore;

  32. /**
  33.  * LikeExpressionSQL
  34.  *
  35.  * @author Poli Andrea (apoli@link.it)
  36.  * @author $Author$
  37.  * @version $Rev$, $Date$
  38.  */
  39. public class DayFormatExpressionSQL extends DayFormatExpressionImpl implements ISQLExpression {

  40.     private ISQLFieldConverter sqlFieldConverter;
  41.    
  42.     public DayFormatExpressionSQL(ISQLFieldConverter sqlFieldConverter,IObjectFormatter objectFormatter, IField field,
  43.             String value, DayFormatEnum dayFormatEnum) {
  44.         super(objectFormatter, field, value, dayFormatEnum);
  45.         this.sqlFieldConverter = sqlFieldConverter;
  46.     }

  47.     private SQLQueryObjectCore getSQLQueryObjectCore(ISQLQueryObject sqlQueryObject) throws ExpressionException {
  48.         if(sqlQueryObject==null) {
  49.             try {
  50.                 // uso uno di default
  51.                 if(this.sqlFieldConverter!=null && this.sqlFieldConverter.getDatabaseType()!=null) {
  52.                     sqlQueryObject = SQLObjectFactory.createSQLQueryObject(this.sqlFieldConverter.getDatabaseType());
  53.                 }
  54.                 else {
  55.                     sqlQueryObject = SQLObjectFactory.createSQLQueryObject(TipiDatabase.POSTGRESQL); // uso come default
  56.                 }
  57.             }catch(Exception e) {
  58.                 throw new ExpressionException(e.getMessage(),e);
  59.             }
  60.         }
  61.         return (SQLQueryObjectCore) sqlQueryObject;
  62.     }
  63.    
  64.     private String toSqlEngine(SQLMode mode,ISQLQueryObject sqlQueryObject,List<?> oggettiPreparedStatement,Map<String, ?> oggettiJPA)throws ExpressionException{
  65.        
  66.         if(mode!=null) {
  67.             // nop
  68.         }
  69.         if(oggettiPreparedStatement!=null) {
  70.             // nop
  71.         }
  72.         if(oggettiJPA!=null) {
  73.             // nop
  74.         }
  75.        
  76.         StringBuilder bf = new StringBuilder();
  77.         if(isNot()){
  78.             bf.append("( NOT ");
  79.         }
  80.         bf.append("( ");
  81.        
  82.         SQLQueryObjectCore sqlObjectCore = getSQLQueryObjectCore(sqlQueryObject);
  83.        
  84.         try {
  85.             String prefix = sqlObjectCore.getExtractDayFormatFromTimestampFieldPrefix(this.dayFormatEnum);
  86.             bf.append(prefix);
  87.         }catch(Exception e) {
  88.             throw new ExpressionException(e.getMessage(),e);
  89.         }
  90.        
  91.         if(this.sqlFieldConverter!=null) {
  92.             bf.append(this.sqlFieldConverter.toColumn(this.getField(),true));
  93.         }
  94.         else {
  95.             bf.append(this.getField().getFieldName());
  96.         }

  97.         try {
  98.             String suffix = sqlObjectCore.getExtractDayFormatFromTimestampFieldSuffix(this.dayFormatEnum);
  99.             bf.append(" ");
  100.             bf.append(suffix);
  101.         }catch(Exception e) {
  102.             throw new ExpressionException(e.getMessage(),e);
  103.         }
  104.        
  105.         bf.append(" = '");
  106.         String sqlValue = null;
  107.         try{
  108.             sqlValue = super.getObjectFormatter().toString(this.getValue());
  109.         }catch(Exception e){
  110.             return "ERROR: "+e.getMessage();
  111.         }
  112.         bf.append(sqlValue);
  113.         bf.append("'");
  114.        
  115.         bf.append(" )");
  116.         if(isNot()){
  117.             bf.append(" )");
  118.         }
  119.         return bf.toString();
  120.     }
  121.    
  122.     private void toSqlEngine(ISQLQueryObject sqlQueryObject,SQLMode mode,List<Object> oggettiPreparedStatement,Map<String, Object> oggettiJPA)throws ExpressionException{
  123.         try{
  124.             String s = toSqlEngine(mode, sqlQueryObject, oggettiPreparedStatement, oggettiJPA);
  125.             s = s.substring(1,s.length()-2);
  126.             sqlQueryObject.addWhereCondition(s);
  127.         }catch(Exception e){
  128.             throw new ExpressionException(e);
  129.         }
  130.     }
  131.    
  132.     @Override
  133.     public String toSql() throws ExpressionException {
  134.         return toSqlEngine(SQLMode.STANDARD, null, null, null);
  135.     }

  136.     @Override
  137.     public String toSqlPreparedStatement(List<Object> oggetti)
  138.             throws ExpressionException {
  139.         return toSqlEngine(SQLMode.PREPARED_STATEMENT, null, oggetti, null);
  140.     }

  141.     @Override
  142.     public String toSqlJPA(Map<String, Object> oggetti)
  143.             throws ExpressionException {
  144.         return toSqlEngine(SQLMode.JPA, null, null, oggetti);
  145.     }
  146.    
  147.     @Override
  148.     public void toSql(ISQLQueryObject sqlQueryObject) throws ExpressionException {
  149.         toSqlEngine(sqlQueryObject,SQLMode.STANDARD, null, null);
  150.     }

  151.     @Override
  152.     public void toSqlPreparedStatement(ISQLQueryObject sqlQueryObject,List<Object> oggetti)
  153.             throws ExpressionException {
  154.         toSqlEngine(sqlQueryObject,SQLMode.PREPARED_STATEMENT, oggetti, null);
  155.     }

  156.     @Override
  157.     public void toSqlJPA(ISQLQueryObject sqlQueryObject,Map<String, Object> oggetti)
  158.             throws ExpressionException {
  159.         toSqlEngine(sqlQueryObject,SQLMode.JPA, null, oggetti);
  160.     }
  161.    
  162. }