Case.java
/*
* GovWay - A customizable API Gateway
* https://govway.org
*
* Copyright (c) 2005-2025 Link.it srl (https://link.it).
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License version 3, as published by
* the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*
*/
package org.openspcoop2.utils.sql;
import java.util.ArrayList;
import java.util.List;
/**
* Case
*
* @author Poli Andrea (apoli@link.it)
* @author $Author$
* @version $Rev$, $Date$
*/
public class Case {
private List<String> condizioni = new ArrayList<>();
private List<String> valori = new ArrayList<>();
private CastColumnType tipoColonna;
private int dimensioneColonna = 255;
private String valoreDefault;
private boolean stringValueType = false;
public Case(CastColumnType type) throws SQLQueryObjectException {
this.stringValueType = false;
this.tipoColonna = type;
if(this.tipoColonna==null) {
throw new SQLQueryObjectException("Tipo Colonna non fornito");
}
}
public Case(CastColumnType type, String valoreDefault) throws SQLQueryObjectException {
this(type, false, valoreDefault);
}
public Case(CastColumnType type, boolean stringValueType, String valoreDefault) throws SQLQueryObjectException{
this.stringValueType = stringValueType;
if(valoreDefault==null) {
throw new SQLQueryObjectException("Valore di default non fornito");
}
this.valoreDefault = valoreDefault;
this.tipoColonna = type;
if(this.tipoColonna==null) {
throw new SQLQueryObjectException("Tipo Colonna non fornito");
}
}
public void addCase(String condizione, String valore) throws SQLQueryObjectException {
this.condizioni.add(condizione);
this.valori.add(valore);
if(condizione==null) {
throw new SQLQueryObjectException("Condizione non fornita");
}
if(valore==null) {
throw new SQLQueryObjectException("Valore non fornito");
}
}
public List<String> getCondizioni() {
return this.condizioni;
}
public List<String> getValori() {
return this.valori;
}
public boolean isStringValueType() {
return this.stringValueType;
}
public void setStringValueType(boolean stringValueType) {
this.stringValueType = stringValueType;
}
public String getValoreDefault() {
return this.valoreDefault;
}
public CastColumnType getTipoColonna() {
return this.tipoColonna;
}
public int getDimensioneColonna() {
return this.dimensioneColonna;
}
public void setDimensioneColonna(int dimensioneColonna) {
this.dimensioneColonna = dimensioneColonna;
}
}