2013-08-26 07:08:21 +00:00
|
|
|
<?php
|
|
|
|
error_reporting(E_ALL ^ E_STRICT ^ E_NOTICE ^ E_WARNING);
|
|
|
|
|
|
|
|
// Define path to application directory
|
|
|
|
defined('APPLICATION_PATH')
|
2013-08-29 07:10:06 +00:00
|
|
|
|| define('APPLICATION_PATH', realpath(dirname(__FILE__) . '/../../application'));
|
2013-08-26 07:08:21 +00:00
|
|
|
|
|
|
|
// Define application environment
|
|
|
|
defined('APPLICATION_ENV')
|
2013-08-29 07:10:06 +00:00
|
|
|
|| define('APPLICATION_ENV', (getenv('APPLICATION_ENV') ? getenv('APPLICATION_ENV') : 'production'));
|
2013-08-26 07:08:21 +00:00
|
|
|
|
|
|
|
// Ensure library/ is on include_path
|
|
|
|
set_include_path(implode(PATH_SEPARATOR, array(
|
2013-08-29 07:10:06 +00:00
|
|
|
realpath(APPLICATION_PATH . '/../library'),
|
|
|
|
get_include_path(),
|
2013-08-26 07:08:21 +00:00
|
|
|
)));
|
|
|
|
|
|
|
|
/** Zend_Application */
|
|
|
|
require_once 'Zend/Application.php';
|
|
|
|
|
|
|
|
// Create application, bootstrap, and run
|
|
|
|
$application = new Zend_Application(
|
|
|
|
APPLICATION_ENV,
|
|
|
|
APPLICATION_PATH . '/configs/application.ini'
|
|
|
|
);
|
|
|
|
|
|
|
|
try {
|
|
|
|
$opts = new Zend_Console_Getopt(
|
|
|
|
//Options
|
|
|
|
array(
|
|
|
|
'help|?' => "Displays usage information.",
|
2013-08-28 15:07:16 +00:00
|
|
|
'cron' => "Mandatory option for launch the cli in cron",
|
2013-09-02 10:12:16 +00:00
|
|
|
'regen=s' => "Specify the file name to execute or regenerate output file",
|
2013-08-28 15:07:16 +00:00
|
|
|
'manual=s' => "Provide manualy the file path to get result and debug values",
|
2013-09-02 10:12:16 +00:00
|
|
|
'resume=s' => "Use with --regen and --manual to resume the file",
|
2013-08-26 07:08:21 +00:00
|
|
|
'debug' => "Send a mail for debug",
|
|
|
|
)
|
|
|
|
);
|
|
|
|
$opts->parse();
|
|
|
|
} catch (Zend_Console_Getopt_Exception $e) {
|
|
|
|
echo $e->getUsageMessage();
|
|
|
|
exit;
|
|
|
|
}
|
|
|
|
|
|
|
|
//Usage
|
|
|
|
if( isset($opts->help) || count($opts->getOptions())==0 )
|
|
|
|
{
|
|
|
|
echo "Place files in right directory for sending to the customer.\n";
|
|
|
|
echo $opts->getUsageMessage();
|
|
|
|
exit;
|
|
|
|
}
|
|
|
|
|
|
|
|
require_once APPLICATION_PATH.'/configs/config.php';
|
|
|
|
|
|
|
|
require_once 'framework/fwk.php';
|
|
|
|
require_once 'framework/common/chiffres.php';
|
|
|
|
require_once 'framework/common/dates.php';
|
|
|
|
require_once 'framework/mail/sendMail.php';
|
|
|
|
require_once 'framework/common/mysql.php';
|
|
|
|
|
|
|
|
require_once 'Metier/insee/classMInsee.php';
|
|
|
|
require_once 'Metier/scores/classMSolvabilite.php';
|
|
|
|
require_once 'Metier/partenaires/classMLiens.php';
|
|
|
|
|
|
|
|
$c = new Zend_Config($application->getOptions());
|
|
|
|
$db = Zend_Db::factory($c->profil->db->metier);
|
|
|
|
Zend_Db_Table_Abstract::setDefaultAdapter($db);
|
|
|
|
|
2013-09-02 10:12:16 +00:00
|
|
|
//Input path
|
|
|
|
$pathIn = $c->profil->path->storage .
|
|
|
|
DIRECTORY_SEPARATOR . 'clients' .
|
|
|
|
DIRECTORY_SEPARATOR . strtolower($client) .
|
|
|
|
DIRECTORY_SEPARATOR . 'send';
|
|
|
|
|
|
|
|
//Output path
|
|
|
|
$pathOut = $c->profil->path->storage .
|
|
|
|
DIRECTORY_SEPARATOR . 'clients' .
|
|
|
|
DIRECTORY_SEPARATOR . strtolower($client) .
|
|
|
|
DIRECTORY_SEPARATOR . 'recv';
|
|
|
|
|
2013-08-26 07:08:21 +00:00
|
|
|
//Configuration
|
|
|
|
$fileOptionsIn = array(
|
2013-09-02 10:12:16 +00:00
|
|
|
'dir' => $pathIn,
|
2013-08-26 07:08:21 +00:00
|
|
|
'type' => 'csv',
|
|
|
|
'delimiter' => ';',
|
|
|
|
'enclosure' => '"',
|
|
|
|
'header' => array('idDemande', 'SSAEmetteur'),
|
|
|
|
'columns' => array('siren', 'nbLignes', 'dateContrat', 'nbContrats', 'ir'),
|
|
|
|
);
|
|
|
|
|
|
|
|
$fileOkOptionsOut = array(
|
2013-09-02 10:12:16 +00:00
|
|
|
'dir' => $pathOut,
|
2013-08-26 07:08:21 +00:00
|
|
|
'type' => 'csv',
|
|
|
|
'delimiter' => ';',
|
|
|
|
'enclosure' => '"',
|
|
|
|
'header' => array('idDemande', 'SSAEmetteur'),
|
|
|
|
'columns' => array('siren', 'idVOR', 'PO', 'commentaire'),
|
|
|
|
'name' => 'FICH_RCE_RETOUR_',
|
|
|
|
);
|
|
|
|
|
|
|
|
$fileErrorOptionsOut = array(
|
2013-09-02 10:12:16 +00:00
|
|
|
'dir' => $pathOut,
|
2013-08-26 07:08:21 +00:00
|
|
|
'type' => 'csv',
|
|
|
|
'delimiter' => ';',
|
|
|
|
'enclosure' => '"',
|
|
|
|
'header' => array('idDemande', 'SSAEmetteur'),
|
|
|
|
'columns' => array('siren', 'code'),
|
|
|
|
'name' => 'FICH_RCE_ERREUR_',
|
|
|
|
);
|
|
|
|
|
|
|
|
$client = 'SFR';
|
|
|
|
$typeDepot = 'SFTP';
|
2013-08-26 09:46:25 +00:00
|
|
|
$prestation = 'FICH_RCE';
|
2013-08-26 07:08:21 +00:00
|
|
|
|
2013-09-02 10:12:16 +00:00
|
|
|
//Get the file to resume
|
|
|
|
//@todo : Define the real use header return by the internal function to not guess the header
|
|
|
|
if ( $opts->resume ) {
|
|
|
|
if ( file_exists($pathOut . DIRECTORY_SEPARATOR . $opts->resume) ) {
|
|
|
|
if (($handle = fopen($pathOut . DIRECTORY_SEPARATOR . $opts->resume, 'r')) !== false) {
|
|
|
|
$row = 0;
|
|
|
|
while (($data = fgetcsv($handle, 0, $fileOptionsIn['delimiter'], $fileOptionsIn['enclosure'])) !== false)
|
|
|
|
{
|
|
|
|
$row++;
|
|
|
|
$fileOkOptionsOut['line'][] = $data;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
fclose($handle);
|
|
|
|
} else {
|
|
|
|
echo "Fichier introuvable !" . PHP_EOL;
|
|
|
|
exit;
|
|
|
|
}
|
|
|
|
|
|
|
|
$resumeAt = $row;
|
|
|
|
}
|
|
|
|
|
2013-08-28 15:07:16 +00:00
|
|
|
// => Debug Mode - Create file with debug values
|
2013-08-26 07:08:21 +00:00
|
|
|
if ( $opts->manual ) {
|
|
|
|
|
|
|
|
$filepath = $opts->manual;
|
2013-09-03 14:54:52 +00:00
|
|
|
$pathOut = dirname(realpath($filepath));
|
2013-08-26 07:08:21 +00:00
|
|
|
|
2013-09-03 14:54:52 +00:00
|
|
|
$fileOptionsIn['dir'] = $pathOut;
|
2013-09-02 10:12:16 +00:00
|
|
|
$fileErrorOptionsOut['dir'] = $pathOut;
|
|
|
|
$fileOkOptionsOut['dir'] = $pathOut;
|
2013-08-26 07:08:21 +00:00
|
|
|
|
2013-09-02 10:12:16 +00:00
|
|
|
$dateBegin = date('YmdHis');
|
|
|
|
$filesOutOptions = array(
|
|
|
|
'ok' => $fileOkOptionsOut,
|
|
|
|
'error' => $fileErrorOptionsOut
|
|
|
|
);
|
|
|
|
foreach ($filesOutOptions as $code => $file) {
|
|
|
|
$filesOutOptions[$code]['name'] = $file['name'] . $dateBegin . '.csv';
|
2013-08-26 07:08:21 +00:00
|
|
|
}
|
|
|
|
|
2013-09-02 10:12:16 +00:00
|
|
|
//Read file
|
|
|
|
$result = execFileIn($filepath, $fileOptionsIn, $filesOutOptions, true);
|
|
|
|
|
2013-08-26 07:08:21 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// => Automatic mode
|
2013-09-02 10:12:16 +00:00
|
|
|
if ($opts->cron || $opts->regen ) {
|
2013-08-28 15:07:16 +00:00
|
|
|
|
|
|
|
if ( $opts->cron ) {
|
|
|
|
|
|
|
|
//Lire les fichiers à traiter dans la table
|
|
|
|
$c = new Zend_Config($application->getOptions());
|
|
|
|
$db = Zend_Db::factory($c->profil->metier);
|
|
|
|
Zend_Db_Table::setDefaultAdapter($db);
|
|
|
|
|
|
|
|
//client, name, typeDepot, dateDepot, fileDepot, nblignes, dateInsert, dateExecute
|
|
|
|
$fluxinM = new Application_Model_Sdv1FluxFileIn();
|
|
|
|
$sql = $fluxinM->select()
|
|
|
|
->where('client=?',$client)
|
|
|
|
->where('name=?', $prestation)
|
|
|
|
->where('typeDepot=?',$typeDepot)
|
|
|
|
->where('dateExecute=?','0000-00-00 00:00:00')
|
|
|
|
->order('dateInsert DESC');
|
|
|
|
|
|
|
|
$pitems = $fluxinM->fetchAll($sql);
|
|
|
|
|
|
|
|
if ( $pitems->count()==0 ) {
|
|
|
|
//@todo : Send a mail
|
|
|
|
exit;
|
|
|
|
}
|
2013-08-26 07:08:21 +00:00
|
|
|
|
2013-08-27 08:50:25 +00:00
|
|
|
foreach ($pitems as $p) {
|
2013-09-02 10:12:16 +00:00
|
|
|
$filepath = $pathIn . DIRECTORY_SEPARATOR . $p->fileDepot;
|
2013-08-27 08:50:25 +00:00
|
|
|
break;
|
|
|
|
}
|
2013-08-26 07:08:21 +00:00
|
|
|
|
2013-08-28 15:07:16 +00:00
|
|
|
}
|
2013-08-26 07:08:21 +00:00
|
|
|
|
2013-09-02 10:12:16 +00:00
|
|
|
if ($opts->regen) {
|
|
|
|
$filepath = $pathIn . DIRECTORY_SEPARATOR . $opts->regen;
|
2013-08-28 15:07:16 +00:00
|
|
|
}
|
2013-08-26 07:08:21 +00:00
|
|
|
|
2013-08-28 15:07:16 +00:00
|
|
|
if ( !file_exists($filepath) ) {
|
|
|
|
echo "Fichier inexistant ! ".PHP_EOL;
|
|
|
|
exit;
|
|
|
|
}
|
|
|
|
|
2013-09-02 10:12:16 +00:00
|
|
|
$dateBegin = date('YmdHis');
|
|
|
|
$filesOutOptions = array(
|
|
|
|
'ok' => $fileOkOptionsOut,
|
|
|
|
'error' => $fileErrorOptionsOut
|
|
|
|
);
|
|
|
|
foreach ($filesOutOptions as $code => $file) {
|
|
|
|
$filesOutOptions[$code]['name'] = $file['name'] . $dateBegin . '.csv';
|
|
|
|
}
|
|
|
|
|
|
|
|
//Execute file
|
|
|
|
$result = execFileIn($filepath, $fileOptionsIn, $filesOutOptions, false);
|
2013-08-28 15:07:16 +00:00
|
|
|
|
|
|
|
$fluxoutM = new Application_Model_Sdv1FluxFileOut();
|
|
|
|
$rows = 0;
|
|
|
|
foreach($result as $code => $file) {
|
|
|
|
|
2013-09-02 10:12:16 +00:00
|
|
|
$rows = count($file[$code]['line']);
|
2013-08-26 07:08:21 +00:00
|
|
|
|
2013-08-28 15:07:16 +00:00
|
|
|
$dateEnd = date('YmdHis');
|
2013-08-26 07:08:21 +00:00
|
|
|
|
2013-08-28 15:07:16 +00:00
|
|
|
if ( $opts->cron ) {
|
2013-08-26 07:08:21 +00:00
|
|
|
$fluxoutM->insert(array(
|
|
|
|
'client' => $client,
|
2013-08-26 09:46:25 +00:00
|
|
|
'name' => $prestation,
|
2013-08-26 07:08:21 +00:00
|
|
|
'nbLines' => $rows,
|
|
|
|
'dateBegin' => $dateBegin,
|
|
|
|
'dateEnd' => $dateEnd,
|
2013-09-02 10:12:16 +00:00
|
|
|
'fileOut' => $file[$code]['name'],
|
2013-08-28 15:07:16 +00:00
|
|
|
'depotType' => $typeDepot,
|
|
|
|
'depotDate' => '0000-00-00 00:00:00',
|
2013-08-26 07:08:21 +00:00
|
|
|
));
|
|
|
|
}
|
2013-08-28 15:07:16 +00:00
|
|
|
}
|
|
|
|
if ( $opts->cron ) {
|
2013-08-26 07:08:21 +00:00
|
|
|
//Ecrire la date d'execution dans flux_filein
|
|
|
|
$fluxinM->update(array(
|
|
|
|
'dateExecute' => $dateEnd,
|
2013-08-27 08:50:25 +00:00
|
|
|
), 'id='.$p->id);
|
2013-08-26 07:08:21 +00:00
|
|
|
}
|
2013-08-28 15:07:16 +00:00
|
|
|
|
2013-08-26 07:08:21 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
*
|
2013-08-27 08:50:25 +00:00
|
|
|
* @param array $values
|
2013-08-28 15:07:16 +00:00
|
|
|
* @param string $seq
|
2013-08-26 07:08:21 +00:00
|
|
|
* @param string $debug
|
2013-08-28 15:07:16 +00:00
|
|
|
* @return array
|
2013-08-26 07:08:21 +00:00
|
|
|
*/
|
2013-08-28 15:07:16 +00:00
|
|
|
function execInternal($values, $seq, $debug = false)
|
2013-08-26 07:08:21 +00:00
|
|
|
{
|
|
|
|
$error = 0;
|
|
|
|
|
|
|
|
$siren = $values['siren'];
|
|
|
|
|
|
|
|
echo "$siren";
|
|
|
|
|
|
|
|
$classInsee = new MInsee();
|
|
|
|
|
2013-08-28 15:07:16 +00:00
|
|
|
$values['code'] = '';
|
2013-08-26 07:08:21 +00:00
|
|
|
//Siren valide - 1010
|
|
|
|
if ( !$classInsee->valideSiren($siren) ) {
|
|
|
|
$error = 1;
|
2013-08-30 13:45:56 +00:00
|
|
|
$code = 'error';
|
2013-08-26 07:08:21 +00:00
|
|
|
$values['code'] = '1010';
|
2013-08-27 08:50:25 +00:00
|
|
|
echo " - Erreur 1010.";
|
2013-08-26 07:08:21 +00:00
|
|
|
}
|
|
|
|
//Siren existant - 1020
|
2013-08-27 08:50:25 +00:00
|
|
|
else if ( !$classInsee->sirenExiste($siren) ) {
|
2013-08-26 07:08:21 +00:00
|
|
|
$error = 1;
|
2013-08-30 13:45:56 +00:00
|
|
|
$code = 'error';
|
2013-08-26 07:08:21 +00:00
|
|
|
$values['code'] = '1020';
|
2013-08-27 08:50:25 +00:00
|
|
|
echo " - Erreur 1020.";
|
2013-08-26 07:08:21 +00:00
|
|
|
}
|
|
|
|
|
2013-08-27 08:50:25 +00:00
|
|
|
if ( $error == 0 ) {
|
2013-08-26 07:08:21 +00:00
|
|
|
//Calculate data
|
|
|
|
require_once 'Metier/Sfr/Sfr.php';
|
|
|
|
$sfrM = new Metier_Sfr();
|
2013-08-26 09:46:25 +00:00
|
|
|
|
|
|
|
//Set Values
|
2013-09-05 07:06:38 +00:00
|
|
|
$sfrM->setVal('ContratDate', $values['dateContrat']);
|
|
|
|
$sfrM->setVal('IR', $values['ir']);
|
2013-08-26 09:46:25 +00:00
|
|
|
|
|
|
|
//Evaluate
|
2013-08-26 07:08:21 +00:00
|
|
|
$sfrM->evaluate($siren);
|
|
|
|
$values['idVOR'] = $sfrM->getIndicateur();
|
|
|
|
$values['commentaire'] = $sfrM->getComment();
|
|
|
|
$values['PO'] = $sfrM->getPo();
|
|
|
|
|
2013-08-27 08:50:25 +00:00
|
|
|
$valuesDebug = $sfrM->getValDebug();
|
2013-08-26 07:08:21 +00:00
|
|
|
if ($debug) {
|
|
|
|
$values = array_merge($values, $valuesDebug);
|
|
|
|
}
|
|
|
|
|
2013-08-30 13:45:56 +00:00
|
|
|
$code = 'ok';
|
|
|
|
|
2013-08-27 08:50:25 +00:00
|
|
|
echo " - VOR=".$values['idVOR']." , commentaire=".$values['commentaire']." , PO=".$values['PO'];
|
|
|
|
}
|
|
|
|
|
|
|
|
echo PHP_EOL;
|
|
|
|
|
|
|
|
if ( !$debug ) {
|
|
|
|
$sfrDataM = new Application_Model_JoSfrData();
|
|
|
|
$sfrDataM->insert(array(
|
2013-08-28 15:07:16 +00:00
|
|
|
'NumSeq' => $seq,
|
|
|
|
'siren' => $siren,
|
|
|
|
'NbLignes' => $values['nbLignes'],
|
|
|
|
'NbContrats' => $values[''],
|
|
|
|
'DateContrat' => $values['dateContrat'],
|
|
|
|
'IR' => $values['ir'],
|
|
|
|
'IdVOR' => $values['idVOR'],
|
|
|
|
'comment' => $values['comment'],
|
|
|
|
'PO' => $values['PO'],
|
|
|
|
'debug' => json_encode($valuesDebug),
|
|
|
|
'error' => $values['code'],
|
2013-08-27 08:50:25 +00:00
|
|
|
));
|
2013-08-26 07:08:21 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
return array(
|
|
|
|
'values' => $values,
|
2013-08-30 13:45:56 +00:00
|
|
|
'code' => $code,
|
2013-08-26 07:08:21 +00:00
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
*
|
2013-09-02 10:12:16 +00:00
|
|
|
* @param string $file
|
2013-08-26 09:46:25 +00:00
|
|
|
* @param array $fileOptionsIn
|
|
|
|
* @param array $filesOptionsOut
|
|
|
|
* @param boolean $debug
|
2013-09-02 10:12:16 +00:00
|
|
|
* @param boolean $resume
|
|
|
|
* @return array
|
2013-08-26 07:08:21 +00:00
|
|
|
*/
|
2013-09-02 10:12:16 +00:00
|
|
|
function execFileIn($file, $fileOptionsIn, $filesOptionsOut = array(), $debug = false, $resume = false)
|
2013-08-26 07:08:21 +00:00
|
|
|
{
|
2013-09-02 10:12:16 +00:00
|
|
|
//Set the input file path
|
|
|
|
$filepathIn = $fileOptionsIn['dir'] . DIRECTORY_SEPARATOR . $file;
|
2013-08-26 07:08:21 +00:00
|
|
|
|
2013-09-02 10:12:16 +00:00
|
|
|
//Open output file path
|
2013-09-03 14:54:52 +00:00
|
|
|
foreach ($filesOptionsOut as $code => $file) {
|
2013-09-02 10:12:16 +00:00
|
|
|
${'fp'.$code} = fopen($file['dir'] . DIRECTORY_SEPARATOR . $file['name'], 'w');
|
|
|
|
}
|
|
|
|
|
|
|
|
//Read file
|
|
|
|
if ( file_exists($filepathIn) ) {
|
2013-08-26 07:08:21 +00:00
|
|
|
|
2013-09-02 10:12:16 +00:00
|
|
|
if (($handle = fopen($filepathIn, 'r')) !== false) {
|
2013-08-26 07:08:21 +00:00
|
|
|
$row = 0;
|
|
|
|
while (($data = fgetcsv($handle, 0, $fileOptionsIn['delimiter'], $fileOptionsIn['enclosure'])) !== false)
|
|
|
|
{
|
|
|
|
$row++;
|
|
|
|
|
|
|
|
echo "Ligne $row : ";
|
|
|
|
|
|
|
|
//Header
|
|
|
|
if (count($fileOptionsIn['header']) > 0 && $row == 1) {
|
|
|
|
foreach ( $fileOptionsIn['header'] as $i => $column ) {
|
|
|
|
$header[$column] = $data[$i];
|
|
|
|
}
|
|
|
|
echo "Detection HEADER.".PHP_EOL;
|
|
|
|
|
|
|
|
if ($debug) {
|
2013-09-02 10:12:16 +00:00
|
|
|
$filesOptionsOut['error']['header'] = array();
|
|
|
|
$filesOptionsOut['ok']['header'] = array();
|
2013-08-26 07:08:21 +00:00
|
|
|
} else {
|
2013-09-02 10:12:16 +00:00
|
|
|
$filesOptionsOut['error']['header'] = $header;
|
|
|
|
$filesOptionsOut['ok']['header'] = $header;
|
|
|
|
}
|
|
|
|
|
|
|
|
if ( $resume ) {
|
|
|
|
fputcsv(${'fp'.$codeRetour}, $filesOptionsOut['ok']['line'][0], $filesOptionsOut['ok']['delimiter'], $filesOptionsOut['ok']['enclosure']);
|
2013-08-26 07:08:21 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
//Content
|
|
|
|
else {
|
|
|
|
|
2013-08-27 08:50:25 +00:00
|
|
|
//Set values from file
|
2013-08-26 07:08:21 +00:00
|
|
|
$values = array();
|
|
|
|
foreach ( $fileOptionsIn['columns'] as $i => $column ) {
|
|
|
|
$values[$column] = $data[$i];
|
|
|
|
}
|
|
|
|
|
2013-09-02 10:12:16 +00:00
|
|
|
$isResume = false;
|
2013-08-26 07:08:21 +00:00
|
|
|
|
2013-09-02 10:12:16 +00:00
|
|
|
if ( $resume ) {
|
|
|
|
foreach ( $filesOptionsOut['ok']['line'] as $line ) {
|
|
|
|
if ( $line[0] == $data[0] ) {
|
|
|
|
fputcsv(${'fp'.$codeRetour}, $line, $filesOptionsOut['ok']['delimiter'], $filesOptionsOut['ok']['enclosure']);
|
|
|
|
$isResume = true;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
2013-08-26 07:08:21 +00:00
|
|
|
}
|
|
|
|
|
2013-09-02 10:12:16 +00:00
|
|
|
if ( !$isResume ) {
|
|
|
|
|
|
|
|
//Exec the process
|
|
|
|
$valuesClient = execInternal($values, $header['idDemande'], true);
|
|
|
|
|
|
|
|
//Format output
|
|
|
|
$codeRetour = $valuesClient['code'];
|
|
|
|
$filesOptionsOut[$codeRetour]['line'][] = $valuesClient['values'];
|
|
|
|
if ($debug) {
|
|
|
|
$filesOptionsOut[$codeRetour]['columns'] = array_keys($valuesClient['values']);
|
|
|
|
}
|
|
|
|
|
2013-09-03 14:54:52 +00:00
|
|
|
if ($row == 2) {
|
|
|
|
foreach ($filesOptionsOut as $code => $file) {
|
2013-09-02 10:12:16 +00:00
|
|
|
$line = array();
|
|
|
|
//Dynamic Header
|
|
|
|
if ( count($file['header'])>0 ) {
|
|
|
|
foreach ( $file['header'] as $i => $column ) {
|
|
|
|
$line[] = $column;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
//Static Header
|
|
|
|
else {
|
|
|
|
foreach ( $file['columns'] as $i => $column ) {
|
|
|
|
$line[] = $column;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
fputcsv(${'fp'.$code}, $line, $filesOptionsOut[$code]['delimiter'], $filesOptionsOut[$code]['enclosure']);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
//Write the line following the return code
|
|
|
|
$line = array();
|
|
|
|
foreach ( $filesOptionsOut[$codeRetour]['columns'] as $i => $column ) {
|
2013-09-03 14:54:52 +00:00
|
|
|
$line[] = $valuesClient['values'][$column];
|
2013-09-02 10:12:16 +00:00
|
|
|
}
|
|
|
|
fputcsv(${'fp'.$codeRetour}, $line, $filesOptionsOut[$codeRetour]['delimiter'], $filesOptionsOut[$codeRetour]['enclosure']);
|
|
|
|
}
|
2013-08-26 07:08:21 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
fclose($handle);
|
|
|
|
|
2013-09-02 10:12:16 +00:00
|
|
|
foreach ($filesOutOptions as $code => $file) {
|
|
|
|
fclose(${'fp'.$code});
|
|
|
|
}
|
|
|
|
|
2013-08-26 07:08:21 +00:00
|
|
|
return $output;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
*
|
2013-08-27 08:50:25 +00:00
|
|
|
* @param string $file
|
|
|
|
* @param array $options
|
2013-08-26 07:08:21 +00:00
|
|
|
*/
|
|
|
|
function execFileOut($file, $options)
|
|
|
|
{
|
|
|
|
$fp = fopen($file, 'w');
|
|
|
|
|
|
|
|
//=> Header
|
|
|
|
$line = array();
|
|
|
|
//Dynamic Header
|
|
|
|
if ( count($options['header'])>0 ) {
|
|
|
|
foreach ( $options['header'] as $i => $column ) {
|
|
|
|
$line[] = $column;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
//Static Header
|
|
|
|
else {
|
|
|
|
foreach ( $options['columns'] as $i => $column ) {
|
|
|
|
$line[] = $column;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
fputcsv($fp, $line, $options['delimiter'], $options['enclosure']);
|
|
|
|
|
|
|
|
//=> Content
|
|
|
|
if ( count($options['line'])>0 ) {
|
|
|
|
foreach ($options['line'] as $c ) {
|
|
|
|
$line = array();
|
|
|
|
foreach ( $options['columns'] as $i => $column ) {
|
|
|
|
$line[] = $c[$column];
|
|
|
|
}
|
|
|
|
fputcsv($fp, $line, $options['delimiter'], $options['enclosure']);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
fclose($fp);
|
2013-08-26 09:46:25 +00:00
|
|
|
|
|
|
|
return count($options['line']);
|
2013-08-26 07:08:21 +00:00
|
|
|
}
|