batch/scripts/clients/RrgSurv.php

338 lines
11 KiB
PHP
Raw Normal View History

2015-01-19 16:49:15 +00:00
<?php
//error_reporting(E_ALL & ~E_STRICT & ~E_NOTICE & ~E_WARNING & ~E_DEPRECATED);
error_reporting(E_ALL & ~E_STRICT & ~E_NOTICE & ~E_WARNING & ~E_DEPRECATED);
2015-09-14 20:31:06 +00:00
// --- Define path to application directory
2015-01-19 16:49:15 +00:00
defined('APPLICATION_PATH')
2015-09-14 20:31:06 +00:00
|| define('APPLICATION_PATH', realpath(__DIR__ . '/../../application'));
2015-01-19 16:49:15 +00:00
2015-09-14 20:31:06 +00:00
// --- Define application environment
2015-01-19 16:49:15 +00:00
defined('APPLICATION_ENV')
2015-09-14 20:31:06 +00:00
|| define('APPLICATION_ENV', (getenv('APPLICATION_ENV') ? getenv('APPLICATION_ENV') : 'production'));
2015-01-19 16:49:15 +00:00
// --- Composer autoload
2015-09-14 20:31:06 +00:00
require_once realpath(__DIR__ . '/../../vendor/autoload.php');
2015-01-19 16:49:15 +00:00
// Create application, bootstrap, and run
2015-09-14 20:31:06 +00:00
$application = new Zend_Application(APPLICATION_ENV, APPLICATION_PATH . '/configs/application.ini');
2015-01-19 16:49:15 +00:00
try {
$opts = new Zend_Console_Getopt(
//Options
array(
'help|?' => "Displays usage information.",
'since=s' => "Depuis une date (format AAAAMMJJ) ou depuis le dernier flux (flux)",
'from=s' => "depuis surveillance (surv) ou logs (log:default)",
2015-01-19 16:49:15 +00:00
'debug' => "Génére uniquement un fichier sans télétransmission",
'cron' => "Mandatory option for launch the cli in cron",
)
);
$opts->parse();
} catch (Zend_Console_Getopt_Exception $e) {
echo $e->getUsageMessage();
exit;
}
//Usage
if( isset($opts->help) || count($opts->getOptions())==0 )
{
echo "Prestation RRG Surveillance.\n";
echo $opts->getUsageMessage();
exit;
}
$c = new Zend_Config($application->getOptions());
Zend_Registry::set('config', $c);
$login = 'rrgws';
2015-01-19 16:49:15 +00:00
$client = 'rrg';
$typeDepot = 'FTP';
$prestation = 'HEXAVIA';
//Output path
2016-01-26 13:50:08 +00:00
$pathOut = $c->profil->path->shared . '/clients/' . $client . '/recv';
2015-01-19 16:49:15 +00:00
$fileOptionsOut = array(
'dir' => $pathOut,
'type' => 'csv',
'delimiter' => '$',
2015-02-09 10:58:58 +00:00
/*'enclosure' => '"',*/
2015-01-29 08:53:24 +00:00
/*'header' => array(
2015-01-19 16:49:15 +00:00
'ID_S&D',
'SIRET',
'DATE_CREATION',
'CA',
'ANNEE_CA',
'CODE_PAIEMENT',
'LIBELLE_CODE_PAIE',
'INDISCORE20',
'ENCOURS'
2015-01-29 08:53:24 +00:00
),*/
2015-01-19 16:49:15 +00:00
'columns' => array(
'SourceID',
'Siret',
'DateCreaEn',
'BilanCA',
'BilanDateCloture',
'PaiementCS',
'PaiementInfo',
'Indiscore',
'Encours',
),
'name' => 'surv_',
//'encoding' => 'ISO-8859-15',
);
require_once APPLICATION_PATH.'/configs/config.php';
require_once 'framework/fwk.php';
require_once 'Metier/Scores/MScores.php';
2015-01-19 16:49:15 +00:00
$db = Zend_Db::factory($c->profil->db->metier);
$db->setFetchMode(Zend_Db::FETCH_OBJ);
Zend_Db_Table_Abstract::setDefaultAdapter($db);
2015-02-06 15:19:05 +00:00
$dateStart = new Zend_Date();
$dateEnd = new Zend_Date();
if ($opts->since == 'flux') {
$fluxoutM = new Application_Model_Sdv1FluxFileOut();
$sql = $fluxoutM->select()
->where('client=?', 'rrg')
->where('name=?', 'HEXAVIA')
->where('fileOut LIKE ?', 'surv_%')
->where('depotDate!=?', '0000-00-00 00:00:00')
->order('depotDate DESC')->limit(1);
$resultDate = $fluxoutM->fetchRow($sql);
$dateStart->set($resultDate->dateEnd, 'yyyyMMdd')->subDay(1);
$dateEnd->subDay(1);
} elseif ($opts->since) {
2015-02-06 15:19:05 +00:00
$dateStart->set($opts->since, 'yyyyMMdd');
$dateEnd->subDay(1);
2015-01-19 16:49:15 +00:00
} else {
if ( $dateStart->getWeekday() == 1 ) {
2015-02-06 15:19:05 +00:00
$dateStart->subDay(3);
} else {
$dateStart->subDay(1);
}
$dateEnd->subDay(1);
2015-01-19 16:49:15 +00:00
}
2015-02-06 15:19:05 +00:00
$dateSql1 = $dateStart->toString('yyyy-MM-dd');
$dateSql2 = $dateEnd->toString('yyyy-MM-dd');
2015-01-19 16:49:15 +00:00
// --- Entités consultées via webservice (dateAjout) + Entités avec scores modifiés ou ajoutés (indiScoreDate)
if ($opts->from == 'surv') {
2015-02-06 15:19:05 +00:00
echo date('Y-m-d H:i:s')." - Selection dans le portefeuille entre le $dateSql1 et $dateSql2\n";
$sql = "SELECT LPAD(surv.siren,9,0) AS siren, surv.dateAjout, score.indiScore20, score.indiScoreDate, score.encours, score.cs, score.dateBilan
2015-01-19 16:49:15 +00:00
FROM jo.surveillances_site AS surv LEFT JOIN jo.scores_surveillance AS score ON surv.siren = score.siren
WHERE surv.source='score' AND surv.login='".$login."' AND
2015-02-06 15:19:05 +00:00
( (surv.dateAjout BETWEEN '".$dateSql1." 00:00:00' AND '".$dateSql2." 23:59:59')
OR (score.indiScoreDate BETWEEN '".$dateSql1." 00:00:00' AND '".$dateSql2." 23:59:59') )
2015-01-19 16:49:15 +00:00
GROUP BY siren ORDER BY siren, dateAjout DESC";
}
// --- Entités consultées via webservice depuis les logs (dateHeure) + Entités avec scores modifiés ou ajoutés (indiScoreDate)
elseif ($opts->from == 'log') {
2015-02-09 11:24:44 +00:00
echo date('Y-m-d H:i:s')." - Selection dans les logs entre le $dateSql1 et $dateSql2\n";
$sql = "SELECT LPAD(surv.siren,9,0) AS siren, surv.dateHeure AS dateAjout, score.indiScore20, score.indiScoreDate, score.encours, score.cs, score.dateBilan
FROM sdv1.logs AS surv LEFT JOIN jo.scores_surveillance AS score ON surv.siren = score.siren
2015-02-10 08:28:06 +00:00
WHERE surv.login='".$login."' AND page='identite' AND
2015-02-06 15:19:05 +00:00
( (surv.dateHeure BETWEEN '".$dateSql1." 00:00:00' AND '".$dateSql2." 23:59:59')
OR (score.indiScoreDate BETWEEN '".$dateSql1." 00:00:00' AND '".$dateSql2." 23:59:59') )
GROUP BY siren ORDER BY siren, dateAjout DESC";
}
2015-01-19 16:49:15 +00:00
try {
$resultItem = $db->fetchAll($sql);
} catch (Zend_Db_Exception $e) {
echo $e->getMessage();
echo "\n";
}
if ( count($resultItem) == 0 ) {
echo date('Y-m-d H:i:s')." - Aucun élément.\n";
} else {
2015-07-20 08:14:39 +00:00
2015-01-19 16:49:15 +00:00
$dateBegin = date('YmdHis');
echo date('Y-m-d H:i:s')." - NbLignes=".count($resultItem)."\n";
// --- Ecriture du fichier
$file = $fileOptionsOut['dir'] . '/' .$fileOptionsOut['name'] . substr($dateBegin,0,8) . '.' . $fileOptionsOut['type'];
// --- Ouverture fichier
$fp = fopen($file, 'w');
if ( $fp === false ) {
echo date('Y-m-d H:i:s')." - ERREUR Impossible de créer le fichier ".$file."\n";
exit;
}
// --- Header
if ( count($fileOptionsOut['header']) > 0 ) {
fputcsv($fp, $fileOptionsOut['header'], $fileOptionsOut['delimiter'], $fileOptionsOut['enclosure']);
}
2015-01-19 16:49:15 +00:00
$iDb = new WDB();
$row = 0;
// --- Content
foreach ($resultItem as $item) {
2015-07-20 08:14:39 +00:00
2015-02-10 08:28:06 +00:00
if (intval($item->siren) == 0) {
continue;
}
2015-07-20 08:14:39 +00:00
2015-01-19 16:49:15 +00:00
$row++;
if ($opts->debug) { echo date('Y-m-d H:i:s')." - Ligne ".$row; }
2015-07-20 08:14:39 +00:00
2015-01-19 16:49:15 +00:00
// --- Data
$sql = $db->select()
->from('etablissements', array(
'LPAD(source_id,10,0) AS source_id',
'LPAD(siren,9,0) AS siren',
'LPAD(nic,5,0) AS nic'),
'jo')->where('siren=?', $item->siren)->where('siege=1')->order('actif DESC')->limit(1);
$etablissement = $db->fetchRow($sql, null, Zend_Db::FETCH_OBJ);
2015-07-20 08:14:39 +00:00
2015-01-19 16:49:15 +00:00
$DateCreaEn = '';
$BilanCA = '';
$BilanDateCloture = '';
$Indiscore = '';
$Encours = '';
// --- Calcul du score ou lecture depuis la table de sauvegarde des scores
if ($item->indiScoreDate === null) {
2015-07-20 08:14:39 +00:00
2015-01-19 16:49:15 +00:00
if ($opts->debug) { echo " - Calcul du score"; }
2015-07-20 08:14:39 +00:00
$evaluation = calculIndiScore($item->siren, 0, false, 0, false, 'scores', $iDb);
2015-07-20 08:14:39 +00:00
2015-01-19 16:49:15 +00:00
$PaiementCS = $evaluation['cs'];
$Indiscore = $evaluation['Indiscore20'];
$Encours = round($evaluation['encours']/1000) * 1000;
2015-07-20 08:14:39 +00:00
2015-01-19 16:49:15 +00:00
} else {
2015-07-20 08:14:39 +00:00
if ($opts->debug) { echo " - Données en cache"; }
2015-07-20 08:14:39 +00:00
$PaiementCS = $item->cs;
2015-01-19 16:49:15 +00:00
$Indiscore = $item->indiScore20;
$Encours = round($item->encours/1000) * 1000;
}
2015-07-20 08:14:39 +00:00
// --- Informations identitaire
$iInsee = new Metier_Insee_MInsee($iDb);
$tabIdentite = $iInsee->getIdentiteEntreprise($item->siren, 0, 0, false, false);
$DateCreaEn = $tabIdentite['DateCreaEn'];
if ( $tabIdentite['DateCreaEt'] > 0 && $tabIdentite['DateCreaEt'] < $tabIdentite['DateCreaEn'] ) {
$DateCreaEn = $tabIdentite['DateCreaEt'];
} elseif ( $tabIdentite['DateCreaEn'] > 0 ) {
$DateCreaEn = $tabIdentite['DateCreaEn'];
}
2015-07-20 08:14:39 +00:00
2015-04-23 15:36:12 +00:00
// --- Correction pour l'envoi des dates
if ( !empty($DateCreaEn) ) {
2015-06-22 13:51:21 +00:00
if (strlen($DateCreaEn)<8) {
$DateCreaEn = str_pad($DateCreaEn, 8, '0', STR_PAD_RIGHT);
}
2015-04-23 15:36:12 +00:00
if (substr($DateCreaEn, -2) * 1 == 0) {
$DateCreaEn = substr($DateCreaEn,0,6).'01';
}
}
2015-07-20 08:14:39 +00:00
// --- Gestion des bilans
$today = new Zend_Date();
if ( !empty($tabIdentite['bilanDate']) ) {
$compare = $today->sub($tabIdentite['bilanDate'], 'yyMMdd');
2015-04-23 15:36:12 +00:00
if ( $compare->toValue(Zend_Date::MONTH) < 37 ) {
$BilanDateCloture = substr($tabIdentite['bilanDate'],6,2).substr($tabIdentite['bilanDate'],4,2).substr($tabIdentite['bilanDate'],0,4);
$BilanCA = $tabIdentite['bilanFL'];
}
}
2015-07-20 08:14:39 +00:00
// --- Estimation du CA bilan
2015-04-23 15:36:12 +00:00
if (empty($BilanCA) && !empty($tabIdentite['bilanAnnee'])) {
2015-07-20 08:14:39 +00:00
2015-04-23 15:36:12 +00:00
$dateCreaRecente = new Zend_Date();
$dateCreaRecente->subYear(2)->setMonth(1)->setDay(1);
$dateClotureEstime = new Zend_Date();
$dateClotureEstime->setMonth(12)->setDay(31);
2015-07-20 08:14:39 +00:00
2015-04-23 15:36:12 +00:00
// --- Condition RRG
if ( $tabIdentite['Eff'] > 0
|| substr($tabIdentite['FJ'],0,1) == 1 && $tabIdentite['Eff'] < 1
|| !empty($tabIdentite['NafEnt']) && strlen($tabIdentite['NafEnt']) == 5 && $tabIdentite['NafEnt'] != '0000Z' ) {
2015-07-20 08:14:39 +00:00
2015-04-23 15:36:12 +00:00
// --- Création récente
2015-05-18 12:39:53 +00:00
if ( $dateCreaRecente->compare($DateCreaEn, 'yyMMdd') == 1 ) {
2015-04-23 15:36:12 +00:00
$BilanDateCloture = '3112'.date('Y');
$BilanCA = $tabIdentite['bilanFLestime'];
}
// --- Date cloture estimée < Date de création
elseif ( $dateClotureEstime->compare($DateCreaEn, 'yyMMdd') == -1) {
$BilanDateCloture = '3112'.$tabIdentite['bilanAnnee'];
$BilanCA = $tabIdentite['bilanFLestime'];
}
}
2015-01-19 16:49:15 +00:00
}
2015-07-20 08:14:39 +00:00
// Récupération du libellé d'information de paiement
2015-01-19 16:49:15 +00:00
$PaiementInfo = '';
if ( in_array($PaiementCS, array('0', 'I', 'P', 'D')) ) {
$iFacto = new Metier_Partenaires_MFacto($iDb);
2015-01-19 16:49:15 +00:00
$info = $iFacto->getLibInfoCS($PaiementCS);
$PaiementInfo = $info['LibCS'];
2015-01-19 16:49:15 +00:00
}
2015-07-20 08:14:39 +00:00
2015-01-19 16:49:15 +00:00
$values = array(
'SourceID' => $etablissement->source_id,
'Siret' => $etablissement->siren.$etablissement->nic,
'DateCreaEn' => $DateCreaEn,
'BilanCA' => $BilanCA,
'BilanDateCloture' => $BilanDateCloture,
'PaiementCS' => $PaiementCS,
'PaiementInfo' => $PaiementInfo,
'Indiscore' => $Indiscore,
'Encours' => $Encours,
);
2015-07-20 08:14:39 +00:00
2015-01-19 16:49:15 +00:00
// --- Trier données
$line = array();
foreach ( $fileOptionsOut['columns'] as $i => $column ) {
$line[] = $values[$column];
}
// --- Ecrire ligne
if ($opts->debug) { echo " - Ecriture ligne"; }
if ( empty($fileOptionsOut['enclosure']) ) {
2015-02-09 10:58:58 +00:00
fwrite($fp, join($fileOptionsOut['delimiter'], $line)."\n");
} else {
fputcsv($fp, $line, $fileOptionsOut['delimiter'], $fileOptionsOut['enclosure']);
}
2015-07-20 08:14:39 +00:00
2015-01-19 16:49:15 +00:00
if ($opts->debug) { echo "\n"; }
}
// --- Fermeture fichier
fclose($fp);
2015-07-20 08:14:39 +00:00
2015-01-19 16:49:15 +00:00
// --- Encoding
if ( array_key_exists('encoding', $fileOptionsOut) ) {
if ( $fileOptionsOut['encoding'] == 'ISO-8859-15' ) {
passthru("iconv -f UTF-8 -t ISO-8859-15 ".$file." -o ".$file.".enc");
passthru("cp -fv ".$file.".enc ".$file);
}
}
2015-07-20 08:14:39 +00:00
2015-01-19 16:49:15 +00:00
$nbLines = $row;
echo date('Y-m-d H:i:s')." - Nb Lignes Traitées : ".$nbLines."\n";
2015-07-20 08:14:39 +00:00
2015-01-19 16:49:15 +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,
'fileOut' => basename($file),
'depotType' => $typeDepot,
'depotDate' => '0000-00-00 00:00:00',
));
}
}
echo date('Y-m-d H:i:s')." - Fin.\n";