2013-08-26 07:08:21 +00:00
< ? php
2013-09-24 08:12:55 +00:00
/*
* Crontab
2013-10-23 10:20:57 +00:00
* 01 19 * * 1 - 6 scores php / home / scores / batch / scripts / clients / SfrIndicateur . php -- cron -- load >> / home / scores / log / SfrIndicateur . log
* 01 00 * * 1 - 6 scores php / home / scores / batch / scripts / clients / SfrIndicateur . php -- cron -- evaluate >> / home / scores / log / SfrIndicateur . log
2013-09-24 08:12:55 +00:00
*/
2015-01-19 15:25:39 +00:00
error_reporting ( E_ALL & ~ E_STRICT & ~ E_NOTICE & ~ E_WARNING & ~ E_DEPRECATED );
2013-10-21 09:43:01 +00:00
2013-08-26 07:08:21 +00:00
// 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
)));
2014-08-04 14:45:48 +00:00
//Use classmap autoloader - useful with opcode and realpath cache
require_once 'Zend/Loader/AutoloaderFactory.php' ;
require_once 'Zend/Loader/ClassMapAutoloader.php' ;
Zend_Loader_AutoloaderFactory :: factory ( array (
'Zend_Loader_ClassMapAutoloader' => array (
2015-07-20 08:14:39 +00:00
__DIR__ . '/../../library/autoload_classmap.php' ,
2014-08-04 14:45:48 +00:00
),
'Zend_Loader_StandardAutoloader' => array (
'prefixes' => array (
'Zend' => __DIR__ . '/../../library/Zend' ,
'Application' => __DIR__ . '/../../library/Application' ,
'Scores' => __DIR__ . '/../../library/Scores' ,
'SdMetier' => __DIR__ . '/../../library/SdMetier' ,
'Metier' => __DIR__ . '/../../library/Metier' ,
),
'fallback_autoloader' => true
)
));
// Zend_Application - Use it if you don't have autoloaders
//require_once 'Zend/Application.php';
2013-08-26 07:08:21 +00:00
// Create application, bootstrap, and run
$application = new Zend_Application (
2014-08-04 14:45:48 +00:00
APPLICATION_ENV ,
APPLICATION_PATH . '/configs/application.ini'
2013-08-26 07:08:21 +00:00
);
try {
$opts = new Zend_Console_Getopt (
//Options
array (
2013-09-13 15:45:54 +00:00
'help|?' => " Displays usage information. " ,
2013-10-02 09:58:37 +00:00
'load-s' => " Preload file in database and check SIREN " ,
2013-09-13 15:45:54 +00:00
'evaluate-s' => " Lauch evaluation (specify the Seq Number to regen) " ,
2013-09-16 10:51:57 +00:00
'manual-s' => " Provide manualy the file path to get result and debug values " ,
2013-09-13 15:45:54 +00:00
'debug' => " Debug " ,
'cron' => " Mandatory option for launch the cli in cron " ,
2013-08-26 07:08:21 +00:00
)
);
$opts -> parse ();
} catch ( Zend_Console_Getopt_Exception $e ) {
echo $e -> getUsageMessage ();
exit ;
}
//Usage
if ( isset ( $opts -> help ) || count ( $opts -> getOptions ()) == 0 )
{
2013-09-13 15:45:54 +00:00
echo " Execute prestation SFR. \n " ;
2013-08-26 07:08:21 +00:00
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' ;
$c = new Zend_Config ( $application -> getOptions ());
$db = Zend_Db :: factory ( $c -> profil -> db -> metier );
Zend_Db_Table_Abstract :: setDefaultAdapter ( $db );
2013-10-02 15:29:06 +00:00
$client = 'sfrbtr' ;
2013-09-16 10:51:57 +00:00
$typeDepot = 'SFTP' ;
$prestation = 'FICH_RCE' ;
2013-09-02 10:12:16 +00:00
//Input path
$pathIn = $c -> profil -> path -> storage .
DIRECTORY_SEPARATOR . 'clients' .
2013-10-02 15:29:06 +00:00
DIRECTORY_SEPARATOR . $client .
2013-09-02 10:12:16 +00:00
DIRECTORY_SEPARATOR . 'send' ;
//Output path
$pathOut = $c -> profil -> path -> storage .
DIRECTORY_SEPARATOR . 'clients' .
2013-10-02 15:29:06 +00:00
DIRECTORY_SEPARATOR . $client .
2013-09-02 10:12:16 +00:00
DIRECTORY_SEPARATOR . 'recv' ;
2013-09-20 14:55:37 +00:00
/*
* File Configuration
* Possible encoding :
* Windows - 1252 //TRANSLIT
* ISO - 8859 - 15 //TRANSLIT
*
*/
2013-08-26 07:08:21 +00:00
$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' ),
2013-10-15 06:15:52 +00:00
'encoding' => 'ISO-8859-15' ,
2013-08-26 07:08:21 +00:00
);
$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_' ,
2013-10-15 06:15:52 +00:00
'encoding' => 'ISO-8859-15' ,
2013-08-26 07:08:21 +00:00
);
$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_' ,
2013-10-15 06:15:52 +00:00
'encoding' => 'ISO-8859-15' ,
2013-08-26 07:08:21 +00:00
);
2013-09-20 12:22:31 +00:00
$filePortefeuilleOptionsOut = array (
'dir' => $pathOut ,
'type' => 'csv' ,
'delimiter' => ',' ,
'enclosure' => '"' ,
'header' => array (),
'columns' => array (
'loginUti' ,
'source' ,
'email' ,
'siren' ,
'nic' ,
'ref' ,
'dateAjout' ,
'rs' ,
'cp' ,
'ville' ,
'dateDerEnvoi' ,
'encoursClient' ,
'actif' ,
'procol' ,
'indiScore20' ,
'encours' ,
'indiScoreDate' ,
'dateBilan' ,
'indiScore20Pre' ,
'encoursPre' ,
'indiScoreDatePre' ,
'sourceModif' ,
'scoreSolv' ,
'scoreSolvPre' ,
'scoreDir' ,
'scoreDirPre' ,
'scoreConf' ,
'scoreConfPre' ,
'cj' ,
'capital' ,
'capitalDev' ,
'ape_entrep' ,
'tca' ,
'teff_entrep' ,
'dateUpdate' ,
),
'name' => 'CLIENTSINDISCORE_' ,
2013-10-15 06:15:52 +00:00
'encoding' => 'ISO-8859-15' ,
2013-09-20 12:22:31 +00:00
);
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 ) {
2013-09-16 10:51:57 +00:00
if ( ! empty ( $opts -> manual ) && $opts -> manual !== true ) {
$filepath = $opts -> manual ;
$pathOut = dirname ( realpath ( $filepath ));
} else {
$pathOut = dirname ( __FILE__ );
}
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
);
2013-08-26 07:08:21 +00:00
}
// => Automatic mode
2013-09-13 15:45:54 +00:00
if ( $opts -> cron ) {
2013-08-28 15:07:16 +00:00
2013-09-16 10:51:57 +00:00
/*
2014-05-01 16:18:21 +00:00
* Detecter si la date n ' est pas trop ancienne
2013-09-16 10:51:57 +00:00
*/
$dateNow = new Zend_Date ();
$dateIn1 = $dateNow -> toString ( 'yyyy-MM-dd HH:mm:ss' );
2013-10-15 06:15:52 +00:00
$diff = $dateNow -> sub ( 20 , Zend_Date :: HOUR );
2013-09-16 10:51:57 +00:00
$dateIn2 = $diff -> toString ( 'yyyy-MM-dd HH:mm:ss' );
2013-10-02 09:58:37 +00:00
//client, name, depotType, depotDate, depotFile, nbLines, dateInsert, dateExecute
2013-09-13 15:45:54 +00:00
$fluxinM = new Application_Model_Sdv1FluxFileIn ();
$sql = $fluxinM -> select ()
-> where ( 'client=?' , $client )
-> where ( 'name=?' , $prestation )
2013-10-02 09:58:37 +00:00
-> where ( 'depotType=?' , $typeDepot )
2013-09-13 15:45:54 +00:00
-> where ( 'dateExecute=?' , '0000-00-00 00:00:00' )
2013-09-16 10:51:57 +00:00
-> where ( " dateInsert BETWEEN ' " . $dateIn2 . " ' AND ' " . $dateIn1 . " ' " )
2013-09-13 15:45:54 +00:00
-> order ( 'dateInsert DESC' );
2013-08-26 07:08:21 +00:00
2013-09-13 15:45:54 +00:00
$pitems = $fluxinM -> fetchAll ( $sql );
2013-08-26 07:08:21 +00:00
2013-09-13 15:45:54 +00:00
if ( $pitems -> count () == 0 ) {
2013-10-02 09:58:37 +00:00
echo date ( 'Y-m-d H:i:s' ) . " : Aucun traitement à réaliser. " . PHP_EOL ;
2013-09-13 15:45:54 +00:00
exit ;
2013-08-28 15:07:16 +00:00
}
2013-08-26 07:08:21 +00:00
2013-09-13 15:45:54 +00:00
foreach ( $pitems as $p ) {
2013-10-02 09:58:37 +00:00
$filepath = $pathIn . DIRECTORY_SEPARATOR . $p -> depotFile ;
2013-09-13 15:45:54 +00:00
break ;
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 ) ) {
2013-10-02 09:58:37 +00:00
echo date ( 'Y-m-d H:i:s' ) . " : Fichier inexistant ! " . PHP_EOL ;
2013-08-28 15:07:16 +00:00
exit ;
}
2013-09-13 15:45:54 +00:00
$opts -> load = $filepath ;
}
2013-09-02 10:12:16 +00:00
2013-10-02 14:24:09 +00:00
/**
* Chargement du fichier avec premières vérifications
*/
2013-10-02 15:00:57 +00:00
if ( $opts -> load && ! $opts -> evaluate ) {
2013-08-28 15:07:16 +00:00
2013-10-01 09:25:57 +00:00
//Lire et vérifier le fichier
if ( checkFile ( $opts -> load , $fileOptionsIn ) )
{
2013-10-02 14:24:09 +00:00
//Charger dans la table client AVEC vérification SIREN valide et existe
2013-10-02 13:44:16 +00:00
echo date ( 'Y-m-d H:i:s' ) . " - Début chargement... " . PHP_EOL ;
2013-10-01 09:25:57 +00:00
$seq = execDbIn ( $opts -> load , $fileOptionsIn );
2013-08-28 15:07:16 +00:00
2013-10-02 13:44:16 +00:00
//Marquer les SIREN qui n'existe pas dans la bdd
echo date ( 'Y-m-d H:i:s' ) . " - Marquage des SIREN inexistant " . PHP_EOL ;
2013-10-23 10:20:57 +00:00
$sql = " UPDATE jo.sfr_data SET error=1020 WHERE NumSeq=' " . $seq . " ' AND error=0 AND siren NOT IN (SELECT DISTINCT siren FROM jo.etablissements_old) " ;
2014-02-19 12:50:19 +00:00
try {
$result = $db -> query ( $sql );
} catch ( Zend_Db_Exception $e ) {
$sql = " UPDATE jo.sfr_data SET error=1020 WHERE NumSeq=' " . $seq . " ' AND error=0 AND siren NOT IN (SELECT DISTINCT siren FROM jo.etablissements) " ;
$result = $db -> query ( $sql );
}
2013-10-02 13:44:16 +00:00
2014-05-01 16:18:21 +00:00
//@todo : Mise à jour du portefeuille CFT (Nom de la prestation)
2013-10-02 14:24:09 +00:00
//Ajouter les SIREN valide qui ne sont pas en surveillance
2013-10-02 13:44:16 +00:00
echo date ( 'Y-m-d H:i:s' ) . " - Mise sous surveillance " . PHP_EOL ;
2013-10-01 09:25:57 +00:00
$sql = " INSERT IGNORE INTO jo.scores_surveillance (siren) (SELECT siren FROM jo.sfr_data WHERE error=0 AND NumSeq=' " . $seq . " ') " ;
$result = $db -> query ( $sql );
2013-09-13 15:45:54 +00:00
2013-10-02 13:44:16 +00:00
//Marquer les SIREN qui ne seront pas calculé
2013-10-23 10:20:57 +00:00
/* echo date ( 'Y-m-d H:i:s' ) . " - Marquage des SIREN imposssible à calculer " . PHP_EOL ;
$sql = " UPDATE jo.sfr_data SET error=2020 WHERE NumSeq=' " . $seq . " ' AND error=0 AND siren IN (SELECT siren FROM jo.scores_surveillance WHERE naf='' OR CJ IS NULL OR dateCrea IS NULL OR indiScoreDate='0000-00-00') " ;
$result = $db -> query ( $sql ); */
2013-10-01 09:25:57 +00:00
}
2015-07-20 08:14:39 +00:00
2015-02-05 08:43:17 +00:00
// --- Nettoyage
$date = new Zend_Date ();
if ( $date -> getWeekday () == 6 ) {
$date -> setDay ( - 1 ) -> setHour ( 23 ) -> setMinute ( 59 ) -> setSecond ( 59 );
echo date ( 'Y-m-d H:i:s' ) . " - Suppression ancienne référence. " . PHP_EOL ;
$sql = " DELETE FROM jo.sfr_data WHERE dateInsert < ' " . $date -> toString ( 'yyyy-MM-dd HH:mm:ss' ) . " ' " ;
try {
$result = $db -> query ( $sql );
} catch ( Zend_Db_Exception $e ) {}
}
2015-07-20 08:14:39 +00:00
2013-08-26 07:08:21 +00:00
}
2013-10-02 14:24:09 +00:00
/**
* Lancement de l ' évaluation et création des 3 fichiers de sorties
*/
2013-09-13 15:45:54 +00:00
if ( $opts -> evaluate ) {
2013-09-16 10:51:57 +00:00
if ( ! empty ( $opts -> manual ) && $opts -> manual !== true ) {
2013-09-13 15:45:54 +00:00
2013-09-16 10:51:57 +00:00
echo " Traitement Manuel... " . PHP_EOL ;
execFileIn ( $filepath , $fileOptionsIn , array ( 'ok' => $fileOkOptionsOut , 'error' => $fileErrorOptionsOut ), $opts -> debug );
2013-09-13 15:45:54 +00:00
} else {
2013-09-16 10:51:57 +00:00
$nbLines = 0 ;
2013-09-13 15:45:54 +00:00
//Use Seq Number from command line
if ( $opts -> evaluate !== true ) {
$seq = $opts -> evaluate ;
}
//Guess the last Seq Number
else {
try {
$db -> setFetchMode ( Zend_Db :: FETCH_OBJ );
2013-10-02 09:58:37 +00:00
$result = $db -> fetchRow ( 'SELECT NumSeq, dateInsert FROM jo.sfr_data ORDER BY id DESC LIMIT 0,1' );
2013-09-13 15:45:54 +00:00
} catch ( Zend_Db_Adapter_Exception $e ) {
echo $e -> getMessage ();
}
$seq = $result -> NumSeq ;
2013-09-16 10:51:57 +00:00
//Vérification date
$dateNow = new Zend_Date ();
$dateInsert = new Zend_Date ( $result -> dateInsert , 'yyyy-MM-dd HH:mm:ss' );
$diff = $dateNow -> sub ( $dateInsert );
$measure = new Zend_Measure_Time ( $diff -> toValue (), Zend_Measure_Time :: HOUR );
2013-10-15 06:15:52 +00:00
if ( $measure -> getValue () < 20 ) {
2013-10-02 09:58:37 +00:00
echo date ( 'Y-m-d H:i:s' ) . " : Aucun traitement à réaliser (Dernière date : " . $dateInsert -> toString ( 'yyyy-MM-dd HH:mm:ss' ) . " ). " . PHP_EOL ;
2013-09-16 10:51:57 +00:00
exit ;
}
2013-09-13 15:45:54 +00:00
}
$dateBegin = date ( 'YmdHis' );
//Génération des fichiers
$db -> setFetchMode ( Zend_Db :: FETCH_OBJ );
2013-10-23 10:20:57 +00:00
if ( $opts -> cron ) {
//Marquer les SIREN qui ne seront pas calculé
echo date ( 'Y-m-d H:i:s' ) . " - Marquage des SIREN imposssible à calculer " . PHP_EOL ;
$sql = " UPDATE jo.sfr_data SET error=2020 WHERE NumSeq=' " . $seq . " ' AND error=0 AND siren IN (SELECT siren FROM jo.scores_surveillance WHERE naf='' OR CJ IS NULL OR dateCrea IS NULL OR indiScoreDate='0000-00-00') " ;
$result = $db -> query ( $sql );
}
2013-09-13 15:45:54 +00:00
//Recherche des siren valides ainsi que leur scores
2013-09-16 10:51:57 +00:00
$sql = 'SELECT sfr.siren, sfr.DateContrat, sfr.IR,' .
' surv.actif, surv.procol, surv.naf, surv.CJ, surv.dateImmat, surv.dateCrea, surv.effectif, surv.indiScore20, surv.indiScoreDate, surv.dateUpdate' .
2013-09-13 15:45:54 +00:00
' FROM jo.sfr_data AS sfr' .
2013-09-16 10:51:57 +00:00
' LEFT JOIN jo.scores_surveillance AS surv ON sfr.siren=surv.siren' .
' WHERE sfr.error=0 AND sfr.NumSeq=\'' . $seq . '\'' ;
2013-10-15 06:15:52 +00:00
echo date ( 'Y-m-d H:i:s' ) . " - Recherche des SIREN valides avec leur score. " . PHP_EOL ;
2013-09-13 15:45:54 +00:00
$result = $db -> fetchAll ( $sql );
if ( $result !== null ) {
2013-10-15 06:15:52 +00:00
echo date ( 'Y-m-d H:i:s' ) . " - NbLignes= " . count ( $result ) . PHP_EOL ;
2013-09-16 10:51:57 +00:00
2013-09-13 15:45:54 +00:00
$sfrDataM = new Application_Model_JoSfrData ();
2013-09-16 10:51:57 +00:00
$file = $fileOkOptionsOut [ 'dir' ] . DIRECTORY_SEPARATOR . $fileOkOptionsOut [ 'name' ] . $dateBegin . '.' . $fileOkOptionsOut [ 'type' ];
2013-09-13 15:45:54 +00:00
//Ouverture fichier RETOUR
2013-09-16 10:51:57 +00:00
$fp = fopen ( $file , 'w' );
2014-06-26 07:23:14 +00:00
$sfrM = new SdMetier_Sfr_Scoring ();
2013-09-16 10:51:57 +00:00
$sfrM -> notCalculateInError = true ;
2013-09-13 15:45:54 +00:00
//Header
2013-09-16 10:51:57 +00:00
if ( $opts -> debug ) {
$keys = array_keys ( $sfrM -> getValDebug ());
$fileOkOptionsOut [ 'columns' ] = array_merge ( $fileOkOptionsOut [ 'columns' ], $keys );
$line = array ();
foreach ( $fileOkOptionsOut [ 'columns' ] as $i => $column ) {
$line [] = array ( $seq , 'RCE' );
}
} else {
2013-09-18 11:54:56 +00:00
$line = array ( $seq , 'RCE' );
2013-09-13 15:45:54 +00:00
}
2013-09-16 10:51:57 +00:00
2013-09-13 15:45:54 +00:00
fputcsv ( $fp , $line , $fileOkOptionsOut [ 'delimiter' ], $fileOkOptionsOut [ 'enclosure' ]);
2013-09-16 10:51:57 +00:00
$row = 0 ;
2013-09-13 15:45:54 +00:00
//Content
foreach ( $result as $item ) {
2013-09-16 10:51:57 +00:00
$row ++ ;
2014-05-01 16:18:21 +00:00
echo date ( 'Y-m-d H:i:s' ) . " - Ligne $row : Siren= " . $item -> siren ;
2013-09-16 10:51:57 +00:00
2013-09-13 15:45:54 +00:00
//Score non calculé
if ( $item -> indiScore20 === null ) {
2014-05-01 16:18:21 +00:00
echo " , Non calculé " ;
2013-09-16 10:51:57 +00:00
$sfrDataM -> update ( array ( 'error' => 2020 ), " siren=' " . $item -> siren . " ' AND NumSeq=' " . $seq . " ' " );
2013-09-13 15:45:54 +00:00
}
//Evaluation
else {
2014-07-02 14:36:11 +00:00
$sfrM = new SdMetier_Sfr_Scoring ();
2013-10-15 06:15:52 +00:00
$sfrM -> notCalculateInError = true ;
2013-09-13 15:45:54 +00:00
//Set Values
$sfrM -> setVal ( 'ContratDate' , $item -> DateContrat );
$sfrM -> setVal ( 'IR' , $item -> IR );
$sfrM -> setVal ( 'NAF' , $item -> naf );
$sfrM -> setVal ( 'FJ' , $item -> CJ );
$sfrM -> setVal ( 'InseeActif' , $item -> actif );
$sfrM -> setVal ( 'Effectif' , $item -> effectif );
$sfrM -> setVal ( 'Indiscore' , $item -> indiScore20 );
$sfrM -> setVal ( 'DateCalculIndiscore' , $item -> indiScoreDate );
$sfrM -> setVal ( 'DateUpdate' , $item -> dateUpdate );
$sfrM -> setVal ( 'DateCrea' , $item -> dateCrea );
$sfrM -> setVal ( 'DateImmat' , $item -> dateImmat );
$sfrM -> setVal ( 'SituationJuridique' , $item -> procol );
//Evaluate
if ( $sfrM -> evaluate ( $item -> siren ) ) {
2013-09-18 11:54:56 +00:00
$values = array ();
2013-10-15 06:15:52 +00:00
$values [ 'siren' ] = str_pad ( $item -> siren , 9 , '0' , STR_PAD_LEFT );
2013-09-13 15:45:54 +00:00
$values [ 'idVOR' ] = $sfrM -> getIndicateur ();
$values [ 'commentaire' ] = $sfrM -> getComment ();
2013-10-15 06:15:52 +00:00
//Only return PO when FEU = ORANGE
if ( $values [ 'idVOR' ] == 'ORANGE' ) {
$values [ 'PO' ] = $sfrM -> getPo ();
} else {
$values [ 'PO' ] = '' ;
}
2013-09-13 15:45:54 +00:00
2013-09-16 10:51:57 +00:00
if ( $opts -> debug ) {
2013-09-13 15:45:54 +00:00
$valuesDebug = $sfrM -> getValDebug ();
$values = array_merge ( $values , $valuesDebug );
}
2014-05-01 16:18:21 +00:00
echo " , ID= " . $values [ 'idVOR' ] . " , commentaire= " . $values [ 'commentaire' ];
2013-09-16 10:51:57 +00:00
2013-09-13 15:45:54 +00:00
//Ecrire fichier RETOUR
$line = array ();
foreach ( $fileOkOptionsOut [ 'columns' ] as $i => $column ) {
2013-10-15 06:15:52 +00:00
$line [] = $values [ $column ];
2013-09-13 15:45:54 +00:00
}
fputcsv ( $fp , $line , $fileOkOptionsOut [ 'delimiter' ], $fileOkOptionsOut [ 'enclosure' ]);
} else {
2014-05-01 16:18:21 +00:00
echo " , Pas de calcul " ;
2013-09-16 10:51:57 +00:00
$sfrDataM -> update ( array ( 'error' => 2020 ), " siren=' " . $item -> siren . " ' AND NumSeq=' " . $seq . " ' " );
2013-09-13 15:45:54 +00:00
}
}
2013-09-16 10:51:57 +00:00
echo PHP_EOL ;
2013-09-13 15:45:54 +00:00
}
fclose ( $fp );
}
2013-10-15 06:15:52 +00:00
if ( $fileOkOptionsOut [ 'encoding' ]) {
2013-10-24 19:21:02 +00:00
echo " Encodage du fichier " . PHP_EOL ;
2013-10-21 09:43:01 +00:00
passthru ( " iconv -f UTF-8 -t ISO-8859-15 " . $file . " -o " . $file . " .enc " );
passthru ( " cp -fv " . $file . " .enc " . $file );
2013-10-15 06:15:52 +00:00
}
2013-09-13 15:45:54 +00:00
2013-09-16 10:51:57 +00:00
$nbLines = $row ;
if ( $opts -> cron ) {
$fluxoutM = new Application_Model_Sdv1FluxFileOut ();
$dateEnd = date ( 'YmdHis' );
$fluxoutM -> insert ( array (
'client' => $client ,
'name' => $prestation ,
'nbLines' => $nbLines ,
'dateBegin' => $dateBegin ,
'dateEnd' => $dateEnd ,
2013-10-15 06:15:52 +00:00
'fileOut' => basename ( $file ),
2013-09-16 10:51:57 +00:00
'depotType' => $typeDepot ,
'depotDate' => '0000-00-00 00:00:00' ,
));
//Ecrire la date d'execution dans flux_filein
$fluxinM -> update ( array ( 'dateExecute' => $dateEnd ), 'id=' . $p -> id );
}
2013-09-13 15:45:54 +00:00
//Recherche des siren en erreur
$sql = 'SELECT sfr.siren, sfr.error' .
' FROM jo.sfr_data AS sfr' .
2013-09-18 11:54:56 +00:00
' WHERE sfr.error!=0 AND sfr.NumSeq=\'' . $seq . '\'' ;
2013-09-16 10:51:57 +00:00
2013-10-15 06:15:52 +00:00
echo date ( 'Y-m-d H:i:s' ) . " - Recherche des SIREN en erreur. " . PHP_EOL ;
2013-09-13 15:45:54 +00:00
$result = $db -> fetchAll ( $sql );
if ( $result !== null ) {
2013-10-15 06:15:52 +00:00
echo date ( 'Y-m-d H:i:s' ) . " - NbLignes= " . count ( $result ) . PHP_EOL ;
2013-09-16 10:51:57 +00:00
$file = $fileErrorOptionsOut [ 'dir' ] . DIRECTORY_SEPARATOR . $fileErrorOptionsOut [ 'name' ] . $dateBegin . '.' . $fileErrorOptionsOut [ 'type' ];
2013-09-13 15:45:54 +00:00
//Ouverture fichier ERREUR
2013-09-16 10:51:57 +00:00
$fp = fopen ( $file , 'w' );
2013-09-13 15:45:54 +00:00
//Header
2013-09-18 11:54:56 +00:00
$line = array ( $seq , 'RCE' );
2013-09-13 15:45:54 +00:00
fputcsv ( $fp , $line , $fileErrorOptionsOut [ 'delimiter' ], $fileErrorOptionsOut [ 'enclosure' ]);
2013-09-16 10:51:57 +00:00
$row = 0 ;
2013-09-13 15:45:54 +00:00
//Content
foreach ( $result as $item ) {
2013-09-16 10:51:57 +00:00
$row ++ ;
2013-10-15 06:15:52 +00:00
echo date ( 'Y-m-d H:i:s' ) . " - Ligne $row : Siren= " . $item -> siren ;
2013-09-16 10:51:57 +00:00
2013-09-13 15:45:54 +00:00
$values = array (
2013-10-15 06:15:52 +00:00
'siren' => str_pad ( $item -> siren , 9 , '0' , STR_PAD_LEFT ),
2013-09-13 15:45:54 +00:00
'code' => $item -> error ,
);
//Ecrire fichier ERREUR
$line = array ();
foreach ( $fileErrorOptionsOut [ 'columns' ] as $i => $column ) {
2013-10-15 06:15:52 +00:00
$line [] = $values [ $column ];
2013-09-13 15:45:54 +00:00
}
fputcsv ( $fp , $line , $fileErrorOptionsOut [ 'delimiter' ], $fileErrorOptionsOut [ 'enclosure' ]);
2013-09-16 10:51:57 +00:00
echo PHP_EOL ;
}
2013-09-13 15:45:54 +00:00
fclose ( $fp );
2013-10-15 06:15:52 +00:00
if ( $fileErrorOptionsOut [ 'encoding' ]) {
2013-10-23 10:20:57 +00:00
passthru ( " iconv -f UTF-8 -t ISO-8859-15 " . $file . " -o " . $file . " .enc " );
passthru ( " cp -fv " . $file . " .enc " . $file );
2013-10-15 06:15:52 +00:00
}
2013-09-16 10:51:57 +00:00
$nbLines = $row ;
2013-10-15 06:15:52 +00:00
echo date ( 'Y-m-d H:i:s' ) . " - Nb Lignes Traitées : " . $nbLines . PHP_EOL ;
2013-09-16 10:51:57 +00:00
if ( $opts -> cron ) {
$fluxoutM = new Application_Model_Sdv1FluxFileOut ();
$dateEnd = date ( 'YmdHis' );
$fluxoutM -> insert ( array (
'client' => $client ,
'name' => $prestation ,
'nbLines' => $nbLines ,
'dateBegin' => $dateBegin ,
'dateEnd' => $dateEnd ,
2013-10-15 06:15:52 +00:00
'fileOut' => basename ( $file ),
2013-09-16 10:51:57 +00:00
'depotType' => $typeDepot ,
'depotDate' => '0000-00-00 00:00:00' ,
));
//Ecrire la date d'execution dans flux_filein
$fluxinM -> update ( array ( 'dateExecute' => $dateEnd ), 'id=' . $p -> id );
}
2013-09-13 15:45:54 +00:00
}
//Extraction du fichier PORTEFEUILLE - @todo
2013-09-18 11:54:56 +00:00
$sql = 'SELECT sfr.siren,' .
' surv.actif, surv.procol, surv.indiScore20, surv.encours, surv.indiScoreDate,' .
' surv.dateBilan, surv.indiScore20Pre, surv.encoursPre, surv.indiScoreDatePre, surv.sourceModif,' .
' surv.scoreSolv, surv.scoreSolvPre, surv.scoreDir, surv.scoreDirPre, surv.scoreConf, surv.scoreConfPre,' .
' surv.CJ, surv.naf, surv.effectif, surv.dateUpdate' .
2013-09-13 15:45:54 +00:00
' FROM jo.sfr_data AS sfr, jo.scores_surveillance AS surv' .
2013-09-18 11:54:56 +00:00
' WHERE sfr.siren=surv.siren AND sfr.error=0 AND sfr.NumSeq=\'' . $seq . '\' AND indiScore20 IS NOT NULL' ;
2013-09-16 10:51:57 +00:00
2013-10-15 06:15:52 +00:00
echo date ( 'Y-m-d H:i:s' ) . " - Extraction du portefeuille. " . PHP_EOL ;
2013-09-13 15:45:54 +00:00
$result = $db -> fetchAll ( $sql );
if ( $result !== null ) {
2013-10-15 06:15:52 +00:00
echo date ( 'Y-m-d H:i:s' ) . " - NbLignes= " . count ( $result ) . PHP_EOL ;
2013-09-18 11:54:56 +00:00
2013-09-16 10:51:57 +00:00
$file = $filePortefeuilleOptionsOut [ 'dir' ] . DIRECTORY_SEPARATOR . $filePortefeuilleOptionsOut [ 'name' ] . $dateBegin . '.' . $filePortefeuilleOptionsOut [ 'type' ];
2013-09-13 15:45:54 +00:00
//Ouverture fichier PORTEFEUILLE
2013-09-16 10:51:57 +00:00
$fp = fopen ( $file , 'w' );
2013-09-13 15:45:54 +00:00
//Header
2013-09-18 11:54:56 +00:00
fputcsv ( $fp , $filePortefeuilleOptionsOut [ 'columns' ], $filePortefeuilleOptionsOut [ 'delimiter' ], $filePortefeuilleOptionsOut [ 'enclosure' ]);
2013-09-13 15:45:54 +00:00
2014-05-02 12:39:10 +00:00
$row = 0 ;
2013-09-13 15:45:54 +00:00
//Content
foreach ( $result as $item ) {
2014-05-02 12:39:10 +00:00
$row ++ ;
2013-09-13 15:45:54 +00:00
$values = array (
2013-09-17 07:26:46 +00:00
'loginUti' => 'AUTO' ,
'source' => 'score' ,
'email' => 'AUTO' ,
2013-10-15 06:15:52 +00:00
'siren' => str_pad ( $item -> siren , 9 , '0' , STR_PAD_LEFT ),
2013-09-18 11:54:56 +00:00
'nic' => '00000' ,
2013-09-17 07:26:46 +00:00
'ref' => 'AUTO' ,
2013-09-18 11:54:56 +00:00
'dateAjout' => '' ,
'rs' => '' ,
'cp' => '' ,
'ville' => '' ,
'dateDerEnvoi' => '' ,
'encoursClient' => '' ,
2013-09-17 07:26:46 +00:00
'actif' => $item -> actif ,
'procol' => $item -> procol ,
'indiScore20' => $item -> indiScore20 ,
'encours' => $item -> encours ,
'indiScoreDate' => $item -> indiScoreDate ,
2013-09-20 12:22:31 +00:00
'dateBilan' => ( $item -> dateBilan == '0000-00-00 00:00:00' ) ? '' : $item -> dateBilan ,
2013-09-17 07:26:46 +00:00
'indiScore20Pre' => $item -> indiScore20Pre ,
'encoursPre' => $item -> encoursPre ,
2013-09-20 12:22:31 +00:00
'indiScoreDatePre' => ( $item -> indiScoreDatePre == '0000-00-00 00:00:00' ) ? '' : $item -> indiScoreDatePre ,
2013-09-17 07:26:46 +00:00
'sourceModif' => $item -> sourceModif ,
'scoreSolv' => $item -> scoreSolv ,
'scoreSolvPre' => $item -> scoreSolvPre ,
'scoreDir' => $item -> scoreDir ,
'scoreDirPre' => $item -> scoreDirPre ,
'scoreConf' => $item -> scoreConf ,
'scoreConfPre' => $item -> scoreConfPre ,
2013-09-18 11:54:56 +00:00
'cj' => $item -> CJ ,
'capital' => '' ,
'capitalDev' => '' ,
'ape_entrep' => $item -> naf ,
'tca' => '' ,
'teff_entrep' => $item -> effectif ,
2013-09-17 07:26:46 +00:00
'dateUpdate' => $item -> dateUpdate ,
2013-09-13 15:45:54 +00:00
);
2013-10-15 06:15:52 +00:00
//Ecrire fichier POTEFEUILLE
2013-09-13 15:45:54 +00:00
$line = array ();
foreach ( $filePortefeuilleOptionsOut [ 'columns' ] as $i => $column ) {
2013-10-15 06:15:52 +00:00
$line [] = $values [ $column ];
2013-09-13 15:45:54 +00:00
}
fputcsv ( $fp , $line , $filePortefeuilleOptionsOut [ 'delimiter' ], $filePortefeuilleOptionsOut [ 'enclosure' ]);
}
fclose ( $fp );
2013-10-15 06:15:52 +00:00
if ( $filePortefeuilleOptionsOut [ 'encoding' ]) {
2013-10-23 10:20:57 +00:00
passthru ( " iconv -f UTF-8 -t ISO-8859-15 " . $file . " -o " . $file . " .enc " );
passthru ( " cp -fv " . $file . " .enc " . $file );
2013-10-15 06:15:52 +00:00
}
2013-09-13 15:45:54 +00:00
2014-05-02 12:39:10 +00:00
$nbLines = $row ;
echo date ( 'Y-m-d H:i:s' ) . " - Nb Lignes Traitées : " . $nbLines . PHP_EOL ;
2013-09-16 10:51:57 +00:00
if ( $opts -> cron ) {
$fluxoutM = new Application_Model_Sdv1FluxFileOut ();
$dateEnd = date ( 'YmdHis' );
$fluxoutM -> insert ( array (
'client' => $client ,
'name' => $prestation ,
'nbLines' => $nbLines ,
'dateBegin' => $dateBegin ,
'dateEnd' => $dateEnd ,
2013-10-15 06:15:52 +00:00
'fileOut' => basename ( $file ),
2013-09-16 10:51:57 +00:00
'depotType' => $typeDepot ,
'depotDate' => '0000-00-00 00:00:00' ,
));
//Ecrire la date d'execution dans flux_filein
$fluxinM -> update ( array ( 'dateExecute' => $dateEnd ), 'id=' . $p -> id );
}
2013-09-13 15:45:54 +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-09-05 11:39:03 +00:00
//Date incorrecte - 2010
Zend_Date :: setOptions ( array ( 'extend_month' => true ));
if ( $values [ 'dateContrat' ] != '' && Zend_Date :: isDate ( $values [ 'dateContrat' ], array ( 'date_format' => 'yyyyMMdd' )) ) {
$error = 1 ;
$code = 'error' ;
$values [ 'code' ] = '2010' ;
echo " - Erreur 2010 " ;
}
2013-08-27 08:50:25 +00:00
if ( $error == 0 ) {
2013-08-26 07:08:21 +00:00
//Calculate data
2015-04-08 08:58:41 +00:00
$sfrM = new SdMetier_Sfr_Scoring ();
2013-09-13 15:45:54 +00:00
$sfrM -> notCalculateInError = false ;
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-09-13 15:45:54 +00:00
if ( $sfrM -> evaluate ( $siren ) ) {
$values [ 'idVOR' ] = $sfrM -> getIndicateur ();
$values [ 'commentaire' ] = $sfrM -> getComment ();
$values [ 'PO' ] = $sfrM -> getPo ();
$valuesDebug = $sfrM -> getValDebug ();
if ( $debug ) {
$values = array_merge ( $values , $valuesDebug );
}
2013-08-26 07:08:21 +00:00
2013-09-13 15:45:54 +00:00
$code = 'ok' ;
2013-08-30 13:45:56 +00:00
2013-09-13 15:45:54 +00:00
echo " - VOR= " . $values [ 'idVOR' ] . " , commentaire= " . $values [ 'commentaire' ] . " , PO= " . $values [ 'PO' ];
} else {
$error = 1 ;
$code = 'error' ;
$values [ 'code' ] = '2020' ;
echo " - Not calculated " ;
}
2013-08-27 08:50:25 +00:00
}
echo PHP_EOL ;
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-13 15:45:54 +00:00
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-16 10:51:57 +00:00
global $dateBegin ;
2013-09-02 10:12:16 +00:00
//Set the input file path
2013-09-13 15:45:54 +00:00
$filepathIn = $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-16 10:51:57 +00:00
$ { 'fp' . $code } = fopen ( $file [ 'dir' ] . DIRECTORY_SEPARATOR . $file [ 'name' ] . $dateBegin . '.' . $file [ 'type' ], 'w' );
2013-09-02 10:12:16 +00:00
}
//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' ];
2013-09-10 16:16:55 +00:00
//$filesOptionsOut[$codeRetour]['line'][] = $valuesClient['values'];
2013-09-02 10:12:16 +00:00
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-10 16:16:55 +00:00
foreach ( $filesOptionsOut as $code => $file ) {
2013-09-02 10:12:16 +00:00
fclose ( $ { 'fp' . $code });
}
2013-08-26 07:08:21 +00:00
}
}
2013-10-01 09:25:57 +00:00
/**
*
* @ param string $filepathIn
* @ param array $fileOptionsIn
* @ return boolean
*/
function checkFile ( $filepathIn , $fileOptionsIn )
{
if ( file_exists ( $filepathIn ) ) {
if (( $handle = fopen ( $filepathIn , 'r' )) !== false ) {
$row = 0 ;
while (( $data = fgetcsv ( $handle , 0 , $fileOptionsIn [ 'delimiter' ], $fileOptionsIn [ 'enclosure' ])) !== false )
{
$row ++ ;
//Header
if ( count ( $fileOptionsIn [ 'header' ]) > 0 && $row == 1 ) {
if ( count ( $fileOptionsIn [ 'header' ]) != count ( $data ) ) {
return false ;
}
}
//Content
else {
if ( count ( $fileOptionsIn [ 'columns' ]) != count ( $data ) ) {
return false ;
}
}
}
}
fclose ( $handle );
2013-09-13 15:45:54 +00:00
2013-10-01 09:25:57 +00:00
return true ;
}
}
2013-09-13 15:45:54 +00:00
2013-08-26 07:08:21 +00:00
/**
2013-09-13 15:45:54 +00:00
* Load in database
2013-08-27 08:50:25 +00:00
* @ param string $file
2013-09-13 15:45:54 +00:00
* @ param array $fileOptionsIn
* @ param array $filesOptionsOut
* @ param boolean $debug
* @ param boolean $resume
* @ return array
2013-08-26 07:08:21 +00:00
*/
2013-09-13 15:45:54 +00:00
function execDbIn ( $file , $fileOptionsIn , $debug = false )
2013-08-26 07:08:21 +00:00
{
2013-09-13 15:45:54 +00:00
//Set the input file path
//$filepathIn = $fileOptionsIn['dir'] . DIRECTORY_SEPARATOR . $file;
$filepathIn = $file ;
//Read file
if ( file_exists ( $filepathIn ) ) {
$sfrDataM = new Application_Model_JoSfrData ();
if (( $handle = fopen ( $filepathIn , 'r' )) !== false ) {
$row = 0 ;
while (( $data = fgetcsv ( $handle , 0 , $fileOptionsIn [ 'delimiter' ], $fileOptionsIn [ 'enclosure' ])) !== false )
{
$row ++ ;
2013-10-02 13:44:16 +00:00
echo date ( 'Y-m-d H:i:s' ) . " - Ligne $row : " ;
2013-09-13 15:45:54 +00:00
//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 ) {
$filesOptionsOut [ 'error' ][ 'header' ] = array ();
$filesOptionsOut [ 'ok' ][ 'header' ] = array ();
} else {
$filesOptionsOut [ 'error' ][ 'header' ] = $header ;
$filesOptionsOut [ 'ok' ][ 'header' ] = $header ;
}
}
//Content
else {
//Set values from file
$values = array ();
foreach ( $fileOptionsIn [ 'columns' ] as $i => $column ) {
$values [ $column ] = $data [ $i ];
}
//Exec the process
$values = execDbInternal ( $values );
$sfrDataM -> insert ( array (
'NumSeq' => $header [ 'idDemande' ],
'siren' => $values [ 'siren' ],
'NbLignes' => $values [ 'nbLignes' ],
'NbContrats' => $values [ 'nbContrats' ],
'DateContrat' => $values [ 'dateContrat' ],
'IR' => $values [ 'ir' ],
'IdVOR' => '' ,
'comment' => '' ,
'PO' => 0 ,
'debug' => '' ,
'error' => $values [ 'code' ],
));
}
}
2013-08-26 07:08:21 +00:00
}
2013-09-13 15:45:54 +00:00
fclose ( $handle );
return $header [ 'idDemande' ];
2013-08-26 07:08:21 +00:00
}
2013-09-13 15:45:54 +00:00
}
function execDbInternal ( $values , $debug = false )
{
$error = 0 ;
$siren = $values [ 'siren' ];
echo " $siren " ;
$classInsee = new MInsee ();
$values [ 'code' ] = '' ;
//Siren valide - 1010
if ( ! $classInsee -> valideSiren ( $siren ) ) {
2013-10-02 13:44:16 +00:00
$error = 1 ;
$code = 'error' ;
$values [ 'code' ] = '1010' ;
echo " Erreur 1010. " ;
2013-08-26 07:08:21 +00:00
}
2013-09-13 15:45:54 +00:00
//Siren existant - 1020
2013-10-02 13:44:16 +00:00
/* else if ( ! $classInsee -> sirenExiste ( $siren ) ) {
2013-09-13 15:45:54 +00:00
$error = 1 ;
$code = 'error' ;
$values [ 'code' ] = '1020' ;
echo " - Erreur 1020. " ;
2013-10-02 13:44:16 +00:00
} */
2013-08-26 09:46:25 +00:00
2013-09-13 15:45:54 +00:00
//Date incorrecte - 2010
Zend_Date :: setOptions ( array ( 'extend_month' => true ));
if ( $values [ 'dateContrat' ] != '' && Zend_Date :: isDate ( $values [ 'dateContrat' ], array ( 'date_format' => 'yyyyMMdd' )) ) {
$error = 1 ;
$code = 'error' ;
$values [ 'code' ] = '2010' ;
2013-10-02 13:44:16 +00:00
echo " Erreur 2010 " ;
2013-09-13 15:45:54 +00:00
}
echo PHP_EOL ;
return $values ;
2013-08-26 07:08:21 +00:00
}
2013-09-13 15:45:54 +00:00