ConfigurazioneGeneraleFetch.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.core.controllo_traffico.dao.jdbc.fetch;

  21. import org.openspcoop2.core.controllo_traffico.Cache;
  22. import org.openspcoop2.core.controllo_traffico.ConfigurazioneControlloTraffico;
  23. import org.openspcoop2.core.controllo_traffico.ConfigurazioneGenerale;
  24. import org.openspcoop2.core.controllo_traffico.ConfigurazioneRateLimiting;
  25. import org.openspcoop2.core.controllo_traffico.TempiRispostaErogazione;
  26. import org.openspcoop2.core.controllo_traffico.TempiRispostaFruizione;
  27. import org.openspcoop2.generic_project.beans.IModel;
  28. import org.openspcoop2.generic_project.dao.jdbc.utils.AbstractJDBCFetch;
  29. import org.openspcoop2.generic_project.dao.jdbc.utils.GenericJDBCParameterUtilities;
  30. import org.openspcoop2.generic_project.exception.ServiceException;

  31. import java.sql.ResultSet;
  32. import java.util.Map;

  33. import org.openspcoop2.utils.TipiDatabase;
  34. import org.openspcoop2.utils.jdbc.IKeyGeneratorObject;


  35. /**    
  36.  * ConfigurazioneGeneraleFetch
  37.  *
  38.  * @author Poli Andrea (poli@link.it)
  39.  * @author $Author$
  40.  * @version $Rev$, $Date$
  41.  */
  42. public class ConfigurazioneGeneraleFetch extends AbstractJDBCFetch {

  43.     @Override
  44.     public Object fetch(TipiDatabase tipoDatabase, IModel<?> model , ResultSet rs) throws ServiceException {
  45.        
  46.         try{
  47.             GenericJDBCParameterUtilities jdbcParameterUtilities =  
  48.                     new GenericJDBCParameterUtilities(tipoDatabase);

  49.             if(model.equals(ConfigurazioneGenerale.model())){
  50.                 ConfigurazioneGenerale object = new ConfigurazioneGenerale();
  51.                 object.setControlloTraffico(new ConfigurazioneControlloTraffico());
  52.                 setParameter(object, "setId", Long.class,
  53.                     jdbcParameterUtilities.readParameter(rs, "id", Long.class));
  54.                 setParameter(object.getControlloTraffico(), "setControlloMaxThreadsEnabled", ConfigurazioneGenerale.model().CONTROLLO_TRAFFICO.CONTROLLO_MAX_THREADS_ENABLED.getFieldType(),
  55.                     jdbcParameterUtilities.readParameter(rs, "max_threads_enabled", ConfigurazioneGenerale.model().CONTROLLO_TRAFFICO.CONTROLLO_MAX_THREADS_ENABLED.getFieldType()));
  56.                 setParameter(object.getControlloTraffico(), "setControlloMaxThreadsWarningOnly", ConfigurazioneGenerale.model().CONTROLLO_TRAFFICO.CONTROLLO_MAX_THREADS_WARNING_ONLY.getFieldType(),
  57.                     jdbcParameterUtilities.readParameter(rs, "max_threads_warning_only", ConfigurazioneGenerale.model().CONTROLLO_TRAFFICO.CONTROLLO_MAX_THREADS_WARNING_ONLY.getFieldType()));
  58.                 setParameter(object.getControlloTraffico(), "setControlloMaxThreadsSoglia", ConfigurazioneGenerale.model().CONTROLLO_TRAFFICO.CONTROLLO_MAX_THREADS_SOGLIA.getFieldType(),
  59.                     jdbcParameterUtilities.readParameter(rs, "max_threads", ConfigurazioneGenerale.model().CONTROLLO_TRAFFICO.CONTROLLO_MAX_THREADS_SOGLIA.getFieldType()));
  60.                 setParameter(object.getControlloTraffico(), "setControlloMaxThreadsTipoErrore", ConfigurazioneGenerale.model().CONTROLLO_TRAFFICO.CONTROLLO_MAX_THREADS_TIPO_ERRORE.getFieldType(),
  61.                     jdbcParameterUtilities.readParameter(rs, "max_threads_tipo_errore", ConfigurazioneGenerale.model().CONTROLLO_TRAFFICO.CONTROLLO_MAX_THREADS_TIPO_ERRORE.getFieldType()));
  62.                 setParameter(object.getControlloTraffico(), "setControlloMaxThreadsTipoErroreIncludiDescrizione", ConfigurazioneGenerale.model().CONTROLLO_TRAFFICO.CONTROLLO_MAX_THREADS_TIPO_ERRORE_INCLUDI_DESCRIZIONE.getFieldType(),
  63.                     jdbcParameterUtilities.readParameter(rs, "max_threads_includi_errore", ConfigurazioneGenerale.model().CONTROLLO_TRAFFICO.CONTROLLO_MAX_THREADS_TIPO_ERRORE_INCLUDI_DESCRIZIONE.getFieldType()));
  64.                 setParameter(object.getControlloTraffico(), "setControlloCongestioneEnabled", ConfigurazioneGenerale.model().CONTROLLO_TRAFFICO.CONTROLLO_CONGESTIONE_ENABLED.getFieldType(),
  65.                     jdbcParameterUtilities.readParameter(rs, "cc_enabled", ConfigurazioneGenerale.model().CONTROLLO_TRAFFICO.CONTROLLO_CONGESTIONE_ENABLED.getFieldType()));
  66.                 setParameter(object.getControlloTraffico(), "setControlloCongestioneThreshold", ConfigurazioneGenerale.model().CONTROLLO_TRAFFICO.CONTROLLO_CONGESTIONE_THRESHOLD.getFieldType(),
  67.                     jdbcParameterUtilities.readParameter(rs, "cc_threshold", ConfigurazioneGenerale.model().CONTROLLO_TRAFFICO.CONTROLLO_CONGESTIONE_THRESHOLD.getFieldType()));
  68.                 object.setTempiRispostaFruizione(new TempiRispostaFruizione());
  69.                 setParameter(object.getTempiRispostaFruizione(), "setConnectionTimeout", ConfigurazioneGenerale.model().TEMPI_RISPOSTA_FRUIZIONE.CONNECTION_TIMEOUT.getFieldType(),
  70.                     jdbcParameterUtilities.readParameter(rs, "pd_connection_timeout", ConfigurazioneGenerale.model().TEMPI_RISPOSTA_FRUIZIONE.CONNECTION_TIMEOUT.getFieldType()));
  71.                 setParameter(object.getTempiRispostaFruizione(), "setReadTimeout", ConfigurazioneGenerale.model().TEMPI_RISPOSTA_FRUIZIONE.READ_TIMEOUT.getFieldType(),
  72.                     jdbcParameterUtilities.readParameter(rs, "pd_read_timeout", ConfigurazioneGenerale.model().TEMPI_RISPOSTA_FRUIZIONE.READ_TIMEOUT.getFieldType()));
  73.                 setParameter(object.getTempiRispostaFruizione(), "setTempoMedioRisposta", ConfigurazioneGenerale.model().TEMPI_RISPOSTA_FRUIZIONE.TEMPO_MEDIO_RISPOSTA.getFieldType(),
  74.                     jdbcParameterUtilities.readParameter(rs, "pd_avg_time", ConfigurazioneGenerale.model().TEMPI_RISPOSTA_FRUIZIONE.TEMPO_MEDIO_RISPOSTA.getFieldType()));
  75.                 object.setTempiRispostaErogazione(new TempiRispostaErogazione());
  76.                 setParameter(object.getTempiRispostaErogazione(), "setConnectionTimeout", ConfigurazioneGenerale.model().TEMPI_RISPOSTA_EROGAZIONE.CONNECTION_TIMEOUT.getFieldType(),
  77.                     jdbcParameterUtilities.readParameter(rs, "pa_connection_timeout", ConfigurazioneGenerale.model().TEMPI_RISPOSTA_EROGAZIONE.CONNECTION_TIMEOUT.getFieldType()));
  78.                 setParameter(object.getTempiRispostaErogazione(), "setReadTimeout", ConfigurazioneGenerale.model().TEMPI_RISPOSTA_EROGAZIONE.READ_TIMEOUT.getFieldType(),
  79.                     jdbcParameterUtilities.readParameter(rs, "pa_read_timeout", ConfigurazioneGenerale.model().TEMPI_RISPOSTA_EROGAZIONE.READ_TIMEOUT.getFieldType()));
  80.                 setParameter(object.getTempiRispostaErogazione(), "setTempoMedioRisposta", ConfigurazioneGenerale.model().TEMPI_RISPOSTA_EROGAZIONE.TEMPO_MEDIO_RISPOSTA.getFieldType(),
  81.                     jdbcParameterUtilities.readParameter(rs, "pa_avg_time", ConfigurazioneGenerale.model().TEMPI_RISPOSTA_EROGAZIONE.TEMPO_MEDIO_RISPOSTA.getFieldType()));
  82.                 object.setRateLimiting(new ConfigurazioneRateLimiting());
  83.                 setParameter(object.getRateLimiting(), "setTipoErrore", ConfigurazioneGenerale.model().RATE_LIMITING.TIPO_ERRORE.getFieldType(),
  84.                     jdbcParameterUtilities.readParameter(rs, "rt_tipo_errore", ConfigurazioneGenerale.model().RATE_LIMITING.TIPO_ERRORE.getFieldType()));
  85.                 setParameter(object.getRateLimiting(), "setTipoErroreIncludiDescrizione", ConfigurazioneGenerale.model().RATE_LIMITING.TIPO_ERRORE_INCLUDI_DESCRIZIONE.getFieldType(),
  86.                     jdbcParameterUtilities.readParameter(rs, "rt_includi_errore", ConfigurazioneGenerale.model().RATE_LIMITING.TIPO_ERRORE_INCLUDI_DESCRIZIONE.getFieldType()));
  87.                 object.setCache(new Cache());
  88.                 setParameter(object.getCache(), "setCache", ConfigurazioneGenerale.model().CACHE.CACHE.getFieldType(),
  89.                     jdbcParameterUtilities.readParameter(rs, "cache", ConfigurazioneGenerale.model().CACHE.CACHE.getFieldType()));
  90.                 setParameter(object.getCache(), "setSize", ConfigurazioneGenerale.model().CACHE.SIZE.getFieldType(),
  91.                     jdbcParameterUtilities.readParameter(rs, "cache_size", ConfigurazioneGenerale.model().CACHE.SIZE.getFieldType()));
  92.                 setParameter(object.getCache(), "setAlgorithmRawEnumValue", String.class,
  93.                     jdbcParameterUtilities.readParameter(rs, "cache_algorithm", ConfigurazioneGenerale.model().CACHE.ALGORITHM.getFieldType())+"");
  94.                 setParameter(object.getCache(), "setIdleTime", ConfigurazioneGenerale.model().CACHE.IDLE_TIME.getFieldType(),
  95.                     jdbcParameterUtilities.readParameter(rs, "cache_idle_time", ConfigurazioneGenerale.model().CACHE.IDLE_TIME.getFieldType()));
  96.                 setParameter(object.getCache(), "setLifeTime", ConfigurazioneGenerale.model().CACHE.LIFE_TIME.getFieldType(),
  97.                     jdbcParameterUtilities.readParameter(rs, "cache_life_time", ConfigurazioneGenerale.model().CACHE.LIFE_TIME.getFieldType()));
  98.                 return object;
  99.             }
  100.            
  101.             else{
  102.                 throw new ServiceException("Model ["+model.toString()+"] not supported by fetch: "+this.getClass().getName());
  103.             }  
  104.                    
  105.         }catch(Exception e){
  106.             throw new ServiceException("Model ["+model.toString()+"] occurs error in fetch: "+e.getMessage(),e);
  107.         }
  108.        
  109.     }
  110.    
  111.     @Override
  112.     public Object fetch(TipiDatabase tipoDatabase, IModel<?> model , Map<String,Object> map ) throws ServiceException {
  113.        
  114.         try{

  115.             if(model.equals(ConfigurazioneGenerale.model())){
  116.                 ConfigurazioneGenerale object = new ConfigurazioneGenerale();
  117.                 object.setControlloTraffico(new ConfigurazioneControlloTraffico());
  118.                 setParameter(object, "setId", Long.class,
  119.                     this.getObjectFromMap(map,"controllo-traffico.id"));
  120.                 setParameter(object.getControlloTraffico(), "setControlloMaxThreadsEnabled", ConfigurazioneGenerale.model().CONTROLLO_TRAFFICO.CONTROLLO_MAX_THREADS_ENABLED.getFieldType(),
  121.                     this.getObjectFromMap(map,"controllo-traffico.controllo-max-threads-enabled"));
  122.                 setParameter(object.getControlloTraffico(), "setControlloMaxThreadsWarningOnly", ConfigurazioneGenerale.model().CONTROLLO_TRAFFICO.CONTROLLO_MAX_THREADS_WARNING_ONLY.getFieldType(),
  123.                     this.getObjectFromMap(map,"controllo-traffico.controllo-max-threads-warning-only"));
  124.                 setParameter(object.getControlloTraffico(), "setControlloMaxThreadsSoglia", ConfigurazioneGenerale.model().CONTROLLO_TRAFFICO.CONTROLLO_MAX_THREADS_SOGLIA.getFieldType(),
  125.                     this.getObjectFromMap(map,"controllo-traffico.controllo-max-threads-soglia"));
  126.                 setParameter(object.getControlloTraffico(), "setControlloMaxThreadsTipoErrore", ConfigurazioneGenerale.model().CONTROLLO_TRAFFICO.CONTROLLO_MAX_THREADS_TIPO_ERRORE.getFieldType(),
  127.                     this.getObjectFromMap(map,"controllo-traffico.controllo-max-threads-tipo-errore"));
  128.                 setParameter(object.getControlloTraffico(), "setControlloMaxThreadsTipoErroreIncludiDescrizione", ConfigurazioneGenerale.model().CONTROLLO_TRAFFICO.CONTROLLO_MAX_THREADS_TIPO_ERRORE_INCLUDI_DESCRIZIONE.getFieldType(),
  129.                     this.getObjectFromMap(map,"controllo-traffico.controllo-max-threads-tipo-errore-includi-descrizione"));
  130.                 setParameter(object.getControlloTraffico(), "setControlloCongestioneEnabled", ConfigurazioneGenerale.model().CONTROLLO_TRAFFICO.CONTROLLO_CONGESTIONE_ENABLED.getFieldType(),
  131.                     this.getObjectFromMap(map,"controllo-traffico.controllo-congestione-enabled"));
  132.                 setParameter(object.getControlloTraffico(), "setControlloCongestioneThreshold", ConfigurazioneGenerale.model().CONTROLLO_TRAFFICO.CONTROLLO_CONGESTIONE_THRESHOLD.getFieldType(),
  133.                     this.getObjectFromMap(map,"controllo-traffico.controllo-congestione-threshold"));
  134.                 object.setTempiRispostaFruizione(new TempiRispostaFruizione());
  135.                 setParameter(object.getTempiRispostaFruizione(), "setConnectionTimeout", ConfigurazioneGenerale.model().TEMPI_RISPOSTA_FRUIZIONE.CONNECTION_TIMEOUT.getFieldType(),
  136.                     this.getObjectFromMap(map,"tempi-risposta-fruizione.connection-timeout"));
  137.                 setParameter(object.getTempiRispostaFruizione(), "setReadTimeout", ConfigurazioneGenerale.model().TEMPI_RISPOSTA_FRUIZIONE.READ_TIMEOUT.getFieldType(),
  138.                     this.getObjectFromMap(map,"tempi-risposta-fruizione.read-timeout"));
  139.                 setParameter(object.getTempiRispostaFruizione(), "setTempoMedioRisposta", ConfigurazioneGenerale.model().TEMPI_RISPOSTA_FRUIZIONE.TEMPO_MEDIO_RISPOSTA.getFieldType(),
  140.                     this.getObjectFromMap(map,"tempi-risposta-fruizione.tempo-medio-risposta"));
  141.                 object.setTempiRispostaErogazione(new TempiRispostaErogazione());
  142.                 setParameter(object.getTempiRispostaErogazione(), "setConnectionTimeout", ConfigurazioneGenerale.model().TEMPI_RISPOSTA_EROGAZIONE.CONNECTION_TIMEOUT.getFieldType(),
  143.                     this.getObjectFromMap(map,"tempi-risposta-erogazione.connection-timeout"));
  144.                 setParameter(object.getTempiRispostaErogazione(), "setReadTimeout", ConfigurazioneGenerale.model().TEMPI_RISPOSTA_EROGAZIONE.READ_TIMEOUT.getFieldType(),
  145.                     this.getObjectFromMap(map,"tempi-risposta-erogazione.read-timeout"));
  146.                 setParameter(object.getTempiRispostaErogazione(), "setTempoMedioRisposta", ConfigurazioneGenerale.model().TEMPI_RISPOSTA_EROGAZIONE.TEMPO_MEDIO_RISPOSTA.getFieldType(),
  147.                     this.getObjectFromMap(map,"tempi-risposta-erogazione.tempo-medio-risposta"));
  148.                 object.setRateLimiting(new ConfigurazioneRateLimiting());
  149.                 setParameter(object.getRateLimiting(), "setTipoErrore", ConfigurazioneGenerale.model().RATE_LIMITING.TIPO_ERRORE.getFieldType(),
  150.                     this.getObjectFromMap(map,"rate-limiting.tipo-errore"));
  151.                 setParameter(object.getRateLimiting(), "setTipoErroreIncludiDescrizione", ConfigurazioneGenerale.model().RATE_LIMITING.TIPO_ERRORE_INCLUDI_DESCRIZIONE.getFieldType(),
  152.                     this.getObjectFromMap(map,"rate-limiting.tipo-errore-includi-descrizione"));
  153.                 object.setCache(new Cache());
  154.                 setParameter(object.getCache(), "setCache", ConfigurazioneGenerale.model().CACHE.CACHE.getFieldType(),
  155.                     this.getObjectFromMap(map,"cache.cache"));
  156.                 setParameter(object.getCache(), "setSize", ConfigurazioneGenerale.model().CACHE.SIZE.getFieldType(),
  157.                     this.getObjectFromMap(map,"cache.size"));
  158.                 setParameter(object.getCache(), "setAlgorithmRawEnumValue", String.class,
  159.                     this.getObjectFromMap(map,"cache.algorithm"));
  160.                 setParameter(object.getCache(), "setIdleTime", ConfigurazioneGenerale.model().CACHE.IDLE_TIME.getFieldType(),
  161.                     this.getObjectFromMap(map,"cache.idle-time"));
  162.                 setParameter(object.getCache(), "setLifeTime", ConfigurazioneGenerale.model().CACHE.LIFE_TIME.getFieldType(),
  163.                     this.getObjectFromMap(map,"cache.life-time"));
  164.                 return object;
  165.             }
  166.            
  167.             else{
  168.                 throw new ServiceException("Model ["+model.toString()+"] not supported by fetch: "+this.getClass().getName());
  169.             }  
  170.                    
  171.         }catch(Exception e){
  172.             throw new ServiceException("Model ["+model.toString()+"] occurs error in fetch: "+e.getMessage(),e);
  173.         }
  174.        
  175.     }
  176.    
  177.    
  178.     @Override
  179.     public IKeyGeneratorObject getKeyGeneratorObject( IModel<?> model )  throws ServiceException {
  180.        
  181.         try{

  182.             if(model.equals(ConfigurazioneGenerale.model())){
  183.                 return new org.openspcoop2.utils.jdbc.CustomKeyGeneratorObject("ct_config","id","seq_ct_config","ct_config_init_seq");
  184.             }
  185.            
  186.             else{
  187.                 throw new ServiceException("Model ["+model.toString()+"] not supported by getKeyGeneratorObject: "+this.getClass().getName());
  188.             }

  189.         }catch(Exception e){
  190.             throw new ServiceException("Model ["+model.toString()+"] occurs error in getKeyGeneratorObject: "+e.getMessage(),e);
  191.         }
  192.        
  193.     }

  194. }