From edbb42dc524c07443d32d176cc3b38e21e3b2f49 Mon Sep 17 00:00:00 2001 From: Rodolphe Quiedeville Date: Sat, 15 Nov 2003 17:41:07 +0000 Subject: [PATCH] Nouveau fichier --- .../modules/DolibarrModules.class.php | 191 ++++++++++++++++++ 1 file changed, 191 insertions(+) create mode 100644 htdocs/includes/modules/DolibarrModules.class.php diff --git a/htdocs/includes/modules/DolibarrModules.class.php b/htdocs/includes/modules/DolibarrModules.class.php new file mode 100644 index 00000000000..a3f9cb17229 --- /dev/null +++ b/htdocs/includes/modules/DolibarrModules.class.php @@ -0,0 +1,191 @@ + + * + * This program is free software; you can redistribute it and/or modify + * it under the terms of the GNU General Public License as published by + * the Free Software Foundation; either version 2 of the License, or + * (at your option) any later version. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with this program; if not, write to the Free Software + * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. + * + * $Id$ + * $Source$ + * + */ + +class DolibarrModules +{ + + /* + * Initialisation + * + */ + + Function DolibarrModules($DB) + { + $this->db = $DB ; + } + /* + * + * + * + */ + + Function _init($array_sql) + { + /* + * Activation du module + */ + $err = 0; + + + $sql = "REPLACE INTO llx_const SET name = '".$this->const_name."', value='1', visible = 0"; + + if (!$this->db->query($sql)) + { + $err++; + } + + foreach ($this->boxes as $key => $value) + { + $titre = $this->boxes[$key][0]; + $file = $this->boxes[$key][1]; + + $sql = "SELECT count(*) FROM llx_boxes_def WHERE name ='".$titre."'"; + + if ( $this->db->query($sql) ) + { + $row = $this->db->fetch_row($sql); + if ($row[0] == 0) + { + $sql = "insert into llx_boxes_def (name, file) values ('".$titre."','".$file."')"; + if (! $this->db->query($sql) ) + { + $err++; + } + } + } + else + { + $err++; + } + } + + foreach ($this->const as $key => $value) + { + $name = $this->const[$key][0]; + $type = $this->const[$key][1]; + $val = $this->const[$key][2]; + $note = $this->const[$key][3]; + + $sql = "SELECT count(*) FROM llx_const WHERE name ='".$name."'"; + + if ( $this->db->query($sql) ) + { + $row = $this->db->fetch_row($sql); + + if ($row[0] == 0) + { + if (strlen($note)){ + $sql = "INSERT INTO llx_const (name,type,value,note) VALUES ('".$name."','".$type."','".$val."','$note')"; + }elseif (strlen($val)) + { + $sql = "INSERT INTO llx_const (name,type,value) VALUES ('".$name."','".$type."','".$val."')"; + } + else + { + $sql = "INSERT INTO llx_const (name,type) VALUES ('".$name."','".$type."')"; + } + + if (! $this->db->query($sql) ) + { + $err++; + } + } + } + else + { + $err++; + } + } + + + /* + * + */ + + for ($i = 0 ; $i < sizeof($array_sql) ; $i++) + { + if (! $this->db->query($array_sql[$i])) + { + $err++; + } + } + + if ($err > 0) + { + return 0; + } + else + { + return 1; + } + } + /* + * + * + */ + Function _remove($array_sql) + { + $err = 0; + + $sql = "DELETE FROM llx_const WHERE name = '".$this->const_name."'"; + + if (!$this->db->query($sql)) + { + $err++; + } + + for ($i = 0 ; $i < sizeof($array_sql) ; $i++) + { + + if (!$this->db->query($array_sql[$i])) + { + $err++; + } + } + + /* + * Boites + */ + foreach ($this->boxes as $key => $value) + { + $titre = $this->boxes[$key][0]; + $file = $this->boxes[$key][1]; + + $sql = "DELETE FROM llx_boxes_def WHERE file = '".$file."'"; + if (! $this->db->query($sql) ) + { + $err++; + } + } + + if ($err > 0) + { + return 0; + } + else + { + return 1; + } + } + +} +?>