Workflows¶
The Workflows tool is available in Advanced Pack.
The Workflows tool automates your business processes in an easy way. You can access Workflows from Administration panel. To create a Workflow rule, you need to define:
- Target Entity – what entity type the rule is applied to;
- Trigger Type – how the rule will be triggered;
- Conditions – conditions need to be met to trigger the rule;
- Actions – what to do if the rule is triggered.
In this article:
Trigger types¶
After record created¶
Triggered only when a new record is created. If specified conditions are met, then actions will be executed.
After record updated¶
Triggered only when an existing record is updated. If specified conditions are met, then actions will be executed.
After record saved¶
Triggered when a new record is created or an existing record is updated. If specified conditions are met, then actions will be executed.
For Workflow rules with this trigger type, it's a common practice to have a condition that checks whether some field was changed. For example, if a Case's status is changed, then do some actions.
Manual¶
As of v2.12.
Triggered manually by a user by clicking a button (or a dropdown menu item) on the record detail view.
The ability to define:
- an element type (a button or a dropdown item);
- a label text;
- teams allowed to run the Workflow;
- dynamic-logic conditions that make a button/menu-item available;
- access to the record required to be able to run the Workflow (read, edit, admin).
Limitations:
- Portal Users are not allowed to run Manual Workflows.
Scheduled¶
Triggered according to a defined scheduling. You can set up it to run every day, every week, etc. Actions will be applied for records returned by a specified List Report. Hence, you need also to create a List Report.
Scheduling is specified in a crontab notation.
* * * * * *
| | | | | |
| | | | | +-- Year (range: 1900-3000)
| | | | +---- Day of the Week (range: 1-7, 1 standing for Monday)
| | | +------ Month of the Year (range: 1-12)
| | +-------- Day of the Month (range: 1-31)
| +---------- Hour (range: 0-23)
+------------ Minute (range: 0-59)
How it works:
- You need to create a List Report showing records that met specific criteria. You can specify any columns for the Report, it doesn't matter in this context.
- Then, create a Workflow rule with the Scheduled trigger type, select the Report you creted before. Specify the needed scheduling.
- Specify one or multiple actions in the Workflow rule.
The Workflow rule will be running in idle according to the specified scheduling. On each run, it will run the Report and obtain all records from the Report result. Then, it will apply the action (or multiple actions) for every record.
Example, a use case
Send a notification email to customers who have their license expiring in 1 week. You will need a report listing contacts who have their license expiring exactly in 7 days. Set up a Workflow to run once a day.
Sequential¶
Is supposed to be run by another Workflow. Provides the ability to create complex logic.
- Create a Workflow rule with the Sequential trigger type.
- Create another Workflow rule with another trigger type. Add an action Trigger another Workflow and select the Workflow rule from the step 1.
Note
It can be reasonable to utilize BPM tool rather than Workflows if you need more complex logic.
Signal¶
Triggered when a specified signal is escalated in the system. Only object signals can be used here. See more info about signals.
Conditions¶
You can specify conditions that must be met to trigger a Workflow rule. There are two ways how conditions can be specified: with the UI condition builder and with a Formula script.
UI condition builder¶
Some available condition types:
- equals – the field equals to a specific value or a value of another field;
- was equal – the field was equal to a specific value before the Workflow was triggered;
- not equals – the field does not equal to a specific value or a value of another field;
- was not equal – the field was not equal to specific value before the Workflow was triggered;
- empty – the field value is empty;
- not empty – the field value is not empty;
- changed – the field was changed;
- not changed – the field was not changed.
Formula conditions¶
Formula provides the ability to define conditions of any complexity. To read about formula syntax, follow this article.
Note
There should not be any ;
delimiter used in formula code when it determines a condition. It should be one expression that returns a value (TRUE or FALSE).
Example
Expression with the logical AND:
status == 'New' && assignedUserId == null
Actions¶
- Send Email
- Create Record
- Create Related Record
- Update Target Record
- Update Related Record
- Link with another Record
- Unlink from another Record
- Apply Assignment Rule
- Create Notification
- Make Followed
- Trigger another Workflow
- Run Service Action
- Start BPM Process
- Send HTTP Request
- Execute Formula Script
Send Email¶
System will send an email using a specified Email Template. A recipient’s email address can be taken from the target record, any related record, the current user, followers, team users or specified explicitly. The email can be sent immediately or delayed for a specific interval.
If you specify the From address with an address of an existing Group Email Account, then SMTP parameters of that account will be used for sending.
It's possible to add an opt-out link to an email body.
It's possible to specify multiple email addresses by separating them with a semicolon.
It's possible to use a formula variable when specifying an email address. Example: {$$variable}
. As of v3.6.
Additional attachments can be added to an email using the Attachmnents Variable parameter. Specify a Formula variable name that contains an attachment ID or an array of attachment IDs. You can generate needed attachments in a Formula script in a previous action. As of v3.6.
Create Record¶
The system will create a new record of any entity type. If there is a relationship between the target entity type and the entity type of records being created, it's possible to relate them.
There is the ability to define a Formula script to calculate field values.
Note
Variables defined within the Formula script won't be availble in following actions (or the BPM process). They are only available within the current script.
Create Related Record¶
The system will create the record related to a target record.
It's possible to define a Formula script to calculate field values. Note: Variables defined within the Formula script will be only available within the current script.
Update Target Record¶
Allows to change specific fields of a target record.
It's possible to define a Formula script to calculate field values. Note: Variables defined within the Formula script will be only available within the current script.
Note
It's not recommended to rely on an Update Target Record action triggering another after-update Workflow. In some cases it won't work. It's better to define additional actions in the same Workflow or trigger a Sequential Workflow.
Important
Formula within an Update Target Record action must be utilized only for field updating. Use the Execute Formula Script action for any other need.
For Link-Multiple, Array, Multi-Enum, and Checklist fields it's possible to add or remove items without loosing set items. For example, adding a specific Team while preserving existing Teams.
There is the ability to delete the record with the following formula code: deleted = true
;
Update Related Record¶
Allows to change specific fields of a related record (or records).
It's possible to define Formula script to calculate field values. Note: Variables defined within formula won't be passed back.
There is the ability to delete the record with the following formula code: deleted = true
;
Tip
If there can be many related records, it's reasonable to process updating these records in idle. For this, utilize the Trigger Another Workflow action with a small or zero delay. Define an Update Related Record action in a Sequential Workflow rule.
Link with another Record¶
Relates the target record with another specific record. For example, add specific team to the record.
Unlink from another Record¶
Unrelates the target record from another specific record. For example. remove a specific team from the record.
Apply Assignment Rule¶
Assigns the target record to a User using a specific distribution rule. There are two available rules: Round-Robin and Least-Busy.
- Round-Robin – Users are chosen from the top to the bottom of a list and then starting again.
- Least-Busy – the User who has fewer assigned records will be chosen for assignment.
List Report – determines what records will be taken into account to calculate the number of assigned records for Least-Busy distribution. For example, we need to take into account only active Cases.
Target Team – Users of the selected team will take part in the assignment process.
Target User Position – Allows to restrict the list of users that will take part in the assignment process. Users that have the selected position (in team) will take part. If the field is set to All, then all team members will take part.
Create Notification¶
Notify specific users with a message.
It's possible to use placeholders in the message template:
{entity}
– a target record;{user}
– a current user.
Make Followed¶
Forces specific users to follow the target record or a specified related record.
Trigger another Workflow¶
Allows to make Sequential Workflows. It's possible to diverge Workflows by condition: you can set up a Workflow to trigger two Workflows with different conditions defined in those Workflows.
It's possible to delay executing of a Sequential Workflow. In a Sequential Workflow, you can define the condition that checks whether specific fields were changed since the parent Workflow was triggered by using Changed and Was Equal condition types.
A Target for a triggered Workflow can be substituted with a related record.
Note
For complex logic, it can be more reasonable to utilize BPM tool rather than Workflows.
Note
It's possible to trigger only Workflow rules of Sequential type.
Run Service Action¶
Allows to run specific service scripts.
The following actions are available out-of-the-box:
Meetings/Calls:
- Send Invitations – sends invitations to event attendees
Quotes/Sales Orders/Invoices:
- Add Items
- Convert Currency – converts all currency values based on current rates (since version 5.7.0)
- Send in Email
Opportunities:
- Convert Currency
Contacts/Leads/Accounts:
- Opt-out – unsubscribes from a specific target list or entirely
Users:
- Generate Password – generates a new password for a user and sends it to their email address
Developers can write their own service actions. See more detail.
Start BPM Process¶
Starts a BPM process. You can specify what target record will be used for the process.
Send HTTP Request¶
Provides the ability to call an external API.
Supported request methods:
- GET
- POST
- PUT
- PATCH
- DELETE
A payload can be taken from a formula variable or specified in a JSON format.
Additional headers can be specified.
Placeholders can be used in:
- Headers
- Request URL
- Payload JSON
Available placeholders:
- {$attribute} – a value of an attribute (field) of a target record; e.g.
{$description}
,{$assignedUserId}
(see info about attributes); - {$$variable} – a value of a variable (available only in BPM process); e.g.
{$$myVariableName}
.
Additionally, in headers, App Secrets can be added with a placeholder {#secrets.name} (as of v3.4.7).
A payload example:
{
"int": {$$myIntegerVariable},
"bool": {$$myBooleanVariable},
"string": "{$$myStringVariable}"
}
Handling HTTP response¶
A response body of a sent HTTP request will be available in formula with a function workflow\lastHttpResponseBody()
. It can be accessed in a following Workflow action. JSON attributes can be retrieved with a function json\retrieve
.
Example
A POST request returns a JSON body {"id": "SOME_ID"}
. We need to store that ID. Add a Update Target Record action in the same Workflow rule with the formula script:
$id = json\retrieve(workflow\lastHttpResponseBody(), 'id');
entity\setAttribute('someIdField', $id);
Note
In the context of a BPM process, the last response body is available only within a Task that contains the Send HTTP Request action. The variable won't be passed further along the process flow.
In the context of a BPM process, it's possible to catch response errors with an Error Boundary Event. The error code can be obtained by using bpm\caughtErrorCode
function.
Execute Formula Script¶
Executes a formula script. Variables defined within the script will be passed back. They will be available in the next Workflow actions or the BPM process.
Using formula in actions¶
It's possible to define formula to calculate fields in the following actions:
- Execute Formula Script,
- Create Record,
- Update Target Record,
- Create Related Record,
- Update Related Record.
Formula functions¶
workflow\targetEntity\attribute¶
workflow\targetEntity\attribute(ATTRIBUTE_NAME)
Returns an attribute value of the target entity. Useful when the scope is switched to a related record.
workflow\targetEntity\attributeFetched¶
workflow\targetEntity\attributeFetched(ATTRIBUTE_NAME)
Returns a previous attribute value of the target entity (before the Workflow was triggered).
workflow\trigger¶
workflow\trigger(ENTITY_TYPE, ID, WORKFLOW_ID)
Triggers another Workflow rule.
workflow\signalParam¶
workflow\signalParam(PARAM)
Get a signal param.