AliasPortletHome.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.portlet;

  35. import java.util.Collection;

  36. import fr.paris.lutece.portal.service.spring.SpringContextService;
  37. import fr.paris.lutece.util.ReferenceList;

  38. /**
  39.  * This class provides instances management methods for AliasPortlet objects
  40.  */
  41. public class AliasPortletHome extends PortletHome
  42. {
  43.     // ///////////////////////////////////////////////////////////////////////////////
  44.     // Constants
  45.     // Static variable pointed at the DAO instance
  46.     private static IAliasPortletDAO _dao = SpringContextService.getBean( "aliasPortletDAO" );

  47.     /** This class implements the Singleton design pattern. */
  48.     private static AliasPortletHome _singleton;

  49.     /**
  50.      * Constructor
  51.      */
  52.     protected AliasPortletHome( )
  53.     {
  54.         if ( _singleton == null )
  55.         {
  56.             _singleton = this;
  57.         }
  58.     }

  59.     /**
  60.      * Returns the identifier of the alias portlet type
  61.      *
  62.      * @return the portlet type identifier
  63.      */
  64.     public String getPortletTypeId( )
  65.     {
  66.         String strCurrentClassName = this.getClass( ).getName( );
  67.         return PortletTypeHome.getPortletTypeId( strCurrentClassName );
  68.     }

  69.     /**
  70.      * Returns the instance of AliasPortletHome
  71.      *
  72.      * @return the AliasPortletHome instance
  73.      */
  74.     public static synchronized PortletHome getInstance( )
  75.     {
  76.         if ( _singleton == null )
  77.         {
  78.             _singleton = new AliasPortletHome( );
  79.         }
  80.         return _singleton;
  81.     }

  82.     /**
  83.      * Returns the instance of the FolderListingPortletDAO singleton
  84.      *
  85.      * @return the instance of the FolderListingPortletDAO
  86.      */
  87.     public IPortletInterfaceDAO getDAO( )
  88.     {
  89.         return _dao;
  90.     }

  91.     /**
  92.      * Returns the portlet alias identifier of the portlet whose identifier is specified in parameter
  93.      *
  94.      * @param nIdPortlet
  95.      *            the identifier of the portlet
  96.      * @return the identifier of the alias portlet
  97.      */
  98.     public static int getAliasId( int nIdPortlet )
  99.     {
  100.         return _dao.selectAliasId( nIdPortlet );
  101.     }

  102.     /**
  103.      * Returns the Reference list of the portlets which accept an alias
  104.      *
  105.      * @return the list of the portlets in form of ReferenceList
  106.      */
  107.     public static ReferenceList getAcceptAliasPortletRefList( )
  108.     {
  109.         return _dao.selectAcceptAliasPortletRefList( );
  110.     }

  111.     /**
  112.      * Returns the list of the portlets which accept an alias
  113.      *
  114.      * @return the list of the portlets
  115.      */
  116.     public static Collection<Portlet> getAcceptAliasPortletList( )
  117.     {
  118.         return _dao.selectAcceptAliasPortletList( );
  119.     }

  120.     /**
  121.      * Loads the list of the portlets whose type is the same as the one specified in parameter
  122.      *
  123.      * @param strPortletTypeId
  124.      *            the portlet type identifier
  125.      * @return the list of the portlets in form of a ReferenceList
  126.      */
  127.     public static ReferenceList getPortletsByTypeList( String strPortletTypeId )
  128.     {
  129.         return _dao.selectPortletsByTypeList( strPortletTypeId );
  130.     }
  131. }