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:

  1. App-Defined Actions
  2. Server Scripts
  3. Webhooks

On top of this, each transition task can be either:

  1. 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.

  2. 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:

Discard
Save

On this page

Review Changes ← Back to Content
Message Status Space Raised By Last update on