PorteApplicativeList.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.web.ctrlstat.servlet.pa;

  21. import java.util.List;

  22. import javax.servlet.http.HttpServletRequest;
  23. import javax.servlet.http.HttpServletResponse;
  24. import javax.servlet.http.HttpSession;

  25. import org.apache.struts.action.Action;
  26. import org.apache.struts.action.ActionForm;
  27. import org.apache.struts.action.ActionForward;
  28. import org.apache.struts.action.ActionMapping;
  29. import org.openspcoop2.core.commons.Liste;
  30. import org.openspcoop2.core.config.PortaApplicativa;
  31. import org.openspcoop2.web.ctrlstat.core.ControlStationCore;
  32. import org.openspcoop2.web.ctrlstat.core.ConsoleSearch;
  33. import org.openspcoop2.web.ctrlstat.servlet.GeneralHelper;
  34. import org.openspcoop2.web.lib.mvc.ForwardParams;
  35. import org.openspcoop2.web.lib.mvc.GeneralData;
  36. import org.openspcoop2.web.lib.mvc.PageData;
  37. import org.openspcoop2.web.lib.mvc.ServletUtils;

  38. /**
  39.  * porteAppList
  40.  *
  41.  * @author Andrea Poli (apoli@link.it)
  42.  * @author Stefano Corallo (corallo@link.it)
  43.  * @author Sandra Giangrandi (sandra@link.it)
  44.  * @author $Author$
  45.  * @version $Rev$, $Date$
  46.  *
  47.  */
  48. public final class PorteApplicativeList extends Action {

  49.     @Override
  50.     public ActionForward execute(ActionMapping mapping, ActionForm form, HttpServletRequest request, HttpServletResponse response) throws Exception {

  51.         HttpSession session = request.getSession(true);

  52.         // Inizializzo PageData
  53.         PageData pd = new PageData();

  54.         GeneralHelper generalHelper = new GeneralHelper(session);

  55.         // Inizializzo GeneralData
  56.         GeneralData gd = generalHelper.initGeneralData(request);

  57.         try {
  58.             PorteApplicativeHelper porteApplicativeHelper = new PorteApplicativeHelper(request, pd, session);
  59.             Integer parentPA = ServletUtils.getIntegerAttributeFromSession(PorteApplicativeCostanti.ATTRIBUTO_PORTE_APPLICATIVE_PARENT, session, request);
  60.             if(parentPA == null) parentPA = PorteApplicativeCostanti.ATTRIBUTO_PORTE_APPLICATIVE_PARENT_NONE;
  61.             Boolean useIdSogg = parentPA == PorteApplicativeCostanti.ATTRIBUTO_PORTE_APPLICATIVE_PARENT_SOGGETTO;
  62.            
  63.             String idsogg = porteApplicativeHelper.getParameter(PorteApplicativeCostanti.PARAMETRO_PORTE_APPLICATIVE_ID_SOGGETTO);
  64.             int soggInt = -1;
  65.             // Posso arrivare a questa pagina anche dal menu' senza specificare il soggetto
  66.             if(idsogg != null){
  67.                 soggInt = Integer.parseInt(idsogg);
  68.                 useIdSogg = true;
  69.             } else {
  70.                 useIdSogg = false;
  71.             }
  72.            
  73.             parentPA = useIdSogg ? PorteApplicativeCostanti.ATTRIBUTO_PORTE_APPLICATIVE_PARENT_SOGGETTO : PorteApplicativeCostanti.ATTRIBUTO_PORTE_APPLICATIVE_PARENT_NONE;

  74.             // salvo il punto di ingresso
  75.             ServletUtils.setObjectIntoSession(request, session, parentPA, PorteApplicativeCostanti.ATTRIBUTO_PORTE_APPLICATIVE_PARENT);

  76.             // Preparo il menu
  77.             porteApplicativeHelper.makeMenu();

  78.             PorteApplicativeCore porteApplicativeCore = new PorteApplicativeCore();

  79.             // Preparo la lista
  80.             ConsoleSearch ricerca = (ConsoleSearch) ServletUtils.getSearchObjectFromSession(request, session, ConsoleSearch.class);

  81.             List<PortaApplicativa> lista = null;
  82.             int idLista = -1;
  83.             if(useIdSogg){
  84.                 idLista = Liste.PORTE_APPLICATIVE_BY_SOGGETTO;
  85.                 ricerca = porteApplicativeHelper.checkSearchParameters(idLista, ricerca);
  86.                 lista = porteApplicativeCore.porteAppList(soggInt, ricerca);
  87.             }else{
  88.                 idLista = Liste.PORTE_APPLICATIVE;
  89.                 ricerca = porteApplicativeHelper.checkSearchParameters(idLista, ricerca);
  90.                 lista = porteApplicativeCore.porteAppList(null, ricerca);
  91.             }
  92.            

  93.             porteApplicativeHelper.preparePorteAppList(ricerca, lista, idLista);

  94.             ServletUtils.setSearchObjectIntoSession(request, session, ricerca);
  95.             ServletUtils.setGeneralAndPageDataIntoSession(request, session, gd, pd);
  96.            
  97.             // Forward control to the specified success URI
  98.             return ServletUtils.getStrutsForward (mapping, PorteApplicativeCostanti.OBJECT_NAME_PORTE_APPLICATIVE,
  99.                     ForwardParams.LIST());
  100.         } catch (Exception e) {
  101.             return ServletUtils.getStrutsForwardError(ControlStationCore.getLog(), e, pd, request, session, gd, mapping,
  102.                     PorteApplicativeCostanti.OBJECT_NAME_PORTE_APPLICATIVE,
  103.                     ForwardParams.LIST());
  104.         }
  105.     }
  106. }