diff --git a/content/en/building/reference/app-settings/transitions.md b/content/en/building/reference/app-settings/transitions.md index 3250a92f5..0a31bca77 100644 --- a/content/en/building/reference/app-settings/transitions.md +++ b/content/en/building/reference/app-settings/transitions.md @@ -29,7 +29,7 @@ As of version 3.12.0 some transitions will partially run on the client for offli } ``` -In this example the `d` transition will not be applied, `a`, `b` `c` will be applied on the server and on the client, while `e` will only be applied on the server. +In the example above, the `d` transition will not be applied, `a`, `b` `c` will be applied on the server and on the client, while `e` will only be applied on the server. ## Available transitions @@ -57,11 +57,10 @@ The following transitions are available and executed in order. | [mark_for_outbound]({{% ref "building/reference/app-settings/outbound" %}}) | Enables outbound pushes. Available since 3.5.x | | [self_report](#self_report) | Maps patient to sender. Available since 3.9.x | | [create_user_for_contacts](#create_user_for_contacts) | Allows for automatically creating or replacing users based on data from their associated contact. Available since 4.1.x | | -## Transition Configuration Guide -Guides for how to setup specific transitions. +Below are guides to setup specific transitions. -### multi_report_alerts +## multi_report_alerts Send alert messages by SMS when specific conditions are received through reports. More flexible than simple Alerts. @@ -87,7 +86,7 @@ Understanding the different types of reports used in the configuration: `0`, `1` : `new_reports` : `counted_reports` that came in since the previous alert was sent. They haven't been messaged about yet. -#### Configuration +##### Configuration ``` "multi_report_alerts" : [ @@ -112,11 +111,11 @@ Note that we are using Mustache templates for our message templates (anything wi For performance reasons the `num_reports_threshold` cannot exceed 100. -### death_reporting +## death_reporting Updates patient documents with a `date_of_death` field which updates how the patient is displayed in the UI. -#### Configuration +##### Configuration Configuration is stored in the `death_reporting` field of the settings. @@ -136,7 +135,7 @@ Configuration is stored in the `death_reporting` field of the settings. } ``` -### Registration +## registration Configuration is held at `app_settings.registrations`, as a list of objects connecting forms to validations, events and messages. @@ -307,22 +306,22 @@ To provide an alternative location for the place name, provide a `place_name_fie Sets the `case_id` on the root of the registration document. -### Generate Shortcode on Contacts +## generate_shortcode_on_contacts -No custom configuration for `generate_shortcode_on_contacts`. +There is no custom configuration for `generate_shortcode_on_contacts`. -### Generate Patient ID On People +## generate_patient_id_on_people **Deprecated since 3.8.x** in favor of `generate_shortcode_on_contacts` -No custom configuration for `generate_patient_id_on_people`. +There is no custom configuration for `generate_patient_id_on_people`. -### update_notifications +## update_notifications **Deprecated in favor of [Muting](#muting)** -#### Configuration +##### Configuration ``` "notifications": { @@ -352,53 +351,64 @@ No custom configuration for `generate_patient_id_on_people`. } ``` -### Muting +## muting Implements muting/unmuting of persons and places. Supports multiple forms for each action, for webapp and sms workflows. +### Muting action -##### Muting action +Updates the target contact and all its descendants, setting the `muted` property equal to the current date in ISO format. -As of 3.12.0, client-side muting only runs on new reports or new contacts, before they are saved in the local database: +#### Client-side -- updates the target contact and all its descendants[10], setting the `muted` property equal to the device's current `date` in ISO format[8]. -- adds/updates the `muting_history`[11] property on every updated contact, to keep track of all the updates that have been processed client-side, as well as the last known server-side state of the contact and sets the `last_update` property to `client_side` -- updates the report doc to add a `client_side_transitions` property to track which transitions have run client-side +*Added in 3.12.0* -Server-side: +Client-side muting runs offline on a user's device. Only the contacts and reports available on the device will be updated. -- updates the target contact and all its descendants[1], setting the `muted` property equal to the current `date` in ISO format[2]. If the contact was already muted by a client, the `muted` date will be overwritten. The client-side `muting_history` will have a copy of the client-side muting date. -- adds a `muting_history` entry to Sentinel `info` docs for every updated contact[7] -- updates all connected registrations[3], changing the state of all unsent[4] `scheduled_tasks` to `muted` -- as of 3.12.0, updates the contact's client-side `muting_history` to set the `last_update` property to `server_side` and update the `server_side` section with the current date and muted state. -- as of 3.12.0, if the report was processed client-side, all "following" muting/unmuting events that have affected the same contacts will be replayed. This means the transition _could_ end up running multiple times over the same report[9]. +- Sets the `muted` property on the target contact and all its descendants to the device's current `date` (the moment the report is processed). +- Adds/updates the [`muting_history` property]({{< ref "#client-side-muting-history" >}}) on every updated contact, to keep track of all the updates that have been processed client-side, as well as the last known server-side state of the contact and sets the `last_update` property to `client_side` +- Updates the report doc to add a `client_side_transitions` property to track which transitions have run client-side -##### Unmuting action: +#### Server-side -As of 3.12.0, client-side unmuting only runs on new reports before they are saved in the local database: +Server-side muting runs as a typical Sentinel transition. Contacts that are already in the correct state are skipped. This applies to updates to the contact itself, updates to the Sentinel `muting_history` and to the connected registrations (registrations of a contact that is already in the correct state will not be updated). -- updates the target contact's topmost muted ancestor[10][5] and all its descendants, removing the `muted` property. -- adds/updates the `muting_history`[9] property on every updated contact, sets the last known server-side state of the contact and sets the `last_update` property to `client_side` -- updates the report doc to add a `client_side_transitions` property to track which transitions have run client-side +- Sets the `muted` property on the target contact and all its descendants to the moment Sentinel processed the muting action. + - If the contact was already muted by a client, the `muted` date will be overwritten. The [client-side `muting_history`]({{< ref "#client-side-muting-history" >}}) will have a copy of the client-side muting date. +- Adds a [`muting_history` entry]({{< ref "#server-side-muting-history" >}}) to Sentinel `info` docs for every updated contact +- Updates all connected registrations (for the target contact and descendants), changing the state of all unsent `scheduled_tasks` to `muted` + - Unsent `scheduled_tasks` have either a `scheduled` or `pending` state +- Updates the contact's client-side `muting_history` to set the `last_update` property to `server_side` and update the `server_side` section with the current date and muted state. +- If the report was processed client-side, all "following" muting/unmuting events that have affected the same contacts will be replayed. This means the transition _could_ end up running multiple times over the same report. + - Replaying is required due to how PouchDB <-> CouchDB synchronization does not respect the order in which the documents have been created, to ensure that contacts end up in the correct muted state. -Server-side: +### Unmuting action -- updates the target contact's topmost muted ancestor[1][5] and all its descendants, removing the `muted` property -- adds a `muting_history` entry to Sentinel `info` docs for every updated contact[7] -- updates all connected registrations[3], changing the state of all present/future[6] `muted` `scheduled_tasks` to `scheduled` -- as of 3.12.0, updates the contact's client-side `muting_history` to set the `last_update` property to `server_side` and update the `server_side` section with the current date and muted state. -- as of 3.12.0, if the report was processed client-side, all "following" muting/unmuting events that have affected the same contacts will be replayed. This means the transition _could_ end up running multiple times over the same report[10]. +Updates the target contact's topmost muted ancestor and all its descendants, removing the `muted` property. Because the muted state is inherited, unmuting cascades upwards to the highest level muted ancestor. If none of the ancestors is muted, unmuting cascades downwards only. -[1] Contacts that are already in the correct state are skipped. This applies to updates to the contact itself, updates to the Sentinel `muting_history` and to the connected registrations (registrations of a contact that is already in the correct state will not be updated). -[2] The date represents the moment Sentinel has processed the muting action -[3] target contact and descendants' registrations -[4] `scheduled_tasks` being in either `scheduled` or `pending` state -[5] Because the muted state is inherited, unmuting cascades upwards to the highest level muted ancestor. If none of the ancestors is muted, unmuting cascades downwards only. -[6] `scheduled_tasks` which are due today or in the future. All `scheduled_tasks` with a due date in the past will remain unchanged. -[8] The date represents the device's date when the report is processed. -[9] Replaying is required due to how PouchDB <-> CouchDB synchronization does not respect the order in which the documents have been created, to ensure that contacts end up in the correct muted state. -[10] The updated contacts are limited to the contacts available on the device. +#### Client-side + +*Added in 3.12.0* + +Client-side unmuting runs offline on a user's device. Only the contacts and reports available on the device will be updated. + +- Adds/updates the [`muting_history` property]({{< ref "#client-side-muting-history" >}}) on every updated contact, sets the last known server-side state of the contact and sets the `last_update` property to `client_side` +- Updates the report doc to add a `client_side_transitions` property to track which transitions have run client-side + +#### Server-side + +Server-side unmuting runs as a typical Sentinel transition. Contacts that are already in the correct state are skipped. This applies to updates to the contact itself, updates to the Sentinel `muting_history` and to the connected registrations (registrations of a contact that is already in the correct state will not be updated). + +- Adds a [`muting_history` entry]({{< ref "#server-side-muting-history" >}}) to Sentinel `info` docs for every updated contact +- Updates all connected registrations (for the target contact and descendants), changing the state of all present/future `scheduled_tasks` (ones due today or in the future) with the `muted` state to have the `scheduled` state. + - All `scheduled_tasks` with a due date in the past will remain unchanged. +- Updates the contact's [client-side `muting_history`]({{< ref "#client-side-muting-history" >}}) to set the `last_update` property to `server_side` and update the `server_side` section with the current date and muted state. +- If the report was processed client-side, all "following" muting/unmuting events that have affected the same contacts will be replayed. This means the transition _could_ end up running multiple times over the same report. + - Replaying is required due to how PouchDB <-> CouchDB synchronization does not respect the order in which the documents have been created, to ensure that contacts end up in the correct muted state. + +### Muting history + +#### Server-side muting history -##### [7] Muting history Each time the `muted` state of a contact changes, an entry is added to a `muting_history` list saved in Sentinel `info` docs (stored as an array property with the same name). Entries in `muting_history` contain the following information: @@ -408,8 +418,10 @@ Entries in `muting_history` contain the following information: | date | Date in ISO Format | | report_id | An `_id` reference to the report that triggered the action | +#### Client-side muting history + +*Added in 3.12.0* -##### [11] Client-side Muting history as of 3.12.0 Each time the client changes the `muted` state of a contact, an entry is added to a `muting_history` property on the contact's doc. The `last_update` entry is also changed to `client_side`. The `muting_history` property contains the following information: @@ -424,8 +436,7 @@ The `muting_history` property contains the following information: | client_side[].date | Date in ISO format | Client-side muting/unmuting date | | client_side[].report_id | uuid | The uuid of the muting/unmuting report that triggered the update | - -#### Configuration +##### Configuration Configuration is stored in the `muting` field of `app_settings.json`. | Property | Description | @@ -501,15 +512,15 @@ When muting events are processed both client-side and server-side, there is no g } ``` -### Accept patient reports +## accept_patient_reports Allow reporting about patient and place centric workflows by -- validating the report, -- assigning the relevant subject (patient or place) to the report if a registration with the given shortcode (patient_id or place_id) exists, -- clearing messages on the registration, and -- generating response messages on the report. +- validating the report +- assigning the relevant subject (patient or place) to the report if a registration with the given shortcode (patient_id or place_id) exists +- clearing messages on the registration +- generating response messages on the report -#### Example +##### Example ```json "transitions": { @@ -546,7 +557,7 @@ Allow reporting about patient and place centric workflows by }] ``` -### Accept case reports +## accept_case_reports Allow reporting about case centric workflows by - validating the report configuration documentation, @@ -554,7 +565,7 @@ Allow reporting about case centric workflows by - clearing messages on the registration, and - generating response messages on the report. -#### Example +##### Example ```json "registrations": [{ @@ -576,13 +587,13 @@ Allow reporting about case centric workflows by }] ``` -### self_report +## self_report Updates a `data_record` to set its patient to its sender. The resulting doc will have `fields.patient_uuid` and `fields.patient_id` filled with the sender's information. Provides hydrated patient information to subsequent transitions. The `sender` is the contact associated with the phone number that sent the original SMS. If a doc already contains a `patient` field, does not have a sender or its `form` is not configured to be enabled for this transition, it will be ignored. -#### Configuration +##### Configuration Configuration is stored in the `self_report` field of `app_settings.json` as a list of objects connecting forms to messages. Every object should have this structure: @@ -635,10 +646,10 @@ Supported `events_types` are: ] ``` -### update_clinics +## update_clinics Adds a contact’s info to a data record so as to attribute an incoming SMS message or report to the appropriate contact. -#### Configuration +##### Configuration As of version 3.12 you can add configuration to send a message whenever a contact match fails while running this transition. Configuration is stored in the `update_clinics` field of app_settings.json as a list of objects connecting forms to messages. Every object should have this structure: | Property | Description | @@ -680,11 +691,11 @@ If this configuration is not set then the message defaults to what is set in the ] ``` -### create_user_for_contacts +## create_user_for_contacts Users are automatically created for certain contacts. Both creating a new user for a new contact and replacing an existing user with a new user are supported. -#### Configuration +##### Configuration Several configurations are required in `app_settings` to enable the `create_user_for_contacts` transition. @@ -704,8 +715,6 @@ The [`app_url` property]({{< ref "building/reference/app-settings#app_settingsjs } ``` -#### Create User - When adding a new person contact, the `create_user_for_contacts` transition can be triggered to create a new user associated with that contact. _Available since 4.2.x._ ##### Example scenario @@ -732,7 +741,7 @@ The new person contacts _must_ have the following fields set: See the `person-create` contact form provided in the [Default config](https://github.com/medic/cht-core/tree/master/config/default) as an example. This form will trigger the creation of a new user for the contact when the role is set to `chw` or `chw_supervisor` and a phone number is provided. -#### Replace User +### Replace User An existing offline user can be replaced on a device so that a new user can use that device without needing to immediately sync with the server. _Available since 4.1.x._ @@ -775,7 +784,7 @@ See the `replace_user` app form provided in the [Default config](https://github. } ``` -#### Troubleshooting +## Troubleshooting Configuration is validated when Sentinel starts. Issues with the configuration will be show in the Sentinel logs.