apex-chainable
apex-chainable copied to clipboard
Chain Asynchronous Apex in a readable and flexible way without hardcoding the successor.
Apex Chainable data:image/s3,"s3://crabby-images/ea022/ea02214d3f8baa8299359e6ec046fcefffb67e8a" alt="Codacy Badge"
data:image/s3,"s3://crabby-images/2f883/2f88383f3cb5305ecb6efcdfc607447a2ccf1655" alt="Deploy to Salesforce"
Apex Batches can be chained by calling the successor batch from the finish()
method of the previous batch.
But such hardcoding makes this model inflexible. It's hard to build the chain from outside, neighter from a central class
nor on runtime dependant on business logic.
The same applies when the execute()
method of Schedulable
or Queueable
classes call other classes.
With Chainable
The Chainable
wrapper class of this repository overcomes those drawbacks.
- No need to hardcode successor batch in
finish()
method - Created batch chains of arbitrary length without changing existing Batch classes
- Support
Batchable
,Queueable
andSchedulable
classes as chain members - Allows sharing and passing of variables between chain members
new FirstBatch().setShared('result', new Money(0))
.then(AnotherBatch())
.then(QueueableJob())
.then(ScheduledJob())
...
.execute();
Without Chainable
class FirstBatch implements Batchable<SObject> {
Iterator<SObject> start(BatchableContext ctx) { ... }
void execute(BatchableContext ctx, List<Account> scope) { ... }
void finish(BatchableContext ctx) {
Database.enqueueBatch(new SecondBatch());
}
}
class AnotherBatch implements Batchable<SObject> {
Iterator<SObject> start(BatchableContext ctx) { ... }
void execute(BatchableContext ctx, List<Account> scope) { ... }
void finish(BatchableContext ctx) {
System.schedule('name', cron, new ScheduledJob());
}
}