AliasPortlet.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 fr.paris.lutece.portal.service.message.SiteMessageException;
  36. import fr.paris.lutece.util.xml.XmlUtil;

  37. import java.util.Map;

  38. import javax.servlet.http.HttpServletRequest;

  39. /**
  40.  * This class represents business objects AliasPortlet
  41.  */
  42. public class AliasPortlet extends Portlet
  43. {
  44.     // ///////////////////////////////////////////////////////////////////////////////
  45.     // Constants
  46.     private int _nAliasId;

  47.     /**
  48.      * Sets the identifier of the portlet type to the value specified in the AliasPortletHome class
  49.      */
  50.     public AliasPortlet( )
  51.     {
  52.         setPortletTypeId( AliasPortletHome.getInstance( ).getPortletTypeId( ) );
  53.     }

  54.     /**
  55.      * Sets the alias identifier of the portlet with the specified int value
  56.      *
  57.      * @param nAliasId
  58.      *            the Alias identifier
  59.      */
  60.     public void setAliasId( int nAliasId )
  61.     {
  62.         _nAliasId = nAliasId;
  63.     }

  64.     /**
  65.      * Returns the alias identifier of the portlet
  66.      *
  67.      * @return the Alias identifier
  68.      */
  69.     public int getAliasId( )
  70.     {
  71.         return _nAliasId;
  72.     }

  73.     /**
  74.      * {@inheritDoc}
  75.      */
  76.     @Override
  77.     public boolean isContentGeneratedByXmlAndXsl( )
  78.     {
  79.         Portlet portletParent = PortletHome.findByPrimaryKey( getAliasId( ) );
  80.         return portletParent.isContentGeneratedByXmlAndXsl( );
  81.     }

  82.     /**
  83.      * Returns the html content code of the Alias portlet
  84.      *
  85.      * @param request
  86.      *            The HTTP servlet request
  87.      * @return the Html content code of the Alias portlet content
  88.      */
  89.     @Override
  90.     public String getHtmlContent( HttpServletRequest request )
  91.     {
  92.         Portlet portlet = PortletHome.findByPrimaryKey( getAliasId( ) );
  93.         return portlet.getHtmlContent( request );
  94.     }

  95.     /**
  96.      * Returns the Xml code of the Alias portlet without XML heading
  97.      *
  98.      * @param request
  99.      *            The HTTP servlet request
  100.      * @return the Xml code of the Alias portlet content
  101.      * @throws SiteMessageException
  102.      *             occurs when a site message need to be displayed
  103.      */
  104.     public String getXml( HttpServletRequest request ) throws SiteMessageException
  105.     {
  106.         // gets the portlet parent
  107.         Portlet portlet = PortletHome.findByPrimaryKey( getAliasId( ) );
  108.         String strXmlAlias = portlet.getXml( request );
  109.         String strTagPortletName = "</" + TAG_PORTLET_NAME + ">";
  110.         int indexDeb = strXmlAlias.indexOf( strTagPortletName );
  111.         int indexFin = strXmlAlias.indexOf( "</" + TAG_PORTLET + ">" );
  112.         strXmlAlias = strXmlAlias.substring( indexDeb + strTagPortletName.length( ), indexFin );

  113.         StringBuffer buffXml = new StringBuffer( );
  114.         XmlUtil.beginElement( buffXml, TAG_PORTLET );
  115.         XmlUtil.addElement( buffXml, TAG_PORTLET_NAME, getName( ) );
  116.         buffXml.append( strXmlAlias );
  117.         XmlUtil.endElement( buffXml, TAG_PORTLET );

  118.         return buffXml.toString( );
  119.     }

  120.     /**
  121.      * Returns the Xml code of the Alias portlet with XML heading
  122.      *
  123.      * @param request
  124.      *            The HTTP Servlet request
  125.      * @return the Xml code of the Alias portlet
  126.      * @throws SiteMessageException
  127.      *             occurs when a site message need to be displayed
  128.      */
  129.     public String getXmlDocument( HttpServletRequest request ) throws SiteMessageException
  130.     {
  131.         return XmlUtil.getXmlHeader( ) + getXml( request );
  132.     }

  133.     /**
  134.      * Gets the XSl parameters of the alias portlet and returns them in form of a dictionnary
  135.      *
  136.      * @return the Xsl params
  137.      */
  138.     @Override
  139.     public Map<String, String> getXslParams( )
  140.     {

  141.         // gets the portlet parent
  142.         Portlet portlet = PortletHome.findByPrimaryKey( getAliasId( ) );

  143.         return portlet.getXslParams( );
  144.     }

  145.     /**
  146.      * Updates the current instance of the AliasPortlet object
  147.      */
  148.     public void update( )
  149.     {
  150.         AliasPortletHome.getInstance( ).update( this );
  151.     }

  152.     /**
  153.      * Removes the current instance of the AliasPortlet object
  154.      */
  155.     public void remove( )
  156.     {
  157.         AliasPortletHome.getInstance( ).remove( this );
  158.     }

  159. }