Dan Haywood created ISIS-661: -------------------------------- Summary: BackgroundService and BackgroundTaskService as a way of creating mementos to execute jobs asynchronously Key: ISIS-661 URL: https://issues.apache.org/jira/browse/ISIS-661 Project: Isis Issue Type: New Feature Components: Core, Objectstore: JDO Affects Versions: core-1.3.0, objectstore-jdo-1.3.0 Reporter: Dan Haywood Assignee: Dan Haywood Fix For: objectstore-jdo-1.4.0, core-1.4.0
BackgroundService is the service that creates the mementos, with a default implementation in isis-core. usage: public void submitInvoices() { for(Customer customer: customerRepository.findCustomersToInvoice()) { backgroundService.execute(customer).submitInvoice(); } } @javax.inject.Inject private BackgroundService backgroundService; Here the service creates a javassist proxy through which it can figure out the arguments. The MementoService and BookmarkService can be used to create the memento string (XML). ~~~~~~~~~~~~~ BackgroundTaskService is the service that persists the mementos, with a default implementation in objectstore-jdo. Each persisted BackgroundTask should be associated with the transactionId of the Interaction (see ISIS-660). ~~~~ also: - require separate "contributions" service to add in the BackgroundTask collection to the Interaction. ~~~~ NB: the docs should indicate that an alternative implementation for BackgroundTaskService could be webhooks. Per Maurizio's comment: a web hook is basically an HTTP callback An example of web hook is available on the Google infrastructure, where task longer than 30 sec. are not allowed. This is similar to your idea of background service: public void calculateInvoices() { for(Customer customer: customerRepository.findCustomersToInvoice()) { Queue queue = QueueFactory.getDefaultQueue(); queue.add(withUrl("/worker").param("id", customer.getId())); } } Tasks added to the queue will execute by calling the request handler at the URL /worker with the parameter id at a given task rate. https://developers.google.com/appengine/docs/java/taskqueue/overview-push -- This message was sent by Atlassian JIRA (v6.1.5#6160)