PortletService.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.service.portlet;

  35. import fr.paris.lutece.portal.business.page.Page;
  36. import fr.paris.lutece.portal.business.page.PageHome;
  37. import fr.paris.lutece.portal.business.portlet.Portlet;
  38. import fr.paris.lutece.portal.business.user.AdminUser;
  39. import fr.paris.lutece.portal.service.page.IPageService;
  40. import fr.paris.lutece.portal.service.page.PageResourceIdService;
  41. import fr.paris.lutece.portal.service.spring.SpringContextService;

  42. import java.util.ArrayList;
  43. import java.util.Collection;

  44. /**
  45.  * class PortletService
  46.  */
  47. public final class PortletService
  48. {
  49.     private static PortletService _singleton;
  50.     private static IPageService _pageService = SpringContextService.getBean( "pageService" );

  51.     /**
  52.      * Constructor for class PortletService
  53.      *
  54.      */
  55.     private PortletService( )
  56.     {
  57.     }

  58.     /**
  59.      * Get the unique instance of the service
  60.      *
  61.      * @return The unique instance
  62.      */
  63.     public static synchronized PortletService getInstance( )
  64.     {
  65.         if ( _singleton == null )
  66.         {
  67.             _singleton = new PortletService( );
  68.         }

  69.         return _singleton;
  70.     }

  71.     /**
  72.      * Filter a collection of portlet associated to a given user
  73.      *
  74.      * @param collectionPortlet
  75.      *            the The collection to filter
  76.      * @param user
  77.      *            the current user
  78.      * @return a collection of portlet associated to a given user
  79.      */
  80.     public Collection<Portlet> getAuthorizedPortletCollection( Collection<Portlet> collectionPortlet, AdminUser user )
  81.     {
  82.         Collection<Portlet> collectionPortletAuthorized = new ArrayList<>( );

  83.         for ( Portlet portlet : collectionPortlet )
  84.         {
  85.             if ( _pageService.isAuthorizedAdminPage( portlet.getPageId( ), PageResourceIdService.PERMISSION_VIEW, user ) )
  86.             {
  87.                 collectionPortletAuthorized.add( portlet );
  88.             }
  89.         }

  90.         return collectionPortletAuthorized;
  91.     }

  92.     /**
  93.      * Check if a portlet should be visible to the user
  94.      *
  95.      * @param idPortlet
  96.      *            the id of the portlet
  97.      * @param user
  98.      *            the current user
  99.      * @return true if authorized, otherwise false
  100.      */
  101.     public boolean isAuthorized( int idPortlet, AdminUser user )
  102.     {
  103.         Page page = PageHome.getPageByIdPortlet( idPortlet );

  104.         return _pageService.isAuthorizedAdminPage( page.getId( ), PageResourceIdService.PERMISSION_VIEW, user );
  105.     }

  106.     /**
  107.      * Check if a portlet should be visible to the user
  108.      *
  109.      * @param portlet
  110.      *            the portlet
  111.      * @param user
  112.      *            the current user
  113.      * @return true if authorized, otherwise false
  114.      */
  115.     public boolean isAuthorized( Portlet portlet, AdminUser user )
  116.     {
  117.         Page page = PageHome.findByPrimaryKey( portlet.getPageId( ) );

  118.         return _pageService.isAuthorizedAdminPage( page.getId( ), PageResourceIdService.PERMISSION_VIEW, user );
  119.     }
  120. }