batch/bin/prestaA6cmoEntrep.php

1211 lines
60 KiB
PHP
Raw Normal View History

<?php
/**
* Diffusion Insee Spécifique A6CMO
* - Executer tous les lundi
* - Lire la tables des prestations de type A6CMO, récupérer les paramètres et le numéro d'incrément de fichier
*
* Options d'execution à paramètrer dans la base
* nomClient => Libellé du client pour la prestation
* typePrestation => diffusionInsee
* (prestaActive => depuis paramètres)
* (clientIdentifiant => Code prestation, depuis paramètres)
* clientNumTourFichier => Numéro de tour du fichier pour le client
* nbBilansMax => Nombre de bilans max
* typeLigneBilan => 401
* CodeCom => Liste des codes communes séparés par des virgules
* CJ =>
* CJEx => Liste des CJ séparés par des virgules
* NAF =>
* NAFEx => Liste des NAF séparés par des virgules
* freqenvois => Fréquence des envois H:Hebdo, M=Mensuel, Q=Quotidien
* mailTo => Liste des emails séparés par des virgules
* EOL => Linux : LF (\n), Windows CRLF (\r\n)
*/
error_reporting(E_ALL ^ E_STRICT ^ E_NOTICE ^ E_WARNING ^ E_DEPRECATED);
// --- Define path to application directory
defined('APPLICATION_PATH')
|| define('APPLICATION_PATH', realpath(__DIR__ . '/../application'));
// --- Define application environment
defined('APPLICATION_ENV')
|| define('APPLICATION_ENV', (getenv('APPLICATION_ENV') ? getenv('APPLICATION_ENV') : 'production'));
// --- Composer autoload
require_once realpath(__DIR__ . '/../vendor/autoload.php');
// --- Create application, bootstrap, and run
$application = new Zend_Application(APPLICATION_ENV, APPLICATION_PATH . '/configs/application.ini');
// --- Options
2016-04-11 16:32:24 +02:00
$displayUsage = false;
try {
$opts = new Zend_Console_Getopt(array(
'help|?' => "Displays usage information.",
'debug' => "Debuggage, genere un fichier test.",
'cron' => "Execution par cron, automatique",
'liste|l' => "Affichage de la liste des prestations",
'stock|s' => "Generation du stock",
'date=s' => "Depuis la date AAAAMMDD[HHIISS]",
'presta|p=s' => "Execution de la prestation id",
'force|f' => "Forcer l'execution",
'nomail' => "Ne pas envoyer l'email",
));
$opts->parse();
} catch (Zend_Console_Getopt_Exception $e) {
2016-04-11 16:32:24 +02:00
$displayUsage = true;
}
// --- Aide / Options
if (count($opts->getOptions())==0 || isset($opts->help)) {
$displayUsage = true;
}
// --- Usage
2016-04-11 16:32:24 +02:00
if ($displayUsage) {
echo "Production de Stock/Diffusion des bases A6CMO (ce traitement ce lance automatiquement pour les diffusions le lundi).\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';
$appconfig = new Zend_Config($application->getOptions());
$db = Zend_Db::factory($appconfig->profil->db->metier);
Zend_Db_Table_Abstract::setDefaultAdapter($db);
// --- Liste des paramètres
$defineParams = array(
'nomClient',
'typePrestation',
'clientIdentifiant',
'clientNumTourFichier',
'nbBilansMax',
'typeLigneBilan',
'CodeCom',
'CJ',
'CJEx',
'NAF',
'NAFEx',
'freqenvois',
'mailTo',
2015-07-27 20:47:19 +00:00
'EOL'
);
// --- Liste des prestations : CLIENT | PRESTATION | ACTIVE
if ($opts->liste) {
$prestaM = new Application_Model_Sdv1ClientsPresta();
$prestaSql = $prestaM->select(true)->setIntegrityCheck(false)
->join('sdv1.clients', 'clients_presta.clientId = clients.id', array('nom'))
->where('clients_presta.type=?', 'a6cmoinsee');
$prestaResult = $prestaM->fetchAll($prestaSql);
if (count($prestaResult) == 0) {
echo date('Y-m-d H:i:s')." - Aucune prestation.\n";
} else {
foreach ($prestaResult as $p) {
echo $p->code;
echo "\t";
if ($p->actif==1) {
echo "ACTIF";
} else {
echo "INACTIF";
}
echo "\t";
echo $p->label;
echo "\t";
echo $p->nom;
echo "\n";
}
}
exit;
}
// --- Liste des prestations pour execution
$prestaM = new Application_Model_Sdv1ClientsPresta();
$prestaSql = $prestaM->select(true)->setIntegrityCheck(false)
->join('sdv1.clients', 'clients_presta.clientId = clients.id', array('nom'))
->where('clients_presta.type=?', 'a6cmoinsee');
$prestaResult = $prestaM->fetchAll($prestaSql);
if (count($prestaResult) == 0) {
echo date('Y-m-d H:i:s')." - Aucune prestation.\n"; exit;
}
$tabPresta = array();
foreach ($prestaResult as $p) {
$tabPresta[$p->code] = $p;
}
// --- Cron : Liste des prestations actives + execution
if ($opts->cron) {
}
// --- Execution prestation unitaire
elseif ($opts->presta) {
if (array_key_exists($opts->presta, $tabPresta)) {
$tabPresta = array($opts->presta => $tabPresta[$opts->presta]);
} else {
echo date('Y-m-d H:i:s')." - Prestation inconnue\n";
}
}
// --- Stop
else {
echo date('Y-m-d H:i:s')." - Aucune execution...\n";
}
$tabProduction = array();
$tTime = array();
// --- Execution
foreach($tabPresta as $prestaId => $prestaDetail) {
echo date('Y-m-d H:i:s')." - Prestation ".$prestaId."\n";
// --- Définition des paramètres par defaut
foreach ($defineParams as $d) {
${'Option'.ucfirst($d)} = null;
}
$OptionEOL = "\n";
$OptionFreqenvois = 'H';
// --- Lire les paramètres de la prestation
$paramsM = new Application_Model_Sdv1ClientsPrestaParams();
$paramsSql = $paramsM->select()->where('code=?', $prestaId);
$paramsResult = $paramsM->fetchAll($paramsSql);
if (count($paramsResult) == 0) {
echo date('Y-m-d H:i:s')." - Aucun paramètres.\n";
continue;
} else {
// --- Un paramètre est enregistré dans une variable $Option{Name}
foreach ($paramsResult as $p) {
if (in_array($p->name, $defineParams)) {
${'Option'.ucfirst($p->name)} = trim($p->value);
}
}
}
// --- Tableau de valeur
$tabFJ = array();
if ($OptionCJ !== null) {
$tabFJ = explode(',', $OptionCJ);
}
$tabFJexclus = array();
if ($OptionCJEx !== null) {
$tabFJexclus = explode(',', $OptionCJEx);
}
$tabNAF = array();
if ($OptionNAF !== null) {
$tabNAF = explode(',', $OptionNAF);
}
$tabNAFexclus = array();
if ($OptionNAFEx !== null) {
$tabNAFexclus = explode(',', $OptionNAFEx);
}
$tabDepCom = array();
if ($OptionCodeCom !== null) {
2015-07-27 20:47:19 +00:00
$tabDepCom = explode(',', $OptionCodeCom);
}
$prestaActive = $prestaDetail->actif;
// --- Lire la dernière execution
$execM = new Application_Model_Sdv1PrestaOut();
$execSql = $execM->select()
->where('code=?', $prestaId)
->where('dateEnd!="0000-00-00 00:00:00"')
->order('dateEnd DESC')->limit(1);
$execResult = $execM->fetchRow($execSql);
$dateLastExec = false;
if ($execResult !== null) {
$dateLastExec = new Zend_Date($execResult->dateEnd, Zend_Date::ISO_8601);
}
$dateNow = new Zend_Date();
// --- Surcharge date
if (strlen($opts->date) == 8) {
$dateLastExec = new Zend_Date($opts->date, 'yyyyMMdd');
} elseif (strlen($opts->date) == 14) {
$dateLastExec = new Zend_Date($opts->date, 'yyyyMMddHHmmss');
}
// --- Livraison d'un stock
if ($opts->stock) {
}
// --- Suivi
elseif (!$opts->force) {
// --- Est ce que la prestation doit s'executer... freqenvois ?
if ($dateLastExec !== false && $dateNow->compareDate($dateLastExec, 'yyyyMMdd') == 0) {
echo date('Y-m-d H:i:s')." - Déjà executé ce jour.\n";
continue;
}
// Fréquence Mensuelle : le 1er lundi du mois
if ($OptionFreqenvois == 'M') {
if ($dateNow->get(Zend_Date::DAY_SHORT) < 8 && $dateNow->get(Zend_Date::WEEKDAY_DIGIT) == 1) {
if ($dateLastExec === false) {
$dateLastExec = $dateNow;
$dateLastExec->subDay(31);
}
} else {
echo date('Y-m-d H:i:s')." - Pas d'execution ce jour.\n";
continue;
}
}
// Fréquence Hebdomadaire (par défaut) : le lundi
elseif ($OptionFreqenvois == 'H') {
if ($dateNow->get(Zend_Date::WEEKDAY_DIGIT) == '1') {
if ($dateLastExec === false) {
$dateLastExec = $dateNow;
$dateLastExec->subDay(7);
}
} else {
echo date('Y-m-d H:i:s')." - Pas d'execution ce jour.\n";
continue;
}
}
// Fréquence Quotidienne : du lundi au vendredi
elseif ($OptionFreqenvois == 'Q') {
if (in_array($dateNow->get(Zend_Date::WEEKDAY_DIGIT), array(1,2,3,4,5))) {
if ($dateLastExec === false) {
$dateLastExec = $dateNow;
$dateLastExec->subDay(1);
}
} else {
echo date('Y-m-d H:i:s')." - Pas d'execution ce jour.\n";
continue;
}
}
}
// Si pas de date
if ($dateLastExec === false) {
echo date('Y-m-d H:i:s')." - Pas de date.\n";
continue;
}
$dateDebut = $dateLastExec->toString('yyyy-MM-dd HH:mm:ss');
if (!defined('VERSION_FICHIER_IDENTITE'))
define('VERSION_FICHIER_IDENTITE','0106');
$tLibFreq = array(
'Q' => 'Quotidien',
'H' => 'Hebdo',
2015-07-27 20:47:19 +00:00
'M' => 'Mensuel'
);
$iDb = new WDB();
$iInsee = new Metier_Insee_MInsee($iDb);
$iBodacc = new Metier_Bodacc_MBodacc($iDb);
$iRnvp = new Metier_Partenaires_MRnvp();
$dateDeb = date('YmdHis');
$file = $OptionTypePrestation.'_'.$prestaId.'_'.$dateDeb.'.txt';
$filepath = $appconfig->profil->path->storage . '/clients/A6CMO/' . $file;
if (empty($opts->debug)) {
$suiviM = new Application_Model_Sdv1PrestaOut();
2015-07-27 20:47:19 +00:00
$suiviId = $suiviM->insert(array(
'code' => $prestaId,
2015-07-27 20:47:19 +00:00
'dateStart' => $dateDeb,
));
}
// --- Ligne d'entete
$str = initstr('001', 3, '0', ALIGN_RIGHT). // Type de ligne
initstr($dateDeb, 14 ). // Date de génération du fichier
initstr($OptionClientNumTourFichier, 10, '0', ALIGN_RIGHT). // Numéro de tour du fichier pour le client
initstr($prestaId, 36 ). // Identifiant Client
initstr($OptionTypePrestation, 32 ). // Type de prestation
initstr(VERSION_FICHIER_IDENTITE, 4 ). // Type de prestation
initstr(FILLER, 1901 ). // FILLER
'';
// --- Ecriture fichier
$isWrite = file_put_contents($filepath, initstr($str,LONGUEUR_LIGNE_SORTIE).$OptionEOL);
if ($isWrite === false) {
echo date('Y-m-d H:i:s')." - Impossible d'écrire le fichier $filepath\n";
continue;
}
$nbLignes = 1;
$tabProduction[$prestaId]['nomClient'] = $OptionNomClient;
$tabProduction[$prestaId]['dateDeb'] = $dateDeb;
$tabProduction[$prestaId]['dateRetro'] = $dateLastExec->toString('yyyy-MM-dd hh:ii:ss');
$tabProduction[$prestaId]['frequence'] = $OptionFreqenvois;
$timeDeb = microtime(true);
if (count($tabFJ)>0 && $tabFJ[0]<>'') {
$strFJ =' AND cj IN('.implode(',',$tabFJ).') ';
} elseif (count($tabFJexclus)>0 && $tabFJexclus[0]<>'') {
$strFJ =' AND cj NOT IN('.implode(',',$tabFJexclus).') ';
} else {
$strFJ ='';
}
if (count($tabNAF)>0 && $tabNAF[0]<>'') {
$strNAF=" AND ape_etab IN('".implode("','",$tabNAF)."') ";
} elseif (count($tabNAFexclus)>0 && $tabNAFexclus[0]<>'') {
$strNAF=" AND ape_etab NOT IN('".implode("','",$tabNAFexclus)."') ";
} else {
$strNAF ='';
}
$strDepCom=$strDepComStock='';
foreach ($tabDepCom as $idepcom=>$depcom) {
/** @todo Vérifier si les DOM fonctionnent **/
if ($idepcom==0) {
$strDepCom.="AND (";
$strDepComStock.="AND (";
}
$strDepCom.="(insDEPET IN ('".substr($depcom,0,2)."','0".substr($depcom,0,2)."'";
$strDepComStock.="(adr_dep IN ('".substr($depcom,0,2)."','0".substr($depcom,0,2)."'";
if (substr($depcom,0,2)>96) {
$strDepCom.=",'".substr($depcom,0,3)."'";
$strDepComStock.=",'".substr($depcom,0,3)."'";
}
$strDepCom.=") "; $strDepComStock.=") ";
if (substr($depcom,2,3)*1==0) $depSeul=true;
else {
$depSeul=false;
$strDepCom.="AND insCOMET=".substr($depcom,2,3);
$strDepComStock.="AND adr_com=".substr($depcom,2,3);
// On test si il y a présence d'un code rivoli séparé par un point "."
if (substr($depcom,5,1)=='.') {
$strDepCom.=" AND insCODEVOIE LIKE '".substr($depcom,6,4)."%'";
$strDepComStock.=" AND rivoli LIKE '".substr($depcom,6,4)."%'";
}
}
$strDepCom.=") "; $strDepComStock.=") ";
if (isset($tabDepCom[$idepcom+1])) { $strDepCom.=' OR '; $strDepComStock.=' OR '; }
elseif (trim(substr($depcom,3,2))<>'') { $strDepCom.=')'; $strDepComStock.=')'; }
elseif ($depSeul) { $strDepCom.=')'; $strDepComStock.=')'; }
}
if ($opts->stock) {
echo date('Y-m-d H:i:s') ." - Sélection du stock pour '$OptionNomClient' (dernier $OptionFreqenvois le $dateDebut)\n";
} else {
echo date('Y-m-d H:i:s') ." - Sélection de la cible $OptionFreqenvois pour '$OptionNomClient' depuis $dateDebut...\n";
}
if ($opts->stock) {
$field = 'siren, nic';
$table = 'etablissements_old';
$where = "source=2 AND actif=1 AND siege IN (0,1) $strDepComStock $strFJ $strNAF";
$etab = $iDb->select($table, $field, $where, false, MYSQL_ASSOC);
if ($iDb->getLastErrorNum() == 1146) {
// Table don't exist ?
$table = 'etablissements';
$etab = $iDb->select($table, $field, $where, false, MYSQL_ASSOC);
}
}
else {
$strFJ = str_replace(' cj ',' insCJ ', $strFJ);
$strNAF = str_replace(' ape_etab ',' insAPET700 ', $strNAF);
$field = 'LPAD(insSIREN,9,0) AS siren, LPAD(insNIC,5,0) AS nic,
insDESTINAT, insEVE, insDATEVE, insTYPETAB, insSIRETPS, insSIRETASS, MAX(insMNICSIEGE) AS insMNICSIEGE, MAX(insMNOMEN) AS insMNOMEN, MAX(insMCJ) AS insMCJ,
MAX(insMAPEN) AS insMAPEN, MAX(insMENSEIGNE) AS insMENSEIGNE, MAX(insMAPET) AS insMAPET, MAX(insMADRESSE) AS insMADRESSE, MAX(insMAUXILT) AS insMAUXILT,
MAX(insMSIGLE) AS insMSIGLE, MAX(insMEXPLEN) AS insMEXPLEN, MAX(insMEXPLET) AS insMEXPLET, insDREACTET, insDREACTEN';
$table = 'insee.insee_even';
$where = "1 $strDepCom $strFJ $strNAF AND dateInsert>='$dateDebut' AND (insVMAJ NOT IN ('I','F') OR insVMAJ2=1 OR insVMAJ3=1) GROUP BY insSIREN, insNIC";
$etab = $iDb->select($table, $field, $where, false, MYSQL_ASSOC);
}
echo "SELECT $field FROM $table WHERE $where;";
echo date('Y-m-d H:i:s')." - ".$iDb->getLastErrorMsg()."\n";
$nbEtab = count($etab);
echo date('Y-m-d H:i:s')." - Nombre d'établissement en sortie : ".$nbEtab."\n";
if (empty($opts->debug)) {
$suiviM->update(array('unitTotal' => $nbEtab), 'id='.$suiviId);
}
//@todo :
$tabProduction[$prestaId]['nbEtabs']=$nbEtab;
$unit = 0;
$nbLignes200 = $nbLignesBil = 0;
foreach ($etab as $lSiret)
{
$unit++;
// Réinitialisation de zones
$ev_EVE=$ev_TYPETAB=$ev_DESTINAT='';
$ev_SIRETLIE=$ev_SIRETLIETYPE=$ev_MNICSIEGE=$ev_MNOMEN=$ev_MCJ=$ev_MAPEN=$ev_DREACTEN=$ev_DATEFEREN=$ev_DATEVE=0;
$ev_MENSEIGNE=$ev_MAPET=$ev_MADRESSE=$ev_MAUXILT=$ev_MSIGLE=$ev_MEXPLEN=$ev_MEXPLET=0;
$siren=$lSiret['siren'];
$nic=$lSiret['nic'];
$t1=microtime(1);
$a=$iInsee->getIdentiteEntreprise($siren, $nic);
$t2=microtime(1);
$tTime['Identite']+=$t2-$t1;
$b=$iInsee->getInfosNotice($siren, $nic);
$t3=microtime(1);
$tTime['Notice']+=$t3-$t2;
$c=$iInsee->getAdresse($siren, $nic);
$t4=microtime(1);
$tTime['Adresse']+=$t4-$t3;
echo date ('Y/m/d - H:i:s')." - Entité $unit/$nbEtab - Siret $siren $nic\n";
if ($opts->stock === null) {
$ev_EVE=trim($lSiret['insEVE']);
// Conversion de sirene4 en sirene3
switch($ev_EVE) {
case 'CE': // Création établissement
case 'CC': // Création par le calage
$ev_EVE=130; // Création de l'établissement
break;
case 'CS': // Création siège
$ev_EVE=110; // Création de l'entreprise
break;
case 'SU': // Cessation juridique
$ev_EVE=410; // Cessation juridique de l'entreprise
break;
case 'O': // Sortie du champ de la diffusion commerciale
$ev_EVE=795; // Personne radiée à sa demande de de la base SIRENE diffusion
break;
case 'RI': // Refus d'immatriculation au RCS
$ev_EVE=810; // Suppression du SIREN suite au refus d'inscription au RCS
break;
case 'I': // Entrée dans le champ de la diffusion commerciale
$ev_EVE=125; // Réactivation de l'entreprise suite à une mise à jour du répertoire SIRENE
break;
case 'RE': // Réactivation établissement
$ev_EVE=145; // Reprise d'activité de l'établissement suite à une mise à jour du répertoire SIRENE
break;
case 'RS': // Réactivation siège
$ev_EVE=120; // Réactivation de l'entreprise
break;
case 'SE': // Fermeture (ou désactivation) établissement
$ev_EVE=430; // Fermeture de l'établissement
break;
case 'SS': // Fermeture (ou désactivation) siège
$ev_EVE=425; // Absence d'activité d'une entreprise suite à une mise à jour au répertoire SIRENE
break;
case 'MC': // Modification par le calage
$ev_EVE=781; // Modification de l'établissement suite à correction d'erreur
break;
case 'SC': // Suppression par le calage
$ev_EVE=435; // Fermeture de l'établissement suite à une mise à jour au répertoire SIRENE
break;
case 'ME': // Modification établissement
$ev_EVE=780; // Modification de l'établissement
break;
case 'MS': // Modification siège
$ev_EVE=610; // Modification d'activité au niveau du SIREN associé à une activation économique par adjonction de moyens de production
break;
case 'MU': // Modification entreprise
$ev_EVE=631; // Modification d'activité du SIREN
break;
case 'MTDE': // Modification établissement départ (transfert)
case 'MTAE': // Modification établissement arrivée (transfert)
case 'MTDS': // Modification siège départ (transfert)
case 'MTAS': // Modification siège arrivée (transfert)
$ev_EVE=540; // Modification de l'établissement d'arrivée et modification de l'établissement de départ dans le cadre d'un transfert
break;
case 'CTE': // Création établissement (transfert)
case 'CTS': // Création siège (transfert)
$ev_EVE=520; // Création de l'établissement d'arrivée et modification de l'établissement de départ dans le cadre d'un transfert
break;
case 'STE': // Fermeture établissement (transfert)
case 'STS': // Fermeture siège (transfert)
$ev_EVE=530; // Modification de l'établissement d'arrivée et cessation de l'établissement de départ dans le cadre d'un transfert
break;
default:
$ev_EVE=substr($ev_EVE,0,3);
break;
}
$ev_DATEVE=$lSiret['insDATEVE'];
$ev_TYPETAB=$lSiret['insTYPETAB'];
$ev_DESTINAT=$lSiret['insDESTINAT'];
switch($ev_EVE*1) {
case 410:
case 420:
case 425:
$ev_DATEFEREN=substr(strtr($ev_DATEVE,array('-'=>'',':'=>'')),0,8);
break;
}
$ev_SIRETLIE=$lSiret['insSIRETPS']*1;
if ($ev_SIRETLIE<1000) {
$ev_SIRETLIE=$lSiret['insSIRETASS']*1;
if ($ev_SIRETLIE<1000) $ev_SIRETLIETYPE='';
else $ev_SIRETLIETYPE='A';
} else
$ev_SIRETLIETYPE='P';
$ev_MNICSIEGE=$lSiret['insMNICSIEGE'];
$ev_MNOMEN=$lSiret['insMNOMEN'];
$ev_MCJ=$lSiret['insMCJ'];
$ev_MAPEN=$lSiret['insMAPEN'];
$ev_MENSEIGNE=$lSiret['insMENSEIGNE'];
$ev_MAPET=$lSiret['insMAPET'];
$ev_MADRESSE=$lSiret['insMADRESSE'];
$ev_MAUXILT=$lSiret['insMAUXILT'];
$ev_MSIGLE=$lSiret['insMSIGLE'];
$ev_MEXPLEN=$lSiret['insMEXPLEN'];
$ev_MEXPLET=$lSiret['insMEXPLET'];
$ev_DREACTEN=$lSiret['insDREACTEN'];
}
$tmp = $iDb->select('jo.etablissements_act', 'bilType, bilAnnee, bilTca, bilFL', "siren=$siren LIMIT 0,1", false, MYSQL_ASSOC, false);
if (count($tmp)>0) {
$tcaSED=$tmp[0]['bilTca'];
$tcaSEDtype=$tmp[0]['bilType'];
$tcaSEDannee=$tmp[0]['bilAnnee'];
$tcaSEDmt=$tmp[0]['bilFL'];
} else {
$tcaSED=' ';
$tcaSEDtype='I';
$tcaSEDannee='0000';
$tcaSEDmt=0;
}
// @todo : Forcage pour idclient=3 nimes metropole !!!
if ($prestaId=='DIFINSPRDFTSA6CMONIMESMETRO' && $tcaSED<>' ') $a['TrancheCA']=$tcaSED;
$tabRnvp=$iRnvp->getAdresseRnvpSource(2, $a['SourceId']);
$codeRnvp=$tabRnvp['CQAdrRnvp']*1;
if ($codeRnvp>0) {
$L1rnvp=strtr($tabRnvp['L1rnvp'],'/*',' ');
$L2rnvp=$tabRnvp['L2rnvp'];
$L3rnvp=$tabRnvp['L3rnvp'];
$L4rnvp=$tabRnvp['L4rnvp'];
$L5rnvp=$tabRnvp['L5rnvp'];
$L6rnvp=$tabRnvp['L6rnvp'];
$L7rnvp=$tabRnvp['L7rnvp'];
} elseif (trim($a['L1_NOMEN'])<>'' && trim($a['L4_VOIE'])<>'' && trim($a['L6_POST'])<>'') {
// On prend l'adresse RNVP origine INSEE (Syracuse)
$L1rnvp=strtr($a['L1_NOMEN'],'/*',' ');
$L2rnvp=$a['L2_COMP'];
$L3rnvp=$a['L3_CADR'];
$L4rnvp=$a['L4_VOIE'];
$L5rnvp=$a['L5_DISP'];
$L6rnvp=$a['L6_POST'];
$L7rnvp=$a['L7_ETRG'];
} else {
// Historique Insee Notice 80
$L1rnvp=strtr($c['L1_NOM'],'/*',' ');
$L2rnvp=$c['L2_NOM2'];
$L3rnvp=$c['L3_ADRCOMP'];
$L4rnvp=$c['L4_VOIE'];
$L5rnvp=$c['L5_DISTSP'];
$L6rnvp=$c['L6_POST'];
$L7rnvp=$c['L7_PAYS'];
}
// 1 (3) : Obligatoire CODE_ENTETE Ligne de description structurée de l'identité
$str = initstr(200, 3) .
// 4 (10) : Obligatoire ID Numéro unique d'identification interne d'un établissement S&D
initstr($a['SourceId'], 10 , '0', ALIGN_RIGHT) .
// 14 (9) : Obligatoire SIREN Siren de l'entreprise
initstr($siren, 9 , '0', ALIGN_RIGHT) .
// 14 (5) : Obligatoire NIC Nic de l'établissement
initstr($nic, 5 , '0', ALIGN_RIGHT) .
// 14 (3) : Obligatoire SOURCE Source de la fiche d'identité
initstr($a['Source'], 3 , '0', ALIGN_RIGHT) .
// 14 (1) : Obligatoire SIRETVALIDE Siren/siret valide
initstr($iInsee->valideSiren($siren,$nic), 1 , '0', ALIGN_RIGHT) .
// 14 (10) : Facultatif NUMRCS Numéro de Registre du Commerce et des Sociétés
initstr($a['numRC'], 10 ) .
// 14 (6) : Facultatif TRIBUNAL Identifiant du Tribunal
initstr($a['Tribunal'], 6 ) .
// 14 (9) : Obligatoire DATEMAJ Date de la dernière mise à jour dans la base S&D
initstr(str_replace('-', '', $a['dateMajIdentite']), 8 , '0', ALIGN_RIGHT) . // @todo : Erreur date 20150730 vs 20150803 ?
// 14 (9) : Obligatoire ACTIF Établissement juridiquement actif
initstr($a['Actif'], 1 , '0', ALIGN_RIGHT) .
// 14 (9) : Obligatoire ACTIFECO Établissement économiquement actif
initstr($a['ActifEco'], 1 , '0', ALIGN_RIGHT) .
// 14 (9) : Obligatoire SITJUR Situation Juridique de l'entreprise
initstr($a['SituationJuridique'], 2 ) .
// 14 (9) : Facultatif EVE Dernier événement Insee recensé
initstr($ev_EVE, 3 ) .
// 14 (9) : Facultatif DATEVE Date du dernier événement Insee recensé
initstr(str_replace('-','', $a['DateMajINSEE']), 8 , '0', ALIGN_RIGHT) .
// 14 (9) : Facultatif TYPETAB Type d'établissement concerné par l'événement
initstr($ev_TYPETAB, 2 ) .
// 14 (9) : Obligatoire SIEGE Établissement siège, secondaire ou principal
initstr($a['Siege'], 1 , '0', ALIGN_RIGHT) .
// 14 (9) : Obligatoire NOM Raison Sociale
initstr($a['Nom'], 160 ) . // @todo : pas de raison sociale sur certaines entités
// 14 (9) : Facultatif NOMCOM Nom commercial
initstr($a['NomCommercial'], 160 ) .
// 14 (9) : Facultatif ENSEIGNE Enseigne de l'établissement
initstr($a['Enseigne'], 80 ) .
// 14 (9) : Facultatif SIGLE sigle de l'entreprise
initstr($a['Sigle'], 40 ) .
// 14 (9) : Facultatif ADR_NUMVOIE Numéro dans la voie
initstr($a['AdresseNum'], 4 , '0', ALIGN_RIGHT) .
// 14 (9) : Facultatif ADR_BTQ Indicateur de répétition (Bis, Ter, etc...)
initstr($a['AdresseBtq'], 1 ) .
// 14 (9) : Facultatif ADR_TYPVOIE Type de voie
initstr($a['AdresseVoie'], 4 ) .
// 14 (9) : Obligatoire ADR_LIBVOIE Libellé de la voie
initstr($a['AdresseRue'], 32 ) .
// 14 (9) : Obligatoire ADR_LIBCOM Commune
initstr($a['Ville'], 32 ) .
// 14 (9) : Obligatoire ADR_CP Code postal
initstr($a['CP'], 5 , '0', ALIGN_RIGHT) .
// 14 (9) : Facultatif ADR_COMP Complément d'adresse
initstr($a['Adresse2'], 38 ) .
// 14 (9) : Facultatif ADR_DISTSP Distribution spéciale
initstr('', 38 ) .
// 14 (9) : Facultatif PAYS Pays
initstr($a['Pays'], 38 ) .
// 14 (9) : Facultatif PAYSISO2 Code Pays au format ISO2
initstr($a['PaysIso2'], 2 ) .
// 14 (9) : Obligatoire ADR_DEP Département de l'établissement
initstr($a['Dept'], 2 ) .
// 14 (9) : Obligatoire ADR_COM Code commune de l'établissement
initstr($a['codeCommune'], 3 , '0', ALIGN_RIGHT) .
// 14 (9) : Facultatif CODEVOIE Code voie de l'établissement
initstr(str_replace(' ', '', $a['Rivoli']), 5 ) .
// 14 (9) : Facultatif CODEIRIS Code Iris de l'établissement
initstr($a['codIris'], 4 ) .
// 14 (9) : Facultatif CODEILOT Code Ilot de l'établissement
initstr('', 5 ) .
// 14 (9) : Facultatif ADRESSEDOM Indicateur d'adresse de domiciliation
initstr($a['AdresseDom'], 1 , '0', ALIGN_RIGHT) .
// 14 (9) : Facultatif TEL Numéro de téléphone
initstr($a['Tel'], 15 ) . // @todo : Différence dans les téléphones ou absent
// 14 (9) : Facultatif FAX Numéro de télécopie
initstr($a['Fax'], 15 ) .
// 14 (9) : Facultatif WEB Site Web
initstr($a['Web'], 80 ) .
// 14 (9) : Facultatif MAIL Adresse Email de contact générique
initstr($a['Mail'], 80 ) . // @todo : Absence email
// 14 (9) : Facultatif AUXILT Auxiliarité de l'activité de l'établissement
initstr($a['Auxiliaire'], 1 , '0', ALIGN_RIGHT) .
// 14 (9) : Facultatif SAISONAT Saisonnalité de l'établissement
initstr($a['Saisonnalite'], 1 , '0', ALIGN_RIGHT) .
// 14 (9) : Facultatif ACTIVNAT Nature de l'activité de l'établissement
initstr($a['NatureActivite'], 2 , '0', ALIGN_RIGHT) .
// P 922 - L 2 : Facultatif ORIGINE Origine de la création de l'établissement
initstr($a['OrigineCreation'], 2 ) . // @todo : aberrant 2 cas
// 14 (9) : Facultatif TYPEXPLOIT Type d'exploitation
initstr($a['TypeExploitation'], 2 , '0', ALIGN_RIGHT) .
// 14 (9) : Facultatif LIEUACT Lieu de l'activité de l'établissement
initstr($a['LIEUACT'], 2 , '0', ALIGN_RIGHT) .
// 14 (9) : Facultatif ACTISURF Type de magasin
initstr($a['ACTISURF'], 2 , '0', ALIGN_RIGHT) .
// 14 (9) : Facultatif PRODPART Participation particulière à la production de l'établissement
initstr($a['PRODPART'], 1 , '0', ALIGN_RIGHT) .
// 14 (9) : Facultatif ARRONET Arrondissement de l'établissement
initstr($b['insARRONET'], 2 , '0', ALIGN_RIGHT) .
// 14 (9) : Facultatif CTONET Canton
initstr($b['insCTONET'], 3 , '0', ALIGN_RIGHT) .
// 14 (9) : Facultatif TCD Tranche de commune détaillée
initstr($b['insTCD'], 2 , '0', ALIGN_RIGHT) .
// 14 (9) : Facultatif ZEMET Zone d'emploi
initstr($b['insZEMET'], 2 , '0', ALIGN_RIGHT) .
// 14 (9) : Facultatif DU Département de l'unité urbaine de localisation
initstr($b['insDU'], 2 ) .
// 14 (9) : Facultatif TU Taille de l'unité urbaine
initstr($b['insTU'], 1 ) .
// 14 (9) : Facultatif UU Numéro de l'untié urbaine
initstr($b['insUU'], 2 ) .
// 14 (9) : Facultatif DCRET Date de création de l'établissement
initstr(str_replace('-', '', $a['DateCreaEt']), 8 , '0', ALIGN_RIGHT) .
// 14 (9) : Obligatoire APE_ETAB Code activité dans la NAF rév2 de l'établissement
initstr($a['NafEtab'], 5 ) .
// 14 (9) : Facultatif NACE_ETAB Code activité NACE de l'établissement
initstr($a['NaceEtab'], 5 ) .
// 14 (9) : Facultatif DAPET Année de validité de l'activité principale de l'établissement
initstr(0, 4 , '0', ALIGN_RIGHT) .
// 14 (9) : Facultatif EFF_ET Effectif de l'établissement
initstr($a['EffectifEtab'], 7 , '0', ALIGN_RIGHT) .
// 14 (9) : Facultatif TEFF_ET Tranche d'effectif de l'établissement
initstr($a['EffEtTr'], 2 ) .
// 14 (9) : Facultatif DEFET Année de mise à jour de l'effectif établissement
initstr($a['AnneeEffEt'], 4 , '0', ALIGN_RIGHT) .
// 14 (9) : Facultatif MODET Modalité de l'activité pricipale de l'établissement
initstr('', 1 ) .
// 14 (9) : Facultatif EXPLET Etablissement exploitant tout ou partie des moyens de production
initstr($a['EXPLET'], 1 ) .
// 14 (9) : Facultatif RPET Région de localisation de l'établissement
initstr($b['insRPET'], 2 , '0', ALIGN_RIGHT) .
// 14 (9) : Facultatif DREACTET Date de réactivation de l'établissement
initstr(str_replace('-','',0), 8 , '0', ALIGN_RIGHT) .
// 14 (9) : Facultatif DATEFERET Date de fermeture de l'établissement
initstr(str_replace('-','',0), 8 , '0', ALIGN_RIGHT) .
// 14 (9) : Facultatif EAEANT Année de validité des rubriques de niveau Etab provenant des EAE*
initstr($b['insEAEANT'], 4 , '0', ALIGN_RIGHT) .
// 14 (9) : Facultatif EAEAPET Activité principale de l'établissement issue des EAE
initstr($b['insEAEAPET'], 5 ) .
// 14 (9) : Facultatif EAESEC1T Activité secondaire de l'établissement issue des EAE
initstr($b['insEAESEC1T'], 5 ) .
// 14 (9) : Facultatif EAESEC2T Autre activité secondaire de l'établissement issue des EAE
initstr($b['insEAESEC2T'], 5 ) .
// 14 (9) : Facultatif DCREN Date de création de l'entreprise
initstr(str_replace('-','',$a['DateCreaEn']), 8 , '0', ALIGN_RIGHT) .
// 14 (9) : Obligatoire APE_ENT Code activité dans la NAF rév2 de l'entreprise
initstr($a['NafEnt'], 5 ) .
// 14 (9) : Facultatif NACE_ENT Code activité NACE de l'entreprise
initstr($a['NaceEnt'], 5 ) .
// 14 (9) : Facultatif DAPEN Année de validité de l'activité principale de l'entreprise
initstr(0, 4 , '0', ALIGN_RIGHT) .
// 14 (9) : Facultatif EFF_ENT Effectif de l'entreprise
initstr($a['Effectif'], 7 , '0', ALIGN_RIGHT) .
// 14 (9) : Facultatif TEFF_ENT Tranche d'effectif de l'entreprise
initstr($a['EffEnTr'], 2 ) .
// 14 (9) : Facultatif DEFEN Année de mise à jour de l'effectif entreprise
initstr($a['AnneeEffEn'], 4 , '0', ALIGN_RIGHT) .
// 14 (9) : Facultatif MODEN Modalité de l'activité pricipale de l'entreprise
initstr($a['MODEN'], 1 ) .
// 14 (9) : Facultatif EXPLEN Entreprise exploitant tout ou partie des moyens de production
initstr($a['EXPLEN'], 1 ) .
// 14 (9) : Facultatif RPEN Région de localisation du siège de l'entreprise
initstr($b['insRPEN'], 2 , '0', ALIGN_RIGHT) .
// 14 (9) : Facultatif DREACTEN Date de réactivation de l'entreprise
initstr(str_replace('-','',$ev_DREACTEN), 8 , '0', ALIGN_RIGHT) .
// 14 (9) : Facultatif DATEFEREN Date de fermeture de l'entreprise
initstr(str_replace('-','',$ev_DATEFEREN), 8 , '0', ALIGN_RIGHT) .
// 14 (9) : Facultatif DATEIMMAT Date d'immatriculation de l'entreprise au RCS
initstr(str_replace('-','',$a['dateImmat']),8 , '0', ALIGN_RIGHT) .
// 14 (9) : Facultatif DATERAD Date de radiation de l'entreprise du RCS
initstr(str_replace('-','',$a['dateRad']), 8 , '0', ALIGN_RIGHT) .
// 14 (9) : Facultatif CAPITAL Montant du capital de l'entreprise
initstr($a['Capital'], 15 , '0', ALIGN_RIGHT) .
// 14 (9) : Facultatif CAPITALTYPE Type de capital
initstr($a['CapitalType'], 1 ) .
// 14 (9) : Facultatif CAPITALDEV Devise du capital
initstr($a['CapitalDev'], 3 ) .
// P 1109 - L 4 : Obligatoire, CJ Catégorie Juridique de l'entreprise
initstr($a['FJ'], 4 , '0', ALIGN_RIGHT) . // @todo non definie
// 14 (9) : Facultatif CIVILITE Civilité de l'entreprise si Personne Physique
initstr($a['Civilite'], 1 , '0', ALIGN_RIGHT) .
// 14 (9) : Facultatif NBETAB Nombre d'établissements actifs de l'entreprise
initstr($a['NbEtab'], 4 , '0', ALIGN_RIGHT) .
// 14 (9) : Facultatif TCA Tranche de chiffre d'affaire
initstr($a['TrancheCA'], 1 , '0', ALIGN_RIGHT) .
// 14 (9) : Facultatif TCAEXP Tranche de chiffre d'affaire à l'export
initstr($a['TrancheCAexp'], 1 , '0', ALIGN_RIGHT) .
// 14 (9) : Facultatif APRM Activité principale au registre des métiers
initstr($a['APRM'], 6 ) .
// 14 (9) : Facultatif MONOREG Mono-régionalité de l'entreprise
initstr($a['MONOREG'], 1 , '0', ALIGN_RIGHT) .
// 14 (9) : Facultatif REGIMP Principale région d'implantation de l'entreprise
initstr($a['REGIMP'], 2 , '0', ALIGN_RIGHT) .
// 14 (9) : Facultatif MONOACT Mono-activité de l'entreprise
initstr($a['MONOACT'], 1 , '0', ALIGN_RIGHT) .
// 14 (9) : Facultatif NICSIEGE Nic de l'établissement siège
initstr(substr($a['SiretSiege'],-5), 5 , '0', ALIGN_RIGHT) .
// 14 (9) : Facultatif RECME Répertoire des Entreprises Contrôlées Majoritairement par l'État
initstr($a['RECME'], 1 , '0', ALIGN_RIGHT) .
// 14 (9) : Facultatif SIRETLIE Siret lié : prédécesseur, successeur, doublon, autre
initstr($ev_SIRETLIE, 14 , '0', ALIGN_RIGHT) .
// 14 (9) : Facultatif SIRETLIETYPE Type de sitet lié
initstr($ev_SIRETLIETYPE, 1) .
// 1151 (5) : Facultatif NICPREC Nic de l'établissement prédécesseur (dans le cadre d'un transfert)
initstr($a['AutreSiret']['pre']['nic'], 5 , '0', ALIGN_RIGHT) . // @todo non definie
// 14 (9) : Facultatif NICSUIV Nic de l'établissement successeur (dans le cadre d'un transfert)
initstr($a['AutreSiret']['suc']['nic'], 5 , '0', ALIGN_RIGHT) . // @todo non definie
// 14 (9) : Facultatif insDESTINAT Destination Insee
initstr($ev_DESTINAT, 2 ) .
// 14 (9) : Facultatif insDEPCOMEN Code commune Insee du siège de l'entreprise
initstr($b['insDEPCOMEN'], 5 , '0', ALIGN_RIGHT) .
// 14 (9) : Facultatif insMNICSIEGE Indicateur de MAJ du NIC SIEGE
initstr($ev_MNICSIEGE, 1 , '0', ALIGN_RIGHT) .
// 14 (9) : Facultatif insMNOMEN Indicateur de MAJ de la Raison Sociale
initstr($ev_MNOMEN, 1 , '0', ALIGN_RIGHT) .
// 14 (9) : Facultatif insMCJ Indicateur de MAJ de la Forme Juridique
initstr($ev_MCJ, 1 , '0', ALIGN_RIGHT) .
// 14 (9) : Facultatif insMAPEN Indicateur de MAJ du NAF entreprise
initstr($ev_MAPEN, 1 , '0', ALIGN_RIGHT) .
// 14 (9) : Facultatif insMENSEIGNE Indicateur de MAJ de l'ENSEIGNE
initstr($ev_MENSEIGNE, 1 , '0', ALIGN_RIGHT) .
// 14 (9) : Facultatif insMAPET Indicateur de MAJ du NAF établissement
initstr($ev_MAPET, 1 , '0', ALIGN_RIGHT) .
// 14 (9) : Facultatif insMADRESSE Indicateur de MAJ de l'ADRESSE de l'établissement
initstr($ev_MADRESSE, 1 , '0', ALIGN_RIGHT) .
// 14 (9) : Facultatif insMAUXILT Indicateur de MAJ de l'AUXILIARITE
initstr($ev_MAUXILT, 1 , '0', ALIGN_RIGHT) .
// 14 (9) : Facultatif insMSIGLE Indicateur de MAJ du SIGLE
initstr($ev_MSIGLE, 1 , '0', ALIGN_RIGHT) .
// 14 (9) : Facultatif insMEXPLEN Indicateur de MAJ du caractère EXPLOITANT entrep
initstr($ev_MEXPLEN, 1 , '0', ALIGN_RIGHT) .
// 14 (9) : Facultatif insMEXPLET Indicateur de MAJ du caractère EXPLOITANT étab
initstr($ev_MEXPLET, 1 , '0', ALIGN_RIGHT) .
// 14 (9) : Facultatif ADR_RNVP Type de Prestation RNVP si RNVP
initstr($codeRnvp, 1 , '0', ALIGN_RIGHT) .
// 14 (9) : Facultatif L1_nomen Ligne 1 : Nom de l'entreprise
initstr($L1rnvp, 38 ) .
// 14 (9) : Facultatif L2_COMP Ligne 2 : Complément de nom
initstr($L2rnvp, 38 ) .
// 14 (9) : Facultatif L3_CADR Ligne 3 : Complément d'adresse
initstr($L3rnvp, 38 ) .
// 14 (9) : Facultatif L4_VOIE Ligne 4 : Adresse
initstr($L4rnvp, 38 ) .
// 14 (9) : Facultatif L5_DISP Ligne 5 : Distribution spéciale
initstr($L5rnvp, 38 ) .
// 14 (9) : Facultatif L6_POST Ligne 6 : Code Postal, commune, etc..
initstr($L6rnvp, 38 ) .
initstr($L7rnvp, 38 ) .
// 14 (9) : Facultatif EAEANN Année de validité des rubriques de niveau ENTREP provenant des EAE*
initstr($b['insEAEANN'], 4 , '0', ALIGN_RIGHT) .
// 14 (9) : Facultatif EAEAPEN Activité principale de l'entreprise issue des EAE
initstr($b['insEAEAPEN'], 5 ) .
// 14 (9) : Facultatif inseaesec1n Activité secondaire n°1 de l'entreprise issue des EAE
initstr($b['insEAESEC1N'], 5 ) .
// 14 (9) : Facultatif inseaesec2n Activité secondaire n°2 de l'entreprise issue des EAE
initstr($b['insEAESEC2N'], 5 ) .
// 14 (9) : Facultatif inseaesec3n Activité secondaire n°3 de l'entreprise issue des EAE
initstr($b['insEAESEC3N'], 5 ) .
// 14 (9) : Facultatif inseaesec4n Activité secondaire n°4 de l'entreprise issue des EAE
initstr($b['insEAESEC4N'], 5 ) .
// P 1475 - L 12 : Facultatif GPSX Latitude en ° et décimales de ° (format WGS1984)
initstr($a['GeoLat'], 12 , ' ', ALIGN_RIGHT) . // @todo : format
// 14 (9) : Facultatif GPSY Longitude en ° et décimales de ° (format WGS1984)
initstr($a['GeoLon'], 12 , ' ', ALIGN_RIGHT) . // @todo : format
// P 1499 - L 1 : Facultatif GPSP Niveau de précision du géocodage
initstr($a['GeoPrecis'], 1 , '0', ALIGN_RIGHT) . // @todo : format
// 14 (9) : Facultatif ZUS Identifiant de la Zone Urbaine Sensible
initstr($a['GeoInfos']['NZUS'], 10 ) .
// 14 (9) : Facultatif ZRU Identifiant de la Zone de Rénovation Urbaine
initstr($a['GeoInfos']['NZRU'], 10 ) .
// 14 (9) : Facultatif ZFU Identifiant de la Zone Franche Urbaine
initstr($a['GeoInfos']['NZFU'], 10 ) .
// 14 (9) : Facultatif CUCS Identifiant de la Zone Contrat Urbain de Cohésion Social
initstr($a['GeoInfos']['NCUCS'],10 ) .
// 14 (9) : Facultatif AFR Identifiant de la Zone AFR
initstr($a['GeoInfos']['NAFR'], 10 ) .
// 14 (9) : Facultatif ZRR Identifiant de la ZRR
initstr($a['GeoInfos']['NZRR'], 10 ) .
// P 160 - L 15 Facultatif TVA Numéro de TVA Intracommunataire
initstr($a['TvaNumero'], 15 ) .
// P 1575 - L 1 : Facultatif TVAVALIDE Numéro de TVA validé
initstr($a['TvaAttribue'], 1 , '0', ALIGN_RIGHT) .
// P 1576 - L 1 : Facultatif ANCIENSIEGE Ancien siège
initstr($a['AncienSiege'], 1 , '0', ALIGN_RIGHT) .
// 14 (9) : Facultatif CODEISIN Code ISIN de l'entreprise si cotation en bourse
initstr($a['Isin'], 12 ) .
// 14 (9) : Facultatif PPDIR1NOM Nom du principal dirigeant
initstr($a['dir1Nom'], 40 ) .
// 14 (9) : Facultatif PPDIR1PRENOM Prénom du principal dirigeant
initstr(preg_replace('/,?\s.*$/','',$a['dir1Prenom']), 30 ) .
// 14 (9) : Facultatif PPDIR1NNAISS Nom de naissance du ppl dirigeant
initstr($a['dir1NomUsage'], 40 ) .
// 14 (9) : Facultatif PPDIR1DNAISS Date de naissance
initstr(str_replace('-','',$a['dir1DateNaiss']), 8 , '0', ALIGN_RIGHT).
// 14 (9) : Facultatif PPDIR1LNAISS Lieu de Naissance
initstr($a['dir1LieuNaiss'], 35 ) .
// P 1742 - L 4 : Facultatif PPDIR1FONC Code Fonction
initstr($a['dir1Code'], 4 , '0', ALIGN_RIGHT) . // @todo : Pas les mêmes code - correction dans lib
// 14 (9) : Facultatif PPDIR1MAJ Date de MAJ du ppl dirigeant
initstr(str_replace('-', '', $a['dir1DateFct']), 8 , '0', ALIGN_RIGHT) .
// 14 (9) : Facultatif PPDIR2NOM Nom du seconde principal dirigeant
initstr($a['dir2Nom'], 40 ) .
// 14 (9) : Facultatif PPDIR2PRENOM Prénom du 2ème principal dirigeant
initstr(preg_replace('/,?\s.*$/', '', $a['dir2Prenom']), 30 ) .
// 14 (9) : Facultatif PPDIR2NNAISS Nom de naissance du 2ème ppl dirigeant
initstr($a['dir2NomUsage'], 40 ) .
// 14 (9) : Facultatif PPDIR2DNAISS Date de naissance du 2ème ppl dirigeant
initstr(str_replace('-','',$a['dir2DateNaiss']), 8 , '0', ALIGN_RIGHT).
// 14 (9) : Facultatif PPDIR2LNAISS Lieu de Naissance du 2ème ppl dirigeant
initstr($a['dir2LieuNaiss'], 35 ) .
// 14 (9) : Facultatif PPDIR2FONC Code Fonction du 2ème ppl dirigeant
initstr($a['dir2Code'], 4 , '0', ALIGN_RIGHT) .
// 14 (9) : Facultatif PPDIR2MAJ Date de MAJ du 2ème ppl dirigeant
initstr(str_replace('-','', $a['dir2DateFct']), 8 , '0', ALIGN_RIGHT) .
// 14 (9) : Facultatif BILANCLOT Date de dernière clôture de bilan disponible
initstr(str_replace('-','', $a['bilanDate']), 8 , '0', ALIGN_RIGHT) .
// 14 (9) : Facultatif BILANDUREE Durée du dernier exercice disponible
initstr($a['bilanMois'], 2 , '0', ALIGN_RIGHT) .
// 14 (9) : Facultatif BILANCA Chiffre d'affaires au dernier bilan disponible
initstr($tcaSEDmt, 15 , '0', ALIGN_RIGHT) .
// 14 (9) : Facultatif BILANRES Résultat au dernier bilan disponible
initstr($a['bilanHN'], 15 , '0', ALIGN_RIGHT) .
// 14 (9) : Tranche de CA SED
initstr($tcaSED, 1 ) .
// 14 (9) : Type de tranche de CA : (R)éel, (I)nconnu ou (E)stimé
initstr($tcaSEDtype, 1 ) .
// 14 (9) : Année du CA
initstr($tcaSEDannee, 4 ) .
// 14 (9) : PPDIR1 Genre
initstr($a['dir1Genre'], 1 ) . // @todo : De temps en temps non délivrés
// 14 (9) : PPDIR2 Genre
initstr($a['dir2Genre'], 1 ) . // @todo : De temps en temps non délivrés
// 14 (9) : Indicateur du champ de publipostage
initstr($a['IND_PUBLIPO']*1, 1 ) .
// 14 (9) : Facultatif FILLER1 Zone libre
initstr(' ', 32 ) ;
/*
AnneeTCA
CapitalNbActions
CapitalMtActions
*/
// --- Ecriture ligne 200
if ($opts->debug && mb_strlen($str)>LONGUEUR_LIGNE_SORTIE) {
echo date('Y-m-d H:i:s')." - Ligne supérieur à LONGUEUR MAX";
}
file_put_contents($filepath, initstr($str,LONGUEUR_LIGNE_SORTIE).$OptionEOL, FILE_APPEND);
$nbLignes++;
$nbLignes200++;
$mBil=new Metier_Partenaires_MBilans($siren);
$tabBilans = $mBil->listeBilans();
$iBil=0;
if ($OptionNbBilansMax>0) {
foreach ($tabBilans as $idxBilan=>$derBilan) {
$iBil++;
$t5=microtime(1);
$p = $mBil->getBilan(WDate::dateT('Ymd','d/m/Y',$derBilan['dateExercice']), $derBilan['typeBilan']);
$t6=microtime(1);
$tTime['Bilan']+=$t6-$t5;
//print_r($p);
if ($p['CONSOLIDE']=='S') $numLiasse='2033';
else $numLiasse='2050';
$unite=strtoupper($p['MONNAIE_LIV_UNITE']);
if ($unite=='') $unite='U';
$nbLignesBil++;
// 14 (9) : Obligatoire CODE_ENTETE Ligne de description structurée de l'identité
$strIni = initstr($OptionTypeLigneBilan, 3) .
// 14 (9) : Obligatoire ID Numéro unique d'identification interne d'un établissement S&D
initstr($a['SourceId'], 10, '0', ALIGN_RIGHT) .
// 14 (9) : Obligatoire SIREN Siren de l'entreprise
initstr($siren, 9, '0', ALIGN_RIGHT) .
// 14 (9) : Obligatoire NIC Nic de l'établissement
initstr($nic, 5, '0', ALIGN_RIGHT) .
// 14 (9) : Obligatoire SOURCE Source de la fiche d'identité
initstr($a['Source'], 3, '0', ALIGN_RIGHT) .
// 14 (9) : Obligatoire SIRETVALIDE Siren/siret valide
initstr($iInsee->valideSiren($siren,$nic), 1 , '0', ALIGN_RIGHT) .
// 14 (9) : Facultatif NUMRCS Numéro de Registre du Commerce et des Sociétés
initstr($a['numRC'], 10 ) .
// 14 (9) : Facultatif TRIBUNAL Identifiant du Tribunal
initstr($a['Tribunal'], 6 ) .
// DATEMAJ Date de la dernière mise à jour du bilan dans la base S&D Format AAAAMMJJ
initstr(str_replace('-','',$p['DATE_FRAICHE_BILAN']), 8, '0', ALIGN_RIGHT) .
// MILLESIME Année du bilan
initstr(substr($p['DATE_FRAICHE_BILAN'],0,4), 4, '0', ALIGN_RIGHT) .
// BILAN_DATE Date de clôture du bilan Format AAAAMMJJ
initstr(str_replace('-','',$p['DATE_CLOTURE']), 8, '0', ALIGN_RIGHT) .
// BILAN_DUREE Durée de l'exercice en mois
initstr($p['DUREE_MOIS'], 2, '0', ALIGN_RIGHT) .
// BILAN_DATEP Date de clôture du bilan précédent Format AAAAMMJJ
initstr(str_replace('-','',$p['DATE_CLOTURE_PRE']), 8, '0', ALIGN_RIGHT) .
// BILAN_DUREEP Durée de l'exercice précédent en mois
initstr($p['DUREE_MOIS_PRE'], 2, '0', ALIGN_RIGHT) .
// BILAN_LIASSE Numéro de la première liasse du bilan 2033,2050
initstr($numLiasse,4) .
// BILAN_TYPE Type de bilan S=Réel Normal Simplifié, C=Consolidé, N=Réel Normal
initstr($p['CONSOLIDE'], 1) .
// BILAN_MONNAIE Code devise de livraison selon la norme ISO 4217 (3 lettres)
initstr($p['MONNAIE'], 3) .
// BILAN_MONNAIEO Code devise d'origine du bilan selon la norme ISO 4217*
initstr($p['MONNAIE_ORI'], 3) .
// BILAN_UNITE Unité du bilan livré U=en unité de devise, K=en milliers, M=en millions
initstr($unite, 1);
unset($p['SIREN']);
unset($p['SOURCE']);
unset($p['devise']);
unset($p['DATE_FRAICHE_BILAN']);
unset($p['DATE_CLOTURE']);
unset($p['DATE_CLOTURE_PRE']);
unset($p['DUREE_MOIS']);
unset($p['DUREE_MOIS_PRE']);
unset($p['MONNAIE']);
unset($p['CONSOLIDE']);
unset($p['MONNAIE_ORI']);
unset($p['MONNAIE_LIV_UNITE']);
$strIni.=initstr(count($p), 4, '0', ALIGN_RIGHT); // BILAN_NBPOSTES Nombre de postes livrés
$nbP=0;
$strP='';
if ($OptionTypeLigneBilan==400) {
foreach ($p as $code=>$valeur) {
$nbP++;
if ($valeur>=0) $signe='+';
else $signe='-';
$strP.= initstr($code, 4).$signe.initstr(abs($valeur), 20, '0', ALIGN_RIGHT);
if($nbP<76) continue;
// --- Ecriture ligne 400
file_put_contents($filepath, initstr($strIni.$strP,LONGUEUR_LIGNE_SORTIE).$OptionEOL, FILE_APPEND);
$nbLignes++;
$nbLignesBil++;
$nbP=0;$strP='';
}
if($nbP<76) { // Ecriture de la dernière ligne sauf s'il y a dejà 76 postes
// --- Ecriture ligne 400
file_put_contents($filepath, initstr($strIni.$strP,LONGUEUR_LIGNE_SORTIE).$OptionEOL, FILE_APPEND);
$nbLignes++;
$nbLignesBil++;
}
} else {
$uniteMultiple=1;
switch (strtoupper($unite)) {
case 'K': $uniteMultiple=1000; break;
case 'M': $uniteMultiple=1000000; break;
}
if ($p['CONSOLIDE']=='S') $tabPostes=$iBilan->bilanSimplifie2Normal($p);
else $tabPostes=$p;
// Chiffre d'affaires - Poste FL au format 2050
$strP.= @exporteRatio($p['FL']);
// Chiffre d'affaires Export - Poste FK
$strP.= @exporteRatio($p['FK']);
// Valeur Ajoutée - R130 = FL + FM+FN - (FS+FU) - (FT+FV) - (FW-HP-HQ)
$va=$p['FL'] + $p['FM'] + $p['FN'] - ($p['FS'] + $p['FU']) - ($p['FT'] + $p['FV']) - ($p['FW']-$p['HP']-$p['HQ']);
$strP.= @exporteRatio($va);
// Masse salariale - R132 = FY + FZ
$ms=$p['FY'] + $p['FZ'];
$strP.= @exporteRatio($ms);
// EBE - R140 = R130-R132 - FX + FO
$strP.= @exporteRatio($va-$ms - $p['FX'] + $p['FO']);
// Personnel extérieur à l'entreprise, Intérim = Poste YU
$strP.= @exporteRatio($p['YU']);
// Sous-traitance
$strP.= @exporteRatio($p['YT']);
// Effectif
$strP.= @exporteRatio($p['YP']);
// Capital - Poste DA
$strP.= @exporteRatio($p['DA']);
// Montant des Immo. Corp. Terrains Brut Poste AN
$strP.= @exporteRatio($p['AN']);
// Montant des Immo. Corp. Constructions Poste AP
$strP.= @exporteRatio($p['AP']);
// Montant des Installations Techniques, matériel et outillage industriels Poste AR
$strP.= @exporteRatio($p['AR']);
// Montant des Immo. Corp. Brut =AN+AP+AR+AT+AV+AX
$strP.= @exporteRatio($p['AN'] + $p['AP'] + $p['AR'] + $p['AT'] + $p['AV'] + $p['AX']);
// Montant des Immo. Corp. Net =AN-AO + AP-AQ + AR-AS + AT-AU + AV-AW + AX-AY
$strP.= @exporteRatio($p['AN']-$p['AO'] + $p['AP']-$p['AQ'] + $p['AR']-$p['AS'] + $p['AT']-$p['AU'] + $p['AV']-$p['AW'] + $p['AX']-$p['AY']);
// Montant des Immo. Incorp. Brut =AB+AD+AF+AH+AJ+AL
$strP.= @exporteRatio($p['AB'] + $p['AD'] + $p['AF'] + $p['AH'] + $p['AJ'] + $p['AL']);
// Montant des Immo. Incorp. Net =AB-AC + AD-AE + AF-AG + AH-AI + AJ-AK + AL-AM
$strP.= @exporteRatio($p['AB']-$p['AC'] + $p['AD']-$p['AE'] + $p['AF']-$p['AG'] + $p['AH']-$p['AI'] + $p['AJ']-$p['AK'] + $p['AL']-$p['AM']);
// Montant des Taxe professionnelle Poste YW
$strP.= @exporteRatio($p['YW']);
// --- Ecriture ligne
file_put_contents($filepath, initstr($strIni.$strP,LONGUEUR_LIGNE_SORTIE).$OptionEOL, FILE_APPEND);
$nbLignes++;
$nbLignesBil++;
$strP='';
}
if ($iBil==$OptionNbBilansMax) break;
}
}
if (empty($opts->debug)) {
$suiviM->update(array(
'unitIncrement' => $unit,
2015-07-27 20:47:19 +00:00
'unitExec' => date('YmdHis'),
), 'id='.$suiviId);
}
echo date ('Y/m/d - H:i:s')." - Fin ligne $unit/$nbEtab\n";
}
// --- Fin de ligne du fichier
$nbLignes++;
$dateFin=date('YmdHis');
$str= initstr('999', 3, '0', ALIGN_RIGHT) . // Type de ligne
initstr($dateFin, 14) . // Date & Heure de fin génération du fichier
initstr($OptionClientNumTourFichier, 10, '0', ALIGN_RIGHT) . // Numéro de tour du fichier pour le client
initstr($prestaId, 36) . // Identifiant Client
initstr($OptionTypePrestation, 32) . // Type de prestation
initstr($nbLignes, 10, '0', ALIGN_RIGHT) . // Nombre de lignes Total du fichier
'';
// Pas de fin de ligne sur la dernière ligne
file_put_contents($filepath, initstr($str,LONGUEUR_LIGNE_SORTIE), FILE_APPEND);
$tabProduction[$prestaId]['dateFin']=$dateFin;
$duree=round(microtime(true)-$timeDeb,3);
$dureeD=floor($duree/86400);
$reste=$duree%86400;
$dureeH=floor($reste/3600);
$reste=$reste%3600;
$dureeM=floor($reste/60);
$dureeS=$reste%60;
$tabProduction[$prestaId]['duree']=$duree.' secondes';
if ($dureeD==0 && $dureeH==0) $tabProduction[$prestaId]['dureeLisible']="$dureeM m. $dureeS s.";
elseif ($dureeD==0) $tabProduction[$prestaId]['dureeLisible']="$dureeH h. $dureeM m. $dureeS s.";
else $tabProduction[$prestaId]['dureeLisible']="$dureeD j. $dureeH h. $dureeM m. $dureeS s.";
$tabProduction[$prestaId]['nbLignes']=$nbLignes;
echo date ('Y/m/d - H:i:s')." - Prestation $prestaId, Client $OptionNomClient : Fichier client terminé.\n";
// --- Envoi du fichier produit par mail
if (!empty($OptionMailTo)) {
$OptionMailTo.= ',';
}
$OptionMailTo.= 'suivi@scores-decisions.com';
if ($opts->nomail === null && !empty($OptionMailTo)) {
$tabAttached = array($filepath);
$messageInfo="Bonjour,
Veuillez trouver le fichier d'établissements Scores & Décisions relatifs à votre abonnement.
Bien Cordialement,
Le service Support.
ATTENTION : Cet email est un message automatique. Merci de ne pas y répondre. Pour toute question nous vous invitons à contacter notre support à l'adresse support@scores-decisions.com.
---
SCORES & DECISIONS
Service support
1, rue de Clairefontaine - 78120 RAMBOUILLET
tél : 33 (0)1 75 43 80 10
fax : 33 (0)1 75 43 85 74
support@scores-decisions.com
http://www.scores-decisions.com/
Scores & Décisions est l'acteur nouvelle génération de l'information et de l'évaluation des entreprises
Pensez à l'environnement avant d'imprimer ce message !
Save paper - think before you print";
if(sendMail('production@scores-decisions.com', $OptionMailTo, "Diffusion A6CMO S&D", $messageInfo, '', $tabAttached)) {
echo date ('Y/m/d - H:i:s')." - Prestation $prestaId, Client $OptionNomClient : Fichier envoyé à ".$OptionMailTo."\n";
} else {
echo date ('Y/m/d - H:i:s')." - Prestation $prestaId, Client $OptionNomClient : Erreur lors de l'envoi du fichier à ".$OptionMailTo."\n";
}
} else {
}
if (empty($opts->debug)) {
$suiviparamM = new Application_Model_Sdv1PrestaOutDetail();
$suiviparamM->insert(array(
'execId' => $suiviId,
'code' => $prestaId,
'name' => 'fichier',
2015-07-27 20:47:19 +00:00
'value' => $file,
));
$suiviM->update(array('dateEnd' => date('YmdHis')), 'id='.$suiviId);
}
echo date ('Y/m/d - H:i:s')." - Prestation $prestaId, Client $OptionNomClient : Fin.\n";
} // --- Fin boucle presta
if ($opts->stock) $strStock="des stocks";
else $strStock="des fichiers hebdos";
$messageFinObj="FIN de la diffusion $strStock A6CMO";
$messageFinMsg=print_r($tabProduction, true);
$messageFinMsg.=print_r($tTime, true);
if ($opts->nomail === null) {
sendMail('production@scores-decisions.com', 'ylenaour@scores-decisions.com,suivi@scores-decisions.com', $messageFinObj, $messageFinMsg);
}
function exporteRatio($valeur) {
$signe='+';
if($valeur<0) $signe='-';
return ''.$signe.initstr(abs($valeur), 20, '0', ALIGN_RIGHT);
}