aucun commentaire * @var int */ protected $level = 0; protected $nm; protected $nmp; protected $nmp2; protected $nmp3; protected $nmp4; protected $regR; protected $regRs; protected $tabRegX; protected $tabVariables; protected $tabFormules; protected $tabFormulesRatios; protected $tva; /** * */ public function __construct($db = null) { if ( $db === null ) { $this->db = new Metier_Util_Db(); } // --- Initialisation tableau libellé des variables $this->tabVariables = include __DIR__ . '/Data/Variables.php'; // --- Initialisation formules $this->tabFormules = include __DIR__ . '/Data/Formules.php'; } /** * Défini une date limite de prise en compte des événements * @param string $date AAAAMMJJ */ public function setEvenLimit($date) { $this->companyEvenDateStop = $date; } /** * Défini le niveau des commentaires * @param int $num */ public function setCommentLevel($num) { $this->level = $num; } public function injectAnnonces(){} public function injectIdentite(){} public function injectBilans(){} /** * Return the history of previous stored IndiScores on the companies * @param string $siren * Siren number of the company * @return array */ public function getIndiscoreHisto($siren) { if (intval($siren) < 1000) return false; $query="SELECT siren, actif, procol, naf, indiScore, indiScore20, encours, indiScoreDate, dateBilan, sourceModif, scoreSolv, scoreDir, scoreConf, scoreZ, scoreCH, scoreAfdcc1, scoreAfdcc2, scoreAfdcc2note, scoreAltman, scoreAltmanCote, scoreCCF, cs, csMoisMaj, csMoisFin, adresseDom, situFi, infoNote, noteStruct, noteFin, tendance, nbModifs, dateUpdate FROM jo.scores_surveillance WHERE siren=$siren UNION SELECT siren, actif, procol, naf, indiScore, indiScore20, encours, indiScoreDate, dateBilan, sourceModif, scoreSolv, scoreDir, scoreConf, scoreZ, scoreCH, scoreAfdcc1, scoreAfdcc2, scoreAfdcc2note, scoreAltman, scoreAltmanCote, scoreCCF, cs, csMoisMaj, csMoisFin, adresseDom, situFi, infoNote, noteStruct, noteFin, tendance, nbModifs, dateUpdate FROM historiques.scores_surveillance WHERE siren=$siren GROUP BY indiScoreDate ORDER BY indiScoreDate DESC"; $iDb = new Metier_Util_Db(); $ret = $iDb->query($query); $tabRet = array(); while( $ret = $iDb->fetch(MYSQL_ASSOC) ) { $tabRet[]=array( 'siren' => $ret['siren'], 'actif' => $ret['actif'], 'procol' => $ret['procol'], 'naf' => $ret['naf'], 'indiScore' => $ret['indiScore'], 'indiScore20' => $ret['indiScore20'], 'encours' => $ret['encours'], 'indiScoreDate' => $ret['indiScoreDate'], 'dateBilan' => $ret['dateBilan'], 'sourceModif' => $ret['sourceModif'], 'scoreSolv' => $ret['scoreSolv'], 'scoreDir' => $ret['scoreDir'], 'scoreConf' => $ret['scoreConf'], 'scoreZ' => $ret['scoreZ'], 'scoreCH' => $ret['scoreCH'], 'scoreAfdcc1' => $ret['scoreAfdcc1'], //'scoreAfdcc2' => $ret['scoreAfdcc2'], 'scoreAfdcc2note' => $ret['scoreAfdcc2note'], 'scoreAltman' => $ret['scoreAltman'], 'scoreAltmanCote' => $ret['scoreAltmanCote'], 'scoreCCF' => $ret['scoreCCF'], 'cs' => $ret['cs'], 'csMoisMaj' => $ret['csMoisMaj'], 'csMoisFin' => $ret['csMoisFin'], 'adresseDom' => $ret['adresseDom'], 'situFi' => $ret['situFi'], 'infoNote' => $ret['infoNote'], 'noteStruct' => $ret['noteStruct'], 'noteFin' => $ret['noteFin'], 'tendance' => $ret['tendance'], 'nbModifs' => $ret['nbModifs'], 'dateUpdate' => $ret['dateUpdate'], ); } return $tabRet; } /** * Récupére les scores dans la table de cache scores_surveillance * @param string $siren * @return array */ public function getIndiscoreCache($siren) { if ($siren<1000) return false; $query="SELECT siren, actif, procol, naf, indiScore, indiScore20, encours, indiScoreDate, dateBilan, sourceModif, scoreSolv, scoreDir, scoreConf, scoreZ, scoreCH, scoreAfdcc1, scoreAfdcc2, scoreAfdcc2note, scoreAltman, scoreAltmanCote, scoreCCF, cs, csMoisMaj, csMoisFin, adresseDom, situFi, infoNote, noteStruct, noteFin, tendance, nbModifs, dateUpdate FROM jo.scores_surveillance WHERE siren=$siren ORDER BY indiScoreDate DESC"; $ret = $this->db->query($query); $tabRet = array(); while( $ret = $this->db->fetch(MYSQL_ASSOC) ) { $tabRet[] = array ( 'siren' => $ret['siren'], 'actif' => $ret['actif'], 'procol' => $ret['procol'], 'naf' => $ret['naf'], 'indiScore' => $ret['indiScore'], 'indiScore20' => $ret['indiScore20'], 'encours' => $ret['encours'], 'indiScoreDate' => $ret['indiScoreDate'], 'dateBilan' => $ret['dateBilan'], 'sourceModif' => $ret['sourceModif'], 'scoreSolv' => $ret['scoreSolv'], 'scoreDir' => $ret['scoreDir'], 'scoreConf' => $ret['scoreConf'], 'scoreZ' => $ret['scoreZ'], 'scoreCH' => $ret['scoreCH'], 'scoreAfdcc1' => $ret['scoreAfdcc1'], //'scoreAfdcc2' => $ret['scoreAfdcc2'], 'scoreAfdcc2note' => $ret['scoreAfdcc2note'], 'scoreAltman' => $ret['scoreAltman'], 'scoreAltmanCote' => $ret['scoreAltmanCote'], 'scoreCCF' => $ret['scoreCCF'], 'cs' => $ret['cs'], 'csMoisMaj' => $ret['csMoisMaj'], 'csMoisFin' => $ret['csMoisFin'], 'adresseDom' => $ret['adresseDom'], 'situFi' => $ret['situFi'], 'infoNote' => $ret['infoNote'], 'noteStruct' => $ret['noteStruct'], 'noteFin' => $ret['noteFin'], 'tendance' => $ret['tendance'], 'nbModifs' => $ret['nbModifs'], 'dateUpdate' => $ret['dateUpdate'], ); } return $tabRet; } /** * Return the medium indiscore on an activity sector * @param string $naf5 * @return array */ public function getScoreSecteur($naf5) { if (len($naf)<>5) return false; $tabTmp=$iDb->select('jo.scores_surveillance', 'naf, AVG(indiScore) AS score100moy, AVG(indiScore20) AS score20moy, AVG(encours) AS encoursMoy, MAX(indiScoreDate) AS lastScore, COUNT(siren) AS nbSiren', "naf='$naf5' AND actif=1", false, MYSQL_ASSOC); if ( count($tabTmp)>0 ) { $tabTmp=$tabTmp[0]; return array( 'naf' => $tabTmp['naf'], 'score100moy' => $tabTmp['score100moy'], 'score20moy' => $tabTmp['score20moy'], 'encoursMoy' => $tabTmp['encoursMoy'], 'lastScore' => $tabTmp['lastScore'], 'nbScoresn' => $tabTmp['nbSiren'] ); } return array(); } /** * Taux de tva * @param string $date AAAAMM * @return double */ public function getTxTva($date) { $tabTxTva = include __DIR__ . '/Data/Tva.php'; foreach ($tabTxTva as $ym => $v) { if ($ym > $date) { break; } $tva = $v; } return $tva; } /** * Donne le taux de rendement des actions pour une année donnée * @param unknown $annee * @return unknown */ public function getTxRendement($annee) { $tabTxRendObli = include __DIR__ . '/Data/RendObli.php'; if ( isset($tabTxRendObli[$annee]) ) { return $tabTxRendObli[$annee]; } } /** * Formattage élément numéraire en texte * @param number $nombre * @param int $decimales * @param string $sepDec * @param string $sepMil * @param string $unite * @param string $signe */ public function number_format2($nombre, $decimales, $sepDec, $sepMil, $unite, $signe) { if (round($nombre,$decimales) == round($nombre)) { $decimales = 0; } if ($signe == '+') { if ($nombre > 0) { return '+ '.number_format(abs($nombre),$decimales,$sepDec,$sepMil).' '.$unite; } elseif ($nombre < 0) { return '- '.number_format(abs($nombre),$decimales,$sepDec,$sepMil).' '.$unite; } else { return number_format(abs($nombre),$decimales,$sepDec,$sepMil).' '.$unite; } } elseif ($signe == '!') { return number_format(abs($nombre),$decimales,$sepDec,$sepMil).' '.$unite; } else { return number_format($nombre,$decimales,$sepDec,$sepMil).' '.$unite; } } /** * Formatte les entités Ratio en mode texte * @param array $ratio * @param string $id * @param string $unite * @param string $forceSigne * @return string */ public function formatRatio($ratio, $id, $unite, $forceSigne='') { switch (trim(strtoupper($unite))) { case 'EU': case 'EUR': if ($ratio[$id] >= 0 && $ratio[$id] < 5000 || $ratio[$id] > -5000 && $ratio[$id] <= 0) { return number_format2($ratio[$id],0,',',' ','€', $forceSigne); } elseif ($ratio[$id] <= -10000000 || $ratio[$id] >= 10000000) { return number_format2($ratio[$id]/1000000,0,',',' ','M€', $forceSigne); } else { return number_format2($ratio[$id]/1000,0,',',' ','K€', $forceSigne); } break; case '%': if ($ratio[$id] >= 0 && $ratio[$id] < 10) { return number_format2($ratio[$id],1,',',' ','%', $forceSigne); } elseif ($ratio[$id] > -10 && $ratio[$id] < 0) { return number_format2($ratio[$id],1,',',' ','%', $forceSigne); } else { return number_format2($ratio[$id],0,',',' ','%', $forceSigne); } break; case 'AN': if ($ratio[$id] >= -1 && $ratio[$id] <= 1) { return number_format2($ratio[$id],0,',',' ','an', $forceSigne); } else { return number_format2($ratio[$id],0,',',' ','ans', $forceSigne); } break; case 'JOURS': if ($ratio[$id] < 0) { $signe=-1; } else { $signe=1; } $vabsolue = abs($ratio[$id]); $an = 0; while ($vabsolue>360) { $vabsolue = $vabsolue-360; $an++; } if ($an>1) { return number_format2($an*$signe,0,',',' ','ans', $forceSigne); } elseif ($an == 1) { return number_format2($an*$signe,0,',',' ','an', $forceSigne); } elseif ($vabsolue <= 1) { return number_format2($vabsolue*$signe,0,',',' ','jour', $forceSigne); } else { return number_format2($vabsolue*$signe,0,',',' ','jours', $forceSigne); } break; case 'PERS': return number_format2($ratio[$id],0,',',' ', 'salarié(s)', $forceSigne); break; case 'U': return number_format2($ratio[$id],1,',',' ', '', $forceSigne); break; default: break; } return $ratio[$id].' '.$unite; } /** * Formattage des variables pour affichage * @param string $var * @param int $longeur * @param string $fonction * @return mixed */ public function formatValeur($var, $longeur=0, $fonction='') { $varValue = strtr($var, array('{'=>'','}'=>'')); $varLabel = strtr($varValue, array('$'=>'')); // --- Gestion des valeurs présentent dans un tableau de variables if ( isset($this->tabVariables[$varLabel]) ) { if ($longeur > 0) { return $var; } else { // Tableau ZEMET if ($varLabel == 'ZEMET') { if (substr($this->DateNotice80,0,4) >= 2010) { $tableZemet = 'ZEMET2010'; } else { $tableZemet = 'ZEMET1994'; } // Cette variable a un libellé associé if (isset($this->tabVariables[$tableZemet][$this->RPET.$this->ZEMET]['art'])) { return $this->tabVariables[$tableZemet][$this->RPET.$this->ZEMET]['art']; } else { return $this->tabVariables[$tableZemet][$this->RPET.$this->ZEMET]['lib']; } } // Cette variable a un libellé associé if (isset($this->tabVariables[$varLabel][$this->{$varValue}]['lib'])) { return $this->tabVariables[$varLabel][$this->{$varValue}]['lib']; } elseif (isset($this->tabVariables[$varLabel]['0'.$this->{$varValue}]['lib'])) { return $this->tabVariables[$varLabel]['0'.$this->{$varValue}]['lib']; } } } // --- Formattage variable [...]DATE elseif (preg_match('/DATE$/', $varLabel)) { return preg_replace('/00\//','01/', Metier_Util_Date::dateT('Ymd','d/m/Y', substr(str_replace('-','',$this->{$varValue}),0,8))); } // --- Formattage variable [...]DATEp[NNNN] elseif (preg_match('/DATEp[0-9]{0,}$/', $varLabel)) { return preg_replace('/00\//','01/', Metier_Util_Date::dateT('Ymd','d/m/Y', substr(str_replace('-','',$this->{$varValue}),0,8))); } // --- Formattage variable [...]MMAA elseif (preg_match('/MMAA$/', $varLabel)) { return Metier_Util_Date::dateT('Y-m','M Y', $this->{$varValue}); } // --- Formattage variable [...]_MT elseif (preg_match('/_MT$/', $varLabel)) { return number_format($this->{$varValue}, 2, ',', ' ').' €'; } // --- Formattage variable [...]_NB elseif (preg_match('/_NB$/', $varLabel)) { return number_format($this->{$varValue}, 0, ',', ' '); } // --- Formattage variable [...]_EU elseif (preg_match('/_EU$/', $varLabel)) { if ($this->{$varValue}>=0 && $this->{$varValue}<10 || $this->{$varValue}>-10 && $this->{$varValue}<=0) { return number_format($this->{$varValue}, 2, ',', ' ').' €'; } elseif ($this->{$varValue}>=10 && $this->{$varValue}<5000 || $this->{$varValue}>-5000 && $this->{$varValue}<=10) { return number_format($strTmp,0,',',' ').' €'; } elseif ($this->{$varValue}<=-10000000 || $this->{$varValue}>=10000000) { return number_format($this->{$varValue}/1000000, 0, ',', ' ').' M€'; } else { return number_format($this->{$varValue}/1000, 0, ',', ' ').' K€'; } } // --- Formattage variable [...]_POURC elseif (preg_match('/_POURC$/', $varLabel)) { if ($this->{$varValue}>=10 || $this->{$varValue}<=-10) return number_format($this->{$varValue}, 0, ',', ' ').' %'; elseif ($this->{$varValue}>=1 || $this->{$varValue}<=-1) return number_format($this->{$varValue}, 1, ',', ' ').' %'; else return number_format($this->{$varValue}, 3, ',', ' ').' %'; } // --- Formattage variable [...]CAPITAL elseif (preg_match('/CAPITAL$/', $varLabel)) { return number_format($this->CAPITAL, 0, ',', ' ').' €'; } // --- Formattage variable [...]CAPITAL_PRE elseif (preg_match('/CAPITAL_PRE$/', $varLabel)) { return number_format($this->CAPITAL_PRE, 0, ',', ' ').' €'; } // --- Formattage variable [...]CAPITAL_MTACTION elseif (preg_match('/CAPITAL_MTACTION$/', $varLabel)) { return number_format($this->CAPITAL_MTACTION, 0, ',', ' ').' €'; } // --- Formattage variable [...]CAPITAL_NBACTION elseif (preg_match('/CAPITAL_NBACTION$/', $varLabel)) { return number_format($this->CAPITAL_NBACTION, 0, ',', ' '); } // --- Formattage variable CAESTIME elseif (preg_match('/^CAESTIME$/', $varLabel)) { return number_format($this->CAESTIME/1000,0,',',' ').' k€'; } // --- Formattage variable CABIOUES elseif (preg_match('/^CABIOUES$/', $varLabel)) { return number_format($this->CABIOUES/1000,0,',',' ').' k€'; } // --- Formattage variable [...]DIMMAT elseif (preg_match('/DIMMAT$/', $varLabel)) { return preg_replace('/00\//','01/', Metier_Util_Date::dateT('Ymd','d/m/Y', substr(str_replace('-','',$this->DIMMAT),0,8))); } // --- Formattage variable [...]DCREN elseif (preg_match('/DCREN$/',$varLabel)) { return preg_replace('/00\//','01/', Metier_Util_Date::dateT('Ymd','d/m/Y', substr(str_replace('-','',$this->DCREN),0,8))); } // --- Formattage variable [...]MARCHEVOL elseif (preg_match('/MARCHEVOL$/', $varLabel)) { if (abs($MARCHEVOL)>=5) { return round($MARCHEVOL).' %'; } else { return number_format($MARCHEVOL,3,',',' ').' %'; } } // --- Formattage variable [...]MARCHEPART elseif (preg_match('/MARCHEPART$/', $varLabel)) { if (abs($this->MARCHEPART)>=5) { return round($this->MARCHEPART).' %'; } else { return number_format($this->MARCHEPART,3,',',' ').' %'; } } // --- Formattage variable [...]MARCHEPARTp elseif (preg_match('/MARCHEPARTp$/', $varLabel)) { if (abs($this->MARCHEPARTp)>=5) { return round($this->MARCHEPARTp).' %'; } else { return number_format($this->MARCHEPARTp,3,',',' ').' %'; } } // --- Formattage variable [...]MARCHEPARTEVOL elseif (preg_match('/MARCHEPARTEVOL$/', $varLabel)) { if (abs($this->MARCHEPARTEVOL) >= 5) { return round($this->MARCHEPARTEVOL).' %'; } else { return number_format($this->MARCHEPARTEVOL,3,',',' ').' %'; } } // --- Formattage variable [...]MARCHE elseif (preg_match('/MARCHE$/', $varLabel)) { if ($this->MARCHE < 10000) { return number_format($MARCHE,0, ',', ' ').' €'; } elseif ($this->MARCHE < 1000000) { return number_format($this->MARCHE / 1000, 0, ',', ' ').' K€'; } elseif ($this->MARCHE < 1000000000) { return number_format($this->MARCHE / 1000000, 0, ',', ' ').' M€'; } else { return number_format($this->MARCHE / 1000000000, 0, ',', ' ')." milliards d'€"; } } // --- Formattage variable [...]MARCHEp elseif (preg_match('/MARCHEp$/', $varLabel)) { if ($this->MARCHEp < 10000) { return number_format($MARCHEp,0, ',', ' ').' €'; } elseif ($this->MARCHEp < 1000000) { return number_format($this->MARCHEp / 1000, 0, ',', ' ').' K€'; } elseif ($this->MARCHEp < 1000000000) { return number_format($this->MARCHEp / 1000000, 0, ',', ' ').' M€'; } else { return number_format($this->MARCHEp / 1000000000, 0, ',', ' ')." milliards d'€"; } } // --- Formattage variable CA_Y[*] elseif (preg_match('/^CA_Y\[(.*)\]/U', $varLabel, $matches2)) { return number_format($this->CA_Y[$matches2[1]]/1000, 0, ',', ' ').' K€'; } // --- Formattage variable RCAI_Y[*] elseif (preg_match('/^RCAI_Y\[(.*)\]/U', $varLabel, $matches2)) { return number_format($this->RCAI_Y[$matches2[1]]/1000, 0, ',', ' ').' K€'; } // --- Formattage variable [...]_MT || [...]_TAUX elseif (preg_match('/(_COEF|_TAUX)$/', $varLabel)) { return number_format($this->{$varValue}, 2, ',', '').' %'; } // --- Formattage variable SIREN elseif (preg_match('/^SIREN$/', $varLabel)) { return sprintf("%09s", $this->SIREN); } // --- Formattage variable SIRET elseif (preg_match('/^SIRET$/', $varLabel)) { return sprintf("%09s", substr($this->SIRET,0,9)).' '.substr($this->SIRET,-5); } // --- Formattage variable SIRENMERE elseif (preg_match('/^SIRENMERE$/', $varLabel)) { return sprintf("%09s", $this->SIRENMERE); } // --- Formattage variable SIRETMERE elseif (preg_match('/^SIRETMERE$/', $varLabel)) { return sprintf("%09s", substr($this->SIRETMERE,0,9)).' '.substr($this->SIRETMERE,-5); } // --- Formattage variable SIRENFILLE elseif (preg_match('/^SIRENFILLE$/', $varLabel)) { return sprintf("%09s", $this->SIRENFILLE); } // --- Formattage variable SIRETFILLE elseif (preg_match('/^SIRETFILLE$/', $varLabel)) { return sprintf("%09s", substr($this->SIRETFILLE,0,9)).chr(160).substr($this->SIRETFILLE,-5); } // --- Formattage variable TVAINTRA elseif (preg_match('/^TVAINTRA$/', $varLabel)) { return substr($this->TVAINTRA,0,2).' '.substr($this->TVAINTRA,2,2).' '.substr($this->TVAINTRA,4); } // --- Formattage variable DELAIPAY elseif (preg_match('/^DELAIPAY$/', $varLabel)) { return number_format($this->DELAIPAY,0,',',' ').' jours'; } // --- Formattage variable DELAIPAYp elseif (preg_match('/^DELAIPAYp$/', $varLabel)) { return number_format($this->DELAIPAYp,0,',',' ').' jours'; } // --- Formattage variable SCOREDEFTAUX elseif (preg_match('/^SCOREDEFTAUX$/', $varLabel)) { if ($this->SCOREDEFTAUX >= 5) { return round($this->SCOREDEFTAUX).' %'; } else { return number_format($this->SCOREDEFTAUX, 3, ',', ' ').' %'; } } // --- Formattage variable BILANANNEE elseif (preg_match('/BILANANNEE$/', $varLabel)) { return $this->BILANANNEE; } return $this->{$var}; } /** * Format value for display * @param string $matches */ public function format($matches) { $strRetour='$'.$matches[1]; $strUnite=''; // --- Moyenne if (preg_match("/\{MOY\(R\[(\d+)\],(\d+)\)/Ui", $strRetour, $matches2)) { $tmpRatioId = $matches2[1]*1; $tmpAnnees = $matches2[2]*1; $valeur = $this->R[$tmpRatioId]; for($iMoy=0; $iMoy<$tmpAnnees; $iMoy++) { if ($iMoy==1) { $valeur+= $this->Rp[$tmpRatioId]; } elseif ($iMoy==2) { $valeur+= $this->Rp2[$tmpRatioId]; } elseif ($iMoy==3) { $valeur+= $this->Rp3[$tmpRatioId]; } elseif ($iMoy==4) { $valeur+= $this->Rp4[$tmpRatioId]; } } return formatRatio('', $valeur/$tmpAnnees, strtoupper($this->tabFormulesRatios[$tmpRatioId]['unite'])); } // --- Graphique elseif (preg_match('/\{GRAPH\((.*)\)\}/Ui', $strRetour, $matches2)) { return $matches[1]; } // --- Ratios elseif (preg_match('/\$\{(\+|!|)(Rp4|Rp3|Rp2|Rp|Rs|Rsp|Rap|Ra|Rdiff|Revolp2|Revolp|Revol|R|regR)\[(\d+)\]\}/Ui', $strRetour, $matches2)) { $tmpRatio = $matches2[2]; $tmpRatioId = $matches2[3]*1; $unite = strtoupper($this->tabFormulesRatios[$tmpRatioId]['unite']); if ($matches2[1]=='+') { $forceSigne='+'; } elseif ($matches2[1]=='!') { $forceSigne='!'; } else { $forceSigne=''; } if ($tmpRatio=='R') { return formatRatio($this->R, $tmpRatioId, $unite, $forceSigne); } elseif ($tmpRatio=='Rp') { return formatRatio($this->Rp, $tmpRatioId, $unite, $forceSigne); } elseif ($tmpRatio=='Rp2') { return formatRatio($this->Rp2, $tmpRatioId, $unite, $forceSigne); } elseif ($tmpRatio=='Rp3') { return formatRatio($this->Rp3, $tmpRatioId, $unite, $forceSigne); } elseif ($tmpRatio=='Rp4') { return formatRatio($this->Rp4, $tmpRatioId, $unite, $forceSigne); } elseif ($tmpRatio=='Ra') { return formatRatio($this->Ra, $tmpRatioId, $unite, $forceSigne); } elseif ($tmpRatio=='Rap') { return formatRatio($this->Rap, $tmpRatioId, $unite, $forceSigne); } elseif ($tmpRatio=='Rs') { return formatRatio($this->Rs, $tmpRatioId, $unite, $forceSigne); } elseif ($tmpRatio=='Rsp') { return formatRatio($this->Rsp, $tmpRatioId, $unite, $forceSigne); } elseif ($tmpRatio=='Rsp2') { return formatRatio($this->Rsp2, $tmpRatioId, $unite, $forceSigne); } elseif ($tmpRatio=='Rsp3') { return formatRatio($this->Rsp3, $tmpRatioId, $unite, $forceSigne); } elseif ($tmpRatio=='Rsp4') { return formatRatio($this->Rsp4, $tmpRatioId, $unite, $forceSigne); } elseif ($tmpRatio=='Revol') { return formatRatio($this->Revol, $tmpRatioId, '%', $forceSigne); } elseif ($tmpRatio=='Rdiff') { return formatRatio($this->Rdiff, $tmpRatioId, $unite, $forceSigne); } elseif ($tmpRatio=='Revolp') { return formatRatio($this->Revolp, $tmpRatioId, '%', $forceSigne); } elseif ($tmpRatio=='Revolp2') { return formatRatio($this->Revolp2, $tmpRatioId, '%', $forceSigne); } elseif ($tmpRatio=='Revolp3') { return formatRatio($this->Revolp3, $tmpRatioId, '%', $forceSigne); } elseif ($tmpRatio=='regR') { return formatRatio($this->regR, $tmpRatioId, $unite, $forceSigne); } } // --- Valeur elseif (preg_match('/\$\{(.*)\((\d+)\)\}/Ui', $strRetour, $matches2)) { $tmpVar = $matches2[1]; $tmpVarLen = $matches2[2]*1; return $this->formatValeur('$'.$tmpVar, $tmpVarLen); } else { return $this->formatValeur($strRetour); } return $strRetour.' '.$strUnite; } /** * Projection * @param unknown $valeur * @param unknown $nbAnnees */ public function PROJEC($valeur, $nbAnnees) { $projec = new Metier_Scores_Projection(); $projec->tabRegX = $this->tabRegX; $result = $projec->calc($valeur, $nbAnnees); if ( $result !== false ) { $this->Y = $projec->getY(); //@todo : ????? $this->Yaff = $projec->getYaff(); $this->PROJECTAUX = $projec->getProjecTaux(); $this->PROJECCOEF = $projec->getProjecCoeff(); } } /** * Compute the indiScore * @param string $siren * @param string $type * "scores" ou "valo" * @param string $sourceModif * */ public function calculIndiScore($siren, $type = 'scores', $sourceModif='jour') { $timer = array('debutIndiscore'=>microtime(true)); if (strlen($siren)>9 || (substr(''.$siren,0,9)*1)<100 ) { return false; } $this->NIVEAU = $cycleClient; // 1, 2, 3 ou 5 Niveau de version des commentaires $iInsee = new Metier_Insee_MInsee($this->db); if ($this->companyEvenDateStop !== null) { $iInsee->setEvenLimit($this->companyEvenDateStop); } /** * Récupération des informations identitaire */ if ($this->companyEvenDateStop === null) { $tabIdentite = $iInsee->getIdentiteEntreprise($siren, $nic, 0, false, false); } else { $tabIdentite = $iInsee->getIdentiteEntrepriseHisto($siren); } $timer['identite']=microtime(true); if (empty($tabIdentite)) { Metier_Util_Log::write('W', "Siren $siren non présent en base", __LINE__, __FILE__, __FUNCTION__, __CLASS__); return false; } $this->tva = $this->getTxTva(date('Ym')); if ( !in_array($type, array('scores', 'valo')) ) { $type = 'scores'; } $genereComment = false; if ( in_array($this->NIVEAU, array(2, 3, 4, 5)) ) { $genereComment = true; } //Initialisation tabFormules depuis le cache $tabFormules = include __DIR__ . '/Data/Formules.php'; $this->tabFormulesRatios = array(); foreach ($tabFormules as $tmpFormule) { $this->tabFormulesRatios[$tmpFormule['id']] = $tmpFormule; $tabRatiosInfos[$tmpFormule['id']] = array('unite' => $tmpFormule['unite']); } $tabRatiosSecteurs = $tabRatios2 = $tabRatiosEvol = array(); $this->NIC = substr($tabIdentite['SiretSiege'],-5); $this->SIREN = $siren; $this->SIRET = $tabIdentite['SiretSiege']; $this->ANNEE = date('Y')*1; $this->ANNEEp3 = $this->ANNEE-3; $this->ANNEEp2 = $this->ANNEE-2; $this->ANNEEp = $this->ANNEE-1; $this->ANNEE1 = $this->ANNEE+1; $this->ANNEE2 = $this->ANNEE+2; $this->ANNEE3 = $this->ANNEE+3; $this->ANNEE4 = $this->ANNEE+4; $this->ANNEE5 = $this->ANNEE+5; $this->JOUR_DATE = date('Y-m-d'); $this->JOUR_HEURE = date('H:i'); /** Zones utilisées dans les calculs **/ $this->CALCUL1 = 0; $this->CALCUL2 = 0; $this->CALCUL3 = 0; $this->CALCUL4 = 0; $this->CALCUL5 = 0; $this->CALCUL6 = 0; $this->CALCUL7 = 0; $this->CALCUL8 = 0; $this->CALCUL9 = 0; $this->ENQUETELIM = 6; // 6 mois de validités pour une note en provenance d'une enquête $this->ENQUETEMAXI = 90; // Score Maximum / 100 en provenance d'une enquête $tendance = ''; $naf = $tabIdentite['NafEnt']; $this->APEETAB = $tabIdentite['NafEtab']; $this->TRIBUNAL_ACTUEL = strtr($tabIdentite['TribunalLib'],array('TC '=>'Tribunal de Commerce de ')); $this->TRIBUNAL_CREATION = $this->TRIBUNAL_PROCOL=''; $nafLib = $tabIdentite['NafEntLib']; $efftr = $tabIdentite['Effectif']*1; $fj = $tabIdentite['FJ']; // Société côtée en bourse $this->SOCIETE_COTE=false; $this->SOCIETE_COTE_MARCHE_MERE=''; /** @todo: Nom du marché de l'actionnaire côté **/ $this->SOCIETE_COTE_ISIN=$tabIdentite['Isin']; if ($this->SOCIETE_COTE_ISIN<>'') { $this->SOCIETE_COTE=true; $this->SOCIETE_COTE_PLACE=$tabIdentite['Bourse']['placeCotation']; $this->SOCIETE_COTE_MARCHE=$tabIdentite['Bourse']['marche']; $this->SOCIETE_COTE_CAPITALISATION=$tabIdentite['Bourse']['capitalisation']; // Afficher en KE $this->SOCIETE_COTE_COURS=$tabIdentite['Bourse']['derCoursCloture']; $this->SOCIETE_COTE_COURS_DATE=$tabIdentite['Bourse']['derCoursDate']; $this->SOCIETE_COTE_COURS_MIN=0;//@todo:$tabRet['Bourse']['derCoursDate']; $this->SOCIETE_COTE_COURS_MAX=0;//@todo:$tabRet['Bourse']['derCoursDate']; } // Elements provenant du Notice 80 hors identité $tabIden80 = $iInsee->getInfosNotice($siren, $NIC); $timer['getInfosNotice'] = microtime(true); $this->RECME = $tabIden80['insRECME']; $this->ZEMET = $tabIden80['insZEMET']; $this->RPET = $tabIden80['insRPET']; $this->RPEN = $tabIden80['insRPEN']; $this->DateNotice80 = $tabIden80['dateNotice']; $depcomen = $tabIden80['insDEPCOMEN']*1; $this->TU = $tabIden80['insTU']; /** * Différences INSEE/RNCS */ $iRncs = new Metier_Partenaires_MRncs($this->db); $tabIdentiteRncs = $iRncs->getInfosEntrep($siren); $this->ACTIFRNCS = $tabIdentiteRncs['actif']; $this->ACTIFINSEE = $tabIdentite['Actif']; $this->APEENT = $this->APEINSEE = $naf; $this->APERNCS = $tabIdentiteRncs['nafEnt']; if (strlen($this->APEENT)==5) $this->APE5 = $this->APEENT; elseif (strlen($this->APEENT)==4) $this->APE4 = $this->APEENT; else $this->APE5 = $this->APE4 = ''; $this->DIMMAT = $tabIdentiteRncs['dateImma']; $this->DIMMAT_AA = substr($tabIdentiteRncs['dateImma'],0,4); $this->FJURINSEE = $tabIdentite['FJ']*1; $this->FJURINSEE1 = substr($this->FJURINSEE,0,1)*1; if ($this->FJURINSEE1==0) $this->FJURINSEE1=substr($this->FJURINSEE,0,1)*1; $this->FJURINSEE2 = substr($this->FJURINSEE,0,2)*1; if ($this->FJURINSEE2==0) $this->FJURINSEE2=$this->FJURINSEE; $this->FJURRNCS=$tabIdentiteRncs['cj']*1; $this->FJURRNCS1=substr($this->FJURRNCS,0,1)*1; if ($this->FJURRNCS1==0) $this->FFJURRNCS1=substr($this->FJURRNCS,0,1)*1; $this->FJURRNCS2=substr($this->FJURRNCS,0,2)*1; if ($this->FJURRNCS2==0) $this->FJURRNCS2=$this->FJURRNCS; if (trim($tabIdentiteRncs['raisonSociale'])=='') $this->PRESENTRNCS=false; else $this->PRESENTRNCS=true; if ($tabIdentite['Source']*1<>2) $this->PRESENTINSEE=false; else $this->PRESENTINSEE=true; $this->NOMEN = trim(strtr($tabIdentite['Nom'],array('*'=>' ','/'=>' '))); $this->ENSEIGNE = $tabIdentite['Enseigne']; $this->ENTREP_ALT = $tabIdentite['GeoAlt']; // Altitude de l'établissement $this->ACTIVNAT = $tabIdentite['NatureActivite']; $this->AUXILT = $tabIdentite['Auxiliaire']; $this->ORIGINE = $tabIdentite['OrigineCreation']; $this->ACTISURF = $tabIdentite['ACTISURF']; $this->EXPLEN = $tabIdentite['EXPLEN']; $this->EXPLET = $tabIdentite['EXPLET']; $this->LIEUACT = $tabIdentite['LIEUACT']; $this->MODEN = $tabIdentite['MODEN']; $this->MONOACT = $tabIdentite['MONOACT']; $this->MONOREG = $tabIdentite['MONOREG']; $this->PRODPART = $tabIdentite['PRODPART']; // Saisonnalité de l'activité if ($tabIdentite['Saisonnalite']==1) $this->SAISONAT='S'; else $this->SAISONAT='P'; $this->CAPITAL = $tabIdentite['Capital']; $this->CAPITAL_NBACTION = $tabIdentite['CapitalNbActions']; $this->CAPITAL_MTACTION = $tabIdentite['CapitalMtActions']; if ($this->CAPITAL>0) { switch ($tabIdentite['CapitalType']) { case 'V': $this->CAPITAL_TYPE = 'variable'; break; case 'S': $this->CAPITAL_TYPE = 'fixe'; break; default: $this->CAPITAL_TYPE = ''; break; } } else $this->CAPITAL_TYPE = ''; $this->TCAEXP=$tabIdentite['TrancheCAexp']; // Formes Juridique de l'entreprise $this->FJUR=$this->FJUR4=$fj*1; $this->FJUR1=substr($fj,0,1)*1; if ($this->FJUR1==0) $this->FJUR1=substr($this->FJUR,0,1)*1; $this->FJUR2=substr($fj,0,2)*1; if ($this->FJUR2==0) $this->FJUR2=$this->FJUR; $this->NBETEXPL=$tabIdentite['NbEtab']; $this->REGIMP=$tabIdentite['REGIMP']; if (strtoupper(substr($tabIdentite['AutreId'],0,1))=='W') $this->WALDEC=$tabIdentite['AutreId']; else $this->WALDEC=''; // AGE en mois if ($tabIdentite['DateCreaEt']>0 && $tabIdentite['DateCreaEt']<$tabIdentite['DateCreaEn']) $dateCrea=$tabIdentite['DateCreaEt']; elseif ($tabIdentite['DateCreaEn']>0) $dateCrea=$tabIdentite['DateCreaEn']; elseif (str_replace('-','',$this->DIMMAT)*1>19000101) $dateCrea=str_replace('-','',$this->DIMMAT); else { $dateCrea=0; } $this->DCREN = $dateCrea; $this->DCREN_AA = substr($dateCrea,0,4); $this->AGE = Metier_Util_Date::nbMoisEntre($dateCrea, date('Ymd')); // --- Liste des bilans $tabBilan = $tabBil = $this->tabRegX = array(); $mBil = new Metier_Partenaires_MBilans($siren, $this->db); if ($this->companyEvenDateStop !== null) { $mBil->setEvenLimit($this->companyEvenDateStop); } $tabBilans = $mBil->listeBilans($accesDist); $this->NBBILAN = count($tabBilans); if ($this->NBBILAN > 0) { $this->BILAN = $this->BILANp = $this->BILANp2 = $this->BILANp3 = $this->BILANp4 = 0; // --- Postes des bilans $i = 0; foreach ($tabBilans as $millesime => $item) { if ($i > 4) { break; } if ( $item['typeBilan'] == 'N' ) { $tabBilan[] = $mBil->getBilan(substr($millesime,-10), substr($millesime,0,1), ''); $i++; } elseif ( $item['typeBilan'] == 'S' ) { $tabN = $mBil->getBilan(substr($millesime,-10), substr($millesime,0,1), ''); $tabS = $mBil->bilanSimplifie2Normal($tabN); $tabBilan[] = array_merge($tabN, $tabS); $i++; } $this->tabRegX[] = $item['millesime']; } // --- Bilan le plus récent disponible if (isset($tabBilan[0])) { $this->EFFBILAN = $tabBilan[0]['YP']; $this->nm = $nbMoisBilCumul = $tabBilan[0]['DUREE_MOIS']; $this->BILANDATE = $tabBilan[0]['DATE_CLOTURE']; $this->BILANDATEp = $tabBilan[0]['DATE_CLOTURE_PRE']; if ($this->BILANDATEp == 0 && isset($tabBilan[1])) { $this->BILANDATEp = $tabBilan[1]['DATE_CLOTURE']; $this->BILANANNEEp = substr($this->BILANDATEp,0,4)*1; } $this->BILANANNEE = substr($this->BILANDATE,0,4)*1; $this->nmp = $tabBilan[0]['DUREE_MOIS_PRE']; if ($this->BILANANNEEp > 0) { $this->BILANp = 1; $nbMoisBilDate = Metier_Util_Date::nbMoisEntre($this->BILANDATEp, $this->BILANDATE); $nbMoisBilCumul += $this->nmp; } } // --- Elements des 5 bilans les plus récent if (isset($tabBilan[2])) { $this->BILANDATEp2 = $tabBilan[2]['DATE_CLOTURE']; $this->BILANANNEEp2 = substr($this->BILANDATEp2,0,4)*1; $this->nmp2=$tabBilan[2]['DUREE_MOIS']; if ($this->BILANANNEEp2 > 0) { $this->BILANp2 = 1; $nbMoisBilDate = Metier_Util_Date::nbMoisEntre($this->BILANDATEp2, $this->BILANDATE); $nbMoisBilCumul += $this->nmp2; } } if (isset($tabBilan[3])) { $this->BILANDATEp3 = $tabBilan[3]['DATE_CLOTURE']; $this->BILANANNEEp3 = substr($this->BILANDATEp3,0,4)*1; $this->nmp3 = $tabBilan[3]['DUREE_MOIS']; if ($this->BILANANNEEp3 > 0) { $this->BILANp3 = 1; $nbMoisBilDate = Metier_Util_Date::nbMoisEntre($this->BILANDATEp3, $this->BILANDATE); $nbMoisBilCumul += $this->nmp3; } } if (isset($tabBilan[4])) { $this->BILANDATEp4 = $tabBilan[4]['DATE_CLOTURE']; $this->BILANANNEEp4 = substr($this->BILANDATEp4,0,4)*1; $this->nmp4=$tabBilan[4]['DUREE_MOIS']; if ($this->BILANANNEEp4 > 0) { $this->BILANp4 = 1; $nbMoisBilDate = Metier_Util_Date::nbMoisEntre($this->BILANDATEp4, $this->BILANDATE); //$nbMoisBilCumul+=$this->nmp4; } } // Liste des années de bilans ultérieurs $this->BILANANNEE1 = $this->BILANANNEE + 1; $this->BILANANNEE2 = $this->BILANANNEE + 2; $this->BILANANNEE3 = $this->BILANANNEE + 3; $this->BILANANNEE4 = $this->BILANANNEE + 4; $this->BILANANNEE5 = $this->BILANANNEE + 5; // --- Calcul des ratios $mRatios = new Metier_Scores_MRatios(); $mRatios->setTrancheEffectif($efftr); $tabRatios = $mRatios->calcul($tabBilan); } $timer['ratios']=microtime(true); // Tableau des années de bilans $tabAnnees = array(); // Tableau d'infos sur les bilans $i2=0; if (count($tabRatios)>0) { foreach ($tabRatios as $i => $Ritem) { if (substr($tabBilan[$i]['DATE_CLOTURE'],0,4) > 1900){ $tabAnnees[$i] = substr($tabBilan[$i]['DATE_CLOTURE'], 0, 4); } // Utilisation d'un index texte à cause du webservice foreach ($Ritem as $Ridx => $Rmont) { if ( ($tabBilan[$i]['CONSOLIDE']=='S' && isset($tabRatios[$i+1]) && ($tabBilan[$i+1]['CONSOLIDE']=='S' || ($tabBilan[$i+1]['CONSOLIDE']=='N' && $tabBilan[$i+1]['DATE_CLOTURE']!=$tabBilan[$i]['DATE_CLOTURE']))) || ($tabBilan[$i]['CONSOLIDE']=='N' && isset($tabRatios[$i+1]) && ($tabBilan[$i+1]['CONSOLIDE']=='N' || ($tabBilan[$i+1]['CONSOLIDE']=='S' && $tabBilan[$i+1]['DATE_CLOTURE']!=$tabBilan[$i]['DATE_CLOTURE']))) ) { $Rmont = (($tabRatios[$i][$Ridx]-$tabRatios[$i+1][$Ridx])*100)/abs($tabRatios[$i+1][$Ridx]); $Rdiffmont = $tabRatios[$i][$Ridx]-$tabRatios[$i+1][$Ridx]; } elseif ( ($tabBilan[$i]['CONSOLIDE']=='S'&&isset($tabRatios[$i+1])&&($tabBilan[$i+2]['CONSOLIDE']=='S' || ($tabBilan[$i+2]['CONSOLIDE']=='N'&&$tabBilan[$i+2]['DATE_CLOTURE']!=$tabBilan[$i]['DATE_CLOTURE']))) || ($tabBilan[$i]['CONSOLIDE']=='N'&&isset($tabRatios[$i+1])&&($tabBilan[$i+2]['CONSOLIDE']=='N' || ($tabBilan[$i+2]['CONSOLIDE']=='S'&&$tabBilan[$i+2]['DATE_CLOTURE']!=$tabBilan[$i]['DATE_CLOTURE']))) ) { $Rmont = (($tabRatios[$i][$Ridx]-$tabRatios[$i+2][$Ridx])*100)/abs($tabRatios[$i+2][$Ridx]); $Rdiffmont = $tabRatios[$i][$Ridx]-$tabRatios[$i+1][$Ridx]; } else { $Rmont = 'NS'; $Rdiffmont = 'NS'; } $tabRatiosEvol[$i2][$Ridx] = $Rmont; $tabRatiosDiff[$i2][$Ridx] = $Rdiffmont; } $tabRatiosNew[$i2] = $tabRatios[$i]; if ($tabBilan[$i]['CONSOLIDE']!='C') $i2++; } $this->R = $tabRatiosNew[0]; $this->Rp = $tabRatiosNew[1]; // Ratios précédents N-1 $this->Rp2 = $tabRatiosNew[2]; // Ratios précédents N-2 $this->Rp3 = $tabRatiosNew[3]; // Ratios précédents N-3 $this->Rp4 = $tabRatiosNew[4]; // Ratios précédents N-4 $this->Rdiff = $tabRatiosDiff[0]; $this->Revol = $tabRatiosEvol[0]; $this->Revolp = $tabRatiosEvol[1]; $this->Revolp2 = $tabRatiosEvol[2]; $this->Revolp3 = $tabRatiosEvol[3]; } $timer['anbilans']=microtime(true); // Régression : Ratios $iMax = count($this->tabRegX); foreach ($tabFormules as $i2 => $Rtmp) { for ( $i = 0 ; $i <= $iMax ; $i++ ) { if ( isset($tabRatios[$i][$Rtmp['id']]) ) { $this->regR[$Rtmp['id']][]=$tabRatios[$i][$Rtmp['id']]; } else { if ( array_key_exists($i, $this->tabRegX) ) { //unset($tabRegX[$i]); } } if (isset($tabRatiosSecteurs[$i][$Rtmp['id']])) { $this->regRs[$Rtmp['id']][]=$tabRatiosSecteurs[$i][$Rtmp['id']]; } } if ( is_array($this->regR) && array_key_exists($Rtmp['id'], $this->regR) ) { $this->regR[$Rtmp['id']] = array_reverse($this->regR[$Rtmp['id']]); } if ( is_array($this->regRs) && array_key_exists($Rtmp['id'], $this->regRs) ) { $this->regRs[$Rtmp['id']] = array_reverse($this->regRs[$Rtmp['id']]); } } // On renverse les tableaux 2008, 2007, 2006... en 2006, 2007, 2008 $this->tabRegX = array_reverse($this->tabRegX); $this->EFFECTIF=$this->R[24]; if ($this->EFFECTIF*1==0 && $efftr>0) $this->EFFECTIF=$efftr; $this->CABILAN=$this->R[6]; // Ratios Secteur en fonction des dernières années de bilans $this->MARCHE=$this->MARCHEp=$this->MARCHEVOL=$this->MARCHEPART=$this->MARCHEPARTp=$this->MARCHEPARTEVOL=''; $this->MARCHESAL=$this->MARCHESALp=$this->MARCHENBENT=$this->MARCHENBENTp=''; $tabRatiosSecteurs=$Rtot=array(); if (count($tabAnnees) > 0) { if (strlen($naf)>4) $strNaf=" AND naf5='$naf' "; else $strNaf=" AND naf4='$naf' "; if (count($tabAnnees)>2) $strAnnees='AND annee BETWEEN '.$tabAnnees[2].' AND '.$tabAnnees[0]; elseif (count($tabAnnees)>1) $strAnnees='AND annee BETWEEN '.$tabAnnees[1].' AND '.$tabAnnees[0]; else $strAnnees='AND annee='.$tabAnnees[0]; $tabTmp = $this->db->select('jo.ratios_secteurs', 'annee, naf5, naf4, id, (montant/nombre) AS ratio, montant, nombre', "1 $strNaf $strAnnees ORDER BY annee DESC, id ASC", $this->debug, MYSQL_ASSOC); $anneePre = $tabTmp[0]['annee']; $iAn=0; foreach ($tabTmp as $tabTmp2) { if ($anneePre<>$tabTmp2['annee']){ $iAn++; } $Ridx=$tabTmp2['id']; if ($tabRatiosInfos[$Ridx]['unite']=='EUR'){ $montant=round($tabTmp2['ratio']*1000); } else { $montant=round($tabTmp2['ratio']); } // Gestion des bornes if ($tabBorneMin[$Ridx]<>'' && $montant<$tabBorneMin[$Ridx]){ $montant='<'.$tabBorneMin[$Ridx]; } elseif ($tabBorneMax[$Ridx]<>'' && $montant>$tabBorneMax[$Ridx]){ $montant='>'.$tabBorneMax[$Ridx]; } if (substr($montant,0,1)=='N' || substr($montant,0,1)=='<' || substr($montant,0,1)=='>'){ $tabRatiosSecteurs[$iAn][$Ridx]=$montant; } else { $tabRatiosSecteurs[$iAn][$Ridx]=round($montant,2); } $anneePre=$tabTmp2['annee']; // Calcul des infos MARCHES if (date('m')*1>6) // On est courant 2ème semestre $anneeBaseMarche=-1; else $anneeBaseMarche=-2; for ($iMarche=0; $iMarche<3; $iMarche++) { $tmpCalc=($this->ANNEE-$iMarche+$anneeBaseMarche)*1; if ($tmpCalc==$tabTmp2['annee']*1) { switch ($Ridx*1) { //$nb=$tabTmp2['nombre']; //case 1: // CA France en M? //case 3: // CA Export en M? case 5: // CA Total en M? $Rtot[$iMarche][0]=$tabTmp2['nombre']; // On ne calcul le nombre d'acteurs pour cette information qu'avec le CA total, information la + renseignée case 7: // Résultat Net $Rtot[$iMarche][$Ridx]=round($tabTmp2['montant']*1000); // En euro break; case 24:// Effectif $Rtot[$iMarche][$Ridx]=round($tabTmp2['montant']); break; } } } } $this->MARCHE=$Rtot[0][5]; // Taille du marché en ME $this->MARCHEp=$Rtot[1][5]; // Taille du marché précédent en ME $this->MARCHEVOL=(($this->MARCHE-$this->MARCHEp)*100)/$this->MARCHEp; // % évolution du marche N/N-1 $this->MARCHEPART=$this->R[5]*100/$this->MARCHE; // Part de marche en % $this->MARCHEPARTp=$this->Rp[5]*100/$this->MARCHEp; // Part de marche précédent en % $this->MARCHEPARTEVOL=(($this->MARCHEPART-$this->MARCHEPARTp)*100)/$this->MARCHEPARTp; // % évolution de la part de marché N / N-1 $this->MARCHESAL=$Rtot[0][24]; // Nb salariés du marché $this->MARCHESALp=$Rtot[1][24]; // Nb salariés du marché N-1 $this->MARCHENBENT=$Rtot[0][0]; // Nombre d'entités $this->MARCHENBENTp=$Rtot[1][0]; // Nombre d'entités N-1 $this->Rs=$tabRatiosSecteurs[0]; $this->Rsp=$tabRatiosSecteurs[1]; $this->Rsp2=$tabRatiosSecteurs[2]; // Ratios secteurs précédents N-2 $this->Rsp3=$tabRatiosSecteurs[3]; // Ratios secteurs précédents N-3 $this->Rsp4=$tabRatiosSecteurs[4]; // Ratios secteurs précédents N-4 $timer['ratiosecteur']=microtime(true); } $timer['regression']=microtime(true); // --- Détection fine de l'état de fermeture éventuel à l'INSEE $where = "insSIREN=$siren AND insEVE IN ('400','410','420','425','MPF','MNP') ORDER BY insDATEVE DESC"; if ($this->companyEvenDateStop !== null) { $where = "insSIREN=$siren AND insEVE IN ('400','410','420','425','MPF','MNP') AND idFlux < '". $this->companyEvenDateStop."' ORDER BY insDATEVE DESC"; } $tabTmp = $this->db->select('insee.insee_even', 'insEVE, insDATEVE', $where, $this->debug, MYSQL_ASSOC); if (count($tabTmp)>0) { $tabModif = $tabTmp[0]; $this->ETATINSEE_MMAA = substr($tabModif['insDATEVE'],0,7); switch(''.$tabModif['insEVE']) { // Suppression d'un double case '400': $this->ACTIFINSEE = false; $this->ETATINSEE = 'SUPD'; break; // Cessation juridique de l'entreprise case '410': if (!$this->ACTIFINSEE) { $this->ETATINSEE = 'JURF'; } break; // Absence d'activité de l'entreprise (cessation économique de l.entreprise) case '420': // Absence d'activité d'une entreprise suite à une mise à jour au répertoire case '425': if (!$this->ACTIFINSEE) { $this->ETATINSEE = 'ECOF'; } break; // Présumé Fermé case 'MPF': $this->ETATINSEE = 'PFER'; break; // NPAI case 'MNP': $this->ETATINSEE = 'NPAI'; break; } } /** Eléments provenant des évènements INSEE **/ $tabTmp = $this->db->select('insee.insee_even', 'COUNT(*) AS nb, MAX(insDATEVE) AS dateMaj', "insSIREN=$siren", $this->debug, MYSQL_ASSOC); $tabModif=$tabTmp[0]; $this->MODIFINSEE=$tabModif['nb']; $this->MODIFINSEEDATE=$tabModif['dateMaj']; if ($tabIdentite['DateMajINSEE']>=$this->MODIFINSEEDATE) $this->MODIFINSEEDATE=$tabIdentite['DateMajINSEE']; /** Eléments provenant des évènements RNCS **/ $tabTmp=$this->db->select('jo.rncs_modifs', 'COUNT(*) AS nb, MAX(flux) AS dateMaj', "siren=$siren", $this->debug, MYSQL_ASSOC); $tabModif=$tabTmp[0]; $this->MODIFRNCS=$tabModif['nb']; $this->MODIFRNCSDATE=$tabModif['dateMaj']; if ($tabIdentite['DateMajRCS']>=$this->MODIFRNCSDATE) $this->MODIFRNCSDATE=$tabIdentite['DateMajRCS']; /** $ANNONCEBOD **/ $this->ANNONCEBOD=$this->ANNONCEBODA=$this->ANNONCEBODB=$this->ANNONCEBODC=0; $this->ANNONCECAC=$this->ANNONCECAP=$this->ANNONCECAPAUG=$this->ANNONCECAPAUGDIM=$this->ANNONCECAPDIM=$this->ANNONCECAPDIMAUG=$this->ANNONCECAPSIG=0; $this->ANNONCECAC2=$this->ANNONCECAC3=0; $this->ANNONCEADR=$this->ANNONCEDIR=$this->ANNONCEFJUR=0; $this->ANNONCEADRDATE=$this->ANNONCECACDATE=$this->ANNONCEPCDATE=$this->ANNONCEPC_CESDATE=$this->ANNONCEPLANFINDATE=''; $this->ANNONCEPC_INT1=$this->ANNONCEPC_INT1_TIT=$this->ANNONCEPC_INT2=$this->ANNONCEPC_INT2_TIT=''; $this->ANNONCELJ=$this->ANNONCERJ=$this->ANNONCESV=$this->ANNONCEPUB=0; $this->ANNONCEFUS=0; $this->FUSIONPROJET=''; // Présence d'un projet de fusion, libellé du projet $this->FUSIONPROJET_SIREN=''; // Siren concerné par le projet de fusion $this->FUSIONPROJET_DATE=''; // Date du projet de fusion $this->NOMFUSION=''; $this->CAPITAL_PRE=''; // Montant du capital Précédent $this->ANNONCEHOM=0; // Nombre d'annonces d'homologation $this->ANNONCEHOMDATE=''; // Date de la dernière parution d'annonces d'homologation $this->ANNONCEPLAN=$this->ANNONCEPLANMODIFDATE=$this->ANNONCEPLANDATE=$this->PLAN=$this->PLANMODIF=$this->ANNONCEPC=''; $this->ANNONCEPC_OBS=false; $this->ANNONCEOBJET=''; /** @todo : Prendre la date de changement d'état du dirigeant **/ $this->ANNONCEINTERDITDATE=''; $timer['even']=microtime(true); /** Tableau des taux d'inflation et inflations moyennes **/ $tabInfla = include __DIR__ . '/Data/Infla.php'; if (is_array($tabInfla) && count($tabInfla) > 0) { krsort($tabInfla); $i = 0; foreach ($tabInfla as $itemAnnee => $itemInfla) { if ($i > 10) break; if ($itemAnnee > $this->BILANANNEE) continue; $this->INFLA[$itemAnnee] = $itemInfla; if ($i==0) { $this->INFLATION = $itemInfla; } elseif ($i==1) { $this->INFLA1 = $itemInfla; $this->INFLAMOY1 = ($this->INFLA1 + $this->INFLATION) / 2; } elseif ($i==2) { $this->INFLA2 = $itemInfla; $this->INFLAMOY2 = ($this->INFLA2 + $this->INFLA1 + $this->INFLATION) / 3; } elseif ($i==3) { $this->INFLAMOY3 = ($itemInfla + $this->INFLA2 + $this->INFLA1 + $this->INFLATION) / 4; } $i++; } } /** Divers éléments calculés **/ $iInsee->AnnoncesLegalesVisu = true; $companyAnnonces = $iInsee->getAnnoncesLegales($siren); $iInsee->AnnoncesLegalesVisu = false; // Annonces de dépôt des comptes $tabDepotCpt = $iInsee->annoncesFilter($companyAnnonces, 'C'); $nbDepotCpt = count($tabDepotCpt); $nbMoisMax=0; $this->ANNONCEBODCMANQDATE = false; $this->ANNONCEBODCREGUL = true; $this->BILANDERANNEE = 0; $tabAnnBodc=array(); if($nbDepotCpt>0) { foreach ($tabDepotCpt as $iDep=>$depot) { if ($iDep==0) { // On prend la dernière Annonce de dépot de comptes $this->ANNONCEPUB=true; $tabTmp=array(); foreach ($depot['evenements'] as $even) { $tabTmp[]=$even['LibEven']; } // Libellé code Even de la plus récente annonce publiée peu importe la source $this->ANNONCEDER=implode(', ', $tabTmp); $this->ANNONCEDERDATE=$depot['DateParution']; switch(substr($depot['BodaccCode'],0,1)) { case 'B': $this->ANNONCEDERSOURCE='BODACC'; break;// INPI, Publication Régionale case 'P': $this->ANNONCEDERSOURCE='RNCS'; break; case 'G': $this->ANNONCEDERSOURCE='GREFFE DU TRIBUNAL'; break; default: $this->ANNONCEDERSOURCE='JOURNAL REGIONAL'; break; } $this->ANNONCEDERTEXTE=$depot['texteAnnonce'];// INPI, Publication Régionale // Date de l'annonce $this->ANNONCEDATE=$depot['DateParution']; $this->ANNONCEBODCDATE=$depot['DateParution']; $this->BILANDERANNEE=date('Y', mktime(0, 0, 0, Metier_Util_Date::dateT('Y-m-d', 'm', $depot['dateEffet']), Metier_Util_Date::dateT('Y-m-d', 'd', $depot['dateEffet']), Metier_Util_Date::dateT('Y-m-d', 'Y', $depot['dateEffet'])+1)); $this->ANNONCEBODDATE=$depot['DateParution'];//dateEffet if ($nbDepotCpt==1 && // 1 seul dépôt des comptes abs(Metier_Util_Date::nbMoisEntre(date('Y-m-d'), $dateCrea))<60) {// Entreprise de moins de 5 ans (60 mois) $nbMoisMax=abs(Metier_Util_Date::nbMoisEntre($dateCrea,$depot['dateEffet'])); } } else { if (abs(Metier_Util_Date::nbMoisEntre($lastDepot, $depot['dateEffet']))>$nbMoisMax) { $nbMoisMax=abs(Metier_Util_Date::nbMoisEntre($lastDepot, $depot['dateEffet'])); if ($nbMoisMax>24 && $this->ANNONCEBODCMANQDATE==false) { /** @todo Annomalie Bilans 1 mois sur 976320309 ** $ANNONCEBODCREGUL 0 Pas de publication régulière des comptes * 1 Régulier et 12 mois identiques * 2 Régulier mais Présence de changements de date d'exercice ** $ANNONCEBODCMANQDATE Date de la dernière cloture manquante ** $ANNONCEBODCMANQ_AA Année de la dernière cloture manquante ** $NBBILANMANQUE Nombre d'années de bilans manquant ** $nmp=$tabBilan[0]['DUREE_MOIS_PRE']; $nmp2=$tabBilan[2]['DUREE_MOIS']; $nmp3=$tabBilan[3]['DUREE_MOIS']; $nmp4 **/ $this->ANNONCEBODCMANQDATE=date('Y-m-d', mktime(0, 0, 0, Metier_Util_Date::dateT('Y-m-d', 'm', $depot['dateEffet']), Metier_Util_Date::dateT('Y-m-d', 'd', $depot['dateEffet']), Metier_Util_Date::dateT('Y-m-d', 'Y', $depot['dateEffet'])+1)); $this->ANNONCEBODCMANQ_AA=substr($this->ANNONCEBODCMANQDATE,0,4); } } } $lastDepot=$depot['dateEffet']; $this->ANNONCEBOD++; $this->ANNONCEBODC++; } } // Publications régulieres et 12 mois identiques if ( ($nbMoisBilDate+1) == $nbMoisBilCumul || $nbMoisBilDate == $nbMoisBilCumul || ($nbMoisBilDate-1)==$nbMoisBilCumul ) { $this->ANNONCEBODCREGUL=1; // Annonces BODACC de changement de date d'exercice $tabDepotCpt = $iInsee->annoncesFilter($companyAnnonces, array(2303)); if (count($tabDepotCpt)>0) $this->ANNONCEBODCREGUL=2; } // Pas de publication régulière des comptes else { $this->ANNONCEBODCREGUL=0; } // Pas de Dernière année de bilan et on est en juillet passé if ($this->BILANDERANNEE==0 && date('m')*1>6) { $this->BILANDERANNEE=date('Y', mktime(0, 0, 0, date('m'), date('d'), date('Y')-1)); } // Pas de Dernière année de bilan et on est au premier semestre elseif ($this->BILANDERANNEE==0 && date('m')*1<=6) { $this->BILANDERANNEE=date('Y', mktime(0, 0, 0, date('m'), date('d'), date('Y')-2)); } // Annonces BODACC A $tabDepotCpt = $iInsee->annoncesFilter($companyAnnonces, 'BODA'); $nbDepotA=count($tabDepotCpt); if ($nbDepotA>0) { foreach ($tabDepotCpt as $iDep=>$depot) { if ($iDep==0) { $this->ANNONCEBODADATE=$depot['DateParution']; if (Metier_Util_Date::dateT('Y-m-d', 'Ymd',$this->ANNONCEBODADATE)>Metier_Util_Date::dateT('Y-m-d', 'Ymd',$this->ANNONCEBODDATE)) { $this->ANNONCEBODDATE=$depot['DateParution']; $tabTmp=array(); foreach ($depot['evenements'] as $even) { $tabTmp[]=$even['LibEven']; } // Libellé code Even de la plus récente annonce publiée peu importe la source $this->ANNONCEDER=implode(', ', $tabTmp); $this->ANNONCEDERDATE=$depot['DateParution']; switch(substr($depot['BodaccCode'],0,1)) { case 'B': $this->ANNONCEDERSOURCE='BODACC'; break;// INPI, Publication Régionale case 'P': $this->ANNONCEDERSOURCE='RNCS'; break; case 'G': $this->ANNONCEDERSOURCE='GREFFE DU TRIBUNAL'; break; default: $this->ANNONCEDERSOURCE='JOURNAL REGIONAL'; break; } $this->ANNONCEDERTEXTE=$depot['texteAnnonce'];// INPI, Publication Régionale } } // La première annonce de Bodacc A étant cencée être celle de création elseif ( ($iDep+1)==$nbDepotA ) { $this->TRIBUNAL_CREATION=strtr($depot['Tribunal'],array('TC '=>'Tribunal de Commerce de ')); } $this->ANNONCEBOD++; $this->ANNONCEBODA++; } } // Annonces BODACC B $tabDepotCpt = $iInsee->annoncesFilter($companyAnnonces, 'BODB'); if (is_array($tabDepotCpt) && count($tabDepotCpt)>0){ foreach ($tabDepotCpt as $iDep=>$depot) { if ($iDep==0) { $this->ANNONCEBODBDATE=$depot['DateParution']; if (Metier_Util_Date::dateT('Y-m-d', 'Ymd',$this->ANNONCEBODBDATE)>Metier_Util_Date::dateT('Y-m-d', 'Ymd',$this->ANNONCEBODDATE)) { $this->ANNONCEBODDATE=$depot['DateParution']; $tabTmp=array(); foreach ($depot['evenements'] as $even) { $tabTmp[]=$even['LibEven']; } // Libellé code Even de la plus récente annonce publiée peu importe la source $this->ANNONCEDER=implode(', ', $tabTmp); $this->ANNONCEDERDATE=$depot['DateParution']; switch(substr($depot['BodaccCode'],0,1)) { case 'B': $this->ANNONCEDERSOURCE='BODACC'; break;// INPI, Publication Régionale case 'P': $this->ANNONCEDERSOURCE='RNCS'; break; case 'G': $this->ANNONCEDERSOURCE='GREFFE DU TRIBUNAL'; break; default: $this->ANNONCEDERSOURCE='JOURNAL REGIONAL'; break; } $this->ANNONCEDERTEXTE=$depot['texteAnnonce'];// INPI, Publication Régionale } } $this->ANNONCEBOD++; $this->ANNONCEBODB++; } } // Annonces BODACC Changement d'adresse $tabDepotCpt = $iInsee->annoncesFilter($companyAnnonces, array(2300,2301,2901,2902,2903,2904)); if (is_array($tabDepotCpt) && count($tabDepotCpt)>0){ foreach ($tabDepotCpt as $iDep=>$depot) { if ($iDep == 0) { $this->ANNONCEADRDATE = $depot['DateParution']; } $this->ANNONCEADR++; } } // Annonces BODACC Changement de dirigeant $tabDepotCpt = $iInsee->annoncesFilter($companyAnnonces, array(2315)); if (is_array($tabDepotCpt) && count($tabDepotCpt)>0){ foreach ($tabDepotCpt as $iDep=>$depot) { if ($iDep==0) { $this->ANNONCEDIRDATE = $depot['DateParution']; } $this->ANNONCEDIR++; if (preg_match('/Commissaire/iu', $depot['texteAnnonce'])) { $this->ANNONCECAC++; if ($this->ANNONCECAC == 1) { $this->ANNONCECACDATE=$depot['DateParution']; } } } } // Annonces BODACC Changement de FJur $tabDepotCpt = $iInsee->annoncesFilter($companyAnnonces, array(2307)); if (is_array($tabDepotCpt) && count($tabDepotCpt)>0){ foreach ($tabDepotCpt as $iDep=>$depot) { if ($iDep==0) { $this->ANNONCEFJURDATE = $depot['DateParution']; } $this->FJUR_PRE=''; $this->ANNONCEFJUR++; } } // Annonces BODACC Fusion/Absorptions /** * 2700 Fusion/Absorption (entitée absorbante) * 2701 Fusion/Absorption (Entitée absorbante. Entité absorbée inconnue) * 2702 Fusion/Absorption (Entitée absorbante. Entité absorbée mal SIRENEE) * 2703 Fusion/Absorption (Entitée absorbante. Entité absorbée non SIRENEE) * 2720 Fusion/Absorption (entitée absorbée) * 2721 Fusion/Absorption (entitée absorbée non identifiée) * 2725 Fusion/Absorption */ $tabDepotCpt = $iInsee->annoncesFilter($companyAnnonces, array(2700,2701,2702,2703,2710,2720,2721,2725,2726,2730,2740)); if (is_array($tabDepotCpt) && count($tabDepotCpt)>0){ foreach ($tabDepotCpt as $iDep=>$depot) { if ($iDep == 0) { $this->ANNONCEFUSDATE = $depot['DateParution']; } $this->ANNONCEFUS++; foreach ($depot['evenements'] as $even) { switch ($even['CodeEven']*1) { case 2710: // Projet de fusion (entitée absorbante) case 2726: // Projet de Fusion/Absorption case 2730: // Projet de fusion (entitée absorbée) $this->FUSIONPROJET_DATE=$depot['dateJugement']; // Date du projet de fusion $this->FUSIONPROJET=$depot['complement']; // Présence d'un projet de fusion, libellé du projet $this->FUSIONPROJET_SIREN=''; if (preg_match_all("/((?:[0-9]{9,9})|(?:[0-9]{3,3} [0-9]{3,3} [0-9]{3,3})|(?:[0-9]{3,3}\.[0-9]{3,3}\.[0-9]{3,3})|(?:[0-9]{3,3}-[0-9]{3,3}-[0-9]{3,3}))/", $this->FUSIONPROJET, $matches)) { foreach ($matches[1] as $this->FUSIONPROJET_SIREN) { $this->FUSIONPROJET_SIREN=strtr($this->FUSIONPROJET_SIREN, array('.'=>'','-'=>'', ' '=>'')); if (!$iInsee->valideSiren($this->FUSIONPROJET_SIREN)) { $this->FUSIONPROJET_SIREN=0; } else { break; } } } if ($this->FUSIONPROJET_SIREN*1<100) $this->FUSIONPROJET_SIREN=''; break; } } } } // Annonces BODACC Changement de capital $annCapPre=0; $tabDepotCpt = $iInsee->annoncesFilter($companyAnnonces, array(2100,2101,2102)); $tabDepotCpt = array_reverse($tabDepotCpt); $this->CAPITAL_PRE = 0; if (is_array($tabDepotCpt) && count($tabDepotCpt)>0){ foreach ($tabDepotCpt as $iDep=>$depot) { // Date de la plus récente Annonce changement de capital $this->ANNONCECAPDATE=$depot['DateParution']; if (count($tabDepotCpt)>1 && $iDep == count($tabDepotCpt)-2) { if ($depot['capitalDev']=='FRF') { $this->CAPITAL_PRE = round($depot['capital']/6.55957); } else { $this->CAPITAL_PRE = $depot['capital']; } } // Boucle sur les evenements foreach ($depot['evenements'] as $even) { // Evenement 2101 : Modificaition de capital if ($even['CodeEven'] == 2101) { if ($iDep > 0 && $this->CAPITAL_PRE > 0) { if ($depot['capitalDev']=='FRF') { $annonceCapital = round($depot['capital']/6.55957); } else { $annonceCapital = $depot['capital']; } // Augmentation if ($annonceCapital > $this->CAPITAL_PRE) { $even['CodeEven'] = 2102; } // Diminution elseif ($annonceCapital < $this->CAPITAL_PRE) { $even['CodeEven'] = 2100; } } } switch ($even['CodeEven']*1) { // Diminution de capital case 2100: $this->ANNONCECAPDIM++; if ($this->ANNONCECAPDIM==1) { // Année de la plus ancienne Annonce diminution de capital $this->ANNONCECAPDIM_AAD = substr($depot['DateParution'],0,4); } else { // Date de la plus récente Annonce de diminution de capital $this->ANNONCECAPDIMDATE=$depot['DateParution']; // Année de la plus récente Annonce diminution de capital $this->ANNONCECAPDIM_AAF=substr($depot['DateParution'],0,4); } // Augmentation suivie de diminution de capital if ($annCapPre == 2102) { $this->ANNONCECAPAUGDIM++; } $annCapPre=2100; break; // Augmentation de capital case 2102: $this->ANNONCECAPAUG++; if ($this->ANNONCECAPAUG==1) { // Année de la plus ancienne Annonce Augmentation de capital $this->ANNONCECAPAUG_AAD = substr($depot['DateParution'],0,4); } else { // Date de la plus récente Annonce Augmentation de capital $this->ANNONCECAPAUGDATE=$depot['DateParution']; // Année de la plus récente Annonce Augmentation de capital $this->ANNONCECAPAUG_AAF=substr($depot['DateParution'],0,4); } // Diminution suivie de Augmentation de capital if ($annCapPre == 2100){ $this->ANNONCECAPDIMAUG++; } $annCapPre=2102; break; } } $this->ANNONCECAP++; $this->ANNONCECAPSIG++; } } // Annonces BODACC Cessation d'activité avec dissolution $tabDepotCpt = $iInsee->annoncesFilter($companyAnnonces, array(2202,2203,2204,2210,2212)); if (is_array($tabDepotCpt) && count($tabDepotCpt)>0){ foreach ($tabDepotCpt as $iDep=>$depot) { if ($this->BILANDATEANNONCEDISSODATE=$depot['DateParution']; $this->ANNONCEDISSO=true; } break; } } // Annonces BODACC Poursuite de l'activité malgré la perte de plus de la moitié du capital social $tabDepotCpt = $iInsee->annoncesFilter($companyAnnonces, array(2314,2319)); if (is_array($tabDepotCpt) && count($tabDepotCpt)>0){ foreach ($tabDepotCpt as $iDep=>$depot) { $this->ANNONCEPOURSDATE= $this->ANNONCEDISSONONDATE= $depot['DateParution']; $this->ANNONCEPOURS= $this->ANNONCEDISSONON= true; break; } } // Annonces BODACC Reconsitution de l'actif net ou de la moitié $tabDepotCpt = $iInsee->annoncesFilter($companyAnnonces, array(2320,2321)); if (is_array($tabDepotCpt) && count($tabDepotCpt)>0){ foreach ($tabDepotCpt as $iDep=>$depot) { $this->ANNONCERECONDATE=$depot['DateParution']; $this->ANNONCERECON=true; break; } } // Annonces BODACC Location gérance reçue $tabDepotCpt = $iInsee->annoncesFilter($companyAnnonces, array(2800,2880,4355)); if (is_array($tabDepotCpt) && count($tabDepotCpt)>0){ foreach ($tabDepotCpt as $iDep=>$depot) { $this->ANNONCELOCDATE=$depot['DateParution']; $this->ANNONCELOC=true; break; } } // Annonces BODACC Mise en sommeil de la société $tabDepotCpt = $iInsee->annoncesFilter($companyAnnonces, array(2206)); if (is_array($tabDepotCpt) && count($tabDepotCpt)>0){ foreach ($tabDepotCpt as $iDep=>$depot) { $this->ANNONCESOMMDATE=$depot['DateParution']; $this->ANNONCESOMM=true; break; } } $timer['bodacc']=microtime(true); $this->ANNONCEOBJET=$tabIdentite['Activite']; if ($tabIdentite['SituationJuridique']=='P') { $this->ANNONCEPC='Procédure Collective'; $tabProCol = $iInsee->annoncesFilter($companyAnnonces, 'P'); foreach ($tabProCol as $iProcol=>$procol) { foreach ($procol['evenements'] as $even) { if ($iProcol==0) $this->ANNONCEPC=$even['LibEven']; switch ($even['CodeEven']*1) { case 1300: // Conversion Redressement Judiciaire en Liquidation Judiciaire case 1301: // Ouverture Liquidation Judiciaire case 1302: // Ouverture Liquidation Judiciaire Simplifiée case 1305: // Liquidation Judiciaire if (substr($procol['dateFinObservation'],0,4)*1>0) $this->ANNONCEPC_OBS=true; case 1303: // Ouverture Liquidation Judiciaire sur résolution du plan case 1304: // Réouverture Liquidation Judiciaire case 1306: // Liquidation Judiciaire simplifiée case 1307: // Conversion sauvegarde en Liquidation Judiciaire case 1311: // Liquidation Judiciaire par extension au(x) gérant(s) case 1312: // Liquidation Judiciaire avec continuation d'exploitation case 1313: // Liquidation Judiciaire sans remise des accessoires case 1417: // Jugement d'extension de liquidation judiciaire // Annonce de liquidation judiciaire $this->ANNONCELJ=true; // Date de l'annonce LJ $this->ANNONCELJDATE=$procol['dateJugement']; $this->ANNONCEDATE=$this->ANNONCEPCDATE=$procol['dateJugement']; $this->TRIBUNAL_PROCOL=strtr($procol['Tribunal'],array('TC '=>'Tribunal de Commerce de ')); break; case 1200: // Redressement Judiciaire if (substr($procol['dateFinObservation'],0,4)*1>0) $this->ANNONCEPC_OBS=true; case 1201: // Conversion sauvegarde en Redressement Judiciaire case 1211: // Redressement Judiciaire par extension au(x) gérant(s) case 1212: // Réforme de Liquidation Judiciaire en Redressement Judiciaire case 1418: // Jugement d'extension d'une procédure de redressement judiciaire // Annonce de redressement judiciaire $this->ANNONCERJ=true; // Date de l'annonce RJ $this->ANNONCERJDATE=$procol['dateJugement']; $this->ANNONCEDATE=$this->ANNONCEPCDATE=$procol['dateJugement']; $this->TRIBUNAL_PROCOL=strtr($procol['Tribunal'],array('TC '=>'Tribunal de Commerce de ')); break; case 1100: // Ouverture sauvegarde if (substr($procol['dateFinObservation'],0,4)*1>0) $this->ANNONCEPC_OBS=true; case 1419: // Jugement d'extension d'une procédure de sauvegarde // Annonce de sauvegarde $this->ANNONCESV=true; // Date de l'annonce Sauv $this->ANNONCESVDATE=$procol['dateJugement']; $this->ANNONCEDATE=$this->ANNONCEPCDATE=$procol['dateJugement']; $this->TRIBUNAL_PROCOL=strtr($procol['Tribunal'],array('TC '=>'Tribunal de Commerce de ')); break; case 1407: // Modification de plan case 1408: // Modification du plan de cession case 1409: // Modification du plan de continuation case 1415: // Prolongement du plan cession // Modif de plan d'apurement $this->PLANMODIF=true; $this->ANNONCEPLANMODIFDATE=$this->ANNONCEDATE=$procol['dateJugement']; break; case 1411: // Arrêt du plan de cession case 1414: // Arrêt du plan de redressement $this->ANNONCEPLANFINDATE=$procol['dateFinObservation']; if (substr($this->ANNONCEPLANFINDATE,0,4)*1==0) $this->ANNONCEPLANFINDATE=''; /** @todo $ANNONCEPLANDUREE=''; **/ case 1412: // Arrêt du plan de cession partielle case 1413: // Arrêt du plan de continuation case 1101: // Jugement arrêtant plan de sauvegarde $this->PLAN=true; // Présence d'une annonce de plan d'apurement if ($even['CodeEven']*1==1411) $this->ANNONCEPLAN='cession'; elseif ($even['CodeEven']*1==1412) $this->ANNONCEPLAN='cession partielle'; elseif ($even['CodeEven']*1==1413) $this->ANNONCEPLAN='continuation'; elseif ($even['CodeEven']*1==1414) $this->ANNONCEPLAN='redressement'; elseif ($even['CodeEven']*1==1101) $this->ANNONCEPLAN='sauvegarde'; // Date de l'annonce de plan $this->ANNONCEPLANDATE=$procol['dateJugement']; $this->ANNONCEDATE=$this->ANNONCEPCDATE=$procol['dateJugement']; break; case 1600: // Interdictions et Faillites case 1601: case 1610: case 1611: $this->ANNONCEINTERDITDATE=$procol['dateJugement']; break; case 1202: // Renouvellement de la période d'observation $this->ANNONCEPC_OBS=true; //1430, Jugement autorisant la poursuite d'activité break; } } } // Le SIREN est éliminé du scoring $this->ELIMINE=true; } elseif ($tabIdentite['SituationJuridique']=='PL') { $this->ANNONCEPCHISTO=true; $this->ELIMINE=false; $this->ANNONCEPC='Plan de continuation/redressement'; $tabProCol = $iInsee->annoncesFilter($companyAnnonces, 'P'); foreach ($tabProCol as $iProcol=>$procol) { foreach ($procol['evenements'] as $even) { if ($iProcol==0) $this->ANNONCEPC=$even['LibEven']; switch ($even['CodeEven']*1) { case 1300: // Conversion Redressement Judiciaire en Liquidation Judiciaire case 1301: // Ouverture Liquidation Judiciaire case 1302: // Ouverture Liquidation Judiciaire Simplifiée case 1305: // Liquidation Judiciaire if (substr($procol['dateFinObservation'],0,4)*1>0) $this->ANNONCEPC_OBS=true; case 1303: // Ouverture Liquidation Judiciaire sur résolution du plan case 1304: // Réouverture Liquidation Judiciaire case 1306: // Liquidation Judiciaire simplifiée case 1307: // Conversion sauvegarde en Liquidation Judiciaire case 1311: // Liquidation Judiciaire par extension au(x) gérant(s) case 1312: // Liquidation Judiciaire avec continuation d'exploitation case 1313: // Liquidation Judiciaire sans remise des accessoires case 1417: // Jugement d'extension de liquidation judiciaire // Annonce de liquidation judiciaire $this->ANNONCELJ=true; // Date de l'annonce LJ $this->ANNONCELJDATE=$procol['dateJugement']; $this->ANNONCEDATE=$this->ANNONCEPCDATE=$procol['dateJugement']; $this->TRIBUNAL_PROCOL=strtr($procol['Tribunal'],array('TC '=>'Tribunal de Commerce de ')); break; case 1200: // Redressement Judiciaire if (substr($procol['dateFinObservation'],0,4)*1>0) $this->ANNONCEPC_OBS=true; case 1201: // Conversion sauvegarde en Redressement Judiciaire case 1211: // Redressement Judiciaire par extension au(x) gérant(s) case 1212: // Réforme de Liquidation Judiciaire en Redressement Judiciaire case 1418: // Jugement d'extension d'une procédure de redressement judiciaire // Annonce de redressement judiciaire $this->ANNONCERJ=true; // Date de l'annonce RJ $this->ANNONCERJDATE=$procol['dateJugement']; $this->ANNONCEDATE=$this->ANNONCEPCDATE=$procol['dateJugement']; $this->TRIBUNAL_PROCOL=strtr($procol['Tribunal'],array('TC '=>'Tribunal de Commerce de ')); break; case 1100: // Ouverture sauvegarde if (substr($procol['dateFinObservation'],0,4)*1>0) $this->ANNONCEPC_OBS=true; case 1419: // Jugement d'extension d'une procédure de sauvegarde // Annonce de sauvegarde $this->ANNONCESV=true; // Date de l'annonce Sauv $this->ANNONCESVDATE=$procol['dateJugement']; $this->ANNONCEDATE=$this->ANNONCEPCDATE=$procol['dateJugement']; $this->TRIBUNAL_PROCOL=strtr($procol['Tribunal'],array('TC '=>'Tribunal de Commerce de ')); break; case 1407: // Modification de plan case 1408: // Modification du plan de cession case 1409: // Modification du plan de continuation case 1415: // Prolongement du plan cession // Modif de plan d'apurement $this->PLANMODIF=true; $this->ANNONCEPLANMODIFDATE=$this->ANNONCEDATE=$procol['dateJugement']; break; case 1411: // Arrêt du plan de cession case 1414: // Arrêt du plan de redressement $this->ANNONCEPLANFINDATE=$procol['dateFinObservation']; if (substr($this->ANNONCEPLANFINDATE,0,4)*1==0) $this->ANNONCEPLANFINDATE=''; case 1412: // Arrêt du plan de cession partielle case 1413: // Arrêt du plan de continuation case 1101: // Jugement arrêtant plan de sauvegarde $this->PLAN=true; // Présence d'une annonce de plan d'apurement if ($even['CodeEven']*1==1411) $this->ANNONCEPLAN='cession'; elseif ($even['CodeEven']*1==1412) $this->ANNONCEPLAN='cession partielle'; elseif ($even['CodeEven']*1==1413) $this->ANNONCEPLAN='continuation'; elseif ($even['CodeEven']*1==1414) $this->ANNONCEPLAN='redressement'; elseif ($even['CodeEven']*1==1101) $this->ANNONCEPLAN='sauvegarde'; // Date de l'annonce de plan $this->ANNONCEPLANDATE=$procol['dateJugement']; $this->ANNONCEDATE=$this->ANNONCEPCDATE=$procol['dateJugement']; break; case 1600: // Interdictions et Faillites case 1601: case 1610: case 1611: $this->ANNONCEINTERDITDATE=$procol['dateJugement']; break; case 1202: // Renouvellement de la période d'observation $this->ANNONCEPC_OBS=true; //1430, Jugement autorisant la poursuite d'activité break; } } } } // --- Ni P, Ni PL else { $tabProCol = $iInsee->annoncesFilter($companyAnnonces, 'PH'); if (count($tabProCol) > 0) { $this->ANNONCEPCHISTO = true; } else { $this->ANNONCEPCHISTO = false; } if ($tabIdentite['Actif'] == 0) { $this->ELIMINE = true; } else { $this->ELIMINE = false; } } /** Annonces d'Homologation **/ $tabDepotCpt = $iInsee->annoncesFilter($companyAnnonces, array(1050,1550)); if (is_array($tabDepotCpt) && count($tabDepotCpt)>0){ foreach ($tabDepotCpt as $iDep=>$depot) { if ($iDep==0) $this->ANNONCEHOMDATE=$depot['DateParution']; $this->ANNONCEHOM++; } } /** Ventes Cessions en tant que vendeur **/ $tabProCol = $iInsee->annoncesFilter($companyAnnonces, 'V'); $this->ANNONCEVC=0; // Nombre d'annonce de VC (vendeur) $this->ANNONCEVC_OBJ=$this->ANNONCEVCDATE=$this->ANNONCEVC_MT=''; foreach ($tabProCol as $iProcol=>$procol) { $this->ANNONCEVC++; if ($iProcol==0) { foreach ($procol['evenements'] as $even) { $this->ANNONCEVC_OBJ[]=$even['LibEven']; } $this->ANNONCEVC_OBJ=implode(', ', $this->ANNONCEVC_OBJ); $this->ANNONCEVCDATE=$procol['dateJugement']; $this->ANNONCEVC_MT=$procol['montantVente']; // Montant de la vente } } if ($naf=='741J' || $naf=='6420Z' || // Activités des sociétés holding $this->R[302]>0 || $this->R[303]>0 || $this->R[304]>0 // Holding déclaré au Bilan ) $this->HOLDING=true; else $this->HOLDING=false; // Présence d'au moins un bilan if ($this->NBBILAN>0) $this->BILAN=true; else $this->BILAN=false; // Département du siège de l'entreprise if ($depcomen==0) $depcomen=$tabIdentite['CP']*1; if ($depcomen>99000) $this->DEPSIE=$depcomen; elseif ($depcomen>96000) $this->DEPSIE=substr($depcomen,0,3); elseif ($depcomen<10000) $this->DEPSIE=substr($depcomen,0,1); else $this->DEPSIE=substr($depcomen,0,2); $this->DEPSIE_DE = $iInsee->getDepartement($this->DEPSIE,true); /** * Solvabilité */ $isolv = new Metier_Scores_MSolvabilite( $siren, $naf, $tabIdentite['EffEnTr'], $tabIdentite['Effectif']*1, $tabIdentite['CP'], $fj, $tabIdentite['Capital'], $tabIdentite['CapitalDev'], $tabIdentite['DateCreaEn'], $tabIdentite['DateCreaEt'], '', $this->RECME, $this->db ); $noteStructure = $isolv->getSolvabilite(); $timer['solv'] = microtime(true); $tabStructure['activite'] = $isolv->getPtActivite(); $tabStructure['naf4'] = $isolv->getNaf4($naf); $tabStructure['age'] = $isolv->getPtAge(date('Y')); $tabStructure['capital'] = $isolv->getPtCapital(); $tabStructure['effectif'] = $isolv->getPtEffectif(); $tabStructure['fj'] = $isolv->getPtFormeJuridique(); $tabStructure['localite'] = $isolv->getPtGeographie(); $tabStructure['singulier'] = $isolv->getPtSingularite(); // Le dépôt des comptes annuel est facultatif ? if ($isolv->doitPublier($fj, $naf)) { $this->FJURPUB=true; $this->BILANFACULT=false; } else { $this->FJURPUB=false; // L'entreprise n'est pas soumise à publication de ses bilans $this->BILANFACULT=true; } /** @todo : Attention, variable à charger uniquement si le dernier bilan est non diffusible **/ $this->BILANNONDIF=false; /** Classements import Export **/ $tabImportExport=$iInsee->getImportExport($siren); $this->EXPORTRANG=$this->IMPORTRANG=0; foreach ($tabImportExport as $rangAnnee) { if ($rangAnnee['importExport']=='I' && $this->IMPORTRANG==0) { $this->IMPORTRANG=$rangAnnee['rangNational']*1; //$IMPORTRANG_ARR; switch (strlen($this->IMPORTRANG)) { case 1: $this->IMPORTRANG_ARR=10; break; case 2: $this->IMPORTRANG_ARR=100; break; case 3: $this->IMPORTRANG_ARR='1 000'; break; case 4: $this->IMPORTRANG_ARR='10 000'; break; default: $this->IMPORTRANG_ARR='100 000'; break; } } elseif ($rangAnnee['importExport']=='E' && $this->EXPORTRANG==0) { $this->EXPORTRANG=$rangAnnee['rangNational']*1; switch (strlen($this->EXPORTRANG)) { case 1: $this->EXPORTRANG_ARR=10; break; case 2: $this->EXPORTRANG_ARR=100; break; case 3: $this->EXPORTRANG_ARR='1 000'; break; case 4: $this->EXPORTRANG_ARR='10 000'; break; default: $this->EXPORTRANG_ARR='100 000'; break; } } } $timer['importexport']=microtime(true); /** Recherche d'une annonce de RJ sur Actionnaire / Participation **/ $this->RJMERE=$this->RJFILLE=false; $this->SITUACT=$this->NICMERE=$this->SIRENMERE=$this->SIRETMERE=$this->NOMMERE=''; $lienM = new Metier_Liens_Base(); $lienM->setId($siren, 'siren'); // Actionnaire $tabA = $lienM->getActionnaires(null, true); if (count($tabA)>0) { foreach ($tabA as $i=>$lien) { $lienInsee = new Metier_Insee_MInsee($this->db); if(intval($lien->siren)>100 && ( $lien->MajMin=='+' || $lien->PDetention>50)) { $tabIdentiteA=$lienInsee->getIdentiteLight($lien->siren); if ($this->NICMERE*1==0) { $this->NICMERE=substr($tabIdentiteA['SiretSiege'],-5); $this->SIRENMERE=$lien->Siren; $this->SIRETMERE=$tabIdentiteA['SiretSiege']; $this->NOMMERE=$tabIdentiteA['Nom']; if ($tabIdentiteA['FJ']<2000) $this->TYPEMERE='PP'; else $this->TYPEMERE='PM'; } $mBilA = new Metier_Partenaires_MBilans($lien->siren, $this->db); $tabBilansA = $mBilA->listeBilans(false,2); $nbBilansA = count($tabBilansA); if ($nbBilansA > 0) { $mRatiosA = new Metier_Scores_MRatios(); $mRatiosA->setTrancheEffectif($tabIdentiteA['EffEnTr']); $tabRatiosA = $mRatiosA->calcul($tabBilansA); $this->SITUACT=$tabRatiosA[0][19]; $this->Ra=$tabRatiosA[0]; $this->Rap=$tabRatiosA[1]; } if ($lien->siren>100 && count($lienInsee->getAnnoncesLegales($lien->siren, 0, 'P', false))>0) { $this->RJMERE=true; } break; } } } $timer['actionnaires']=microtime(true); // Participation $this->NBFILLE=0; $this->NICFILLE=$this->SIRENFILLE=$this->SIRETFILLE=$this->NOMFILLE=''; $tabP=$lienM->getParticipations(null, true); if (count($tabP)>0) { foreach ($tabP as $i=>$lien) { if ($lien->siren>100 && ( $lien->MajMin=='+' || $lien->PDetention>50)) { $lienInsee = new Metier_Insee_MInsee($this->db); $this->NBFILLE++; // Nombre de participations à plus de 50% if ($this->NBFILLE==1) { $tabIdentiteP=$lienInsee->getIdentiteLight($lien->siren); $this->NICFILLE=substr($tabIdentiteP['SiretSiege'],-5); $this->SIRENFILLE=$lien->Siren; $this->SIRETFILLE=$tabIdentiteP['SiretSiege']; // N° SIRET de la sté 1ere fille à plus de 50% $this->NOMFILLE=$tabIdentiteP['Nom']; } if (count($lienInsee->getAnnoncesLegales($lien->siren, 0, 'P', false))>0) { $this->RJFILLE=true; } } } } $timer['participations']=microtime(true); $tabBil=array(); if ($this->NBBILAN == 0) { $noteSolvabilite = round($noteStructure) * 5; // La note finale est sur 100 /** Pas de bilan mais capital elevé **/ if ($this->ACTIFRNCS && $this->FJURRNCS1>1 && $this->FJURRNCS1<7) { if ($this->CAPITAL < 9000) $this->NOTECAP20=3; elseif ($this->CAPITAL < 30000) $this->NOTECAP20=5; elseif ($this->CAPITAL < 150000) $this->NOTECAP20=7; elseif ($this->CAPITAL < 350000) $this->NOTECAP20=9; elseif ($this->CAPITAL < 500000) $this->NOTECAP20=10; elseif ($this->CAPITAL < 750000) $this->NOTECAP20=11; elseif ($this->CAPITAL < 1500000) $this->NOTECAP20=12; elseif ($this->CAPITAL < 2000000) $this->NOTECAP20=13; elseif ($this->CAPITAL < 5000000) $this->NOTECAP20=15; elseif ($this->CAPITAL < 10000000) $this->NOTECAP20=17; else $this->NOTECAP20=19; } } else { $numBil = $i = 0; foreach ($tabBilan as $item) { if ($item['CONSOLIDE']=='S') { $tabTmp = $mBil->bilanSimplifie2Normal($item); $tabBilan[$i] = array_merge($tabTmp, $item); $numBil++; } elseif ($item['CONSOLIDE']=='N') { $numBil++; } else { continue; } if ($numBil>2) break; $icotation = new Metier_Scores_ICotation($item, true, $this->db); $secteur=$icotation->getSecteurActivite($isolv->getNaf4($naf)); $libSecteur=$icotation->tabLibActivite[$secteur]; $chiffeAffaire=$icotation->calculChiffreAffaires($isolv->getNaf4($naf)); $tabBil[$i] = array( 'Millesime'=>$item['DATE_CLOTURE'], 'FraisPerso'=>$icotation->calculFraisPersonnel(), 'CA'=>$chiffeAffaire, 'EBE'=>$icotation->calculEBE(), 'TxInvest'=>$icotation->calculTauxInvestissement(), 'TxEndett'=>$icotation->calculTauxEndettementFinancier(), 'DettesCT'=>$icotation->calculDettesCT(), 'FraisFi'=>$icotation->calculFraisFinanciers(), 'BFR'=>$icotation->calculBFR(), 'FR'=>$icotation->calculFR(), 'FondsPr'=>$icotation->calculFondsPropres(), 'DelaiCli'=>$icotation->calculDelaisClients(), 'DelaiFour'=>$icotation->calculDelaisFournisseurs(), ); unset($note); unset($noteB); unset($numerateur); unset($denominateur); $note[0]=$noteB[0]=$numerateur[0]=$denominateur[0]=$noteTot=0; $tabTmp = $icotation->noteCapitalisation(); $numerateur[1] = number_format($tabTmp['NUMERATEUR'], 0, ',', ''); $denominateur[1]= number_format($tabTmp['DENOMINATEUR'], 0, ',', ''); $note[1] = number_format($tabTmp['NOTE'], 2, ',', ' '); $noteB[1] = $icotation->getNoteBorne($tabTmp['NOTE'], 1, $secteur, $numerateur[1], $denominateur[1]); // On minimise la note de capitalisation qui est souvent un peu violente if ($noteB[1]<11 && $this->CAPITAL>=100000000) $noteB[1]=11; if ($noteB[1]<6 && $chiffeAffaire>=50000000 && $this->EFFECTIF>300) $noteB[1]=11; $this->NOTECAP20=$noteTot+=$noteB[1]; $tabTmp = $icotation->noteLevierEndettement(); $numerateur[2] = number_format($tabTmp['NUMERATEUR'], 0, ',', ''); $denominateur[2]= number_format($tabTmp['DENOMINATEUR'], 0, ',', ''); $note[2] = number_format($tabTmp['NOTE'], 2, ',', ' '); $noteB[2] = $icotation->getNoteBorne($tabTmp['NOTE'], 2, $secteur, $numerateur[2], $denominateur[2]); $noteTot+=$noteB[2]; $this->NOTELED20=$noteB[2]; $tabTmp = $icotation->noteCapaciteRemboursement(); $numerateur[3] = number_format($tabTmp['NUMERATEUR'], 0, ',', ''); $denominateur[3]= number_format($tabTmp['DENOMINATEUR'], 0, ',', ''); $note[3] = number_format($tabTmp['NOTE'], 2, ',', ' '); $noteB[3] = $icotation->getNoteBorne($tabTmp['NOTE'], 3, $secteur, $numerateur[3], $denominateur[3]); $noteTot+=$noteB[3]; $this->NOTERBT20=$noteB[3]; $tabTmp = $icotation->noteCouvChargesFi(); $numerateur[4] = number_format($tabTmp['NUMERATEUR'], 0, ',', ''); $denominateur[4]= number_format($tabTmp['DENOMINATEUR'], 0, ',', ''); $note[4] = number_format($tabTmp['NOTE'], 2, ',', ' '); $noteB[4] = $icotation->getNoteBorne($tabTmp['NOTE'], 4, $secteur, $numerateur[4], $denominateur[4]); $noteTot+=$noteB[4]; $this->NOTECFI20=$noteB[4]; $tabTmp = $icotation->noteTresorerie($isolv->getNaf4($naf)); $numerateur[5] = number_format($tabTmp['NUMERATEUR'], 0, ',', ''); $denominateur[5]= number_format($tabTmp['DENOMINATEUR'], 0, ',', ''); $note[5] = number_format($tabTmp['NOTE'], 0, ',', ''); $noteB[5] = $icotation->getNoteBorne($tabTmp['NOTE'], 5, $secteur, $numerateur[5], $denominateur[5]); $noteTot+=$noteB[5]; $this->NOTETRES20=$noteB[5]; $tabTmp = $icotation->noteMargeExploitation($isolv->getNaf4($naf)); $numerateur[6] = number_format($tabTmp['NUMERATEUR'], 0, ',', ''); $denominateur[6]= number_format($tabTmp['DENOMINATEUR'], 0, ',', ''); $note[6] = number_format($tabTmp['NOTE'], 2, ',', ' '); $noteB[6] = $icotation->getNoteBorne($tabTmp['NOTE'], 6, $secteur, $numerateur[6], $denominateur[6]); $noteTot+=$noteB[6]; $this->NOTEMEX20=$noteB[6]; $noteMoy=number_format($noteTot/6, 2, '.', ''); if ($noteMoy<8 && $chiffeAffaire>=100000000 && $this->EFFECTIF>=1000) $noteMoy=8; $noteFinanciere = $icotation->getNotationFin($noteMoy); $libNoteFinanciere = $icotation->getInfosNotation($noteFinanciere); $noteSD=round(($noteStructure+$noteMoy)*2.5); $fondsPropres=$icotation->calculFondsPropresNetsCorriges(); /** MALUS **/ // Limitation de la note si Fonds Propres Négatifs if ($fondsPropres<0 && $noteSD>50) $noteSD=50; // Limitation de la note si RJ sur société mère if ($this->RJMERE && $noteSD>40) $noteSD=40; // Limitation de la note si RJ sur société fille if ($this->RJFILLE && $noteSD>55) $noteSD=55; /** BONUS **/ // Major. si entreprise majoritairement contrôlée par l'état if ($this->RECME && $noteSD<55) $noteSD=55; if ((trim(strtr($tabIdentite['DateClotEt'],'-/',' '))*1)>0 ){ $noteSD=0; $analyseConf='L\'entreprise est radiée depuis le '.$tabIdentite['DateClotEt']; } else $analyseConf='L\'analyse de la conformité est correcte.'; if ($numBil==1) { $caEntrep=$chiffeAffaire; $noteSolvabilite=$noteSD; $noteFin=$noteMoy; $scoreConanH=round($icotation->scoreConanHolder(),1); $scoreAfdcc1=round($icotation->scoreAfdcc1(),2); $scoreAfdcc2=round($icotation->scoreAfdcc2($naf, $trancheEffectif),1); $scoreAfdcc2note=round($icotation->noteAfdcc,2); $scoreZ =round($icotation->scoreZbis(),1); $pDef36 =$icotation->evaluationCCF(); $valeurCCF =$icotation->valeurCCF; $scoreAltman=round($icotation->scoreAltman(),2); $scoreAltmanB=round($icotation->scoreAltman(true),2); $tabInfosNotation=$icotation->getInfosNotation($noteFinanciere, 'array'); $this->SCOREDEFTAUX=$tabInfosNotation['ProbabiliteDefaut']; // Liste des équivalences de notes $note20scoreCH=$note20afdcc2=NULL; // AFDCC1 Pertinant ? $nbScoresComp=3; // Par défaut on compare 3 scores : BDF, S&D et AFDCC1 $note20afdcc1=($scoreAfdcc1+4)*1.95; if ($note20afdcc1<0) $note20afdcc1=0; elseif ($note20afdcc1>20) $note20afdcc1=20; // BDF Z Pertinant ? $note20scoreZ=($scoreZ+3)*3; if ($note20scoreZ<0) $note20scoreZ=0; elseif ($note20scoreZ>20) $note20scoreZ=20; // Secteur Industriel : Conan Holder mauvais ? switch ($secteur) { case 15: // Industries Alimentaires : Collecte Appro case 1: // Industries Manufacturières case 2: case 3: case 5: // Industries Alimentaires case 6: // Industries extractives / Production Distribution : Énergie Eau if ($caEntrep>=1500000 && $caEntrep<=75000000) { $nbScoresComp++; $note20scoreCH=$scoreConanH+4; if ($note20scoreCH<0) $note20scoreCH=0; elseif ($note20scoreCH>20) $note20scoreCH=20; } break; } // Score AFDCC2 mauvais ? if ($caEntrep>=150000 && $caEntrep<=75000000) { $nbScoresComp++; $note20afdcc2=$scoreAfdcc2note+9.5; if ($note20afdcc2<0) $note20afdcc2=0; elseif ($note20afdcc2>20) $note20afdcc2=20; } if ($this->debug) { $strNote=""; $tabTmp=array( 1=>'Capitalisation', 2=>'Levier Endettement', 3=>'CapaciteRemboursement', 4=>'CouvChargesFi', 5=>'Tresorerie', 6=>'MargeExploitation', ); for($iTmp=1; $iTmp<7; $iTmp++) $strNote.=$tabTmp[$iTmp]." : ".$numerateur[$iTmp].'/'.$denominateur[$iTmp].'='.$note[$iTmp].' (Borné à '.$noteB[$iTmp].')'.PHP_EOL; $strNote.="Note Financière=$noteFin Conan Holder=$scoreConanH Afdcc1=$scoreAfdcc1 Afdcc2=$scoreAfdcc2note (Classe $scoreAfdcc2) Z=$scoreZ CCF=$valeurCCF ($pDef36) Altman=$scoreAltman AltmanCote=$scoreAltmanB".PHP_EOL.print_r($tabInfosNotation,true); } } else { $noteSolvabilitePre=$noteSD; $noteFinPre=$noteMoy; if ($noteSolvabilite>$noteSolvabilitePre) $tendance='Haussière'; elseif ($noteSolvabilite==$noteSolvabilitePre) $tendance='Stable'; else $tendance='Baissière'; } $i++; } // Cas de présence unique de bilan Banque ou Assurance qui ne sont pas géré financièrement if ($numBil==0 && !isset($noteSD)) $noteSolvabilite=round($noteStructure)*5; // La note finale est sur 100 } $timer['scorefi']=microtime(true); // Au cas ou ! if ($noteSolvabilite>90) $noteSolvabilite=90; $this->SCORECONF=100; // Présence d'un bilan mais trop vieux if ($this->NBBILAN>0 && Metier_Util_Date::nbMoisEntre($this->BILANDATE,date('Ymd'))>=24) $this->BILANVIEUX=true; else $this->BILANVIEUX=false; // Présence d'un bilan mais trop vieux et c'est anormal if ($this->NBBILAN>0 && Metier_Util_Date::nbMoisEntre($this->BILANDATE,date('Ymd'))>=30) $this->BILANMANQUE=true; else $this->BILANMANQUE=false; if ( (@$tabBil[0]['Millesime']+20000FJURPUB ) { // et est soumise à publication $this->SCORECONF-=20; } if (!$tabIdentite['TvaAttribue']) { // Entreprise sans numéro de TVA $this->TVAINTRA=false; $this->TVAINTRAFACULT=$tabIdentite['TvaFacultatif']; // 0, 1=MicroEntrep, 2=Dom Tom Etranger, 99=Erreur validation n°TVA if ($this->TVAINTRAFACULT==0) $this->SCORECONF-=10; } else $this->TVAINTRA=$tabIdentite['TvaNumero']; if ($tabIdentite['NonDiffusible']>0) { // Entreprise FJ=1xxx ayant demandé à sortir du champ de diffusion INSEE $this->SCORECONF-=5; $this->PPNONDIFF=true; } else { $this->PPNONDIFF=false; } /** Entreprise en Zone Prioritaire ? **/ $this->ZONEPRI=false; $this->ZONEPRIZUS=$this->ZONEPRIAFR=$this->ZONEPRICUCS=$this->ZONEPRIZFU=$this->ZONEPRIZRR=$this->ZONEPRIZRU=''; if ($tabIdentite['GeoInfos']['ZUS']=='OUI') $this->ZONEPRIZUS=$tabIdentite['GeoInfos']['NZUS']; if ($tabIdentite['GeoInfos']['AFR']=='OUI') $this->ZONEPRIAFR=$tabIdentite['GeoInfos']['NAFR']; if ($tabIdentite['GeoInfos']['CUCS']=='OUI')$this->ZONEPRICUCS=$tabIdentite['GeoInfos']['NCUCS']; if ($tabIdentite['GeoInfos']['ZFU']=='OUI') $this->ZONEPRIZFU=$tabIdentite['GeoInfos']['NZFU']; if ($tabIdentite['GeoInfos']['ZRR']=='OUI') $this->ZONEPRIZRR=$tabIdentite['GeoInfos']['NZRR']; if ($tabIdentite['GeoInfos']['ZRU']=='OUI') $this->ZONEPRIZRU=$tabIdentite['GeoInfos']['NZRU']; if ($this->ZONEPRIZUS || $this->ZONEPRIAFR || $this->ZONEPRICUCS || $this->ZONEPRIZFU || $this->ZONEPRIZRR || $this->ZONEPRIZRU) { // Entreprise en Zone Prioritaire $this->SCORECONF-=10; $zonesPri=array(); foreach ($tabIdentite['GeoInfos'] as $zone=>$valeur) if ($valeur=='OUI') $zonesPri[]=$zone; $this->ZONEPRI=implode(', ', $zonesPri); } /** Domiciliation d'entreprise **/ $this->ADRDOM=@$tabIdentite['AdresseDom']; if ($tabIdentite['AdresseDom']==2) $this->SCORECONF-=50; elseif ($tabIdentite['AdresseDom']==1) $this->SCORECONF-=35; // Nombre d'entrep à l'adresse de domiciliation $this->DOM_NB=@$tabIdentite['AdresseDomNb']; // Nom du domiciliuataire avéré ou suspecté $this->DOM_NOM=@$tabIdentite['AdresseDomEnt'][0]['nom']; // SIREN du domiciliataire avéré ou suspecté $this->DOM_SIREN=@$tabIdentite['AdresseDomEnt'][0]['siren']; /** Calcul du score Dirigeance **/ $this->SCOREDIRI=100; $this->ANNONCEINTERDIT=0; $dirs = $iInsee->getDirigeants($siren, false); $timer['getDirigeants'] = microtime(true); //Metier_Util_Log::write('I', 'SCOREDIR = '. print_r($dirs,1), __LINE__, __FILE__, __FUNCTION__, __CLASS__); $this->DIR_NB=$this->NBDIRLIENS=$this->NBDIRSCI=$this->NBDIRSCIADR=0; if (count($dirs) > 0 ) { foreach ($dirs as $nb => $dir) { if ($dir['Ancien']==0 && preg_match('/G.rant|Personne|Pr.sident|Directeur|Repr.sentant/Uisu', $dir['Titre'])) { $this->DIR_NB++; if ($this->DIR_NB==1) { $this->DIR1_NOM=preg_replace('/ +/',' ',$dir['Civilite'].' '.$dir['Nom'].' '.$dir['Prenom']); $this->DIR1_AGE=floor(Metier_Util_Date::nbMoisEntre(Metier_Util_Date::dateT('d/m/Y','Ymd',$dir['NaissDate']))/12); $this->DIR1_FONC=$dir['Titre']; $this->DIR1_TYPE='PP'; } elseif ($this->DIR_NB==2) { $this->DIR2_NOM=preg_replace('/ +/',' ',$dir['Civilite'].' '.$dir['Nom'].' '.$dir['Prenom']); $this->DIR2_AGE=floor(Metier_Util_Date::nbMoisEntre(Metier_Util_Date::dateT('d/m/Y','Ymd',$dir['NaissDate']))/12); $this->DIR2_FONC=$dir['Titre']; $this->DIR2_TYPE='PP'; } $activeRechercheDir = true; if ($activeRechercheDir){ $tabDir = $iInsee->rechercheDir($dir['Nom'], $dir['Prenom'], '', $dir['NaissDate'], '', 0, 200, 200); $tabDir = $tabDir['reponses']; $nbFctDir=$nbFctDirSci=$nbFctDirSciAdr=0; if (count($tabDir)>0){ foreach($tabDir as $iDir=>$tabDiri) { if ($tabDiri['Actif']==1 && $tabDiri['Siege']==1) { $nbFctDir++; if ($tabDiri['FJ']==6540) { $nbFctDirSci++; if ($tabDiri['FJ']==6540) { /* [Adresse] => 0001 RUE DU CHAMP FLEURI [Adresse2] => [CP] => 49770 [Ville] => LA MEIGNANNE */ $nbFctDirSciAdr++; } } } } } } // Nombre d'entreprises maximum dirigé par un des dirigeants if ($nbFctDir>$this->NBDIRLIENS) $this->NBDIRLIENS=$nbFctDir; // Nombre de SCI maximum dirigé par un des dirigeants (inclus dans NBDIRLIENS) if ($nbFctDirSci>$this->NBDIRSCI) $this->NBDIRSCI=$nbFctDirSci; // Nombre de SCI maximum dirigé par un des dirigeants à l'adresse (inclus dans les autres NBDIR...) if ($nbFctDirSciAdr>$this->NBDIRSCIADR) $this->NBDIRSCIADR=$nbFctDirSciAdr; } switch ($dir['Cinf']) { case 11: case 12: // Interdiction de gérer ou FP en cours if ($dir['Ancien']==0) { $noteSolvabilite=5; $this->SCORECONF=0; $this->SCOREDIRI=0; } elseif ($dir['Ancien']==1) { if ($this->SCORECONF>50) $this->SCORECONF=50; $this->SCOREDIRI=30; if ($noteSolvabilite>35) $noteSolvabilite=35; } $this->ANNONCEINTERDIT++; $this->ANNONCEINTERDITDATE=Metier_Util_Date::dateT('d/m/Y','Y-m-d', $dir['DateFct']); break(2); case 15: case 16: // Procédure collective dans l'historique du dirigeant if ($dir['Ancien']==0 && preg_match('/G.rant|Personne|Pr.sident|Directeur|Repr.sentant/Uisu', $dir['Titre'])) { $this->SCORECONF-=20; $this->SCOREDIRI-=60; if ($noteSolvabilite>45) $noteSolvabilite=45; } elseif ($dir['Ancien']==1 && preg_match('/G.rant|Personne|Pr.sident|Directeur|Repr.sentant/Uisu', $dir['Titre'])) { $this->SCORECONF-=10; $this->SCOREDIRI-=30; if ($noteSolvabilite>55) $noteSolvabilite=55; } else { $this->SCOREDIRI-=20; if ($noteSolvabilite>60) $noteSolvabilite=60; } break(2); case 19: if ($dir['Ancien']==0 && preg_match('/G.rant|Personne|Pr.sident|Directeur|Repr.sentant/Uisu', $dir['Titre'])) { $this->SCOREDIRI-=50; if ($noteSolvabilite>40) $noteSolvabilite=40; } elseif ($dir['Ancien']==1 && preg_match('/G.rant|Personne|Pr.sident|Directeur|Repr.sentant/Uisu', $dir['Titre'])) { $this->SCOREDIRI-=20; if ($noteSolvabilite>52) $noteSolvabilite=52; } else { $this->SCOREDIRI-=10; if ($noteSolvabilite>65) $noteSolvabilite=65; } break(2); default: break; } } } $timer['traitementDirigeants'] = microtime(true); /** Affichage des informations de paiement dans le score **/ $this->COTEOK_MMAA=$this->IMPAYE_MMAA=$this->PRIVILEGES_MMAA=$this->RISQUEGROUPE_MMAA=''; $this->DEFAUT_MMAA=$this->LCASSUR_MMAA=$this->RISQUEIMPAYE_MMAA=$this->CSFACTO_MMAA=''; $this->COTEOK=$this->IMPAYE=$this->PRIVILEGES=$this->RISQUEGROUPE=$this->DEFAUT=$this->LCASSUR=$this->RISQUEIMPAYE=$this->CSFACTO=false; $this->MODIFPAIDATE=0; $iFacto = new Metier_Partenaires_MFacto($this->db); $infoFacto = $iFacto->getCoteSpeciale($siren); $timer['factoCS']=microtime(true); $libProfilPayeur=trim($iFacto->getProfilPayeur($siren)); $profilPayeur=$iFacto->profilPayeur; $timer['factoProfil']=microtime(true); $this->DELAIPAY=$iFacto->DELAIPAY; $this->DELAIPAYp=$iFacto->DELAIPAYp; $this->DELAIPAY_MMAA=$iFacto->DELAIPAY_MMAA; if (isset($infoFacto[0])) { $nivRisquePaiement=$infoFacto[0]['risque']; $this->MODIFPAIDATE=$infoFacto[0]['DateEven']; switch ($infoFacto[0]['CodeRisque']) { case 'OK': $this->COTEOK=true; $this->COTEOK_MMAA=$this->CSFACTO_MMAA=Metier_Util_Date::dateT('Y-m-d', 'Ym', $infoFacto[0]['DateEven']); if ($noteSolvabilite>=40 && $noteSolvabilite<=45) $noteSolvabilite+=5; $this->CSFACTO=0; break; case 'IP': $this->IMPAYE=true; $this->IMPAYE_MMAA=$this->CSFACTO_MMAA=Metier_Util_Date::dateT('Y-m-d', 'Ym', $infoFacto[0]['DateEven']); $this->CSFACTO='I'; $profilPayeur=5; break; case 'PR': $this->PRIVILEGES=true; $this->PRIVILEGES_MMAA=$this->CSFACTO_MMAA=Metier_Util_Date::dateT('Y-m-d', 'Ym', $infoFacto[0]['DateEven']); $this->CSFACTO='P'; $profilPayeur=5; break; case 'RG': $this->RISQUEGROUPE=true; $this->RISQUEGROUPE_MMAA=$this->CSFACTO_MMAA=Metier_Util_Date::dateT('Y-m-d', 'Ym', $infoFacto[0]['DateEven']); $this->CSFACTO=24; $this->SCOREDIRI-=10; break; case 'DEF': $this->DEFAUT=true; $this->DEFAUT_MMAA=$this->CSFACTO_MMAA=Metier_Util_Date::dateT('Y-m-d', 'Ym', $infoFacto[0]['DateEven']); $this->CSFACTO='D'; break; case 'LC': $this->LCASSUR=true; $this->LCASSUR_MMAA=$this->CSFACTO_MMAA=Metier_Util_Date::dateT('Y-m-d', 'Ym', $infoFacto[0]['DateEven']); $this->CSFACTO='T'; break; case 'KO': $noteSolvabilite=$this->SCORECONF=$this->SCOREDIRI=0; $this->CSFACTO=50; $this->CSFACTO_MMAA=Metier_Util_Date::dateT('Y-m-d', 'Ym', $infoFacto[0]['DateEven']); break; default: if ($iFacto->risqueImpaye) { $this->RISQUEIMPAYE_MMAA=$iFacto->risqueImpayeMois; $this->RISQUEIMPAYE=true; } else { $this->CSFACTO=$infoFacto[0]['CoteCS']*1; $this->CSFACTO_MMAA=Metier_Util_Date::dateT('Y-m-d', 'Ym', $infoFacto[0]['DateEven']); } break; } $this->CSFACTOFIN_MMAA=Metier_Util_Date::dateT('Y-m-d', 'Ym', $infoFacto[0]['DateFin']); if ($infoFacto[0]['CoteCS']*1>0) $libInfoPaiement='Courant '.Metier_Util_Date::dateT('Y-m-d', 'M Y', $infoFacto[0]['DateEven']).' : '.$infoFacto[0]['LibCS']; else { $libInfoPaiement=trim('Depuis '.Metier_Util_Date::dateT('Y-m-d', 'M Y', $infoFacto[0]['DateEven']).' : '.$infoFacto[0]['LibCS'].' '.$libProfilPayeur); $encoursCS=7500; } } else { $nivRisquePaiement=0; if ($libProfilPayeur<>'') { $libInfoPaiement=$libProfilPayeur; } else { $libInfoPaiement='Aucun retard de paiement significatif n\'a été porté à notre connaissance par l\'ensemble de nos partenaires.'; } if ($iFacto->risqueImpaye) { $this->RISQUEIMPAYE_MMAA=Metier_Util_Date::dateT('Y-m', 'Ym', $iFacto->risqueImpayeDate); if ((''.$iFacto->risqueImpayeDate.'-01')>$this->MODIFPAIDATE) $this->MODIFPAIDATE=''.$iFacto->risqueImpayeDate.'-01'; } } $timer['factoImpaye']=microtime(true); // Tableaux des Paiements $tabPaiements=$iFacto->getTabPaiements($siren); $timer['factoPaiements']=microtime(true); // Présence de Privilèges $this->PRIVILEGESECU=$this->PRIVILEGESECU_MT=$this->PRIVILEGETRES=$this->PRIVILEGETRES_MT=0; $iPriv = new Metier_Partenaires_MPrivileges($this->db); $tabPriv = $iPriv->getPrivilegesCumul($siren); $noteSolvMax=100; if (isset($tabPriv['03']['nb'])) { $this->PRIVILEGES=true; $this->PRIVILEGESECU=$tabPriv['03']['nb']; $this->PRIVILEGESECU_MT=$tabPriv['03']['insCumul']; $this->PRIVILEGES_MMAA=Metier_Util_Date::dateT('Y-m-d', 'Ym', $tabPriv['03']['dateFraiche']); if ($tabPriv['03']['dateFraiche']>$this->MODIFPAIDATE) $this->MODIFPAIDATE=$tabPriv['03']['dateFraiche']; if ($infoFacto[0]['CoteCS']*1==0) $libInfoPaiement=trim('Depuis le '.Metier_Util_Date::dateT('Y-m-d', 'd/m/Y', $tabPriv['03']['dateFraiche'])." : $this->PRIVILEGESECU inscription(s) URSSAF pour un montant de ".number_format($this->PRIVILEGESECU_MT,2,',',' ')." euros. $libProfilPayeur"); if ($this->PRIVILEGESECU==1 && $this->PRIVILEGESECU_MT<15000) { if (($this->NBBILAN==0||$this->BILANVIEUX||$this->BILANMANQUE) && $this->CAPITAL<750000) $noteSolvMax=42; elseif (($this->NBBILAN==0||$this->BILANVIEUX||$this->BILANMANQUE) && $this->CAPITAL>=750000) $noteSolvMax=45; else $noteSolvMax=49; } elseif ($this->PRIVILEGESECU>0) { if (($this->NBBILAN==0||$this->BILANVIEUX||$this->BILANMANQUE) && $this->CAPITAL<750000) $noteSolvMax=37; elseif (($this->NBBILAN==0||$this->BILANVIEUX||$this->BILANMANQUE) && $this->CAPITAL>=750000) $noteSolvMax=38; else $noteSolvMax=39; } //if ($noteSolvabilite>$noteSolvMax) $noteSolvabilite=$noteSolvMax; } if (isset($tabPriv['04']['nb'])) { $this->PRIVILEGES=true; $this->PRIVILEGETRES=$tabPriv['04']['nb']; $this->PRIVILEGETRES_MT=$tabPriv['04']['insCumul']; $this->PRIVILEGES_MMAA=Metier_Util_Date::dateT('Y-m-d', 'Ym', $tabPriv['04']['dateFraiche']); if ($tabPriv['04']['dateFraiche']>$this->MODIFPAIDATE) $this->MODIFPAIDATE=$tabPriv['04']['dateFraiche']; if ($infoFacto[0]['CoteCS']*1==0) if ($this->PRIVILEGESECU<1) $libInfoPaiement=trim('Depuis le '.Metier_Util_Date::dateT('Y-m-d', 'd/m/Y', $tabPriv['04']['dateFraiche'])." : $this->PRIVILEGETRES inscription(s) TRESOR pour un montant de ".number_format($this->PRIVILEGETRES_MT,2,',',' ')." euros. $libProfilPayeur"); else $libInfoPaiement.='
'.trim('Depuis le '.Metier_Util_Date::dateT('Y-m-d', 'd/m/Y', $tabPriv['04']['dateFraiche'])." : $this->PRIVILEGETRES inscription(s) TRESOR pour un montant de ".number_format($this->PRIVILEGETRES_MT,2,',',' ')." euros. $libProfilPayeur"); if ($this->PRIVILEGETRES==1 && $this->PRIVILEGETRES_MT<15000) { if ($this->PRIVILEGESECU>0) $seuil=45; else $seuil=55; if (($this->NBBILAN==0||$this->BILANVIEUX||$this->BILANMANQUE) && $this->CAPITAL<750000) $noteSolvMax=$seuil-10; elseif (($this->NBBILAN==0||$this->BILANVIEUX||$this->BILANMANQUE) && $this->CAPITAL>=750000) $noteSolvMax=$seuil-5; else $noteSolvMax=$seuil; } elseif ($this->PRIVILEGETRES>0) { if ($this->PRIVILEGESECU>0) $seuil=46; else $seuil=56; if (($this->NBBILAN==0||$this->BILANVIEUX||$this->BILANMANQUE) && $this->CAPITAL<750000) $noteSolvMax=$seuil-11; elseif (($this->NBBILAN==0||$this->BILANVIEUX||$this->BILANMANQUE) && $this->CAPITAL>=750000) $noteSolvMax=$seuil-6; else $noteSolvMax=$seuil; } } if ($this->PRIVILEGES) { $this->SCORECONF-=20; if ($noteSolvMax==100) { if (($this->NBBILAN==0||$this->BILANVIEUX||$this->BILANMANQUE) && $this->CAPITAL<750000) $noteSolvMax=40; elseif (($this->NBBILAN==0||$this->BILANVIEUX||$this->BILANMANQUE) && $this->CAPITAL>=750000) $noteSolvMax=46; else $noteSolvMax=50; } } if ($this->IMPAYE) { $this->SCORECONF-=10; if ($this->PRIVILEGES) $noteSolvMax-=10; elseif ($this->SOCIETE_COTE) $noteSolvMax=61; elseif ($this->NBBILAN==0 && $this->FJURPUB && $this->CAPITAL<750000) $noteSolvMax=40; elseif ($this->NBBILAN==0 && !$this->FJURPUB && $this->CAPITAL<750000) $noteSolvMax=42; elseif ($this->NBBILAN==0 && $this->FJURPUB && $this->CAPITAL<1500000) $noteSolvMax=45; elseif ($this->NBBILAN==0 && !$this->FJURPUB && $this->CAPITAL<1500000) $noteSolvMax=47; elseif ($this->NBBILAN==0 && $this->FJURPUB ) $noteSolvMax=50; elseif ($this->NBBILAN==0 && !$this->FJURPUB) $noteSolvMax=51; elseif ($this->NBBILAN>0 && $this->FJURPUB && ($this->BILANVIEUX||$this->BILANMANQUE) && $this->CAPITAL<750000) $noteSolvMax=45; elseif ($this->NBBILAN>0 && $this->FJURPUB && ($this->BILANVIEUX||$this->BILANMANQUE) && $this->CAPITAL<1500000) $noteSolvMax=50; elseif ($this->NBBILAN>0 && $this->FJURPUB && ($this->BILANVIEUX||$this->BILANMANQUE)) $noteSolvMax=52; elseif ($this->CAPITAL<750000) $noteSolvMax=47; elseif ($this->CAPITAL<1500000) $noteSolvMax=50; else $noteSolvMax=52; } if ($this->ANNONCEHOM>0) { //$this->SCORECONF+=10; if ($this->PRIVILEGES || $this->IMPAYE || $this->DEFAUT) $noteSolvMax=46; elseif ($this->CAPITAL<750000) $noteSolvMax=48; elseif ($this->CAPITAL<1500000) $noteSolvMax=53; else $noteSolvMax=56; } if ($this->DEFAUT) { if (($this->NBBILAN==0 || $this->BILANVIEUX) && $this->CAPITAL<750000) $noteSolvMax=41; elseif (($this->NBBILAN==0 || $this->BILANVIEUX) && $this->CAPITAL<1500000)$noteSolvMax=48; elseif (($this->NBBILAN==0 || $this->BILANVIEUX)) $noteSolvMax=51; else $noteSolvMax=54; } if ($this->RISQUEGROUPE) { if ($this->RJMERE) $noteSolvMax=39; elseif ($this->RJFILLE)$noteSolvMax=49; else $noteSolvMax=56; } if ($tabIdentite['SituationJuridique']=='PL') { $this->SCOREDIRI-=20; $this->SCORECONF+=10; if (($this->NBBILAN==0 || $this->BILANVIEUX) && $this->CAPITAL<750000) $noteSolvMax=39; elseif (($this->NBBILAN==0 || $this->BILANVIEUX) && $this->CAPITAL<1500000) $noteSolvMax=41; elseif (($this->NBBILAN==0 || $this->BILANVIEUX)) $noteSolvMax=48; else $noteSolvMax=51; } if ($noteSolvabilite>$noteSolvMax) $noteSolvabilite=$noteSolvMax; $timer['privileges']=microtime(true); // Paiements $this->MODIFDERDATE = $this->MODIFINSEEDATE; if ($this->MODIFPAIDATE > $this->MODIFDERDATE) { $this->MODIFDERDATE = $this->MODIFPAIDATE; } // Rcs if ($this->MODIFRNCSDATE > $this->MODIFDERDATE) { $this->MODIFDERDATE = $this->MODIFRNCSDATE; } // Annonces if ($this->ANNONCEDERDATE > $this->MODIFDERDATE) { $this->MODIFDERDATE = $this->ANNONCEDERDATE; } // --- Cut Off $this->ENQUETE=''; if ($this->companyEvenDateStop === null) { $tabTmp = $this->db->select('jo.scores_cutoff', 'encours, scoreSolv, scoreDir, scoreConf, paiement, DATE(dateInsert)*1 AS dateInsert, DATE(dateUpdate)*1 AS dateUpdate', "siren=$siren", $this->debug, MYSQL_ASSOC); $timer['scores_cutoff'] = microtime(true); if (count($tabTmp) > 0) { if($tabTmp[0]['dateUpdate'] > $tabTmp[0]['dateInsert']) { $dateMaj = $tabTmp[0]['dateUpdate']; } else { $dateMaj = $tabTmp[0]['dateInsert']; } // Si pas plus vieux que 6 mois if (Metier_Util_Date::nbMoisEntre($dateMaj, date('Ymd')) <= $this->ENQUETELIM) { $tabLibCS = $iFacto->getLibInfoCS($tabTmp[0]['paiement']); $libInfoPaiement = $tabLibCS['LibCS']; $encoursForce=$tabTmp[0]['encours']; if ($tabTmp[0]['scoreConf'] !== null) { $this->SCORECONF = $tabTmp[0]['scoreConf']; } if ($this->SCORECONF > $this->ENQUETEMAXI) { $this->SCORECONF = $this->ENQUETEMAXI; } if ($tabTmp[0]['scoreDir'] !== null) { $this->SCOREDIRI = $tabTmp[0]['scoreDir']; } if ($this->SCOREDIRI > $this->ENQUETEMAXI) { $this->SCOREDIRI = $this->ENQUETEMAXI; } if ($tabTmp[0]['scoreSolv'] !== null) { $this->ENQUETE = $noteSolvabilite = $tabTmp[0]['scoreSolv']; } if ($this->ENQUETE > $this->ENQUETEMAXI) { $this->ENQUETE = $this->ENQUETEMAXI; } // Permet de supprimer la prise en compte de la procol if ($this->ENQUETE > 0) { $tabIdentite['SituationJuridique'] = $this->ANNONCEPC = ''; $this->ANNONCELJ = $this->ANNONCERJ = $this->ANNONCESV = $this->PLANMODIF = $this->PLAN = $this->ANNONCEPC_OBS = $this->ELIMINE = false; } } } } // --- Commentaire Dirigeance if ($this->SCOREDIRI >= 70) { $analyseDir = "L'étude de la dirigeance ne relève aucun problème."; } elseif ($this->SCOREDIRI >= 40) { $analyseDir = "L'étude de la dirigeance retient notre attention."; } elseif ($this->SCOREDIRI > 0) { $analyseDir = "L'étude de la dirigeance attire toute notre attention."; } else { $analyseDir = "L'étude de la dirigeance révèle des anomalies."; $this->SCOREDIRI = 0; } // --- Commentaire Conformité if ($tabIdentite['SituationJuridique'] == 'P') { $noteSolvabilite = $this->SCORECONF = $this->SCOREDIRI = 0; $analyseConf = "L'entreprise est en procédure collective"; } elseif ($tabIdentite['SituationJuridique'] == 'CL') { $noteSolvabilite = $this->SCORECONF = $this->SCOREDIRI = 0; $analyseConf = "Cloture après la procédure"; } elseif ($tabIdentite['SituationJuridique'] == 'D') { $noteSolvabilite = $this->SCORECONF = $this->SCOREDIRI = 0; $analyseConf = "L'entreprise est dissoute"; } elseif ($tabIdentite['SituationJuridique'] == 'A') { $noteSolvabilite = $this->SCORECONF = $this->SCOREDIRI = 0; $analyseConf = "L'entreprise est absorbée"; } elseif ($tabIdentite['SituationJuridique'] == 'RR' && $this->FJUR1 != 1) { $noteSolvabilite = $this->SCORECONF = $this->SCOREDIRI = 0; $analyseConf = "L'entreprise est radiée"; } elseif ($tabIdentite['Actif'] == 0) { $noteSolvabilite = $this->SCORECONF = $this->SCOREDIRI = 0; $analyseConf = "L'entreprise n'est pas en activité"; } elseif ($this->SCORECONF >= 70) { $analyseConf = "L'analyse de la conformité est correcte."; } elseif ($this->SCORECONF >= 40) { $analyseConf = "L'analyse de la conformité est acceptable."; } elseif ($this->SCORECONF > 0) { $analyseConf = "L'analyse de la conformité est sensible."; } else { $analyseConf = "L'analyse de la conformité est très sensible."; $this->SCORECONF = 0; } // --- Commentaire Solvabilité if ($noteFin > 0) { $noteSolv = ($noteStructure+$noteFin)/2; } else { $noteSolv = ($noteStructure+$noteFin)/5; } if ($noteSolv >= 15) { $analyseSolv = 'Excellente'; } elseif ($noteSolv >= 12) { $analyseSolv = 'Bonne'; } elseif ($noteSolv >= 10) { $analyseSolv = 'Correcte'; } elseif ($noteSolv >= 8) { $analyseSolv = 'Moyenne'; } elseif ($noteSolv >= 6) { $analyseSolv = 'Délicate'; } else { $analyseSolv = 'Inquiétante'; } if ($noteSolvabilite >= 40 && $analyseSolv == 'Inquiétante') { $analyseSolv = 'Correcte'; } // --- CA Moyen par salarié pour un secteur donné $this->CAESTIME = $iInsee->getCAnafEffectif($naf, $this->EFFECTIF); if ($this->CABILAN > 0) { $this->CABIOUES = $this->CABILAN; } else { $this->CABIOUES = $this->CAESTIME; } // L'encours de départ est à 10% du capital $encoursIni = $tabIdentite['Capital']/10; // Ou à l'encours ini CS car pas d'informations négatives if ($encoursCS>$encoursIni) $encoursIni=$encoursCS; $this->ENCOURS = $encoursIni; $encoursEstime = 0; $timer['camoyen']=microtime(true); // L'encours de trésorerie prend 1/6è de 1/12è de la Trésorerie if ($this->R[63] > 0) { $encoursTR = $this->R[63]/72; } if ($noteSolvabilite>=40) { if ($this->HOLDING) { // Cas des Holding $this->ENCOURS = $tabIdentite['Capital'] / 12; if (@$tabBil[0]['FondsPr']>0) { $encoursFP = $tabBil[0]['FondsPr'] / 72 ; if ($encoursFP > $this->ENCOURS) { $this->ENCOURS=$encoursFP; } } elseif ($encoursTR > $this->ENCOURS) { $this->ENCOURS=$encoursTR; } } elseif (isset($tabBil[0])) { // SI BILAN : L'encours théorique de base est plafonnée au CA/36 if ($tabBil[0]['CA']>0) $this->ENCOURS=(($tabBil[0]['CA'])/36); if ($encoursCS>$this->ENCOURS) $this->ENCOURS=$encoursCS; //Plafond à 25% des fonds propres ou à 1000 ? si FP<0 if ($tabBil[0]['FondsPr']>0) $plafond=$tabBil[0]['FondsPr']/4; elseif ($this->R[63]>0) $plafond=$this->R[63]/12; if ($this->ENCOURS>$plafond) $this->ENCOURS=$plafond; } else { // Détermination de l'encours sans bilans : Encours estimé = CA Estimé / 72 if ($this->CAESTIME>0) $encoursEstime=$this->CAESTIME/36; } // Plafond des encours en fonction de la note / 100 if ($noteSolvabilite > 65) $plafond=500000; elseif ($noteSolvabilite > 60) $plafond=350000; elseif ($noteSolvabilite > 55) $plafond=250000; elseif ($noteSolvabilite >= 50) $plafond=150000; elseif ($noteSolvabilite >= 45) $plafond=30000; else $plafond=15000; if ($this->ENCOURS>$plafond) $this->ENCOURS=$plafond; // Plafond si encours estimé if ($noteSolvabilite<50) $plafondEstime=$plafond/10; else $plafondEstime=$plafond/25; if ($encoursEstime>$plafondEstime) $encoursEstime=$plafondEstime; // Metier_Util_Log::write('I', "INDISCORE B $encoursIni $encoursEstime $encours", __LINE__, __FILE__, __FUNCTION__, __CLASS__); // Si l'entreprise à moins de 12 mois, on divise son encours estimé par 2 if ($encoursEstime>0) { $dateCre=$tabIdentite['DateCreaEn']*1; if ($dateCre==0 || ( ($tabIdentite['DateCreaEt']*1)>0 && $dateCre>$tabIdentite['DateCreaEt']*1) ) { $dateCre=$tabIdentite['DateCreaEt']*1; } if ($dateCre+10000>date('Ymd')*1) { $encoursEstime=$encoursEstime/2; $libEncours='Encours limité étant donné la jeunesse de la structure.'; } } // Si encours sans bilan, l'encours donné est la moyenne de l'encours capital + l'encours estimé if ($encoursEstime > 0 && $this->ENCOURS > 0) { $this->ENCOURS = ($this->ENCOURS + $encoursEstime) / 2; } // Si l'encours est forcé, on en tiens compte ! if ($encoursForce != null) { $this->ENCOURS = $encoursForce; } switch ($this->FJUR2) { case 11: case 12: case 13: case 14: case 15: case 16: case 19: if ($this->ENCOURS == 0 && $this->ENCOURS <= 2000 && !$this->IMPAYE && !$this->PRIVILEGES && !$this->RISQUEGROUPE && !$this->DEFAUT && !$this->LCASSUR && $this->CSFACTO != 50 && !$this->RISQUEIMPAYE) { $this->ENCOURS = $this->CAESTIME/36; if ($noteSolvabilite >= 50 && $this->AGE >= 120) { $plafond = 7000; } elseif ($noteSolvabilite >= 45 && $this->AGE >= 60) { $plafond = 5000; } elseif ($noteSolvabilite >= 45 && $this->AGE >= 36) { $plafond = 3000; } elseif ($noteSolvabilite >= 55) { $plafond = 2000; } if ($this->DELAIPAY > $this->DELAIPAYp && $this->DELAIPAYp > 0 && $this->DELAIPAY <= 90) { $plafond = $plafond/2; } /*elseif ($this->DELAIPAY > 90) { $plafond = 0; }*/ if ($this->ENCOURS > $plafond) { $this->ENCOURS = $plafond; } } break; case 18: // Associé Gérant de société case 27: // Paroisse hors zone concordataire case 29: // Autre groupement de droit privé non doté de la personnalité morale //case 31: // Personne morale de droit étranger, immatriculée au RCS //case 32: // Personne morale de droit étranger, non immatriculée au RCS $this->ENCOURS='N/A'; $libEncours='Il est préférable de demander un enquête commerciale sur cette entité.'; break; case 81: // Organisme gérant un régime de protection sociale à adhésion obligatoire case 82: // Organisme mutualiste case 83: // Comité d'entreprise case 84: // Organisme professionnel case 91: // Syndicat de propriétaires case 92: // Association loi 1901 ou assimilé case 93: // Fondation case 99: // Fondation $tabTmp=$this->db->select('jo.asso_bilans', 'dateCloture, dateCloture*1 as dateClotureNum', "siren=$siren ORDER BY dateCloture DESC LIMIT 0,5", $this->debug, MYSQL_ASSOC); $this->NBBILAN=count($tabTmp); $this->BILANDATE=$tabTmp[0]['dateClotureNum']; if ($this->BILANDATE>0 && $tabIdentite['SituationJuridique']=='' && $tabIdentite['Actif']==1) { $this->BILAN=true; if (Metier_Util_Date::nbMoisEntre($this->BILANDATE,date('Ymd'))>=24) $this->BILANVIEUX=true; else $this->BILANVIEUX=false; if (Metier_Util_Date::nbMoisEntre($this->BILANDATE,date('Ymd'))>=30) $this->BILANMANQUE=true; else $this->BILANMANQUE=false; $this->ENCOURS=$this->CAESTIME/72; if ($noteSolvabilite>=40 && $this->ENCOURS<5000) $this->ENCOURS=5000; if ($noteSolvabilite> 65) $plafond=200000; elseif ($noteSolvabilite> 60) $plafond=150000; elseif ($noteSolvabilite> 55) $plafond=100000; elseif ($noteSolvabilite>=50) $plafond=50000; elseif ($noteSolvabilite>=45) $plafond=10000; else $plafond=5000; if ($this->ENCOURS>$plafond) $this->ENCOURS=$plafond; $libEncours='Il est préférable de demander un enquête commerciale sur les organisations, associations et fondations.'; } else { $this->ENCOURSCALC=$this->ENCOURS; $this->ENCOURS='N/A'; $libEncours='Il est préférable de demander un enquête commerciale sur les organisations, associations et fondations.'; } break; case 99: // Autre personne morale de droit privé case 41: // Établissement public ou régie à caractère industriel ou commercial case 71: // Administration de l'état case 72: // Collectivité territoriale case 73: // Établissement public administratif case 74: // Autre personne morale de droit public administratif $this->ENCOURSCALC=$this->ENCOURS; $this->ENCOURS='N/A'; $libEncours='Aucun risque de défaillance sur les administrations ou institutions.'; break; } } // Encours à 0 car score < 40 else { $this->ENCOURSCALC=$this->ENCOURS; $this->ENCOURS=0; $libEncours='Aucun encours conseillé par rapport à notre évaluation.'; } /** Pondération de l'encours en fonction des informations de paiement GE **/ if ($this->ENCOURS<>'N/A' && $this->ENCOURS*1>0 && $nivRisquePaiement>0) { $plafond=7500; switch ($nivRisquePaiement) { case 4: // Défaut avéré $this->ENCOURS=0; break; case 3: // Impayés if ($noteSolvabilite>=50 && $caEntrep>=3000000) $plafond=30000; elseif ($noteSolvabilite>=50 && $caEntrep< 3000000) $plafond=20000; elseif ($noteSolvabilite<50 && $caEntrep>=3000000) $plafond=10000; else $plafond=7500; break; case 2: // Risque d'impayés if ($noteSolvabilite>=50 && $caEntrep>=3000000) $plafond=65000; elseif ($noteSolvabilite>=50 && $caEntrep< 3000000) $plafond=45000; elseif ($noteSolvabilite<50 && $caEntrep>=3000000) $plafond=25000; else $plafond=15000; break; case 1: // Fin d'activité $this->ENCOURS=0; break; default: break; } if ($this->ENCOURS>$plafond) $this->ENCOURS=$plafond; } if ($tendance=='') $tendance='Stable'; /** Avis à 3 ans **/ if ($noteSolvabilite>=50) { if ($valeurCCF>2160) $this->AVIS3ANS=true; elseif($valeurCCF>0 && $valeurCCF<2160) $this->AVIS3ANS=false; } /** Etalonage pour l'indiscore sur 20 **/ if ($noteSolvabilite<5) $indiscore20=0; elseif ($noteSolvabilite<20) $indiscore20=1; elseif ($noteSolvabilite<30) $indiscore20=2; elseif ($noteSolvabilite<35) $indiscore20=3; elseif ($noteSolvabilite<36) $indiscore20=4; elseif ($noteSolvabilite<39) $indiscore20=5; elseif ($noteSolvabilite<41) $indiscore20=6; elseif ($noteSolvabilite<45) $indiscore20=7; elseif ($noteSolvabilite<46) $indiscore20=8; elseif ($noteSolvabilite<50) $indiscore20=9; elseif ($noteSolvabilite<51) $indiscore20=10; elseif ($noteSolvabilite<55) $indiscore20=11; elseif ($noteSolvabilite<57) $indiscore20=12; elseif ($noteSolvabilite<60) $indiscore20=13; elseif ($noteSolvabilite<62) $indiscore20=14; elseif ($noteSolvabilite<65) $indiscore20=15; elseif ($noteSolvabilite<69) $indiscore20=16; elseif ($noteSolvabilite<73) $indiscore20=17; elseif ($noteSolvabilite<80) $indiscore20=18; else $indiscore20=19; /** Classe de risque **/ if ($indiscore20>=15) $classeRisque=5; elseif ($indiscore20>=12) $classeRisque=4; elseif ($indiscore20>=10) $classeRisque=3; elseif ($indiscore20>=8) $classeRisque=2; else $classeRisque=1; if ( ($this->ACTIFRNCS*1==0 && $this->ACTIFINSEE*1==0) || $tabIdentite['SituationJuridique'] == 'P' || $tabIdentite['SituationJuridique'] == 'PL') $classeRisque=9; elseif ($this->ENCOURS==='N/A') $classeRisque=8; /** Fin note **/ $this->NOTE100=$noteSolvabilite; // Note finale sur 100 $this->NOTESBRUTE=$this->NOTE100; // Note du score sur 100 originale (de type bancaire) $this->NOTESCORE=$noteFin*5; // Note du score financier sur 100 $timer['encours']=microtime(true); // --- Si NIVEAU avec generation des commentaires if ($genereComment) { // --- Grand Groupe $tabTmp=$this->db->select('jo.surveillances_site', 'count(*) as nb', "login IN ('dgfipb', 'dgfipc', 'dgfipifu1', 'dgfipifu10', 'dgfipifu11', 'dgfipifu12', 'dgfipifu13', 'dgfipifu14', 'dgfipifu2', 'dgfipifu3', 'dgfipifu4', 'dgfipifu5', 'dgfipifu6', 'dgfipifu7', 'dgfipifu8', 'dgfipifu9') AND siren=$siren AND dateSuppr=0", $this->debug, MYSQL_ASSOC); $timer['GrandGroupe'] = microtime(true); $tabTmp=$tabTmp[0]; if ($tabTmp['nb']>0) $this->GRANDGROUPE = true; else $this->GRANDGROUPE = false; // NBNIC $tabTmp = $this->db->select('jo.etablissements', 'MAX(NIC) as NBNIC', "SIREN=$this->SIREN", $this->debug, MYSQL_ASSOC); $this->NBNIC = $tabTmp[0]['NBNIC']; $timer['nbNic']=microtime(true); if ($this->ANNONCEPC<>'') { // Intervenants $tabInter = $iRncs->getIntervenants($this->SIREN); $this->ANNONCEPC_INT1_TIT=$tabInter[0]['admfonction']; // Titre de l'intervenant $this->ANNONCEPC_INT1=$tabInter[0]['admnom']; // NOM Prénom et adresse complète $this->ANNONCEPC_INT2_TIT=$tabInter[1]['admfonction']; $this->ANNONCEPC_INT2=$tabInter[1]['admnom']; /* ANNONCEPC_INT2 NOM Prénom et adresse complète ANNONCEPC_INT2TIT Titre de l'intervenant n°2 'admadrNum', 'admadrInd', 'admadrVoie','admadrCP','admadrVille' */ } $timer['intervenants']=microtime(true); /** N° d'ordre de l'entreprise dans le classement des CA pour le marché de l'entreprise **/ $caTmp = round($this->CABIOUES,0); $tabTmp = $this->db->select('jo.etablissements_act', 'count(*) AS nb', "siege=1 AND ape_entrep='$naf' AND bilFL>=$caTmp", $this->debug, MYSQL_ASSOC); if (count($tabTmp) > 0) { $this->MARCHEPLACE = $tabTmp[0]['nb']*1; } $tabTmp = $this->db->select('jo.etablissements_act', 'count(*) AS nb', "siege=1 AND ape_entrep='$naf' AND bilFL>=$caTmp AND adr_dep='".$tabIdentite['Dept']."'", $this->debug, MYSQL_ASSOC); if (count($tabTmp) > 0) { $this->MARCHEPLACE_DEP = $tabTmp[0]['nb']*1; } $tabTmp = $this->db->select('jo.etablissements_act', 'count(*) AS nb', "siege=1 AND ape_entrep='$naf' AND adr_dep='".$tabIdentite['Dept']."' AND adr_com=".$tabIdentite['codeCommune'], $this->debug, MYSQL_ASSOC); if (count($tabTmp) > 0) { $this->MARCHENBENT_VILLE = $tabTmp[0]['nb']*1; } $tabTmp = $this->db->select('jo.etablissements_act', 'count(*) AS nb', "siege=1 AND ape_entrep='$naf' AND adr_dep='".$tabIdentite['Dept']."'", $this->debug, MYSQL_ASSOC); if (count($tabTmp) > 0) { $this->MARCHENBENT_DEP = $tabTmp[0]['nb']*1; } $timer['marcheEntrepPosition']=microtime(true); /** Liste des communes couvertes **/ $tabTmp = $this->db->select( 'jo.etablissements', 'siren, nic, adr_dep, adr_com', "siren=$siren AND nic>0 AND actif=1 ORDER BY siege DESC, teff_etab DESC LIMIT 0,50", $this->debug, MYSQL_ASSOC); $tabCommunes=array(); foreach ($tabTmp as $iTmp=>$tabArret) { $dep=$tabArret['adr_dep']*1; $com=$tabArret['adr_com']; if ($dep==20) { $tabCommunes[]='20'.$com; $tabCommunes[]='2A'.$com; $tabCommunes[]='2B'.$com; } elseif ($dep>96) $tabCommunes[]=''.substr($tabArret['adr_dep'],0,2).$com; elseif ($dep<10) $tabCommunes[]='0'.$dep.$com; else $tabCommunes[]=''.$dep.$com; } $strCom=implode("','", $tabCommunes); $timer['risquesCommunes']=microtime(true); /** Liste des risques Géo **/ $this->RISQUEGEO_NB=0; // Nombre d'établissements concernés: neutraliser si >= 10 $this->RISQUEGEO=array(); $tabTmp=$this->db->select('pollutions.prim_Risques','libCommune, risque', "codeInsee IN ('$strCom') ORDER BY risque", $this->debug, MYSQL_ASSOC); foreach ($tabTmp as $iTmp=>$tabArret) { $this->RISQUEGEO[]=$tabArret['risque']; // Libellé risque lié à la localisation l'un des etablissements (INNONDATION, TREMBLEMENT DE TERRE etc..) $this->RISQUEGEO_NB++; } $this->RISQUEGEO=array_unique($this->RISQUEGEO); $this->RISQUEGEO=implode(', ', $this->RISQUEGEO); $timer['risquesGeo']=microtime(true); /** Liste des arretes de cata **/ $this->RISQUEGEOARRETE_NB=0; // Nombre d'Arrété de catastrophe naturelle sur la commune de l'un des étab depuis 1982 $this->RISQUEGEOARRETE_VILLE=$this->RISQUEGEOARRETE=$this->RISQUEGEOARRETE_DATE=$this->RISQUEGEOARRETE_JODATE=$this->RISQUEGEOARRETE_EVTDATE=$this->RISQUEGEOARRETE_AA=''; $tabTmp=$this->db->select( 'pollutions.prim_Arrets', 'libCommune, risque, dateDeb, dateFin, dateArret, dateJO', "codeInsee IN ('$strCom') ORDER BY dateFin DESC", $this->debug, MYSQL_ASSOC); foreach ($tabTmp as $iTmp=>$tabArret) { $this->RISQUEGEOARRETE_NB++; if ($iTmp==0) { $this->RISQUEGEOARRETE_VILLE=$tabArret['libCommune']; $this->RISQUEGEOARRETE=$tabArret['risque']; // Plus récent Arrété de catastrophe naturelle sur la commune de l'un des étab $this->RISQUEGEOARRETE_DATE=$tabArret['dateArret']; // DATE du plus récent Arrété de catastrophe naturelle sur la commune de l'un des étab $this->RISQUEGEOARRETE_AA=substr($this->RISQUEGEOARRETE_DATE,0,4); $this->RISQUEGEOARRETE_JODATE=$tabArret['dateJO']; // Date du JO Arrété de catastrophe naturelle sur la commune de l'un des étab $this->RISQUEGEOARRETE_EVTDATE=$tabArret['dateDeb']; // Date de début de l'événement, cité dans l'Arrété de catastrophe naturelle sur la commune de l'un des étab } } $timer['risquesArret']=microtime(true); /** Liste des établissements polluants **/ $sirenDeb=$siren.'00000'; $sirenFin=$siren.'99999'; $tabTmp=$this->db->select( 'pollutions.iREP_etablissements e, pollutions.iREP_rejets_etablissements r', 'e.codecommune, e.nom, e.codesiret, e.idetab, r.idrejet, r.coderejet, r.libellerejet, r.codeouvragedepollution, r.codeentitehydro, r.nomstep, r.nommilieu', "e.codesiret BETWEEN $sirenDeb AND $sirenFin AND e.idetab=r.idetab GROUP BY e.codesiret, r.libellerejet LIMIT 0,50", $this->debug, MYSQL_ASSOC); // Nombre d'établissements concernés: neutraliser si >= 10 $this->RISQUEACT_NB=count($tabTmp); $this->RISQUEACT=array(); foreach ($tabTmp as $iTmp=>$tabArret) { $this->RISQUEACT[]=$tabArret['libellerejet']; // Libellé risque lié à la l'activité de l'un des etablissements "l'entreprise à au moins l'un de ses établissements figurant au registre francais des émissions polluantes" (AIR, EAU ou et SOL) } $this->RISQUEACT=array_unique($this->RISQUEACT); $this->RISQUEACT=implode(', ', $this->RISQUEACT); $timer['risquesPollu']=microtime(true); /** Bassin hydro : Le ou les libellés des bassins hydrographiques concernés **/ $tabTmp=$this->db->select('pollutions.bassins', 'codeBassin', "codeInsee IN ('$strCom') GROUP BY codeBassin", $this->debug, MYSQL_ASSOC); $this->RISQUEACTBASSIN=array(); $tabBassins=array( 'A' =>'Artois-Picardie', // 01 Escaut, Somme et cours d'eau côtiers de la Manche et Mer du Nord 'B1'=>'Meuse', // 02 La Meuse 'B2'=>'Sambre', // 02 La Sambre 'C'=>'Rhin', // 02 Le Rhin 'D'=>'Rhone-Méditerranée', // 06 Le Rhône et les cours d'eau côtiers méditeranéens 'E'=>'Corse', // 06 Les cours d'eau de la Corse 'F'=>'Adour-Garonne', // 05 La Garonne, l'Adour, la Dordogne, la Charente et les cours d'eau côtiers charentais et aquitains 'G'=>'Loire-Bretagne', // 04 La Loire, les cours d'eau côtiers vendéens et bretons 'H'=>'Seine-Normandie', // 03 La Seine et les cours d'eau côtiers normands 'I'=>'Guadeloupe', // 07 Les cours d'eau de la Guadeloupe 'J'=>'Martinique', // 08 Les cours d'eau de la Martinique 'K'=>'Guyane', // 09 Les fleuves et cours d'eau côtiers de la Guyane 'L'=>'Réunion', // 10 Les cours d'eau de la Réunion 'M'=>'Mayotte', // Les cours d'eau de Mayotte ); foreach ($tabTmp as $iTmp=>$tabArret) { $this->RISQUEACTBASSIN[]=$tabBassins[$tabArret['codeBassin']]; // Libellé risque lié à la localisation l'un des etablissements (INNONDATION, TREMBLEMENT DE TERRE etc..) } $this->RISQUEACTBASSIN=trim(implode(', ', $this->RISQUEACTBASSIN)); // Le ou les libellés des bassins hydrographiques concernés $timer['risquesBassins']=microtime(true); /** INFOS Orias **/ $iOrias = new Metier_Partenaires_MOrias(false, $this->db); $tabTmp = $iOrias->getInfosOrias($this->SIREN); $this->ORIASID=$this->ORIASCAT=$this->ORIASID_DATE=''; if (count($tabTmp)>0) { $this->ORIASID=$tabTmp['numOrias']; $this->ORIASCAT=''; $this->ORIASID_DATE=''; foreach ($tabTmp['categories'] as $tabTmp) { $this->ORIASCAT.=$tabTmp['categorie'].', '; // On prend la première date if ($this->ORIASID_DATE=='') $this->ORIASID_DATE=$tabTmp['dateInscription']; } $this->ORIASCAT=preg_replace('/, $/','', $this->ORIASCAT); } $timer['orias']=microtime(true); /** Liste des marques **/ $this->MARQUENB_INT=0; // Nombre de marques déposées à l'international $this->MARQUENB_EUR=0; // Nombre de marques déposées en EUROPE $this->MARQUENB_FR=0; // Nombre de marques déposées en FRANCE $tabMarques['WW']=$tabMarques['EU']=$tabMarques['FR']=array(); $iMarque = new Metier_Partenaires_MMarques($this->db); $ret = $iMarque->getMarques($siren); if ($ret!==false && count($ret)>0) { foreach ($ret as $i=>$marque) { switch ($marque['rayonMarque']) { case 'Marque communautaire': $this->MARQUENB_EUR++; if ($this->MARQUENB_EUR<11 && $marque['nomMarque']<>'(figurative)') $tabMarques['EU'][]=$marque['nomMarque']; break; case 'Marque française': $this->MARQUENB_FR++; if ($this->MARQUENB_FR<11 && $marque['nomMarque']<>'(figurative)') $tabMarques['FR'][]=$marque['nomMarque']; break; case 'Marque internationale': $this->MARQUENB_INT++; if ($this->MARQUENB_INT<11 && $marque['nomMarque']<>'(figurative)') $tabMarques['WW'][]=$marque['nomMarque']; break; } } } $this->MARQUENB=$this->MARQUENB_EUR+$this->MARQUENB_FR+$this->MARQUENB_INT; // Nombre de marques déposées en tout $this->MARQUELISTE_INT=implode(', ', $tabMarques['WW']); // Liste en ligne des 10 dernières marques déposées à l'internationale séparées par des virgules $this->MARQUELISTE_EUR=implode(', ', $tabMarques['EU']); // Liste en ligne des 10 dernières marques déposées à l'europe séparées par des virgules $this->MARQUELISTE_FR =implode(', ', $tabMarques['FR']); // Liste en ligne des 10 dernières marques déposées à la France séparées par des virgules $timer['marques']=microtime(true); /** Marchés publics **/ $this->MARCHEPUBLIC3_NB=0; // Nombre de marchés public / 3 dernières années $this->MARCHEPUBLIC3_MT=0; // Montant cumulé des marchés public / 3 dernières années $this->MARCHEPUBLICDER_OBJ=''; // Objet du dernier MP remporté $this->MARCHEPUBLICDER_CLI=''; // Nom complet de l'acheteur du dernier MP $this->MARCHEPUBLICDER_MT=false; // Montant $this->MARCHEPUBLICDER_ANNEE=0; // Année du dernier marché public remporté $this->MARCHEPUBLICDER_DATE=0; // Date du dernier marché public remporté $ret=$iInsee->getAnnoncesBoamp($siren); if (count($ret)>0) { foreach ($ret as $i=>$mp) { if (substr($mp['id'],0,1)=='A' || $mp['BodaccCode']=='BOMP C') { if ($this->MARCHEPUBLICDER_MT===false) { $this->MARCHEPUBLICDER_MT =$mp['Montant']; $this->MARCHEPUBLICDER_CLI=$mp['Organisme']; $this->MARCHEPUBLICDER_OBJ=$mp['Objet']; $this->MARCHEPUBLICDER_ANNEE=substr($mp['DateParution'],0,4)*1; $this->MARCHEPUBLICDER_DATE=$mp['DateParution']; } if (substr($mp['DateParution'],0,4)*1>=$this->ANNEEp3) { $this->MARCHEPUBLIC3_NB++; $this->MARCHEPUBLIC3_MT+=$mp['Montant']; } } } } // % du CA du dernier Bilan de la moyenne des 3 dernières années de MP $this->MARCHEPUBLIC3_POURC=($this->MARCHEPUBLIC3_MT*100)/$this->CABIOUES; $timer['marchesPublics']=microtime(true); /** Recherche de Franchise si enseigne **/ $this->FRANCHISE=''; if ($this->ENSEIGNE<>'') { $tmp=addslashes($this->ENSEIGNE); $tabTmp=$this->db->select( 'sdv1.franchiseurs', "id, enseigne, MATCH (enseigne) AGAINST ('$tmp') as score", "MATCH (enseigne) AGAINST ('$tmp') HAVING score>1 ORDER BY score DESC", $this->debug, MYSQL_ASSOC); // Nombre d'établissements concernés: neutraliser si >= 10 foreach ($tabTmp as $iTmp=>$tabArret) { $lev=levenshtein(strtoupper($this->ENSEIGNE), strtoupper($tabArret['enseigne'])); if ($lev<7) { $this->FRANCHISE=$tabArret['enseigne'].' ('.$tabArret['score']." / $lev)"; // Nom du réseau des franchisés break; } } } /** Population commune **/ $codeCommuneInsee=$tabIdentite['Dept'].$tabIdentite['codeCommune']; $tabTmp = $this->db->select( 'insee.insee_tabVilles', 'Pop_mun_2007, popMunZFU, popMunZUS', "CODGEO='$codeCommuneInsee'", $this->debug, MYSQL_ASSOC ); // Nombre d'habitants de la commune du siège $this->POPULATION = (is_array($tabTmp) && count($tabTmp)>0) ? $tabTmp[0]['Pop_mun_2007'] : null ; // % d'effectif salarié sur la population communale if (!empty($this->POPULATION)){ $this->EFFECTIF_POPU=($this->EFFECTIF/$this->POPULATION)*100; } else { $this->EFFECTIF_POPU = null; } // On filtre les ventes sur les entit�s similaires en terme de CA et effectif $filtreCAEff=""; if ($tabIdentite['TrancheCA']*1==0) { $filtreCAEff.=" AND (v.tca=0 OR v.tca IS NULL) "; } else { $filtreCAEff.=" AND v.tca=".$tabIdentite['TrancheCA'].' '; } if ($tabIdentite['EffEnTr']*1==0) { $filtreCAEff.=" AND (v.teffEn=0 OR v.teffEn IS NULL) "; } else { $filtreCAEff.=" AND v.teffEn=".$tabIdentite['EffEnTr'].' '; } /** Ventes par villes, départements et France **/ // Attention, arrondissements pour Paris, Lyon & Marseille //if ($codeCommuneInsee>=75000 && $codeCommuneInsee<76000) $this->VILLE=$tabIdentite['Ville']; // Ville ou ville + arrondissement de l'entreprise $ya2ans=$this->ANNEEp2.'-'.date('m-d'); $ret = $this->db->query("SELECT MIN(b.VenteMt) AS vtMin, AVG(b.VenteMt) AS vtMoy, MAX(b.VenteMt) AS vtMax, COUNT(b.id) AS vtNb FROM ( SELECT v.id, v.VenteMt FROM jo.scores_ventes v WHERE v.nafEn LIKE '$this->APEENT' AND v.codeCommune LIKE '$codeCommuneInsee' AND v.Bodacc_Date_Parution>='$ya2ans' AND v.VenteMt>1 AND v.VenteDev='EUR' $filtreCAEff GROUP BY v.id)b"); if (count($ret)>0) { while($ret=$this->db->fetch(MYSQL_ASSOC)) { $this->VENTEMAX_MT = $this->VENTEMAX_VILLE_MT = $this->VENTEMAX_VILLE_EU = $ret['vtMax']; // Plus grand montant de vente annonce VC niveau "ville" $this->VENTEMOY_VILLE_MT = $this->VENTEMOY_VILLE_EU = $ret['vtMoy']; $this->VENTEMIN_MT = $this->VENTEMIN_VILLE_MT = $this->VENTEMIN_VILLE_EU = $ret['vtMin']; // Plus petit montant de vente annonce VC niveau "ville" $this->VENTE_NB = $this->VENTE_VILLE_NB = $ret['vtNb']; // Nombre de ventes dans le niveau statistique "ville" dans les 24 derniers mois } } // Par département $this->DEPARTEMENT=$iInsee->getDepartement($tabIdentite['Dept']); $this->DEPARTEMENT_DE=$iInsee->getDepartement($tabIdentite['Dept'], true); $ret=$this->db->query("SELECT MIN(b.VenteMt) AS vtMin, AVG(b.VenteMt) AS vtMoy, MAX(b.VenteMt) AS vtMax, COUNT(b.id) AS vtNb FROM ( SELECT v.id, v.VenteMt FROM jo.scores_ventes v WHERE v.nafEn LIKE '$this->APEENT' AND v.codeCommune LIKE '".$tabIdentite['Dept']."%' AND v.Bodacc_Date_Parution>='$ya2ans' AND v.VenteMt>1 AND v.VenteDev='EUR' $filtreCAEff GROUP BY v.id)b"); while($ret=$this->db->fetch(MYSQL_ASSOC)) { $this->VENTEMAX_DEP_MT = $this->VENTEMAX_DEP_EU = $ret['vtMax']; // Plus grand montant de vente annonce VC niveau "ville" $this->VENTEMOY_DEP_MT = $this->VENTEMOY_DEP_EU = $ret['vtMoy']; $this->VENTEMIN_DEP_MT = $this->VENTEMIN_DEP_EU = $ret['vtMin']; // Plus petit montant de vente annonce VC niveau "ville" $this->VENTE_DEP_NB = $ret['vtNb']; // Nombre de ventes dans le niveau statistique "ville" dans les 24 derniers mois } // France entière $ret=$this->db->query("SELECT MIN(b.VenteMt) AS vtMin, AVG(b.VenteMt) AS vtMoy, MAX(b.VenteMt) AS vtMax, COUNT(b.id) AS vtNb FROM ( SELECT v.id, v.VenteMt FROM jo.scores_ventes v WHERE v.nafEn LIKE '$this->APEENT' AND v.Bodacc_Date_Parution>='$ya2ans' AND v.VenteMt>1 AND v.VenteDev='EUR' $filtreCAEff GROUP BY v.id)b"); while($ret=$this->db->fetch(MYSQL_ASSOC)) { $this->VENTEMAX_FRA_MT = $this->VENTEMAX_FRA_EU = $ret['vtMax']; // Plus grand montant de vente annonce VC niveau "ville" $this->VENTEMOY_FRA_MT = $this->VENTEMOY_FRA_EU = $ret['vtMoy']; $this->VENTEMIN_FRA_MT = $this->VENTEMIN_FRA_EU = $ret['vtMin']; // Plus petit montant de vente annonce VC niveau "ville" $this->VENTE_FRA_NB = $ret['vtNb']; // Nombre de ventes dans le niveau statistique "ville" dans les 24 derniers mois } $timer['ventes']=microtime(true); /** Cadastre **/ $this->CADBAT_NB_TOT=0; // nombre de postes BATIMENT du SIREN toutes adresses $this->CADTER_NB_TOT=0; // nombre de postes TERRAIN du SIREN toutes adresses $this->CADBAT_NB_PROP=0; // nombre de postes BATIMENT à l'adresse dont elle est propriétaire $this->CADTER_NB_PROP=0; // nombre de postes TERRAIN à l'adresse dont elle est propriétaire $this->CADBAT_NB_NONPROP=0; // nombre de postes BATIMENT à l'adresse dont elle n'est pas propriétaire $this->CADTER_NB_NONPROP=0; // nombre de postes TERRAINS à l'adresse dont elle n'est pas propriétaire $this->CADBAT_SURF_TOT=0; // Surface totale des batiments du SIREN $this->CADTER_SURF_TOT=0; // Surface totale des terrains du SIREN $iCadastre = new Metier_Partenaires_MCadastre($siren, $this-db); // Locaux $batimentP = $iCadastre->getSurfaceTotal('local'); if (count($batimentP) > 0) { $this->CADBAT_NB_PROP = $batimentP['itemTotal']; $this->CADBAT_SURF_TOT+= $batimentP['surfaceTotal']; } $batimentL = $iCadastre->getSurfaceTotal('local', 'L'); if (count($batiment) > 0) { $this->CADBAT_NB_NONPROP = $batimentL['itemTotal']; $this->CADBAT_SURF_TOT+= $batimentL['surfaceTotal']; } $this->CADBAT_NB_TOT = $this->CADBAT_NB_PROP + $this->CADBAT_NB_NONPROP; // Parcelles $terrainP = $iCadastre->getSurfaceTotal('parcelle'); if (count($terrainP) > 0) { $this->CADTER_NB_PROP = $batimentP['itemTotal']; $this->CADTER_SURF_TOT+= $batimentP['surfaceTotal']; } $terrainL = $iCadastre->getSurfaceTotal('parcelle', 'L'); if (count($terrainL) > 0) { $this->CADTER_NB_NONPROP = $batimentL['itemTotal']; $this->CADTER_SURF_TOT+= $batimentL['surfaceTotal']; } $this->CADTER_NB_TOT = $this->CADTER_NB_PROP + $this->CADTER_NB_NONPROP; $timer['cadastre'] = microtime(true); /** RPS : Entreprise avec négociations ou accord sur les RPS ? **/ $tabTmp = $this->db->select( 'sdv1.gouv_rps', 'idfent, dateMAJ, negotiations, nbreunions, accordsigne, accorddate, absenceEchec', "siren='$this->SIREN'", $this->debug, MYSQL_ASSOC ); if (isset($tabTmp[0]) && $tabTmp[0]['idfent']>0) { $this->RPS_NEGO=$this->RPS_PLAN=false; // Date de dernière MAJ dans le répertoire RPS $this->RPS_INFODATE=$tabTmp[0]['dateMAJ']; // Négotiations if ($tabTmp[0]['negotiations']=='oui') $this->RPS_NEGO=true; // Date de signature de l'accord des RPS qui peut être à 0 $this->RPS_ACCORDDATE=$tabTmp[0]['accorddate']; // Présence du libellé Plan d'action if (!$this->RPS_NEGO && $this->RPS_ACCORDDATE*1==0) $this->RPS_PLAN=true; } /** Recherche de la liste des Produits / NAF **/ $this->LISTEPRODUIT=implode(', ', $iInsee->listeProduits($naf)); /** Taux de défaillance secteur **/ // Nb Entrep actives $tabTmp=$this->db->select( 'jo.scores_secteurs',"sum(nbEntrep) AS nb", "annee=YEAR(NOW()) AND mois=MONTH(NOW())", $this->debug, MYSQL_ASSOC ); $nbEntrep=$tabTmp[0]['nb']; // Nb en défaut sur 12 mois glissant $tabTmp=$this->db->select( 'jo.scores_secteurs', "sum(nbProcol) AS nb", "annee=YEAR(NOW())-1 AND mois>=MONTH(NOW()) OR annee=YEAR(NOW())", $this->debug, MYSQL_ASSOC ); $nbEntrepProcol=$tabTmp[0]['nb']; // Nb en défaut sur 12 mois glissant $tabTmp=$this->db->select( 'jo.scores_secteurs', "MAX(nbEntrep) as nbSecteur, SUM(nbProcol) AS nb", "naf5='$this->APEENT' AND (annee=YEAR(NOW())-1 AND mois>=MONTH(NOW()) OR annee=YEAR(NOW()))", $this->debug, MYSQL_ASSOC ); $nbEntrepSecteur=$tabTmp[0]['nbSecteur']; $nbEntrepSecteurProcol=$tabTmp[0]['nb']; $txDefautTotal=$nbEntrepProcol/$nbEntrep; $txDefautSecteur=$nbEntrepSecteurProcol/$nbEntrepSecteur; $this->NOTEDEFSEC=round(50+(1-($txDefautSecteur/$txDefautTotal))*50); if ($this->NOTEDEFSEC>100) $this->NOTEDEFSEC=100; elseif ($this->NOTEDEFSEC<50) $this->NOTEDEFSEC=round(50+(1-($txDefautSecteur/$txDefautTotal))*10); if ($this->NOTEDEFSEC<0) $this->NOTEDEFSEC=0; /** Date de cessation des paiements et dernier numéro de jugement **/ $tabTmp=$this->db->select( 'jo.annonces', "MIN(dateCessationPaiement) AS cessPai, MAX(numero) AS numPC", "siren=$siren", $this->debug, MYSQL_ASSOC ); $this->ANNONCEPC_CESDATE=$tabTmp[0]['cessPai']; $this->ANNONCEPC_NUM=$tabTmp[0]['numPC']; /** Activite réglementée **/ $this->ACTIVREG=''; $tabTmp=$iInsee->getActivite($siren, $nic); if ($tabTmp) $this->ACTIVREG=$tabTmp['libActivite']; // Libellé de l'activité règlementé $this->NBSUIVICLI=0; // Nombre de clients suivants cette entreprise $this->NBSOCSEC=0; // Nombre de siren composants les ratios secteurs $this->NBSOCSECPUB=0; // Nombre de siren du secteurs devant publier $this->NBINTERRO1=0; $this->NBINTERRO3=0; $this->NBINTERRO6=0; $this->NBINTERRO12=0; if ( $type == 'valo' ) { $tabTxRendObli = $this->getTxRendement(date('Y')); $this->TAUXRA = $tabTxRendObli; /** Tableau des taux de rendement **/ $tabTmp=$tabTxRendObli; krsort($tabTmp); foreach ($tabTmp as $iTmp=>$tabTmp2) { if ($iTmp==0) { $tmpTxN=$tabTmp2; } elseif ($iTmp==1) { $tmpTxN1=$tabTmp2; $this->TAUXRAMOY1=($tmpTxN+$tabTmp2)/2; } elseif ($iTmp==2) { $tmpTxN2=$tabTmp2; $this->TAUXRAMOY2=($tmpTxN+$tmpTxN1+$tabTmp2)/3; } elseif ($iTmp==3) { $this->TAUXRAMOY3=($tmpTxN+$tmpTxN1+$tmpTxN2+$tabTmp2)/4; } } $this->VALCOEFMINCA=0; $this->VALCOEFMAXCA=0; $naf2=substr($this->APEENT,0,2); $naf3=substr($this->APEENT,0,3); $naf4=substr($this->APEENT,0,4); $tabTmp=$this->db->select('jo.tabNafValo', 'naf5, MINI, MAXI, TYPE, LENGTH(naf5) AS naf5len', "naf5 LIKE '$naf2%' OR naf5 LIKE '$naf3%' OR naf5 LIKE '$naf4%' OR naf5='$this->APEENT' ORDER BY naf5len DESC LIMIT 0,1", $this->debug, MYSQL_ASSOC); // On prend le 1er secteur trouvé le + précis if (count($tabTmp) > 0) { $tabTmp=$tabTmp[0]; $this->VALCOEFMINCA=$tabTmp['MINI']; $this->VALCOEFMAXCA=$tabTmp['MAXI']; } } //Chargement des phrases de commentaires - @todo : mettre en valeur de config $tabCommentaires = $tabTriAff = array(); switch( $type ) { case 'scores': $version = '414'; $tabCommentaires = include __DIR__ . '/Comment/ScoreTxt'.$version.'N'.$this->NIVEAU.'.php'; $tabTriAff = include __DIR__ . '/Comment/ScoreTri'.$version.'N'.$NIVEAU.'.php'; require_once 'Metier/Scores/Formule/Score_'.$version.'.php'; break; case 'valo': $version = 'v209'; $tabCommentaires = include __DIR__ . '/Comment/ValoTxt'.$version.'N'.$this->NIVEAU.'.php'; $tabTriAff = include __DIR__ . '/Comment/ValoTri'.$version.'N'.$this->NIVEAU.'.php'; require_once 'Metier/Scores/Formule/Valo_'.$version.'.php'; break; } asort($tabTriAff); $tabCommentairesATrier=array(); $timer['calculcommentaires']=microtime(true); $numC=0; foreach ($C as $idx=>$value) { $numC++; if ($value) { $commentaires=@implode('
',$tabCommentaires[$idx]); $commentaires=preg_replace('/\[0+/', '[', $commentaires); if($this->debug) { file_put_contents(LOG_PATH.'/debugFmt.log', date("Y/m/d H:i:s")." - formule 0=$idx : $commentaires\n", FILE_APPEND); if ( preg_match_all('/(\{.*\})/Us', $commentaires, $tabTmp) ) { foreach ($tabTmp[1] as $valeur) { $valeur2=strtr($valeur, array('{'=>'', '}'=>'')); file_put_contents(LOG_PATH.'/debugFmt.log', date("Y/m/d H:i:s")." - formule A=$idx : $valeur\n", FILE_APPEND); } } } $strCommentaire=strtr(preg_replace_callback('/(\{.*\})/U', array($this,'format'), $commentaires), array('"'=>'\'')); // Gestion de la balise signifiant un espacement obligatoire de xx if (preg_match('/\/Ui', $strCommentaire, $matches)){ $strCommentaire=str_repeat('_', $matches[1]).preg_match('/\/', '', $strCommentaire); } /*if (preg_match('/\(.*)$/Ui', $strCommentaire, $matches)) $strCommentaire='+ '.$matches[1]; elseif (preg_match('/\(.*)$/Ui', $strCommentaire, $matches)) $strCommentaire='- '.$matches[1]; elseif (preg_match('/\
  • (.*)$/Ui', $strCommentaire, $matches)) $strCommentaire='* '.$matches[1];*/ // Gestion de la balise pour concaténation à la ligne précédente if (preg_match('/\(.*)$/Ui', $strCommentaire, $matches)) $strCommentaire=$matches[1]; if (preg_match('/^\(.*)$/', trim($strCommentaire), $matches2)) { if (substr(trim($tabCommentairesATrier[$idxPre]),-1)=='.') $tabCommentairesATrier[$idxPre]=substr(trim($tabCommentairesATrier[$idxPre]),0,-1).//' '. $matches2[1]; else $tabCommentairesATrier[$idxPre].=$matches2[1]; } elseif (preg_match('/^\(.*)$/', trim($strCommentaire), $matches2)) { if (substr(trim($tabCommentairesATrier[$idxPre]),-1)==':') $tabCommentairesATrier[$idxPre]=substr(trim($tabCommentairesATrier[$idxPre]),0,-1).//' '. $matches2[1]; else $tabCommentairesATrier[$idxPre].=$matches2[1]; } elseif (preg_match('/^\(.*)$/', trim($strCommentaire), $matches2)) { if (substr(trim($tabCommentairesATrier[$idxPre]),-1)==';') $tabCommentairesATrier[$idxPre]=substr(trim($tabCommentairesATrier[$idxPre]),0,-1).//' '. $matches2[1]; else $tabCommentairesATrier[$idxPre].=$matches2[1]; } elseif (preg_match('/^\(.*)$/', trim($strCommentaire), $matches2)) { if (substr(trim($tabCommentairesATrier[$idxPre]),-1)==',') $tabCommentairesATrier[$idxPre]=substr(trim($tabCommentairesATrier[$idxPre]),0,-1).//' '. $matches2[1]; else $tabCommentairesATrier[$idxPre].=$matches2[1]; } elseif (preg_match('/^\(.*)$/', trim($strCommentaire), $matches2)) $tabCommentairesATrier[$idxPre].=$matches2[1]; else { $tabCommentairesATrier[$idx]=$strCommentaire; $idxPre=$idx; } } } //echo '
    '; $tabComment=array(); $tableau=false; foreach ($tabTriAff as $idxC=>$ordre) { $idxC=floor($idxC); if (isset($tabCommentairesATrier[$idxC])) { //echo "$idxC"; // Gérer les parenthèses //$strTmp2=strtr($tabCommentairesATrier[$idxC], array('(4)'=>'')); $strTmp2=$tabCommentairesATrier[$idxC]; $debLigne=$finLigne=''; if (preg_match('/('=>'','
    '=>'','
    '=>'','
    '=>'')); $tableau=true; } else { $tableau=false; if ($tableauPre) $debLigne.=''; } if (preg_match('/(.*)/Uis', $strTmp2, $matchesTmp)) { if (!preg_match('/<\/i>/Uis', $matchesTmp[1])) // Il manque la fin de l'italique $finLigne.=''; } if (preg_match('/(.*)($|.*$)/Uis', $strTmp2, $matchesTmp)) { $nivH=$matchesTmp[1]; $strTmp2="".$matchesTmp[2]."".$matchesTmp[3]; } if (preg_match('/^(.*)\{GRAPH\((.*)\)\}(.*)$/Uis', $strTmp2, $matchesTmp)) { $strTmp='ERREUR DE FORMULE LORS DE LA GENERATION DU GRAPHIQUE no '.$idxC; $strTmp2=trim(str_replace('$','',$matchesTmp[1]))."[GRAPHIQUE id=$idxC titre=".$matchesTmp[2].']'.trim($matchesTmp[3]); // $matchesTmp[3]; //{GRAPH("Marge brute d'exploitation/secteur",R[506]#H,Rs[506]#H)} } else $strTmp='ERREUR DE FORMULE LORS DE LA GENERATION DU COMMENTAIRE no '.$idxC; //@eval('\$strTmp="'.$strTmp2.'";'); $strTmp=eval("return \"$strTmp2\";"); $tabComment[$idxC]=preg_replace('/<\/i>(?:)<\/i>/i','', $debLigne.$strTmp.$finLigne);//." ($idxC, $ordre)"; if (substr($strTmp,0,17)=='ERREUR DE FORMULE') { } // echo " ($ordre)
    "; $tableauPre=$tableau; } } // Si le dernier commentaire est une fin de tableau, on gère le cas ! if ($tableau) $tabComment[$idxC].=''; $timer['finIndiscore']=microtime(true); } // Fin Génération des commentaires if($this->debug) { $variables="\n\$NIVEAU=$this->NIVEAU\n\$numBil=$numBil\n\$noteSD=$noteSD\n\t-----\n"; foreach ($tabVar as $var) { if (isset(${$var})) { if (is_array(${$var})) { $variables.="$var=".print_r(${$var}).PHP_EOL; } else { $variables.="$var='${$var}'".PHP_EOL; } } else { $variables.="$var='${$var}' NON DEFINIE !!!".PHP_EOL; } } file_put_contents($this->SIREN.'_'.$type.'.log', "Indiscore sur $siren : Commentaires".PHP_EOL. "Liste des variables :\n$variables".PHP_EOL. 'CA_COEF='.$this->CA_COEF.PHP_EOL. 'CA_Y='.print_r($this->CA_Y,true).PHP_EOL.PHP_EOL. 'RCAI_COEF='.$this->RCAI_COEF.PHP_EOL. 'RCAI_Y='.print_r($this->RCAI_Y,true).PHP_EOL. "PROJECCOEF=$this->PROJECCOEF".PHP_EOL. "PROJECTAUX=$this->PROJECTAUX".PHP_EOL. "Y=".print_r($this->Y,true).PHP_EOL. "Yaff=".print_r($this->Yaff,true).PHP_EOL. "tabRegX=".print_r($this->tabRegX,true).PHP_EOL. print_r($tabComment, true).PHP_EOL. "Liste des commentaires a trier :\n".print_r($tabCommentairesATrier,true).PHP_EOL. "Tableau des codes de tri pour calcul :\n".print_r($tabTri,true).PHP_EOL. "Tableau des codes de tri pour affichage :\n".print_r($tabTriAff,true).PHP_EOL. $debugFormule.PHP_EOL.'-----------------------'.PHP_EOL. "Liste des Bilans :\n".print_r($tabBilans, true).PHP_EOL. "tabBil=".print_r($tabBil,true).PHP_EOL. "Liste des Ratios :\n".print_r($tabRatios, true).PHP_EOL. "Liste des ratios Evolutions :\n". print_r($tabRatiosEvol, true).PHP_EOL ); $i=0; $strTime=''; foreach ($timer as $lib=>$time) { $strTime.="$lib : "; $duree=round($time-$timePre,3); if ($i==0) { $strTime.="0 s"; $timeDeb=$time; } else $strTime.="$duree s"; $strTime.="\n"; $timePre=$time; $i++; } $duree=round($time-$timeDeb,3); $strTime.="---------------------\nTOTAL : $duree secondes\n"; file_put_contents('time.log', "Indiscore sur $siren : Durées ".$strTime.PHP_EOL.$strNote.PHP_EOL.$variables.PHP_EOL.print_r($tabRatiosInfos,true)); } // EntActiveRCS if ($this->ACTIFRNCS || $this->ACTIFINSEE) { $actif=1; } else { $actif=0; } // Libellé Information de paiemet - Procédure collective if ($libInfoPaiement<>'' && $tabIdentite['SituationJuridique']=='P') { $libInfoPaiement = 'En procédure collective'; } //Retour $tabRet = array( 'id' => $tabIdentite['id'], 'Siret' => $tabIdentite['SiretSiege'], 'Actif' => $actif,//$tabIdentite['Actif'], 'AutreId' => $tabIdentite['AutreId'], 'Nom' => $tabIdentite['Nom'], 'Sigle' => $tabIdentite['Sigle'], 'Enseigne' => $tabIdentite['Enseigne'], 'Adresse' => $tabIdentite['Adresse'], 'Adresse2' => $tabIdentite['Adresse2'], 'AdresseNum' => $tabIdentite['AdresseNum'], 'AdresseBtq' => $tabIdentite['AdresseBtq'], 'AdresseVoie' => $tabIdentite['AdresseVoie'], 'AdresseRue' => $tabIdentite['AdresseRue'], 'CP' => $tabIdentite['CP'], 'Ville' => $tabIdentite['Ville'], 'Civilite' => $tabIdentite['Civilite'], 'NbEtab' => $tabIdentite['NbEtab'], 'Tel' => $tabIdentite['Tel'], 'Fax' => $tabIdentite['Fax'], 'Web' => $tabIdentite['Web'], 'Mail' => $tabIdentite['Mail'], 'FJ' => $fj, 'FJ_lib' => $tabIdentite['FJ_lib'], 'Siren' => $tabIdentite['Siren'], 'Nic' => $tabIdentite['Nic'], 'NafEtab' => $tabIdentite['NafEtab'], 'NafEnt' => $tabIdentite['NafEnt'], 'NafEntLib' => $tabIdentite['NafEntLib'], 'Activite' => $tabIdentite['Activite'], 'Capital' => $tabIdentite['Capital'], 'CapitalDev' => $tabIdentite['CapitalDev'], 'DateCreaEt' => $tabIdentite['DateCreaEt'], 'DateCreaEn' => $tabIdentite['DateCreaEn'], 'DateClotEt' => $tabIdentite['DateClotEt'], 'EffEnTr' => $tabIdentite['EffEnTr'], 'EffEnTrLib' => $tabIdentite['EffEnTrLib'], 'Effectif' => $tabIdentite['Effectif'], 'Dept' => $tabIdentite['Dept'], 'codeCommune' => $tabIdentite['codeCommune'], 'TrancheCA' => $tabIdentite['TrancheCA'], 'TrancheCALib' => $tabIdentite['TrancheCALib'], 'dir1Titre' => $tabIdentite['dir1Titre'], 'dir1NomPrenom' => $tabIdentite['dir1NomPrenom'], 'dir1DateFct' => $tabIdentite['dir1DateFct'], 'dir2Titre' => $tabIdentite['dir2Titre'], 'dir2NomPrenom' => $tabIdentite['dir2NomPrenom'], 'dir2DateFct' => $tabIdentite['dir2DateFct'], 'Rivoli' => $tabIdentite['Rivoli'], 'NbBilansScore' => $this->NBBILAN, 'Bilans' => $tabBil, 'Note_Structure' => $noteStructure, 'Notes_Structure' => $tabStructure, 'Note_Financiere' => $noteFin, 'Indiscore' => $noteSolvabilite, 'Indiscore20' => $indiscore20, 'TendanceIndiscore' => $tendance, 'DevraitPublier' => $this->FJURPUB, 'ScoreSolvabilite' => $noteSolvabilite, 'AnalyseSolvabilite'=> $analyseSolv, 'ScoreDirigeance' => $this->SCOREDIRI, 'AnalyseDirigeance' => $analyseDir, 'ScoreConfor' => $this->SCORECONF, 'AnalyseConfor' => $analyseConf, 'LibSecteur' => $libSecteur, 'tabBilans' => $tabBilans, 'tabBilan' => $tabBilan, 'tabRatios' => $tabRatiosNew, 'tabRatiosDiff' => $tabRatiosDiff, 'tabRatiosEvol' => $tabRatiosEvol, 'encours' => $this->ENCOURS, 'encoursIni' => $encoursIni, 'encoursStat' => $encoursEstime, 'infoEncours' => $libEncours, 'infoPaiement' => $libInfoPaiement, 'profilPayeur' => $profilPayeur, 'classeRisque' => $classeRisque, 'AdresseDom' => $tabIdentite['AdresseDom'], 'scores' => array( 'ConanH'=> $scoreConanH, 'Afdcc1'=> $scoreAfdcc1, 'Afdcc2'=> $scoreAfdcc2, 'Afdcc2note'=>$scoreAfdcc2note, 'Z' => $scoreZ, 'Altman'=> $scoreAltman, 'AltmanCote'=> $scoreAltmanB, '36mois'=> $pDef36, 'CCF' => $valeurCCF, 'NOTECAP'=> $this->NOTECAP20, // Capitalisation 'NOTELED'=> $this->NOTELED20, // Levier Endettement 'NOTERBT'=> $this->NOTERBT20, // Capa. Remboursement 'NOTECFI'=> $this->NOTECFI20, // Couv. Charges Finan. 'NOTETRES'=> $this->NOTETRES20,// Tresorerie 'NOTEMEX'=> $this->NOTEMEX20, // Marge Exploitation ), 'paiements' => $tabPaiements, 'cs' => $this->CSFACTO, 'csMoisMaj' => $this->CSFACTO_MMAA, 'csMoisFin' => $this->CSFACTOFIN_MMAA, 'SituationJuridique'=> $tabIdentite['SituationJuridique'], 'tabInfosNotations' => $tabInfosNotation, 'tabImportExport' => $tabImportExport, 'tabCommentaires' => $tabComment, 'tabVariables' => array('CA_Y'=>$this->Yaff), ); $indiScore = $tabRet['Indiscore']*1; $this->ENCOURS = round($tabRet['encours']); /** Historisation du score **/ $tabTmp = $this->db->select('jo.scores_surveillance s', "s.siren, s.actif, s.procol, s.indiScore, s.indiScore20, s.encours, s.indiScoreDate, scoreSolv, scoreConf, scoreDir, scoreZ, scoreCH, scoreAfdcc1, scoreAfdcc2, scoreAfdcc2note, scoreAltman, scoreAltmanCote, scoreCCF, situFi, infoNote, noteStruct, noteFin, tendance, nbModifs, s.dateUpdate, s.cs, s.csMoisMaj, s.csMoisFin", "s.siren=$siren", false, MYSQL_ASSOC); //Déjà en surveillance score => il faut faire un update dans la base if (count($tabTmp)>0) { $entrep = $tabTmp[0]; $indiScorePre = $entrep['indiScore']*1; $encoursPre = $entrep['encours']*1; $dateScore = str_replace('-','',$entrep['indiScoreDate'])*1; $procol = $entrep['procol']; if ($entrep['nbModifs']==0) $sourceModif='ajout'; $nbModifs = ($entrep['nbModifs']*1)+1; $actionHisto = 'update'; } else { $entrep=array(); $indiScorePre=$encoursPre=null; $dateScore=0; $sourceModif='ajout'; $nbModifs = 1; $actionHisto = 'insert'; } /** Si un score a déjà été calculé, on affine la variable "TendanceIndiscore" **/ if ($dateScore>0) { if ($indiScore>$indiScorePre) $tabRet['TendanceIndiscore']='Haussiere'; elseif ($indiScore<$indiScorePre) $tabRet['TendanceIndiscore']='Baissiere'; else $tabRet['TendanceIndiscore']='Stable'; } if ($this->companyEvenDateStop === null) { // --- Scores identique au précedent, simple mise à jour if ($indiScore==$indiScorePre && $this->ENCOURS==$encoursPre && $dateScore<>0 ) { $tabUpdate2 = array('sourceModif'=>$sourceModif, 'nbModifs'=>$nbModifs); if (!$this->db->update('jo.scores_surveillance', $tabUpdate2, "siren=$siren", false, 0, true)) { Metier_Util_Log::write('W', 'Erreur lors de la MAJ du score en surveillance pour '. $tabIdentite['Nom'], __LINE__, __FILE__, __FUNCTION__, __CLASS__); } } else { // --- Calcul de l'effectif réel $EffectifEn = $tabIdentite['Effectif']; $bilanAgeMax = 3 * 12; //Age maximum du dernier bilan en mois if (!empty($tabIdentite['bilanDate']) && intval($tabIdentite['bilanYP'])>0 ) { $dateBilan = DateTime::createFromFormat('Ymd', $tabIdentite['bilanDate']); $dateCompare = new DateTime(); $dateCompare->sub(new DateInterval('P'.$bilanAgeMax.'M')); if ($dateBilan > $dateCompare) { $EffectifEn = $tabIdentite['bilanYP']; } } //Insertion ou mise à jour du score $tabUpdate = array( 'siren' => $siren, 'naf' => $naf, 'CJ' => $tabIdentite['FJ'], 'dateImmat' => $tabIdentite['dateImmat'], 'dateCrea' => $tabIdentite['DateCreaEn'], 'effectif' => $EffectifEn, 'actif' => $tabRet['Actif'], 'procol' => $tabRet['SituationJuridique'], 'indiScore' => $tabRet['Indiscore'], 'indiScore20' => $tabRet['Indiscore20'], 'encours' => $tabRet['encours'], 'indiScoreDate' => $this->JOUR_DATE, 'dateBilan' => @$tabRet['Bilans'][0]['Millesime'], 'scoreSolv' => $tabRet['ScoreSolvabilite'], 'scoreConf' => $tabRet['ScoreConfor'], 'scoreDir' => $tabRet['ScoreDirigeance'], 'scoreZ' => $tabRet['scores']['Z'], 'scoreCH' => $tabRet['scores']['ConanH'], 'scoreAfdcc1' => $tabRet['scores']['Afdcc1'], 'scoreAfdcc2' => $tabRet['scores']['Afdcc2'], 'scoreAfdcc2note' => $tabRet['scores']['Afdcc2note'], 'scoreAltman' => $tabRet['scores']['Altman'], 'scoreAltmanCote' => $tabRet['scores']['AltmanCote'], 'scoreCCF' => $tabRet['scores']['CCF'], 'situFi' => $tabRet['tabInfosNotations']['SituationFinanciere'], 'infoNote' => $tabRet['tabInfosNotations']['Notation'], 'noteStruct' => $tabRet['Note_Structure'], 'noteFin' => $tabRet['Note_Financiere'], 'tendance' => $tabRet['TendanceIndiscore'], 'cs' => $tabRet['cs'], 'csMoisMaj' => $tabRet['csMoisMaj'], 'csMoisFin' => $tabRet['csMoisFin'], 'adresseDom' => $tabRet['AdresseDom'], 'sourceModif' => $sourceModif, 'indiScorePre' => $entrep['indiScore'], 'indiScore20Pre' => $entrep['indiScore20'], 'indiScoreDatePre' => $entrep['indiScoreDate'], 'encoursPre' => $entrep['encours'], 'scoreSolvPre' => $entrep['scoreSolv'], 'scoreConfPre' => $entrep['scoreConf'], 'scoreDirPre' => $entrep['scoreDir'], 'scoreZPre' => $entrep['scoreZ'], 'scoreCHPre' => $entrep['scoreCH'], 'scoreAfdcc1Pre' => $entrep['scoreAfdcc1'], 'scoreAfdcc2Pre' => $entrep['scoreAfdcc2'], 'scoreAfdcc2notePre'=> $entrep['scoreAfdcc2note'], 'scoreAltmanPre' => $entrep['scoreAltman'], 'scoreAltmanCotePre'=> $entrep['scoreAltmanCote'], 'scoreCCFPre' => $entrep['scoreCCF'], 'situFiPre' => $entrep['situFi'], 'infoNotePre' => $entrep['infoNote'], 'noteStructPre' => $entrep['noteStruct'], 'noteFinPre' => $entrep['noteFin'], 'tendancePre' => $entrep['tendance'], 'csPre' => $entrep['cs'], 'csMoisMajPre' => $entrep['csMoisMaj'], 'csMoisFinPre' => $entrep['csMoisFin'], 'adresseDomPre' => $entrep['adresseDom'], 'nbModifs' => $nbModifs, ); // --- Sauvegarde et Historisation du score if ( $actionHisto == 'insert' ) { if (!$this->db->insert('jo.scores_surveillance', $tabUpdate, false, true)) { Metier_Util_Log::write('W', "Erreur lors de l'ajout du score en surveillance pour ". $tabIdentite['Nom']." - ".mysql_error(), __LINE__, __FILE__, __FUNCTION__, __CLASS__); } } else { if (!$this->db->update('jo.scores_surveillance', $tabUpdate, "siren=$siren", false, 0, true)) { Metier_Util_Log::write('W', "Erreur lors de mise à jour du score en surveillance pour ". $tabIdentite['Nom']." - ".mysql_error(), __LINE__, __FILE__, __FUNCTION__, __CLASS__); } } // --- Historisation du score if (!$this->db->insert('historiques.scores_surveillance', $tabUpdate)) { Metier_Util_Log::write('W', "Erreur lors de l'historisation du score pour ". $tabIdentite['Nom'], __LINE__, __FILE__, __FUNCTION__, __CLASS__); } } } Metier_Util_Log::write('I', 'Etablissement retourné FIN = '. $tabIdentite['Nom'], __LINE__, __FILE__, __FUNCTION__, __CLASS__); return $tabRet; } /** * Calcul des éléments SCORE - EVALUATION * Paramètres en ENTREE * - Identite * - Annonces Legales * - Bilans * * Paramètres en SORTIE * - Définir une structure de données * * */ public function calcul() { } public function comment(){} protected function save(){} } ?>