IdentityPrincipalReader.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.utils.transport.http.credential;

  21. import javax.servlet.http.HttpServletRequest;

  22. import org.openspcoop2.utils.transport.http.HttpServletCredential;
  23. import org.slf4j.Logger;

  24. /**
  25.  * Implementazione dell'interfaccia {@link IPrincipalReader} che utilizza la classe {@link HttpServletCredential} come strumento per leggere il principal dalla request.
  26.  *
  27.  * @author Pintori Giuliano (pintori@link.it)
  28.  * @author $Author$
  29.  * @version $Rev$, $Date$
  30.  */
  31. public class IdentityPrincipalReader implements IPrincipalReader{


  32.     private Logger log = null;

  33.     /**
  34.      *
  35.      */
  36.     private static final long serialVersionUID = 1L;

  37.     public IdentityPrincipalReader(Logger log){
  38.         this.log = log;
  39.         this.log.debug("IdentityPrincipalReader inizializzato.");
  40.     }

  41.     @Override
  42.     public void init(Object... parametri) throws PrincipalReaderException {
  43.     }

  44.     @Override
  45.     public String getPrincipal(HttpServletRequest request) throws PrincipalReaderException {
  46.         this.log.debug("Estrazione principal in corso...");

  47.         try{
  48.             HttpServletCredential identity = new HttpServletCredential(request,this.log);
  49.             String username = identity.getPrincipal();

  50.             this.log.debug("Username trovato nel principal [identity.getPrincipal()]: ["+username+"]");
  51.             this.log.debug("Username trovato nel principal [identity.getUsername()]: ["+identity.getUsername()+"]");

  52.             return username;
  53.         }catch (Exception e) {
  54.             this.log.error("Errore durante la lettura del principal: "+ e.getMessage(),e);
  55.             throw new PrincipalReaderException(e);
  56.         }
  57.     }
  58. }