Difference between revisions of "Interfaces Dolibarr vers exterieur"

From Dolibarr ERP CRM Wiki
Jump to navigation Jump to search
Line 1: Line 1:
== Ajouter son code sur un évênement ==
+
== Ajouter son code sur un événement ==
  
Pour permettre de déclencher du code personnalisé en réaction à un évènement Dolibarr (création/modification/suppression d'une société/facture/produit), Dolibarr propose un mécanisme de triggers. Ce mécanisme vous permet de personnaliser un workflow afin que les évènements de gestion Dolibarr soient répercutés dans une autre application. Rien n'empèche également de l'utiliser pour modifier le comportement de Dolibarr même: par exemple, pour que la validation d'une facture provoque la création d'un contrat automatiquement.
+
Pour permettre de déclencher du code personnalisé en réaction à un évènement Dolibarr (création/modification/suppression d'une société/facture/produit), Dolibarr propose un mécanisme de triggers. Ce mécanisme vous permet de personnaliser un workflow afin que les événements de gestion Dolibarr soient répercutés dans une autre application. Rien n'empèche également de l'utiliser pour modifier le comportement de Dolibarr même: par exemple, pour que la validation d'une facture provoque la création d'un contrat automatiquement.
  
  
 
Donc, pour ajouter son propre code à déclencher par trigger, la procédure est la suivante:
 
Donc, pour ajouter son propre code à déclencher par trigger, la procédure est la suivante:
 
# Copier le fichier ''includes/triggers/interface_demo.class.php'' sous le nom ''interface_xxx.class.php'' (ou xxx est une chaine de votre choix), en laissant ce nouveau fichier dans le même répertoire. Par exemple ''includes/triggers/interface_monworkflow.class.php''
 
# Copier le fichier ''includes/triggers/interface_demo.class.php'' sous le nom ''interface_xxx.class.php'' (ou xxx est une chaine de votre choix), en laissant ce nouveau fichier dans le même répertoire. Par exemple ''includes/triggers/interface_monworkflow.class.php''
# Editer ce fichier ''interface_monworkflow.class.php'' afin de renommer la classe ''InterfaceDemo'' par ''InterfaceMonWorkflow'' et ajouter votre code dans la fonction ''run_trigger''. Cette fonction est appelée à chaque évènement Dolibarr. Placer votre code en fonction du ou des évènements sur lesquels vous voulez réagir, chaque évènement étant identifié par un test sur la variable $action:
+
# Editer ce fichier ''interface_monworkflow.class.php'' afin de renommer la classe ''InterfaceDemo'' par ''InterfaceMonWorkflow'' et ajouter votre code dans la fonction ''run_trigger''. Cette fonction est appelée à chaque événement Dolibarr. Placer votre code en fonction du ou des événements sur lesquels vous voulez réagir, chaque événement étant identifié par un test sur la variable $action:
  
 
   function run_trigger($action,$object,$user,$lang,$conf)
 
   function run_trigger($action,$object,$user,$lang,$conf)
Line 26: Line 26:
 
   }
 
   }
  
Il n'y a plus qu'à tester, en provoquant l'évènement déclencheur dans Dolibarr.
+
Il n'y a plus qu'à tester, en provoquant l'événement déclencheur dans Dolibarr.
  
 
== Gérer de nouveaux évènements ==
 
== Gérer de nouveaux évènements ==

Revision as of 18:19, 12 June 2006

Ajouter son code sur un événement

Pour permettre de déclencher du code personnalisé en réaction à un évènement Dolibarr (création/modification/suppression d'une société/facture/produit), Dolibarr propose un mécanisme de triggers. Ce mécanisme vous permet de personnaliser un workflow afin que les événements de gestion Dolibarr soient répercutés dans une autre application. Rien n'empèche également de l'utiliser pour modifier le comportement de Dolibarr même: par exemple, pour que la validation d'une facture provoque la création d'un contrat automatiquement.


Donc, pour ajouter son propre code à déclencher par trigger, la procédure est la suivante:

  1. Copier le fichier includes/triggers/interface_demo.class.php sous le nom interface_xxx.class.php (ou xxx est une chaine de votre choix), en laissant ce nouveau fichier dans le même répertoire. Par exemple includes/triggers/interface_monworkflow.class.php
  2. Editer ce fichier interface_monworkflow.class.php afin de renommer la classe InterfaceDemo par InterfaceMonWorkflow et ajouter votre code dans la fonction run_trigger. Cette fonction est appelée à chaque événement Dolibarr. Placer votre code en fonction du ou des événements sur lesquels vous voulez réagir, chaque événement étant identifié par un test sur la variable $action:
 function run_trigger($action,$object,$user,$lang,$conf)
 {
       // Mettre ici le code à exécuter en réaction de l'action
       // Le type de l'évènement Dolibarr est stocké dans $action
       // Les données de l'action sont stockées dans $object
       // La configuration, utilisateur et langage sont dans $conf,$user et $lang
       if ($action == 'COMPANY_CREATE')
       {
           dolibarr_syslog("Trigger for action '$action' launched. id=".$object->id);
       }
       elseif ($action == 'COMPANY_MODIFY')
       {        
           dolibarr_syslog("Trigger for action '$action' launched. id=".$object->id);
       }
       elseif ($action == 'COMPANY_DELETE')
       ...
 }

Il n'y a plus qu'à tester, en provoquant l'événement déclencheur dans Dolibarr.

Gérer de nouveaux évènements

Les évènements Dolibarr qui provoquent un appel de triggers sont, pour l'instant, identifiés par les codes évènements suivants:

  • USER_CREATE
  • USER_MODIFY
  • USER_DISABLE

Dans ces 3 cas, la variable $object contient un objet de type user.class.php

  • COMPANY_CREATE
  • COMPANY_MODIFY
  • COMPANY_DELETE

Dans ces 3 cas, la variable $object contient un objet de type societe.class.php

  • PRODUCT_CREATE
  • PRODUCT_MODIFY
  • PRODUCT_DELETE

Dans ces 3 cas, la variable $object contient un objet de type product.class.php

  • ORDER_CREATE
  • ORDER_MODIFY
  • ORDER_DELETE

Dans ces 3 cas, la variable $object contient un objet de type commande.class.php

  • PROPAL_CREATE
  • PROPAL_MODIFY
  • PROPAL_VALIDATE
  • PROPAL_CLOSE_SIGNED
  • PROPAL_CLOSE_REFUSED

Dans ces 5 cas, la variable $object contient un objet de type societe.class.php

  • CONTRACT_CREATE
  • CONTRACT_MODIFY
  • CONTRACT_ACTIVATE
  • CONTRACT_CANCEL
  • CONTRACT_CLOSE
  • CONTRACT_DELETE

Dans ces 6 cas, la variable $object contient un objet de type contract.class.php

  • BILL_CREATE
  • BILL_MODIFY
  • BILL_VALIDATE
  • BILL_CANCEL
  • BILL_DELETE

Dans ces 5 cas, la variable $object contient un objet de type facture.class.php

  • PAYMENT_CUSTOMER_CREATE

Dans ce cas, la variable $object contient un objet de type paiement.class.php

  • PAYMENT_SUPPLIER_CREATE

Dans ce cas, la variable $object contient un objet de type paiementfourn.class.php

  • MEMBER_CREATE
  • MEMBER_VALIDATE
  • MEMBER_SUBSCRIPTION
  • MEMBER_MODIFY
  • MEMBER_RESILIATE
  • MEMBER_DELETE

Dans ces cas, la variable $object contient un objet de type adherent.class.php


Pour gérer d'autre évènements que ceux ci-dessus, il faut modifier le code Dolibarr pour y ajouter la séquence suivante dans les méthodes métiers des classes utilisées pour gérer les évenements:

 // Appel des triggers
 include_once(DOL_DOCUMENT_ROOT . "/interfaces.class.php");
 $interface=new Interfaces($this->db);
 $interface->run_triggers('XXXXX_YYYYYY',$this,$user,$lang,$conf);
 // Fin appel triggers

Ici, $this doit être l'objet de la classe métier qui contient toutes les informations à passer au trigger. Remplacer, de plus, le 'XXXXX_YYYYYY' par un code évènement non déjà utilisé. Il sera alors possible d'ajouter dans la méthode run_trigger, un if qui permet de gérer ce code. La méthode run_trigger serait alors de la forme :

 function run_trigger($action,$object,$user,$lang,$conf)
 {
       // Mettre ici le code à exécuter en réaction de l'action
       // Le type de l'évènement Dolibarr est stocké dans $action
       // Les données de l'action sont stockées dans $object
       // La configuration, utilisateur et langage sont dans $conf,$user et $lang
       
       if ($action == 'XXXXX_YYYYY')
       {
           dolibarr_syslog("Trigger for action '$action' launched. id=".$object->id);
       }
       
       elseif ($action == 'COMPANY_CREATE')
       {
           dolibarr_syslog("Trigger for action '$action' launched. id=".$object->id);
       }
       elseif ($action == 'COMPANY_MODIFY')
       {        
           dolibarr_syslog("Trigger for action '$action' launched. id=".$object->id);
       }
       elseif ($action == 'COMPANY_DELETE')
       ...
 }