/**
*
* Copyright
* 2009-2015 Jayway Products AB
* 2016-2017 Föreningen Sambruk
*
* Licensed under AGPL, Version 3.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.gnu.org/licenses/agpl.txt
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package se.streamsource.streamflow.web.application.archival;
import org.qi4j.api.configuration.Configuration;
import org.qi4j.api.injection.scope.Service;
import org.qi4j.api.injection.scope.This;
import org.qi4j.api.mixin.Mixins;
import org.qi4j.api.service.Activatable;
import org.qi4j.api.service.ServiceComposite;
import org.quartz.JobDetail;
import org.quartz.Trigger;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import se.streamsource.streamflow.web.infrastructure.scheduler.QuartzSchedulerService;
import static org.quartz.CronScheduleBuilder.cronSchedule;
import static org.quartz.JobBuilder.newJob;
import static org.quartz.TriggerBuilder.newTrigger;
/**
* TODO
*/
@Mixins(ArchivalService.Mixin.class)
public interface ArchivalService
extends ServiceComposite, Configuration<ArchivalConfiguration>, Activatable
{
abstract class Mixin
implements ArchivalService, Activatable
{
@Service
QuartzSchedulerService scheduler;
private JobDetail startJob;
private JobDetail stopJob;
@This
Configuration<ArchivalConfiguration> config;
Logger logger = LoggerFactory.getLogger(ArchivalService.class);
public void activate() throws Exception
{
if (config.configuration().enabled().get())
{
try
{
startJob = newJob( ArchivalStartJob.class ).withIdentity( "archivalstartjob", "archivalgroup" ).build();
stopJob = newJob( ArchivalStopJob.class ).withIdentity( "archivalstopjob", "archivalgroup").build();
if( config.configuration().startScheduledArchival().get() )
{
Trigger startTrigger = newTrigger().withIdentity( "archivalstart", "archivalgroup" ).startNow()
.withSchedule(cronSchedule(config.configuration().startSchedule().get())).build();
Trigger stopTrigger = newTrigger().withIdentity("archivalstop", "archivalgroup" ).startNow()
.withSchedule( cronSchedule( config.configuration().stopSchedule().get())).build();
scheduler.scheduleJob(startJob, startTrigger );
scheduler.scheduleJob( stopJob, stopTrigger );
}
} catch ( Exception e )
{
startJob = null;
stopJob = null;
logger.error( "Unable to start ArchivalService: " + e.getMessage() );
}
if( config.configuration().startScheduledArchival().get() )
{
logger.info( "Start activated: " + config.configuration().startSchedule().get() );
logger.info( "Stop activated: " + config.configuration().stopSchedule().get() );
} else
{
logger.info( "Activated: Manual mode only. " );
}
}
}
public void passivate() throws Exception
{
if( scheduler != null )
{
if( startJob != null )
{
scheduler.deleteJob(startJob.getKey());
}
if( stopJob != null )
{
scheduler.deleteJob( stopJob.getKey() );
}
}
logger.info( "Passivated" );
}
}
}