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 P
establishTriggerStateIfApplicable(String contextId)
Establish theNotificationStateAware
contract forTriggeredJobEventProducer.TYPE
.P
executeJob(String id, com.broadleafcommerce.data.tracking.core.context.ContextInfo context)
Causes the specifiedScheduledJob
to be executed immediately.P
markJobAsExecuted(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, theNotificationState
of typeTriggeredJobEventProducer.TYPE
should be configured to start the resiliency lifecycle. SeeNotificationState
for 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 theNotificationStateAware
contract forTriggeredJobEventProducer.TYPE
. This should initialize the basic support for a trigger typeNotificationState
item 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 specifiedScheduledJob
to be executed immediately.- Parameters:
id
- The identifier for the scheduled jobcontext
- context information surrounding multitenant state- Returns:
- The job that was executed
-
-