use of org.pentaho.platform.api.scheduler2.IJobTrigger in project pentaho-platform by pentaho.
the class PentahoBlockoutManager method getBlockOut.
@Override
public IJobTrigger getBlockOut(String blockOutJobId) {
try {
Job blockOutJob = this.scheduler.getJob(blockOutJobId);
IJobTrigger blockOutJobTrigger = blockOutJob.getJobTrigger();
blockOutJobTrigger.setDuration(((Number) blockOutJob.getJobParams().get(DURATION_PARAM)).longValue());
return blockOutJobTrigger;
} catch (SchedulerException e) {
throw new RuntimeException(e);
}
}
use of org.pentaho.platform.api.scheduler2.IJobTrigger in project pentaho-platform by pentaho.
the class ActionAdapterQuartzJob method invokeAction.
/**
* Invokes the {@link IAction} bean that is created from the provided {@code actionClassName} and {@code actionId} as
* the provided {@code actionUser}. If the {@code IAction} execution fails as-is, the scheduler attempts to re-create
* the job that will try to invoke the {@link IAction} again.
*
* @param actionClassName The class name of the {@link IAction} bean; used as a backup, if the {@code actionId} is not
* available or vald
* @param actionId The bean id of the {@link IAction} requested to be invoked.
* @param actionUser The user invoking the {@link IAction}
* @param context the {@code JobExecutionContext}
* @param params the {@link Map} or parameters needed to invoke the {@link IAction}
* @throws Exception when the {@code IAction} cannot be invoked for some reason.
*/
protected void invokeAction(final String actionClassName, final String actionId, final String actionUser, final JobExecutionContext context, final Map<String, Serializable> params) throws Exception {
final String workItemUid = ActionUtil.extractUid(params);
WorkItemLifecycleEventUtil.publish(workItemUid, params, WorkItemLifecyclePhase.SUBMITTED);
// creates an instance of IActionInvoker, which knows how to invoke this IAction - if the IActionInvoker bean is
// not defined through spring, fall back on the default action invoker
final IActionInvoker actionInvoker = Optional.ofNullable(PentahoSystem.get(IActionInvoker.class)).orElse(getActionInvoker());
// Instantiate the requested IAction bean
final IAction actionBean = (IAction) ActionUtil.createActionBean(actionClassName, actionId);
if (actionInvoker == null || actionBean == null) {
final String failureMessage = Messages.getInstance().getErrorString(// $NON-NLS-1$
"ActionAdapterQuartzJob.ERROR_0002_FAILED_TO_CREATE_ACTION", getActionIdentifier(null, actionClassName, actionId), StringUtil.getMapAsPrettyString(params));
WorkItemLifecycleEventUtil.publish(workItemUid, params, WorkItemLifecyclePhase.FAILED, failureMessage);
throw new LoggingJobExecutionException(failureMessage);
}
if (actionBean instanceof BlockoutAction) {
params.put(IBlockoutManager.SCHEDULED_FIRE_TIME, context.getScheduledFireTime());
}
// Invoke the action and get the status of the invocation
final IActionInvokeStatus status = actionInvoker.invokeAction(actionBean, actionUser, getSerializableMap(params));
// Status may not be available for remote execution, which is expected
if (status == null) {
if (log.isWarnEnabled()) {
log.warn(Messages.getInstance().getErrorString(// $NON-NLS-1$
"ActionAdapterQuartzJob.WARN_0002_NO_STATUS", getActionIdentifier(actionBean, actionClassName, actionId), StringUtil.getMapAsPrettyString(params)));
}
return;
}
// exception
if (!status.isExecutionSuccessful()) {
// throw job exception
throw new JobExecutionException(Messages.getInstance().getActionFailedToExecute(// $NON-NLS-1$
actionBean.getClass().getName()));
}
final boolean requiresUpdate = status.requiresUpdate();
final Throwable throwable = status.getThrowable();
Object objsp = status.getStreamProvider();
IBackgroundExecutionStreamProvider sp = null;
if (objsp != null && IBackgroundExecutionStreamProvider.class.isAssignableFrom(objsp.getClass())) {
sp = (IBackgroundExecutionStreamProvider) objsp;
}
final IBackgroundExecutionStreamProvider streamProvider = sp;
// shallow copy
final Map<String, Serializable> jobParams = new HashMap<String, Serializable>(params);
final IScheduler scheduler = PentahoSystem.getObjectFactory().get(IScheduler.class, "IScheduler2", null);
if (throwable != null) {
Object restartFlag = jobParams.get(QuartzScheduler.RESERVEDMAPKEY_RESTART_FLAG);
if (restartFlag == null) {
final SimpleJobTrigger trigger = new SimpleJobTrigger(new Date(), null, 0, 0);
final Class<IAction> iaction = (Class<IAction>) actionBean.getClass();
// recreate the job in the context of the original creator
SecurityHelper.getInstance().runAsUser(actionUser, new Callable<Void>() {
@Override
public Void call() throws Exception {
if (streamProvider != null) {
// remove generated content
streamProvider.setStreamingAction(null);
}
QuartzJobKey jobKey = QuartzJobKey.parse(context.getJobDetail().getName());
String jobName = jobKey.getJobName();
jobParams.put(QuartzScheduler.RESERVEDMAPKEY_RESTART_FLAG, Boolean.TRUE);
WorkItemLifecycleEventUtil.publish(workItemUid, params, WorkItemLifecyclePhase.RESTARTED);
scheduler.createJob(jobName, iaction, jobParams, trigger, streamProvider);
log.warn("New RunOnce job created for " + jobName + " -> possible startup synchronization error");
return null;
}
});
} else {
log.warn("RunOnce already created, skipping");
}
throw new JobExecutionException(throwable);
}
scheduler.fireJobCompleted(actionBean, actionUser, params, streamProvider);
if (requiresUpdate) {
log.warn("Output path for job: " + context.getJobDetail().getName() + " has changed. Job requires update");
try {
final IJobTrigger trigger = scheduler.getJob(context.getJobDetail().getName()).getJobTrigger();
final Class<IAction> iaction = (Class<IAction>) actionBean.getClass();
// remove job with outdated/invalid output path
scheduler.removeJob(context.getJobDetail().getName());
// recreate the job in the context of the original creator
SecurityHelper.getInstance().runAsUser(actionUser, new Callable<Void>() {
@Override
public Void call() throws Exception {
// remove generated content
streamProvider.setStreamingAction(null);
QuartzJobKey jobKey = QuartzJobKey.parse(context.getJobDetail().getName());
String jobName = jobKey.getJobName();
WorkItemLifecycleEventUtil.publish(workItemUid, params, WorkItemLifecyclePhase.RESTARTED);
org.pentaho.platform.api.scheduler2.Job j = scheduler.createJob(jobName, iaction, jobParams, trigger, streamProvider);
log.warn("New Job: " + j.getJobId() + " created");
return null;
}
});
} catch (Exception e) {
log.error(e.getMessage(), e);
}
}
if (log.isDebugEnabled()) {
log.debug(MessageFormat.format("Scheduling system successfully invoked action {0} as user {1} with params [ {2} ]", // $NON-NLS-1$
actionBean.getClass().getName(), actionUser, QuartzScheduler.prettyPrintMap(params)));
}
}
use of org.pentaho.platform.api.scheduler2.IJobTrigger in project pentaho-platform by pentaho.
the class QuartzScheduler method updateJob.
@Override
public void updateJob(String jobId, Map<String, Serializable> jobParams, IJobTrigger trigger) throws SchedulerException {
QuartzJobKey jobKey = QuartzJobKey.parse(jobId);
Trigger quartzTrigger = createQuartzTrigger(trigger, jobKey);
quartzTrigger.setJobName(jobId);
quartzTrigger.setJobGroup(jobKey.getUserName());
Calendar triggerCalendar = quartzTrigger instanceof CronTrigger ? createQuartzCalendar((ComplexJobTrigger) trigger) : null;
try {
Scheduler scheduler = getQuartzScheduler();
// int triggerState = scheduler.getTriggerState(jobId, jobKey.getUserName());
// if (triggerState != Trigger.STATE_PAUSED) {
// scheduler.pauseTrigger(jobId, jobKey.getUserName());
// }
JobDetail origJobDetail = scheduler.getJobDetail(jobId, jobKey.getUserName());
if (origJobDetail.getJobDataMap().containsKey(RESERVEDMAPKEY_ACTIONCLASS)) {
jobParams.put(RESERVEDMAPKEY_ACTIONCLASS, origJobDetail.getJobDataMap().get(RESERVEDMAPKEY_ACTIONCLASS).toString());
} else if (origJobDetail.getJobDataMap().containsKey(RESERVEDMAPKEY_ACTIONID)) {
jobParams.put(RESERVEDMAPKEY_ACTIONID, origJobDetail.getJobDataMap().get(RESERVEDMAPKEY_ACTIONID).toString());
}
if (origJobDetail.getJobDataMap().containsKey(RESERVEDMAPKEY_STREAMPROVIDER)) {
jobParams.put(RESERVEDMAPKEY_STREAMPROVIDER, (Serializable) origJobDetail.getJobDataMap().get(RESERVEDMAPKEY_STREAMPROVIDER));
}
if (origJobDetail.getJobDataMap().containsKey(RESERVEDMAPKEY_UIPASSPARAM)) {
jobParams.put(RESERVEDMAPKEY_UIPASSPARAM, (Serializable) origJobDetail.getJobDataMap().get(RESERVEDMAPKEY_UIPASSPARAM));
}
JobDetail jobDetail = createJobDetails(jobKey, jobParams);
scheduler.addJob(jobDetail, true);
if (triggerCalendar != null) {
scheduler.addCalendar(jobId.toString(), triggerCalendar, true, true);
quartzTrigger.setCalendarName(jobId.toString());
}
scheduler.rescheduleJob(jobId, jobKey.getUserName(), quartzTrigger);
// if (triggerState != Trigger.STATE_PAUSED) {
// scheduler.resumeTrigger(jobId, jobKey.getUserName());
// }
logger.debug(MessageFormat.format("Scheduling job {0} with trigger {1} and job parameters [ {2} ]", jobId.toString(), trigger, // $NON-NLS-1$
prettyPrintMap(jobParams)));
} catch (org.quartz.SchedulerException e) {
throw new SchedulerException(Messages.getInstance().getString("QuartzScheduler.ERROR_0001_FAILED_TO_SCHEDULE_JOB", jobKey.getJobName()), // $NON-NLS-1$
e);
}
}
use of org.pentaho.platform.api.scheduler2.IJobTrigger in project pentaho-platform by pentaho.
the class QuartzScheduler method createJob.
/**
* {@inheritDoc}
*/
protected Job createJob(String jobName, Map<String, Serializable> jobParams, IJobTrigger trigger, IBackgroundExecutionStreamProvider outputStreamProvider) throws SchedulerException {
String curUser = getCurrentUser();
// determine if the job params tell us who owns the job
Serializable jobOwner = jobParams.get(RESERVEDMAPKEY_ACTIONUSER);
if (jobOwner != null && jobOwner.toString().length() > 0) {
curUser = jobOwner.toString();
}
QuartzJobKey jobId = new QuartzJobKey(jobName, curUser);
Trigger quartzTrigger = createQuartzTrigger(trigger, jobId);
if (trigger.getEndTime() != null) {
quartzTrigger.setEndTime(trigger.getEndTime());
}
Calendar triggerCalendar = quartzTrigger instanceof CronTrigger ? createQuartzCalendar((ComplexJobTrigger) trigger) : null;
if (outputStreamProvider != null) {
jobParams.put(RESERVEDMAPKEY_STREAMPROVIDER, outputStreamProvider);
}
if (trigger.getUiPassParam() != null) {
jobParams.put(RESERVEDMAPKEY_UIPASSPARAM, trigger.getUiPassParam());
}
if (!jobParams.containsKey(RESERVEDMAPKEY_LINEAGE_ID)) {
String uuid = UUID.randomUUID().toString();
jobParams.put(RESERVEDMAPKEY_LINEAGE_ID, uuid);
}
JobDetail jobDetail = createJobDetails(jobId, jobParams);
try {
Scheduler scheduler = getQuartzScheduler();
if (triggerCalendar != null) {
scheduler.addCalendar(jobId.toString(), triggerCalendar, false, false);
quartzTrigger.setCalendarName(jobId.toString());
}
logger.debug(MessageFormat.format("Scheduling job {0} with trigger {1} and job parameters [ {2} ]", jobId.toString(), trigger, // $NON-NLS-1$
prettyPrintMap(jobParams)));
scheduler.scheduleJob(jobDetail, quartzTrigger);
} catch (org.quartz.SchedulerException e) {
throw new SchedulerException(Messages.getInstance().getString("QuartzScheduler.ERROR_0001_FAILED_TO_SCHEDULE_JOB", jobName), // $NON-NLS-1$
e);
}
Job job = new Job();
job.setJobParams(jobParams);
job.setJobTrigger((JobTrigger) trigger);
job.setNextRun(quartzTrigger.getNextFireTime());
job.setLastRun(quartzTrigger.getPreviousFireTime());
job.setJobId(jobId.toString());
job.setJobName(jobName);
job.setUserName(curUser);
job.setState(JobState.NORMAL);
return job;
}
use of org.pentaho.platform.api.scheduler2.IJobTrigger in project pentaho-platform by pentaho.
the class SchedulerResourceUtil method convertScheduleRequestToJobTrigger.
public static IJobTrigger convertScheduleRequestToJobTrigger(JobScheduleRequest scheduleRequest, IScheduler scheduler) throws SchedulerException, UnifiedRepositoryException {
// Used to determine if created by a RunInBackgroundCommand
boolean runInBackground = scheduleRequest.getSimpleJobTrigger() == null && scheduleRequest.getComplexJobTrigger() == null && scheduleRequest.getCronJobTrigger() == null;
// add 10 seconds to the RIB to ensure execution (see PPP-3264)
IJobTrigger jobTrigger = runInBackground ? new SimpleJobTrigger(new Date(System.currentTimeMillis() + 10000), null, 0, 0) : scheduleRequest.getSimpleJobTrigger();
if (scheduleRequest.getSimpleJobTrigger() != null) {
SimpleJobTrigger simpleJobTrigger = scheduleRequest.getSimpleJobTrigger();
if (simpleJobTrigger.getStartTime() == null) {
simpleJobTrigger.setStartTime(new Date());
}
jobTrigger = simpleJobTrigger;
} else if (scheduleRequest.getComplexJobTrigger() != null) {
ComplexJobTriggerProxy proxyTrigger = scheduleRequest.getComplexJobTrigger();
ComplexJobTrigger complexJobTrigger = new ComplexJobTrigger();
complexJobTrigger.setStartTime(proxyTrigger.getStartTime());
complexJobTrigger.setEndTime(proxyTrigger.getEndTime());
complexJobTrigger.setDuration(scheduleRequest.getDuration());
if (proxyTrigger.getDaysOfWeek().length > 0) {
if (proxyTrigger.getWeeksOfMonth().length > 0) {
for (int dayOfWeek : proxyTrigger.getDaysOfWeek()) {
for (int weekOfMonth : proxyTrigger.getWeeksOfMonth()) {
QualifiedDayOfWeek qualifiedDayOfWeek = new QualifiedDayOfWeek();
qualifiedDayOfWeek.setDayOfWeek(DayOfWeek.values()[dayOfWeek]);
if (weekOfMonth == JobScheduleRequest.LAST_WEEK_OF_MONTH) {
qualifiedDayOfWeek.setQualifier(DayOfWeekQualifier.LAST);
} else {
qualifiedDayOfWeek.setQualifier(DayOfWeekQualifier.values()[weekOfMonth]);
}
complexJobTrigger.addDayOfWeekRecurrence(qualifiedDayOfWeek);
}
}
} else {
for (int dayOfWeek : proxyTrigger.getDaysOfWeek()) {
complexJobTrigger.addDayOfWeekRecurrence(dayOfWeek + 1);
}
}
} else if (proxyTrigger.getDaysOfMonth().length > 0) {
for (int dayOfMonth : proxyTrigger.getDaysOfMonth()) {
complexJobTrigger.addDayOfMonthRecurrence(dayOfMonth);
}
}
for (int month : proxyTrigger.getMonthsOfYear()) {
complexJobTrigger.addMonthlyRecurrence(month + 1);
}
for (int year : proxyTrigger.getYears()) {
complexJobTrigger.addYearlyRecurrence(year);
}
Calendar calendar = Calendar.getInstance();
calendar.setTime(complexJobTrigger.getStartTime());
complexJobTrigger.setHourlyRecurrence(calendar.get(Calendar.HOUR_OF_DAY));
complexJobTrigger.setMinuteRecurrence(calendar.get(Calendar.MINUTE));
complexJobTrigger.setUiPassParam(scheduleRequest.getComplexJobTrigger().getUiPassParam());
jobTrigger = complexJobTrigger;
} else if (scheduleRequest.getCronJobTrigger() != null) {
if (scheduler instanceof QuartzScheduler) {
String cronString = scheduleRequest.getCronJobTrigger().getCronString();
// $NON-NLS-1$
String delims = "[ ]+";
String[] tokens = cronString.split(delims);
if (tokens.length < 7) {
cronString += " *";
}
ComplexJobTrigger complexJobTrigger = QuartzScheduler.createComplexTrigger(cronString);
complexJobTrigger.setStartTime(scheduleRequest.getCronJobTrigger().getStartTime());
complexJobTrigger.setEndTime(scheduleRequest.getCronJobTrigger().getEndTime());
complexJobTrigger.setDuration(scheduleRequest.getCronJobTrigger().getDuration());
complexJobTrigger.setUiPassParam(scheduleRequest.getCronJobTrigger().getUiPassParam());
jobTrigger = complexJobTrigger;
} else {
throw new IllegalArgumentException();
}
}
return jobTrigger;
}
Aggregations