
import java.math.BigDecimal;
import java.sql.*;
import com.softwareag.entirex.aci.Broker;
import com.softwareag.entirex.aci.BrokerException;
import com.softwareag.entirex.aci.EntireXSecurity;

/**
 * <p>Titre : Jwftetl1Php</p>
 * <p>Description : Classe de récupération de la liste des ftp état</p>
 * <p>Copyright : Copyright (c) 2012</p>
 * <p>Societe : ENSOR</p>
 * @author HP <i>12/01/2012</i>
 * @version 1.0
 */
public class Jwftetl1Web {	

		private static String PRINT = "NO";
			
		/**
		 * <p>Titre : getListeFtpEtat</p>
		 * <p>Description : Récupération de l'objet Liste des ftp état</p>
		 * <p>Copyright : Copyright (c) 2011</p>
		 * <p>Societe : ENSOR</p>
		 * @author AR & DR <i>25/10/2011</i>
		 * @version 1.0
		 */
		public static Jwftetl1 getListeFtpEtat(
			String nbrep,
			String page,
			String fonction,
			String f_cd_cible,
			String f_cd_titre,
			String f_code_etat,
			String f_dt_trf_deb,
			String f_dt_trf_fin,
			String f_statut_etat,
			String f_code_famille,
			String f_k_parution,
			String f_dt_parution,
			
			String groupe_exploitant,
			String numero_session,
			String utilisateur,
			String cd_stegrp,
			String cd_cible,
			String dbid,
			String rpc_name,
			Broker broker) throws BrokerException {
			// Initialisation des variables en entrees
	     	Jwftetl1 jwftetl1 = new Jwftetl1(broker, Utils.formatSrvAddr  (rpc_name));
			
			// Initialisation de la vWebent depuis les informations de connexion
			Jwftetl1.Nwftetl1Axwebent vWebent = jwftetl1.new Nwftetl1Axwebent();
			vWebent.dbid = new BigDecimal (dbid);
			vWebent.cible_exploitant = cd_cible;
			vWebent.groupe_exploitant = groupe_exploitant;
			vWebent.numero_session = new BigDecimal (numero_session);
			vWebent.utilisateur =  utilisateur;
			//vWebent.transaction = "WFTETLST";
			vWebent.transaction = "WBWFTLST";
			vWebent.fonction = fonction;
			vWebent.cd_cible =  cd_cible;
			vWebent.cd_stegrp = cd_stegrp;
			vWebent.cd_application = Constantes.CD_APPLICATION;
			jwftetl1.setNwftetl1Axwebent (vWebent);
	        
			// Initialisation des paramètres de pagination
			Jwftetl1.Nwftetl1Axweblst vWeblst = jwftetl1.new Nwftetl1Axweblst();
			vWeblst.nb_rep_souhait = new BigDecimal(nbrep);
			vWeblst.num_page_souhait = new BigDecimal(page);
			jwftetl1.setNwftetl1Axweblst (vWeblst);

			// Initialisation des critères (tous à vide pour l'instant)
			Jwftetl1.Nwftetl1Awftetl1 vFtetl1 = jwftetl1.new Nwftetl1Awftetl1();
			Jwftetl1.Nwftetl1Awftetl1Demande vFtetl1Demande = jwftetl1.new Nwftetl1Awftetl1Demande();
			Jwftetl1.Nwftetl1Awftetl1DemandeCritere_select vFtetl1DemandeCritere = jwftetl1.new Nwftetl1Awftetl1DemandeCritere_select();
			vFtetl1DemandeCritere.f_cd_cible = f_cd_cible;
			vFtetl1DemandeCritere.f_cd_titre = f_cd_titre;
			vFtetl1DemandeCritere.f_code_etat = f_code_etat;
			if(f_dt_trf_deb!="" && f_dt_trf_deb!=null)
				vFtetl1DemandeCritere.f_dt_trf_deb = new BigDecimal(f_dt_trf_deb);
			else
				vFtetl1DemandeCritere.f_dt_trf_deb =null ;
			if(f_dt_trf_fin!="" && f_dt_trf_fin!=null)
				vFtetl1DemandeCritere.f_dt_trf_fin = new BigDecimal(f_dt_trf_fin);
			else 
				vFtetl1DemandeCritere.f_dt_trf_fin = null ;
			if(f_statut_etat!="" && f_statut_etat!=null){
				vFtetl1DemandeCritere.f_statut_etat = f_statut_etat;
			}	
			vFtetl1DemandeCritere.f_code_famille = f_code_famille;			
			vFtetl1DemandeCritere.f_k_parution = f_k_parution;
			if(f_dt_parution!="" && f_dt_parution!=null){
				vFtetl1DemandeCritere.f_dt_parution = new BigDecimal(f_dt_parution);
			}
			vFtetl1Demande.critere_select = vFtetl1DemandeCritere;
			vFtetl1.demande = vFtetl1Demande;
			
			jwftetl1.setNwftetl1Awftetl1 (vFtetl1);
			
		    // CALL SERVER
			System.out.println ("AVANT APPEL");
		    jwftetl1.nwftetl1();
			System.out.println ("APRES APPEL");
				                                
	        // Verification du code retour
			vWebent = jwftetl1.getNwftetl1Axwebent();
			System.out.println("Code retour nwftetl1() = " + vWebent.code_retour.intValue());
			
			if(vWebent.code_retour.intValue() != 0){
				for(int i=0; i < vWebent.nb_ano.intValue(); i++){
				   System.out.println(vWebent.t_ano[i].code_ano + "[" + vWebent.t_ano[i].type_ano + "] : '" + vWebent.t_ano[i].lib_ano.trim() + "'");
			   	   }
				}
			else {
				//Récupération du résultat si code retour OK
				Jwftetl1.Nwftetl1Awftetl1_tab vWeblsttab = jwftetl1.getNwftetl1Awftetl1_tab();
				
				//Affichage de la liste des résultats
				if(PRINT == "YES") {
					for(int i = 0; i < new BigDecimal(nbrep).intValue(); i++){
							//System.out.println ("CD_CIBLE=" + vWeblsttab.ligne_ref[i].cd_cible + ";LIB_CIBLE=" + vWeblsttab.ligne_ref[i].lib_cible + ";CD_TITRE=" + vWeblsttab.ligne_ref[i].cd_titre + ";LIB_TITRE=" + vWeblsttab.ligne_ref[i].lib_titre + ";CODE_ETAT=" + vWeblsttab.ligne_ref[i].code_etat + ";LIB_ETAT=" + vWeblsttab.ligne_ref[i].lib_etat.trim() + ";STATUT_ETAT=" + vWeblsttab.ligne_ref[i].statut_etat.trim() + ";CODE_FAMILLE=" + vWeblsttab.ligne_ref[i].code_famille.trim() + ";LIB_FAMILLE=" + vWeblsttab.ligne_ref[i].lib_famille.trim() + ";TRF_PC_DIR=" + vWeblsttab.ligne_ref[i].trf_pc_dir.trim() + ";NOM_FIC_PC=" + vWeblsttab.ligne_ref[i].nom_fic_pc.trim() );
							System.out.println ("ID_PDF=" + vWeblsttab.ligne_ref[i].id_pdf + ";STATUT_ETAT=" + vWeblsttab.ligne_ref[i].statut_etat.trim() + "K-PARUTION  =" + vWeblsttab.ligne_ref[i].k_parution+ " DT-PARUTION  =" + vWeblsttab.ligne_ref[i].dt_parution);
							System.out.println("\n");
					}
					//Affichage des informations de pagination
					System.out.println ("nb_rep_rendues : " + jwftetl1.getNwftetl1Axweblst().nb_rep_rendues);
					System.out.println ("num_page_rendue : " + jwftetl1.getNwftetl1Axweblst().num_page_rendue);
					System.out.println ("top_page_suivante : " + jwftetl1.getNwftetl1Axweblst().top_page_suivante);
					System.out.println ("nb_pages_totales : " + jwftetl1.getNwftetl1Axweblst().nb_pages_totales);
				}
			}
			return jwftetl1;
			
	    }
		// End getListeFtpEtat

		/**
		 * <p>Titre : main</p>
		 * <p>Description : Programme principal de tests</p>
		 * <p>Copyright : Copyright (c) 2011</p>
		 * <p>Societe : ENSOR</p>
		 * @author AR & DR <i>25/10/2011</i>
		 * @version 1.0
		 */
	   	public static void main(String[] args) throws BrokerException {
			Constantes.loadProperties("BW") ;
			JxweblogBw.setUtilisateur ("MADAA01");
			JxweblogBw.setPassword ("MADAAF1");
			PRINT = "YES";
			Broker broker 	  = JxweblogBw.logonBroker();
			Jxweblog jxweblog = JxweblogBw.getConnexion("50", "14", "SRV1", broker);

			Jxweblog.NxweblogAxwebent connexion = jxweblog.getNxweblogAxwebent();
			String groupe_exploitant = connexion.groupe_exploitant;
			String numero_session = Integer.toString(connexion.numero_session.intValue());
			String utilisateur = connexion.utilisateur;
			String cd_cible = connexion.cd_cible;
			String cd_stegrp = connexion.cd_stegrp;
			System.out.println ("groupe_exploitant=" + groupe_exploitant);
			System.out.println ("numero_session=" + numero_session);
			System.out.println ("utilisateur=" + utilisateur);
			System.out.println ("cd_cible=" + cd_cible);
			System.out.println ("cd_stegrp=" + cd_stegrp);
			
			Jwftetl1 jwftetl1 = getListeFtpEtat("20", "1", "I", null, null, null, null, null, null, "RULESBAN", null, null, groupe_exploitant, numero_session, utilisateur, cd_stegrp, cd_cible, "14", "SRV1", broker);
			
			JxweblogBw.closeConnexion ("SRV1", jxweblog, broker);
			
			JxweblogBw.closeBroker (broker);
	    }
}
// END Jwftetl1Php