1 /*
2  * JasperReports - Free Java Reporting Library.
3  * Copyright (C) 2001 - 2019 TIBCO Software Inc. All rights reserved.
4  * http://www.jaspersoft.com
5  *
6  * Unless you have purchased a commercial license agreement from Jaspersoft,
7  * the following license terms apply:
8  *
9  * This program is part of JasperReports.
10  *
11  * JasperReports is free software: you can redistribute it and/or modify
12  * it under the terms of the GNU Lesser General Public License as published by
13  * the Free Software Foundation, either version 3 of the License, or
14  * (at your option) any later version.
15  *
16  * JasperReports is distributed in the hope that it will be useful,
17  * but WITHOUT ANY WARRANTY; without even the implied warranty of
18  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
19  * GNU Lesser General Public License for more details.
20  *
21  * You should have received a copy of the GNU Lesser General Public License
22  * along with JasperReports. If not, see <http://www.gnu.org/licenses/>.
23  */

24 package net.sf.jasperreports.types.date;
25
26 import net.sf.jasperreports.engine.JRRuntimeException;
27 import net.sf.jasperreports.engine.query.ClauseFunctionParameterHandler;
28 import net.sf.jasperreports.engine.query.JRJdbcQueryExecuter;
29 import net.sf.jasperreports.engine.query.JRQueryClauseContext;
30 import net.sf.jasperreports.engine.query.SQLLessOrGreaterBaseClause;
31
32
33 /**
34  * @author Lucian Chirita (lucianc@users.sourceforge.net)
35  */

36 public class DateRangeSQLLessOrGreaterClause extends SQLLessOrGreaterBaseClause
37 {
38     public static final String EXCEPTION_MESSAGE_KEY_UNEXPECTED_PARAMETER_TYPE = "date.range.unexpected.parameter.type";
39     public static final String EXCEPTION_MESSAGE_KEY_UNKNOWN_CLAUSE_ID = "date.range.unknown.clause.id";
40
41     protected static final DateRangeSQLLessOrGreaterClause singleton = new DateRangeSQLLessOrGreaterClause();
42     
43     /**
44      * Returns the singleton function instance.
45      * 
46      * @return the singleton function instance
47      */

48     public static DateRangeSQLLessOrGreaterClause instance()
49     {
50         return singleton;
51     }
52
53     @Override
54     protected ClauseFunctionParameterHandler createParameterHandler(JRQueryClauseContext queryContext, 
55             String clauseId, String parameterName)
56     {
57         Object paramValue = queryContext.getValueParameter(parameterName).getValue();
58         if (paramValue != null && !(paramValue instanceof DateRange))
59         {
60             throw 
61                 new JRRuntimeException(
62                     EXCEPTION_MESSAGE_KEY_UNEXPECTED_PARAMETER_TYPE,
63                     new Object[]{parameterName, clauseId});
64         }
65         
66         boolean useRangeStart;
67         if (JRJdbcQueryExecuter.CLAUSE_ID_LESS.equals(clauseId) 
68                 || JRJdbcQueryExecuter.CLAUSE_ID_GREATER_OR_EQUAL.equals(clauseId))
69         {
70             useRangeStart = true;
71         }
72         else if (JRJdbcQueryExecuter.CLAUSE_ID_GREATER.equals(clauseId) 
73                 || JRJdbcQueryExecuter.CLAUSE_ID_LESS_OR_EQUAL.equals(clauseId))
74         {
75             useRangeStart = false;
76         }
77         else
78         {
79             throw 
80                 new JRRuntimeException(
81                     EXCEPTION_MESSAGE_KEY_UNKNOWN_CLAUSE_ID,
82                     new Object[]{clauseId});
83         }
84         
85         return new DateRangeParameterHandler(queryContext, parameterName, 
86                 (DateRange) paramValue, useRangeStart);
87     }
88 }
89