2010-11-04 11:21:31 +00:00
|
|
|
<?php
|
|
|
|
// --------------------------------------------------------------------------- //
|
|
|
|
// Formulaire de requete Sphinx
|
|
|
|
// --------------------------------------------------------------------------- //
|
|
|
|
// Fichiers lus en entree : crit2seq.prn et comb2crit.txt
|
|
|
|
// --------------------------------------------------------------------------- //
|
|
|
|
if (defined('DEBUG') == false) {
|
|
|
|
define( 'DEBUG', 0);
|
|
|
|
}
|
|
|
|
|
2012-04-24 12:51:07 +00:00
|
|
|
require_once realpath(dirname(__FILE__)).'/criteresFonc.php';
|
2010-11-04 11:21:31 +00:00
|
|
|
|
|
|
|
$gDatabaseJO = databaseJO();
|
|
|
|
|
|
|
|
// --------------------------------------------------------------------------- //
|
|
|
|
// databaseJO
|
|
|
|
// --------------------------------------------------------------------------- //
|
|
|
|
function databaseJO()
|
|
|
|
{
|
2012-04-24 12:51:07 +00:00
|
|
|
$db = new mysqli(MYSQL_HOST, MYSQL_USER, MYSQL_PASS, 'jo');
|
2010-11-04 11:21:31 +00:00
|
|
|
if (mysqli_connect_error()) {
|
|
|
|
println('Ne peut pas se connecter a la base.');
|
|
|
|
return;
|
|
|
|
}
|
2011-06-21 15:59:12 +00:00
|
|
|
$db->query("SET NAMES 'utf8';");
|
2010-11-04 11:21:31 +00:00
|
|
|
return $db;
|
|
|
|
}
|
|
|
|
|
|
|
|
// --------------------------------------------------------------------------- //
|
|
|
|
// println
|
|
|
|
// --------------------------------------------------------------------------- //
|
|
|
|
function println($ln = '')
|
|
|
|
{
|
|
|
|
print $ln.'<br/>';
|
|
|
|
}
|
|
|
|
|
|
|
|
// --------------------------------------------------------------------------- //
|
|
|
|
// debugln
|
|
|
|
// --------------------------------------------------------------------------- //
|
|
|
|
if (DEBUG) {
|
|
|
|
function debugln($ln = '')
|
|
|
|
{
|
|
|
|
print $ln.'<br/>';
|
|
|
|
}
|
|
|
|
} else if (LOCAL) {
|
|
|
|
function debugln($ln = '')
|
|
|
|
{
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
function debugln($ln = '')
|
|
|
|
{
|
2013-01-04 17:36:17 +00:00
|
|
|
/*
|
|
|
|
$fp = fopen(LOG_PATH.'/recherchesDebug.log', 'a');
|
|
|
|
fwrite($fp, $ln.'\n');
|
|
|
|
fclose($fp);
|
|
|
|
*/
|
2010-11-04 11:21:31 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// --------------------------------------------------------------------------- //
|
|
|
|
// Filtre les caracteres speciaux
|
|
|
|
// --------------------------------------------------------------------------- //
|
|
|
|
function filtreCaracteresSpeciaux(&$formR)
|
|
|
|
{
|
|
|
|
foreach ($formR as $label => $valeur) {
|
|
|
|
if (empty($valeur) == true) {
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
$formR[$label] = str_replace('@', 'a', $valeur);
|
|
|
|
$formR[$label] = str_replace('\'', ' ', $formR[$label]);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// --------------------------------------------------------------------------- //
|
|
|
|
// Filtre pour le siren
|
|
|
|
// --------------------------------------------------------------------------- //
|
|
|
|
function filtreSiret(&$formR, &$criteres, &$sphinx)
|
|
|
|
{
|
|
|
|
if (empty($formR['siret']) == true) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (strstr($criteres, 'I') != false) {
|
|
|
|
if (preg_match('/[0-9]{9}/', $formR['siret'], $arraySiren) > 0) {
|
|
|
|
debugln("filtre siren='$arraySiren[0]'");
|
|
|
|
$sphinx->SetFilter('siren', $arraySiren);
|
|
|
|
} else if (preg_match('/[0-9]{5}/', $formR['siret'], $arrayNic) > 0) {
|
|
|
|
debugln("filtre nic='$arrayNic[0]'");
|
|
|
|
$sphinx->SetFilter('nic', $arrayNic);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// --------------------------------------------------------------------------- //
|
|
|
|
// Filtre pour les elements de l'adresse
|
|
|
|
// --------------------------------------------------------------------------- //
|
|
|
|
function filtreAdresse(&$formR, &$criteres, &$sphinx)
|
|
|
|
{
|
2011-07-01 07:59:45 +00:00
|
|
|
$gDatabaseJO = databaseJO();
|
2010-11-04 11:21:31 +00:00
|
|
|
|
|
|
|
if (empty($formR['cpVille']) == true) {
|
|
|
|
return;
|
|
|
|
}
|
2013-01-04 17:36:17 +00:00
|
|
|
|
2010-11-04 11:21:31 +00:00
|
|
|
$adressePostale = $formR['cpVille'];
|
2012-09-04 09:13:20 +00:00
|
|
|
//If we have a CEDEX
|
|
|
|
if (preg_match('/^[0-9]{5}\s(.*)\sCEDEX/i', $adressePostale, $codePostaux)) {
|
|
|
|
$formR['departement'] = '';
|
|
|
|
$formR['ville'] = $codePostaux[1];
|
|
|
|
}
|
|
|
|
//If we have a Code Postal
|
|
|
|
elseif (preg_match('/[0-9]{5}/', $adressePostale, $codePostaux) > 0)
|
|
|
|
{
|
|
|
|
if (strstr($criteres, 'L') != false)
|
|
|
|
{
|
2010-11-04 11:21:31 +00:00
|
|
|
debugln("filtre adr_cp='$codePostaux[0]'");
|
|
|
|
$sphinx->SetFilter('adr_cp', $codePostaux);
|
2012-09-04 09:13:20 +00:00
|
|
|
}
|
|
|
|
else if (strstr($criteres, 'D') != false)
|
|
|
|
{
|
2010-11-04 11:21:31 +00:00
|
|
|
$departement = substr($codePostaux[0], 0, 2);
|
2012-09-04 09:13:20 +00:00
|
|
|
if ($departement == 97 || $departement == 98)
|
|
|
|
{
|
2010-11-04 11:21:31 +00:00
|
|
|
$departement = substr($codePostaux[0], 0, 3);
|
|
|
|
}
|
|
|
|
debugln("filtre adr_dep='$departement'");
|
|
|
|
$sphinx->SetFilter('adr_dep', array($departement));
|
|
|
|
}
|
2012-09-04 09:13:20 +00:00
|
|
|
|
|
|
|
$formR['ville'] = str_replace($codePostaux[0], '', $adressePostale);
|
2010-11-04 11:21:31 +00:00
|
|
|
$dep = intval(substr($codePostaux[0], 0, 2));
|
2013-01-04 17:36:17 +00:00
|
|
|
|
2012-09-04 09:13:20 +00:00
|
|
|
//Monaco
|
2010-11-04 11:21:31 +00:00
|
|
|
if ($codePostaux[0] == '98000') {
|
|
|
|
$formR['departement'] = 99;
|
|
|
|
$formR['localite'] = 0;
|
2012-09-04 09:13:20 +00:00
|
|
|
//DOM-TOM
|
|
|
|
} else if ($dep == 97 || $dep == 98) {
|
2010-11-04 11:21:31 +00:00
|
|
|
$formR['departement'] = substr($codePostaux[0], 0, 3);
|
|
|
|
$formR['localite'] = substr($codePostaux[0], 3, 2);
|
|
|
|
} else {
|
|
|
|
$formR['departement'] = substr($codePostaux[0], 0, 2);
|
|
|
|
$formR['localite'] = substr($codePostaux[0], 2, 3);
|
|
|
|
}
|
2012-09-04 09:13:20 +00:00
|
|
|
}
|
|
|
|
//If we have a Departement
|
|
|
|
else if (preg_match('/(2[A|B]|[0-9]{2})/', $adressePostale, $departements)
|
|
|
|
|| preg_match('/([0-9]{3})/', $adressePostale, $departements))
|
|
|
|
{
|
|
|
|
$departement = $departements[1];
|
2013-01-04 17:36:17 +00:00
|
|
|
|
2012-09-04 09:13:20 +00:00
|
|
|
if ($departement == '2A'){
|
|
|
|
$departement = 201;
|
|
|
|
}
|
|
|
|
if ($departement == '2B' ) {
|
|
|
|
$departement = 202;
|
|
|
|
}
|
2013-01-04 17:36:17 +00:00
|
|
|
|
2010-11-04 11:21:31 +00:00
|
|
|
if (strstr($criteres, 'D') != false) {
|
2012-09-04 09:13:20 +00:00
|
|
|
debugln("filtre adr_dep='$departement'");
|
|
|
|
$sphinx->SetFilter('adr_dep', array($departement));
|
2010-11-04 11:21:31 +00:00
|
|
|
}
|
2012-09-04 09:13:20 +00:00
|
|
|
$formR['ville'] = str_replace($departement, '', $adressePostale);
|
|
|
|
$formR['departement'] = $departement;
|
2010-11-04 11:21:31 +00:00
|
|
|
} else {
|
|
|
|
$formR['ville'] = $adressePostale;
|
|
|
|
}
|
|
|
|
|
|
|
|
// Completion
|
|
|
|
if (isset($formR['ville']) == true &&
|
|
|
|
isset($formR['localite']) == false) {
|
|
|
|
$ville = strtoupper(trim($formR['ville']));
|
|
|
|
if ($ville == 'PARIS') {
|
|
|
|
$formR['departement'] = 75;
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
if ($ville == 'LYON') {
|
|
|
|
$formR['departement'] = 69;
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
if ($ville == 'MARSEILLE') {
|
|
|
|
$formR['departement'] = 13;
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
$requeteDB = "select * from communes where LibCom like '$ville'";
|
|
|
|
debugln($requeteDB);
|
|
|
|
$resDB = $gDatabaseJO->query($requeteDB);
|
|
|
|
if ($resDB->num_rows == 1) {
|
|
|
|
$cp = $resDB->fetch_assoc();
|
|
|
|
$cp = $cp['Code Postal'];
|
|
|
|
$formR['departement'] = substr($cp, 0, 2);
|
|
|
|
if ($formR['departement'] == '97' ||
|
|
|
|
$formR['departement'] == '98') {
|
|
|
|
$formR['departement'] = substr($cp, 0, 3);
|
|
|
|
$formR['localite'] = substr($cp, 3, 2);
|
|
|
|
} else {
|
|
|
|
$formR['localite'] = substr($cp, 2, 3);
|
|
|
|
}
|
|
|
|
if (DEBUG) {
|
|
|
|
print 'Completion: '.$formR['ville'].' '.
|
|
|
|
$formR['departement'].$formR['localite'].'<br/>';
|
|
|
|
}
|
|
|
|
}
|
|
|
|
// TODO:
|
|
|
|
// On peut ameliorer avec le departement si plusieurs resultats
|
|
|
|
// ou tronquer la ville si aucun resultat
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// --------------------------------------------------------------------------- //
|
|
|
|
// Filtre pour le numero de la voie
|
|
|
|
// --------------------------------------------------------------------------- //
|
|
|
|
function filtreNumero(&$formR, &$criteres, &$sphinx)
|
|
|
|
{
|
|
|
|
if (empty($formR['numVoie']) == false) {
|
|
|
|
if (strstr($criteres, 'N') != false) {
|
|
|
|
debugln("filtre adr_num='$formR[numVoie]'");
|
|
|
|
$sphinx->SetFilter('adr_num', array($formR['numVoie']));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// --------------------------------------------------------------------------- //
|
|
|
|
// Filtre pour la date de naissance
|
|
|
|
// --------------------------------------------------------------------------- //
|
|
|
|
function filtreDateNaiss(&$formR, &$criteres, &$sphinx)
|
|
|
|
{
|
|
|
|
$jj = preg_replace('/[^0-9]/', '', $formR['dirDateNaissJJ']);
|
|
|
|
if ($jj < 0 ||
|
|
|
|
$jj > 31) {
|
2011-03-25 16:18:01 +00:00
|
|
|
echo ('Jour de naissance incorrect !');
|
2010-11-04 11:21:31 +00:00
|
|
|
}
|
|
|
|
$mm = preg_replace('/[^0-9]/', '', $formR['dirDateNaissMM']);
|
|
|
|
if ($mm < 0 ||
|
|
|
|
$mm > 12) {
|
2011-03-25 16:18:01 +00:00
|
|
|
echo ('Mois de naissance incorrect !');
|
2010-11-04 11:21:31 +00:00
|
|
|
}
|
|
|
|
$aa = preg_replace('/[^0-9]/', '', $formR['dirDateNaissAAAA']);
|
|
|
|
$annee = date('Y') - 18;
|
|
|
|
if ($aa < 0 ||
|
|
|
|
$aa > $annee) {
|
2011-03-25 16:18:01 +00:00
|
|
|
echo ('Année de naissance incorrecte !');
|
2010-11-04 11:21:31 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
if (empty($jj) == false && strstr($criteres, 'J') != false) {
|
|
|
|
debugln("filtre naiss_jour='$jj'");
|
|
|
|
$sphinx->SetFilter('naiss_jour', array($jj));
|
|
|
|
}
|
|
|
|
if (empty($mm) == false && strstr($criteres, 'M') != false) {
|
|
|
|
debugln("filtre naiss_jour='$mm'");
|
|
|
|
$sphinx->SetFilter('naiss_mois', array($mm));
|
|
|
|
}
|
|
|
|
if (empty($aa) == false) {
|
|
|
|
if (strstr($criteres, 'A') != false) {
|
|
|
|
debugln("filtre naiss_jour='$aa'");
|
|
|
|
$sphinx->SetFilter('naiss_annee', array($aa));
|
|
|
|
} else if (strstr($criteres, 'R') != false) {
|
|
|
|
debugln("filtre naiss_jour='".($aa-5).'-'.($aa+5)."'");
|
|
|
|
$sphinx->SetFilterRange('naiss_annee', $aa - 5, $aa + 5);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2012-04-24 12:51:07 +00:00
|
|
|
//Filtre sur les actifs
|
2012-06-06 13:33:29 +00:00
|
|
|
function filtreActif(&$formR, &$criteres, &$sphinx)
|
2012-04-24 12:51:07 +00:00
|
|
|
{
|
|
|
|
if ( array_key_exists('actif', $formR) && in_array($formR['actif'], array(0,1)) ) {
|
|
|
|
$sphinx->setFilter('actif', array($formR['actif']));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2012-12-04 16:06:44 +00:00
|
|
|
//Filtre sur les sieges
|
|
|
|
function filtreSiege(&$formR, &$criteres, &$sphinx)
|
|
|
|
{
|
2013-01-04 17:36:17 +00:00
|
|
|
if ( array_key_exists('siege', $formR) && $formR['siege']==1 ) {
|
2012-12-04 16:06:44 +00:00
|
|
|
$sphinx->setFilter('siege', array(1));
|
|
|
|
}
|
|
|
|
}
|
2012-04-24 12:51:07 +00:00
|
|
|
|
2010-11-04 11:21:31 +00:00
|
|
|
// --------------------------------------------------------------------------- //
|
|
|
|
// Premiere requete Sphinx
|
|
|
|
// --------------------------------------------------------------------------- //
|
|
|
|
// Premiere requete sans la gestion des mots non significatifs
|
|
|
|
// et avec concatenation de tous les mots de la raison sociale
|
|
|
|
// --------------------------------------------------------------------------- //
|
|
|
|
function premiereRequeteSphinx(&$sphinx, &$index, &$formR, &$criteres,
|
|
|
|
&$criteresSphinx, &$form2crit, $sirenValide)
|
|
|
|
{
|
2012-12-04 16:06:44 +00:00
|
|
|
filtreSiege($formR, $criteres, $sphinx);
|
|
|
|
filtreActif($formR, $criteres, $sphinx);
|
2010-11-04 11:21:31 +00:00
|
|
|
filtreSiret ($formR, $criteres, $sphinx);
|
|
|
|
filtreAdresse($formR, $criteres, $sphinx);
|
|
|
|
filtreNumero ($formR, $criteres, $sphinx);
|
|
|
|
if ($sirenValide == true) {
|
|
|
|
$sphinx->SetFilter('sirenValide', array(1));
|
|
|
|
}
|
|
|
|
|
|
|
|
$requete_sphinx = '';
|
|
|
|
foreach ($formR as $label => $valeur) {
|
|
|
|
if ($label == 'naf' && empty($valeur) == false) {
|
|
|
|
$requete_sphinx .= '@ape_etab '.$valeur.' ';
|
|
|
|
} else if (empty($valeur) == false &&
|
|
|
|
isset($criteresSphinx[$label]) == true &&
|
|
|
|
strstr($criteres, $form2crit[$label]) != false) {
|
|
|
|
if ($label == 'raisonSociale') {
|
|
|
|
$sans_espace = str_replace(' ', '', $valeur);
|
|
|
|
if ($sans_espace != $valeur) {
|
|
|
|
if (strstr($valeur, '"') == false) {
|
|
|
|
$valeur = '"'.$valeur.'"';
|
|
|
|
}
|
|
|
|
$valeur = '('.$sans_espace.' | '.$valeur.'~2)';
|
|
|
|
} else if (strstr($valeur, '"') == false) {
|
|
|
|
$valeur = '"'.$valeur.'"';
|
|
|
|
}
|
|
|
|
}
|
|
|
|
$requete_sphinx .= $criteresSphinx[$label].' '.$valeur.' ';
|
|
|
|
}
|
|
|
|
}
|
|
|
|
debugln("requete='$requete_sphinx'");
|
|
|
|
if (substr($index, 0, 3) == 'ent') {
|
2012-06-06 13:33:29 +00:00
|
|
|
$sphinx->SetSortMode(SPH_SORT_EXTENDED,'sirenValide DESC, actif DESC, siege DESC, rang DESC');
|
2010-11-04 11:21:31 +00:00
|
|
|
} else if (substr($index, 0, 3) == 'dir') {
|
|
|
|
$sphinx->SetSortMode(SPH_SORT_EXTENDED, 'actif DESC');
|
|
|
|
}
|
|
|
|
|
|
|
|
return $sphinx->Query($requete_sphinx, $index);
|
|
|
|
}
|
|
|
|
|
|
|
|
// --------------------------------------------------------------------------- //
|
|
|
|
// Requete Sphinx
|
|
|
|
// --------------------------------------------------------------------------- //
|
|
|
|
function requeteSphinx(&$sphinx, &$index, &$formR, &$criteres,
|
|
|
|
&$criteresSphinx, &$form2crit, $quorum_actif, $quorum,
|
|
|
|
$sirenValide)
|
|
|
|
{
|
2012-12-04 16:06:44 +00:00
|
|
|
filtreSiege($formR, $criteres, $sphinx);
|
|
|
|
filtreActif($formR, $criteres, $sphinx);
|
2010-11-04 11:21:31 +00:00
|
|
|
filtreSiret ($formR, $criteres, $sphinx);
|
|
|
|
filtreAdresse($formR, $criteres, $sphinx);
|
|
|
|
filtreNumero ($formR, $criteres, $sphinx);
|
|
|
|
if ($sirenValide == true) {
|
|
|
|
$sphinx->SetFilter('sirenValide', array(1));
|
2012-06-06 13:33:29 +00:00
|
|
|
}
|
|
|
|
|
2010-11-04 11:21:31 +00:00
|
|
|
if ($quorum_actif == true) {
|
|
|
|
foreach ($quorum as $label => $valeur) {
|
|
|
|
if ($valeur > 1 && strstr($formR[$label], '"') == false) {
|
|
|
|
$formR[$label] = '"'.$formR[$label].'"/'.($valeur-1);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
$requete_sphinx = '';
|
|
|
|
foreach ($formR as $label => $valeur) {
|
|
|
|
if ($label == 'naf' && empty($valeur) == false) {
|
|
|
|
$requete_sphinx .= '@ape_etab '.$valeur.' ';
|
|
|
|
} else if (empty($valeur) == false &&
|
|
|
|
isset($criteresSphinx[$label]) == true &&
|
|
|
|
strstr($criteres, $form2crit[$label]) != false) {
|
|
|
|
$requete_sphinx .= $criteresSphinx[$label].' '.$valeur.' ';
|
|
|
|
}
|
|
|
|
}
|
|
|
|
debugln("requete='$requete_sphinx'");
|
|
|
|
if (substr($index, 0, 3) == 'ent') {
|
|
|
|
$sphinx->
|
|
|
|
SetSortMode(SPH_SORT_EXTENDED,
|
|
|
|
'sirenValide DESC, rang DESC, actif DESC, siege DESC');
|
|
|
|
} else if (substr($index, 0, 3) == 'dir') {
|
|
|
|
$sphinx->SetSortMode(SPH_SORT_EXTENDED, 'actif DESC');
|
|
|
|
}
|
|
|
|
|
|
|
|
return $sphinx->Query($requete_sphinx, $index);
|
|
|
|
}
|
|
|
|
|
|
|
|
// --------------------------------------------------------------------------- //
|
|
|
|
// Criteres de depart
|
|
|
|
// --------------------------------------------------------------------------- //
|
|
|
|
function criteresDeDepart(&$formR, &$form2crit)
|
|
|
|
{
|
|
|
|
$criteres = '';
|
|
|
|
foreach ($form2crit as $label => $valeur) {
|
|
|
|
if (empty($formR[$label]) == false) {
|
|
|
|
if ($valeur == 'I') { // Dans ce cas on ne garde que le siren
|
|
|
|
return 'I ';
|
|
|
|
}
|
|
|
|
$criteres .= $valeur;
|
|
|
|
} else {
|
|
|
|
$criteres .= ' ';
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return $criteres;
|
|
|
|
}
|
|
|
|
|
|
|
|
// --------------------------------------------------------------------------- //
|
|
|
|
// Affichage du status de Sphinx
|
|
|
|
// --------------------------------------------------------------------------- //
|
|
|
|
function afficheStatusSphinx(&$sphinx, &$resSphinx)
|
|
|
|
{
|
|
|
|
if (DEBUG) {
|
|
|
|
if ($resSphinx == false) {
|
|
|
|
println('Query failed: '.$sphinx->GetLastError().'.');
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
if ($sphinx->GetLastWarning()) {
|
|
|
|
println('WARNING: '.$sphinx->GetLastWarning());
|
|
|
|
}
|
|
|
|
|
|
|
|
println("Query retrieved $resSphinx[total]".
|
|
|
|
" of $resSphinx[total_found] matches in $resSphinx[time] sec.");
|
|
|
|
println('Query stats:');
|
|
|
|
if (isset ($resSphinx['words']) &&
|
|
|
|
is_array($resSphinx['words'])) {
|
|
|
|
foreach ($resSphinx['words'] as $word => $info) {
|
|
|
|
println(" '$word' found $info[hits] times".
|
|
|
|
" in $info[docs] documents");
|
|
|
|
}
|
|
|
|
println('');
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// --------------------------------------------------------------------------- //
|
|
|
|
// Affichage des donnees en base
|
|
|
|
// --------------------------------------------------------------------------- //
|
|
|
|
function afficheDB(&$resSphinx, &$formR, &$form2crit, $table, &$base2form,
|
|
|
|
$deb, $nbRep)
|
|
|
|
{
|
2011-06-21 15:59:12 +00:00
|
|
|
$gDatabaseJO = databaseJO();
|
2010-11-04 11:21:31 +00:00
|
|
|
|
|
|
|
if (isset($resSphinx['matches']) == false) {
|
|
|
|
println('Aucun résultat');
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
if ($formR['type'] == 'ent') {
|
|
|
|
$requeteDB = "select *, (siren>200) AS sirenValide";
|
|
|
|
} else {
|
|
|
|
$requeteDB = "select *";
|
|
|
|
}
|
|
|
|
$requeteDB .= " from $table where id=".$resSphinx['matches'][0]['id'];
|
|
|
|
for ($i = 1; $i + $deb < $resSphinx['total'] && $i < $nbRep; ++$i) {
|
|
|
|
$requeteDB .= ' or id='.$resSphinx['matches'][$i]['id'];
|
|
|
|
}
|
|
|
|
if ($formR['type'] == 'ent') {
|
|
|
|
$requeteDB .=
|
2012-06-06 13:33:29 +00:00
|
|
|
' ORDER BY sirenValide DESC, actif DESC, siege DESC, rang DESC';
|
2010-11-04 11:21:31 +00:00
|
|
|
} else {
|
|
|
|
$requeteDB .= ' ORDER BY actif DESC';
|
|
|
|
}
|
|
|
|
$requeteDB .= ' limit 0, '.$nbRep;
|
|
|
|
debugln("requeteDB='$requeteDB'");
|
|
|
|
$resDB = $gDatabaseJO->query($requeteDB);
|
|
|
|
$nb_res = $resDB->num_rows;
|
|
|
|
for ($i = 0; $i < $nb_res; ++$i) {
|
|
|
|
$ligne = $resDB->fetch_assoc();
|
|
|
|
println();
|
|
|
|
foreach ($base2form as $label => $valeur) {
|
|
|
|
if (empty($formR[$valeur]) == false) {
|
|
|
|
print "$form2crit[$valeur]=<b>'$ligne[$label]'</b> ";
|
|
|
|
} else {
|
|
|
|
print "$form2crit[$valeur]='$ligne[$label]' ";
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
println();
|
|
|
|
}
|
|
|
|
|
|
|
|
// --------------------------------------------------------------------------- //
|
|
|
|
// Nombre de mots trouves dans un champ
|
|
|
|
// --------------------------------------------------------------------------- //
|
|
|
|
function nombreDeMots(&$res, $champ)
|
|
|
|
{
|
|
|
|
if (isset($res['words']) == false) {
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
$champ = preg_replace('/[^A-Za-z]/', ' ', $champ);
|
|
|
|
$mot = explode(' ', strtolower($champ));
|
|
|
|
$n = 0;
|
|
|
|
$nul = 0;
|
|
|
|
|
|
|
|
foreach ($mot as $m) {
|
|
|
|
if (isset($res['words'][$m]) == true) {
|
|
|
|
debugln('nombre de mots: '.
|
|
|
|
$m.' => '.$res['words'][$m]['hits']);
|
|
|
|
if ($res['words'][$m]['hits'] == 0) {
|
|
|
|
++$nul;
|
|
|
|
}
|
|
|
|
++$n;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if ($nul > 2) {
|
|
|
|
return $n - $nul + 1;
|
|
|
|
} else {
|
|
|
|
return $n;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// --------------------------------------------------------------------------- //
|
|
|
|
// changePass
|
|
|
|
// --------------------------------------------------------------------------- //
|
|
|
|
// mode et index doivent etre positionnes a chaque fois
|
|
|
|
// --------------------------------------------------------------------------- //
|
|
|
|
function changePass(&$pass, &$mode, &$index, &$quorumActif, &$formR)
|
|
|
|
{
|
|
|
|
switch ($pass) {
|
|
|
|
case 1: // Pass 2 : Phonex
|
|
|
|
$pass = 2;
|
|
|
|
$mode = SPH_MATCH_EXTENDED2;
|
|
|
|
$index = 'ent_phx';
|
|
|
|
return true;
|
|
|
|
case 2: // Pass 3 : Ispell
|
|
|
|
$pass = 3;
|
|
|
|
$mode = SPH_MATCH_ISPELL;
|
|
|
|
$index = 'ent_mns';
|
|
|
|
return true;
|
|
|
|
case 3: // Pass 4 : Quorum n-1
|
|
|
|
$pass = 4;
|
|
|
|
$mode = SPH_MATCH_EXTENDED2;
|
|
|
|
$index = 'ent_mns';
|
|
|
|
$quorumActif = true;
|
|
|
|
return true;
|
|
|
|
case 4: // Pass 5 : Quorum n-2
|
|
|
|
$pass = 5;
|
|
|
|
foreach ($formR as $label => $valeur) {
|
|
|
|
if (preg_match('@.*"/[1-9]+@', $valeur) != false) {
|
|
|
|
$n = preg_replace('@.*"/([1-9]+).*@', '$1', $valeur);
|
|
|
|
if ($n > 1) {
|
|
|
|
$formR[$label] = str_replace($n, $n - 1, $valeur);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return true;
|
|
|
|
default:
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// --------------------------------------------------------------------------- //
|
|
|
|
// initSphinx
|
|
|
|
// --------------------------------------------------------------------------- //
|
|
|
|
function initSphinx(&$sphinx, $mode, $pass, $deb, $nbRep, $max)
|
|
|
|
{
|
|
|
|
debugln();
|
|
|
|
debugln('pass '.$pass);
|
|
|
|
debugln();
|
|
|
|
$sphinx->SetMatchMode($mode);
|
|
|
|
$sphinx->resetFilters();
|
2011-06-27 11:32:11 +00:00
|
|
|
$sphinx->SetLimits(intval($deb), intval($nbRep), intval($max));
|
2010-11-04 11:21:31 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// --------------------------------------------------------------------------- //
|
|
|
|
// Criteres recherche par dirigeant
|
|
|
|
// --------------------------------------------------------------------------- //
|
|
|
|
function criteresDir($c, &$index)
|
|
|
|
{
|
|
|
|
if (substr($c, strlen($c) - 1, 1) == 'p') {
|
|
|
|
$c = substr($c, 0, strlen($c) - 1);
|
|
|
|
$index = 'dir';
|
|
|
|
} else {
|
|
|
|
$index = 'dir_phx';
|
|
|
|
return $c.'p';
|
|
|
|
}
|
|
|
|
$tab =
|
|
|
|
array('NPAMJDV' => 'NPAM DV',
|
|
|
|
'NPAM DV' => 'NPA DV',
|
|
|
|
'NPA DV' => 'NPR DV',
|
|
|
|
'NPR DV' => 'NP DV',
|
|
|
|
'NP DV' => 'NPAMJD ',
|
|
|
|
'NPAMJD ' => 'NPAMJ ',
|
|
|
|
'NPAMJ ' => 'N AMJDV',
|
|
|
|
'N AMJDV' => 'N AM DV',
|
|
|
|
'N AM DV' => 'N A DV',
|
|
|
|
'N A DV' => 'N R DV',
|
|
|
|
'N R DV' => 'N DV',
|
|
|
|
'N DV' => 'N AMJD ',
|
|
|
|
'N AMJD ' => 'N AMJ ',
|
|
|
|
'N AMJ ' => ' PAMJDV',
|
|
|
|
' PAMJDV' => ' PAM DV',
|
|
|
|
' PAM DV' => ' PA DV',
|
|
|
|
' PA DV' => ' PR DV',
|
|
|
|
' PR DV' => ' P DV',
|
|
|
|
' P DV' => ' PAMJD ',
|
|
|
|
' PAMJD ' => ' PAMJ ',
|
|
|
|
' PAMJ ' => ' PAM ');
|
|
|
|
|
|
|
|
if (isset($tab[$c]) == true) {
|
|
|
|
$ret = $tab[$c];
|
|
|
|
} else {
|
|
|
|
$ret = '';
|
|
|
|
}
|
|
|
|
|
|
|
|
return $ret;
|
|
|
|
}
|
|
|
|
|
|
|
|
// --------------------------------------------------------------------------- //
|
|
|
|
// clientSphinx
|
|
|
|
// --------------------------------------------------------------------------- //
|
|
|
|
function clientSphinx(&$formR)
|
|
|
|
{
|
|
|
|
// Formulaire
|
|
|
|
$formulaire_vide = true;
|
|
|
|
foreach ($formR as $label => $valeur) {
|
|
|
|
if ($label != 'type' && // Ce champs ne devrait pas etre dans formR
|
|
|
|
empty($valeur) == false) {
|
|
|
|
$formulaire_vide = false;
|
|
|
|
$formR[$label] = trim($valeur);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if ($formulaire_vide == true) {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
if (DEBUG) {
|
|
|
|
foreach ($formR as $label => $valeur) {
|
|
|
|
println("$label = '$valeur'");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2011-07-15 09:20:41 +00:00
|
|
|
switch($formR['type'])
|
|
|
|
{
|
|
|
|
case 'ent':
|
|
|
|
$host = SPHINX_ENT_HOST;
|
|
|
|
$port = SPHINX_ENT_PORT;
|
2012-06-06 13:33:29 +00:00
|
|
|
$version = defined('SPHINX_ENT_VERSION') ? SPHINX_ENT_VERSION : 1;
|
2011-07-15 09:20:41 +00:00
|
|
|
break;
|
|
|
|
case 'dir':
|
2012-06-06 13:33:29 +00:00
|
|
|
$version = defined('SPHINX_DIR_VERSION') ? SPHINX_DIR_VERSION : 1;
|
2011-07-15 09:20:41 +00:00
|
|
|
$host = SPHINX_DIR_HOST;
|
|
|
|
$port = SPHINX_DIR_PORT;
|
|
|
|
break;
|
|
|
|
case 'histo':
|
2012-06-06 13:33:29 +00:00
|
|
|
$version = defined('SPHINX_HISTO_VERSION') ? SPHINX_HISTO_VERSION : 1;
|
2011-07-15 09:20:41 +00:00
|
|
|
$host = SPHINX_HISTO_HOST;
|
|
|
|
$port = SPHINX_HISTO_PORT;
|
|
|
|
break;
|
2012-04-24 13:02:22 +00:00
|
|
|
case 'act':
|
|
|
|
$version = defined('SPHINX_ACT_VERSION') ? SPHINX_ACT_VERSION : 1;
|
2011-07-15 09:20:41 +00:00
|
|
|
$host = SPHINX_ACT_HOST;
|
|
|
|
$port = SPHINX_ACT_PORT;
|
|
|
|
break;
|
|
|
|
}
|
2012-06-06 13:33:29 +00:00
|
|
|
|
2012-04-24 13:02:22 +00:00
|
|
|
switch ( $version ) {
|
|
|
|
case 1:
|
|
|
|
require_once realpath(dirname(__FILE__)).'/sphinxapi.php';
|
|
|
|
break;
|
|
|
|
case 2:
|
|
|
|
require_once 'sphinxapi/sphinxapi-2.0.2.php';
|
|
|
|
break;
|
|
|
|
}
|
2012-06-06 13:33:29 +00:00
|
|
|
|
2012-04-24 13:02:22 +00:00
|
|
|
// Client Sphinx
|
|
|
|
$sphinx = new SphinxClient();
|
2011-07-15 09:20:41 +00:00
|
|
|
$sphinx->SetServer($host, $port);
|
2010-11-04 11:21:31 +00:00
|
|
|
$sphinx->SetConnectTimeout(1);
|
|
|
|
$sphinx->SetRankingMode(SPH_RANK_PROXIMITY_BM25);
|
|
|
|
$sphinx->SetArrayResult(true);
|
|
|
|
|
|
|
|
return $sphinx;
|
|
|
|
}
|
|
|
|
|
2011-03-25 16:18:01 +00:00
|
|
|
// --------------------------------------------------------------------------- //
|
|
|
|
// compare
|
|
|
|
// --------------------------------------------------------------------------- //
|
|
|
|
function compare($a1, $a2)
|
|
|
|
{
|
|
|
|
$a1 = strtoupper($a1);
|
|
|
|
$a2 = strtoupper($a2);
|
|
|
|
$a1 = str_replace('&', 'ET', $a1);
|
|
|
|
$a2 = str_replace('&', 'ET', $a2);
|
|
|
|
if (DEBUG) {
|
|
|
|
print 'Compare: '.$a1.' avec: '.$a2;
|
|
|
|
}
|
|
|
|
$l1 = levenshtein($a1, $a2);
|
|
|
|
$t1 = explode(' ', $a1);
|
|
|
|
$t2 = explode(' ', $a2);
|
|
|
|
sort($t1);
|
|
|
|
sort($t2);
|
|
|
|
$a1 = implode(' ', $t1);
|
|
|
|
$a2 = implode(' ', $t2);
|
|
|
|
$l2 = levenshtein($a1, $a2);
|
|
|
|
$l = min($l1, $l2);
|
|
|
|
$ret = 1 - $l / max(strlen($a1), strlen($a2));
|
|
|
|
debugln(' levenshtein: '.$l.' pertinence: '.$ret);
|
|
|
|
|
|
|
|
return $ret;
|
|
|
|
}
|
2010-11-04 11:21:31 +00:00
|
|
|
|
|
|
|
// --------------------------------------------------------------------------- //
|
|
|
|
// reponse
|
|
|
|
// --------------------------------------------------------------------------- //
|
|
|
|
function reponse(&$resSphinx, &$resDB, $criteres, $time, $formR, $form2crit,
|
|
|
|
$deb, $ligneDir = array())
|
|
|
|
{
|
|
|
|
$criteresRet = array();
|
|
|
|
|
|
|
|
foreach ($form2crit as $field => $letter) {
|
|
|
|
if (preg_match("/$letter/", $criteres)) {
|
|
|
|
if (empty($formR[$field]) == false) {
|
|
|
|
$criteresRet[] = strtoupper($formR[$field]);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
$ret['criteres'] = $criteresRet;
|
|
|
|
//$ret['nbReponses'] = $resDB->num_rows;
|
|
|
|
$ret['nbReponsesTotal'] = $resSphinx['total'];
|
|
|
|
$ret['duree'] = $time;
|
|
|
|
|
2011-03-25 16:18:01 +00:00
|
|
|
$pertinence_generale = 100;
|
|
|
|
if ($formR['type'] == 'ent') {
|
|
|
|
//$pertinence_generale = 100 - 5 * $resSphinx['pass'];;
|
|
|
|
$tot = 0;
|
|
|
|
$num = 0;
|
|
|
|
$poids = array('I' => 10,
|
|
|
|
'T' => 1,
|
|
|
|
'S' => 9,
|
|
|
|
'E' => 8,
|
|
|
|
'P' => 7,
|
|
|
|
'D' => 6,
|
|
|
|
'L' => 4,
|
|
|
|
'V' => 5,
|
|
|
|
'N' => 2,
|
|
|
|
'R' => 3);
|
|
|
|
foreach ($form2crit as $field => $letter) {
|
|
|
|
if (empty($formR[$field]) == false) {
|
|
|
|
$tot += $poids[$letter];
|
|
|
|
if (preg_match("/$letter/", $criteres)) {
|
|
|
|
$num += $poids[$letter];
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
$pertinence_generale *= $num / $tot;
|
|
|
|
$pertinence_generale = intval($pertinence_generale);
|
2012-06-10 17:38:53 +00:00
|
|
|
//print 'Pertinence generale: '.$pertinence_generale.'<br/>';
|
2011-03-25 16:18:01 +00:00
|
|
|
}
|
2013-01-04 17:36:17 +00:00
|
|
|
|
2012-09-04 09:13:20 +00:00
|
|
|
if ( is_object($resDB) ) {
|
2013-01-04 17:36:17 +00:00
|
|
|
|
2012-09-04 09:13:20 +00:00
|
|
|
$resDB->data_seek(0);
|
2013-01-04 17:36:17 +00:00
|
|
|
|
2012-09-04 09:13:20 +00:00
|
|
|
for ($i = 0; $i < $resDB->num_rows; $i++) {
|
2010-11-04 11:21:31 +00:00
|
|
|
$ligne = $resDB->fetch_assoc();
|
2013-01-04 17:36:17 +00:00
|
|
|
|
2012-09-04 09:13:20 +00:00
|
|
|
//file_put_contents('test.log', "\n".'i = '.$i.print_r($ligne,1), FILE_APPEND);
|
2013-01-04 17:36:17 +00:00
|
|
|
|
2012-09-04 09:13:20 +00:00
|
|
|
$ret['reponses'][$i]['id'] = $ligne['id'];
|
|
|
|
$pertinence = $pertinence_generale;
|
|
|
|
if ($formR['type'] == 'ent') {
|
|
|
|
if (empty($formR['raisonSociale']) == false) {
|
|
|
|
$pertinence *= compare($formR['raisonSociale'], $ligne['raisonSociale']);
|
|
|
|
}
|
|
|
|
if (empty($formR['voie']) == false) {
|
|
|
|
$pertinence *= compare($formR['voie'], $ligne['adr_typeVoie'].' '.$ligne['adr_libVoie']);
|
2010-11-04 11:21:31 +00:00
|
|
|
}
|
2012-09-04 09:13:20 +00:00
|
|
|
if (empty($formR['ville']) == false) {
|
|
|
|
$pertinence *= compare($formR['ville'], $ligne['adr_ville']);
|
2011-07-15 09:20:41 +00:00
|
|
|
}
|
2010-11-04 11:21:31 +00:00
|
|
|
}
|
2012-09-04 09:13:20 +00:00
|
|
|
$ret['reponses'][$i]['Pertinence'] = $pertinence;
|
|
|
|
$ret['reponses'][$i]['Siret'] = $ligne['siret'];
|
|
|
|
$ret['reponses'][$i]['Siren'] = $ligne['siren'];
|
|
|
|
$ret['reponses'][$i]['Nic'] = $ligne['nic'];
|
|
|
|
$ret['reponses'][$i]['Siege'] = $ligne['siege'];
|
|
|
|
$ret['reponses'][$i]['Nom'] = $ligne['raisonSociale'];
|
|
|
|
$ret['reponses'][$i]['Nom2'] = '';
|
|
|
|
$ret['reponses'][$i]['Sigle'] = $ligne['sigle'];
|
|
|
|
$ret['reponses'][$i]['Enseigne'] = $ligne['enseigne'];
|
|
|
|
$ret['reponses'][$i]['Adresse'] =
|
|
|
|
$ligne['adr_num'].' '.
|
|
|
|
$ligne['adr_typeVoie'].' '.
|
|
|
|
$ligne['adr_libVoie'];
|
|
|
|
$ret['reponses'][$i]['Adresse2'] = $ligne['adr_comp'];
|
|
|
|
$ret['reponses'][$i]['CP'] = $ligne['adr_cp'];
|
|
|
|
$ret['reponses'][$i]['Ville'] = $ligne['adr_ville'];
|
|
|
|
$ret['reponses'][$i]['Tel'] = $ligne['tel'];
|
|
|
|
$ret['reponses'][$i]['Fax'] = $ligne['fax'];
|
|
|
|
$ret['reponses'][$i]['FJ'] = $ligne['cj'];
|
|
|
|
$ret['reponses'][$i]['Actif'] = $ligne['actif'];
|
|
|
|
$ret['reponses'][$i]['NafEtab'] = $ligne['ape_etab'];
|
|
|
|
$ret['reponses'][$i]['NafEnt'] = $ligne['ape_entrep'];
|
2013-01-04 17:36:17 +00:00
|
|
|
|
2012-09-04 09:13:20 +00:00
|
|
|
if ($formR['type']=='dir') {
|
|
|
|
// Dirigeant
|
|
|
|
$ret['reponses'][$i]['DirRs'] = '';
|
|
|
|
$ret['reponses'][$i]['DirNom'] = $ligneDir[$i]['nom'];
|
|
|
|
$ret['reponses'][$i]['DirPrenom'] = $ligneDir[$i]['prenom'];
|
|
|
|
$ret['reponses'][$i]['DirNomUsage'] = $ligneDir[$i]['naissance_nom'];
|
|
|
|
$ret['reponses'][$i]['DirDateNaiss'] = $ligneDir[$i]['naissance_date'];
|
|
|
|
$ret['reponses'][$i]['DirLieuNaiss'] = $ligneDir[$i]['naissance_lieu'];
|
|
|
|
$ret['reponses'][$i]['DirDateEffet'] = '';
|
|
|
|
$ret['reponses'][$i]['DirFonction'] = $ligneDir[$i]['fonction_lib'];
|
|
|
|
$ret['reponses'][$i]['DirDepart'] = '';
|
|
|
|
} elseif ($formR['type']=='act') {
|
|
|
|
// Actionnaire
|
|
|
|
$ret['reponses'][$i]['ActNomRs'] = $ligneDir[$i]['ActNomRs'];
|
|
|
|
$ret['reponses'][$i]['ActPays'] = $ligneDir[$i]['ActPays'];
|
|
|
|
$ret['reponses'][$i]['ActDateLien'] = $ligneDir[$i]['ActDateLien'];
|
|
|
|
$ret['reponses'][$i]['ActActif'] = $ligneDir[$i]['ActActif'];
|
|
|
|
$ret['reponses'][$i]['ActPmin'] = $ligneDir[$i]['ActPmin'];
|
|
|
|
}
|
2010-11-04 11:21:31 +00:00
|
|
|
}
|
|
|
|
}
|
2013-01-04 17:36:17 +00:00
|
|
|
|
2010-11-04 11:21:31 +00:00
|
|
|
if ($formR['type'] == 'ent') {
|
|
|
|
$ret['pass'] = $resSphinx['pass'];
|
|
|
|
}
|
|
|
|
$ret['nbReponses'] = count($ret['reponses']);
|
|
|
|
if (DEBUG) {
|
|
|
|
print '<pre>';
|
|
|
|
print_r($ret);
|
|
|
|
print '</pre>';
|
|
|
|
}
|
|
|
|
return $ret;
|
|
|
|
}
|
|
|
|
|
|
|
|
// --------------------------------------------------------------------------- //
|
|
|
|
// Recherche par dirigeant
|
|
|
|
// --------------------------------------------------------------------------- //
|
|
|
|
function rechercheDir(&$formR, $deb, $nbRep, $max)
|
|
|
|
{
|
2011-06-21 15:59:12 +00:00
|
|
|
$gDatabaseJO = databaseJO();
|
2010-11-04 11:21:31 +00:00
|
|
|
|
|
|
|
// Duree totale
|
|
|
|
$total_time = 0;
|
|
|
|
|
|
|
|
$sphinx = clientSphinx($formR);
|
|
|
|
if ($sphinx == false) {
|
|
|
|
return array('nbReponses' => 0,
|
|
|
|
'nbReponsesTotal' => 0,
|
|
|
|
'duree' => $total_time,
|
|
|
|
'erreur' => 'Formulaire vide');
|
|
|
|
}
|
|
|
|
|
|
|
|
$criteresSphinx = array('nom' => '@nom',
|
|
|
|
'prenom' => '@prenom',
|
|
|
|
'ville' => '@naissance_lieu');
|
|
|
|
|
|
|
|
$form2crit = array('nom' => 'N',
|
|
|
|
'prenom' => 'P',
|
|
|
|
'dirDateNaissAAAA' => 'A',
|
|
|
|
'dirDateNaissMM' => 'M',
|
|
|
|
'dirDateNaissJJ' => 'J',
|
|
|
|
'departement' => 'D',
|
|
|
|
'ville' => 'V');
|
|
|
|
|
|
|
|
$index = 'dir';
|
|
|
|
$mode = SPH_MATCH_EXTENDED2;
|
|
|
|
$pass = 0;
|
|
|
|
$criteres = 'NPAMJDV';
|
|
|
|
initSphinx($sphinx, $mode, $pass, $deb, $nbRep, $max);
|
|
|
|
|
|
|
|
while (empty($criteres) == false) {
|
|
|
|
debugln("criteres: $criteres");
|
|
|
|
filtreDateNaiss($formR, $criteres, $sphinx);
|
|
|
|
filtreAdresse($formR, $criteres, $sphinx);
|
|
|
|
$requete_sphinx = '';
|
|
|
|
foreach ($formR as $label => $valeur) {
|
|
|
|
if (empty($valeur) == false &&
|
|
|
|
isset($criteresSphinx[$label]) == true &&
|
|
|
|
strstr($criteres, $form2crit[$label]) != false) {
|
|
|
|
if ($label == 'prenom') {
|
|
|
|
$requete_sphinx .= $criteresSphinx[$label].
|
|
|
|
' "'.$valeur.'"/1 ';
|
|
|
|
} else {
|
|
|
|
$requete_sphinx .= $criteresSphinx[$label].' '.$valeur.' ';
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
debugln("requete='$requete_sphinx'");
|
|
|
|
$sphinx->SetSortMode(SPH_SORT_EXTENDED, 'actif DESC');
|
|
|
|
$resSphinx = $sphinx->Query($requete_sphinx, $index);
|
|
|
|
if ($resSphinx != false) {
|
|
|
|
$total_time += $resSphinx['time'];
|
|
|
|
}
|
|
|
|
if ($resSphinx != false && $resSphinx['total'] > 0) {
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
|
|
|
$criteres = criteresDir($criteres, $index);
|
|
|
|
$sphinx->resetFilters();
|
|
|
|
}
|
|
|
|
|
|
|
|
afficheStatusSphinx($sphinx, $resSphinx);
|
|
|
|
if ($resSphinx == false) {
|
|
|
|
return array('nbReponses' => 0,
|
|
|
|
'nbReponsesTotal' => 0,
|
|
|
|
'duree' => $total_time,
|
|
|
|
'erreur' => $sphinx->GetLastError(),
|
|
|
|
'criteres' => $criteres);
|
|
|
|
}
|
|
|
|
if ($resSphinx['total'] == 0) {
|
|
|
|
return array('nbReponses' => 0,
|
|
|
|
'nbReponsesTotal' => 0,
|
|
|
|
'duree' => $total_time,
|
|
|
|
'criteres' => $criteres);
|
|
|
|
}
|
|
|
|
|
|
|
|
if (DEBUG) {
|
|
|
|
$base2form = array('adr_dep' => 'departement',
|
|
|
|
'nom' => 'nom',
|
|
|
|
'prenom' => 'prenom',
|
|
|
|
'naissance_nom' => 'nom',
|
|
|
|
'naissance_date' => 'dirDateNaissAAAA',
|
|
|
|
'naissance_lieu' => 'ville');
|
2011-06-10 10:08:21 +00:00
|
|
|
afficheDB($resSphinx, $formR, $form2crit, 'dirigeants', $base2form,
|
2010-11-04 11:21:31 +00:00
|
|
|
$deb, $nbRep);
|
|
|
|
}
|
|
|
|
|
|
|
|
// Recherche des sieges
|
|
|
|
if ($gDatabaseJO == false) {
|
|
|
|
return array('nbReponses' => 0,
|
|
|
|
'nbReponsesTotal' => $resSphinx['total'],
|
|
|
|
'duree' => $total_time,
|
|
|
|
'erreur' => 'Base inaccessible');
|
|
|
|
}
|
|
|
|
|
|
|
|
if (isset($resSphinx['matches']) == false) {
|
|
|
|
return array('nbReponses' => 0,
|
|
|
|
'nbReponsesTotal' => $resSphinx['total'],
|
|
|
|
'duree' => $total_time,
|
|
|
|
'erreur' => 'Aucun résultat');
|
|
|
|
}
|
|
|
|
|
2011-12-12 08:48:33 +00:00
|
|
|
$requeteDB =
|
2012-09-04 09:13:20 +00:00
|
|
|
"SELECT d.nom, d.prenom, d.naissance_nom, d.naissance_date, d.naissance_lieu, l.libelle AS fonction_lib,".
|
|
|
|
" e.id, CONCAT(e.siren,e.nic) AS siret, e.siren, e.nic, e.siege, e.raisonSociale, e.sigle, e.enseigne,".
|
|
|
|
" e.adr_num, e.adr_typeVoie, e.adr_libVoie, e.adr_comp, e.adr_cp, e.adr_ville, e.tel, e.fax, e.cj, e.actif, e.ape_etab, e.ape_entrep".
|
2012-06-10 17:38:53 +00:00
|
|
|
" FROM dirigeants d, etablissements e, bodacc_fonctions l".
|
|
|
|
" WHERE d.fonction_code=l.codeFct AND d.id IN (".$resSphinx['matches'][0]['id'];
|
2011-12-12 08:48:33 +00:00
|
|
|
for ($i = 1; $i + $deb < $resSphinx['total'] && $i < $nbRep; ++$i) {
|
2012-06-10 17:38:53 +00:00
|
|
|
$requeteDB .= ",".$resSphinx['matches'][$i]['id'];
|
2011-12-12 08:48:33 +00:00
|
|
|
}
|
2012-06-10 17:38:53 +00:00
|
|
|
$requeteDB .= ") AND e.id = (";
|
|
|
|
$requeteDB .= "SELECT tmp.id FROM etablissements tmp ";
|
|
|
|
$requeteDB .= "WHERE tmp.siren=d.siren ORDER by tmp.actif DESC, tmp.siege DESC LIMIT 1";
|
|
|
|
$requeteDB .= ")";
|
|
|
|
|
2012-09-04 09:13:20 +00:00
|
|
|
//file_put_contents('test.log', $requeteDB);
|
2013-01-04 17:36:17 +00:00
|
|
|
|
2011-12-12 08:48:33 +00:00
|
|
|
debugln();
|
|
|
|
debugln("requeteDB='$requeteDB'");
|
|
|
|
$resDB = $gDatabaseJO->query($requeteDB);
|
|
|
|
|
|
|
|
// Reponse
|
|
|
|
$ligneDir = array();
|
2013-01-04 17:36:17 +00:00
|
|
|
|
2012-09-04 09:13:20 +00:00
|
|
|
for ($i = 0; $i < $resDB->num_rows; $i++) {
|
2011-12-12 08:48:33 +00:00
|
|
|
$ligne = $resDB->fetch_assoc();
|
2013-01-04 17:36:17 +00:00
|
|
|
|
2012-04-24 12:51:07 +00:00
|
|
|
$nom = $ligne['nom'];
|
|
|
|
if ( $ligne['naissance_nom']!='' ) {
|
|
|
|
$nom.= " nom d'usage ".$ligne['naissance_nom'];
|
|
|
|
}
|
|
|
|
$ligneDir[$i] = array(
|
|
|
|
'id' => $ligne['id'],
|
|
|
|
'nom' => $nom,
|
|
|
|
'prenom' => $ligne['prenom'],
|
|
|
|
'fonction_lib' => $ligne['fonction_lib'],
|
|
|
|
'naissance_nom'=> $ligne['naissance_nom'],
|
|
|
|
'naissance_date'=> $ligne['naissance_date'],
|
|
|
|
'naissance_lieu'=> $ligne['naissance_lieu']
|
|
|
|
);
|
2011-12-12 08:48:33 +00:00
|
|
|
}
|
2013-01-04 17:36:17 +00:00
|
|
|
|
2011-12-12 08:48:33 +00:00
|
|
|
debugln();
|
|
|
|
debugln("requeteDB='$requeteDB'");
|
2011-06-10 10:08:21 +00:00
|
|
|
|
|
|
|
return reponse($resSphinx, $resDB, $criteres, $total_time, $formR,
|
|
|
|
$form2crit, $deb, $ligneDir);
|
|
|
|
}
|
|
|
|
|
2011-08-04 07:09:10 +00:00
|
|
|
// --------------------------------------------------------------------------- //
|
|
|
|
// Recherche Histo
|
|
|
|
// --------------------------------------------------------------------------- //
|
|
|
|
function rechercheHisto($formR, $deb, $nbRep, $max)
|
|
|
|
{
|
|
|
|
$gDatabaseJO = databaseJO();
|
2012-06-06 13:33:29 +00:00
|
|
|
|
2011-08-04 07:09:10 +00:00
|
|
|
$sphinx = clientSphinx($formR);
|
2012-06-06 13:33:29 +00:00
|
|
|
|
2011-08-04 07:09:10 +00:00
|
|
|
$index = 'histo';
|
|
|
|
$mode = 'SPH_MATCH_EXTENDED';
|
|
|
|
$pass = 0;
|
|
|
|
initSphinx($sphinx, $mode, $pass, $deb, $nbRep, $max);
|
|
|
|
if (!empty($formR['annee1']))
|
2012-06-06 13:33:29 +00:00
|
|
|
$sphinx->SetFilter('annee1', array(0=>$formR['annee1']));
|
|
|
|
|
2011-08-04 07:09:10 +00:00
|
|
|
$sphinx->SetRankingMode ( SPH_RANK_PROXIMITY_BM25 );
|
2012-06-06 13:33:29 +00:00
|
|
|
|
2011-08-04 07:09:10 +00:00
|
|
|
$sphinxreturn = $sphinx->Query($formR['recherche'], $index);
|
2012-06-06 13:33:29 +00:00
|
|
|
|
2011-08-04 07:09:10 +00:00
|
|
|
$gDatabaseJO->select_db('histobodacc');
|
2012-06-06 13:33:29 +00:00
|
|
|
|
|
|
|
foreach ( $sphinxreturn['matches'] as $doc => $docinfo )
|
2011-08-04 07:09:10 +00:00
|
|
|
{
|
|
|
|
$requette = "SELECT Histo as Loc, id, nomFichier, annee1, bod, texte FROM bodacc_cor WHERE id=$doc";
|
2012-06-06 13:33:29 +00:00
|
|
|
$req = $gDatabaseJO->query($requette);
|
2011-08-04 07:09:10 +00:00
|
|
|
$ligne = $req->fetch_assoc();
|
|
|
|
$etab = $ligne[0];
|
2012-06-06 13:33:29 +00:00
|
|
|
$tabRet[] = array(
|
2011-08-04 07:09:10 +00:00
|
|
|
'Localisation' => $etab['Loc'],
|
|
|
|
'id' => $doc,
|
|
|
|
'Pertinence' => $docinfo['weight'],
|
|
|
|
'Fichier' => $etab['nomFichier'],
|
|
|
|
'Annee' => $etab['annee1'],
|
|
|
|
'Code' => $etab['bod'],
|
|
|
|
'Texte' => $etab['texte'],
|
|
|
|
);
|
|
|
|
}
|
2012-06-06 13:33:29 +00:00
|
|
|
|
|
|
|
return array(
|
2011-08-04 07:09:10 +00:00
|
|
|
'results' => $tabRet,
|
|
|
|
'nbRet' => $sphinxreturn['total'],
|
|
|
|
'nbTot' => $sphinxreturn['total_found'],
|
|
|
|
'duration' => $sphinxreturn['time'],
|
|
|
|
'words' => $sphinxreturn['words'],
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2011-06-10 10:08:21 +00:00
|
|
|
// --------------------------------------------------------------------------- //
|
|
|
|
// Recherche par actionnaire
|
|
|
|
// --------------------------------------------------------------------------- //
|
|
|
|
|
2011-07-15 09:20:41 +00:00
|
|
|
function constructRequete($formR, $sphinxCriteres)
|
|
|
|
{
|
|
|
|
foreach($sphinxCriteres as $name => $critere) {
|
|
|
|
if ($name == 'Req') {
|
|
|
|
$requete .= $formR[$critere];
|
|
|
|
}
|
|
|
|
if ($name[0] == '@') {
|
|
|
|
if(!empty($formR[$critere]))
|
|
|
|
$parametres .= ' '.$name.' '.$formR[$critere];
|
|
|
|
}
|
|
|
|
}
|
|
|
|
echo $sphinxRequete = '"'.$requete.'" '.$parametres;
|
|
|
|
return ($sphinxRequete);
|
|
|
|
}
|
2011-06-10 10:08:21 +00:00
|
|
|
|
2011-07-15 09:20:41 +00:00
|
|
|
function rechercheAct($formR, $deb, $nbRep, $max)
|
|
|
|
{
|
|
|
|
$gDatabaseJO = databaseJO();
|
2012-06-06 13:33:29 +00:00
|
|
|
|
2011-06-10 10:08:21 +00:00
|
|
|
$sphinx = clientSphinx($formR);
|
2011-07-15 09:20:41 +00:00
|
|
|
$sphinx->SetSortMode(SPH_SORT_EXTENDED, 'actif DESC');
|
2012-06-06 13:33:29 +00:00
|
|
|
|
2011-07-15 09:20:41 +00:00
|
|
|
$index = 'act';
|
|
|
|
$mode = 'SPH_MATCH_EXTENDED2';
|
2011-06-10 10:08:21 +00:00
|
|
|
$pass = 0;
|
|
|
|
initSphinx($sphinx, $mode, $pass, $deb, $nbRep, $max);
|
2012-06-06 13:33:29 +00:00
|
|
|
|
2011-07-15 09:20:41 +00:00
|
|
|
$Criteres = array('Siren2' => 'siren',
|
|
|
|
'Req' => 'actNomRS',
|
|
|
|
'@Pays' => 'pays',
|
|
|
|
'PminNum' => 'pctMax'
|
|
|
|
);
|
|
|
|
$form2crit = array('actNomRS' => 'N',
|
|
|
|
'pays' => 'P',
|
|
|
|
'pctMax' => 'M'
|
|
|
|
);
|
2012-06-06 13:33:29 +00:00
|
|
|
|
2011-07-15 09:20:41 +00:00
|
|
|
$Requete = constructRequete($formR, $Criteres);
|
|
|
|
if(!empty($formR['pctMin']))
|
|
|
|
$sphinx->SetFilterRange('PminNum', $formR['pctMin'], 99);
|
|
|
|
if(!empty($formR['pctMax']))
|
|
|
|
$sphinx->SetFilterRange('PminNum', $formR['pctMin'], 99);
|
|
|
|
if(!empty($formR['pctMin']) and !empty($formR['pctMax']))
|
|
|
|
$sphinx->SetFilterRange('PminNum', $formR['pctMix'], $formR['pctMax']);
|
2012-06-06 13:33:29 +00:00
|
|
|
|
2011-07-15 09:20:41 +00:00
|
|
|
|
|
|
|
$sphinxreturn = $sphinx->Query($Requete, $index);
|
|
|
|
$criteres = 'NPM';
|
|
|
|
$requette = 'SELECT l.id AS lienId, l.actif AS lienActif, l.source, l.Pmin, l.PpPm, l.id2, '.
|
|
|
|
'l.Siren2, l.RaisonSociale, l.Pays, '.
|
|
|
|
'IF(l.dateUpdate>IF(l.dateInsert>l.dateLien,l.dateInsert,l.dateLien),l.dateUpdate,IF(l.dateInsert>l.dateLien,l.dateInsert,l.dateLien)) AS dateLien, '.
|
2012-09-04 09:13:20 +00:00
|
|
|
'e.id, CONCAT(e.siren,e.nic) AS siret, e.siren, e.nic, e.siege, e.raisonSociale, e.sigle, e.enseigne, '.
|
|
|
|
'e.adr_num, e.adr_typeVoie, e.adr_libVoie, e.adr_comp, e.adr_cp, e.adr_ville, e.tel, e.fax, e.cj, e.actif, e.ape_etab, e.ape_entrep ' .
|
2011-07-15 09:20:41 +00:00
|
|
|
'FROM liens l, etablissements e '.
|
2012-04-26 10:30:34 +00:00
|
|
|
'WHERE l.Siren1=e.siren AND e.siege=1 AND l.id IN(';
|
2011-08-17 20:41:42 +00:00
|
|
|
$i = 0;
|
2012-06-06 13:33:29 +00:00
|
|
|
|
|
|
|
//file_put_contents('test.log', print_r($sphinxreturn['matches'],1));
|
|
|
|
|
2011-07-15 09:20:41 +00:00
|
|
|
foreach($sphinxreturn['matches'] as $id => $element) {
|
2012-04-26 10:30:34 +00:00
|
|
|
if($i > 0) $requette.= ',';
|
|
|
|
$requette.= $element['id'];
|
2011-07-15 09:20:41 +00:00
|
|
|
$i++;
|
|
|
|
}
|
2012-04-24 12:51:07 +00:00
|
|
|
$requette.= ') GROUP BY l.Siren1, l.id ORDER BY e.actif DESC, e.siege DESC, e.id ASC';
|
2012-06-06 13:33:29 +00:00
|
|
|
|
2012-04-26 10:30:34 +00:00
|
|
|
//file_put_contents('test.log', $requette."\n", FILE_APPEND);
|
2012-06-06 13:33:29 +00:00
|
|
|
|
|
|
|
$req = $gDatabaseJO->query($requette);
|
|
|
|
|
2013-01-04 17:36:17 +00:00
|
|
|
|
2012-09-04 09:13:20 +00:00
|
|
|
/*$requette2 ='SELECT id, CONCAT(siren,nic) AS siret, siren, nic, siege, '.
|
2011-07-15 09:20:41 +00:00
|
|
|
'raisonSociale, sigle, enseigne, adr_num, adr_typeVoie, adr_libVoie, '.
|
|
|
|
'adr_comp, adr_cp, adr_ville, tel, fax, cj, actif, ape_etab, '.
|
2012-04-26 10:30:34 +00:00
|
|
|
'ape_entrep FROM etablissements WHERE id IN (';
|
2012-09-04 09:13:20 +00:00
|
|
|
*/
|
2011-07-15 09:20:41 +00:00
|
|
|
$ligneAct = array();
|
|
|
|
for($i = 0; $i < $req->num_rows; $i++) {
|
2012-06-06 13:33:29 +00:00
|
|
|
$ligne = $req->fetch_assoc();
|
2012-04-26 10:30:34 +00:00
|
|
|
|
|
|
|
//file_put_contents('test.log', print_r($ligne,1)."\n", FILE_APPEND);
|
2012-06-06 13:33:29 +00:00
|
|
|
|
|
|
|
$ligneAct[$i] = array(
|
2012-04-26 10:30:34 +00:00
|
|
|
'id' => $ligne['id'],
|
|
|
|
'ActNomRs' => $ligne['RaisonSociale'],
|
|
|
|
'ActPays' => $ligne['Pays'],
|
|
|
|
'ActDateLien'=>$ligne['dateLien'],
|
|
|
|
'ActActif' => $ligne['actif'],
|
|
|
|
'ActPmin' => $ligne['Pmin'],
|
|
|
|
);
|
|
|
|
if($i > 0) $requette2.= ',';
|
2012-09-04 09:13:20 +00:00
|
|
|
//$requette2.= $ligne['id'];
|
2011-07-15 09:20:41 +00:00
|
|
|
}
|
2012-09-04 09:13:20 +00:00
|
|
|
//$requette2.= ') ORDER BY actif DESC, siege DESC';
|
2012-06-06 13:33:29 +00:00
|
|
|
|
2012-04-26 10:30:34 +00:00
|
|
|
//file_put_contents('test.log', $requette2."\n", FILE_APPEND);
|
2012-06-06 13:33:29 +00:00
|
|
|
|
2012-09-04 09:13:20 +00:00
|
|
|
//$req = $gDatabaseJO->query($requette2);
|
2012-06-06 13:33:29 +00:00
|
|
|
|
2011-07-15 09:20:41 +00:00
|
|
|
return reponse($sphinxreturn, $req, $criteres, $sphinxreturn['time'], $formR, $form2crit, $deb, $ligneAct);
|
2010-11-04 11:21:31 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// --------------------------------------------------------------------------- //
|
|
|
|
// Recherche entreprise
|
|
|
|
// --------------------------------------------------------------------------- //
|
|
|
|
function rechercheEnt(&$formR, $deb, $nbRep, $max, $sirenValide = false)
|
|
|
|
{
|
2011-06-21 15:59:12 +00:00
|
|
|
$gDatabaseJO = databaseJO();
|
2010-11-04 11:21:31 +00:00
|
|
|
|
|
|
|
// Duree totale
|
|
|
|
$total_time = 0;
|
|
|
|
|
|
|
|
$sphinx = clientSphinx($formR);
|
|
|
|
if ($sphinx == false) {
|
|
|
|
return array('nbReponses' => 0,
|
|
|
|
'nbReponsesTotal' => 0,
|
|
|
|
'duree' => $total_time,
|
|
|
|
'erreur' => 'Formulaire vide');
|
|
|
|
}
|
|
|
|
|
|
|
|
$criteresSphinx = array(
|
|
|
|
//'siret' => '@siren',
|
|
|
|
'raisonSociale' => '@nom',
|
|
|
|
//'numVoie' => '@adr_num',
|
|
|
|
//'voie' => '@(adr_typeVoie,adresse)',
|
|
|
|
'voie' => '@adresse',
|
|
|
|
//'cpVille' => '@(adr_dep,adr_cp,ville)',
|
|
|
|
'ville' => '@ville',
|
|
|
|
'telFax' => '@(tel,fax)',
|
|
|
|
'naf' => '@ape_etab');
|
|
|
|
|
|
|
|
$form2crit = array('siret' => 'I',
|
|
|
|
'telFax' => 'T',
|
|
|
|
'raisonSociale' => 'S',
|
|
|
|
'enseigne' => 'E',
|
|
|
|
'prenom' => 'P',
|
|
|
|
'departement' => 'D',
|
|
|
|
'localite' => 'L',
|
|
|
|
'ville' => 'V',
|
|
|
|
'numVoie' => 'N',
|
|
|
|
'voie' => 'R');
|
|
|
|
|
|
|
|
filtreCaracteresSpeciaux($formR);
|
|
|
|
|
|
|
|
// Quorum
|
|
|
|
$quorum_actif = false;
|
|
|
|
$quorum = array();
|
|
|
|
|
|
|
|
// Premiere requete sans la gestion des mots non significatifs
|
|
|
|
// et avec concatenation de tous les mots de la raison sociale
|
|
|
|
$index = 'ent';
|
|
|
|
$mode = SPH_MATCH_EXTENDED2;
|
|
|
|
$pass = 0;
|
|
|
|
$criteres = 'ITSEPDLVNR';
|
|
|
|
initSphinx($sphinx, $mode, $pass, $deb, $nbRep, $max);
|
|
|
|
$resSphinx = premiereRequeteSphinx($sphinx, $index, $formR, $criteres,
|
|
|
|
$criteresSphinx, $form2crit,
|
|
|
|
$sirenValide);
|
|
|
|
afficheStatusSphinx($sphinx, $resSphinx);
|
|
|
|
if ($resSphinx == false) {
|
|
|
|
return array('nbReponses' => 0,
|
|
|
|
'nbReponsesTotal' => 0,
|
|
|
|
'duree' => $total_time,
|
|
|
|
'erreur' => $sphinx->GetLastError(),
|
|
|
|
'pass' => $pass,
|
|
|
|
'criteres' => $criteres);
|
|
|
|
}
|
|
|
|
$total_time += $resSphinx['time'];
|
|
|
|
if ($resSphinx['total'] == 0) {
|
|
|
|
debugln('Sans la gestion des mots non significatifs');
|
|
|
|
debugln();
|
|
|
|
$resSphinx = requeteSphinx($sphinx, $index, $formR, $criteres,
|
|
|
|
$criteresSphinx, $form2crit,
|
|
|
|
false, $quorum, $sirenValide);
|
|
|
|
afficheStatusSphinx($sphinx, $resSphinx);
|
|
|
|
if ($resSphinx == false) {
|
|
|
|
return array('nbReponses' => 0,
|
|
|
|
'nbReponsesTotal' => 0,
|
|
|
|
'duree' => $total_time,
|
|
|
|
'erreur' => $sphinx->GetLastError(),
|
|
|
|
'pass' => $pass,
|
|
|
|
'criteres' => $criteres);
|
|
|
|
}
|
|
|
|
$total_time += $resSphinx['time'];
|
|
|
|
}
|
|
|
|
if ($resSphinx['total'] == 0 && isset($formR['departement']) == true) {
|
2012-09-04 09:13:20 +00:00
|
|
|
debugln('Sans la gestion des mots non significatifs et sans la localité');
|
2010-11-04 11:21:31 +00:00
|
|
|
debugln();
|
|
|
|
$criteres = 'ITSEPD VNR';
|
|
|
|
$sphinx->resetFilters();
|
|
|
|
$resSphinx = requeteSphinx($sphinx, $index, $formR, $criteres,
|
|
|
|
$criteresSphinx, $form2crit,
|
|
|
|
false, $quorum, $sirenValide);
|
|
|
|
afficheStatusSphinx($sphinx, $resSphinx);
|
|
|
|
if ($resSphinx == false) {
|
|
|
|
return array('nbReponses' => 0,
|
|
|
|
'nbReponsesTotal' => 0,
|
|
|
|
'duree' => $total_time,
|
|
|
|
'erreur' => $sphinx->GetLastError(),
|
|
|
|
'pass' => $pass,
|
|
|
|
'criteres' => $criteres);
|
|
|
|
}
|
|
|
|
$total_time += $resSphinx['time'];
|
|
|
|
$criteres = 'ITSEPDLVNR';
|
|
|
|
}
|
|
|
|
$total_premiere_requete = $resSphinx['total'];
|
2013-01-04 17:36:17 +00:00
|
|
|
|
|
|
|
|
2010-11-04 11:21:31 +00:00
|
|
|
if ($total_premiere_requete == 0 ||
|
|
|
|
$total_premiere_requete > 500) { // "huit a huit" donne 414
|
|
|
|
$index = 'ent_mns';
|
|
|
|
|
|
|
|
// Requete sans les mots non significatifs
|
|
|
|
// pour connaitre le nombre de mots trouves pour chaque champ alpha
|
2012-09-04 09:13:20 +00:00
|
|
|
debugln('Avec la gestion des mots non significatifs et avec quorum si l\'adresse est complete');
|
2010-11-04 11:21:31 +00:00
|
|
|
$raisonSociale = $formR['raisonSociale'];
|
|
|
|
if ((empty($formR['ville']) == false ||
|
|
|
|
empty($formR['departement']) == false) &&
|
|
|
|
empty($formR['numVoie']) == false &&
|
|
|
|
empty($formR['voie']) == false) {
|
|
|
|
$quorum = array('raisonSociale' => 2);
|
|
|
|
$quorum_actif = true;
|
|
|
|
}
|
|
|
|
$resSphinx = requeteSphinx($sphinx, $index, $formR, $criteres,
|
|
|
|
$criteresSphinx, $form2crit,
|
|
|
|
$quorum_actif, $quorum, $sirenValide);
|
|
|
|
afficheStatusSphinx($sphinx, $resSphinx);
|
|
|
|
if ($resSphinx == false) {
|
|
|
|
return array('nbReponses' => 0,
|
|
|
|
'nbReponsesTotal' => 0,
|
|
|
|
'duree' => $total_time,
|
|
|
|
'erreur' => $sphinx->GetLastError(),
|
|
|
|
'pass' => $pass,
|
|
|
|
'criteres' => $criteres);
|
|
|
|
}
|
|
|
|
$total_time += $resSphinx['time'];
|
|
|
|
$quorum_actif = false;
|
|
|
|
$quorum = array();
|
|
|
|
$formR['raisonSociale'] = $raisonSociale;
|
|
|
|
if ($resSphinx['total'] == 0) {
|
|
|
|
$pass = 1;
|
|
|
|
$criteres = 'ITSEPDLVNR';
|
|
|
|
initSphinx($sphinx, $mode, $pass, $deb, $nbRep, $max);
|
|
|
|
// Nombre de mots pour le quorum
|
|
|
|
if (isset($formR['raisonSociale']) == true) {
|
|
|
|
$quorum['raisonSociale'] = nombreDeMots($resSphinx,
|
|
|
|
$formR['raisonSociale']);
|
|
|
|
}
|
|
|
|
if (isset($formR['voie']) == true) {
|
|
|
|
$quorum['voie'] = nombreDeMots($resSphinx,
|
|
|
|
$formR['voie']);
|
|
|
|
}
|
|
|
|
if (isset($formR['ville']) == true) {
|
|
|
|
$quorum['ville'] = nombreDeMots($resSphinx,
|
|
|
|
$formR['ville']);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
while ($pass > 0) {
|
2013-01-04 17:36:17 +00:00
|
|
|
filtreSiege($formR, $criteres, $sphinx);
|
|
|
|
filtreActif($formR, $criteres, $sphinx);
|
2010-11-04 11:21:31 +00:00
|
|
|
// Requete Sphinx
|
|
|
|
$resSphinx = requeteSphinx($sphinx, $index, $formR, $criteres,
|
|
|
|
$criteresSphinx, $form2crit,
|
|
|
|
$quorum_actif, $quorum, $sirenValide);
|
|
|
|
afficheStatusSphinx($sphinx, $resSphinx);
|
|
|
|
if ($resSphinx == false) {
|
|
|
|
return array('nbReponses' => 0,
|
|
|
|
'nbReponsesTotal' => 0,
|
|
|
|
'duree' => $total_time,
|
|
|
|
'erreur' => $sphinx->GetLastError(),
|
|
|
|
'pass' => $pass,
|
|
|
|
'criteres' => $criteres);
|
|
|
|
}
|
|
|
|
$total_time += $resSphinx['time'];
|
|
|
|
if ($resSphinx['total'] > 0 &&
|
|
|
|
($total_premiere_requete == 0 ||
|
|
|
|
$total_premiere_requete >= $resSphinx['total'])) {
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (isset($sequence) == false) {
|
|
|
|
// Criteres de depart
|
|
|
|
$criteres = criteresDeDepart($formR, $form2crit);
|
|
|
|
debugln("criteres de depart='$criteres'");
|
|
|
|
|
|
|
|
// Sequence
|
|
|
|
$sequence = nouvelleSequence($criteres);
|
|
|
|
if ($sequence == array()) {
|
|
|
|
debugln('fin des sequences');
|
|
|
|
if (changePass($pass, $mode, $index,
|
|
|
|
$quorum_actif, $formR) == true) {
|
|
|
|
$criteres = 'ITSEPDLVNR';
|
|
|
|
initSphinx($sphinx, $mode, $pass, $deb, $nbRep, $max);
|
|
|
|
$sequencePos = 0;
|
|
|
|
continue;
|
|
|
|
} else {
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
$sequencePos = 0;
|
|
|
|
if (DEBUG) {
|
|
|
|
print "sequence='";
|
|
|
|
foreach ($sequence as $valeur) {
|
|
|
|
print $valeur.' ';
|
|
|
|
}
|
|
|
|
println("'");
|
|
|
|
}
|
|
|
|
|
|
|
|
// Pour les nouveaux criteres
|
|
|
|
if (LOCAL) {
|
|
|
|
$comb2crit = file('comb2crit.txt');
|
|
|
|
} else {
|
2010-11-30 14:00:21 +00:00
|
|
|
$comb2crit = file(realpath(dirname(__FILE__)).'/comb2crit.txt');
|
2010-11-04 11:21:31 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// Combinaison
|
2012-09-04 09:13:20 +00:00
|
|
|
$combinaison = nouvelleCombinaison($sequence, $sequencePos, $pass, $index, $mode);
|
2010-11-04 11:21:31 +00:00
|
|
|
if ($combinaison == '') {
|
|
|
|
debugln('fin des combinaisons');
|
|
|
|
if (changePass($pass, $mode, $index,
|
|
|
|
$quorum_actif, $formR) == true) {
|
|
|
|
$criteres = 'ITSEPDLVNR';
|
|
|
|
initSphinx($sphinx, $mode, $pass, $deb, $nbRep, $max);
|
|
|
|
$sequencePos = 0;
|
|
|
|
continue;
|
|
|
|
} else {
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
debugln("combinaison='$combinaison'");
|
|
|
|
if (strlen($combinaison) == 3) {
|
|
|
|
$combinaison = substr($combinaison, 0, 2);
|
|
|
|
}
|
|
|
|
|
|
|
|
// Nouveaux criteres
|
|
|
|
$criteres = nouveauxCriteres($comb2crit, $combinaison);
|
|
|
|
if ($criteres == '') {
|
|
|
|
debugln("combinaison inconnue: '$combinaison'");
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
debugln("nouveau criteres='$criteres'");
|
|
|
|
|
|
|
|
$sphinx->SetMatchMode($mode);
|
|
|
|
$sphinx->resetFilters();
|
|
|
|
}
|
|
|
|
$resSphinx['pass'] = $pass;
|
|
|
|
|
|
|
|
// Reprise de la premiere requete si elle etait meilleure
|
|
|
|
if ($pass > 0 &&
|
|
|
|
$total_premiere_requete > 0 &&
|
|
|
|
$total_premiere_requete < $resSphinx['total']) {
|
|
|
|
$index = 'ent';
|
|
|
|
$mode = SPH_MATCH_EXTENDED2;
|
|
|
|
$pass = 0;
|
|
|
|
$criteres = 'ITSEPDLVNR';
|
|
|
|
initSphinx($sphinx, $mode, $pass, $deb, $nbRep, $max);
|
|
|
|
$resSphinx = premiereRequeteSphinx($sphinx, $index, $formR, $criteres,
|
|
|
|
$criteresSphinx, $form2crit,
|
|
|
|
$sirenValide);
|
|
|
|
$total_time += $resSphinx['time'];
|
|
|
|
// Sans la gestion des mots non significatifs
|
|
|
|
if ($resSphinx['total'] == 0) {
|
|
|
|
$resSphinx = requeteSphinx($sphinx, $index, $formR, $criteres,
|
|
|
|
$criteresSphinx, $form2crit,
|
|
|
|
false, $quorum, $sirenValide);
|
|
|
|
$total_time += $resSphinx['time'];
|
|
|
|
}
|
|
|
|
// Sans la gestion des mots non significatifs et sans la localité
|
|
|
|
if ($resSphinx['total'] == 0 && isset($formR['departement']) == true) {
|
|
|
|
$criteres = 'ITSEPD VNR';
|
|
|
|
$sphinx->resetFilters();
|
|
|
|
$resSphinx = requeteSphinx($sphinx, $index, $formR, $criteres,
|
|
|
|
$criteresSphinx, $form2crit,
|
|
|
|
false, $quorum, $sirenValide);
|
|
|
|
$total_time += $resSphinx['time'];
|
|
|
|
}
|
|
|
|
$resSphinx['pass'] = $pass;
|
|
|
|
}
|
|
|
|
|
|
|
|
if ($resSphinx['total'] == 0) {
|
|
|
|
return array('nbReponses' => 0,
|
|
|
|
'nbReponsesTotal' => 0,
|
|
|
|
'duree' => $total_time,
|
|
|
|
'pass' => $pass,
|
|
|
|
'criteres' => $criteres);
|
|
|
|
}
|
|
|
|
|
|
|
|
if (DEBUG) {
|
|
|
|
$base2form = array('adr_dep' => 'departement',
|
|
|
|
'adr_cp' => 'localite',
|
|
|
|
'adr_num' => 'numVoie',
|
|
|
|
'adr_libVoie' => 'voie',
|
|
|
|
'adr_comp' => 'voie',
|
|
|
|
'adr_ville' => 'ville',
|
|
|
|
'raisonSociale' => 'raisonSociale',
|
|
|
|
'enseigne' => 'raisonSociale',
|
|
|
|
'sigle' => 'raisonSociale',
|
|
|
|
'identite_pre' => 'raisonSociale');
|
|
|
|
afficheDB($resSphinx, $formR, $form2crit, 'etablissements', $base2form,
|
|
|
|
$deb, $nbRep);
|
|
|
|
}
|
|
|
|
|
|
|
|
// Reponse
|
|
|
|
if ($gDatabaseJO == false) {
|
|
|
|
return array('nbReponses' => 0,
|
|
|
|
'nbReponsesTotal' => $resSphinx['total'],
|
|
|
|
'duree' => $total_time,
|
|
|
|
'erreur' => 'Base inaccessible');
|
|
|
|
}
|
|
|
|
if (isset($resSphinx['matches']) == false) {
|
|
|
|
return array('nbReponses' => 0,
|
|
|
|
'nbReponsesTotal' => $resSphinx['total'],
|
|
|
|
'duree' => $total_time,
|
|
|
|
'erreur' => 'Aucun résultat');
|
|
|
|
}
|
|
|
|
$requeteDB = 'select id, CONCAT(siren,nic) AS siret, siren, nic, siege, '.
|
|
|
|
'raisonSociale, sigle, enseigne, adr_num, adr_typeVoie, adr_libVoie, '.
|
|
|
|
'adr_comp, adr_cp, adr_ville, tel, fax, cj, actif, ape_etab, '.
|
2011-03-25 16:18:01 +00:00
|
|
|
'ape_entrep, (siren>200) AS sirenValide'.
|
2010-11-04 11:21:31 +00:00
|
|
|
' from etablissements where id='.$resSphinx['matches'][0]['id'];
|
|
|
|
for ($i = 1; $i + $deb < $resSphinx['total'] && $i < $nbRep; ++$i) {
|
|
|
|
$requeteDB .= ' or id='.$resSphinx['matches'][$i]['id'];
|
|
|
|
}
|
2012-06-10 17:38:53 +00:00
|
|
|
$requeteDB .= ' ORDER BY sirenValide DESC, actif DESC, siege DESC, rang DESC';
|
2010-11-04 11:21:31 +00:00
|
|
|
|
|
|
|
debugln();
|
|
|
|
debugln("requeteDB='$requeteDB'");
|
|
|
|
$resDB = $gDatabaseJO->query($requeteDB);
|
|
|
|
|
|
|
|
return reponse($resSphinx, $resDB, $criteres, $total_time, $formR,
|
|
|
|
$form2crit, $deb);
|
|
|
|
}
|
|
|
|
|
|
|
|
// --------------------------------------------------------------------------- //
|
|
|
|
// sommeDeControle
|
|
|
|
// --------------------------------------------------------------------------- //
|
|
|
|
function sommeDeControle($sn)
|
|
|
|
{
|
|
|
|
$s = 0;
|
|
|
|
$n = strlen($sn);
|
|
|
|
for ($i = 0; $i < $n; ++$i) {
|
|
|
|
if ($i & 1) {
|
|
|
|
$t = substr($sn, $n - $i - 1, 1) << 1;
|
|
|
|
$s += ($t > 9)? $t - 9 : $t;
|
|
|
|
} else {
|
|
|
|
$s += substr($sn, $n - $i - 1, 1);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return $s % 10;
|
|
|
|
}
|
|
|
|
|
|
|
|
// --------------------------------------------------------------------------- //
|
|
|
|
// Verification du siret
|
|
|
|
// --------------------------------------------------------------------------- //
|
|
|
|
function verificationDuSiret($siret)
|
|
|
|
{
|
|
|
|
if (strlen($siret) == 14) {
|
|
|
|
$sn = substr($siret, 0, 9);
|
|
|
|
$st = $siret;
|
|
|
|
} else if (strlen($siret) == 9) {
|
|
|
|
$sn = $siret;
|
|
|
|
$st = 0;
|
|
|
|
} else {
|
|
|
|
// TODO: message d'erreur et/ou correction
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
// Verification du siren
|
|
|
|
$s = sommeDeControle($sn);
|
|
|
|
if ($s != 0) {
|
|
|
|
// Correction du chiffre de controle
|
|
|
|
$sr = (substr($sn, 8, 1) - $s + 10) % 10;
|
|
|
|
$liste = array(substr($sn, 0, 8).$sr);
|
|
|
|
// Transpositions
|
|
|
|
for ($i = 0; $i < 8; ++$i) {
|
|
|
|
$n1 = substr($sn, $i, 1);
|
|
|
|
$n2 = substr($sn, $i + 1, 1);
|
|
|
|
if ($n1 == $n2) {
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
$p = '';
|
|
|
|
if ($i > 0) {
|
|
|
|
$p .= substr($sn, 0, $i);
|
|
|
|
}
|
|
|
|
$p .= $n2;
|
|
|
|
if ($i < 7) {
|
|
|
|
$p .= $n1;
|
|
|
|
}
|
|
|
|
if ($i < 6) {
|
|
|
|
$p .= substr($sn, $i + 2, 6 - $i);
|
|
|
|
}
|
|
|
|
if ($i & 1) {
|
|
|
|
if ($i < 7) {
|
|
|
|
if ($n1 >= 5) { $n1 -= 9; }
|
|
|
|
if ($n2 >= 5) { $n2 -= 9; }
|
|
|
|
} else {
|
|
|
|
$n1 = ($n1 >= 5) ? ($n1 << 1) - 9 : ($n1 << 1);
|
|
|
|
$n2 = ($n2 >= 5) ? ($n2 << 1) - 9 : ($n2 << 1);
|
|
|
|
}
|
|
|
|
$p .= ($sr + $n1 - $n2 + 10) % 10;
|
|
|
|
} else {
|
|
|
|
if ($n2 >= 5) { $n2 -= 9; }
|
|
|
|
if ($n1 >= 5) { $n1 -= 9; }
|
|
|
|
$p .= ($sr + $n2 - $n1 + 10) % 10;
|
|
|
|
}
|
|
|
|
$liste[] = $p;
|
|
|
|
}
|
|
|
|
// Substitutions
|
|
|
|
for ($i = 0; $i < 8; ++$i) {
|
|
|
|
$n = substr($sn, $i, 1);
|
|
|
|
for ($j = 0; $j < 10; ++$j) {
|
|
|
|
if ($j == $n) {
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
$p = '';
|
|
|
|
if ($i > 0) {
|
|
|
|
$p .= substr($sn, 0, $i);
|
|
|
|
}
|
|
|
|
$p .= $j;
|
|
|
|
if ($i < 7) {
|
|
|
|
$p .= substr($sn, $i + 1, 7 - $i);
|
|
|
|
}
|
|
|
|
if ($i & 1) {
|
|
|
|
$n1 = ($n << 1); if ($n1 > 9) { $n1 -= 9; }
|
|
|
|
$n2 = ($j << 1); if ($n2 > 9) { $n2 -= 9; }
|
|
|
|
$p .= ($sr + $n1 - $n2 + 10) % 10;
|
|
|
|
} else {
|
|
|
|
$p .= ($sr + $n - $j + 10) % 10;
|
|
|
|
}
|
|
|
|
$liste[] = $p;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return $liste;
|
|
|
|
}
|
|
|
|
if ($st == 0) {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
// Verification du siret
|
|
|
|
if (sommeDeControle($st) != 0) {
|
|
|
|
return array($sn);
|
|
|
|
}
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
// --------------------------------------------------------------------------- //
|
|
|
|
// Recherche
|
|
|
|
// --------------------------------------------------------------------------- //
|
|
|
|
function recherche(&$formR, $deb = 0, $nbRep = 20, $max = 1000)
|
|
|
|
{
|
|
|
|
if ($formR['type'] == 'ent') {
|
|
|
|
return rechercheEnt($formR, $deb, $nbRep, $max);
|
|
|
|
} else if ($formR['type'] == 'dir') {
|
|
|
|
return rechercheDir($formR, $deb, $nbRep, $max);
|
2011-06-10 10:08:21 +00:00
|
|
|
} else if ($formR['type'] == 'act') {
|
|
|
|
return rechercheAct($formR, $deb, $nbRep, $max);
|
2010-11-04 11:21:31 +00:00
|
|
|
} else {
|
|
|
|
debugln('Type de recherche inconnu');
|
|
|
|
return array('nbReponses' => 0,
|
|
|
|
'nbReponsesTotal' => 0,
|
|
|
|
'duree' => 0,
|
|
|
|
'erreur' => 'Type de recherche inconnu');
|
|
|
|
}
|
|
|
|
}
|
|
|
|
?>
|