XslExportHome.java

  1. /*
  2.  * Copyright (c) 2002-2022, City of Paris
  3.  * All rights reserved.
  4.  *
  5.  * Redistribution and use in source and binary forms, with or without
  6.  * modification, are permitted provided that the following conditions
  7.  * are met:
  8.  *
  9.  *  1. Redistributions of source code must retain the above copyright notice
  10.  *     and the following disclaimer.
  11.  *
  12.  *  2. Redistributions in binary form must reproduce the above copyright notice
  13.  *     and the following disclaimer in the documentation and/or other materials
  14.  *     provided with the distribution.
  15.  *
  16.  *  3. Neither the name of 'Mairie de Paris' nor 'Lutece' nor the names of its
  17.  *     contributors may be used to endorse or promote products derived from
  18.  *     this software without specific prior written permission.
  19.  *
  20.  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
  21.  * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
  22.  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
  23.  * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDERS OR CONTRIBUTORS BE
  24.  * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
  25.  * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
  26.  * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
  27.  * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
  28.  * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
  29.  * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
  30.  * POSSIBILITY OF SUCH DAMAGE.
  31.  *
  32.  * License 1.0
  33.  */
  34. package fr.paris.lutece.portal.business.xsl;

  35. import fr.paris.lutece.portal.business.file.FileHome;
  36. import fr.paris.lutece.portal.service.html.XmlTransformerService;
  37. import fr.paris.lutece.portal.service.plugin.Plugin;
  38. import fr.paris.lutece.portal.service.spring.SpringContextService;
  39. import fr.paris.lutece.util.ReferenceList;

  40. import java.util.List;

  41. /**
  42.  * This class provides instances management methods (create, find, ...) for ExportFormat objects
  43.  */
  44. public final class XslExportHome
  45. {
  46.     // Static variable pointed at the DAO instance
  47.     private static IXslExportDAO _dao = SpringContextService.getBean( "xslExportDAO" );

  48.     /**
  49.      * Private constructor - this class do not need to be instantiated
  50.      */
  51.     private XslExportHome( )
  52.     {
  53.     }

  54.     /**
  55.      * Creation of an instance of Xsl Export
  56.      *
  57.      * @param xslExport
  58.      *            The instance of the xslExport which contains the informations to store
  59.      *
  60.      */
  61.     public static void create( XslExport xslExport )
  62.     {
  63.         _dao.insert( xslExport );
  64.     }

  65.     /**
  66.      * Update of the XslExport which is specified in parameter
  67.      *
  68.      * @param xslExport
  69.      *            The instance of the xslExport which contains the informations to update
  70.      */
  71.     public static void update( XslExport xslExport )
  72.     {
  73.         _dao.store( xslExport );
  74.         XmlTransformerService.clearXslCache( );
  75.     }

  76.     /**
  77.      * Remove the XslExport whose identifier is specified in parameter
  78.      *
  79.      * @param nIdXslExport
  80.      *            The XslExport Id
  81.      */
  82.     public static void remove( int nIdXslExport )
  83.     {
  84.         _dao.delete( nIdXslExport );
  85.         XmlTransformerService.clearXslCache( );
  86.     }

  87.     // /////////////////////////////////////////////////////////////////////////
  88.     // Finders

  89.     /**
  90.      * Returns an instance of a XslExport whose identifier is specified in parameter
  91.      *
  92.      * @param nKey
  93.      *            The xslExport primary key
  94.      * @return an instance of XslExport
  95.      */
  96.     public static XslExport findByPrimaryKey( int nKey )
  97.     {
  98.         XslExport xslExport = _dao.load( nKey );

  99.         if ( ( xslExport != null ) && ( xslExport.getFile( ) != null ) )
  100.         {
  101.             xslExport.setFile( FileHome.findByPrimaryKey( xslExport.getFile( ).getIdFile( ) ) );
  102.         }

  103.         return xslExport;
  104.     }

  105.     /**
  106.      * Loads the data of all the XslExport and returns them in a list
  107.      *
  108.      * @return the list which contains the data of every Xsl export items
  109.      */
  110.     public static List<XslExport> getList( )
  111.     {
  112.         return _dao.selectList( );
  113.     }

  114.     /**
  115.      * Loads the data of XslExport associated with a given plugin and returns them in a list
  116.      *
  117.      * @param plugin
  118.      *            The plugin
  119.      * @return the list which contains the data of Xsl export items
  120.      */
  121.     public static List<XslExport> getListByPlugin( Plugin plugin )
  122.     {
  123.         return _dao.selectListByPlugin( plugin );
  124.     }

  125.     /**
  126.      * Loads in the reference list the data of all the XslExport and returns them in a list
  127.      *
  128.      * @return the list which contains the data of every Xsl Export items
  129.      */
  130.     public static ReferenceList getRefList( )
  131.     {
  132.         ReferenceList refList = new ReferenceList( );

  133.         List<XslExport> xslList = getList( );

  134.         for ( XslExport xslExport : xslList )
  135.         {
  136.             refList.addItem( xslExport.getIdXslExport( ), xslExport.getTitle( ) );
  137.         }

  138.         return refList;
  139.     }

  140.     /**
  141.      * Loads the data of XslExport associated with a given plugin and returns them in a list
  142.      *
  143.      * @param plugin
  144.      *            The plugin
  145.      * @return the list which contains the data of Xsl export items
  146.      */
  147.     public static ReferenceList getRefListByPlugin( Plugin plugin )
  148.     {
  149.         ReferenceList refList = new ReferenceList( );

  150.         List<XslExport> xslList = getListByPlugin( plugin );

  151.         for ( XslExport xslExport : xslList )
  152.         {
  153.             refList.addItem( xslExport.getIdXslExport( ), xslExport.getTitle( ) );
  154.         }

  155.         return refList;
  156.     }
  157. }