Fix: Echec des triggers quand il y a 2 triggers avec meme nom
Fix: Mauvais triggers appel quand creation user.
This commit is contained in:
parent
1f7a2b715c
commit
d7edb59b09
@ -35,62 +35,70 @@
|
||||
|
||||
class Interfaces
|
||||
{
|
||||
//! Repertoire contenant les definitions des triggers
|
||||
var $dir;
|
||||
|
||||
/**
|
||||
* \brief Constructeur.
|
||||
* \param DB handler d'accès base
|
||||
*/
|
||||
function Interfaces($DB)
|
||||
{
|
||||
$this->db = $DB ;
|
||||
$this->dir = DOL_DOCUMENT_ROOT . "/includes/triggers";
|
||||
}
|
||||
|
||||
/**
|
||||
* \brief Fonction appelée lors du déclenchement d'un évènement Dolibarr.
|
||||
* Cette fonction déclenche tous les triggers trouvés
|
||||
* \param action Code de l'evenement
|
||||
* \param object Objet concern
|
||||
* \param user Objet user
|
||||
* \param lang Objet lang
|
||||
* \param conf Objet conf
|
||||
* \return int Nbre de triggers déclenchés si pas d'erreurs. Nb en erreur sinon.
|
||||
*/
|
||||
function run_triggers($action,$object,$user,$lang,$conf)
|
||||
{
|
||||
|
||||
$handle=opendir($this->dir);
|
||||
$modules = array();
|
||||
$nbok = $nbko = 0;
|
||||
|
||||
while (($file = readdir($handle))!==false)
|
||||
{
|
||||
if (is_readable($this->dir."/".$file) && eregi('interface_(.*).class.php$',$file,$reg))
|
||||
{
|
||||
$modName = "Interface".ucfirst($reg[1]);
|
||||
//print "file=$file"; print "modName=$modName"; exit;
|
||||
if ($modName)
|
||||
{
|
||||
include_once($this->dir."/".$file);
|
||||
$objMod = new $modName($this->db);
|
||||
if ($objMod)
|
||||
{
|
||||
if ($objMod->run_trigger($action,$object,$user,$lang,$conf) > 0)
|
||||
{
|
||||
$nbok++;
|
||||
}
|
||||
else
|
||||
{
|
||||
$nbko++;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
if ($nbko) return $nbko;
|
||||
return $nbok;
|
||||
}
|
||||
var $dir; // Repertoire contenant les fichiers triggers
|
||||
|
||||
/**
|
||||
* \brief Constructeur.
|
||||
* \param DB handler d'accès base
|
||||
*/
|
||||
function Interfaces($DB)
|
||||
{
|
||||
$this->db = $DB ;
|
||||
$this->dir = DOL_DOCUMENT_ROOT . "/includes/triggers";
|
||||
}
|
||||
|
||||
/**
|
||||
* \brief Fonction appelée lors du déclenchement d'un évènement Dolibarr.
|
||||
* Cette fonction déclenche tous les triggers trouvés
|
||||
* \param action Code de l'evenement
|
||||
* \param object Objet concern
|
||||
* \param user Objet user
|
||||
* \param lang Objet lang
|
||||
* \param conf Objet conf
|
||||
* \return int Nbre de triggers déclenchés si pas d'erreurs. Nb en erreur sinon.
|
||||
*/
|
||||
function run_triggers($action,$object,$user,$lang,$conf)
|
||||
{
|
||||
|
||||
$handle=opendir($this->dir);
|
||||
$modules = array();
|
||||
$nbok = $nbko = 0;
|
||||
|
||||
while (($file = readdir($handle))!==false)
|
||||
{
|
||||
if (is_readable($this->dir."/".$file) && eregi('interface_(.*).class.php$',$file,$reg))
|
||||
{
|
||||
$modName = "Interface".ucfirst($reg[1]);
|
||||
//print "file=$file"; print "modName=$modName"; exit;
|
||||
if ($modName)
|
||||
{
|
||||
if (in_array($modName,$modules))
|
||||
{
|
||||
dolibarr_syslog("Error: Trigger file with name '$modName' already launched. Remove duplicate file.");
|
||||
}
|
||||
else
|
||||
{
|
||||
include_once($this->dir."/".$file);
|
||||
$objMod = new $modName($this->db);
|
||||
if ($objMod)
|
||||
{
|
||||
$modules[$i] = $modName;
|
||||
if ($objMod->run_trigger($action,$object,$user,$lang,$conf) > 0)
|
||||
{
|
||||
$nbok++;
|
||||
}
|
||||
else
|
||||
{
|
||||
$nbko++;
|
||||
}
|
||||
$i++;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
if ($nbko) return $nbko;
|
||||
return $nbok;
|
||||
}
|
||||
}
|
||||
?>
|
||||
|
||||
@ -651,7 +651,8 @@ class User
|
||||
{
|
||||
$sql = "INSERT INTO ".MAIN_DB_PREFIX."user (datec,login,ldap_sid) VALUES(now(),'".addslashes($this->login)."','".$this->ldap_sid."')";
|
||||
$result=$this->db->query($sql);
|
||||
|
||||
|
||||
dolibarr_syslog("User.class::create sql=".$sql);
|
||||
if ($result)
|
||||
{
|
||||
$table = "".MAIN_DB_PREFIX."user";
|
||||
@ -666,7 +667,7 @@ class User
|
||||
}
|
||||
|
||||
// Update minor fields
|
||||
if ($this->update() < 0)
|
||||
if ($this->update(1) < 0)
|
||||
{
|
||||
$this->error=$this->db->error();
|
||||
$this->db->rollback();
|
||||
|
||||
@ -166,7 +166,7 @@ if ($_POST["action"] == 'add' && $canadduser)
|
||||
$db->rollback();
|
||||
|
||||
//$message='<div class="error">'.$langs->trans("ErrorLoginAlreadyExists",$edituser->login).'</div>';
|
||||
$message='<div class="error">'.$edituser->error.$id.'</div>';
|
||||
$message='<div class="error">'.$edituser->error.'</div>';
|
||||
|
||||
$action="create"; // Go back to create page
|
||||
}
|
||||
|
||||
Loading…
Reference in New Issue
Block a user