diff --git a/library/Metier/Partenaires/MBilans.php b/library/Metier/Partenaires/MBilans.php index 52a14efe..0d8bbb2e 100644 --- a/library/Metier/Partenaires/MBilans.php +++ b/library/Metier/Partenaires/MBilans.php @@ -349,7 +349,7 @@ class Metier_Partenaires_MBilans * Nombre de bilans maximums retournés * @return array */ - public function listeBilans($accesPartenaire = false, $nbMaxBilans = 0) + public function listeBilans($accesPartenaire = false, $nbMaxBilans = 0, $idClient = 0) { $dateDerDepot = 0; $tabRet = $tabRet2 = $tabRet3 = $tabRet = array(); @@ -358,6 +358,7 @@ class Metier_Partenaires_MBilans if ($this->companyEvenDateStop !== null) { $where.= " AND dateExercice<'".$this->companyEvenDateStop."'"; } + $where.= ($idClient > 0) ? " AND (confidentiel = '".$idClient."' OR confidentiel = 0)" : " AND confidentiel = 0"; $where.= " ORDER BY dateExercice DESC, CASE typeBilan WHEN 'N' THEN 1 WHEN 'S' THEN 2 ELSE 3 END"; if ($nbMaxBilans > 0) { $where.= " LIMIT 0, $nbMaxBilans"; diff --git a/library/WsScore/Entreprise/v0.8/Service.php b/library/WsScore/Entreprise/v0.8/Service.php index 892b5b09..5dd5c106 100644 --- a/library/WsScore/Entreprise/v0.8/Service.php +++ b/library/WsScore/Entreprise/v0.8/Service.php @@ -833,14 +833,14 @@ class Entreprise extends Scores_Ws_Server $countryM = new Application_Model_JoTabPays(); $sql = $countryM->select()->from($countryM, array('codPays3', 'libPays')); $result = $countryM->fetchAll($sql); - } catch (Zend_Db_Adapter_Exception $e) { + } catch (Zend_Db_Adapter_Exception $e) { if ($this->User->idClient==1) { throw new SoapFault('ERR', $e->getMessage()); } else { throw new SoapFault('ERR', "Application error"); - } - } catch (Zend_Exception $e) { - throw new SoapFault('ERR', "Application error"); + } + } catch (Zend_Exception $e) { + throw new SoapFault('ERR', "Application error"); } $tabPays = array(); @@ -849,7 +849,7 @@ class Entreprise extends Scores_Ws_Server $tabPays[$item->codPays3] = $item->libPays; } } - + $tabAct = $tabPar = $tabDir = array(); try @@ -925,8 +925,8 @@ class Entreprise extends Scores_Ws_Server //Participations $liens = $liensM->getParticipations(null, true); - if (count($liens)>0) { - foreach ( $liens as $item ) { + if (count($liens)>0) { + foreach ( $liens as $item ) { $detail = new Lien(); $detail->id = $item->id; $detail->idFiche = $item->idPar; @@ -950,10 +950,10 @@ class Entreprise extends Scores_Ws_Server $detail->Pvote = $item->Pvote; $detail->MajMin = $item->MajMin; - if ($item->dateUpdate=='0000-00-00 00:00:00'){ - $detail->date = substr($item->dateInsert,0,10); - } else { - $detail->date = substr($item->dateUpdate,0,10); + if ($item->dateUpdate=='0000-00-00 00:00:00'){ + $detail->date = substr($item->dateInsert,0,10); + } else { + $detail->date = substr($item->dateUpdate,0,10); } $nbIdNum = 3; @@ -984,14 +984,14 @@ class Entreprise extends Scores_Ws_Server } } $detail->identification = $refs; - - $tabPar[] = $detail; - } + + $tabPar[] = $detail; + } } //Directions $liens = $liensM->getDirections(true); - if (count($liens)>0) { + if (count($liens)>0) { foreach ( $liens as $item ) { $detail = new LienDirection(); $detail->siren = $item->siren; @@ -1003,11 +1003,11 @@ class Entreprise extends Scores_Ws_Server if (!empty($item->civilite)) { $nom.= $item->civilite.'. '; } - if (!empty($item->nom)) { - $nom.= $item->nom.' '; + if (!empty($item->nom)) { + $nom.= $item->nom.' '; } - if (!empty($item->prenom)) { - $nom.= $item->prenom; + if (!empty($item->prenom)) { + $nom.= $item->prenom; } $detail->dirNom = $nom; $detail->dirNaissLieu = $item->naissance_lieu; @@ -1017,10 +1017,10 @@ class Entreprise extends Scores_Ws_Server } } } catch(Exception $e) { - if ($this->User->idClient==1) { - throw new SoapFault('ERR', $e->getMessage()); - } else { - throw new SoapFault('ERR', "Application error"); + if ($this->User->idClient==1) { + throw new SoapFault('ERR', $e->getMessage()); + } else { + throw new SoapFault('ERR', "Application error"); } } @@ -1034,17 +1034,17 @@ class Entreprise extends Scores_Ws_Server return $output; } - /** - * Retourne les liens financiers pour une entreprise. - * @param int $id Identifiant de référence de l'entreprise - * @param string $type Type de lien (actionnaire|participation) - * @return LiensReturn - */ - public function getLiensById($id, $type = null) - { + /** + * Retourne les liens financiers pour une entreprise. + * @param int $id Identifiant de référence de l'entreprise + * @param string $type Type de lien (actionnaire|participation) + * @return LiensReturn + */ + public function getLiensById($id, $type = null) + { $this->authenticate(); - $this->permission('liens'); - + $this->permission('liens'); + try { $countryM = new Application_Model_JoTabPays(); $sql = $countryM->select()->from($countryM, array('codPays3', 'libPays')); @@ -1064,48 +1064,48 @@ class Entreprise extends Scores_Ws_Server foreach ( $result as $item ) { $tabPays[$item->codPays3] = $item->libPays; } - } - - $tabAct = $tabPar = $tabDir = array(); - - try - { + } + + $tabAct = $tabPar = $tabDir = array(); + + try + { $liensM = new Metier_Liens_Base(); - $liensM->setId($id); - - //Actionnaires - $liens = $liensM->getActionnaires(null, true); - if (count($liens)>0) { - foreach ( $liens as $item ) { - $detail = new Lien(); - $detail->id = $item->id; - $detail->idFiche = $item->idAct; + $liensM->setId($id); + + //Actionnaires + $liens = $liensM->getActionnaires(null, true); + if (count($liens)>0) { + foreach ( $liens as $item ) { + $detail = new Lien(); + $detail->id = $item->id; + $detail->idFiche = $item->idAct; $detail->nom = $item->RS; - $detail->sigle = $item->sigle; - - $libPays = ''; - if ($item->adresse_pays!='') { - $libPays = array_key_exists($item->adresse_pays, $tabPays) ? - $tabPays[$item->adresse_pays] : $item->adresse_pays; - } else { - $libPays = $tabPays['FRA']; - } - $detail->pays = $libPays; - - if ($item->PpPm=='PP') { - $detail->nom = $item->civilite.' '.$item->nom.' '.$item->prenom; - } - $detail->siren = str_pad($item->siren, 9, "0", STR_PAD_LEFT); - $detail->PDetention = $item->PDetention; - $detail->Pvote = $item->Pvote; - $detail->MajMin = $item->MajMin; - - if ($item->dateUpdate=='0000-00-00 00:00:00'){ - $detail->date = substr($item->dateInsert,0,10); - } else { - $detail->date = substr($item->dateUpdate,0,10); - } - + $detail->sigle = $item->sigle; + + $libPays = ''; + if ($item->adresse_pays!='') { + $libPays = array_key_exists($item->adresse_pays, $tabPays) ? + $tabPays[$item->adresse_pays] : $item->adresse_pays; + } else { + $libPays = $tabPays['FRA']; + } + $detail->pays = $libPays; + + if ($item->PpPm=='PP') { + $detail->nom = $item->civilite.' '.$item->nom.' '.$item->prenom; + } + $detail->siren = str_pad($item->siren, 9, "0", STR_PAD_LEFT); + $detail->PDetention = $item->PDetention; + $detail->Pvote = $item->Pvote; + $detail->MajMin = $item->MajMin; + + if ($item->dateUpdate=='0000-00-00 00:00:00'){ + $detail->date = substr($item->dateInsert,0,10); + } else { + $detail->date = substr($item->dateUpdate,0,10); + } + $nbIdNum = 3; $refs = array(); $idM = new Application_Model_Sdv1TabIdLocal(); @@ -1133,45 +1133,45 @@ class Entreprise extends Scores_Ws_Server $refs[] = $ref; } } - $detail->identification = $refs; - - $tabAct[] = $detail; - } - } - - //Participations - $liens = $liensM->getParticipations(null, true); - if (count($liens)>0) { - foreach ( $liens as $item ) { - $detail = new Lien(); - $detail->id = $item->id; - $detail->idFiche = $item->idPar; + $detail->identification = $refs; + + $tabAct[] = $detail; + } + } + + //Participations + $liens = $liensM->getParticipations(null, true); + if (count($liens)>0) { + foreach ( $liens as $item ) { + $detail = new Lien(); + $detail->id = $item->id; + $detail->idFiche = $item->idPar; $detail->nom = $item->RS; - $detail->sigle = $item->sigle; - - $libPays = ''; - if ($item->adresse_pays!='') { - $libPays = array_key_exists($item->adresse_pays, $tabPays) ? - $tabPays[$item->adresse_pays] : $item->adresse_pays; - } else { - $libPays = $tabPays['FRA']; - } - $detail->pays = $libPays; - - if ($item->PpPm=='PP') { - $detail->nom = $item->civilite.' '.$item->nom.' '.$item->prenom; - } - $detail->siren = str_pad($item->siren, 9, "0", STR_PAD_LEFT); - $detail->PDetention = $item->PDetention; - $detail->Pvote = $item->Pvote; - $detail->MajMin = $item->MajMin; - - if ($item->dateUpdate=='0000-00-00 00:00:00'){ - $detail->date = substr($item->dateInsert,0,10); - } else { - $detail->date = substr($item->dateUpdate,0,10); - } - + $detail->sigle = $item->sigle; + + $libPays = ''; + if ($item->adresse_pays!='') { + $libPays = array_key_exists($item->adresse_pays, $tabPays) ? + $tabPays[$item->adresse_pays] : $item->adresse_pays; + } else { + $libPays = $tabPays['FRA']; + } + $detail->pays = $libPays; + + if ($item->PpPm=='PP') { + $detail->nom = $item->civilite.' '.$item->nom.' '.$item->prenom; + } + $detail->siren = str_pad($item->siren, 9, "0", STR_PAD_LEFT); + $detail->PDetention = $item->PDetention; + $detail->Pvote = $item->Pvote; + $detail->MajMin = $item->MajMin; + + if ($item->dateUpdate=='0000-00-00 00:00:00'){ + $detail->date = substr($item->dateInsert,0,10); + } else { + $detail->date = substr($item->dateUpdate,0,10); + } + $nbIdNum = 3; $refs = array(); $idM = new Application_Model_Sdv1TabIdLocal(); @@ -1192,62 +1192,62 @@ class Entreprise extends Scores_Ws_Server $ref->type = 0; } } else { - $ref->label = 'Identifiant local'; + $ref->label = 'Identifiant local'; $ref->type = 1; } $refs[] = $ref; } } - $detail->identification = $refs; - - $tabPar[] = $detail; - } - } - - //Directions - $liens = $liensM->getDirections(true); - if (count($liens)>0) { - foreach ( $liens as $item ) { - $detail = new LienDirection(); - $detail->siren = $item->siren; - $detail->nom = $item->raisonSociale; - $detail->fonction = $item->fonction_lib; - $detail->dirRS = $item->dirRS; - - $nom = ''; - if (!empty($item->civilite)) { - $nom.= $item->civilite.'. '; - } - if (!empty($item->nom)) { - $nom.= $item->nom.' '; - } - if (!empty($item->prenom)) { - $nom.= $item->prenom; - } - $detail->dirNom = $nom; - $detail->dirNaissLieu = $item->naissance_lieu; - $detail->dirNaissDate = $item->naissance_date; - - $tabDir[] = $detail; - } - } - } catch(Exception $e) { - if ($this->User->idClient==1) { - throw new SoapFault('ERR', $e->getMessage()); - } else { - throw new SoapFault('ERR', "Application error"); - } - } - - $output = new LiensReturn(); - $output->actionnaires = $tabAct; - $output->participations = $tabPar; + $detail->identification = $refs; + + $tabPar[] = $detail; + } + } + + //Directions + $liens = $liensM->getDirections(true); + if (count($liens)>0) { + foreach ( $liens as $item ) { + $detail = new LienDirection(); + $detail->siren = $item->siren; + $detail->nom = $item->raisonSociale; + $detail->fonction = $item->fonction_lib; + $detail->dirRS = $item->dirRS; + + $nom = ''; + if (!empty($item->civilite)) { + $nom.= $item->civilite.'. '; + } + if (!empty($item->nom)) { + $nom.= $item->nom.' '; + } + if (!empty($item->prenom)) { + $nom.= $item->prenom; + } + $detail->dirNom = $nom; + $detail->dirNaissLieu = $item->naissance_lieu; + $detail->dirNaissDate = $item->naissance_date; + + $tabDir[] = $detail; + } + } + } catch(Exception $e) { + if ($this->User->idClient==1) { + throw new SoapFault('ERR', $e->getMessage()); + } else { + throw new SoapFault('ERR', "Application error"); + } + } + + $output = new LiensReturn(); + $output->actionnaires = $tabAct; + $output->participations = $tabPar; $output->directions = $tabDir; $this->wsLog('liens', '', $id); - - return $output; + + return $output; } /** @@ -1261,17 +1261,17 @@ class Entreprise extends Scores_Ws_Server { $this->authenticate(); $this->permission('liens'); - + $refM = new Application_Model_JoLiensRef(); - try { - $rows = $refM->find($id); - } catch (Zend_Db_Exception $e) { - if ($this->User->idClient!=1) { - throw new SoapFault('ERR', "Application error"); - } else { - throw new SoapFault('ERR', $e->getMessage()); - } + try { + $rows = $refM->find($id); + } catch (Zend_Db_Exception $e) { + if ($this->User->idClient!=1) { + throw new SoapFault('ERR', "Application error"); + } else { + throw new SoapFault('ERR', $e->getMessage()); + } } if ($rows->count()==0) { @@ -1309,10 +1309,10 @@ class Entreprise extends Scores_Ws_Server //@todo : Utiliser le libellé du pays $output->adressePays = $result['adresse_pays']; - if ($result['dateUpdate']=='0000-00-00 00:00:00'){ - $output->date = substr($result['dateInsert'],0,10); - } else { - $output->date = substr($result['dateUpdate'],0,10); + if ($result['dateUpdate']=='0000-00-00 00:00:00'){ + $output->date = substr($result['dateInsert'],0,10); + } else { + $output->date = substr($result['dateUpdate'],0,10); } $refs = array(); @@ -1467,263 +1467,263 @@ class Entreprise extends Scores_Ws_Server return $output; } - /** - * Retourne la liste des annonces légales relative à une entreprise - * - * @todo Revoir cette fonction pour la faire marcher avec les associations - * - * @param string $siren Siren de l'entreprise - * @param integer $filtre 1=BODACC, 2=B.A.L.O, 3=JO Association, 4=Boamp - * @param string $idAnn Identifiant de l'annonce - * @param integer $position - * @param integer $nbRep - * @return AnnoncesReturn - */ - protected function getAnnonces($siren, $filtre = 1, $idAnn = '', $position = 0, $nbRep = 100) - { - $this->authenticate(); - $this->permission('annonces'); - - //Initialisation - if (empty($filtre)) { $filtre = 1; } - if (empty($idAnn)) { $idAnn = ''; } - if (empty($position)) { $position = 0; } - if (empty($nbRep)) { $nbRep = 100; } - - //Valeur max - if($nbRep > 200) { $nbRep = 200; } - - $this->logger->info("Annonces demandées pour $siren ($filtre, $idAnn)"); - - $liste = array(); - - if (strlen($siren)!=9) { - $this->logger->warning( "Siren/Siret $siren incorrect"); - $this->sendError('1010'); - } elseif (intval($siren)==0 && $idAnn=='') { - $this->logger->warning( "Siren $siren ou annonce $idAnn inexistant"); - $this->sendError('1010'); - } - - $iInsee = new Metier_Insee_MInsee(); - /* - if ($siren>100 && $filtre==3) $asso=true; - else { - $asso=false; - $tabIdentite=$this->iInsee->getIdentiteLight($siren); - if ($tabIdentite['FJ']>90 && $tabIdentite['FJ']<94 || - $tabIdentite['FJ']>9000 && $tabIdentite['FJ']<9400) $asso=true; - }*/ - - //@todo : Connaitre le nombre d'annonce - - /* - getAnnoncesBoamp => Avis de marché, Avis d'attribution - getAnnoncesAsso => Rien de particulier - getAnnoncesBalo => Rien de particulier - getAnnoncesLegales => Plusieurs requetes SQL suivant la situation - */ - - if ($idAnn=='') { - $anns=$iInsee->getAnnoncesLegales($siren); - $annsB=$iInsee->getAnnoncesBalo($siren); - $annsA=$iInsee->getAnnoncesAsso($siren); - $annsM=$iInsee->getAnnoncesBoamp($siren, $idAnn); - } elseif ($filtre==1) { - $anns=$iInsee->getAnnoncesLegales($siren, $idAnn); - } elseif ($filtre==2) { - $annsB=$iInsee->getAnnoncesBalo($siren, $idAnn); - } elseif ($filtre==3) { - $annsA=$iInsee->getAnnoncesAsso($siren, $idAnn); - } elseif ($filtre==4) { - $annsM=$iInsee->getAnnoncesBoamp($siren, $idAnn); - } - - if (empty($anns) && empty($annsB) && empty($annsA) && empty($annsM)) - { - $this->logger->warning( "Aucune annonce pour le siren $siren (source=$filtre, id=$idAnn)"); - $error->errnum = 102; - $error->errmsg = 'Siren inexistant B '.$siren.' '.$idAnn; - } - else - { - foreach ($anns as $nb=>$ann) - { - $evens = array(); - foreach ($ann['evenements'] as $tabEven) - { - $even = new AnnonceEvenement(); - $even->CodeEven = $tabEven['CodeEven']; - $even->LibEven = $tabEven['LibEven']; - $evens[] = $even; - } - $annonce = new Annonce(); - $annonce->id = $ann['id']; - $annonce->BodaccCode = $ann['BodaccCode']; - $annonce->BodaccNum = $ann['BodaccNum']; - $annonce->NumAnnonce = $ann['NumAnnonce']; - $annonce->DateParution = $ann['DateParution']; //@todo : date - $annonce->Departement = $ann['Departement']; - $annonce->Tribunal = $ann['Tribunal']; - $annonce->TribunalCode = $ann['TribunalCode']; - $annonce->TribunalSiret = $ann['TribunalSiret']; - $annonce->Rubrique = $ann['Rubrique']; - $annonce->typeAnnonce = $ann['typeAnnonce']; - $annonce->texteRectificatif = $ann['texteRectificatif']; - $annonce->texteAnnonce = $ann['texteAnnonce']; - $annonce->libFJ = $ann['libFJ']; - $annonce->codFJ = $ann['codFJ']; - $annonce->capital = $ann['capital']; - $annonce->capitalDev = $ann['capitalDev']; - - $annonce->raisonSociale = $ann['raisonSociale']; - $annonce->nomCommercial = $ann['nomCommercial']; - $annonce->sigle = $ann['sigle']; - $annonce->adresse = $ann['adresse']; - $annonce->dateEffet = $ann['dateEffet']; //@todo : date - $annonce->dateJugement = $ann['dateJugement']; //@todo : date - $annonce->dateInsertionSD = $ann['dateInsertionSD']; //@todo : date - $annonce->evenements = $evens; - $annonce->Lien_Annonce_Pdf = $ann['Lien_Annonce_Pdf']; - - $liste[] = $annonce; - } - - if (is_array($annsB)) - { - foreach ($annsB as $nb=>$ann) - { - $evens = array(); - foreach ($ann['evenements'] as $tabEven) - { - $even = new AnnonceEvenement(); - $even->CodeEven = $tabEven['CodeEven']; - $even->LibEven = $tabEven['LibEven']; - $evens[] = $even; - } - $annonce = new Annonce(); - $annonce->id = $ann['id']; - $annonce->BodaccCode = $ann['BodaccCode']; - $annonce->BodaccNum = $ann['BodaccNum']; - $annonce->NumAnnonce = $ann['NumAnnonce']; - $annonce->DateParution = $ann['DateParution']; //@todo : date - $annonce->Departement = $ann['Departement']; - $annonce->Tribunal = $ann['Tribunal']; - //$annonce->TribunalCode = $ann['TribunalCode']; - $annonce->TribunalSiret = $ann['TribunalSiret']; - $annonce->Rubrique = $ann['Rubrique']; - $annonce->typeAnnonce = $ann['typeAnnonce']; - $annonce->texteRectificatif = $ann['texteRectificatif']; - $annonce->texteAnnonce = utf8_encode($ann['texteAnnonce']); - //$annonce->libFJ = $ann['libFJ']; - //$annonce->codFJ = $ann['codFJ']; - //$annonce->capital = $ann['capital']; - //$annonce->capitalDev = $ann['capitalDev']; - $annonce->dateEffet = $ann['dateEffet']; //@todo : date - $annonce->dateJugement = $ann['dateJugement']; //@todo : date - $annonce->dateInsertionSD = $ann['dateInsertionSD']; //@todo : date - $annonce->evenements = $evens; - $annonce->Lien_Annonce_Pdf = $ann['Lien_Annonce_Pdf']; - - $liste[] = $annonce; - } - } - - if (is_array($annsA)) - { - foreach ($annsA as $nb=>$ann) - { - $evens = array(); - foreach ($ann['evenements'] as $tabEven) - { - $even = new AnnonceEvenement(); - $even->CodeEven = $tabEven['CodeEven']; - $even->LibEven = $tabEven['LibEven']; - $evens[] = $even; - } - - $annonce = new Annonce(); - $annonce->id = $ann['id']; - $annonce->BodaccCode = $ann['BodaccCode']; - $annonce->BodaccNum = $ann['BodaccNum']; - $annonce->NumAnnonce = $ann['NumAnnonce']; - $annonce->DateParution = $ann['DateParution']; //@todo : date - $annonce->Departement = $ann['Departement']; - $annonce->Tribunal = $ann['Tribunal']; - //$annonce->TribunalCode = $ann['TribunalCode']; - $annonce->TribunalSiret = $ann['TribunalSiret']; - $annonce->Rubrique = $ann['Rubrique']; - $annonce->typeAnnonce = $ann['typeAnnonce']; - $annonce->texteRectificatif = $ann['texteRectificatif']; - $annonce->texteAnnonce = utf8_encode($ann['texteAnnonce']); - //$annonce->libFJ = $ann['libFJ']; - //$annonce->codFJ = $ann['codFJ']; - //$annonce->capital = $ann['capital']; - //$annonce->capitalDev = $ann['capitalDev']; - //@todo : date - $annonce->dateEffet = $ann['dateEffet']; //@todo : date - $annonce->dateJugement = $ann['dateJugement']; //@todo : date - $annonce->dateInsertionSD = $ann['dateInsertionSD']; //@todo : date - $annonce->evenements = $evens; - $annonce->Lien_Annonce_Pdf = $ann['Lien_Annonce_Pdf']; - - $liste[] = $annonce; - } - } - - if (is_array($annsM)) - { - foreach ($annsM as $nb=>$ann) - { - $evens = array(); - foreach ($ann['evenements'] as $tabEven) - { - $even = new AnnonceEvenement(); - $even->CodeEven = $tabEven['CodeEven']; - $even->LibEven = $tabEven['LibEven']; - $evens[] = $even; - } - - $annonce = new Annonce(); - $annonce->id = $ann['id']; - $annonce->BodaccCode = $ann['BodaccCode']; - $annonce->BodaccNum = $ann['BodaccNum']; - $annonce->NumAnnonce = $ann['NumAnnonce']; - $annonce->DateParution = $ann['DateParution']; //@todo : date - $annonce->Departement = $ann['Departement']; - $annonce->Tribunal = $ann['Tribunal']; - //$annonce->TribunalCode = $ann['TribunalCode']; - $annonce->TribunalSiret = $ann['TribunalSiret']; - $annonce->Rubrique = $ann['Rubrique']; - $annonce->typeAnnonce = $ann['typeAnnonce']; - $annonce->texteRectificatif = $ann['texteRectificatif']; - $annonce->texteAnnonce = utf8_encode($ann['texteAnnonce']); - //$annonce->libFJ = $ann['libFJ']; - //$annonce->codFJ = $ann['codFJ']; - //$annonce->capital = $ann['capital']; - //$annonce->capitalDev = $ann['capitalDev']; - $annonce->dateEffet = $ann['dateEffet']; //@todo : date - $annonce->dateJugement = $ann['dateJugement']; //@todo : date - $annonce->dateInsertionSD = $ann['dateInsertionSD']; //@todo : date - $annonce->evenements = $evens; - $annonce->Lien_Annonce_Pdf = $ann['Lien_Annonce_Pdf']; - - $liste[] = $annonce; - } - } - } - - $nbReponses = count($liste); - if ($nbReponses>0){ - //$liste = array_slice($liste, $position, $nbRep); - } - $this->logger->info( "Nb Annonces $filtre retournées pour $siren (source=$filtre, id=$idAnn) = ". count($liste)); - $this->wsLog('annonces',$siren,$filtre.'/'.$idAnn); - - $output = new AnnoncesReturn(); - $output->nbReponses = $nbReponses; - $output->result = $liste; - return $output; + /** + * Retourne la liste des annonces légales relative à une entreprise + * + * @todo Revoir cette fonction pour la faire marcher avec les associations + * + * @param string $siren Siren de l'entreprise + * @param integer $filtre 1=BODACC, 2=B.A.L.O, 3=JO Association, 4=Boamp + * @param string $idAnn Identifiant de l'annonce + * @param integer $position + * @param integer $nbRep + * @return AnnoncesReturn + */ + protected function getAnnonces($siren, $filtre = 1, $idAnn = '', $position = 0, $nbRep = 100) + { + $this->authenticate(); + $this->permission('annonces'); + + //Initialisation + if (empty($filtre)) { $filtre = 1; } + if (empty($idAnn)) { $idAnn = ''; } + if (empty($position)) { $position = 0; } + if (empty($nbRep)) { $nbRep = 100; } + + //Valeur max + if($nbRep > 200) { $nbRep = 200; } + + $this->logger->info("Annonces demandées pour $siren ($filtre, $idAnn)"); + + $liste = array(); + + if (strlen($siren)!=9) { + $this->logger->warning( "Siren/Siret $siren incorrect"); + $this->sendError('1010'); + } elseif (intval($siren)==0 && $idAnn=='') { + $this->logger->warning( "Siren $siren ou annonce $idAnn inexistant"); + $this->sendError('1010'); + } + + $iInsee = new Metier_Insee_MInsee(); + /* + if ($siren>100 && $filtre==3) $asso=true; + else { + $asso=false; + $tabIdentite=$this->iInsee->getIdentiteLight($siren); + if ($tabIdentite['FJ']>90 && $tabIdentite['FJ']<94 || + $tabIdentite['FJ']>9000 && $tabIdentite['FJ']<9400) $asso=true; + }*/ + + //@todo : Connaitre le nombre d'annonce + + /* + getAnnoncesBoamp => Avis de marché, Avis d'attribution + getAnnoncesAsso => Rien de particulier + getAnnoncesBalo => Rien de particulier + getAnnoncesLegales => Plusieurs requetes SQL suivant la situation + */ + + if ($idAnn=='') { + $anns=$iInsee->getAnnoncesLegales($siren); + $annsB=$iInsee->getAnnoncesBalo($siren); + $annsA=$iInsee->getAnnoncesAsso($siren); + $annsM=$iInsee->getAnnoncesBoamp($siren, $idAnn); + } elseif ($filtre==1) { + $anns=$iInsee->getAnnoncesLegales($siren, $idAnn); + } elseif ($filtre==2) { + $annsB=$iInsee->getAnnoncesBalo($siren, $idAnn); + } elseif ($filtre==3) { + $annsA=$iInsee->getAnnoncesAsso($siren, $idAnn); + } elseif ($filtre==4) { + $annsM=$iInsee->getAnnoncesBoamp($siren, $idAnn); + } + + if (empty($anns) && empty($annsB) && empty($annsA) && empty($annsM)) + { + $this->logger->warning( "Aucune annonce pour le siren $siren (source=$filtre, id=$idAnn)"); + $error->errnum = 102; + $error->errmsg = 'Siren inexistant B '.$siren.' '.$idAnn; + } + else + { + foreach ($anns as $nb=>$ann) + { + $evens = array(); + foreach ($ann['evenements'] as $tabEven) + { + $even = new AnnonceEvenement(); + $even->CodeEven = $tabEven['CodeEven']; + $even->LibEven = $tabEven['LibEven']; + $evens[] = $even; + } + $annonce = new Annonce(); + $annonce->id = $ann['id']; + $annonce->BodaccCode = $ann['BodaccCode']; + $annonce->BodaccNum = $ann['BodaccNum']; + $annonce->NumAnnonce = $ann['NumAnnonce']; + $annonce->DateParution = $ann['DateParution']; //@todo : date + $annonce->Departement = $ann['Departement']; + $annonce->Tribunal = $ann['Tribunal']; + $annonce->TribunalCode = $ann['TribunalCode']; + $annonce->TribunalSiret = $ann['TribunalSiret']; + $annonce->Rubrique = $ann['Rubrique']; + $annonce->typeAnnonce = $ann['typeAnnonce']; + $annonce->texteRectificatif = $ann['texteRectificatif']; + $annonce->texteAnnonce = $ann['texteAnnonce']; + $annonce->libFJ = $ann['libFJ']; + $annonce->codFJ = $ann['codFJ']; + $annonce->capital = $ann['capital']; + $annonce->capitalDev = $ann['capitalDev']; + + $annonce->raisonSociale = $ann['raisonSociale']; + $annonce->nomCommercial = $ann['nomCommercial']; + $annonce->sigle = $ann['sigle']; + $annonce->adresse = $ann['adresse']; + $annonce->dateEffet = $ann['dateEffet']; //@todo : date + $annonce->dateJugement = $ann['dateJugement']; //@todo : date + $annonce->dateInsertionSD = $ann['dateInsertionSD']; //@todo : date + $annonce->evenements = $evens; + $annonce->Lien_Annonce_Pdf = $ann['Lien_Annonce_Pdf']; + + $liste[] = $annonce; + } + + if (is_array($annsB)) + { + foreach ($annsB as $nb=>$ann) + { + $evens = array(); + foreach ($ann['evenements'] as $tabEven) + { + $even = new AnnonceEvenement(); + $even->CodeEven = $tabEven['CodeEven']; + $even->LibEven = $tabEven['LibEven']; + $evens[] = $even; + } + $annonce = new Annonce(); + $annonce->id = $ann['id']; + $annonce->BodaccCode = $ann['BodaccCode']; + $annonce->BodaccNum = $ann['BodaccNum']; + $annonce->NumAnnonce = $ann['NumAnnonce']; + $annonce->DateParution = $ann['DateParution']; //@todo : date + $annonce->Departement = $ann['Departement']; + $annonce->Tribunal = $ann['Tribunal']; + //$annonce->TribunalCode = $ann['TribunalCode']; + $annonce->TribunalSiret = $ann['TribunalSiret']; + $annonce->Rubrique = $ann['Rubrique']; + $annonce->typeAnnonce = $ann['typeAnnonce']; + $annonce->texteRectificatif = $ann['texteRectificatif']; + $annonce->texteAnnonce = utf8_encode($ann['texteAnnonce']); + //$annonce->libFJ = $ann['libFJ']; + //$annonce->codFJ = $ann['codFJ']; + //$annonce->capital = $ann['capital']; + //$annonce->capitalDev = $ann['capitalDev']; + $annonce->dateEffet = $ann['dateEffet']; //@todo : date + $annonce->dateJugement = $ann['dateJugement']; //@todo : date + $annonce->dateInsertionSD = $ann['dateInsertionSD']; //@todo : date + $annonce->evenements = $evens; + $annonce->Lien_Annonce_Pdf = $ann['Lien_Annonce_Pdf']; + + $liste[] = $annonce; + } + } + + if (is_array($annsA)) + { + foreach ($annsA as $nb=>$ann) + { + $evens = array(); + foreach ($ann['evenements'] as $tabEven) + { + $even = new AnnonceEvenement(); + $even->CodeEven = $tabEven['CodeEven']; + $even->LibEven = $tabEven['LibEven']; + $evens[] = $even; + } + + $annonce = new Annonce(); + $annonce->id = $ann['id']; + $annonce->BodaccCode = $ann['BodaccCode']; + $annonce->BodaccNum = $ann['BodaccNum']; + $annonce->NumAnnonce = $ann['NumAnnonce']; + $annonce->DateParution = $ann['DateParution']; //@todo : date + $annonce->Departement = $ann['Departement']; + $annonce->Tribunal = $ann['Tribunal']; + //$annonce->TribunalCode = $ann['TribunalCode']; + $annonce->TribunalSiret = $ann['TribunalSiret']; + $annonce->Rubrique = $ann['Rubrique']; + $annonce->typeAnnonce = $ann['typeAnnonce']; + $annonce->texteRectificatif = $ann['texteRectificatif']; + $annonce->texteAnnonce = utf8_encode($ann['texteAnnonce']); + //$annonce->libFJ = $ann['libFJ']; + //$annonce->codFJ = $ann['codFJ']; + //$annonce->capital = $ann['capital']; + //$annonce->capitalDev = $ann['capitalDev']; + //@todo : date + $annonce->dateEffet = $ann['dateEffet']; //@todo : date + $annonce->dateJugement = $ann['dateJugement']; //@todo : date + $annonce->dateInsertionSD = $ann['dateInsertionSD']; //@todo : date + $annonce->evenements = $evens; + $annonce->Lien_Annonce_Pdf = $ann['Lien_Annonce_Pdf']; + + $liste[] = $annonce; + } + } + + if (is_array($annsM)) + { + foreach ($annsM as $nb=>$ann) + { + $evens = array(); + foreach ($ann['evenements'] as $tabEven) + { + $even = new AnnonceEvenement(); + $even->CodeEven = $tabEven['CodeEven']; + $even->LibEven = $tabEven['LibEven']; + $evens[] = $even; + } + + $annonce = new Annonce(); + $annonce->id = $ann['id']; + $annonce->BodaccCode = $ann['BodaccCode']; + $annonce->BodaccNum = $ann['BodaccNum']; + $annonce->NumAnnonce = $ann['NumAnnonce']; + $annonce->DateParution = $ann['DateParution']; //@todo : date + $annonce->Departement = $ann['Departement']; + $annonce->Tribunal = $ann['Tribunal']; + //$annonce->TribunalCode = $ann['TribunalCode']; + $annonce->TribunalSiret = $ann['TribunalSiret']; + $annonce->Rubrique = $ann['Rubrique']; + $annonce->typeAnnonce = $ann['typeAnnonce']; + $annonce->texteRectificatif = $ann['texteRectificatif']; + $annonce->texteAnnonce = utf8_encode($ann['texteAnnonce']); + //$annonce->libFJ = $ann['libFJ']; + //$annonce->codFJ = $ann['codFJ']; + //$annonce->capital = $ann['capital']; + //$annonce->capitalDev = $ann['capitalDev']; + $annonce->dateEffet = $ann['dateEffet']; //@todo : date + $annonce->dateJugement = $ann['dateJugement']; //@todo : date + $annonce->dateInsertionSD = $ann['dateInsertionSD']; //@todo : date + $annonce->evenements = $evens; + $annonce->Lien_Annonce_Pdf = $ann['Lien_Annonce_Pdf']; + + $liste[] = $annonce; + } + } + } + + $nbReponses = count($liste); + if ($nbReponses>0){ + //$liste = array_slice($liste, $position, $nbRep); + } + $this->logger->info( "Nb Annonces $filtre retournées pour $siren (source=$filtre, id=$idAnn) = ". count($liste)); + $this->wsLog('annonces',$siren,$filtre.'/'.$idAnn); + + $output = new AnnoncesReturn(); + $output->nbReponses = $nbReponses; + $output->result = $liste; + return $output; } /** @@ -2050,13 +2050,13 @@ class Entreprise extends Scores_Ws_Server //Add acheteur $identite = $iInsee->getIdentiteLight($siren); - $entite = new AnnonceEntite(); - $entite->siret = $identite['Siret']; - $entite->raisonSociale = $identite['Nom']; - $even = new AnnonceEvenement(); - //$even->CodeEven = ''; - $even->LibEven = 'Acheteur'; - $entite->event = $even; + $entite = new AnnonceEntite(); + $entite->siret = $identite['Siret']; + $entite->raisonSociale = $identite['Nom']; + $even = new AnnonceEvenement(); + //$even->CodeEven = ''; + $even->LibEven = 'Acheteur'; + $entite->event = $even; $entites[] = $entite; //Search titulaire @@ -2490,9 +2490,9 @@ class Entreprise extends Scores_Ws_Server $this->permission('VALORISATION'); //Initialisation - $accesPartenaire = true; - if (APPLICATION_ENV == 'development') { - $accesPartenaire = false; + $accesPartenaire = true; + if (APPLICATION_ENV == 'development') { + $accesPartenaire = false; } if (empty($nic)) { $nic = 0; @@ -2727,20 +2727,20 @@ class Entreprise extends Scores_Ws_Server //Ratios global $tva, $mBil, $efftr, $tabInfla; - require_once 'Metier/Scores/MRatios.php'; + require_once 'Metier/Scores/MRatios.php'; $mBil = new Metier_Partenaires_MBilans(); - $mBil->setSiren($siren); - $tabBilans = $mBil->listeBilans($accesPartenaire, 5); - $nbBilans = count($tabBilans); - $tabBilan = $tabBil = array(); + $mBil->setSiren($siren); + $tabBilans = $mBil->listeBilans($accesPartenaire, 5); + $nbBilans = count($tabBilans); + $tabBilan = $tabBil = array(); if ($nbBilans>0) { - $iInsee = new Metier_Insee_MInsee(); - $tabIdentite = $iInsee->getIdentiteEntreprise($siren,0,0,false,false); - $this->logger->info("Liste des Ratios demandée pour $siren après getIdentiteEntreprise"); - $naf = $tabIdentite['NafEnt']; - $nafLib = $tabIdentite['NafEntLib']; - $efftr = $tabIdentite['Effectif']*1; + $iInsee = new Metier_Insee_MInsee(); + $tabIdentite = $iInsee->getIdentiteEntreprise($siren,0,0,false,false); + $this->logger->info("Liste des Ratios demandée pour $siren après getIdentiteEntreprise"); + $naf = $tabIdentite['NafEnt']; + $nafLib = $tabIdentite['NafEntLib']; + $efftr = $tabIdentite['Effectif']*1; $fj = $tabIdentite['FJ']; $i = 0; foreach ($tabBilans as $millesime => $item) { @@ -2759,141 +2759,141 @@ class Entreprise extends Scores_Ws_Server } $mRatios = new Metier_Scores_MRatios(); $mRatios->setTrancheEffectif($efftr); - $tabRatios = $mRatios->calcul($tabBilan); + $tabRatios = $mRatios->calcul($tabBilan); } - - $nbRatios = count($tabRatios); - $this->logger->info("Liste des Ratios demandée pour $siren après calculRatios ($nbRatios)"); - - $tabAnnees = array(); - if ( $nbRatios > 0 ) { - foreach ( $tabRatios as $i=>$R ) { - //Informations sur le bilan - $bilansInfos = new RatiosBilansInfos(); - $bilansInfos->dateCloture = $tabBilan[$i]['DATE_CLOTURE']; //@todo : date - $bilansInfos->duree = $tabBilan[$i]['DUREE_MOIS']; - $bilansInfos->devise = $tabBilan[$i]['MONNAIE']; - $bilansInfos->typeBilan = $tabBilan[$i]['CONSOLIDE']; - $bilansInfos->unite = 'U'; - if ( substr($tabBilan[$i]['DATE_CLOTURE'],0,4)>1900 ){ - $tabAnnees[$i]=substr($tabBilan[$i]['DATE_CLOTURE'],0,4); - } - - $tabRatiosEntrep = array(); - $tabRatiosEntrepEvol = array(); - foreach ( $R as $Ridx=>$Rmont ) { - if ($Rmont<>'NS') { - if ( $tabBorneMin[$Ridx]<>'' && $Rmont<$tabBorneMin[$Ridx] ){ - $Rmont='<'.$tabBorneMin[$Ridx]; - } elseif ( $tabBorneMax[$Ridx]<>'' && $Rmont>$tabBorneMax[$Ridx] ){ - $Rmont='>'.$tabBorneMax[$Ridx]; - } - } - - // RatiosEntrep - $ratiosEntrep = new Ratios(); - if (substr($Rmont,0,1)=='N' || substr($Rmont,0,1)=='<' || substr($Rmont,0,1)=='>'){ - $ratiosEntrep->id = 'r'.$Ridx; - $ratiosEntrep->val = $Rmont; - } else { - $ratiosEntrep->id = 'r'.$Ridx; - $ratiosEntrep->val = round($Rmont,2); - } - $tabRatiosEntrep[] = $ratiosEntrep; - - 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=(($R[$Ridx]-$tabRatios[$i+1][$Ridx])*100)/abs($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 = (($R[$Ridx]-$tabRatios[$i+2][$Ridx])*100)/abs($tabRatios[$i+2][$Ridx]); - } else { - $Rmont = 'NS'; - } - - // RatiosEntrepEvol - $ratiosEntrepEvol = new Ratios(); - if ($Rmont=='NS' || $Rmont<-800 || $Rmont>800){ - $ratiosEntrepEvol->id = 'r'.$Ridx; - $ratiosEntrepEvol->val = 'NS'; - } else { - $ratiosEntrepEvol->id = 'r'.$Ridx; - $ratiosEntrepEvol->val = number_format($Rmont,2,',',' '); - } - $tabRatiosEntrepEvol[] = $ratiosEntrepEvol; - } - $bilansInfos->RatiosEntrep = $tabRatiosEntrep; - $bilansInfos->RatiosEntrepEvol = $tabRatiosEntrepEvol; - $tabBilansR[] = $bilansInfos; - } - } - $this->logger->info("Liste des Ratios demandée pour $siren après EVOLUTION"); - - // Tableau des ratios secteurs - if (strlen($naf)>4) $strNaf = " AND naf5='$naf' "; - else $strNaf = " AND naf4='$naf' "; - $strAnnees = implode(',', $tabAnnees); - - $tabRatiosSecteurs = array(); - - $tabAnnees = array_unique($tabAnnees); - - if ( count($tabAnnees)>0 ) { - $iDb = new Metier_Util_Db(); - $tabTmp = $iDb->select('jo.ratios_secteurs', - 'annee, naf5, naf4, id, (montant/nombre) AS ratio, nombre', - "1 $strNaf AND annee IN ($strAnnees) ORDER BY annee DESC, id ASC", - false, MYSQL_ASSOC); - - $nbRatiosSec = 0; - foreach($tabAnnees as $annee) { - $ratiosSecteur = new RatiosSecteur(); - $ratiosSecteur->annee = $annee; - foreach ($tabTmp as $tmp) - { - if ($tmp['annee']== $annee) - { - $Ridx = $tmp['id']; - if ($tmp['nombre']>$nbRatiosSec){ - $nbRatiosSec = $tmp['nombre']; - } - - $unite = $tabFormulesInfos[$Ridx]['unite']; - if ($unite=='EUR'){ - $montant = round($tmp['ratio']*1000); - } else { - $montant = round($tmp['ratio']); - } - if ($tabBorneMin[$Ridx]<>'' && $montant<$tabBorneMin[$Ridx]){ - $montant='<'.$tabBorneMin[$Ridx]; - } elseif ($tabBorneMax[$Ridx]<>'' && $montant>$tabBorneMax[$Ridx]){ - $montant='>'.$tabBorneMax[$Ridx]; - } - - $ratiosSecteurListe = new Ratios(); - if (substr($montant,0,1)=='N' || substr($montant,0,1)=='<' || substr($montant,0,1)=='>'){ - $ratiosSecteurListe->id = 'r'.$Ridx; - $ratiosSecteurListe->val = $montant; - } else { - $ratiosSecteurListe->id = 'r'.$Ridx; - $ratiosSecteurListe->val = round($montant,2); - } - $ratiosSecteur->liste[] = $ratiosSecteurListe; - } - } - $tabRatiosSecteurs[] = $ratiosSecteur; - } - } - $output->RatiosBilansInfos = $tabBilansR; - $output->RatiosInfos = $tabRatiosInfos; + $nbRatios = count($tabRatios); + $this->logger->info("Liste des Ratios demandée pour $siren après calculRatios ($nbRatios)"); + + $tabAnnees = array(); + if ( $nbRatios > 0 ) { + foreach ( $tabRatios as $i=>$R ) { + //Informations sur le bilan + $bilansInfos = new RatiosBilansInfos(); + $bilansInfos->dateCloture = $tabBilan[$i]['DATE_CLOTURE']; //@todo : date + $bilansInfos->duree = $tabBilan[$i]['DUREE_MOIS']; + $bilansInfos->devise = $tabBilan[$i]['MONNAIE']; + $bilansInfos->typeBilan = $tabBilan[$i]['CONSOLIDE']; + $bilansInfos->unite = 'U'; + if ( substr($tabBilan[$i]['DATE_CLOTURE'],0,4)>1900 ){ + $tabAnnees[$i]=substr($tabBilan[$i]['DATE_CLOTURE'],0,4); + } + + $tabRatiosEntrep = array(); + $tabRatiosEntrepEvol = array(); + foreach ( $R as $Ridx=>$Rmont ) { + if ($Rmont<>'NS') { + if ( $tabBorneMin[$Ridx]<>'' && $Rmont<$tabBorneMin[$Ridx] ){ + $Rmont='<'.$tabBorneMin[$Ridx]; + } elseif ( $tabBorneMax[$Ridx]<>'' && $Rmont>$tabBorneMax[$Ridx] ){ + $Rmont='>'.$tabBorneMax[$Ridx]; + } + } + + // RatiosEntrep + $ratiosEntrep = new Ratios(); + if (substr($Rmont,0,1)=='N' || substr($Rmont,0,1)=='<' || substr($Rmont,0,1)=='>'){ + $ratiosEntrep->id = 'r'.$Ridx; + $ratiosEntrep->val = $Rmont; + } else { + $ratiosEntrep->id = 'r'.$Ridx; + $ratiosEntrep->val = round($Rmont,2); + } + $tabRatiosEntrep[] = $ratiosEntrep; + + 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=(($R[$Ridx]-$tabRatios[$i+1][$Ridx])*100)/abs($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 = (($R[$Ridx]-$tabRatios[$i+2][$Ridx])*100)/abs($tabRatios[$i+2][$Ridx]); + } else { + $Rmont = 'NS'; + } + + // RatiosEntrepEvol + $ratiosEntrepEvol = new Ratios(); + if ($Rmont=='NS' || $Rmont<-800 || $Rmont>800){ + $ratiosEntrepEvol->id = 'r'.$Ridx; + $ratiosEntrepEvol->val = 'NS'; + } else { + $ratiosEntrepEvol->id = 'r'.$Ridx; + $ratiosEntrepEvol->val = number_format($Rmont,2,',',' '); + } + $tabRatiosEntrepEvol[] = $ratiosEntrepEvol; + } + $bilansInfos->RatiosEntrep = $tabRatiosEntrep; + $bilansInfos->RatiosEntrepEvol = $tabRatiosEntrepEvol; + $tabBilansR[] = $bilansInfos; + } + } + $this->logger->info("Liste des Ratios demandée pour $siren après EVOLUTION"); + + // Tableau des ratios secteurs + if (strlen($naf)>4) $strNaf = " AND naf5='$naf' "; + else $strNaf = " AND naf4='$naf' "; + $strAnnees = implode(',', $tabAnnees); + + $tabRatiosSecteurs = array(); + + $tabAnnees = array_unique($tabAnnees); + + if ( count($tabAnnees)>0 ) { + $iDb = new Metier_Util_Db(); + $tabTmp = $iDb->select('jo.ratios_secteurs', + 'annee, naf5, naf4, id, (montant/nombre) AS ratio, nombre', + "1 $strNaf AND annee IN ($strAnnees) ORDER BY annee DESC, id ASC", + false, MYSQL_ASSOC); + + $nbRatiosSec = 0; + foreach($tabAnnees as $annee) { + $ratiosSecteur = new RatiosSecteur(); + $ratiosSecteur->annee = $annee; + foreach ($tabTmp as $tmp) + { + if ($tmp['annee']== $annee) + { + $Ridx = $tmp['id']; + if ($tmp['nombre']>$nbRatiosSec){ + $nbRatiosSec = $tmp['nombre']; + } + + $unite = $tabFormulesInfos[$Ridx]['unite']; + if ($unite=='EUR'){ + $montant = round($tmp['ratio']*1000); + } else { + $montant = round($tmp['ratio']); + } + if ($tabBorneMin[$Ridx]<>'' && $montant<$tabBorneMin[$Ridx]){ + $montant='<'.$tabBorneMin[$Ridx]; + } elseif ($tabBorneMax[$Ridx]<>'' && $montant>$tabBorneMax[$Ridx]){ + $montant='>'.$tabBorneMax[$Ridx]; + } + + $ratiosSecteurListe = new Ratios(); + if (substr($montant,0,1)=='N' || substr($montant,0,1)=='<' || substr($montant,0,1)=='>'){ + $ratiosSecteurListe->id = 'r'.$Ridx; + $ratiosSecteurListe->val = $montant; + } else { + $ratiosSecteurListe->id = 'r'.$Ridx; + $ratiosSecteurListe->val = round($montant,2); + } + $ratiosSecteur->liste[] = $ratiosSecteurListe; + } + } + $tabRatiosSecteurs[] = $ratiosSecteur; + } + } + + $output->RatiosBilansInfos = $tabBilansR; + $output->RatiosInfos = $tabRatiosInfos; $output->RatiosSecteur = $tabRatiosSecteurs; $this->wsLog('valorisation',$siren); @@ -3893,16 +3893,16 @@ class Entreprise extends Scores_Ws_Server //Si la donnée existe déjà et que la source=score alors il faut mettre à jour l'encours client if ($source == 'score' && $detect[0]['dateSuppr']=='0000-00-00 00:00:00') { - $data = array ( - 'encoursClient' => $encoursClient, + $data = array ( + 'encoursClient' => $encoursClient, ); $result = $iDb->update('jo.surveillances_site', $data, $where, false, 0, true); } elseif ( $detect[0]['dateSuppr']!='0000-00-00 00:00:00') { $data = array ( - 'dateAjout' => date('Y-m-d'), - 'dateSuppr' => '0000-00-00 00:00:00', + 'dateAjout' => date('Y-m-d'), + 'dateSuppr' => '0000-00-00 00:00:00', ); $result = $iDb->update('jo.surveillances_site', $data, $where, false, 0, true); @@ -4272,7 +4272,7 @@ class Entreprise extends Scores_Ws_Server 'devise', 'ID_BILAN_SD', 'DATE_BILAN_SD', - 'TOP_CONFIDENTIEL', + 'TOP_CONFIDENTIEL', ); $resultBilan = new Bilan(); @@ -4317,7 +4317,7 @@ class Entreprise extends Scores_Ws_Server $mBil = new Metier_Partenaires_MBilans(); $mBil->setSiren($siren); - $tabBilans = $mBil->listeBilans(true); + $tabBilans = $mBil->listeBilans(true, 0, $this->User->idClient); foreach($tabBilans as $bilan) { $element = new ListeBilans(); $element->dateProvPartenaire = $bilan['dateProvPartenaire']; //@todo : date @@ -4602,10 +4602,10 @@ class Entreprise extends Scores_Ws_Server $accesPartenaire = false; } - $tabRatiosInfos = $tabRatiosSecteurs = $tabBilansR = array(); - $tabRatios = $tabRatiosEvol = array(); + $tabRatiosInfos = $tabRatiosSecteurs = $tabBilansR = array(); + $tabRatios = $tabRatiosEvol = array(); $tabRet = array(); - + /** * Tableau d'infos sur les formules */ @@ -5312,7 +5312,7 @@ class Entreprise extends Scores_Ws_Server 'sirenAsso', //sirenIn 'nomAsso', 'sirenOrigine', //sirenOut - 'libOrigine', //Origine + 'libOrigine', //Origine 'libImputation', //Programme 'mtSubvention', //Montant ));