RunnableQueueItem.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.daemon;

  35. import fr.paris.lutece.portal.service.plugin.Plugin;
  36. import fr.paris.lutece.portal.service.util.AppLogService;

  37. /**
  38.  * Represents a runnable waiting to be launched by the {@link ThreadLauncherDaemon}
  39.  */
  40. public class RunnableQueueItem implements Runnable
  41. {
  42.     private Runnable _runnable;
  43.     private String _strKey;
  44.     private Plugin _plugin;

  45.     /**
  46.      * Creates a new {@link RunnableQueueItem}
  47.      *
  48.      * @param runnable
  49.      *            The runnable waiting to bet launched
  50.      * @param strKey
  51.      *            The key associated with the runnable. Runnables of a given plugin are ensured that they will not be executed at the same time if they have the
  52.      *            same key.
  53.      * @param plugin
  54.      *            The plugin associated with the runnable queue item
  55.      */
  56.     public RunnableQueueItem( Runnable runnable, String strKey, Plugin plugin )
  57.     {
  58.         this._runnable = runnable;
  59.         this._strKey = strKey;
  60.         this._plugin = plugin;
  61.     }

  62.     /**
  63.      * {@inheritDoc}
  64.      */
  65.     @Override
  66.     public void run( )
  67.     {
  68.         try
  69.         {
  70.             _runnable.run( );
  71.         }
  72.         catch( Exception e )
  73.         {
  74.             AppLogService.error( e.getMessage( ), e );
  75.         }
  76.     }

  77.     /**
  78.      * Get the runnable that is waiting for its execution
  79.      *
  80.      * @return The runnable
  81.      */
  82.     public Runnable getRunnable( )
  83.     {
  84.         return _runnable;
  85.     }

  86.     /**
  87.      * Get the key that identifies the runnable.
  88.      *
  89.      * @return the key of the runnable
  90.      */
  91.     public String getKey( )
  92.     {
  93.         return _strKey;
  94.     }

  95.     /**
  96.      * Get the plugin that created the runnable
  97.      *
  98.      * @return The plugin that created the runnable
  99.      */
  100.     public Plugin getPlugin( )
  101.     {
  102.         return _plugin;
  103.     }

  104.     /**
  105.      * Compute the key of the item from its plugin name and the declared key. The difference between the computed key and the defined key is that the computed
  106.      * key is unique, whereas the defined key is unique within a plugin.
  107.      *
  108.      * @return The computed key of this runnable item
  109.      */
  110.     protected String computeKey( )
  111.     {
  112.         if ( ( _strKey != null ) && ( _plugin != null ) )
  113.         {
  114.             return _plugin.getName( ) + _strKey;
  115.         }

  116.         return null;
  117.     }
  118. }