Interface ScheduledJobService<P extends ScheduledJob>
-
- All Superinterfaces:
com.broadleafcommerce.data.tracking.core.service.CrudEntityService<P>,com.broadleafcommerce.data.tracking.core.service.RsqlCrudEntityService<P>
- All Known Implementing Classes:
DefaultScheduledJobService
public interface ScheduledJobService<P extends ScheduledJob> extends com.broadleafcommerce.data.tracking.core.service.RsqlCrudEntityService<P>Service reponsible for functionality related toScheduledJob- Author:
- Chad Harchar (charchar), Jeff Fischer
-
-
Method Summary
All Methods Instance Methods Abstract Methods Modifier and Type Method Description PestablishTriggerStateIfApplicable(String contextId)Establish theNotificationStateAwarecontract forTriggeredJobEventProducer.TYPE.PexecuteJob(String id, com.broadleafcommerce.data.tracking.core.context.ContextInfo context)Causes the specifiedScheduledJobto be executed immediately.PmarkJobAsExecuted(String contextId, TimingType timingType)Mark a job as executed viaScheduledJob.isExecuted().org.springframework.data.domain.Page<P>readAllByName(String name, cz.jirutka.rsql.parser.ast.Node filters, org.springframework.data.domain.Pageable page, com.broadleafcommerce.data.tracking.core.context.ContextInfo context)Read a page of job records focusing on name (optional)Stream<P>streamAll(com.broadleafcommerce.data.tracking.core.context.ContextInfo contextInfo)Read a stream of all ScheduledJobs in the data store.-
Methods inherited from interface com.broadleafcommerce.data.tracking.core.service.CrudEntityService
create, createAll, createAllAllowingPartialSuccess, delete, readAll, readAll, readAll, readAllByContextId, readByContextId, replace, replaceAll, replaceAllAllowingPartialSuccess, update, updateAll, updateAllAllowingPartialSuccess, updateSort
-
-
-
-
Method Detail
-
streamAll
@NonNull Stream<P> streamAll(@Nullable com.broadleafcommerce.data.tracking.core.context.ContextInfo contextInfo)
Read a stream of all ScheduledJobs in the data store.- Parameters:
contextInfo- context information surrounding multitenant state- Returns:
- a stream of all ScheduledJobs in the data store
-
readAllByName
@NonNull org.springframework.data.domain.Page<P> readAllByName(@Nullable String name, @Nullable cz.jirutka.rsql.parser.ast.Node filters, @Nullable org.springframework.data.domain.Pageable page, @Nullable com.broadleafcommerce.data.tracking.core.context.ContextInfo context)
Read a page of job records focusing on name (optional)- Parameters:
name- The name of the job to retrieve (optional)filters- Any additional search filters to applypage- The configuration for the page of records to retrievecontext- The fetch view context- Returns:
- The page of records
-
markJobAsExecuted
@Nullable P markJobAsExecuted(@NonNull String contextId, @NonNull TimingType timingType)
Mark a job as executed viaScheduledJob.isExecuted(). As part of an atomic operation, this method should also set theScheduledJob.getLastExecuted()field and disable the job viaScheduledJob.isEnabled()if the job is ofTimingType.TARGET_DATE. Finally, theNotificationStateof typeTriggeredJobEventProducer.TYPEshould be configured to start the resiliency lifecycle. SeeNotificationStatefor more information on the fields there related to messaging resiliency.- Parameters:
contextId- The tracking identifier for the scheduled jobtimingType- The type of job (e.g. whether it's recurring cron or single use)- Returns:
- the updated job if found and successfully updated, otherwise
null. For example, if another process had already updated the record as being executed, this update would not succeed.
-
establishTriggerStateIfApplicable
P establishTriggerStateIfApplicable(String contextId)
Establish theNotificationStateAwarecontract forTriggeredJobEventProducer.TYPE. This should initialize the basic support for a trigger typeNotificationStateitem in theNotificationStateAware.getNotificationStates()list. This state is generally completed during themarkJobAsExecuted(String, TimingType)lifecycle.- Parameters:
contextId- The tracking identifier for the scheduled job- Returns:
- The initialized entity instance
-
executeJob
P executeJob(@NonNull String id, @Nullable com.broadleafcommerce.data.tracking.core.context.ContextInfo context)
Causes the specifiedScheduledJobto be executed immediately.- Parameters:
id- The identifier for the scheduled jobcontext- context information surrounding multitenant state- Returns:
- The job that was executed
-
-