SbustamentoMessage.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.pdd.mdb;

  21. import java.util.List;

  22. import org.openspcoop2.core.eccezione.details.DettaglioEccezione;
  23. import org.openspcoop2.pdd.config.RichiestaApplicativa;
  24. import org.openspcoop2.pdd.core.PdDContext;
  25. import org.openspcoop2.protocol.sdk.Busta;
  26. import org.openspcoop2.protocol.sdk.Eccezione;
  27. import org.openspcoop2.protocol.sdk.constants.IntegrationFunctionError;
  28. import org.openspcoop2.protocol.sdk.constants.RuoloBusta;

  29. /**
  30.  * Classe utilizzata per raccogliere informazioni incluse in un MessaggioJMS.
  31.  * Il messaggio JMS sara' poi ricevuto, attraverso una coda apposita,
  32.  * dal mdb definito nella classe {@link SbustamentoMDB}.
  33.  *
  34.  *
  35.  * @author Poli Andrea (apoli@link.it)
  36.  * @author $Author$
  37.  * @version $Rev$, $Date$
  38.  */

  39. public class SbustamentoMessage implements GenericMessage {

  40.     /**
  41.      * serialVersionUID
  42.      */
  43.     private static final long serialVersionUID = 1L;

  44.     /* ********  F I E L D S  P R I V A T I  ******** */

  45.     /** Identificatore della Porta Applicativa Richiesta */
  46.     private RichiestaApplicativa richiestaApplicativa;
  47.     /** Busta di richiesta. */
  48.     private Busta busta;
  49.     /** Eventuali errori riscontrati durante la validazione della Busta ricevuta.
  50.         Se non sono presenti errori, questa variabile conterra' un List vuoto (size = 0) */
  51.     private List<Eccezione> errors;
  52.     private IntegrationFunctionError integrationFunctionErrorValidazione;
  53.     /** Indicazione se la busta associata a questo messaggio e' un messaggio od un messaggioErrore */
  54.     private boolean isMessaggioErroreProtocollo;
  55.     /** Indicazione se la busta associata a questo messaggio e' un messaggio senza carico applicativo */
  56.     private boolean isBustaDiServizio;
  57.     /** Indicazione se e' abilitato il filtro duplicati */
  58.     private boolean filtroDuplicatiRichiestoAccordo;
  59.     /** Indicazione se e' abilitato la conferma ricezione */
  60.     private boolean confermaRicezioneRichiestoAccordo;
  61.     /** Indicazione se e' abilitato la consegna in ordine */
  62.     private boolean consegnaOrdineRichiestoAccordo;
  63.     /** ServizioCorrelato necessario per la richiesta Asincrona Asimmetrica */
  64.     private String servizioCorrelato;
  65.     /** Tipo ServizioCorrelato necessario per la richiesta Asincrona Asimmetrica*/
  66.     private String tipoServizioCorrelato;
  67.     /** Versione ServizioCorrelato necessario per la richiesta Asincrona Asimmetrica*/
  68.     private Integer versioneServizioCorrelato;
  69.     /** RuoloBusta */
  70.     private RuoloBusta ruoloBustaRicevuta = null;

  71.     /** Indicazione se siamo in modalita oneway11 */
  72.     private boolean oneWayVersione11;
  73.     /** Indicazione se la porta delegata/applicativa richiesta una modalita stateless (oneway o sincrono)
  74.      *  Il caso oneway11 possiedera questo booleano con il valore false.
  75.      * */
  76.     private boolean stateless;

  77.     /** Tipologia di porta di domino del soggetto mittente */
  78.     private String implementazionePdDSoggettoMittente;
  79.     /** Tipologia di porta di domino del soggetto destinatario */
  80.     private String implementazionePdDSoggettoDestinatario;
  81.    
  82.     /** PdDContext */
  83.     private PdDContext pddContext;
  84.    
  85.     /** DettaglioEccezione */
  86.     private DettaglioEccezione dettaglioEccezione;
  87.    

  88.     /* ********  C O S T R U T T O R E  ******** */

  89.     /**
  90.      * Costruttore.
  91.      *
  92.      *
  93.      */    
  94.     public SbustamentoMessage(){
  95.     }





  96.     /* ********  S E T T E R   ******** */

  97.     /**
  98.      * Imposta l'identificatore della porta applicativa richiesta.
  99.      *
  100.      * @param idpa Identificatore della porta applicativa.
  101.      *
  102.      */
  103.     public void setRichiestaApplicativa(RichiestaApplicativa idpa){
  104.         this.richiestaApplicativa = idpa;
  105.     }
  106.     /**
  107.      * Imposta la Busta ricevuta.
  108.      *
  109.      * @param aBusta Busta ricevuta.
  110.      *
  111.      */
  112.     public void setBusta(Busta aBusta){
  113.         this.busta = aBusta;
  114.     }
  115.     /**
  116.      * Imposta eventuali errori riscontrati durante la validazione della Busta ricevuta.
  117.      * Se non sono presenti errori, questa variabile conterra' un List vuoto (size = 0)
  118.      *
  119.      * @param aErrors Errori riscontrati durante la validazione della busta.
  120.      *
  121.      */
  122.     public void setErrors(List<Eccezione> aErrors, IntegrationFunctionError integrationFunctionError){
  123.         this.errors = aErrors;
  124.         this.integrationFunctionErrorValidazione = integrationFunctionError;
  125.     }
  126.     /**
  127.      * Imposta l'indicazione se la busta associata a questo messaggio e' un messaggio od un messaggioErrore
  128.      *
  129.      * @param isErrore indicazione se la busta associata a questo messaggio e' un messaggio (false)
  130.      *                 od un messaggioErrore (true).
  131.      *
  132.      */
  133.     public void setMessaggioErroreProtocollo(boolean isErrore){
  134.         this.isMessaggioErroreProtocollo = isErrore;
  135.     }
  136.     /**
  137.      * Imposta l'indicazione se la busta associata a questo messaggio e' un messaggio senza carico applicativo
  138.      *
  139.      * @param isDiServizio indicazione se la busta associata a questo messaggio e' un messaggio senza carico applicativo (true).
  140.      *
  141.      */
  142.     public void setIsBustaDiServizio(boolean isDiServizio){
  143.         this.isBustaDiServizio = isDiServizio;
  144.     }
  145.     /**
  146.      * Eventuale servizio correlato associato al servizio presente nella busta.
  147.      *
  148.      * @param ser Eventuale servizio correlato associato al servizio presente nella busta.
  149.      *
  150.      */
  151.     public void setServizioCorrelato(String ser) {
  152.         this.servizioCorrelato = ser;
  153.     }

  154.     /**
  155.      * Eventuale tipo di servizio correlato associato al servizio presente nella busta.
  156.      *
  157.      * @param tipo Eventuale tipo di servizio correlato associato al servizio presente nella busta.
  158.      *
  159.      */
  160.     public void setTipoServizioCorrelato(String tipo) {
  161.         this.tipoServizioCorrelato = tipo;
  162.     }

  163.     public void setVersioneServizioCorrelato(Integer versioneServizioCorrelato) {
  164.         this.versioneServizioCorrelato = versioneServizioCorrelato;
  165.     }
  166.    
  167.     public void setRuoloBustaRicevuta(RuoloBusta ruoloBustaRicevuta) {
  168.         this.ruoloBustaRicevuta = ruoloBustaRicevuta;
  169.     }

  170.     /**
  171.      * @param oneWayVersione11
  172.      */
  173.     public void setOneWayVersione11(boolean oneWayVersione11) {
  174.         this.oneWayVersione11 = oneWayVersione11;
  175.     }
  176.    
  177.    
  178.     public void setStateless(boolean stateless) {
  179.         this.stateless = stateless;
  180.     }




  181.     /* ********  G E T T E R   ******** */

  182.     /**
  183.      * Ritorna l'identificatore della porta applicativa richiesta.
  184.      *
  185.      * @return Identificatore della porta applicativa.
  186.      *
  187.      */
  188.     public RichiestaApplicativa getRichiestaApplicativa(){
  189.         return this.richiestaApplicativa;
  190.     }
  191.     /**
  192.      * Ritorna la Busta ricevuta come risposta.
  193.      *
  194.      * @return Busta ricevuta.
  195.      *
  196.      */
  197.     public Busta getBusta(){
  198.         return this.busta;
  199.     }
  200.     /**
  201.      * Ritorna eventuali errori riscontrati durante la validazione della Busta ricevuta.
  202.      * Se non sono presenti errori, questa variabile conterra' un List vuoto (size = 0)
  203.      *
  204.      * @return Errori riscontrati durante la validazione della busta se presenti, un List vuoto (size = 0) altrimenti.
  205.      *
  206.      */
  207.     public List<Eccezione> getErrors(){
  208.         return this.errors;
  209.     }
  210.     public IntegrationFunctionError getIntegrationFunctionErrorValidazione() {
  211.         return this.integrationFunctionErrorValidazione;
  212.     }
  213.     /**
  214.      * Ritorna l'indicazione se la busta associata a questo messaggio e' un messaggio od un messaggioErrore
  215.      *
  216.      * @return indicazione se la busta associata a questo messaggio e' un messaggio (false)
  217.      *                 od un messaggioErrore (true).
  218.      *
  219.      */
  220.     public boolean isMessaggioErroreProtocollo(){
  221.         return this.isMessaggioErroreProtocollo;
  222.     }
  223.     /**
  224.      * Ritorna l'indicazione se la busta associata a questo messaggio e' un messaggio senza carico applicativo
  225.      *
  226.      * @return indicazione se la busta associata a questo messaggio e' un messaggio senza carico applicativo (true).
  227.      *
  228.      */
  229.     public boolean getIsBustaDiServizio(){
  230.         return this.isBustaDiServizio;
  231.     }


  232.     /**
  233.      * Eventuale servizio correlato associato al servizio presente nella busta.
  234.      *
  235.      * @return Eventuale servizio correlato associato al servizio presente nella busta.
  236.      *
  237.      */
  238.     public String getServizioCorrelato() {
  239.         return this.servizioCorrelato;
  240.     }

  241.     /**
  242.      * Eventuale tipo di servizio correlato associato al servizio presente nella busta.
  243.      *
  244.      * @return Eventuale tipo di servizio correlato associato al servizio presente nella busta.
  245.      *
  246.      */
  247.     public String getTipoServizioCorrelato() {
  248.         return this.tipoServizioCorrelato;
  249.     }

  250.     public Integer getVersioneServizioCorrelato() {
  251.         return this.versioneServizioCorrelato;
  252.     }

  253.     public RuoloBusta getRuoloBustaRicevuta() {
  254.         return this.ruoloBustaRicevuta;
  255.     }

  256.     /**
  257.      * @return indicazione se stiamo gestendo oneway in modalita stateless 1.4
  258.      */
  259.     public boolean isOneWayVersione11() {
  260.         return this.oneWayVersione11;
  261.     }

  262.     public boolean isStateless() {
  263.         return this.stateless;
  264.     }

  265.     public boolean isFiltroDuplicatiRichiestoAccordo() {
  266.         return this.filtroDuplicatiRichiestoAccordo;
  267.     }

  268.     public void setFiltroDuplicatiRichiestoAccordo(
  269.             boolean filtroDuplicatiRichiestoAccordo) {
  270.         this.filtroDuplicatiRichiestoAccordo = filtroDuplicatiRichiestoAccordo;
  271.     }

  272.     public boolean isConfermaRicezioneRichiestoAccordo() {
  273.         return this.confermaRicezioneRichiestoAccordo;
  274.     }
  275.     public void setConfermaRicezioneRichiestoAccordo(
  276.             boolean confermaRicezioneRichiestoAccordo) {
  277.         this.confermaRicezioneRichiestoAccordo = confermaRicezioneRichiestoAccordo;
  278.     }

  279.     public boolean isConsegnaOrdineRichiestoAccordo() {
  280.         return this.consegnaOrdineRichiestoAccordo;
  281.     }
  282.     public void setConsegnaOrdineRichiestoAccordo(
  283.             boolean consegnaOrdineRichiestoAccordo) {
  284.         this.consegnaOrdineRichiestoAccordo = consegnaOrdineRichiestoAccordo;
  285.     }


  286.    
  287.    
  288.     public String getImplementazionePdDSoggettoMittente() {
  289.         return this.implementazionePdDSoggettoMittente;
  290.     }

  291.     public void setImplementazionePdDSoggettoMittente(
  292.             String implementazionePdDSoggettoMittente) {
  293.         this.implementazionePdDSoggettoMittente = implementazionePdDSoggettoMittente;
  294.     }

  295.     public String getImplementazionePdDSoggettoDestinatario() {
  296.         return this.implementazionePdDSoggettoDestinatario;
  297.     }

  298.     public void setImplementazionePdDSoggettoDestinatario(
  299.             String implementazionePdDSoggettoDestinatario) {
  300.         this.implementazionePdDSoggettoDestinatario = implementazionePdDSoggettoDestinatario;
  301.     }
  302.    
  303.     @Override
  304.     public PdDContext getPddContext() {
  305.         return this.pddContext;
  306.     }

  307.     public void setPddContext(PdDContext pddContext) {
  308.         this.pddContext = pddContext;
  309.     }

  310.     public DettaglioEccezione getDettaglioEccezione() {
  311.         return this.dettaglioEccezione;
  312.     }
  313.    
  314.     public void setDettaglioEccezione(DettaglioEccezione dettaglioEccezione) {
  315.         this.dettaglioEccezione = dettaglioEccezione;
  316.     }
  317. }