From 852f9b44de545be0e9087f77b1f9a1af0af5f806 Mon Sep 17 00:00:00 2001 From: Michael RICOIS Date: Wed, 15 Mar 2017 12:27:35 +0100 Subject: [PATCH 01/24] Fix catch exception on DBAL --- library/WsScore/Order/v0.1/Service.php | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/library/WsScore/Order/v0.1/Service.php b/library/WsScore/Order/v0.1/Service.php index 8fa5a100..100ba04a 100644 --- a/library/WsScore/Order/v0.1/Service.php +++ b/library/WsScore/Order/v0.1/Service.php @@ -403,7 +403,7 @@ class Order extends Scores_Ws_Server $item = $stmt->fetch(\PDO::FETCH_OBJ); } } - catch(Zend_Db_Exception $e) { + catch(\Doctrine\DBAL\DBALException $e) { if ($this->User->idClient == 1) { throw new SoapFault('ERR', $e->getMessage()); } else { From 30247e5d6a7f753987ff35eb0e74e8bfabdea824 Mon Sep 17 00:00:00 2001 From: Michael RICOIS Date: Wed, 15 Mar 2017 12:36:10 +0100 Subject: [PATCH 02/24] Remove all Zend_Db call --- library/WsScore/Interne/v0.6/Service.php | 44 +++++++++++++----------- 1 file changed, 24 insertions(+), 20 deletions(-) diff --git a/library/WsScore/Interne/v0.6/Service.php b/library/WsScore/Interne/v0.6/Service.php index d97da90a..7b62fdab 100644 --- a/library/WsScore/Interne/v0.6/Service.php +++ b/library/WsScore/Interne/v0.6/Service.php @@ -2715,14 +2715,16 @@ class Interne extends Scores_Ws_Server $this->authenticate(); try { - $db = Zend_Db_Table_Abstract::getDefaultAdapter(); - $db->setFetchMode(Zend_Db::FETCH_OBJ); - $sql = $db->select()->from('rncs_even', '*', 'jo') - ->join('tabEvenRncs', 'rncs_even.codeEven = tabEvenRncs.codeEven', array('libEven'), 'jo') - ->where('rncs_even.siren=?', $companyId); - $result = $db->fetchAll($sql); - } catch (Zend_Db_Exception $e) { - if ($this->User->idClient==1) { + $sql = "SELECT r.*, t.libEven FROM jo.rncs_even r, jo.tabEvenRncs t + WHERE r.codeEven = t.codeEven AND r.siren=:siren"; + $stmt = $this->conn->prepare($sql); + $stmt->bindValue('siren', $companyId); + $stmt->execute(); + } catch(\Doctrine\DBAL\DBALException $e) { + if ($this->logger !== null) { + $this->logger->error($e->getMessage()); + } + if ($this->User->idClient == 1) { throw new SoapFault('ERR', $e->getMessage()); } else { throw new SoapFault('ERR', "Application error"); @@ -2730,8 +2732,8 @@ class Interne extends Scores_Ws_Server } $evenList = array(); - if (count($result) > 0) { - foreach ($result as $item) { + if ($stmt->rowCount() > 0) { + while($item = $stmt->fetch(\PDO::FETCH_OBJ)) { $even = new RncsEven(); $even->Code = $item->codeEven; $even->Label = $item->libEven; @@ -2755,14 +2757,16 @@ class Interne extends Scores_Ws_Server $this->authenticate(); try { - $db = Zend_Db_Table_Abstract::getDefaultAdapter(); - $db->setFetchMode(Zend_Db::FETCH_OBJ); - $sql = $db->select()->from('rncs_jugements', array('siren', 'codeJugement', 'dateEffet', 'typeDate', 'dateInsert'), 'jo') - ->join('tabJugeRncs', 'rncs_jugements.codeJugement = tabJugeRncs.codJugement', array('libJugement'), 'jo') - ->where('rncs_jugements.siren=?', $companyId); - $result = $db->fetchAll($sql); - } catch (Zend_Db_Exception $e) { - if ($this->User->idClient==1) { + $sql = "SELECT siren, r.codeJugement, r.dateEffet, r.typeDate, r.dateInsert, t.libJugement FROM jo.rncs_jugements r, jo.tabJugeRncs t + WHERE r.codeJugement = t.codJugement AND r.siren=:siren"; + $stmt = $this->conn->prepare($sql); + $stmt->bindValue('siren', $companyId); + $stmt->execute(); + } catch(\Doctrine\DBAL\DBALException $e) { + if ($this->logger !== null) { + $this->logger->error($e->getMessage()); + } + if ($this->User->idClient == 1) { throw new SoapFault('ERR', $e->getMessage()); } else { throw new SoapFault('ERR', "Application error"); @@ -2770,8 +2774,8 @@ class Interne extends Scores_Ws_Server } $evenList = array(); - if (count($result) > 0) { - foreach ($result as $item) { + if ($stmt->rowCount() > 0) { + while($item = $stmt->fetch(\PDO::FETCH_OBJ)) { $even = new RncsJugement(); $even->Code = $item->codeJugement; $even->Label = $item->libJugement; From 7dc7ff1448973523b1f4e66dcfa17242a76115fa Mon Sep 17 00:00:00 2001 From: Michael RICOIS Date: Wed, 15 Mar 2017 14:38:57 +0100 Subject: [PATCH 03/24] Entreprise - getAvisRncs : remove Zend_Db et Application_Model --- library/WsScore/Entreprise/v0.8/Service.php | 32 +++++++++++---------- 1 file changed, 17 insertions(+), 15 deletions(-) diff --git a/library/WsScore/Entreprise/v0.8/Service.php b/library/WsScore/Entreprise/v0.8/Service.php index 892b5b09..8643ee51 100644 --- a/library/WsScore/Entreprise/v0.8/Service.php +++ b/library/WsScore/Entreprise/v0.8/Service.php @@ -290,8 +290,6 @@ class Entreprise extends Scores_Ws_Server $this->sendError('1020'); } - $db = Zend_Db_Table_Abstract::getDefaultAdapter(); - $output = new AvisRncs(); $rncs = new Metier_Partenaires_MRncs(); @@ -342,17 +340,22 @@ class Entreprise extends Scores_Ws_Server //Date du dernier bilan - MOIS/JOUR au pire chercher dans l'annonce try { - $bilanM = new Application_Model_JoBilans(); - $sql = $bilanM->select(true) - ->columns(array('dateExercice')) - ->where('siren=?', $siren) - ->order('dateExercice DESC')->limit(1); - $result = $bilanM->fetchRow($sql); - if ($result !== null) { - $output->CompteArretMois = substr($result->dateExercice,4,2); - $output->CompteArretJour = substr($result->dateExercice,6,2); - } - } catch(Zend_Db_Exception $e) {} + $sql = "SELECT dateExercice FROM jo.bilans WHERE siren=:siren + ORDER BY dateExercice LIMIT 0,1"; + $stmt = $this->conn->prepare($sql); + $stmt->bindValue('siren', $siren); + $stmt->execute(); + if ($stmt->rowCount() > 0) { + $result = $stmt->fetch(\PDO::FETCH_OBJ); + $output->CompteArretMois = substr($result->dateExercice,4,2); + $output->CompteArretJour = substr($result->dateExercice,6,2); + } + } catch(\Doctrine\DBAL\DBALException $e) { + if ($this->logger !== null) { + $this->logger->error($e->getMessage()); + } + } + //=> Avec l'adresse du premier siège $output->ConstitutionTribunalCode = ''; @@ -361,8 +364,7 @@ class Entreprise extends Scores_Ws_Server $iInsee = new Metier_Insee_MInsee(); $dirs = $iInsee->getDirigeants($siren, false); $liste = array(); - foreach ($dirs as $nb => $dir) - { + foreach ($dirs as $nb => $dir) { $dirigeant = new AvisRncsAdmin(); $dirigeant->Code = $dir['Fonction']; From 64a99317388d5a414cc23faeabef3469196db24b Mon Sep 17 00:00:00 2001 From: Michael RICOIS Date: Wed, 15 Mar 2017 14:47:28 +0100 Subject: [PATCH 04/24] Entreprise - getLiasseInfos : remove Application_Model --- library/WsScore/Entreprise/v0.8/Service.php | 62 +++++++++++---------- 1 file changed, 34 insertions(+), 28 deletions(-) diff --git a/library/WsScore/Entreprise/v0.8/Service.php b/library/WsScore/Entreprise/v0.8/Service.php index 8643ee51..e75df8d9 100644 --- a/library/WsScore/Entreprise/v0.8/Service.php +++ b/library/WsScore/Entreprise/v0.8/Service.php @@ -4357,28 +4357,29 @@ class Entreprise extends Scores_Ws_Server //Check SIREN //Lecture de la base de données - try { - $bilansM = new Application_Model_JoGreffesBilans(); - $sql = $bilansM->select() - ->where('siren=?', $siren) - ->where('actif=1') - ->order('date_cloture DESC') - ->order('num_depot DESC') - ->order('dateInsert DESC') - ->limit(1); - $row = $bilansM->fetchRow($sql); - } catch (Zend_Db_Exception $e) { - if ($this->User->idClient==1) { + try { + $sql = "SELECT * FROM jo.greffes_bilans WHERE siren=:siren AND actif=1 + ORDER BY date_cloture DESC, num_depot DESC, dateInsert DESC"; + $stmt = $this->conn->prepare($sql); + $stmt->bindValue('siren', $siren); + $stmt->execute(); + } catch(\Doctrine\DBAL\DBALException $e) { + if ($this->logger !== null) { + $this->logger->error($e->getMessage()); + } + if ($this->User->idClient == 1) { throw new SoapFault('ERR', $e->getMessage()); } else { throw new SoapFault('ERR', "Application error"); } } - if ( $row === null ) { - return null; + if ($stmt->rowCount() == 0) { + return null; } + $row = $stmt->fetch(\PDO::FETCH_OBJ); + $liasseInfos = new LiasseInfos(); $liasseInfos->Id = $row->id; $liasseInfos->BilanDateCloture = $row->date_cloture; @@ -4425,21 +4426,26 @@ class Entreprise extends Scores_Ws_Server //Surcharge des codes de saisie $date = DateTime::createFromFormat('Y-m-d', $row->date_cloture); try { - $liasseM = new Application_Model_JoBilans(); - $sql = $liasseM->select() - ->where('siren=?', $siren) - ->where('typeBilan=?', $liasseInfos->BilanType) - ->where('dateExercice=?', $date->format('Ymd')); - $row = $liasseM->fetchRow($sql); - } catch (Zend_Db_Exception $e) { - //file_put_contents('debug.log', $e->getMessage()."\n", FILE_APPEND); - } - if ( $row !== null ) { - $liasseInfos->SaisieDate = substr($row->dateProvPartenaire,0,4) . - '-' . substr($row->dateProvPartenaire,4,2) . - '-' . substr($row->dateProvPartenaire,6,2); - $liasseInfos->SaisieCode = '00'; + $sql = "SELECT * FROM jo.bilans + WHERE siren=:siren AND typeBilan=:type AND dateExercice=:date"; + $stmt = $this->conn->prepare($sql); + $stmt->bindValue('siren', $siren); + $stmt->bindValue('type', $liasseInfos->BilanType); + $stmt->bindValue('date', $date->format('Ymd')); + $stmt->execute(); + if ($stmt->rowCount() > 0) { + $row = $stmt->fetch(\PDO::FETCH_OBJ); + $liasseInfos->SaisieDate = substr($row->dateProvPartenaire,0,4) . + '-' . substr($row->dateProvPartenaire,4,2) . + '-' . substr($row->dateProvPartenaire,6,2); + $liasseInfos->SaisieCode = '00'; + } + } catch(\Doctrine\DBAL\DBALException $e) { + if ($this->logger !== null) { + $this->logger->error($e->getMessage()); + } } + } return $liasseInfos; From cbae95cf2b56f7a66cc76f241d22d8a2908d2ec6 Mon Sep 17 00:00:00 2001 From: Michael RICOIS Date: Wed, 15 Mar 2017 14:53:12 +0100 Subject: [PATCH 05/24] Entreprise - getLiens : remove Application_Model --- library/WsScore/Entreprise/v0.8/Service.php | 33 +++++++++++---------- 1 file changed, 17 insertions(+), 16 deletions(-) diff --git a/library/WsScore/Entreprise/v0.8/Service.php b/library/WsScore/Entreprise/v0.8/Service.php index e75df8d9..a9163177 100644 --- a/library/WsScore/Entreprise/v0.8/Service.php +++ b/library/WsScore/Entreprise/v0.8/Service.php @@ -831,31 +831,32 @@ class Entreprise extends Scores_Ws_Server $this->permission('liens'); //Load country table - try { - $countryM = new Application_Model_JoTabPays(); - $sql = $countryM->select()->from($countryM, array('codPays3', 'libPays')); - $result = $countryM->fetchAll($sql); - } 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"); + try { + $sql = "SELECT codPays3, libPays FROM jo.tabPays"; + $stmt = $this->conn->prepare($sql); + $stmt->execute(); + } catch(\Doctrine\DBAL\DBALException $e) { + if ($this->logger !== null) { + $this->logger->error($e->getMessage()); + } + if ($this->User->idClient == 1) { + throw new SoapFault('ERR', $e->getMessage()); + } else { + throw new SoapFault('ERR', "Application error"); + } } + $tabPays = array(); - if ( $result->count()>0 ) { - foreach ( $result as $item ) { + if ($stmt->count() > 0) { + while ($item = $stmt->fetch(\PDO::FETCH_OBJ)) { $tabPays[$item->codPays3] = $item->libPays; } } $tabAct = $tabPar = $tabDir = array(); - try - { + try { $liensM = new Metier_Liens_Base(); $liensM->setId($siren, 'siren'); From 73f5b36ef49a20d4799245a7f9f671b50b0fc845 Mon Sep 17 00:00:00 2001 From: Michael RICOIS Date: Wed, 15 Mar 2017 14:59:59 +0100 Subject: [PATCH 06/24] Entreprise - getLiens : remove Application_Model --- library/WsScore/Entreprise/v0.8/Service.php | 63 +++++++++++++-------- 1 file changed, 38 insertions(+), 25 deletions(-) diff --git a/library/WsScore/Entreprise/v0.8/Service.php b/library/WsScore/Entreprise/v0.8/Service.php index a9163177..39f74aec 100644 --- a/library/WsScore/Entreprise/v0.8/Service.php +++ b/library/WsScore/Entreprise/v0.8/Service.php @@ -895,23 +895,30 @@ class Entreprise extends Scores_Ws_Server $nbIdNum = 3; $refs = array(); - $idM = new Application_Model_Sdv1TabIdLocal(); for ($i=0;$i<$nbIdNum;$i++) { if( !empty($item->{'idLoc'.$i.'Num'}) ) { $ref = new LienRefId(); $ref->num = $item->{'idLoc'.$i.'Num'}; - if ( !empty($item->{'idLoc'.$i.'Type'}) ) { - $sql = $idM->select()->from($idM, array('idLocal', 'idPrincipal')) - ->where('id=?', $item->{'idLoc'.$i.'Type'}); - $result = $idM->fetchRow($sql); - if (null!==$result) { - $ref->label = $result->idLocal; - $ref->type = $result->idPrincipal; - } else { - $ref->label = ''; - $ref->type = 0; - } + if (!empty($item->{'idLoc'.$i.'Type'})) { + try { + $sql = "SELECT idLocal, idPrincipal FROM sdv1.tabIdLocal WHERE id=:id"; + $stmt = $this->conn->prepare($sql); + $stmt->bindValue('id', $item->{'idLoc'.$i.'Type'}); + $stmt->execute(); + if ($stmt->rowCount() > 0) { + $result = $stmt->fetch(\PDO::FETCH_OBJ); + $ref->label = $result->idLocal; + $ref->type = $result->idPrincipal; + } else { + $ref->label = ''; + $ref->type = 0; + } + } catch(\Doctrine\DBAL\DBALException $e) { + if ($this->logger !== null) { + $this->logger->error($e->getMessage()); + } + } } else { $ref->label = 'Identifiant local'; $ref->type = 1; @@ -926,7 +933,7 @@ class Entreprise extends Scores_Ws_Server } } - //Participations + // Participations $liens = $liensM->getParticipations(null, true); if (count($liens)>0) { foreach ( $liens as $item ) { @@ -961,22 +968,28 @@ class Entreprise extends Scores_Ws_Server $nbIdNum = 3; $refs = array(); - $idM = new Application_Model_Sdv1TabIdLocal(); for ($i=0;$i<$nbIdNum;$i++) { if( !empty($item->{'idLoc'.$i.'Num'}) ) { $ref = new LienRefId(); $ref->num = $item->{'idLoc'.$i.'Num'}; - - if ( !empty($item->{'idLoc'.$i.'Type'}) ) { - $sql = $idM->select()->from($idM, array('idLocal', 'idPrincipal')) - ->where('id=?', $item->{'idLoc'.$i.'Type'}); - $result = $idM->fetchRow($sql); - if (null!==$result) { - $ref->label = $result->idLocal; - $ref->type = $result->idPrincipal; - } else { - $ref->label = ''; - $ref->type = 0; + if (!empty($item->{'idLoc'.$i.'Type'})) { + try { + $sql = "SELECT idLocal, idPrincipal FROM sdv1.tabIdLocal WHERE id=:id"; + $stmt = $this->conn->prepare($sql); + $stmt->bindValue('id', $item->{'idLoc'.$i.'Type'}); + $stmt->execute(); + if ($stmt->rowCount() > 0) { + $result = $stmt->fetch(\PDO::FETCH_OBJ); + $ref->label = $result->idLocal; + $ref->type = $result->idPrincipal; + } else { + $ref->label = ''; + $ref->type = 0; + } + } catch(\Doctrine\DBAL\DBALException $e) { + if ($this->logger !== null) { + $this->logger->error($e->getMessage()); + } } } else { $ref->label = 'Identifiant local'; From a66fc301194ed567131a3aefe73150f3597a558e Mon Sep 17 00:00:00 2001 From: Michael RICOIS Date: Wed, 15 Mar 2017 15:04:31 +0100 Subject: [PATCH 07/24] Entreprise - getLienRef : remove Application_Model --- library/WsScore/Entreprise/v0.8/Service.php | 57 ++++++++++++--------- 1 file changed, 34 insertions(+), 23 deletions(-) diff --git a/library/WsScore/Entreprise/v0.8/Service.php b/library/WsScore/Entreprise/v0.8/Service.php index 39f74aec..8f7b2fb8 100644 --- a/library/WsScore/Entreprise/v0.8/Service.php +++ b/library/WsScore/Entreprise/v0.8/Service.php @@ -1277,24 +1277,28 @@ 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 { + $sql = "SELECT * FROM jo.liensRef WHERE id=:id"; + $stmt = $this->conn->prepare($sql); + $stmt->bindValue('siren', $companyId); + $stmt->execute(); + } catch(\Doctrine\DBAL\DBALException $e) { + if ($this->logger !== null) { + $this->logger->error($e->getMessage()); + } + if ($this->User->idClient == 1) { + throw new SoapFault('ERR', $e->getMessage()); + } else { + throw new SoapFault('ERR', "Application error"); + } + } - if ($rows->count()==0) { + if ($stmt->count() == 0) { throw new SoapFault('MSG', 'Aucun résultat'); } - $result = $rows->current()->toArray(); + $result = $stmt->fetch(\PDO::FETCH_ASSOC); $output = new LienRef(); $output->siren = $result['siren']; @@ -1335,20 +1339,27 @@ class Entreprise extends Scores_Ws_Server $nbIdNum = 3; $refs = array(); - $idM = new Application_Model_Sdv1TabIdLocal(); for ($i=0;$i<$nbIdNum;$i++) { if( !empty($result['idLoc'.$i.'Type']) ) { $ref = new LienRefId(); $ref->num = $result['idLoc'.$i.'Num']; - $sql = $idM->select()->from($idM, array('idLocal', 'idPrincipal')) - ->where('id=?', $result['idLoc'.$i.'Type']); - $result = $idM->fetchRow($sql); - if (null!==$result) { - $ref->label = $result->idLocal; - $ref->type = $result->idPrincipal; - } else { - $ref->label = ''; - $ref->type = 0; + try { + $sql = "SELECT idLocal, idPrincipal FROM sdv1.tabIdLocal WHERE id=:id"; + $stmt = $this->conn->prepare($sql); + $stmt->bindValue('id', $result['idLoc'.$i.'Type']); + $stmt->execute(); + if ($stmt->rowCount() > 0) { + $result = $stmt->fetch(\PDO::FETCH_OBJ); + $ref->label = $result->idLocal; + $ref->type = $result->idPrincipal; + } else { + $ref->label = ''; + $ref->type = 0; + } + } catch(\Doctrine\DBAL\DBALException $e) { + if ($this->logger !== null) { + $this->logger->error($e->getMessage()); + } } $refs[] = $ref; From 22e907ceaf391362ce4dfb98e42b8ccb9ee8b5ae Mon Sep 17 00:00:00 2001 From: Michael RICOIS Date: Wed, 15 Mar 2017 15:07:14 +0100 Subject: [PATCH 08/24] Entreprise - getLiensById : remove Application_Model --- library/WsScore/Entreprise/v0.8/Service.php | 108 +++++++++++--------- 1 file changed, 60 insertions(+), 48 deletions(-) diff --git a/library/WsScore/Entreprise/v0.8/Service.php b/library/WsScore/Entreprise/v0.8/Service.php index 8f7b2fb8..382dc349 100644 --- a/library/WsScore/Entreprise/v0.8/Service.php +++ b/library/WsScore/Entreprise/v0.8/Service.php @@ -846,7 +846,6 @@ class Entreprise extends Scores_Ws_Server } } - $tabPays = array(); if ($stmt->count() > 0) { while ($item = $stmt->fetch(\PDO::FETCH_OBJ)) { @@ -1061,35 +1060,36 @@ class Entreprise extends Scores_Ws_Server $this->authenticate(); $this->permission('liens'); + //Load country table try { - $countryM = new Application_Model_JoTabPays(); - $sql = $countryM->select()->from($countryM, array('codPays3', 'libPays')); - $result = $countryM->fetchAll($sql); - } 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"); + $sql = "SELECT codPays3, libPays FROM jo.tabPays"; + $stmt = $this->conn->prepare($sql); + $stmt->execute(); + } catch(\Doctrine\DBAL\DBALException $e) { + if ($this->logger !== null) { + $this->logger->error($e->getMessage()); + } + if ($this->User->idClient == 1) { + throw new SoapFault('ERR', $e->getMessage()); + } else { + throw new SoapFault('ERR', "Application error"); + } } - $tabPays = array(); - if ( $result->count()>0 ) { - foreach ( $result as $item ) { - $tabPays[$item->codPays3] = $item->libPays; - } - } + $tabPays = array(); + if ($stmt->count() > 0) { + while ($item = $stmt->fetch(\PDO::FETCH_OBJ)) { + $tabPays[$item->codPays3] = $item->libPays; + } + } $tabAct = $tabPar = $tabDir = array(); - try - { + try { $liensM = new Metier_Liens_Base(); $liensM->setId($id); - //Actionnaires + // Actionnaires $liens = $liensM->getActionnaires(null, true); if (count($liens)>0) { foreach ( $liens as $item ) { @@ -1124,23 +1124,29 @@ class Entreprise extends Scores_Ws_Server $nbIdNum = 3; $refs = array(); - $idM = new Application_Model_Sdv1TabIdLocal(); for ($i=0;$i<$nbIdNum;$i++) { if( !empty($item->{'idLoc'.$i.'Num'}) ) { $ref = new LienRefId(); $ref->num = $item->{'idLoc'.$i.'Num'}; - - if ( !empty($item->{'idLoc'.$i.'Type'}) ) { - $sql = $idM->select()->from($idM, array('idLocal', 'idPrincipal')) - ->where('id=?', $item->{'idLoc'.$i.'Type'}); - $result = $idM->fetchRow($sql); - if (null!==$result) { - $ref->label = $result->idLocal; - $ref->type = $result->idPrincipal; - } else { - $ref->label = ''; - $ref->type = 0; - } + if (!empty($item->{'idLoc'.$i.'Type'})) { + try { + $sql = "SELECT idLocal, idPrincipal FROM sdv1.tabIdLocal WHERE id=:id"; + $stmt = $this->conn->prepare($sql); + $stmt->bindValue('id', $item->{'idLoc'.$i.'Type'}); + $stmt->execute(); + if ($stmt->rowCount() > 0) { + $result = $stmt->fetch(\PDO::FETCH_OBJ); + $ref->label = $result->idLocal; + $ref->type = $result->idPrincipal; + } else { + $ref->label = ''; + $ref->type = 0; + } + } catch(\Doctrine\DBAL\DBALException $e) { + if ($this->logger !== null) { + $this->logger->error($e->getMessage()); + } + } } else { $ref->label = 'Identifiant local'; $ref->type = 1; @@ -1155,7 +1161,7 @@ class Entreprise extends Scores_Ws_Server } } - //Participations + // Participations $liens = $liensM->getParticipations(null, true); if (count($liens)>0) { foreach ( $liens as $item ) { @@ -1190,23 +1196,29 @@ class Entreprise extends Scores_Ws_Server $nbIdNum = 3; $refs = array(); - $idM = new Application_Model_Sdv1TabIdLocal(); for ($i=0;$i<$nbIdNum;$i++) { - if( !empty($item->{'idLoc'.$i.'Num'}) ) { + if (!empty($item->{'idLoc'.$i.'Num'})) { $ref = new LienRefId(); $ref->num = $item->{'idLoc'.$i.'Num'}; - if ( !empty($item->{'idLoc'.$i.'Type'}) ) { - $sql = $idM->select()->from($idM, array('idLocal', 'idPrincipal')) - ->where('id=?', $item->{'idLoc'.$i.'Type'}); - $result = $idM->fetchRow($sql); - if (null!==$result) { - $ref->label = $result->idLocal; - $ref->type = $result->idPrincipal; - } else { - $ref->label = ''; - $ref->type = 0; - } + try { + $sql = "SELECT idLocal, idPrincipal FROM sdv1.tabIdLocal WHERE id=:id"; + $stmt = $this->conn->prepare($sql); + $stmt->bindValue('id', $item->{'idLoc'.$i.'Type'}); + $stmt->execute(); + if ($stmt->rowCount() > 0) { + $result = $stmt->fetch(\PDO::FETCH_OBJ); + $ref->label = $result->idLocal; + $ref->type = $result->idPrincipal; + } else { + $ref->label = ''; + $ref->type = 0; + } + } catch(\Doctrine\DBAL\DBALException $e) { + if ($this->logger !== null) { + $this->logger->error($e->getMessage()); + } + } } else { $ref->label = 'Identifiant local'; $ref->type = 1; From 2ad397baf3096aa4f2e5768c1ddc79bc8443780e Mon Sep 17 00:00:00 2001 From: Michael RICOIS Date: Wed, 15 Mar 2017 15:15:06 +0100 Subject: [PATCH 09/24] Entreprise - getGreffeAffaireDetail : remove Application_Model --- library/WsScore/Entreprise/v0.9/Service.php | 52 +++++++++++++-------- 1 file changed, 33 insertions(+), 19 deletions(-) diff --git a/library/WsScore/Entreprise/v0.9/Service.php b/library/WsScore/Entreprise/v0.9/Service.php index dcec3fdc..c673ba82 100644 --- a/library/WsScore/Entreprise/v0.9/Service.php +++ b/library/WsScore/Entreprise/v0.9/Service.php @@ -934,13 +934,16 @@ class Entreprise extends Scores_Ws_Server $this->authenticate(); $this->permission('contentieux'); - $db = Zend_Db_Table_Abstract::getDefaultAdapter(); - - $affaireSql = "SELECT id, idAffaire, numGreffe, natureDemande, codNatureDemande, etatAffaire, dateEnrolement FROM jo.greffes_affaires ". - "WHERE id=".$id; try { - $affaireResult = $db->fetchRow($affaireSql, null, Zend_DB::FETCH_OBJ); - } catch (Zend_Db_Exception $e) { + $sql = "SELECT id, idAffaire, numGreffe, natureDemande, codNatureDemande, etatAffaire, dateEnrolement + FROM jo.greffes_affaires WHERE id=:id"; + $stmt = $this->conn->prepare($sql); + $stmt->bindValue('id', $id); + $stmt->execute(); + } catch(\Doctrine\DBAL\DBALException $e) { + if ($this->logger !== null) { + $this->logger->error($e->getMessage()); + } if ($this->User->idClient == 1) { throw new SoapFault('ERR', $e->getMessage()); } else { @@ -949,17 +952,22 @@ class Entreprise extends Scores_Ws_Server } // --- Aucun resultat - if ($affaireResult === null) { + if ($stmt->rowCount() == 0) { throw new SoapFault('MSG', "Aucun résultat"); } + $affaireResult = $stmt->fetch(\PDO::FETCH_OBJ); + // --- Selection des Entités $tiers = array(); $entiteSql = "SELECT * FROM jo.greffes_affaires_siren WHERE idAffaire='".$affaireResult->idAffaire."' ORDER BY FIELD(qualite, 'DE', 'DF')"; try { - $entiteResult = $db->fetchAll($entiteSql, null, Zend_DB::FETCH_OBJ); - if (count($entiteResult) > 0) { - foreach ($entiteResult as $item) { + $sql = "SELECT * FROM jo.greffes_affaires_siren WHERE idAffaire=:id ORDER BY FIELD(qualite, 'DE', 'DF')"; + $stmt = $this->conn->prepare($sql); + $stmt->bindValue('id', $affaireResult->idAffaire); + $stmt->execute(); + if ($stmt->rowCount() > 0) { + while($item = $stmt->fetch(\PDO::FETCH_OBJ)) { $entite = new GreffeAffaireTiers(); $entite->companyId = $item->entSiren; $entite->companyNom = $item->nomPartie; @@ -985,7 +993,10 @@ class Entreprise extends Scores_Ws_Server } } - } catch (Zend_Db_Exception $e) { + } catch(\Doctrine\DBAL\DBALException $e) { + if ($this->logger !== null) { + $this->logger->error($e->getMessage()); + } if ($this->User->idClient == 1) { throw new SoapFault('ERR', $e->getMessage()); } else { @@ -995,11 +1006,13 @@ class Entreprise extends Scores_Ws_Server // --- Selection de l'historique $histo = array(); - $histoSql = "SELECT * FROM jo.greffes_affaires_histo WHERE idAffaire='".$affaireResult->idAffaire."' ORDER BY dateDecision DESC"; try { - $histoResult = $db->fetchAll($histoSql, null, Zend_DB::FETCH_OBJ); - if (count($histoResult) > 0) { - foreach ($histoResult as $h){ + $sql = "SELECT * FROM jo.greffes_affaires_histo WHERE idAffaire=:id ORDER BY dateDecision DESC"; + $stmt = $this->conn->prepare($sql); + $stmt->bindValue('id', $affaireResult->idAffaire); + $stmt->execute(); + if ($stmt->rowCount() > 0) { + while ($h = $stmt->fetch(\PDO::FETCH_OBJ)) { $decision = new GreffeAffaireHisto(); $decision->Label = $h->libelleDecision; $decision->Date = $h->dateDecision; @@ -1007,8 +1020,11 @@ class Entreprise extends Scores_Ws_Server $histo[] = $decision; } } - - } catch (Zend_Db_Exception $e) {} + } catch(\Doctrine\DBAL\DBALException $e) { + if ($this->logger !== null) { + $this->logger->error($e->getMessage()); + } + } // --- Formattage $status = include APPLICATION_PATH . '/../library/Metier/Ctx/AffaireStatus.php'; @@ -1357,8 +1373,6 @@ class Entreprise extends Scores_Ws_Server throw new SoapFault('ERR', 'Identifiant incorrect.'); } - $db = Zend_Db_Table_Abstract::getDefaultAdapter(); - $cadastre = new Metier_Partenaires_MCadastre(); $cadastre->setId($companyId); $patrimoine = array(); From d0d4b488413033a5d1d0a9f343a877dbe4aa6e57 Mon Sep 17 00:00:00 2001 From: Michael RICOIS Date: Wed, 15 Mar 2017 15:26:14 +0100 Subject: [PATCH 10/24] Entreprise - getGreffeAffaireList : remove Application_Model --- library/WsScore/Entreprise/v0.9/Service.php | 69 +++++++++++++++------ 1 file changed, 49 insertions(+), 20 deletions(-) diff --git a/library/WsScore/Entreprise/v0.9/Service.php b/library/WsScore/Entreprise/v0.9/Service.php index c673ba82..8fced21b 100644 --- a/library/WsScore/Entreprise/v0.9/Service.php +++ b/library/WsScore/Entreprise/v0.9/Service.php @@ -829,29 +829,32 @@ class Entreprise extends Scores_Ws_Server $tiers = 'DE'; } - $db = Zend_Db_Table_Abstract::getDefaultAdapter(); - // --- Recherche de tiers (type DE ou DF) apparaissant dans les affaires - $tierSql = "SELECT count(idAffaire) AS Nb FROM jo.greffes_affaires_siren " . - "WHERE entSiren=".$companyId." AND qualite='".$tiers."'"; try { - $tierResult = $db->fetchRow($tierSql, null, Zend_DB::FETCH_OBJ); - } catch (Zend_Db_Exception $e) { - if ($this->User->idClient==1) { + $sql = "SELECT count(idAffaire) AS Nb FROM jo.greffes_affaires_siren + WHERE entSiren=:siren AND qualite=:qualite"; + $stmt = $this->conn->prepare($sql); + $stmt->bindValue('siren', $companyId); + $stmt->bindValue('qualite', $tiers); + $stmt->execute(); + } catch(\Doctrine\DBAL\DBALException $e) { + if ($this->logger !== null) { + $this->logger->error($e->getMessage()); + } + if ($this->User->idClient == 1) { throw new SoapFault('ERR', $e->getMessage()); } else { throw new SoapFault('ERR', "Application error"); } } - $totalNb = 0; - if ($tierResult !== null) { - $totalNb = $tierResult->Nb; - } + + $tierResult = $stmt->fetch(\PDO::FETCH_OBJ); + $totalNb = $tierResult->Nb; $output = new GreffeAffaireList(); $output->Nb = $totalNb; - if (count($totalNb) > 0) { + if ($totalNb > 0) { // --- Selection des affaires $tierSubQuery = "SELECT idAffaire FROM jo.greffes_affaires_siren " . "WHERE entSiren=".$companyId." AND qualite='".$tiers."' GROUP BY idAffaire"; @@ -866,13 +869,32 @@ class Entreprise extends Scores_Ws_Server throw new SoapFault('ERR', "Application error"); } } + try { + $tierSubQuery = "SELECT idAffaire FROM jo.greffes_affaires_siren + WHERE entSiren=:siren AND qualite=:qualite GROUP BY idAffaire"; + $affaireSql = "SELECT id, idAffaire, numGreffe, natureDemande, codNatureDemande, etatAffaire, dateEnrolement FROM jo.greffes_affaires + WHERE idAffaire IN (".$tierSubQuery.") ORDER BY dateEnrolement DESC LIMIT $p,$limit"; + $stmt = $this->conn->prepare($affaireSql); + $stmt->bindValue('siren', $companyId); + $stmt->bindValue('qualite', $tiers); + $stmt->execute(); + } catch(\Doctrine\DBAL\DBALException $e) { + if ($this->logger !== null) { + $this->logger->error($e->getMessage()); + } + if ($this->User->idClient==1) { + throw new SoapFault('ERR', $e->getMessage()); + } else { + throw new SoapFault('ERR', "Application error"); + } + } $status = include APPLICATION_PATH . '/../library/Metier/Ctx/AffaireStatus.php'; $categories = include APPLICATION_PATH . '/../library/Metier/Table/AffairesTypes.php'; $affaireList = array(); - if (count($affaireResult) > 0) { - foreach ($affaireResult as $a) { + if ($stmt->rowCount() > 0) { + while ($a = $stmt->fetch(\PDO::FETCH_OBJ)) { // --- Formattage $item = new GreffeAffaire(); @@ -896,18 +918,25 @@ class Entreprise extends Scores_Ws_Server } elseif ($tiers == 'DF') { $tiersQualite = 'DE'; } - $tierSql = "SELECT nomPartie FROM jo.greffes_affaires_siren WHERE idAffaire='".$a->idAffaire."' AND qualite='".$tiersQualite."'"; try { - $tierResult = $db->fetchAll($tierSql, null, Zend_DB::FETCH_OBJ); - } catch (Zend_Db_Exception $e) { - if ($this->User->idClient==1) { + $sql = "SELECT nomPartie FROM jo.greffes_affaires_siren WHERE idAffaire=:id AND qualite=:qualite"; + $tierStmt = $this->conn->prepare($sql); + $tierStmt->bindValue('id', $a->idAffaire); + $tierStmt->bindValue('qualite', $tiers); + $tierStmt->execute(); + } catch(\Doctrine\DBAL\DBALException $e) { + if ($this->logger !== null) { + $this->logger->error($e->getMessage()); + } + if ($this->User->idClient == 1) { throw new SoapFault('ERR', $tierSql . " - " . $e->getMessage()); } else { throw new SoapFault('ERR', "Application error"); } } - if (count($tierResult) > 0) { - foreach ($tierResult as $t) { + + if ($tierStmt->rowCount() > 0) { + while ($t = $tierStmt->fetch(\PDO::FETCH_OBJ)) { $item->TierName[] = $t->nomPartie; } } From 42bc186318bb51e7ab1270e1ddd5003913cd8b41 Mon Sep 17 00:00:00 2001 From: Michael RICOIS Date: Wed, 15 Mar 2017 15:27:05 +0100 Subject: [PATCH 11/24] Entreprise - getGreffeAffaireList : oubli suppression --- library/WsScore/Entreprise/v0.9/Service.php | 13 ------------- 1 file changed, 13 deletions(-) diff --git a/library/WsScore/Entreprise/v0.9/Service.php b/library/WsScore/Entreprise/v0.9/Service.php index 8fced21b..5bc6e74c 100644 --- a/library/WsScore/Entreprise/v0.9/Service.php +++ b/library/WsScore/Entreprise/v0.9/Service.php @@ -856,19 +856,6 @@ class Entreprise extends Scores_Ws_Server if ($totalNb > 0) { // --- Selection des affaires - $tierSubQuery = "SELECT idAffaire FROM jo.greffes_affaires_siren " . - "WHERE entSiren=".$companyId." AND qualite='".$tiers."' GROUP BY idAffaire"; - $affaireSql = "SELECT id, idAffaire, numGreffe, natureDemande, codNatureDemande, etatAffaire, dateEnrolement FROM jo.greffes_affaires ". - "WHERE idAffaire IN (".$tierSubQuery.") ORDER BY dateEnrolement DESC LIMIT $p,$limit"; - try { - $affaireResult = $db->fetchAll($affaireSql, null, Zend_DB::FETCH_OBJ); - } catch (Zend_Db_Exception $e) { - if ($this->User->idClient==1) { - throw new SoapFault('ERR', $e->getMessage()); - } else { - throw new SoapFault('ERR', "Application error"); - } - } try { $tierSubQuery = "SELECT idAffaire FROM jo.greffes_affaires_siren WHERE entSiren=:siren AND qualite=:qualite GROUP BY idAffaire"; From 75b9abeda84501b4bbaacc778d88e4a3924e0f00 Mon Sep 17 00:00:00 2001 From: Michael RICOIS Date: Wed, 15 Mar 2017 15:32:20 +0100 Subject: [PATCH 12/24] Entreprise - getPrivilegeList : remove Zend_Db, Application_Model --- library/WsScore/Entreprise/v0.9/Service.php | 27 ++++++++++++--------- 1 file changed, 16 insertions(+), 11 deletions(-) diff --git a/library/WsScore/Entreprise/v0.9/Service.php b/library/WsScore/Entreprise/v0.9/Service.php index 5bc6e74c..d69dc978 100644 --- a/library/WsScore/Entreprise/v0.9/Service.php +++ b/library/WsScore/Entreprise/v0.9/Service.php @@ -632,10 +632,12 @@ class Entreprise extends Scores_Ws_Server ORDER BY insDate DESC;"; try { - $db = Zend_Db_Table_Abstract::getDefaultAdapter(); - $privResult = $db->fetchAll($privSql, null, Zend_Db::FETCH_OBJ); - } catch(Zend_Db_Exception $e) { - if ($this->User->idClient==1) { + $stmt = $this->conn->executeQuery($privSql); + } catch(\Doctrine\DBAL\DBALException $e) { + if ($this->logger !== null) { + $this->logger->error($e->getMessage()); + } + if ($this->User->idClient == 1) { throw new SoapFault('ERR', $e->getMessage()); } else { throw new SoapFault('ERR', "Application error"); @@ -649,8 +651,8 @@ class Entreprise extends Scores_Ws_Server $privileges = array(); $cumul = array(); - if (count($privResult) > 0) { - foreach($privResult as $p) { + if ($stmt->rowCount() > 0) { + while ($p = $stmt->fetch(\PDO::FETCH_OBJ)) { // --- Cumul des privileges par type (Nb, Montant) $output->NbTotal++; $output->MtTotal+= $p->insMontant; @@ -733,17 +735,19 @@ class Entreprise extends Scores_Ws_Server WHERE siren=$companyId AND id=$id"; try { - $db = Zend_Db_Table_Abstract::getDefaultAdapter(); - $p = $db->fetchRow($privSql, null, Zend_Db::FETCH_OBJ); - } catch(Zend_Db_Exception $e) { - if ($this->User->idClient==1) { + $stmt = $this->conn->executeQuery($privSql); + } catch(\Doctrine\DBAL\DBALException $e) { + if ($this->logger !== null) { + $this->logger->error($e->getMessage()); + } + if ($this->User->idClient == 1) { throw new SoapFault('ERR', $e->getMessage()); } else { throw new SoapFault('ERR', "Application error"); } } - $iRncs = new Metier_Partenaires_MRncs(); + $p = $stmt->fetch(\PDO::FETCH_OBJ); $privilege = new PrivilegeDetail(); $privilege->Id = $p->id; @@ -768,6 +772,7 @@ class Entreprise extends Scores_Ws_Server $privilege->Devise = $p->insDev; $privilege->DebiteurNum = $p->numDebiteur; $privilege->Greffe = $p->greffe; + $iRncs = new Metier_Partenaires_MRncs(); $privilege->GreffeLabel = $iRncs->getLibTribunal($p->greffe); $privilege->RadiationDate = $p->radDate; $privilege->RadiationMention = $p->radMention; From 9f042262860c7b9d64b012670e67b1607b3bb56b Mon Sep 17 00:00:00 2001 From: Michael RICOIS Date: Wed, 15 Mar 2017 15:58:25 +0100 Subject: [PATCH 13/24] Entreprise - getSubventionList : remove Zend_Db --- library/WsScore/Entreprise/v0.8/Service.php | 165 ++++++++++++-------- 1 file changed, 100 insertions(+), 65 deletions(-) diff --git a/library/WsScore/Entreprise/v0.8/Service.php b/library/WsScore/Entreprise/v0.8/Service.php index 382dc349..81b1edd4 100644 --- a/library/WsScore/Entreprise/v0.8/Service.php +++ b/library/WsScore/Entreprise/v0.8/Service.php @@ -2099,14 +2099,19 @@ class Entreprise extends Scores_Ws_Server $entites[] = $entite; //Search titulaire - $boamplotsM = new Application_Model_JoBoampLots(); - $sql = $boamplotsM->select()->from($boamplotsM, array( - 'LPAD(siren, 9, 000000000) AS siren', - 'LPAD(nic, 5, 00000) AS nic', 'nom','adresse','cp', 'ville', 'pays') - )->where('idAnn=?', substr($ann['id'],2)); - $result = $boamplotsM->fetchAll($sql); - if (count($result) > 0) { - foreach ($result as $entity) { + try { + $sql = "SELECT LPAD(siren, 9, 000000000) AS siren, LPAD(nic, 5, 00000) AS nic, nom, adresse, cp, ville, pays + FROM jo.boamp_lots WHERE idAnn=:id"; + $stmt = $this->conn->prepare($sql); + $stmt->bindValue('id', substr($ann['id'],2)); + $stmt->execute(); + } catch(\Doctrine\DBAL\DBALException $e) { + if ($this->logger !== null) { + $this->logger->error($e->getMessage()); + } + } + if ($stmt->rowCount() > 0) { + while ($entity = $stmt->fetch(\PDO::FETCH_OBJ)) { $entite = new AnnonceEntite(); $entite->siret = $entity->siren.$entity->nic; $entite->raisonSociale = $entity->nom; @@ -5338,7 +5343,7 @@ class Entreprise extends Scores_Ws_Server { $this->authenticate(); - //Init + // Init if ( intval($companyId) == 0 ) { $this->sendError('1010'); } elseif ( strlen($companyId)!=9 ) { @@ -5348,77 +5353,94 @@ class Entreprise extends Scores_Ws_Server if ( empty($nbItems) || $nbItems > 100 ) { $nbItems = 100; } if ( !empty($type) ) { $type = strtoupper($type); } - //SQL - $listM = new Application_Model_JoAssoSubventions(); - $countsql = $listM->select()->from($listM, array('COUNT(*) AS num')); - $sql = $listM->select()->from($listM, array( - 'id', - 'millesime', //Annee - 'sirenAsso', //sirenIn - 'nomAsso', - 'sirenOrigine', //sirenOut - 'libOrigine', //Origine - 'libImputation', //Programme - 'mtSubvention', //Montant - )); + // SQL + $qbList = $this->conn->createQueryBuilder(); + $qbCount = $this->conn->createQueryBuilder(); + $qbList->select(array( + 'id', + 'millesime', //Annee + 'sirenAsso', //sirenIn + 'nomAsso', + 'sirenOrigine', //sirenOut + 'libOrigine', //Origine + 'libImputation', //Programme + 'mtSubvention', //Montant + ))->from(jo.asso_subventions); + $qbCount->select('COUNT(*) AS num')->from('jo.asso_subventions'); - //Subvention reçues => sirenAsso = companyId + // Subvention reçues => sirenAsso = companyId if ($type == 'IN') { - $sql->where('sirenAsso=?', $companyId); - $countsql->where('sirenAsso=?', $companyId); + $qbList->where('sirenAsso=:companyId')->setParameter('companyId', $companyId); + $qbCount->where('sirenAsso=:companyId')->setParameter('companyId', $companyId); } - //Subvention reçues => sirenOrigine = companyId + // Subvention reçues => sirenOrigine = companyId elseif ($type == 'OUT') { - $sql->where('sirenOrigine=?', $companyId); - $countsql->where('sirenOrigine=?', $companyId); + $qbList->where('sirenOrigine=:companyId')->setParameter('companyId', $companyId); + $qbCount->where('sirenOrigine=:companyId')->setParameter('companyId', $companyId); } - //All + // All else { - $sql->where('sirenAsso=?', $companyId) - ->orWhere('sirenOrigine=?', $companyId); - $countsql->where('sirenAsso=?', $companyId) - ->orWhere('sirenOrigine=?', $companyId); + $qbList->where('sirenAsso=:companyId')->orWhere('sirenOrigine=:companyId')->setParameter('companyId', $companyId); + $qbCount->where('sirenAsso=:companyId')->orWhere('sirenOrigine=:companyId')->setParameter('companyId', $companyId); } - $sql->order('millesime DESC')->limit($nbItems, $offset); + $qbList->orderBy('millesime DESC')->setFirstResult($offset)->setMaxResults($nbItems); - $count = $listM->fetchRow($countsql); - $nbReponsesTotal = 0; - if ( $count!==null ) { - $nbReponsesTotal = $count->num; + try { + $stmt = $qbCount->execute(); + } catch(\Doctrine\DBAL\DBALException $e) { + if ($this->logger !== null) { + $this->logger->error($e->getMessage()); + } + if ($this->User->idClient == 1) { + throw new SoapFault('ERR', $e->getMessage()); + } else { + throw new SoapFault('ERR', "Application error"); + } } - if ( $nbReponsesTotal != 0 ) { + $count = $stmt->fetch(\PDO::FETCH_OBJ); + $nbReponsesTotal = $count->num; - $rows = $listM->fetchAll($sql); + if ($nbReponsesTotal > 0) { + + try { + $stmt = $qbList->execute(); + } catch(\Doctrine\DBAL\DBALException $e) { + if ($this->logger !== null) { + $this->logger->error($e->getMessage()); + } + if ($this->User->idClient == 1) { + throw new SoapFault('ERR', $e->getMessage()); + } else { + throw new SoapFault('ERR', "Application error"); + } + } $output = new SubventionList(); $output->nbReponsesTotal = $nbReponsesTotal; $result = array(); - if ( $rows !== null ) { - foreach ( $rows as $row ) { - - $item = new Subvention(); - $item->Id = $row->id; - if ( $row->sirenAsso == $companyId ) { - $item->Type = 'IN'; - } elseif ( $row->sirenOrigine == $companyId ) { - $item->Type = 'OUT'; - } - $item->Millesime = $row->millesime; - $item->AssoSiren = $row->sirenAsso; - $item->AssoNom = $row->nomAsso; - $item->OrigineSiren = $row->sirenOrigine; - $item->OrigineLib = $row->libOrigine; - $item->Programme = $row->libImputation; - $item->Montant = $row->mtSubvention; - - $result[] = $item; + while ($row = $stmt->fetch(\PDO::FETCH_OBJ)) { + $item = new Subvention(); + $item->Id = $row->id; + if ( $row->sirenAsso == $companyId ) { + $item->Type = 'IN'; + } elseif ( $row->sirenOrigine == $companyId ) { + $item->Type = 'OUT'; } - $output->result = $result; - $this->wsLog('subventionlist', $companyId); + $item->Millesime = $row->millesime; + $item->AssoSiren = $row->sirenAsso; + $item->AssoNom = $row->nomAsso; + $item->OrigineSiren = $row->sirenOrigine; + $item->OrigineLib = $row->libOrigine; + $item->Programme = $row->libImputation; + $item->Montant = $row->mtSubvention; + + $result[] = $item; } + $output->result = $result; + $this->wsLog('subventionlist', $companyId); } return $output; @@ -5434,14 +5456,27 @@ class Entreprise extends Scores_Ws_Server { $this->authenticate(); - $subventionM = new Application_Model_JoAssoSubventions(); - $row = $subventionM->find($id); + try { + $sql = "SELECT * FROM jo.asso_subventions WHERE id=:id"; + $stmt = $this->conn->prepare($sql); + $stmt->bindValue('id', $id); + $stmt->execute(); + } catch(\Doctrine\DBAL\DBALException $e) { + if ($this->logger !== null) { + $this->logger->error($e->getMessage()); + } + if ($this->User->idClient == 1) { + throw new SoapFault('ERR', $e->getMessage()); + } else { + throw new SoapFault('ERR', "Application error"); + } + } - if (null === row) { + if ($stmt->rowCount() == 0) { throw new SoapFault('MSG', "Aucun résultat"); } - $data = $row->current(); + $data = $stmt->fetch(\PDO::FETCH_OBJ); $item = new SubventionDetail(); $item->Millesime = $data->millesime; From 4e3714c3f92565473d1b569d112df5e504eab08f Mon Sep 17 00:00:00 2001 From: Michael RICOIS Date: Wed, 15 Mar 2017 16:08:27 +0100 Subject: [PATCH 14/24] Entreprise - getAnnoncesLegales : remove Zend_Db --- library/WsScore/Entreprise/v0.8/Service.php | 59 ++++++++++++++------- 1 file changed, 41 insertions(+), 18 deletions(-) diff --git a/library/WsScore/Entreprise/v0.8/Service.php b/library/WsScore/Entreprise/v0.8/Service.php index 81b1edd4..8aad711b 100644 --- a/library/WsScore/Entreprise/v0.8/Service.php +++ b/library/WsScore/Entreprise/v0.8/Service.php @@ -1863,9 +1863,14 @@ class Entreprise extends Scores_Ws_Server if ( is_array($anns) && $nbReponses > 0 ) { foreach ($anns as $nb => $ann) { - if ($isList===true && $nb<$position) { continue; } + if ($isList === true && $nb < $position) { + continue; + } + $cpt++; - if ($isList===true && $cpt>$nbRep) { break; } + if ($isList === true && $cpt > $nbRep) { + break; + } /** * Si l'annonce est une annonce BODACC alors @@ -1873,15 +1878,25 @@ class Entreprise extends Scores_Ws_Server */ $entites = array(); if (in_array($ann['BodaccCode'], array('BODA', 'BODB', 'BODC'))) { - $detailM = new Application_Model_JoBodaccDetail(); - $sql = $detailM->select()->from($detailM, array( - 'LPAD(siren, 9, 0) AS siren', - 'LPAD(nic, 5, 0) AS nic', - 'raisonSociale','adresse', 'codePostal', 'ville', 'typeEven') - )->where('id=?', $ann['id']); - $result = $detailM->fetchAll($sql); - if (count($result)>1) { - foreach ($result as $entity) { + try { + $sql = "SELECT LPAD(siren, 9, 0) AS siren, LPAD(nic, 5, 0) AS nic, raisonSociale, + adresse, codePostal, ville, typeEven FROM jo.bodacc_detail WHERE id=:id"; + $stmt = $this->conn->prepare($sql); + $stmt->bindValue('id', $ann['id']); + $stmt->execute(); + } catch(\Doctrine\DBAL\DBALException $e) { + if ($this->logger !== null) { + $this->logger->error($e->getMessage()); + } + if ($this->User->idClient == 1) { + throw new SoapFault('ERR', $e->getMessage()); + } else { + throw new SoapFault('ERR', "Application error"); + } + } + + if ($stmt->rowCount() > 1) { + while ($entity = $stmt->fetch(\PDO::FETCH_OBJ)) { $entite = new AnnonceEntite(); $entite->siret = $entity->siren . $entity->nic; $entite->raisonSociale = $entity->raisonSociale; @@ -1897,7 +1912,7 @@ class Entreprise extends Scores_Ws_Server } } - //List events + // List events $evens = array(); foreach ($ann['evenements'] as $tabEven) { $even = new AnnonceEvenement(); @@ -3921,12 +3936,20 @@ class Entreprise extends Scores_Ws_Server * Calcul d'initialisation du score lors d'un ajout */ if ( $source == 'score' ) { - $survM = new Application_Model_JoScoresSurveillance(); - $item = $survM->find($siren); - if ( $item === null ) { - require_once 'Metier/Scores/MScores.php'; - calculIndiScore($siren, 0, false, 0); - } + try { + $sql = "SELECT * FROM jo.scores_surveillance WHERE siren=:siren"; + $stmt = $this->conn->prepare($sql); + $stmt->bindValue('siren', $siren); + $stmt->execute(); + if ($stmt->rowCount() == 0) { + require_once 'Metier/Scores/MScores.php'; + calculIndiScore($siren, 0, false, 0); + } + } catch (\Doctrine\DBAL\DBALException $e) { + if ($this->logger !== null) { + $this->logger->error($e->getMessage()); + } + } } $where = "source='$source' AND login='$login' AND email='$email' AND siren=$siren AND nic=$nic AND ref='$ref'"; From 62761b4baa014f1138f68380cde98c9b691be460 Mon Sep 17 00:00:00 2001 From: Michael RICOIS Date: Wed, 15 Mar 2017 16:15:06 +0100 Subject: [PATCH 15/24] Entreprise : remove Metier_Db_Util --- library/WsScore/Entreprise/v0.7/Service.php | 14 ++++++++------ library/WsScore/Entreprise/v0.8/Service.php | 14 ++++++++------ 2 files changed, 16 insertions(+), 12 deletions(-) diff --git a/library/WsScore/Entreprise/v0.7/Service.php b/library/WsScore/Entreprise/v0.7/Service.php index 18dc2860..f037e887 100644 --- a/library/WsScore/Entreprise/v0.7/Service.php +++ b/library/WsScore/Entreprise/v0.7/Service.php @@ -4189,15 +4189,17 @@ class Entreprise extends Scores_Ws_Server $_SERVER['PHP_AUTH_USER'].", hash:".$_SERVER['PHP_AUTH_PW']); $error = new StatusReturn(); + //Test connexion à la base de données - $db = new Metier_Util_Db(); - if (!$db) { - $error->statusCode = 9000; - $error->statusMsg = $this->listError['9000']; + $this->conn->connect(); + if ($this->conn->isConnected()) { + $error->statusCode = 3000; + $error->statusMsg = $this->listError['3000']; } else { - $error->statusCode = 3000; - $error->statusMsg = $this->listError['3000']; + $error->statusCode = 9000; + $error->statusMsg = $this->listError['9000']; } + return $error; } diff --git a/library/WsScore/Entreprise/v0.8/Service.php b/library/WsScore/Entreprise/v0.8/Service.php index 8aad711b..536cf670 100644 --- a/library/WsScore/Entreprise/v0.8/Service.php +++ b/library/WsScore/Entreprise/v0.8/Service.php @@ -5534,15 +5534,17 @@ class Entreprise extends Scores_Ws_Server $_SERVER['PHP_AUTH_USER'].", hash:".$_SERVER['PHP_AUTH_PW']); $error = new StatusReturn(); + //Test connexion à la base de données - $db = new Metier_Util_Db(); - if (!$db) { - $error->statusCode = 9000; - $error->statusMsg = $this->listError['9000']; + $this->conn->connect(); + if ($this->conn->isConnected()) { + $error->statusCode = 3000; + $error->statusMsg = $this->listError['3000']; } else { - $error->statusCode = 3000; - $error->statusMsg = $this->listError['3000']; + $error->statusCode = 9000; + $error->statusMsg = $this->listError['9000']; } + return $error; } From 60a6c7eb675d510cd22adec71bdf3c080c9823dc Mon Sep 17 00:00:00 2001 From: Michael RICOIS Date: Wed, 15 Mar 2017 16:53:42 +0100 Subject: [PATCH 16/24] Fix rowCount --- library/WsScore/Entreprise/v0.8/Service.php | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/library/WsScore/Entreprise/v0.8/Service.php b/library/WsScore/Entreprise/v0.8/Service.php index 536cf670..98f05e7a 100644 --- a/library/WsScore/Entreprise/v0.8/Service.php +++ b/library/WsScore/Entreprise/v0.8/Service.php @@ -847,7 +847,7 @@ class Entreprise extends Scores_Ws_Server } $tabPays = array(); - if ($stmt->count() > 0) { + if ($stmt->rowCount() > 0) { while ($item = $stmt->fetch(\PDO::FETCH_OBJ)) { $tabPays[$item->codPays3] = $item->libPays; } @@ -1077,7 +1077,7 @@ class Entreprise extends Scores_Ws_Server } $tabPays = array(); - if ($stmt->count() > 0) { + if ($stmt->rowCount() > 0) { while ($item = $stmt->fetch(\PDO::FETCH_OBJ)) { $tabPays[$item->codPays3] = $item->libPays; } @@ -1306,7 +1306,7 @@ class Entreprise extends Scores_Ws_Server } } - if ($stmt->count() == 0) { + if ($stmt->rowCount() == 0) { throw new SoapFault('MSG', 'Aucun résultat'); } From 141435a39813d75c3536c37a40d940a4b9aa7221 Mon Sep 17 00:00:00 2001 From: Michael RICOIS Date: Wed, 15 Mar 2017 17:02:23 +0100 Subject: [PATCH 17/24] Fix conflit $result --- library/WsScore/Entreprise/v0.8/Service.php | 10 +++++----- 1 file changed, 5 insertions(+), 5 deletions(-) diff --git a/library/WsScore/Entreprise/v0.8/Service.php b/library/WsScore/Entreprise/v0.8/Service.php index 98f05e7a..b63b724e 100644 --- a/library/WsScore/Entreprise/v0.8/Service.php +++ b/library/WsScore/Entreprise/v0.8/Service.php @@ -1293,7 +1293,7 @@ class Entreprise extends Scores_Ws_Server try { $sql = "SELECT * FROM jo.liensRef WHERE id=:id"; $stmt = $this->conn->prepare($sql); - $stmt->bindValue('siren', $companyId); + $stmt->bindValue('id', $id); $stmt->execute(); } catch(\Doctrine\DBAL\DBALException $e) { if ($this->logger !== null) { @@ -1352,7 +1352,7 @@ class Entreprise extends Scores_Ws_Server $nbIdNum = 3; $refs = array(); for ($i=0;$i<$nbIdNum;$i++) { - if( !empty($result['idLoc'.$i.'Type']) ) { + if(!empty($result['idLoc'.$i.'Type'])) { $ref = new LienRefId(); $ref->num = $result['idLoc'.$i.'Num']; try { @@ -1361,9 +1361,9 @@ class Entreprise extends Scores_Ws_Server $stmt->bindValue('id', $result['idLoc'.$i.'Type']); $stmt->execute(); if ($stmt->rowCount() > 0) { - $result = $stmt->fetch(\PDO::FETCH_OBJ); - $ref->label = $result->idLocal; - $ref->type = $result->idPrincipal; + $id = $stmt->fetch(\PDO::FETCH_OBJ); + $ref->label = $id->idLocal; + $ref->type = $id->idPrincipal; } else { $ref->label = ''; $ref->type = 0; From 26ea2e10213bb3d7f6705931b3929361734f814a Mon Sep 17 00:00:00 2001 From: Michael RICOIS Date: Thu, 16 Mar 2017 14:28:57 +0100 Subject: [PATCH 18/24] Delete --- .../assets/themes/default/js/jquery.form.js | 923 ------------------ 1 file changed, 923 deletions(-) delete mode 100644 public/assets/themes/default/js/jquery.form.js diff --git a/public/assets/themes/default/js/jquery.form.js b/public/assets/themes/default/js/jquery.form.js deleted file mode 100644 index 111bf001..00000000 --- a/public/assets/themes/default/js/jquery.form.js +++ /dev/null @@ -1,923 +0,0 @@ -/*! - * jQuery Form Plugin - * version: 2.85 (23-SEP-2011) - * @requires jQuery v1.3.2 or later - * - * Examples and documentation at: http://malsup.com/jquery/form/ - * Dual licensed under the MIT and GPL licenses: - * http://www.opensource.org/licenses/mit-license.php - * http://www.gnu.org/licenses/gpl.html - */ -;(function($) { - -/* - Usage Note: - ----------- - Do not use both ajaxSubmit and ajaxForm on the same form. These - functions are intended to be exclusive. Use ajaxSubmit if you want - to bind your own submit handler to the form. For example, - - $(document).ready(function() { - $('#myForm').bind('submit', function(e) { - e.preventDefault(); // <-- important - $(this).ajaxSubmit({ - target: '#output' - }); - }); - }); - - Use ajaxForm when you want the plugin to manage all the event binding - for you. For example, - - $(document).ready(function() { - $('#myForm').ajaxForm({ - target: '#output' - }); - }); - - When using ajaxForm, the ajaxSubmit function will be invoked for you - at the appropriate time. -*/ - -/** - * ajaxSubmit() provides a mechanism for immediately submitting - * an HTML form using AJAX. - */ -$.fn.ajaxSubmit = function(options) { - // fast fail if nothing selected (http://dev.jquery.com/ticket/2752) - if (!this.length) { - log('ajaxSubmit: skipping submit process - no element selected'); - return this; - } - - var method, action, url, $form = this; - - if (typeof options == 'function') { - options = { success: options }; - } - - method = this.attr('method'); - action = this.attr('action'); - url = (typeof action === 'string') ? $.trim(action) : ''; - url = url || window.location.href || ''; - if (url) { - // clean url (don't include hash vaue) - url = (url.match(/^([^#]+)/)||[])[1]; - } - - options = $.extend(true, { - url: url, - success: $.ajaxSettings.success, - type: method || 'GET', - iframeSrc: /^https/i.test(window.location.href || '') ? 'javascript:false' : 'about:blank' - }, options); - - // hook for manipulating the form data before it is extracted; - // convenient for use with rich editors like tinyMCE or FCKEditor - var veto = {}; - this.trigger('form-pre-serialize', [this, options, veto]); - if (veto.veto) { - log('ajaxSubmit: submit vetoed via form-pre-serialize trigger'); - return this; - } - - // provide opportunity to alter form data before it is serialized - if (options.beforeSerialize && options.beforeSerialize(this, options) === false) { - log('ajaxSubmit: submit aborted via beforeSerialize callback'); - return this; - } - - var n,v,a = this.formToArray(options.semantic); - if (options.data) { - options.extraData = options.data; - for (n in options.data) { - if( $.isArray(options.data[n]) ) { - for (var k in options.data[n]) { - a.push( { name: n, value: options.data[n][k] } ); - } - } - else { - v = options.data[n]; - v = $.isFunction(v) ? v() : v; // if value is fn, invoke it - a.push( { name: n, value: v } ); - } - } - } - - // give pre-submit callback an opportunity to abort the submit - if (options.beforeSubmit && options.beforeSubmit(a, this, options) === false) { - log('ajaxSubmit: submit aborted via beforeSubmit callback'); - return this; - } - - // fire vetoable 'validate' event - this.trigger('form-submit-validate', [a, this, options, veto]); - if (veto.veto) { - log('ajaxSubmit: submit vetoed via form-submit-validate trigger'); - return this; - } - - var q = $.param(a); - - if (options.type.toUpperCase() == 'GET') { - options.url += (options.url.indexOf('?') >= 0 ? '&' : '?') + q; - options.data = null; // data is null for 'get' - } - else { - options.data = q; // data is the query string for 'post' - } - - var callbacks = []; - if (options.resetForm) { - callbacks.push(function() { $form.resetForm(); }); - } - if (options.clearForm) { - callbacks.push(function() { $form.clearForm(); }); - } - - // perform a load on the target only if dataType is not provided - if (!options.dataType && options.target) { - var oldSuccess = options.success || function(){}; - callbacks.push(function(data) { - var fn = options.replaceTarget ? 'replaceWith' : 'html'; - $(options.target)[fn](data).each(oldSuccess, arguments); - }); - } - else if (options.success) { - callbacks.push(options.success); - } - - options.success = function(data, status, xhr) { // jQuery 1.4+ passes xhr as 3rd arg - var context = options.context || options; // jQuery 1.4+ supports scope context - for (var i=0, max=callbacks.length; i < max; i++) { - callbacks[i].apply(context, [data, status, xhr || $form, $form]); - } - }; - - // are there files to upload? - var fileInputs = $('input:file', this).length > 0; - var mp = 'multipart/form-data'; - var multipart = ($form.attr('enctype') == mp || $form.attr('encoding') == mp); - - // options.iframe allows user to force iframe mode - // 06-NOV-09: now defaulting to iframe mode if file input is detected - if (options.iframe !== false && (fileInputs || options.iframe || multipart)) { - // hack to fix Safari hang (thanks to Tim Molendijk for this) - // see: http://groups.google.com/group/jquery-dev/browse_thread/thread/36395b7ab510dd5d - if (options.closeKeepAlive) { - $.get(options.closeKeepAlive, function() { fileUpload(a); }); - } - else { - fileUpload(a); - } - } - else { - // IE7 massage (see issue 57) - if ($.browser.msie && method == 'get' && typeof options.type === "undefined") { - var ieMeth = $form[0].getAttribute('method'); - if (typeof ieMeth === 'string') - options.type = ieMeth; - } - $.ajax(options); - } - - // fire 'notify' event - this.trigger('form-submit-notify', [this, options]); - return this; - - - // private function for handling file uploads (hat tip to YAHOO!) - function fileUpload(a) { - var form = $form[0], el, i, s, g, id, $io, io, xhr, sub, n, timedOut, timeoutHandle; - var useProp = !!$.fn.prop; - - if (a) { - if ( useProp ) { - // ensure that every serialized input is still enabled - for (i=0; i < a.length; i++) { - el = $(form[a[i].name]); - el.prop('disabled', false); - } - } else { - for (i=0; i < a.length; i++) { - el = $(form[a[i].name]); - el.removeAttr('disabled'); - } - }; - } - - if ($(':input[name=submit],:input[id=submit]', form).length) { - // if there is an input with a name or id of 'submit' then we won't be - // able to invoke the submit fn on the form (at least not x-browser) - alert('Error: Form elements must not have name or id of "submit".'); - return; - } - - s = $.extend(true, {}, $.ajaxSettings, options); - s.context = s.context || s; - id = 'jqFormIO' + (new Date().getTime()); - if (s.iframeTarget) { - $io = $(s.iframeTarget); - n = $io.attr('name'); - if (n == null) - $io.attr('name', id); - else - id = n; - } - else { - $io = $('