From 71ff0d778a10d980e572202b9976bbd003b44b89 Mon Sep 17 00:00:00 2001 From: benoitpotier Date: Wed, 29 Mar 2017 11:16:47 +0200 Subject: [PATCH] =?UTF-8?q?=C3=A9crasement=20des=20fichiers=20librairy=20d?= =?UTF-8?q?u=20backoffice=20au=20profis=20des=20fichiers=20library=20du=20?= =?UTF-8?q?webservice?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- src/Metier/Insee/MInsee.php | 827 ++++++++++++++------------- src/Metier/Liens/Base.php | 6 +- src/Metier/Partenaires/MBilans.php | 11 +- src/Metier/Scores/Data/Formules.php | 62 +- src/Metier/Scores/MScores.php | 85 +-- src/Metier/Scoring/Data/Formules.php | 62 +- src/Metier/sphinx/rechercheFonc.php | 16 +- src/Scores/Ws/Doc.php | 42 +- 8 files changed, 555 insertions(+), 556 deletions(-) diff --git a/src/Metier/Insee/MInsee.php b/src/Metier/Insee/MInsee.php index b23758e..1586167 100644 --- a/src/Metier/Insee/MInsee.php +++ b/src/Metier/Insee/MInsee.php @@ -5591,459 +5591,460 @@ class Metier_Insee_MInsee extends Metier_Insee_Table try { $stmt = $this->conn->executeQuery($sql); - } catch (\Doctrine\DBAL\DBALException $e) { - if ($this->logger !== null) { - $this->logger->error($e->getMessage()); - } - } - // --- Traitement des resultats - if ($stmt->rowCount() > 0) { - // --- Identite Light de l'entité - if ($this->Identite === null) { - $this->Identite = $this->getIdentiteLight($siren); - } - // --- Parcours des annonces - while ($ann = $stmt->fetch(\PDO::FETCH_ASSOC)) { - // --- Formatage bodacc - if ($ann['SourceTable'] == 'bodacc') { - $tabEven = explode(';', $ann['typeEven']); - $tabRetEven = array(); - // --- Annonce rubrique insertion - if ($ann['typeAnnonce']!='Insertion') { - // --- Sélection des événements - foreach ($tabEven as $even) { - if (intval($even) != 0) { - $tabRetEven[] = array( - 'CodeEven' => $even, - 'LibEven' => $this->iBodacc->getEvenement($even) - ); - } - } - // Libellé générique - $tabRetEven[] = array( - 'CodeEven' => '0000', - 'LibEven' => $ann['typeAnnonce']." de l'annonce du ". - Metier_Util_Date::dateT('Y-m-d', 'd/m/Y', $ann['corrBodacc_Date_Parution']) - ); - } - // --- Annonce autre rubrique - else { - if (trim($ann['typeEven'])!='') { + // --- Traitement des resultats + if ($stmt->rowCount() > 0) { + // --- Identite Light de l'entité + if ($this->Identite === null) { + $this->Identite = $this->getIdentiteLight($siren); + } + // --- Parcours des annonces + while ($ann = $stmt->fetch(\PDO::FETCH_ASSOC)) { + // --- Formatage bodacc + if ($ann['SourceTable'] == 'bodacc') { + $tabEven = explode(';', $ann['typeEven']); + $tabRetEven = array(); + // --- Annonce rubrique insertion + if ($ann['typeAnnonce']!='Insertion') { + // --- Sélection des événements foreach ($tabEven as $even) { if (intval($even) != 0) { $tabRetEven[] = array( - 'CodeEven' => $even, - 'LibEven' => $this->iBodacc->getEvenement($even) + 'CodeEven' => $even, + 'LibEven' => $this->iBodacc->getEvenement($even) ); } } - // --- Detection plan - if ($this->AnnoncesLegalesVisu === false) { - $this->getAnnoncesLegalesPlan('bodacc', $this->Identite['FJ'], $ann); - } - } else { - switch ($ann['Rubrique']) { - case 'mmd': $codeEven='2313'; $libEven = "Modification(s) diverse(s)"; break; - case 'comptes': $codeEven='3999'; $libEven = "Dépôt des comptes"; break; - case 'creations': $codeEven='4999'; $libEven = "Création d'entreprise"; break; - case 'procol': $codeEven='1999'; $libEven = "Procédure collective"; break; - case 'radiations': $codeEven='6700'; $libEven = "Radiation"; break; - case 'ventes': $codeEven='5999'; $libEven = "Vente/Cession"; break; - default: $codeEven='0000'; $libEven = $ann['Rubrique']; break; - } + // Libellé générique $tabRetEven[] = array( - 'CodeEven' => $codeEven, - 'LibEven' => $libEven + 'CodeEven' => '0000', + 'LibEven' => $ann['typeAnnonce']." de l'annonce du ". + Metier_Util_Date::dateT('Y-m-d', 'd/m/Y', $ann['corrBodacc_Date_Parution']) ); } - } + // --- Annonce autre rubrique + else { + if (trim($ann['typeEven'])!='') { + foreach ($tabEven as $even) { + if (intval($even) != 0) { + $tabRetEven[] = array( + 'CodeEven' => $even, + 'LibEven' => $this->iBodacc->getEvenement($even) + ); + } + } + // --- Detection plan + if ($this->AnnoncesLegalesVisu === false) { + $this->getAnnoncesLegalesPlan('bodacc', $this->Identite['FJ'], $ann); + } + } else { + switch ($ann['Rubrique']) { + case 'mmd': $codeEven='2313'; $libEven = "Modification(s) diverse(s)"; break; + case 'comptes': $codeEven='3999'; $libEven = "Dépôt des comptes"; break; + case 'creations': $codeEven='4999'; $libEven = "Création d'entreprise"; break; + case 'procol': $codeEven='1999'; $libEven = "Procédure collective"; break; + case 'radiations': $codeEven='6700'; $libEven = "Radiation"; break; + case 'ventes': $codeEven='5999'; $libEven = "Vente/Cession"; break; + default: $codeEven='0000'; $libEven = $ann['Rubrique']; break; + } + $tabRetEven[] = array( + 'CodeEven' => $codeEven, + 'LibEven' => $libEven + ); + } + } - $dateCes = str_replace('-', '', $ann['dateCessationActivite'])*1; - $dateDeb = str_replace('-', '', $ann['dateDebutActivite'])*1; - $dateEff = str_replace('-', '', $ann['dateEffet'])*1; - if ($dateCes > 0) { - $dateEffet = $ann['dateCessationActivite']; - } elseif ($dateDeb > 0) { - $dateEffet = $ann['dateDebutActivite']; - } else { - $dateEffet = $ann['dateEffet']; - } - $adresseAnn = trim(preg_replace('/ +/', ' ', $ann['adresseSiege'].' '.$ann['codePostalSiege'].' '.$ann['villeSiege'])); + $dateCes = str_replace('-', '', $ann['dateCessationActivite'])*1; + $dateDeb = str_replace('-', '', $ann['dateDebutActivite'])*1; + $dateEff = str_replace('-', '', $ann['dateEffet'])*1; + if ($dateCes > 0) { + $dateEffet = $ann['dateCessationActivite']; + } elseif ($dateDeb > 0) { + $dateEffet = $ann['dateDebutActivite']; + } else { + $dateEffet = $ann['dateEffet']; + } + $adresseAnn = trim(preg_replace('/ +/', ' ', $ann['adresseSiege'].' '.$ann['codePostalSiege'].' '.$ann['villeSiege'])); - if (strlen($adresse) <8) { - $adresseAnn = trim(preg_replace('/ +/', ' ', $ann['adresse'].' '.$ann['codePostal'].' '.$ann['ville'])); - } - // --- Retour bodacc - $retFormat = array( - 'id' => $ann['id'], - 'BodaccCode' => 'BOD'.$ann['Bodacc_Code'], - 'BodaccNum' => $ann['Bodacc_Num'], - 'NumAnnonce' => $ann['Num_Annonce'], - 'DateParution' => $ann['Bodacc_Date_Parution'], - 'Departement' => $ann['Tribunal_Dept'], - 'Tribunal' => $ann['triNom'], - 'TribunalCode' => $ann['triCode'], - 'TribunalSiret' => $ann['triSiret'], - 'Rubrique' => $ann['Rubrique'], - 'typeAnnonce' => $ann['typeAnnonce'], - 'texteRectificatif' => $ann['corrTexteRectificatif'], - 'dateEffet' => $dateEffet, - 'dateJugement' => $ann['dateJugement'], - 'dateFin' => $ann['dateFinObservation'], - 'montantVente' => trim($ann['VenteMt'].' '.$ann['VenteDev']), - 'libFJ' => $ann['FJ'], - 'codFJ' => $this->iBodacc->getCodeFormeJur($ann['FJ']), - 'capital' => $ann['Capital'], - 'capitalDev' => $ann['CapitalDev'], - 'raisonSociale' => $ann['raisonSociale'], - 'nomCommercial' => $ann['nomCommercial'], - 'sigle' => $ann['sigle'], - 'adresse' => $adresseAnn, - 'dateInsertionSD' => $ann['dateInsert'], - 'evenements' => $tabRetEven, - 'complement' => $ann['complement'], - 'deleted' => $ann['deleted'], - 'texteAnnonce' => $ann['annonce'], - ); - $tabRet[] = $retFormat; - } - // --- Formattage Histo - elseif ($ann['SourceTable'] == 'histo') { - if ($ann['JAL']==1) { - $Bodacc_Code='BODA'; - } elseif ($ann['JAL']==200) { - $Bodacc_Code='BODB'; - } - // 4xxx - if ($ann['CODEVE']<20) { - $rub='creations'; - } - // 5xxx - elseif ($ann['CODEVE']<=25) { - $rub='ventes'; - } - // 2xxx - elseif ($ann['CODEVE']<40) { - $rub='mmd'; - } - // 6xxx - elseif ($ann['CODEVE']<42) { - $rub='radiations'; - } - // 2xxx - elseif ($ann['CODEVE']<50) { - $rub='mmd'; - } - // 1xxx - elseif ($ann['CODEVE']<80) { - $rub='procol'; + if (strlen($adresse) <8) { + $adresseAnn = trim(preg_replace('/ +/', ' ', $ann['adresse'].' '.$ann['codePostal'].' '.$ann['ville'])); + } + // --- Retour bodacc + $retFormat = array( + 'id' => $ann['id'], + 'BodaccCode' => 'BOD'.$ann['Bodacc_Code'], + 'BodaccNum' => $ann['Bodacc_Num'], + 'NumAnnonce' => $ann['Num_Annonce'], + 'DateParution' => $ann['Bodacc_Date_Parution'], + 'Departement' => $ann['Tribunal_Dept'], + 'Tribunal' => $ann['triNom'], + 'TribunalCode' => $ann['triCode'], + 'TribunalSiret' => $ann['triSiret'], + 'Rubrique' => $ann['Rubrique'], + 'typeAnnonce' => $ann['typeAnnonce'], + 'texteRectificatif' => $ann['corrTexteRectificatif'], + 'dateEffet' => $dateEffet, + 'dateJugement' => $ann['dateJugement'], + 'dateFin' => $ann['dateFinObservation'], + 'montantVente' => trim($ann['VenteMt'].' '.$ann['VenteDev']), + 'libFJ' => $ann['FJ'], + 'codFJ' => $this->iBodacc->getCodeFormeJur($ann['FJ']), + 'capital' => $ann['Capital'], + 'capitalDev' => $ann['CapitalDev'], + 'raisonSociale' => $ann['raisonSociale'], + 'nomCommercial' => $ann['nomCommercial'], + 'sigle' => $ann['sigle'], + 'adresse' => $adresseAnn, + 'dateInsertionSD' => $ann['dateInsert'], + 'evenements' => $tabRetEven, + 'complement' => $ann['complement'], + 'deleted' => $ann['deleted'], + 'texteAnnonce' => $ann['annonce'], + ); + $tabRet[] = $retFormat; } + // --- Formattage Histo + elseif ($ann['SourceTable'] == 'histo') { + if ($ann['JAL']==1) { + $Bodacc_Code='BODA'; + } elseif ($ann['JAL']==200) { + $Bodacc_Code='BODB'; + } + // 4xxx + if ($ann['CODEVE']<20) { + $rub='creations'; + } + // 5xxx + elseif ($ann['CODEVE']<=25) { + $rub='ventes'; + } + // 2xxx + elseif ($ann['CODEVE']<40) { + $rub='mmd'; + } + // 6xxx + elseif ($ann['CODEVE']<42) { + $rub='radiations'; + } + // 2xxx + elseif ($ann['CODEVE']<50) { + $rub='mmd'; + } + // 1xxx + elseif ($ann['CODEVE']<80) { + $rub='procol'; + } - $tabEvens = array(); - $newCodeEven = $this->HistoEvenConvert[$ann['CODEVE']]; - if ($newCodeEven*1 == 2318) { - $tabNewEven = explode(';', $this->HistoRoleConvert[$ann['ROLE']]); - if (count($tabNewEven) > 0) { - foreach ($tabNewEven as $newCodeEven) { + $tabEvens = array(); + $newCodeEven = $this->HistoEvenConvert[$ann['CODEVE']]; + if ($newCodeEven*1 == 2318) { + $tabNewEven = explode(';', $this->HistoRoleConvert[$ann['ROLE']]); + if (count($tabNewEven) > 0) { + foreach ($tabNewEven as $newCodeEven) { + $tabEvens[] = array( + 'CodeEven' => $newCodeEven, + 'LibEven' => $this->iBodacc->getEvenement($newCodeEven)); + } + } else { $tabEvens[] = array( 'CodeEven' => $newCodeEven, - 'LibEven' => $this->iBodacc->getEvenement($newCodeEven)); + 'LibEven' => $this->iBodacc->getEvenement($newCodeEven) + ); } } else { $tabEvens[] = array( 'CodeEven' => $newCodeEven, 'LibEven' => $this->iBodacc->getEvenement($newCodeEven) ); - } - } else { - $tabEvens[] = array( - 'CodeEven' => $newCodeEven, - 'LibEven' => $this->iBodacc->getEvenement($newCodeEven) - ); - // --- Detection plan - if ($this->AnnoncesLegalesVisu === false) { - $this->getAnnoncesLegalesPlan('histo', $this->Identite['FJ'], $ann); + // --- Detection plan + if ($this->AnnoncesLegalesVisu === false) { + $this->getAnnoncesLegalesPlan('histo', $this->Identite['FJ'], $ann); + } } - } - // Recherche du capital et de la FJ dans le texte histo - if (($ann['CODEVE']>=10 && $ann['CODEVE']<20) - || ($ann['CODEVE']>=30 && $ann['CODEVE']<42) - || ($ann['CODEVE']>=51 && $ann['CODEVE']<80)) { - // Recherche du capital - if (preg_match('/Capital(?:.|)\:(.*)(eur.|f|livre)/Uis', $ann['annonceTxt'], $matches)) { - $capital=trim(strtr($matches[1], array(' '=>'', ',00 '=>'', '.00 '=>'')))*1; - if (substr(strtoupper($matches[2]), 0, 3)=='EUR') { - $capitalDev = 'EUR'; - } elseif (substr(strtoupper($matches[2]), 0, 3)=='LIV') { - $capitalDev = 'GBP'; + // Recherche du capital et de la FJ dans le texte histo + if (($ann['CODEVE']>=10 && $ann['CODEVE']<20) + || ($ann['CODEVE']>=30 && $ann['CODEVE']<42) + || ($ann['CODEVE']>=51 && $ann['CODEVE']<80)) { + // Recherche du capital + if (preg_match('/Capital(?:.|)\:(.*)(eur.|f|livre)/Uis', $ann['annonceTxt'], $matches)) { + $capital=trim(strtr($matches[1], array(' '=>'', ',00 '=>'', '.00 '=>'')))*1; + if (substr(strtoupper($matches[2]), 0, 3)=='EUR') { + $capitalDev = 'EUR'; + } elseif (substr(strtoupper($matches[2]), 0, 3)=='LIV') { + $capitalDev = 'GBP'; + } else { + $capitalDev = 'FRF'; + } } else { - $capitalDev = 'FRF'; + $capital=$capitalDev=''; } - } else { - $capital=$capitalDev=''; - } - // Recherche de la forme juridique - if (preg_match('/Forme(?:.|)\:(.*)(Capital|Adresse|Activit.|Administration|Commentaire)(?:.|)\:/Uisu', $ann['annonceTxt'], $matches)) { - $libFJ = trim($matches[1]); - } - } - - // --- Retour histo - $retFormat = array( - 'id' => -$ann['ANBASE'], - 'BodaccCode' => $Bodacc_Code, - 'BodaccNum' => $ann['NOBOD'], - 'NumAnnonce' => $ann['NOANN'], - 'DateParution' => substr($ann['DATE'], 0, 4).'-'.substr($ann['DATE'], 4, 2).'-'.substr($ann['DATE'], 6, 2), - 'Departement' => $ann['DEPT'], - 'Tribunal' => $this->iBodacc->getTribunalNom($ann['CODTRI']), //$ann['triNom'], - 'TribunalSiret' => $this->iBodacc->getTribunalSiret($ann['CODTRI']),//$ann['triSiret'], - 'Rubrique' => $rub, - 'typeAnnonce' => 'Insertion', - 'dateEffet' => substr($ann['DATE'], 0, 4).'-'.substr($ann['DATE'], 4, 2).'-'.substr($ann['DATE'], 6, 2), - 'dateJugement' => substr($ann['DATE'], 0, 4).'-'.substr($ann['DATE'], 4, 2).'-'.substr($ann['DATE'], 6, 2), - 'dateFin' => '', - 'montantVente' => '', - 'libFJ' => $libFJ, - 'codFJ' => $this->iBodacc->getCodeFormeJur($libFJ), - 'capital' => $capital, - 'capitalDev' => $capitalDev, - 'raisonSociale' => '',//$ann['raisonSociale'], - 'nomCommercial' => '',//$ann['nomCommercial'], - 'sigle' => '',//$ann['sigle'], - 'adresse' => '',//$adresseAnn, - 'dateInsertionSD' => '', - 'evenements' => $tabEvens, - 'texteAnnonce' => $ann['NOANN'].' - '.$ann['annonceTxt'], - ); - $tabRet[] = $retFormat; - } - // --- Formattage Annonce - elseif ($ann['SourceTable'] == 'annonce') { - $rubriqueRet = ''; - $tabInter = array( - 'A' => 'Administrateur judiciaire', - 'M' => 'Mandataire judiciaire', - 'H' => 'Huissier', - 'L' => 'Liquidateur', - 'R' => 'Représentant des Créanciers', - 'O' => 'Opposition', - 'U' => 'Curateur', - 'C' => 'Commissaire au plan', - 'S' => 'Syndic', - 'D' => 'Commissaire au concordat', - 'T' => 'Conciliateur', - 'V' => 'Avocat', - 'N' => 'Notaire', - 'J' => 'Juge Commissaire', - 'K' => 'Juge Commissaire Suppléant', - ); - $dept = substr($ann['triCP'], 0, 2)*1; - $depotComptes = false; - if ($dept==97) { - $dept = substr($ann['triCP'], 0, 3)*1; - } - $adresse=''; - - /** Ajout des informations identitaires pour les annonces collecte avant Décembre 2008 **/ - if (trim($ann['raisonSociale'])=='' || trim($ann['adresse'])=='' - || trim($ann['codePostal'])=='' || trim($ann['ville'])=='') { - $ann['raisonSociale'] = $this->Identite['Nom']; - $ann['adresse'] = $this->Identite['Adresse']; - $ann['codePostal'] = $this->Identite['CP']; - $ann['ville'] = $this->Identite['Ville']; - } - $adresse.=ucfirst(strtolower($ann['adresse'])).', '; - - $adresse=trim(preg_replace('/^0+/', '', preg_replace('/ +/', ' ', $adresse))); - if (preg_match('/(3100|3200|3300|3999)/', $ann['typeEven'].';'.$ann['strEven'])) { - $depotComptes = true; - $strRCS = 'Siren : '. $ann['siren'] . '. '; - } else { - $strRCS = $ann['siren'] . ' RCS '. ucfirst(strtolower(strtr($ann['triNom'], array('TGIcc '=>'', 'TGI '=>'', 'TC '=>'', 'TI '=>'', )))).'. '; - } - - $texteAnnonce = 'Date : '.strtolower(Metier_Util_Date::dateT('Y-m-d', 'd M Y', $ann['dateJugement'])) .'. '. $this->iBodacc->getEvenement($ann['typeEven']).'. '. - $strRCS . trim($ann['raisonSociale']). '. Adresse : '. $adresse.' '.$ann['codePostal'].' '.$ann['ville'].'. '; - - if (trim($ann['numero']) != '') { - $texteAnnonce.='Jugement Numéro : '.trim($ann['numero']).'. '; - } - - if ($ann['dateCessationPaiement']*1 != 0) { - $texteAnnonce.='Cessation des paiements le '.strtolower(Metier_Util_Date::dateT('Y-m-d', 'd M Y', $ann['dateCessationPaiement'])).'. '; - } - - for ($mandNum = 1; $mandNum < 5; $mandNum++) { - if (trim($ann['inter'.$mandNum.'type']) != '' - && ($ann['inter'.$mandNum.'id']>0 || trim($ann['inter'.$mandNum.'nom']) != '')) { - $texteAnnonce.= $tabInter[$ann['inter'.$mandNum.'type']].' : '.$ann['inter'.$mandNum.'nom']; - if ($ann['inter'.$mandNum.'id'] != 0) { - $mandStmt = $this->conn->executeQuery("SELECT sirenGrp, sirenMand, - tel, fax, email FROM jo.tabMandataires - WHERE id=".$ann['inter'.$mandNum.'id']); - $mand = $mandStmt->fetch(\PDO::FETCH_ASSOC); - if ($mand['sirenGrp'] != 0) { - $texteAnnonce.= ', Siren SCP '.$mand['sirenGrp']; - } - if ($mand['sirenMand'] != 0) { - $texteAnnonce.= ', Siren '.$mand['sirenMand']; - } - if ($mand['tel'] != '') { - $texteAnnonce.= ', Telephone '.$mand['tel']; - } - if ($mand['fax'] != '') { - $texteAnnonce.= ', Telecopie '.$mand['fax']; - } - if ($mand['email'] != '') { - $texteAnnonce.= ', E-mail : '.$mand['email']; + // Recherche de la forme juridique + if (preg_match('/Forme(?:.|)\:(.*)(Capital|Adresse|Activit.|Administration|Commentaire)(?:.|)\:/Uisu', $ann['annonceTxt'], $matches)) { + $libFJ = trim($matches[1]); } } - $texteAnnonce.= '. '; - } - } - if (trim($ann['nouvActivite']) != '') { - $texteAnnonce.= ' Activité : '.trim($ann['nouvActivite']).'. '; - } - if (trim($ann['nouvDir']) != '') { - $texteAnnonce.= ' Administration : '.trim($ann['nouvDir']).'. '; - } - if (trim($ann['nouvAdr']) != '') { - $texteAnnonce.= ' Nouvelle adresse : '.trim($ann['nouvAdr']).'. '; - } - if ($ann['nouvFJ']*1 > 0) { - $texteAnnonce.= ' Transformation de la société en '.$this->getLibelleFJ($ann['nouvFJ']).'. '; - } - - if ($ann['dateEffetFinP']*1 != '') { - if ($depotComptes) { - $texteAnnonce.= ' Comptes annuels et rapports de l\'exercice clos le : '. - strtolower(Metier_Util_Date::dateT('Y-m-d', 'd M Y', $ann['dateEffetFinP'])).'. '; - } else { - $texteAnnonce.= ' Date d\'effet : '. - strtolower(Metier_Util_Date::dateT('Y-m-d', 'd M Y', $ann['dateEffetFinP'])).'. '; - } - } - - if (trim($ann['complement']) != '') { - $texteAnnonce.= ' Observations : '.trim($ann['complement']).'.'; - } - - $tabRetEven = array(); - $tabRetEven[] = array( - 'CodeEven' => $ann['typeEven'], - 'LibEven' => $this->iBodacc->getEvenement($ann['typeEven']) - ); - if ($ann['typeEven']==2102 || $ann['typeEven']==2100) { - $capital = true; - } else { - $capital = false; - } - - if (trim($ann['strEven']) != '') { - $tabEven = explode(';', $ann['strEven']); - foreach ($tabEven as $even) { - $tabRetEven[] = array( - 'CodeEven' => $even, - 'LibEven' => $this->iBodacc->getEvenement($even) + // --- Retour histo + $retFormat = array( + 'id' => -$ann['ANBASE'], + 'BodaccCode' => $Bodacc_Code, + 'BodaccNum' => $ann['NOBOD'], + 'NumAnnonce' => $ann['NOANN'], + 'DateParution' => substr($ann['DATE'], 0, 4).'-'.substr($ann['DATE'], 4, 2).'-'.substr($ann['DATE'], 6, 2), + 'Departement' => $ann['DEPT'], + 'Tribunal' => $this->iBodacc->getTribunalNom($ann['CODTRI']), //$ann['triNom'], + 'TribunalSiret' => $this->iBodacc->getTribunalSiret($ann['CODTRI']),//$ann['triSiret'], + 'Rubrique' => $rub, + 'typeAnnonce' => 'Insertion', + 'dateEffet' => substr($ann['DATE'], 0, 4).'-'.substr($ann['DATE'], 4, 2).'-'.substr($ann['DATE'], 6, 2), + 'dateJugement' => substr($ann['DATE'], 0, 4).'-'.substr($ann['DATE'], 4, 2).'-'.substr($ann['DATE'], 6, 2), + 'dateFin' => '', + 'montantVente' => '', + 'libFJ' => $libFJ, + 'codFJ' => $this->iBodacc->getCodeFormeJur($libFJ), + 'capital' => $capital, + 'capitalDev' => $capitalDev, + 'raisonSociale' => '',//$ann['raisonSociale'], + 'nomCommercial' => '',//$ann['nomCommercial'], + 'sigle' => '',//$ann['sigle'], + 'adresse' => '',//$adresseAnn, + 'dateInsertionSD' => '', + 'evenements' => $tabEvens, + 'texteAnnonce' => $ann['NOANN'].' - '.$ann['annonceTxt'], ); - if ($even>=1000 && $even<2000) { - $rubriqueRet = 'procol'; - } elseif ($even>=2000 && $even<3000) { - $rubriqueRet='mmd'; - } elseif ($even>=3000 && $even<4000) { - $rubriqueRet = 'comptes'; - } elseif ($even>=4000 && $even<5000) { - $rubriqueRet = 'creations'; - } elseif ($even>=5000 && $even<6000) { - $rubriqueRet = 'ventes'; - } elseif ($even>=6000 && $even<7000) { - $rubriqueRet = 'radiations'; - } - if ($even==2102 || $even==2100) { - $capital = true; - } + $tabRet[] = $retFormat; + } + // --- Formattage Annonce + elseif ($ann['SourceTable'] == 'annonce') { + $rubriqueRet = ''; + $tabInter = array( + 'A' => 'Administrateur judiciaire', + 'M' => 'Mandataire judiciaire', + 'H' => 'Huissier', + 'L' => 'Liquidateur', + 'R' => 'Représentant des Créanciers', + 'O' => 'Opposition', + 'U' => 'Curateur', + 'C' => 'Commissaire au plan', + 'S' => 'Syndic', + 'D' => 'Commissaire au concordat', + 'T' => 'Conciliateur', + 'V' => 'Avocat', + 'N' => 'Notaire', + 'J' => 'Juge Commissaire', + 'K' => 'Juge Commissaire Suppléant', + ); + $dept = substr($ann['triCP'], 0, 2)*1; + $depotComptes = false; + if ($dept==97) { + $dept = substr($ann['triCP'], 0, 3)*1; } - } + $adresse=''; - // --- Detection plan - if ($this->AnnoncesLegalesVisu === false) { - $this->getAnnoncesLegalesPlan('annonce', $this->Identite['FJ'], $ann); - } - - $strVente=''; - $nouvCapital=''; - if ($ann['montant']>0) { - if ($capital) { - $nouvCapital=$ann['montant']; - $texteAnnonce.=' Nouveau capital : '.trim($ann['montant']). ' euros'; - if ($ann['actionsNb']>0) { - $texteAnnonce.=' divisé en '.$ann['actionsNb'].' actions de '. round($ann['montant']/$ann['actionsNb']). ' euros'; + /** Ajout des informations identitaires pour les annonces collecte avant Décembre 2008 **/ + if (trim($ann['raisonSociale'])=='' || trim($ann['adresse'])=='' + || trim($ann['codePostal'])=='' || trim($ann['ville'])=='') { + $ann['raisonSociale'] = $this->Identite['Nom']; + $ann['adresse'] = $this->Identite['Adresse']; + $ann['codePostal'] = $this->Identite['CP']; + $ann['ville'] = $this->Identite['Ville']; + } + $adresse.= ucfirst(strtolower($ann['adresse'])).', '; + $adresse = trim(preg_replace('/^0+/', '', preg_replace('/ +/', ' ', $adresse))); + if (preg_match('/(3100|3200|3300|3999)/', $ann['typeEven'].';'.$ann['strEven'])) { + $depotComptes = true; + $strRCS = 'Siren : '. $ann['siren'] . '. '; + } else { + $strRCS = $ann['siren'] . ' RCS '. ucfirst(strtolower(strtr($ann['triNom'], array('TGIcc '=>'', 'TGI '=>'', 'TC '=>'', 'TI '=>'', )))).'. '; } - } elseif (!preg_match('/ pour un montant de /Uis', $ann['complement'])) { - $texteAnnonce.=' Montant : '.trim($ann['montant']). ' euros'; - $strVente=trim($ann['montant']). ' EUR'; - } - $texteAnnonce.='. '; - } - // On ne prend l'annonce saisie directement que si elle est plus volumineuse - if (trim($ann['annonce']) != '' && strlen(trim($ann['annonce']))>strlen($texteAnnonce)) { - $texteAnnonce=trim($ann['annonce']); - } + $texteAnnonce = 'Date : '.strtolower(Metier_Util_Date::dateT('Y-m-d', 'd M Y', $ann['dateJugement'])).'. '. + $this->iBodacc->getEvenement($ann['typeEven']).'. '. + $strRCS . trim($ann['raisonSociale']).'. Adresse : '. + $adresse.' '.$ann['codePostal'].' '.$ann['ville'].'. '; - $texteAnnonce = preg_replace('/ +/', ' ', strtr($texteAnnonce, array('*'=>' ', '/'=>' ', '..'=>'.'))); + if (trim($ann['numero']) != '') { + $texteAnnonce.='Jugement Numéro : '.trim($ann['numero']).'. '; + } - if (str_replace('-', '', $ann['dateSource'])*1 != 0) { - $dateParution = $ann['dateSource']; - } else { - $dateParution = $ann['dateInsert']; - } + if ($ann['dateCessationPaiement']*1 != 0) { + $texteAnnonce.='Cessation des paiements le '.strtolower(Metier_Util_Date::dateT('Y-m-d', 'd M Y', $ann['dateCessationPaiement'])).'. '; + } - $retFormat = array( - 'id' => '0.'.$ann['id'], - 'BodaccCode' => $ann['source'].'-'.$ann['parutionIdJal'], - 'BodaccNum' => $ann['parutionNum'], - 'NumAnnonce' => 0, - 'DateParution' => $dateParution, - 'Departement' => $dept, - 'Tribunal' => $ann['triNom'], - 'TribunalSiret' => $ann['triSiret'], - 'Rubrique' => $rubriqueRet, - 'typeAnnonce' => 'insertion', - 'dateEffet' => $ann['dateCessationPaiement'], - 'dateJugement' => $ann['dateJugement'], - 'dateFin' => $ann['dateEffetFinP'], - 'montantVente' => $strVente, - 'libFJ' => $ann['nouvFJ'], - 'codFJ' => $this->iBodacc->getCodeFormeJur($ann['nouvFJ']), - 'capital' => $nouvCapital, - 'capitalDev' => 'EUR', - 'raisonSociale' => $ann['raisonSociale'], - 'nomCommercial' => '', - 'sigle' => '', - 'adresse' => $ann['nouvAdr'], - 'dateInsertionSD' => $ann['dateInsert'], - 'evenements' => $tabRetEven, - 'texteAnnonce' => $texteAnnonce, - 'complement' => $ann['complement'], - ); - if ($depotComptes) { - $retFormat['dateEffet'] = $ann['dateEffetFinP']; + for ($mandNum = 1; $mandNum < 5; $mandNum++) { + if (trim($ann['inter'.$mandNum.'type']) != '' + && ($ann['inter'.$mandNum.'id']>0 || trim($ann['inter'.$mandNum.'nom']) != '')) { + $texteAnnonce.= $tabInter[$ann['inter'.$mandNum.'type']].' : '.$ann['inter'.$mandNum.'nom']; + if ($ann['inter'.$mandNum.'id'] != 0) { + $mandStmt = $this->conn->executeQuery( + "SELECT sirenGrp, sirenMand, tel, fax, email + FROM jo.tabMandataires WHERE id=".$ann['inter'.$mandNum.'id']); + $mand = $mandStmt->fetch(\PDO::FETCH_ASSOC); + if ($mand['sirenGrp'] != 0) { + $texteAnnonce.= ', Siren SCP '.$mand['sirenGrp']; + } + if ($mand['sirenMand'] != 0) { + $texteAnnonce.= ', Siren '.$mand['sirenMand']; + } + if ($mand['tel'] != '') { + $texteAnnonce.= ', Telephone '.$mand['tel']; + } + if ($mand['fax'] != '') { + $texteAnnonce.= ', Telecopie '.$mand['fax']; + } + if ($mand['email'] != '') { + $texteAnnonce.= ', E-mail : '.$mand['email']; + } + } + $texteAnnonce.= '. '; + } + } + + if (trim($ann['nouvActivite']) != '') { + $texteAnnonce.= ' Activité : '.trim($ann['nouvActivite']).'. '; + } + if (trim($ann['nouvDir']) != '') { + $texteAnnonce.= ' Administration : '.trim($ann['nouvDir']).'. '; + } + if (trim($ann['nouvAdr']) != '') { + $texteAnnonce.= ' Nouvelle adresse : '.trim($ann['nouvAdr']).'. '; + } + if ($ann['nouvFJ']*1 > 0) { + $texteAnnonce.= ' Transformation de la société en '.$this->getLibelleFJ($ann['nouvFJ']).'. '; + } + + if ($ann['dateEffetFinP']*1 != '') { + if ($depotComptes) { + $texteAnnonce.= ' Comptes annuels et rapports de l\'exercice clos le : '. + strtolower(Metier_Util_Date::dateT('Y-m-d', 'd M Y', $ann['dateEffetFinP'])).'. '; + } else { + $texteAnnonce.= ' Date d\'effet : '. + strtolower(Metier_Util_Date::dateT('Y-m-d', 'd M Y', $ann['dateEffetFinP'])).'. '; + } + } + + if (trim($ann['complement']) != '') { + $texteAnnonce.= ' Observations : '.trim($ann['complement']).'.'; + } + + $tabRetEven = array(); + $tabRetEven[] = array( + 'CodeEven' => $ann['typeEven'], + 'LibEven' => $this->iBodacc->getEvenement($ann['typeEven']) + ); + if ($ann['typeEven']==2102 || $ann['typeEven']==2100) { + $capital = true; + } else { + $capital = false; + } + + if (trim($ann['strEven']) != '') { + $tabEven = explode(';', $ann['strEven']); + foreach ($tabEven as $even) { + $tabRetEven[] = array( + 'CodeEven' => $even, + 'LibEven' => $this->iBodacc->getEvenement($even) + ); + if ($even>=1000 && $even<2000) { + $rubriqueRet = 'procol'; + } elseif ($even>=2000 && $even<3000) { + $rubriqueRet='mmd'; + } elseif ($even>=3000 && $even<4000) { + $rubriqueRet = 'comptes'; + } elseif ($even>=4000 && $even<5000) { + $rubriqueRet = 'creations'; + } elseif ($even>=5000 && $even<6000) { + $rubriqueRet = 'ventes'; + } elseif ($even>=6000 && $even<7000) { + $rubriqueRet = 'radiations'; + } + if ($even==2102 || $even==2100) { + $capital = true; + } + } + } + + // --- Detection plan + if ($this->AnnoncesLegalesVisu === false) { + $this->getAnnoncesLegalesPlan('annonce', $this->Identite['FJ'], $ann); + } + + $strVente=''; + $nouvCapital=''; + if ($ann['montant']>0) { + if ($capital) { + $nouvCapital=$ann['montant']; + $texteAnnonce.=' Nouveau capital : '.trim($ann['montant']). ' euros'; + if ($ann['actionsNb']>0) { + $texteAnnonce.=' divisé en '.$ann['actionsNb'].' actions de '. round($ann['montant']/$ann['actionsNb']). ' euros'; + } + } elseif (!preg_match('/ pour un montant de /Uis', $ann['complement'])) { + $texteAnnonce.=' Montant : '.trim($ann['montant']). ' euros'; + $strVente=trim($ann['montant']). ' EUR'; + } + $texteAnnonce.='. '; + } + + // On ne prend l'annonce saisie directement que si elle est plus volumineuse + if (trim($ann['annonce']) != '' && strlen(trim($ann['annonce']))>strlen($texteAnnonce)) { + $texteAnnonce=trim($ann['annonce']); + } + + $texteAnnonce = preg_replace('/ +/', ' ', strtr($texteAnnonce, array('*'=>' ', '/'=>' ', '..'=>'.'))); + + if (str_replace('-', '', $ann['dateSource'])*1 != 0) { + $dateParution = $ann['dateSource']; + } else { + $dateParution = $ann['dateInsert']; + } + + $retFormat = array( + 'id' => '0.'.$ann['id'], + 'BodaccCode' => $ann['source'].'-'.$ann['parutionIdJal'], + 'BodaccNum' => $ann['parutionNum'], + 'NumAnnonce' => 0, + 'DateParution' => $dateParution, + 'Departement' => $dept, + 'Tribunal' => $ann['triNom'], + 'TribunalSiret' => $ann['triSiret'], + 'Rubrique' => $rubriqueRet, + 'typeAnnonce' => 'insertion', + 'dateEffet' => $ann['dateCessationPaiement'], + 'dateJugement' => $ann['dateJugement'], + 'dateFin' => $ann['dateEffetFinP'], + 'montantVente' => $strVente, + 'libFJ' => $ann['nouvFJ'], + 'codFJ' => $this->iBodacc->getCodeFormeJur($ann['nouvFJ']), + 'capital' => $nouvCapital, + 'capitalDev' => 'EUR', + 'raisonSociale' => $ann['raisonSociale'], + 'nomCommercial' => '', + 'sigle' => '', + 'adresse' => $ann['nouvAdr'], + 'dateInsertionSD' => $ann['dateInsert'], + 'evenements' => $tabRetEven, + 'texteAnnonce' => $texteAnnonce, + 'complement' => $ann['complement'], + ); + if ($depotComptes) { + $retFormat['dateEffet'] = $ann['dateEffetFinP']; + } + $tabRet[] = $retFormat; + } + } // --- Fin du parcours des annonces + + // --- Effacement procol + if ($this->AnnoncesLegalesVisu === false) { + if ($this->getAnnoncesLegalesEffacement($siren, $rubrique, $tabRet) === true) { + return array(); } - $tabRet[] = $retFormat; - } - } // --- Fin du parcours des annonces - - // --- Effacement procol - if ($this->AnnoncesLegalesVisu === false) { - if ($this->getAnnoncesLegalesEffacement($siren, $rubrique, $tabRet) === true) { - return array(); } } + } catch (\Doctrine\DBAL\DBALException $e) { + if ($this->logger !== null) { + $this->logger->error($e->getMessage()); + } } return $tabRet; diff --git a/src/Metier/Liens/Base.php b/src/Metier/Liens/Base.php index 0ca90f7..7b083be 100755 --- a/src/Metier/Liens/Base.php +++ b/src/Metier/Liens/Base.php @@ -208,8 +208,10 @@ class Metier_Liens_Base $sql = "SELECT LPAD(siren, 9, 0) AS siren FROM jo.liensRef WHERE id = :id"; $stmt = $this->conn->prepare($sql); $stmt->bindValue('id', $this->idRef); - $result = $stmt->fetch(\PDO::FETCH_OBJ); - $siren = $result->siren; + if ($stmt->rowCount() > 0) { + $result = $stmt->fetch(\PDO::FETCH_OBJ); + $siren = $result->siren; + } } else { $siren = $this->siren; } diff --git a/src/Metier/Partenaires/MBilans.php b/src/Metier/Partenaires/MBilans.php index dc7187c..52a14ef 100644 --- a/src/Metier/Partenaires/MBilans.php +++ b/src/Metier/Partenaires/MBilans.php @@ -402,11 +402,12 @@ class Metier_Partenaires_MBilans $exercice = substr($tmp, 0, 8); $type = substr($tmp, 9, 1); $ref = $tabRet[''.$typeMillesime]['ref']; + // Suppression du bilan RN de la liste si Réel Normal et Réel Simplifiés présents en base if ($exercice == $exercicePre && $type == 'N' && $typePre == 'S' && $refPre == '') { - // Suppression du bilan RN de la liste si Réel Normal et Réel Simplifiés présents en base unset($tabTri[$tmp]); - } elseif ($exercice == $exercicePre && $type == 'N' && $typePre == 'S' && $refPre != '') { - // Suppression du bilan RS de la liste si Réel Normal Présent en base et réel simplifié non encore en base + } + // Suppression du bilan RS de la liste si Réel Normal Présent en base et réel simplifié non encore en base + elseif ($exercice == $exercicePre && $type == 'N' && $typePre == 'S' && $refPre != '') { if ($tmpPre !== false) { unset($tabTri[$tmpPre]); } @@ -451,15 +452,15 @@ class Metier_Partenaires_MBilans $fields = "dateProvPartenaire, dateExercice, dateExercicePre, dureeExercice, dureeExercicePre, monnaie, typeBilan, monnaieOrigine, unite, postes, partenaire, id, confidentiel, dateInsert"; $where = "siren=:siren AND typeBilan=:typeBilan AND dateExercice=:clotureDate"; + // On ne veut pas de bilans "Téléchargés" directement sur Internet if ($accesPartenaire) { - // On ne veut pas de bilans "Téléchargés" directement sur Internet $where.= " AND partenaire!=7"; } // --- Selection du premier bilan $bilanNb = 0; try { - $bilanSql = "SELECT $fields FROM jo.bilans WHERE $where LIMIT 0,1"; + $bilanSql = "SELECT $fields FROM jo.bilans WHERE $where ORDER BY confidentiel ASC LIMIT 0,1"; $bilanStmt = $this->conn->prepare($bilanSql); $bilanStmt->bindValue('siren', $this->siren); $bilanStmt->bindValue('typeBilan', $typeBilan); diff --git a/src/Metier/Scores/Data/Formules.php b/src/Metier/Scores/Data/Formules.php index 474c5f1..607e211 100644 --- a/src/Metier/Scores/Data/Formules.php +++ b/src/Metier/Scores/Data/Formules.php @@ -66,12 +66,12 @@ return array( 7 => array( 'id' => 7, 'libelle' => "Résultat courant avant impots", - 'commentaires' => "Bénéfice ou perte constaté avant affectation des produits ou charges exceptionnelles, déduction des impôts et participation au bénéfice. Il est égal aux : -produits d'exploitation (notamment les sommes reçues qui relèvent de l'activité de l'entreprise, soit les ventes de biens, prestations de services etc..) -+ quotes-parts de résultats sur opérations faites en commun(par exemple, résultat des opérations faites par l'intermédiaire d'une société en participation) -+ produits financiers (intérêts courus, gains de change, revenus tirés des comptes en banque) -- charges d'exploitation -- quotes-parts de charges sur opérations en commun + 'commentaires' => "Bénéfice ou perte constaté avant affectation des produits ou charges exceptionnelles, déduction des impôts et participation au bénéfice. Il est égal aux : +produits d'exploitation (notamment les sommes reçues qui relèvent de l'activité de l'entreprise, soit les ventes de biens, prestations de services etc..) ++ quotes-parts de résultats sur opérations faites en commun(par exemple, résultat des opérations faites par l'intermédiaire d'une société en participation) ++ produits financiers (intérêts courus, gains de change, revenus tirés des comptes en banque) +- charges d'exploitation +- quotes-parts de charges sur opérations en commun - charges financières.", 'unite' => 'EUR', 'borneMin' => '', @@ -198,17 +198,17 @@ produits d'exploitation (notamment les sommes reçues qui relèvent de l'activit 21 => array( 'id' => 22, 'libelle' => "Total bilan", - 'commentaires' => "Le total du bilan est la somme de tous les actifs ainsi que des passifs, il caractérise la taille de l'entreprise. -Selon le décret n° 2008-1354 du 18 décembre 2008, les critères désormais retenus pour les besoins de l'analyse statistique et économique sont les suivants : -La catégorie des micro entreprises est constituée des entreprises qui : - * d'une part occupent moins de 10 personnes ; - * d'autre part ont un chiffre d'affaires annuel ou un total de bilan n'excédant pas 2 millions d'euros. -La catégorie des petites et moyennes entreprises (PME) est constituée des entreprises qui : - * d'une part occupent moins de 250 personnes ; - * d'autre part ont un chiffre d'affaires annuel n'excédant pas 50 millions d'euros ou un total de bilan n'excédant pas 43 millions d'euros. -La catégorie des entreprises de taille intermédiaire (ETI) est constituée des entreprises qui n'appartiennent pas à la catégorie des petites et moyennes entreprises, et qui : - * d'une part occupent moins de 5 000 personnes ; - * d'autre part ont un chiffre d'affaires annuel n'excédant pas 1 500 millions d'euros ou un total de bilan n'excédant pas 2 000 millions d'euros. + 'commentaires' => "Le total du bilan est la somme de tous les actifs ainsi que des passifs, il caractérise la taille de l'entreprise. +Selon le décret n° 2008-1354 du 18 décembre 2008, les critères désormais retenus pour les besoins de l'analyse statistique et économique sont les suivants : +La catégorie des micro entreprises est constituée des entreprises qui : + * d'une part occupent moins de 10 personnes ; + * d'autre part ont un chiffre d'affaires annuel ou un total de bilan n'excédant pas 2 millions d'euros. +La catégorie des petites et moyennes entreprises (PME) est constituée des entreprises qui : + * d'une part occupent moins de 250 personnes ; + * d'autre part ont un chiffre d'affaires annuel n'excédant pas 50 millions d'euros ou un total de bilan n'excédant pas 43 millions d'euros. +La catégorie des entreprises de taille intermédiaire (ETI) est constituée des entreprises qui n'appartiennent pas à la catégorie des petites et moyennes entreprises, et qui : + * d'une part occupent moins de 5 000 personnes ; + * d'autre part ont un chiffre d'affaires annuel n'excédant pas 1 500 millions d'euros ou un total de bilan n'excédant pas 2 000 millions d'euros. La catégorie des grandes entreprises (GE) est constituée des entreprises qui ne sont pas classées dans les catégories précédentes.", 'unite' => 'EUR', 'borneMin' => '', @@ -227,10 +227,10 @@ La catégorie des grandes entreprises (GE) est constituée des entreprises qui n 23 => array( 'id' => 24, 'libelle' => "Effectif (sans décimales)", - 'commentaires' => "La définition exacte de l'effectif peut varier selon les sources : -DADS : effectif salarié instantané au 30 juin ; -SIRENE : effectif salarié au 31 décembre n (ou au 1er janvier n+1) ; cet effectif fait l'objet d'une mise à jour « de masse » au premier semestre à partir des données DADS, l'effectif d'une entreprise est alors la somme des effectifs de ses établissements au 31 décembre; -SUSE-FICUS : moyenne annuelle de l'effectif salarié. + 'commentaires' => "La définition exacte de l'effectif peut varier selon les sources : +DADS : effectif salarié instantané au 30 juin ; +SIRENE : effectif salarié au 31 décembre n (ou au 1er janvier n+1) ; cet effectif fait l'objet d'une mise à jour « de masse » au premier semestre à partir des données DADS, l'effectif d'une entreprise est alors la somme des effectifs de ses établissements au 31 décembre; +SUSE-FICUS : moyenne annuelle de l'effectif salarié. Dans un bilan c'est la moyenne de l'effectif de l'exercice.", 'unite' => 'Pers.', 'borneMin' => '', @@ -348,9 +348,9 @@ Dans un bilan c'est la moyenne de l'effectif de l'exercice.", 36 => array( 'id' => 63, 'libelle' => "Trésorerie active", - 'commentaires' => "La trésorerie active est constituée de l'ensemble des éléments liquides. A savoir : -- les valeurs mobilières de placement (ensemble des actifs financiers acquis par l'entreprise mais qui n'ont pas de valeur stratégique et qui visent plutôt à réaliser des plus-values). -- l'ensemble des disponibilités déposées sur le compte bancaire de l'entreprise. + 'commentaires' => "La trésorerie active est constituée de l'ensemble des éléments liquides. A savoir : +- les valeurs mobilières de placement (ensemble des actifs financiers acquis par l'entreprise mais qui n'ont pas de valeur stratégique et qui visent plutôt à réaliser des plus-values). +- l'ensemble des disponibilités déposées sur le compte bancaire de l'entreprise. - son fond de caisse.", 'unite' => 'EUR', 'borneMin' => '', @@ -360,9 +360,9 @@ Dans un bilan c'est la moyenne de l'effectif de l'exercice.", 37 => array( 'id' => 64, 'libelle' => "Trésorerie active 12 mois", - 'commentaires' => "Trésorerie active rapporté à 12 mois; elle est constituée de l'ensemble des éléments liquides. A savoir : -- les valeurs mobilières de placement (ensemble des actifs financiers acquis par l'entreprise mais qui n'ont pas de valeur stratégique et qui visent plutôt à réaliser des plus-values). -- l'ensemble des disponibilités déposées sur le compte bancaire de l'entreprise. + 'commentaires' => "Trésorerie active rapporté à 12 mois; elle est constituée de l'ensemble des éléments liquides. A savoir : +- les valeurs mobilières de placement (ensemble des actifs financiers acquis par l'entreprise mais qui n'ont pas de valeur stratégique et qui visent plutôt à réaliser des plus-values). +- l'ensemble des disponibilités déposées sur le compte bancaire de l'entreprise. - son fond de caisse.", 'unite' => 'EUR', 'borneMin' => '', @@ -1155,7 +1155,7 @@ Dans un bilan c'est la moyenne de l'effectif de l'exercice.", 125 => array( 'id' => 231, 'libelle' => "FR (FONDS DE ROULEMENT)", - 'commentaires' => "Le fonds de roulement représente la différence entre l'actif à court terme et le passif à court terme (dont l'échéance est de moins de douze mois). Un fonds de roulement positif indique qu'une entreprise a suffisamment d'actifs liquides pour régler ses dettes et engagements à court terme (12 mois). + 'commentaires' => "Le fonds de roulement représente la différence entre l'actif à court terme et le passif à court terme (dont l'échéance est de moins de douze mois). Un fonds de roulement positif indique qu'une entreprise a suffisamment d'actifs liquides pour régler ses dettes et engagements à court terme (12 mois). Dans certains cas particuliers, le FDR peut être négatif et l'entreprise viable : GSA ou autre Hypermarchés par exemple. Cette situation devenant risquée en cas de baisse du CA.", 'unite' => 'EUR', 'borneMin' => '', @@ -1183,7 +1183,7 @@ Dans certains cas particuliers, le FDR peut être négatif et l'entreprise viabl 128 => array( 'id' => 234, 'libelle' => "COUVERTURE du BFR (FR/BFR)", - 'commentaires' => "Si le FR>BFR, la trésorerie est positive, l'entreprise dispose de disponibilités. Si le FR "Si le FR>BFR, la trésorerie est positive, l'entreprise dispose de disponibilités. Si le FR est inférieur au BFR, la trésorerie est négative, l'entreprise doit se financer à court terme auprès des banques au moyen de concours bancaires courants. Une trésorerie négative d'une manière régulière est souvent la cause d'une mauvaise politique financière. Si les besoins de financement sont à caractère permanent, ils devraient être financés par des ressources permanentes et non des crédits de trésorerie. Il arrive que dans certaines entreprises le BFR soit structurellement négatif, c'est le cas pour certains secteurs du commerce, en grande distribution par exemple. Cela vient du fait que le crédit fournisseur est long voir très long. Les immobilisations deviennent des ressources permanentes puisqu'elles sont financées en partie par l'exploitation.", 'unite' => '%', 'borneMin' => '-800', 'borneMax' => '800', @@ -1315,7 +1315,7 @@ dettes a + 1 an / capitaux propres", 'id' => 248, 'libelle' => "FINANCEMENT DES STOCKS dettes aux fournisseurs / stock", - 'commentaires' => "Vous pouvez agir sur votre trésorerie disponible en exigeant des délais de règlement plus longs de la part de vos fournisseurs - cela tout en vous conformant à la loi LME relative aux délais de paiement, qui, depuis le 1er janvier 2009, impose à l'ensemble des entreprises un paiement à 60 jours, hors accords dérogatoires. Pour la plupart des entreprises, les règlements clients interviennent après les règlements des achats et des charges. Ainsi, les dettes courantes (dettes liées au cycle d'exploitation : fournisseurs, social) sont \"insuffisantes\" pour couvrir le financement des stocks. Plus difficile pour les petites entreprises que pour les entreprises de taille importante, vous pouvez néanmoins jouer sur la mise en concurrence et challenger régulièrement vos fournisseurs en place.", + 'commentaires' => "Vous pouvez agir sur votre trésorerie disponible en exigeant des délais de règlement plus longs de la part de vos fournisseurs - cela tout en vous conformant à la loi LME relative aux délais de paiement, qui, depuis le 1er janvier 2009, impose à l'ensemble des entreprises un paiement à 60 jours, hors accords dérogatoires. Pour la plupart des entreprises, les règlements clients interviennent après les règlements des achats et des charges. Ainsi, les dettes courantes (dettes liées au cycle d'exploitation : fournisseurs, social) sont 'insuffisantes' pour couvrir le financement des stocks. Plus difficile pour les petites entreprises que pour les entreprises de taille importante, vous pouvez néanmoins jouer sur la mise en concurrence et challenger régulièrement vos fournisseurs en place.", 'unite' => '%', 'borneMin' => '-800', 'borneMax' => '800', @@ -2518,7 +2518,7 @@ chiffre d'affaire/actif comptable", 275 => array( 'id' => 573, 'libelle' => "Flux de trésorerie interne (A)", - 'commentaires' => "Le flux de trésorerie interne est un indicateur permettant de mesurer le degré de liberté de + 'commentaires' => "Le flux de trésorerie interne est un indicateur permettant de mesurer le degré de liberté de l'entreprise par sa capacité à investir et à se désendetter. Il informe sur le degré de maîtrise des mouvements de trésorerie ainsi que sur la cohérence des politiques suivies.", 'unite' => 'EUR', 'borneMin' => '', diff --git a/src/Metier/Scores/MScores.php b/src/Metier/Scores/MScores.php index ccbe793..9d3e231 100644 --- a/src/Metier/Scores/MScores.php +++ b/src/Metier/Scores/MScores.php @@ -13,17 +13,17 @@ function getIndiscoreHisto($siren) 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 + $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); @@ -77,12 +77,12 @@ 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 + $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"; $iDb = new Metier_Util_Db(); $ret = $iDb->query($query); @@ -138,7 +138,7 @@ function getScoreSecteur($naf5) return false; } $tabTmp = $iDb->select('jo.scores_surveillance', - 'naf, AVG(indiScore) AS score100moy, AVG(indiScore20) AS score20moy, + '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) { @@ -2252,6 +2252,7 @@ function calculIndiScore($siren, $nic=0, $accesDist=false, $cycleClient=2, $mail } $timer['participations']=microtime(true); + // Début du calcul de la note $tabBil=array(); if ($NBBILAN == 0) { $noteSolvabilite = round($noteStructure) * 5; // La note finale est sur 100 @@ -3726,7 +3727,7 @@ function calculIndiScore($siren, $nic=0, $accesDist=false, $cycleClient=2, $mail $tmp=addslashes($ENSEIGNE); $tabTmp=$iDb->select('sdv1.franchiseurs', "id, enseigne, MATCH (enseigne) AGAINST ('$tmp') as score", - "MATCH (enseigne) AGAINST ('$tmp') + "MATCH (enseigne) AGAINST ('$tmp') HAVING score>1 ORDER BY score DESC", INDISCORE_DEBUG, MYSQL_ASSOC); // Nombre d'établissements concernés: neutraliser si >= 10 foreach ($tabTmp as $iTmp=>$tabArret) { @@ -3772,14 +3773,14 @@ function calculIndiScore($siren, $nic=0, $accesDist=false, $cycleClient=2, $mail //if ($codeCommuneInsee>=75000 && $codeCommuneInsee<76000) $VILLE=$tabIdentite['Ville']; // Ville ou ville + arrondissement de l'entreprise $ya2ans=$ANNEEp2.'-'.date('m-d'); - $ret = $iDb->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 '$APEENT' - AND v.codeCommune LIKE '$codeCommuneInsee' - AND v.Bodacc_Date_Parution>='$ya2ans' - AND v.VenteMt>1 AND v.VenteDev='EUR' $filtreCAEff + $ret = $iDb->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 '$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", INDISCORE_DEBUG); if (count($ret)>0) { while ($ret=$iDb->fetch(MYSQL_ASSOC)) { @@ -3793,14 +3794,14 @@ function calculIndiScore($siren, $nic=0, $accesDist=false, $cycleClient=2, $mail // Par département $DEPARTEMENT=$iInsee->getDepartement($tabIdentite['Dept']); $DEPARTEMENT_DE=$iInsee->getDepartement($tabIdentite['Dept'], true); - $ret=$iDb->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 '$APEENT' - AND v.codeCommune LIKE '".$tabIdentite['Dept']."%' - AND v.Bodacc_Date_Parution>='$ya2ans' - AND v.VenteMt>1 AND v.VenteDev='EUR' $filtreCAEff + $ret=$iDb->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 '$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", INDISCORE_DEBUG); while ($ret=$iDb->fetch(MYSQL_ASSOC)) { $VENTEMAX_DEP_MT = $VENTEMAX_DEP_EU = $ret['vtMax']; // Plus grand montant de vente annonce VC niveau "ville" @@ -3809,13 +3810,13 @@ function calculIndiScore($siren, $nic=0, $accesDist=false, $cycleClient=2, $mail $VENTE_DEP_NB = $ret['vtNb']; // Nombre de ventes dans le niveau statistique "ville" dans les 24 derniers mois } // France entière - $ret=$iDb->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 '$APEENT' - AND v.Bodacc_Date_Parution>='$ya2ans' - AND v.VenteMt>1 AND v.VenteDev='EUR' $filtreCAEff + $ret=$iDb->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 '$APEENT' + AND v.Bodacc_Date_Parution>='$ya2ans' + AND v.VenteMt>1 AND v.VenteDev='EUR' $filtreCAEff GROUP BY v.id)b", INDISCORE_DEBUG); while ($ret=$iDb->fetch(MYSQL_ASSOC)) { $VENTEMAX_FRA_MT = $VENTEMAX_FRA_EU = $ret['vtMax']; // Plus grand montant de vente annonce VC niveau "ville" diff --git a/src/Metier/Scoring/Data/Formules.php b/src/Metier/Scoring/Data/Formules.php index 0b60d51..e623363 100755 --- a/src/Metier/Scoring/Data/Formules.php +++ b/src/Metier/Scoring/Data/Formules.php @@ -66,12 +66,12 @@ return array( 7 => array( 'id' => 7, 'libelle' => "Résultat courant avant impots", - 'commentaires' => "Bénéfice ou perte constaté avant affectation des produits ou charges exceptionnelles, déduction des impôts et participation au bénéfice. Il est égal aux : -produits d'exploitation (notamment les sommes reçues qui relèvent de l'activité de l'entreprise, soit les ventes de biens, prestations de services etc..) -+ quotes-parts de résultats sur opérations faites en commun(par exemple, résultat des opérations faites par l'intermédiaire d'une société en participation) -+ produits financiers (intérêts courus, gains de change, revenus tirés des comptes en banque) -- charges d'exploitation -- quotes-parts de charges sur opérations en commun + 'commentaires' => "Bénéfice ou perte constaté avant affectation des produits ou charges exceptionnelles, déduction des impôts et participation au bénéfice. Il est égal aux : +produits d'exploitation (notamment les sommes reçues qui relèvent de l'activité de l'entreprise, soit les ventes de biens, prestations de services etc..) ++ quotes-parts de résultats sur opérations faites en commun(par exemple, résultat des opérations faites par l'intermédiaire d'une société en participation) ++ produits financiers (intérêts courus, gains de change, revenus tirés des comptes en banque) +- charges d'exploitation +- quotes-parts de charges sur opérations en commun - charges financières.", 'unite' => 'EUR', 'borneMin' => '', @@ -198,17 +198,17 @@ produits d'exploitation (notamment les sommes reçues qui relèvent de l'activit 21 => array( 'id' => 22, 'libelle' => "Total bilan", - 'commentaires' => "Le total du bilan est la somme de tous les actifs ainsi que des passifs, il caractérise la taille de l'entreprise. -Selon le décret n° 2008-1354 du 18 décembre 2008, les critères désormais retenus pour les besoins de l'analyse statistique et économique sont les suivants : -La catégorie des micro entreprises est constituée des entreprises qui : - * d'une part occupent moins de 10 personnes ; - * d'autre part ont un chiffre d'affaires annuel ou un total de bilan n'excédant pas 2 millions d'euros. -La catégorie des petites et moyennes entreprises (PME) est constituée des entreprises qui : - * d'une part occupent moins de 250 personnes ; - * d'autre part ont un chiffre d'affaires annuel n'excédant pas 50 millions d'euros ou un total de bilan n'excédant pas 43 millions d'euros. -La catégorie des entreprises de taille intermédiaire (ETI) est constituée des entreprises qui n'appartiennent pas à la catégorie des petites et moyennes entreprises, et qui : - * d'une part occupent moins de 5 000 personnes ; - * d'autre part ont un chiffre d'affaires annuel n'excédant pas 1 500 millions d'euros ou un total de bilan n'excédant pas 2 000 millions d'euros. + 'commentaires' => "Le total du bilan est la somme de tous les actifs ainsi que des passifs, il caractérise la taille de l'entreprise. +Selon le décret n° 2008-1354 du 18 décembre 2008, les critères désormais retenus pour les besoins de l'analyse statistique et économique sont les suivants : +La catégorie des micro entreprises est constituée des entreprises qui : + * d'une part occupent moins de 10 personnes ; + * d'autre part ont un chiffre d'affaires annuel ou un total de bilan n'excédant pas 2 millions d'euros. +La catégorie des petites et moyennes entreprises (PME) est constituée des entreprises qui : + * d'une part occupent moins de 250 personnes ; + * d'autre part ont un chiffre d'affaires annuel n'excédant pas 50 millions d'euros ou un total de bilan n'excédant pas 43 millions d'euros. +La catégorie des entreprises de taille intermédiaire (ETI) est constituée des entreprises qui n'appartiennent pas à la catégorie des petites et moyennes entreprises, et qui : + * d'une part occupent moins de 5 000 personnes ; + * d'autre part ont un chiffre d'affaires annuel n'excédant pas 1 500 millions d'euros ou un total de bilan n'excédant pas 2 000 millions d'euros. La catégorie des grandes entreprises (GE) est constituée des entreprises qui ne sont pas classées dans les catégories précédentes.", 'unite' => 'EUR', 'borneMin' => '', @@ -227,10 +227,10 @@ La catégorie des grandes entreprises (GE) est constituée des entreprises qui n 23 => array( 'id' => 24, 'libelle' => "Effectif (sans décimales)", - 'commentaires' => "La définition exacte de l'effectif peut varier selon les sources : -DADS : effectif salarié instantané au 30 juin ; -SIRENE : effectif salarié au 31 décembre n (ou au 1er janvier n+1) ; cet effectif fait l'objet d'une mise à jour « de masse » au premier semestre à partir des données DADS, l'effectif d'une entreprise est alors la somme des effectifs de ses établissements au 31 décembre; -SUSE-FICUS : moyenne annuelle de l'effectif salarié. + 'commentaires' => "La définition exacte de l'effectif peut varier selon les sources : +DADS : effectif salarié instantané au 30 juin ; +SIRENE : effectif salarié au 31 décembre n (ou au 1er janvier n+1) ; cet effectif fait l'objet d'une mise à jour « de masse » au premier semestre à partir des données DADS, l'effectif d'une entreprise est alors la somme des effectifs de ses établissements au 31 décembre; +SUSE-FICUS : moyenne annuelle de l'effectif salarié. Dans un bilan c'est la moyenne de l'effectif de l'exercice.", 'unite' => 'Pers.', 'borneMin' => '', @@ -348,9 +348,9 @@ Dans un bilan c'est la moyenne de l'effectif de l'exercice.", 36 => array( 'id' => 63, 'libelle' => "Trésorerie active", - 'commentaires' => "La trésorerie active est constituée de l'ensemble des éléments liquides. A savoir : -- les valeurs mobilières de placement (ensemble des actifs financiers acquis par l'entreprise mais qui n'ont pas de valeur stratégique et qui visent plutôt à réaliser des plus-values). -- l'ensemble des disponibilités déposées sur le compte bancaire de l'entreprise. + 'commentaires' => "La trésorerie active est constituée de l'ensemble des éléments liquides. A savoir : +- les valeurs mobilières de placement (ensemble des actifs financiers acquis par l'entreprise mais qui n'ont pas de valeur stratégique et qui visent plutôt à réaliser des plus-values). +- l'ensemble des disponibilités déposées sur le compte bancaire de l'entreprise. - son fond de caisse.", 'unite' => 'EUR', 'borneMin' => '', @@ -360,9 +360,9 @@ Dans un bilan c'est la moyenne de l'effectif de l'exercice.", 37 => array( 'id' => 64, 'libelle' => "Trésorerie active 12 mois", - 'commentaires' => "Trésorerie active rapporté à 12 mois; elle est constituée de l'ensemble des éléments liquides. A savoir : -- les valeurs mobilières de placement (ensemble des actifs financiers acquis par l'entreprise mais qui n'ont pas de valeur stratégique et qui visent plutôt à réaliser des plus-values). -- l'ensemble des disponibilités déposées sur le compte bancaire de l'entreprise. + 'commentaires' => "Trésorerie active rapporté à 12 mois; elle est constituée de l'ensemble des éléments liquides. A savoir : +- les valeurs mobilières de placement (ensemble des actifs financiers acquis par l'entreprise mais qui n'ont pas de valeur stratégique et qui visent plutôt à réaliser des plus-values). +- l'ensemble des disponibilités déposées sur le compte bancaire de l'entreprise. - son fond de caisse.", 'unite' => 'EUR', 'borneMin' => '', @@ -1155,7 +1155,7 @@ Dans un bilan c'est la moyenne de l'effectif de l'exercice.", 125 => array( 'id' => 231, 'libelle' => "FR (FONDS DE ROULEMENT)", - 'commentaires' => "Le fonds de roulement représente la différence entre l'actif à court terme et le passif à court terme (dont l'échéance est de moins de douze mois). Un fonds de roulement positif indique qu'une entreprise a suffisamment d'actifs liquides pour régler ses dettes et engagements à court terme (12 mois). + 'commentaires' => "Le fonds de roulement représente la différence entre l'actif à court terme et le passif à court terme (dont l'échéance est de moins de douze mois). Un fonds de roulement positif indique qu'une entreprise a suffisamment d'actifs liquides pour régler ses dettes et engagements à court terme (12 mois). Dans certains cas particuliers, le FDR peut être négatif et l'entreprise viable : GSA ou autre Hypermarchés par exemple. Cette situation devenant risquée en cas de baisse du CA.", 'unite' => 'EUR', 'borneMin' => '', @@ -1183,7 +1183,7 @@ Dans certains cas particuliers, le FDR peut être négatif et l'entreprise viabl 128 => array( 'id' => 234, 'libelle' => "COUVERTURE du BFR (FR/BFR)", - 'commentaires' => "Si le FR>BFR, la trésorerie est positive, l'entreprise dispose de disponibilités. Si le FR "Si le FR>BFR, la trésorerie est positive, l'entreprise dispose de disponibilités. Si le FR est inférieur au BFR, la trésorerie est négative, l'entreprise doit se financer à court terme auprès des banques au moyen de concours bancaires courants. Une trésorerie négative d'une manière régulière est souvent la cause d'une mauvaise politique financière. Si les besoins de financement sont à caractère permanent, ils devraient être financés par des ressources permanentes et non des crédits de trésorerie. Il arrive que dans certaines entreprises le BFR soit structurellement négatif, c'est le cas pour certains secteurs du commerce, en grande distribution par exemple. Cela vient du fait que le crédit fournisseur est long voir très long. Les immobilisations deviennent des ressources permanentes puisqu'elles sont financées en partie par l'exploitation.", 'unite' => '%', 'borneMin' => '-800', 'borneMax' => '800', @@ -1315,7 +1315,7 @@ dettes a + 1 an / capitaux propres", 'id' => 248, 'libelle' => "FINANCEMENT DES STOCKS dettes aux fournisseurs / stock", - 'commentaires' => "Vous pouvez agir sur votre trésorerie disponible en exigeant des délais de règlement plus longs de la part de vos fournisseurs - cela tout en vous conformant à la loi LME relative aux délais de paiement, qui, depuis le 1er janvier 2009, impose à l'ensemble des entreprises un paiement à 60 jours, hors accords dérogatoires. Pour la plupart des entreprises, les règlements clients interviennent après les règlements des achats et des charges. Ainsi, les dettes courantes (dettes liées au cycle d'exploitation : fournisseurs, social) sont \"insuffisantes\" pour couvrir le financement des stocks. Plus difficile pour les petites entreprises que pour les entreprises de taille importante, vous pouvez néanmoins jouer sur la mise en concurrence et challenger régulièrement vos fournisseurs en place.", + 'commentaires' => "Vous pouvez agir sur votre trésorerie disponible en exigeant des délais de règlement plus longs de la part de vos fournisseurs - cela tout en vous conformant à la loi LME relative aux délais de paiement, qui, depuis le 1er janvier 2009, impose à l'ensemble des entreprises un paiement à 60 jours, hors accords dérogatoires. Pour la plupart des entreprises, les règlements clients interviennent après les règlements des achats et des charges. Ainsi, les dettes courantes (dettes liées au cycle d'exploitation : fournisseurs, social) sont 'insuffisantes' pour couvrir le financement des stocks. Plus difficile pour les petites entreprises que pour les entreprises de taille importante, vous pouvez néanmoins jouer sur la mise en concurrence et challenger régulièrement vos fournisseurs en place.", 'unite' => '%', 'borneMin' => '-800', 'borneMax' => '800', @@ -2518,7 +2518,7 @@ chiffre d'affaire/actif comptable", 275 => array( 'id' => 573, 'libelle' => "Flux de trésorerie interne (A)", - 'commentaires' => "Le flux de trésorerie interne est un indicateur permettant de mesurer le degré de liberté de + 'commentaires' => "Le flux de trésorerie interne est un indicateur permettant de mesurer le degré de liberté de l'entreprise par sa capacité à investir et à se désendetter. Il informe sur le degré de maîtrise des mouvements de trésorerie ainsi que sur la cohérence des politiques suivies.", 'unite' => 'EUR', 'borneMin' => '', diff --git a/src/Metier/sphinx/rechercheFonc.php b/src/Metier/sphinx/rechercheFonc.php index 0bd8321..4c37e6a 100644 --- a/src/Metier/sphinx/rechercheFonc.php +++ b/src/Metier/sphinx/rechercheFonc.php @@ -9,8 +9,7 @@ if (defined('DEBUG') == false) { // --------------------------------------------------------------------------- // // databaseJO // --------------------------------------------------------------------------- // -function databaseJO() -{ +function databaseJO() { $db = new mysqli(MYSQL_HOST, MYSQL_USER, MYSQL_PASS, 'jo'); if (mysqli_connect_error()) { println('Ne peut pas se connecter a la base.'); @@ -23,8 +22,7 @@ function databaseJO() // --------------------------------------------------------------------------- // // println // --------------------------------------------------------------------------- // -function println($ln = '') -{ +function println($ln = '') { print $ln.'
'; } @@ -32,17 +30,11 @@ function println($ln = '') // debugln // --------------------------------------------------------------------------- // if (DEBUG) { - function debugln($ln = '') - { + function debugln($ln = '') { print $ln.'
'; } -} elseif (LOCAL) { - function debugln($ln = '') - { - } } else { - function debugln($ln = '') - { + function debugln($ln = '') { /* $fp = fopen(LOG_PATH.'/recherchesDebug.log', 'a'); fwrite($fp, $ln."\n"); diff --git a/src/Scores/Ws/Doc.php b/src/Scores/Ws/Doc.php index 943e6af..03aff05 100644 --- a/src/Scores/Ws/Doc.php +++ b/src/Scores/Ws/Doc.php @@ -39,8 +39,7 @@ class Scores_Ws_Doc private function parseService() { $class = new Zend_Server_Reflection(); - $methods = $class->reflectClass($this->serviceClass) - ->getMethods(); + $methods = $class->reflectClass($this->serviceClass)->getMethods(); $methodsElement = array(); foreach ($methods as $method) { $prototype = null; @@ -56,9 +55,9 @@ class Scores_Ws_Doc $paramsElement = array(); foreach ($prototype->getParameters() as $param) { $paramElement = array( - 'type' => $param->getType(), - 'name' => $param->getName(), - 'description' => $param->getDescription(), + 'type' => $param->getType(), + 'name' => $param->getName(), + 'description' => $param->getDescription(), ); if ($param->isOptional()) { @@ -68,11 +67,14 @@ class Scores_Ws_Doc $paramsElement[] = $paramElement; } + $return = $prototype->getReturnValue(); + $methodElement = array( - 'name' => $method->getName(), - 'desc' => $method->getDescription(), - 'params' => $paramsElement, - 'return' => $prototype->getReturnType(), + 'name' => $method->getName(), + 'desc' => $method->getDescription(), + 'params' => $paramsElement, + 'return' => $prototype->getReturnType(), + 'returnDesc' => $return->getDescription(), ); $methodsElement[] = $methodElement; @@ -101,8 +103,8 @@ class Scores_Ws_Doc $docBlock = preg_replace('/\n/', '', $property->getDocComment()); if (preg_match('/\/\*\*(.+) \* @var\s+[^\s]+\s+(?:\*|@)/m', $docBlock, $docBlockMatches)) { $comment.= preg_replace( - array('/\r/', '/\*/' ), - array('', ''), $docBlockMatches[1] + array('/\r/', '/\*/' ), + array('', ''), $docBlockMatches[1] ); } @@ -147,17 +149,17 @@ class Scores_Ws_Doc switch ($ref[1]) { case 'fichier': $urlFichier = $view->url(array( - 'controller' => 'ref', - 'action' => 'fichier', - 'q' => $ref[3], + 'controller' => 'ref', + 'action' => 'fichier', + 'q' => $ref[3], ), null, true); $comment.= ''.$ref[2].''; break; case 'mysql': $urlMysql = $view->url(array( - 'controller' => 'ref', - 'action' => 'table', - 'q' => $ref[3], + 'controller' => 'ref', + 'action' => 'table', + 'q' => $ref[3], ), null, true); $comment.= ''.$ref[2].''; break; @@ -166,9 +168,9 @@ class Scores_Ws_Doc } } $paramElement = array( - 'name' => $name, - 'type' => $type, - 'description' => trim($comment) + 'name' => $name, + 'type' => $type, + 'description' => trim($comment) ); } $paramsElement[] = $paramElement;