2015-12-11 05:08:32 +01:00
#!/usr/bin/env php
2011-07-09 16:11:40 +02:00
< ? php
2005-08-12 23:24:47 +02:00
/* Copyright ( C ) 2005 Rodolphe Quiedeville < rodolphe @ quiedeville . org >
2007-08-26 14:10:50 +02:00
* Copyright ( C ) 2007 Laurent Destailleur < eldy @ users . sourceforge . net >
2005-08-12 23:24:47 +02:00
*
* 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
2013-01-16 15:36:08 +01:00
* the Free Software Foundation ; either version 3 of the License , or
2005-08-12 23:24:47 +02:00
* ( 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
2011-08-01 00:21:57 +02:00
* along with this program . If not , see < http :// www . gnu . org / licenses />.
2005-08-12 23:24:47 +02:00
*
* ATTENTION DE PAS EXECUTER CE SCRIPT SUR UNE INSTALLATION DE PRODUCTION
*/
2005-08-25 22:27:17 +02:00
/**
2015-11-09 16:48:30 +01:00
* \file dev / initdata / generate - proposal . php
* \brief Script example to inject random proposals ( for load tests )
2010-01-20 19:36:42 +01:00
*/
2005-08-25 22:27:17 +02:00
2007-08-26 14:10:50 +02:00
// Test si mode batch
$sapi_type = php_sapi_name ();
if ( substr ( $sapi_type , 0 , 3 ) == 'cgi' ) {
2010-05-02 20:02:43 +02:00
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 ;
2007-08-26 14:10:50 +02:00
}
// Recupere root dolibarr
2016-07-15 19:44:45 +02:00
//$path=preg_replace('/generate-propale.php/i','',$_SERVER["PHP_SELF"]);
require ( __DIR__ . '/../../htdocs/master.inc.php' );
2010-04-25 16:17:39 +02:00
require_once ( DOL_DOCUMENT_ROOT . " /compta/facture/class/facture.class.php " );
2010-04-28 19:30:59 +02:00
require_once ( DOL_DOCUMENT_ROOT . " /comm/propal/class/propal.class.php " );
2010-04-27 10:13:42 +02:00
require_once ( DOL_DOCUMENT_ROOT . " /commande/class/commande.class.php " );
2010-04-29 16:54:12 +02:00
require_once ( DOL_DOCUMENT_ROOT . " /societe/class/societe.class.php " );
2005-08-12 23:24:47 +02:00
2007-08-26 14:10:50 +02:00
/*
* Parameters
*/
2012-02-15 13:58:37 +01:00
define ( GEN_NUMBER_PROPAL , 5 );
2005-08-12 23:24:47 +02:00
2010-07-10 01:13:44 +02:00
$ret = $user -> fetch ( '' , 'admin' );
if ( ! $ret > 0 )
2005-08-12 23:24:47 +02:00
{
2010-07-10 01:13:44 +02:00
print 'A user with login "admin" and all permissions must be created to use this script.' . " \n " ;
exit ;
2005-08-12 23:24:47 +02:00
}
2010-07-10 01:13:44 +02:00
$user -> getrights ();
2005-08-12 23:24:47 +02:00
$socids = array ();
2007-06-12 00:51:47 +02:00
$sql = " SELECT rowid FROM " . MAIN_DB_PREFIX . " societe WHERE client=1 " ;
2005-08-12 23:24:47 +02:00
$resql = $db -> query ( $sql );
2010-01-20 19:36:42 +01:00
if ( $resql )
2005-08-12 23:24:47 +02:00
{
2010-05-02 20:02:43 +02:00
$num_socs = $db -> num_rows ( $resql );
$i = 0 ;
while ( $i < $num_socs )
{
$i ++ ;
$row = $db -> fetch_row ( $resql );
$socids [ $i ] = $row [ 0 ];
}
2005-08-12 23:24:47 +02:00
}
$contids = array ();
2007-06-12 00:51:47 +02:00
$sql = " SELECT rowid, fk_soc FROM " . MAIN_DB_PREFIX . " socpeople " ;
2005-08-12 23:24:47 +02:00
$resql = $db -> query ( $sql );
2010-01-20 19:36:42 +01:00
if ( $resql )
2005-08-12 23:24:47 +02:00
{
2010-05-02 20:02:43 +02:00
$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
}
2005-08-12 23:24:47 +02:00
}
$prodids = array ();
2010-08-11 20:35:31 +02:00
$sql = " SELECT rowid FROM " . MAIN_DB_PREFIX . " product WHERE tosell=1 " ;
2005-08-12 23:24:47 +02:00
$resql = $db -> query ( $sql );
2010-01-20 19:36:42 +01:00
if ( $resql )
2005-08-12 23:24:47 +02:00
{
2010-05-02 20:02:43 +02:00
$num_prods = $db -> num_rows ( $resql );
$i = 0 ;
while ( $i < $num_prods )
{
$i ++ ;
$row = $db -> fetch_row ( $resql );
$prodids [ $i ] = $row [ 0 ];
}
2005-08-12 23:24:47 +02:00
}
2015-01-25 21:32:40 +01:00
$user -> rights -> propal -> creer = 1 ;
$user -> rights -> propal -> propal_advance -> validate = 1 ;
2005-08-12 23:24:47 +02:00
2011-10-24 14:11:49 +02:00
if ( ! empty ( $conf -> global -> PROPALE_ADDON ) && is_readable ( DOL_DOCUMENT_ROOT . " /core/modules/propale/ " . $conf -> global -> PROPALE_ADDON . " .php " ))
2005-08-12 23:24:47 +02:00
{
2011-10-24 14:11:49 +02:00
require_once ( DOL_DOCUMENT_ROOT . " /core/modules/propale/ " . $conf -> global -> PROPALE_ADDON . " .php " );
2005-08-12 23:24:47 +02:00
}
$i = 0 ;
2007-08-26 14:10:50 +02:00
$result = 0 ;
while ( $i < GEN_NUMBER_PROPAL && $result >= 0 )
2005-08-12 23:24:47 +02:00
{
2006-06-17 01:55:20 +02:00
$i ++ ;
$socid = rand ( 1 , $num_socs );
2010-05-02 20:02:43 +02:00
print " Proposal " . $i . " for socid " . $socid ;
2010-01-20 19:36:42 +01:00
2006-06-17 01:55:20 +02:00
$soc = new Societe ( $db );
2010-01-20 19:36:42 +01:00
2014-08-01 14:26:13 +02:00
$propal = new Propal ( $db );
2010-07-10 01:13:44 +02:00
2006-06-17 01:55:20 +02:00
$obj = $conf -> global -> PROPALE_ADDON ;
$modPropale = new $obj ;
2010-07-10 01:13:44 +02:00
$numpr = $modPropale -> getNextValue ( $soc , $propal );
2010-01-20 19:36:42 +01:00
2006-06-17 01:55:20 +02:00
$propal -> ref = $numpr ;
$propal -> contactid = $contids [ $socids [ $socid ]][ 0 ];
2014-08-01 14:26:13 +02:00
$propal -> socid = $socids [ $socid ];
2006-06-17 01:55:20 +02:00
$propal -> datep = time ();
2007-08-26 14:10:50 +02:00
$propal -> cond_reglement_id = 3 ;
$propal -> mode_reglement_id = 3 ;
2006-06-17 01:55:20 +02:00
$propal -> author = $user -> id ;
2010-01-20 19:36:42 +01:00
2007-08-26 14:10:50 +02:00
$result = $propal -> create ( $user );
if ( $result >= 0 )
{
$nbp = rand ( 2 , 5 );
$xnbp = 0 ;
while ( $xnbp < $nbp )
{
$prodid = rand ( 1 , $num_prods );
2013-07-13 10:34:19 +02:00
$product = new Product ( $db );
$result = $product -> fetch ( $prodids [ $prodid ]);
2013-07-10 17:29:54 +02:00
$result = $propal -> addline ( $product -> description , $product -> price , rand ( 1 , 5 ), 0 , 0 , 0 , $prodids [ $prodid ], 0 );
2007-08-26 14:10:50 +02:00
if ( $result < 0 )
{
2009-02-20 23:53:15 +01:00
dol_print_error ( $db , $propal -> error );
2007-08-26 14:10:50 +02:00
}
$xnbp ++ ;
}
2010-07-10 01:13:44 +02:00
print " OK with ref " . $propal -> ref . " \n " ;
2007-08-26 14:10:50 +02:00
}
else
2006-06-17 01:55:20 +02:00
{
2009-02-20 23:53:15 +01:00
dol_print_error ( $db , $propal -> error );
2006-06-17 01:55:20 +02:00
}
2005-08-12 23:24:47 +02:00
}