org.drools.persistence.jpa.JpaJDKTimerService Maven / Gradle / Ivy
/*
* Copyright 2010 Red Hat, Inc. and/or its affiliates.
*
* Licensed under the Apache License, Version 2.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.apache.org/licenses/LICENSE-2.0
*
* 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 org.drools.persistence.jpa;
import org.kie.api.runtime.ExecutableRunner;
import org.drools.core.command.impl.ExecutableCommand;
import org.drools.core.time.InternalSchedulerService;
import org.drools.core.time.Job;
import org.drools.core.time.JobContext;
import org.drools.core.time.SelfRemovalJob;
import org.drools.core.time.SelfRemovalJobContext;
import org.drools.core.time.Trigger;
import org.drools.core.time.impl.DefaultTimerJobInstance;
import org.drools.core.time.impl.JDKTimerService;
import org.drools.core.time.impl.TimerJobInstance;
import org.kie.api.runtime.Context;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import java.util.Collection;
import java.util.Map;
import java.util.concurrent.Callable;
import java.util.concurrent.ConcurrentHashMap;
/**
* A default Scheduler implementation that uses the
* JDK built-in ScheduledThreadPoolExecutor as the
* scheduler and the system clock as the clock.
*/
public class JpaJDKTimerService extends JDKTimerService {
private static Logger logger = LoggerFactory.getLogger( JpaTimerJobInstance.class );
private ExecutableRunner runner;
private Map timerInstances;
public void setCommandService(ExecutableRunner runner ) {
this.runner = runner;
}
public JpaJDKTimerService() {
this( 1 );
timerInstances = new ConcurrentHashMap();
}
public JpaJDKTimerService(int size) {
super( size );
timerInstances = new ConcurrentHashMap();
}
protected Callable createCallableJob(Job job,
JobContext ctx,
Trigger trigger,
JDKJobHandle handle,
InternalSchedulerService scheduler) {
JpaJDKCallableJob jobInstance = new JpaJDKCallableJob( new SelfRemovalJob( job ),
new SelfRemovalJobContext( ctx,
timerInstances ),
trigger,
handle,
scheduler );
this.timerInstances.put( handle.getId(),
jobInstance );
return jobInstance;
}
public Collection getTimerJobInstances() {
return timerInstances.values();
}
public class JpaJDKCallableJob extends DefaultTimerJobInstance {
public JpaJDKCallableJob(Job job,
JobContext ctx,
Trigger trigger,
JDKJobHandle handle,
InternalSchedulerService scheduler) {
super( job,
ctx,
trigger,
handle,
scheduler );
}
public Void call() throws Exception {
try {
JDKCallableJobCommand command = new JDKCallableJobCommand( this );
runner.execute( command );
} catch(Exception e ) {
logger.error("Unable to execute job!", e);
throw e;
}
return null;
}
private Void internalCall() throws Exception {
return super.call();
}
}
public static class JDKCallableJobCommand
implements
ExecutableCommand {
private static final long serialVersionUID = 4L;
private JpaJDKCallableJob job;
public JDKCallableJobCommand(JpaJDKCallableJob job) {
this.job = job;
}
public Void execute(Context context) {
try {
return job.internalCall();
} catch ( Exception e ) {
e.printStackTrace();
}
return null;
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy