Lecture 4 minutes
La personnalisation d’un outil de CRM passe aussi par la création de routines automatisées au sein de l’application afin de reproduire des habitudes de travail ou de définir des règles communes à un groupe d’utilisateur. Ces routines peuvent prendre plusieurs formes : notamment celle d’une action déclenchée automatiquement en fonction de critères bien définis.
La définition du process
Prenons l’exemple d’une société disposant d’une équipe commerciale. L’objectif principal de cette équipe est de concrétiser une phase de prospection par la vente de biens ou de services.
Dans un premier temps, le commercial démarche un ou plusieurs prospects et enregistre leurs informations au sein du CRM. Un premier process automatisé peut alors être envisagé : Dès la création d’un Compte de type Prospect, une tâche « Qualification du client » est alors ajoutée pour l’utilisateur.
Initialisation
La définition de process automatisés au sein d’OroCRM se fait au travers d’un fichier YAML. Il doit obligatoirement être nommé process.yml et se trouver dans le dossier /Resources/config/ d’un bundle. Il contient deux parties qui décrivent la définition du trigger et le déroulé.
Le trigger
Dans notre exemple, nous souhaitons qu’une tâche soit créée dès qu’un nouveau Compte est enregistré comme Prospect. Nous allons donc demander l’exécution de notre process à la création de l’enregistrement :
1 2 3 4 |
triggers: create_task_for_prospect: - event: create |
La partie trigger se compose :
Du nom du process à exécuter
Du type d’événement sur lequel déclencher le process (create ou update)
D’autres options sont disponibles et se trouve dans la documentation associée : Process configuration
La définition
La définition du process est réalisée en plusieurs étapes. La première consiste à :
- Reprendre le nom du procces défini dans la partie trigger (voir plus haut)
- Donner un libellé
- L’associer à une entité de l’application
Ce qui donne :
1 2 3 4 5 |
definitions: create_task_for_prospect: label: "Create a new task for every prospect" enabled: true entity: OroCRM\Bundle\AccountBundle\Entity\Account |
Viens ensuite la partie contenant les conditions auxquelles l’enregistrement doit répondre :
1 2 3 4 5 6 7 8 9 |
definitions: create_task_for_prospect: label: "Create a new task for every prospect" enabled: true entity: OroCRM\Bundle\AccountBundle\Entity\Account pre_conditions: @and: - @not_empty: [$type] - @equal: [$type.id, 'prospect'] |
Dans cet exemple les règles sont simples :
- Le type de Compte ne doit pas être vide
- Le Compte doit être de type Prospect
Dans la suite, nous rentrons dans le coeur du sujet. Nous allons définir nos différentes actions permettant la création d’un ticket :
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 |
definitions: create_task_for_prospect: label: "Create a new task for every prospect" enabled: true entity: OroCRM\Bundle\AccountBundle\Entity\Account pre_conditions: @and: - @not_empty: [$type] - @equal: [$type.id, 'prospect'] actions_configuration: - @find_entity: attribute: $.taskPriority class: OroCRM\Bundle\TaskBundle\Entity\TaskPriority identifier: normal - @format_string: attribute: $.subject string: '%name% - Qualification du prospect' arguments: name: $name - @create_entity: class: OroCRM\Bundle\TaskBundle\Entity\Task attribute: $.newTask flush: true data: subject: $.subject owner: $owner organization: $organization taskPriority: $.taskPriority - @call_method: object: $.newTask method: addActivityTarget method_parameters: [$.data] |
Dans l’ordre nous avons :
- La recherche de l’entité priorité normale
- La définition du titre au travers d’un @format_string. Dans cet exemple, le nom du compte est repris en préfixe du nom de la tâche.
- La création de l’entité Tache avec les différentes données (data)
- L’association de la tâche au compte pour que celui-ci apparaisse comme contexte
Le chargement du process dans l’application
Les process rédigés au sein d’un fichier YAML doivent être chargés en base de données. Les différentes étapes seront aussi traduites sous forme de listener Doctrine et de code PHP afin d’être exécuté.
Pour initialiser ou mettre à jour un process en base, il faut exécuter la commande
1 |
oro:process:configuration:load |
Désormais, lors de l’enregistrement d’un Compte répondant aux critères du process, la tâche sera créée pour l’utilisateur connecté.
Différer son exécution
Dans le cas où le process est susceptible de consommer du temps pour l’envoi d’un email par exemple. Il est alors préférable de différer son exécution pour ne pas ralentir l’application. Il suffit alors simplement d’ajouter 2 options à la définition du trigger :
1 2 3 4 5 6 |
triggers: create_task_for_prospect: - event: create queued: true time_shift: P1D |
Dans cet exemple :
- L’option queued à true indique que le process sera exécuté plus tard par la job queue Oro
- L’option timeshift prend comme argument toutes les valeurs acceptées par la méthode __construct de la class DateInterval ou un entier correspondant à un nombre de secondes