ScopeApiServiceImpl.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.config.rs.server.api.impl.scope;

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

  23. import org.apache.commons.lang.StringEscapeUtils;
  24. import org.openspcoop2.core.commons.Filtri;
  25. import org.openspcoop2.core.commons.Liste;
  26. import org.openspcoop2.core.config.rs.server.api.ScopeApi;
  27. import org.openspcoop2.core.config.rs.server.api.impl.Enums;
  28. import org.openspcoop2.core.config.rs.server.api.impl.Helper;
  29. import org.openspcoop2.core.config.rs.server.config.ServerProperties;
  30. import org.openspcoop2.core.config.rs.server.model.ContestoEnum;
  31. import org.openspcoop2.core.config.rs.server.model.ListaScope;
  32. import org.openspcoop2.core.config.rs.server.model.Scope;
  33. import org.openspcoop2.core.id.IDScope;
  34. import org.openspcoop2.utils.service.BaseImpl;
  35. import org.openspcoop2.utils.service.authorization.AuthorizationConfig;
  36. import org.openspcoop2.utils.service.authorization.AuthorizationManager;
  37. import org.openspcoop2.utils.service.beans.utils.BaseHelper;
  38. import org.openspcoop2.utils.service.beans.utils.ListaUtils;
  39. import org.openspcoop2.utils.service.context.IContext;
  40. import org.openspcoop2.utils.service.fault.jaxrs.FaultCode;
  41. import org.openspcoop2.web.ctrlstat.core.ConsoleSearch;
  42. import org.openspcoop2.web.ctrlstat.servlet.scope.ScopeUtilities;
  43. import org.openspcoop2.web.lib.mvc.TipoOperazione;

  44. /**
  45.  * ScopeApiServiceImpl
  46.  *
  47.  * @author $Author$
  48.  * @version $Rev$, $Date$
  49.  *
  50.  */
  51. public class ScopeApiServiceImpl extends BaseImpl implements ScopeApi {

  52.     public ScopeApiServiceImpl(){
  53.         super(org.slf4j.LoggerFactory.getLogger(ScopeApiServiceImpl.class));
  54.     }

  55.     private AuthorizationConfig getAuthorizationConfig() throws Exception{
  56.         return new AuthorizationConfig(ServerProperties.getInstance().getProperties());
  57.     }
  58.    
  59.     /**
  60.      * Creazione di uno scope
  61.      *
  62.      * Questa operazione consente di creare uno scope
  63.      *
  64.      */
  65.     @Override
  66.     public void createScope(Scope body) {
  67.         IContext context = this.getContext();
  68.         try {
  69.             context.getLogger().info("Invocazione in corso ...");    

  70.             AuthorizationManager.authorize(context, getAuthorizationConfig());
  71.             context.getLogger().debug("Autorizzazione completata con successo");  
  72.            
  73.             BaseHelper.throwIfNull(body);
  74.            
  75.             ScopeEnv env = new ScopeEnv(context.getServletRequest(),context);
  76.             ScopeApiHelper.ovverrideParameters(env.requestWrapper, body);
  77.            
  78.             org.openspcoop2.core.registry.Scope regScope = ScopeApiHelper.apiScopeToRegistroScope(body, env.userLogin);
  79.            
  80.             if(env.scopeCore.existsScope(regScope.getNome())) {
  81.                 throw FaultCode.CONFLITTO.toException("Un scope con nome '" + regScope.getNome() + "' risulta giĆ  registrato");
  82.             }
  83.            
  84.             if (!env.scopeHelper.scopeCheckData(TipoOperazione.ADD, null)) {
  85.                 throw FaultCode.RICHIESTA_NON_VALIDA.toException(StringEscapeUtils.unescapeHtml(env.pd.getMessage()));
  86.             }
  87.            
  88.             env.scopeCore.performCreateOperation(env.userLogin, false, regScope);

  89.             context.getLogger().info("Invocazione completata con successo");
  90.            
  91.            
  92.             // Bug Fix: altrimenti viene generato 204
  93.             context.getServletResponse().setStatus(201);
  94.         }
  95.         catch(javax.ws.rs.WebApplicationException e) {
  96.             context.getLogger().error_except404("Invocazione terminata con errore '4xx': %s",e, e.getMessage());
  97.             throw e;
  98.         }
  99.         catch(Throwable e) {
  100.             context.getLogger().error("Invocazione terminata con errore: %s",e, e.getMessage());
  101.             throw FaultCode.ERRORE_INTERNO.toException(e);
  102.         }
  103.     }
  104.    
  105.     /**
  106.      * Elimina uno scope
  107.      *
  108.      * Questa operazione consente di eliminare uno scope identificato dal nome
  109.      *
  110.      */
  111.     @Override
  112.     public void deleteScope(String nome) {
  113.         IContext context = this.getContext();
  114.         try {
  115.             context.getLogger().info("Invocazione in corso ...");    

  116.             AuthorizationManager.authorize(context, getAuthorizationConfig());
  117.             context.getLogger().debug("Autorizzazione completata con successo");
  118.            
  119.             ScopeEnv sEnv = new ScopeEnv(context.getServletRequest(),context);
  120.            
  121.             final org.openspcoop2.core.registry.Scope scope = BaseHelper.evalnull( () -> sEnv.scopeCore.getScope(nome) );
  122.            
  123.             if ( scope != null ) {
  124.                 StringBuilder inUsoMessage = new StringBuilder();
  125.                 ScopeUtilities.deleteScope(scope, sEnv.userLogin, sEnv.scopeCore, sEnv.scopeHelper, inUsoMessage, "\n");
  126.                
  127.                 if (inUsoMessage.length() > 0) {
  128.                     throw FaultCode.RICHIESTA_NON_VALIDA.toException(StringEscapeUtils.unescapeHtml(inUsoMessage.toString()));
  129.                 }
  130.             }
  131.            
  132.             if ( scope == null && sEnv.delete_404 ) {
  133.                 throw FaultCode.NOT_FOUND.toException("Nessuno scope da eliminare corrisponde al nome: " + nome);
  134.             }
  135.            
  136.                                      
  137.             context.getLogger().info("Invocazione completata con successo");
  138.         }
  139.         catch(javax.ws.rs.WebApplicationException e) {
  140.             context.getLogger().error_except404("Invocazione terminata con errore '4xx': %s",e, e.getMessage());
  141.             throw e;
  142.         }
  143.         catch(Throwable e) {
  144.             context.getLogger().error("Invocazione terminata con errore: %s",e, e.getMessage());
  145.             throw FaultCode.ERRORE_INTERNO.toException(e);
  146.         }
  147.     }
  148.    
  149.     /**
  150.      * Ricerca scope
  151.      *
  152.      * Elenca gli scope registrati
  153.      *
  154.      */
  155.     @Override
  156.     public ListaScope findAllScope(String q, Integer limit, Integer offset, ContestoEnum contesto) {
  157.         IContext context = this.getContext();
  158.         try {
  159.             context.getLogger().info("Invocazione in corso ...");
  160.             AuthorizationManager.authorize(context, getAuthorizationConfig());
  161.            
  162.             context.getLogger().debug("Autorizzazione completata con successo");    
  163.            
  164.             ScopeEnv env = new ScopeEnv(context.getServletRequest(), context);
  165.            
  166.             int idLista = Liste.SCOPE;
  167.             ConsoleSearch ricerca = Helper.setupRicercaPaginata(q, limit, offset, idLista);
  168.            
  169.            
  170.             if (contesto != null)
  171.                 ricerca.addFilter(idLista, Filtri.FILTRO_SCOPE_CONTESTO, Enums.apiContestoToRegistroContesto.get(contesto).toString());
  172.                        
  173.             List<org.openspcoop2.core.registry.Scope> scopes = env.scopeCore.scopeList(null, ricerca);
  174.             if ( env.findall_404 && scopes.isEmpty() ) {
  175.                 throw FaultCode.NOT_FOUND.toException("Nessuno scope corrisponde ai criteri di ricerca specificati");
  176.             }
  177.        
  178.             final ListaScope ret = ListaUtils.costruisciListaPaginata(
  179.                     context.getUriInfo(),
  180.                     ricerca.getIndexIniziale(idLista),
  181.                     ricerca.getPageSize(idLista),
  182.                     ricerca.getNumEntries(idLista),
  183.                     ListaScope.class
  184.                 );
  185.            
  186.             scopes.forEach( regScope -> ret.addItemsItem(ScopeApiHelper.registroScopeToScopeItem(regScope)) );
  187.                
  188.             context.getLogger().info("Invocazione completata con successo");

  189.                
  190.             return ret;
  191.         }
  192.         catch(javax.ws.rs.WebApplicationException e) {
  193.             context.getLogger().error_except404("Invocazione terminata con errore '4xx': %s",e, e.getMessage());
  194.             throw e;
  195.         }
  196.         catch(Throwable e) {
  197.             context.getLogger().error("Invocazione terminata con errore: %s",e, e.getMessage());
  198.             throw FaultCode.ERRORE_INTERNO.toException(e);
  199.         }
  200.     }
  201.    
  202.     /**
  203.      * Restituisce il dettaglio di uno scope
  204.      *
  205.      * Questa operazione consente di ottenere il dettaglio di uno scope identificato dal nome
  206.      *
  207.      */
  208.     @Override
  209.     public Scope getScope(String nome) {
  210.         IContext context = this.getContext();
  211.         try {
  212.             context.getLogger().info("Invocazione in corso ...");    

  213.             AuthorizationManager.authorize(context, getAuthorizationConfig());
  214.             context.getLogger().debug("Autorizzazione completata con successo");    
  215.            
  216.             ScopeEnv env = new ScopeEnv(context.getServletRequest(), context);
  217.            
  218.             org.openspcoop2.core.registry.Scope regScope = null;
  219.             try {
  220.                 regScope = env.scopeCore.getScope(nome);
  221.             } catch (Exception e) {}
  222.            
  223.             if (regScope == null)
  224.                 throw FaultCode.NOT_FOUND.toException("Non trovato alcuno scope con nome " + nome);
  225.            
  226.             context.getLogger().info("Invocazione completata con successo");
  227.            
  228.             return ScopeApiHelper.registroScopeToScope(regScope);
  229.         }
  230.         catch(javax.ws.rs.WebApplicationException e) {
  231.             context.getLogger().error_except404("Invocazione terminata con errore '4xx': %s",e, e.getMessage());
  232.             throw e;
  233.         }
  234.         catch(Throwable e) {
  235.             context.getLogger().error("Invocazione terminata con errore: %s",e, e.getMessage());
  236.             throw FaultCode.ERRORE_INTERNO.toException(e);
  237.         }
  238.     }
  239.    
  240.     /**
  241.      * Modifica i dati di uno scope
  242.      *
  243.      * Questa operazione consente di aggiornare i dati di uno scope identificato dal nome
  244.      *
  245.      */
  246.     @Override
  247.     public void updateScope(Scope body, String nome) {
  248.         IContext context = this.getContext();
  249.         try {
  250.             context.getLogger().info("Invocazione in corso ...");    

  251.             AuthorizationManager.authorize(context, getAuthorizationConfig());
  252.             context.getLogger().debug("Autorizzazione completata con successo");    
  253.            
  254.             BaseHelper.throwIfNull(body);
  255.            
  256.             ScopeEnv env = new ScopeEnv(context.getServletRequest(), context);
  257.             ScopeApiHelper.ovverrideParameters(env.requestWrapper, body);
  258.            
  259.             org.openspcoop2.core.registry.Scope scopeNEW = ScopeApiHelper.apiScopeToRegistroScope(body, env.userLogin);
  260.             org.openspcoop2.core.registry.Scope scopeOLD = BaseHelper.evalnull( () -> env.scopeCore.getScope(nome));
  261.                        
  262.             // Chiedere ad andrea se il detail lo vuole privato o meno.
  263.             if (scopeOLD == null)
  264.                 throw FaultCode.NOT_FOUND.toException("Nessuno scope corrisponde al nome " + nome);
  265.            
  266.             if (!env.scopeHelper.scopeCheckData(TipoOperazione.CHANGE, scopeOLD)) {
  267.                 throw FaultCode.RICHIESTA_NON_VALIDA.toException(StringEscapeUtils.unescapeHtml(env.pd.getMessage()));
  268.             }
  269.            
  270.             scopeNEW.setOldIDScopeForUpdate(new IDScope(nome));

  271.             List<Object> listOggettiDaAggiornare = new ArrayList<>();
  272.            
  273.             listOggettiDaAggiornare.add(scopeNEW);
  274.             if(scopeNEW.getNome().equals(nome)==false){
  275.                 // e' stato modificato il nome
  276.                 IDScope oldIdScope = scopeNEW.getOldIDScopeForUpdate();
  277.                 oldIdScope.setNome(nome);
  278.                
  279.                 ScopeUtilities.findOggettiDaAggiornare(oldIdScope, scopeNEW, env.scopeCore, listOggettiDaAggiornare);
  280.             }
  281.            
  282.             env.scopeCore.performUpdateOperation(env.userLogin, false, listOggettiDaAggiornare.toArray());
  283.             context.getLogger().info("Invocazione completata con successo");
  284.         }
  285.         catch(javax.ws.rs.WebApplicationException e) {
  286.             context.getLogger().error_except404("Invocazione terminata con errore '4xx': %s",e, e.getMessage());
  287.             throw e;
  288.         }
  289.         catch(Throwable e) {
  290.             context.getLogger().error("Invocazione terminata con errore: %s",e, e.getMessage());
  291.             throw FaultCode.ERRORE_INTERNO.toException(e);
  292.         }
  293.     }
  294.    
  295. }