issue #0001467 : Nouveaux paramètres et correction pour les filtres SIEGE et ACTIF

This commit is contained in:
Michael RICOIS 2012-12-17 13:35:36 +00:00
parent 8d63f63448
commit 39059dadf1
2 changed files with 100 additions and 91 deletions

View File

@ -1488,59 +1488,60 @@ public function rechercheDirOld($nom, $prenom='', $fonction='', $dateNaiss='', $
* @param int $maxRep * @param int $maxRep
* @param int $dep * @param int $dep
* @param int $actif * @param int $actif
* @param int $siege
*/ */
public function getEtablissements($siren, $nic='', $deb=0, $nbRep=20, $maxRep=200, $dep=0, $actif=-1) public function getEtablissements($siren, $nic='', $deb=0, $nbRep=20, $maxRep=200, $dep=0, $actif=-1, $siege=null)
{ {
$this->setTabCodesNaf(); $this->setTabCodesNaf();
$deb=$deb*1; $deb=$deb*1;
$dep=$dep*1; $dep=$dep*1;
$nbRep=$nbRep*1; $nbRep=$nbRep*1;
$strInfo = '';
$limit="LIMIT $deb, $nbRep"; $limit="LIMIT $deb, $nbRep";
$strInfo='';
$sqlInfo="'Etab' as Loc, e.id, e.source, e.source_id, e.triCode, e.autre_id, e.siren, e.nic, e.siege, ".
"e.raisonSociale, e.enseigne, e.sigle, e.adr_num, e.adr_btq, e.adr_typeVoie, e.adr_libVoie, ".
"e.adr_comp, e.adr_cp, e.adr_ville, e.tel, e.fax, e.cj, e.ape_etab, e.ape_entrep, e.teff_etab, ".
"CONCAT(e.siren, e.nic) as siret, e.actif, e.identite_pre";
$strActif=''; $strActif='';
if (intval($actif)==1) $strActif=' AND e.actif=1 '; if (intval($actif)==1) $strActif=' AND e.actif=1 ';
elseif (intval($actif)==0) $strActif=' AND e.actif=0 '; elseif (intval($actif)==0) $strActif=' AND e.actif=0 ';
$strSiege='';
if ($siege===null) $strSiege='';
elseif ($siege==1) $strSiege=' AND e.siege=1 ';
elseif ($siege==0) $strSiege=' AND e.siege=0 ';
if ($dep>0 && $dep<99999) { if ($dep>0 && $dep<99999) {
if ($dep<96) $strDep='AND adr_cp BETWEEN '.$dep.'000 AND '.$dep.'999'; if ($dep<96) $strDep='AND adr_cp BETWEEN '.$dep.'000 AND '.$dep.'999';
elseif ($dep>9999) $strDep="AND adr_cp BETWEEN $dep AND $dep"; elseif ($dep>9999) $strDep="AND adr_cp BETWEEN $dep AND $dep";
else $strDep='AND adr_cp BETWEEN '.$dep.'00 AND '.$dep.'99'; else $strDep='AND adr_cp BETWEEN '.$dep.'00 AND '.$dep.'99';
$tabTmp=$this->iDb->select('etablissements e', 'count(*)', "siren=$siren $strDep $strActif"); $tabTmp=$this->iDb->select('etablissements e', 'count(*)', "siren=$siren $strDep $strActif $strSiege");
$nbTot=$tabTmp[0][0]; $nbTot=$tabTmp[0][0];
$listeEtab=$this->iDb->select('etablissements e', $listeEtab=$this->iDb->select('etablissements e', $sqlInfo,
"'Etab' as Loc, e.id, e.source, e.source_id, e.triCode, e.autre_id, e.siren, e.nic, e.siege, ". "siren=$siren $strDep $strActif $strSiege ORDER BY e.siege , e.actif DESC $limit", false, MYSQL_ASSOC);
"e.raisonSociale, e.enseigne, e.sigle, e.adr_num, e.adr_btq, e.adr_typeVoie, e.adr_libVoie, ".
"e.adr_comp, e.adr_cp, e.adr_ville, e.tel, e.fax, e.cj, e.ape_etab, e.ape_entrep, e.teff_etab, ".
"CONCAT(e.siren, e.nic) as siret, e.actif, e.identite_pre",
"siren=$siren $strDep $strActif ORDER BY e.siege , e.actif DESC $limit", false, MYSQL_ASSOC);
} elseif ($nic=='') { } elseif ($nic=='') {
$tabTmp=$this->iDb->select('etablissements e', 'count(*)', "siren=$siren $strActif"); $tabTmp=$this->iDb->select('etablissements e', 'count(*)', "siren=$siren $strActif $strSiege");
$nbTot=$tabTmp[0][0]; $nbTot=$tabTmp[0][0];
$listeEtab=$this->iDb->select('etablissements e', $listeEtab=$this->iDb->select('etablissements e', $sqlInfo,
"'Etab' as Loc, e.id, e.source, e.source_id, e.triCode, e.autre_id, e.siren, e.nic, e.siege, ". "e.siren=$siren $strActif $strSiege ORDER BY e.siege DESC, e.actif DESC $limit", false, MYSQL_ASSOC);
"e.raisonSociale, e.enseigne, e.sigle, e.adr_num, e.adr_btq, e.adr_typeVoie, e.adr_libVoie, ".
"e.adr_comp, e.adr_cp, e.adr_ville, e.tel, e.fax, e.cj, e.ape_etab, e.ape_entrep, e.teff_etab, ".
"CONCAT(e.siren, e.nic) as siret, e.actif, e.identite_pre",
"e.siren=$siren $strActif ORDER BY e.siege DESC, e.actif DESC $limit", false, MYSQL_ASSOC);
} else { } else {
$tabTmp=$this->iDb->select('etablissements e', 'count(*)', "siren=$siren AND (nic=$nic OR siege=1) $strActif"); $tabTmp=$this->iDb->select('etablissements e', 'count(*)', "siren=$siren AND (nic=$nic OR siege=1) $strActif $strSiege");
$nbTot=$tabTmp[0][0]; $nbTot=$tabTmp[0][0];
$listeEtab=$this->iDb->select('etablissements e', $listeEtab=$this->iDb->select('etablissements e', $sqlInfo,
"'Etab' as Loc, e.id, e.source, e.source_id, e.triCode, e.autre_id, e.siren, e.nic, e.siege, ". "siren=$siren AND (nic=$nic OR siege=1) $strActif $strSiege ORDER BY e.siege , e.actif DESC $limit", false, MYSQL_ASSOC);
"e.raisonSociale, e.enseigne, e.sigle, e.adr_num, e.adr_btq, e.adr_typeVoie, e.adr_libVoie, ".
"e.adr_comp, e.adr_cp, e.adr_ville, e.tel, e.fax, e.cj, e.ape_etab, e.ape_entrep, e.teff_etab, ".
"CONCAT(e.siren, e.nic) as siret, e.actif, e.identite_pre",
"siren=$siren AND (nic=$nic OR siege=1) $strActif ORDER BY e.siege , e.actif DESC $limit", false, MYSQL_ASSOC);
} }
@ -1552,8 +1553,7 @@ public function rechercheDirOld($nom, $prenom='', $fonction='', $dateNaiss='', $
$listeSiren=array(); $listeSiren=array();
foreach ($liste as $s) { foreach ($liste as $s) {
if (sommeDeControle($s) != 0) { if (sommeDeControle($s) != 0) {
print 'erreur somme de controle sur '.$s. //print 'erreur somme de controle sur '.$s.' ('.sommeDeControle($s).')<br/>';
' ('.sommeDeControle($s).')<br/>';
} else { } else {
$listeSiren[]=$s; $listeSiren[]=$s;
} }
@ -1561,12 +1561,8 @@ public function rechercheDirOld($nom, $prenom='', $fonction='', $dateNaiss='', $
$strSiren=implode(',',$listeSiren); $strSiren=implode(',',$listeSiren);
$tabTmp=$this->iDb->select('etablissements', 'count(*)', "siren IN ($strSiren) AND siege=1"); $tabTmp=$this->iDb->select('etablissements', 'count(*)', "siren IN ($strSiren) AND siege=1");
$nbTot=$tabTmp[0][0]; $nbTot=$tabTmp[0][0];
$listeEtab=$this->iDb->select('etablissements e', $listeEtab=$this->iDb->select('etablissements e', $sqlInfo,
"'Etab' as Loc, e.id, e.source, e.source_id, e.triCode, e.autre_id, e.siren, e.nic, e.siege, ". "siren IN ($strSiren) AND siege=1 ORDER BY e.rang DESC, e.actif DESC, e.nic ASC $limit", true, MYSQL_ASSOC);
"e.raisonSociale, e.enseigne, e.sigle, e.adr_num, e.adr_btq, e.adr_typeVoie, e.adr_libVoie, ".
"e.adr_comp, e.adr_cp, e.adr_ville, e.tel, e.fax, e.cj, e.ape_etab, e.ape_entrep, e.teff_etab, ".
"CONCAT(e.siren, e.nic) as siret, e.actif, e.identite_pre",
"siren IN ($strSiren) AND siege=1 ORDER BY e.rang DESC, e.actif DESC, e.nic ASC $limit", true, MYSQL_ASSOC);
$strInfo='Siren saisi invalide'; $strInfo='Siren saisi invalide';
} }
@ -1619,11 +1615,11 @@ public function rechercheDirOld($nom, $prenom='', $fonction='', $dateNaiss='', $
if ($dep==0) $dep=''; // Evite l'affichage d'un 0 inutile sur l'Extranet if ($dep==0) $dep=''; // Evite l'affichage d'un 0 inutile sur l'Extranet
return array( return array(
'criteres'=>array('siren'=>$siren, 'nic'=>$nic, 'dep'=>$dep), 'criteres' => array('siren'=>$siren, 'nic'=>$nic, 'dep'=>$dep),
'info'=>$strInfo, 'info' => $strInfo,
'nbReponses'=>count($tabRet), 'nbReponses' => count($tabRet),
'nbReponsesTotal'=>$nbTot, 'nbReponsesTotal' => $nbTot,
'reponses'=>$tabRet); 'reponses' => $tabRet);
} }
/** /**

View File

@ -4,13 +4,6 @@ require_once realpath(dirname(__FILE__)).'/Types.php';
class Entreprise extends WsScore class Entreprise extends WsScore
{ {
public function __construct()
{
parent::__construct();
$this->serviceClient = true;
$this->serviceClientName = 'Vwbank';
$this->serviceName = 'Entreprise';
}
/** /**
* Retourne les informations identitaires de l'entreprise ou de l'établissement demandé * Retourne les informations identitaires de l'entreprise ou de l'établissement demandé
@ -576,53 +569,73 @@ class Entreprise extends WsScore
$nbReponsesTotal = $rep['nbReponsesTotal']; $nbReponsesTotal = $rep['nbReponsesTotal'];
$nbReponses = $rep['nbReponses']; $nbReponses = $rep['nbReponses'];
/** Si le siren est valide, on part chez Infogreffe **/ if (count($tabRet)==0)
if (count($tabRet)==0 && $iInsee->valideSiren($siren)) { {
$iGeffes = new MGreffes(); if ($siege===null || $actif==2)
$etab = $iGeffes->getIdentite($siren); {
if ($etab) { /** Si le siren est valide, on part chez Infogreffe **/
$reponse = new EntrepriseItem(); if ($iInsee->valideSiren($siren)) {
$reponse->id = $etab['id']; $iGeffes = new MGreffes();
$reponse->Pertinence = $etab['Pertinence']; $etab = $iGeffes->getIdentite($siren);
$reponse->Siret = $etab['Siret']; if ($etab) {
$reponse->Siege = $etab['Siege']; $reponse = new EntrepriseItem();
$reponse->Nom = prepareString($etab['Nom']); $reponse->id = $etab['id'];
$reponse->Nom2 = prepareString($etab['Nom2']); $reponse->Pertinence = $etab['Pertinence'];
$reponse->Sigle = prepareString($etab['Sigle']); $reponse->Siret = $etab['Siret'];
$reponse->Enseigne = prepareString($etab['Enseigne']); $reponse->Siege = $etab['Siege'];
$reponse->Adresse = prepareString($etab['Adresse']); $reponse->Nom = prepareString($etab['Nom']);
$reponse->Adresse2 = prepareString($etab['Adresse2']); $reponse->Nom2 = prepareString($etab['Nom2']);
$reponse->CP = $etab['CP']; $reponse->Sigle = prepareString($etab['Sigle']);
$reponse->Ville = prepareString($etab['Ville']); $reponse->Enseigne = prepareString($etab['Enseigne']);
$reponse->Tel = $etab['Tel']; $reponse->Adresse = prepareString($etab['Adresse']);
$reponse->Fax = $etab['Fax']; $reponse->Adresse2 = prepareString($etab['Adresse2']);
$reponse->FJ = $etab['FJ']; $reponse->CP = $etab['CP'];
$reponse->FJLib = utf8_encode(prepareString(utf8_decode($etab['FJLib']))); $reponse->Ville = prepareString($etab['Ville']);
$reponse->Siren = $etab['Siren']; $reponse->Tel = $etab['Tel'];
$reponse->Nic = $etab['Nic']; $reponse->Fax = $etab['Fax'];
$reponse->Actif = $etab['Actif']; $reponse->FJ = $etab['FJ'];
$reponse->NafEtab = $etab['NafEtab']; $reponse->FJLib = prepareString($etab['FJLib']);
$reponse->NafEtabLib = $etab['NafEtabLib']; $reponse->Siren = $etab['Siren'];
$reponse->NafEnt = $etab['NafEnt']; $reponse->Nic = $etab['Nic'];
$reponse->NafEntLib = $etab['NafEntLib']; $reponse->Actif = $etab['Actif'];
$reponse->NafEtab = $etab['NafEtab'];
$reponse->NafEtabLib = $etab['NafEtabLib'];
$reponse->NafEnt = $etab['NafEnt'];
$reponse->NafEntLib = $etab['NafEntLib'];
$tabRet[] = $reponse; $tabRet[] = $reponse;
$nbReponses = 1; $nbReponses = 1;
$nbReponsesTotal = 1; $nbReponsesTotal = 1;
} else { } else {
$iDb = new WDB(); $iDb = new WDB();
$iDb->insert('siren_inexistants', array( $iDb->insert('siren_inexistants', array(
'siren'=>$siren, 'siren'=>$siren,
'nic'=>$nic, 'nic'=>$nic,
'dep'=>$dep, 'dep'=>$dep,
'login'=>$this->tabInfoUser['login'], 'login'=>$this->tabInfoUser['login'],
'client'=>$this->tabInfoUser['idClient'], 'client'=>$this->tabInfoUser['idClient'],
'dateInsert'=>date('YmdHis'))); 'dateInsert'=>date('YmdHis')));
$nbReponses = 0; $nbReponses = 0;
$nbReponsesTotal = 0; $nbReponsesTotal = 0;
$rep['info'] = 'Siren inexistant'; $rep['info'] = 'Siren inexistant';
} }
}
} else {
if ($iInsee->sirenExiste($siren) ) {
$info = 'Aucun ';
if ( $siege == 1 ) $info.= 'siege';
else $info.= 'etablissement';
if ( $actif == 0 ) $info.= ' inactif';
elseif ( $actif == 1) $info.= ' actif';
$rep['info'] = $info;
} else {
$rep['info'] = 'Siren inexistant';
}
}
} }
$output = new SearchReturn(); $output = new SearchReturn();