JobSchedulerService.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.scheduler;

  35. import fr.paris.lutece.portal.service.util.AppLogService;

  36. import org.quartz.CronTrigger;
  37. import org.quartz.JobDetail;
  38. import org.quartz.Scheduler;
  39. import org.quartz.SchedulerException;
  40. import org.quartz.SchedulerFactory;

  41. import org.quartz.impl.StdSchedulerFactory;

  42. import java.util.Date;

  43. /**
  44.  * JobSchedulerService
  45.  */
  46. public final class JobSchedulerService
  47. {
  48.     private static JobSchedulerService _singleton;
  49.     private static Scheduler _scheduler;

  50.     /** Creates a new instance of JobSchedulerService */
  51.     private JobSchedulerService( )
  52.     {
  53.         init( );
  54.     }

  55.     /**
  56.      * Gets the unique instance of the service
  57.      *
  58.      * @return The service's instance
  59.      */
  60.     public static synchronized JobSchedulerService getInstance( )
  61.     {
  62.         if ( _singleton == null )
  63.         {
  64.             _singleton = new JobSchedulerService( );
  65.         }

  66.         return _singleton;
  67.     }

  68.     /**
  69.      * Initialize the service.
  70.      */
  71.     private void init( )
  72.     {
  73.         SchedulerFactory factory = new StdSchedulerFactory( );

  74.         try
  75.         {
  76.             _scheduler = factory.getScheduler( );
  77.             _scheduler.start( );
  78.             AppLogService.info( "Lutece job scheduler started." );
  79.         }
  80.         catch( SchedulerException e )
  81.         {
  82.             AppLogService.error( "Error starting the Lutece job scheduler ", e );
  83.         }
  84.     }

  85.     /**
  86.      * Schedule a job according cron information
  87.      *
  88.      * @param job
  89.      *            The Job to schedule
  90.      * @param trigger
  91.      *            The Cron trigger
  92.      * @return Date
  93.      */
  94.     public Date scheduleJob( JobDetail job, CronTrigger trigger )
  95.     {
  96.         Date date = null;

  97.         if ( _scheduler != null )
  98.         {
  99.             try
  100.             {
  101.                 date = _scheduler.scheduleJob( job, trigger );
  102.                 AppLogService.info( "New job scheduled : {}", job.getKey( ).getName( ) );
  103.             }
  104.             catch( SchedulerException e )
  105.             {
  106.                 AppLogService.error( "Error scheduling job {}", job.getKey( ).getName( ), e );
  107.             }
  108.         }

  109.         return date;
  110.     }

  111.     /**
  112.      * Shutdown the service (Called by the core while the webapp is destroyed)
  113.      */
  114.     public static void shutdown( )
  115.     {
  116.         if ( _scheduler != null )
  117.         {
  118.             try
  119.             {
  120.                 _scheduler.shutdown( );
  121.                 AppLogService.info( "Lutece job scheduler stopped." );
  122.             }
  123.             catch( SchedulerException e )
  124.             {
  125.                 AppLogService.error( "Error shuting down the Lutece job scheduler ", e );
  126.             }
  127.         }
  128.     }
  129. }