* Copyright (C) 2007 Laurent Destailleur * * 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. * * ATTENTION DE PAS EXECUTER CE SCRIPT SUR UNE INSTALLATION DE PRODUCTION */ /** * \file htdocs/dev/generate-propale.php * \brief Script de generation de donnees aleatoires pour les propales * \version $Id$ */ // Test si mode batch $sapi_type = php_sapi_name(); if (substr($sapi_type, 0, 3) == 'cgi') { echo "Erreur: Vous utilisez l'interpreteur PHP pour le mode CGI. Pour executer mailing-send.php en ligne de commande, vous devez utiliser l'interpreteur PHP pour le mode CLI.\n"; exit; } // Recupere root dolibarr $path=preg_replace('/generate-propale.php/i','',$_SERVER["PHP_SELF"]); require ($path."../htdocs/master.inc.php"); require_once(DOL_DOCUMENT_ROOT."/facture.class.php"); require_once(DOL_DOCUMENT_ROOT."/propal.class.php"); require_once(DOL_DOCUMENT_ROOT."/commande/commande.class.php"); require_once(DOL_DOCUMENT_ROOT."/societe.class.php"); /* * Parameters */ define (GEN_NUMBER_PROPAL, 5); $sql = "SELECT min(rowid) FROM ".MAIN_DB_PREFIX."user"; $resql = $db->query($sql); if ($resql) { $row = $db->fetch_row($resql); $user = new User($db, $row[0]); } $socids = array(); $sql = "SELECT rowid FROM ".MAIN_DB_PREFIX."societe WHERE client=1"; $resql = $db->query($sql); if ($resql) { $num_socs = $db->num_rows($resql); $i = 0; while ($i < $num_socs) { $i++; $row = $db->fetch_row($resql); $socids[$i] = $row[0]; } } $contids = array(); $sql = "SELECT rowid, fk_soc FROM ".MAIN_DB_PREFIX."socpeople"; $resql = $db->query($sql); if ($resql) { $num_conts = $db->num_rows($resql); $i = 0; while ($i < $num_conts) { $i++; $row = $db->fetch_row($resql); $contids[$row[1]][0] = $row[0]; // A ameliorer } } $prodids = array(); $sql = "SELECT rowid FROM ".MAIN_DB_PREFIX."product WHERE envente=1"; $resql = $db->query($sql); if ($resql) { $num_prods = $db->num_rows($resql); $i = 0; while ($i < $num_prods) { $i++; $row = $db->fetch_row($resql); $prodids[$i] = $row[0]; } } $user->rights->propale->valider=1; if (! empty($conf->global->PROPALE_ADDON) && is_readable(DOL_DOCUMENT_ROOT ."/includes/modules/propale/".$conf->global->PROPALE_ADDON.".php")) { require_once(DOL_DOCUMENT_ROOT ."/includes/modules/propale/".$conf->global->PROPALE_ADDON.".php"); } $i=0; $result=0; while ($i < GEN_NUMBER_PROPAL && $result >= 0) { $i++; $socid = rand(1, $num_socs); print "Proposal ".$i." for socid ".$socid; $soc = new Societe($db); $obj = $conf->global->PROPALE_ADDON; $modPropale = new $obj; $numpr = $modPropale->getNextValue($soc); $propal = new Propal($db, $socids[$socid]); $propal->ref = $numpr; $propal->contactid = $contids[$socids[$socid]][0]; $propal->datep = time(); $propal->cond_reglement_id = 3; $propal->mode_reglement_id = 3; $propal->author = $user->id; $result=$propal->create($user); if ($result >= 0) { $nbp = rand(2, 5); $xnbp = 0; while ($xnbp < $nbp) { $prodid = rand(1, $num_prods); $result=$propal->addline($propal->id, 'Description '.$xnbp, '100', rand(1,5), '19.6', $prodids[$prodid], 0); if ($result < 0) { dol_print_error($db,$propal->error); } $xnbp++; } print " OK"; } else { dol_print_error($db,$propal->error); } print "\n"; } ?>