Workflow Transition Tasks
Introduction
Workflow Transition Tasks are actions that can be run during state transitions in workflows. Each Workflow Transition can link to a set of transition tasks.
Each Workflow Transition Task can have tasks of the following types:
- App-Defined Actions
- Server Scripts
- Webhooks
On top of this, each transition task can be either:
Synchronous: This is the default mode of transition tasks. All of the transition tasks run one-by-one when the state transition is initiated. Even if one of them fails, the transition is reversed.
Asynchronous: This mode can be enabled using the 'Asynchronous' checkbox. Each asynchronous transition task runs after the state transition is completed, meaning it has zero influence over state completion, and is run in a separate background job of its own.
App-Defined Actions
Each iVendNext app defines them using the 'workflow_methods'
Any dotted path method defined through the workflow_methods hook has to accept doc: Document as the parameter, which is the document on which the transition is being applied.
An example of an app-defined task is:
# hooks.py
workflow_methods = [{"name": "Create a customer", "method":
"myapp.shop.doctype.kirana.create_customer"}]
# myapp/shop/doctype/kirana.py
def create_customer(doc):
customer = frappe.new_doc("Customer")
customer.customer_name = "Customer " + doc.name
customer.customer_type = "Individual"
customer.save()
These will be available in the 'Tasks' drop-down if any of the apps has provided them.
If you are an end user, you can not create app-defined actions on your own and will have to use server scripts as mentioned below.
Server Scripts
These also take the doc: Document parameter and can be set using the 'Workflow Task' Script Type.
Build Server Script
# Create a customer with the same name as the given document
customer = iVendNext.new_doc("Customer")
customer.customer_name = "workflow" + doc.name
customer.customer_type = "Company"
customer.save()
And then these have to be linked to in the transition task.
Webhooks
These can be created by setting the 'Doc Event' field of the webhook to 'workflow_transition'.
And then these have to be linked to in the transition task: