295 lines
9.6 KiB
PHP
Raw Normal View History

2014-04-03 15:28:00 +00:00
<?php
2014-10-06 19:39:52 +00:00
require_once 'framework/common/mysql.php';
require_once 'framework/common/curl.php';
require_once 'framework/common/strings.php';
2014-04-03 15:28:00 +00:00
class MTel
{
2013-06-19 09:45:13 +00:00
public $body = '';
public $header = '';
public $codeRetour = 0;
public $cookie='';
public $urlBase='http://www.pagespro.com/recherche.php';
public $url='';
public $referer='';
public $enCache=false;
private $accesDistant=false;
public $iDb;
2014-05-02 13:00:07 +00:00
public function __construct($accesDistant=false, $db=null)
2014-04-03 15:28:00 +00:00
{
2013-06-19 09:45:13 +00:00
$this->accesDistant=$accesDistant;
$this->accesDistant=false; // Accès bloqué par "pagespro"
if ($this->accesDistant) {
$this->url=$this->urlBase;
$page=getUrl($this->url,$this->cookie,'',$this->referer, false, '', '', 3);
$this->referer=$this->url;
$this->cookie=$page['header']['Set-Cookie'];
$this->body=$page['body'];
$this->codeRetour=$page['code'];
}
2014-05-02 13:00:07 +00:00
if ( $db === null ) {
2014-06-02 12:12:51 +00:00
$this->iDb = new WDB();
2014-05-02 13:00:07 +00:00
} else {
$this->iDb = $db;
}
2013-06-19 09:45:13 +00:00
}
/**
2014-04-03 15:28:00 +00:00
* Information contact
* @param string $siret
* @param string $nic
2014-05-02 13:00:07 +00:00
* @param boolean $last
* @param int $actif
* @return array Retourne une liste de téléphone
2013-06-19 09:45:13 +00:00
*/
2014-05-02 13:00:07 +00:00
public function getTel($siret, $nic=0, $last=false, $actif=null)
2014-04-03 15:28:00 +00:00
{
2013-06-19 09:45:13 +00:00
$tabRet=array();
if (strlen($siret)>9) {
2014-04-03 15:28:00 +00:00
$nic = substr($siret,-5)*1;
$siren = round($siret/100000)*1;
} else {
2013-06-19 09:45:13 +00:00
$siren=$siret*1;
2014-04-03 15:28:00 +00:00
}
2013-06-19 09:45:13 +00:00
2014-05-02 13:00:07 +00:00
if ($siren<1000) return $tabRet;
2014-04-03 15:28:00 +00:00
/** Si le siren est de taille < à 9, on ajoute des 0 significatifs **/
2013-06-19 09:45:13 +00:00
if (strlen($siren)<=9) {
2014-04-03 15:28:00 +00:00
$siren = str_pad($siren, 9, '0', STR_PAD_LEFT);
2013-06-19 09:45:13 +00:00
}
if (strlen($nic)>0) {
2014-04-03 15:28:00 +00:00
$nic = str_pad($nic, 5, '0', STR_PAD_LEFT);
2013-06-19 09:45:13 +00:00
}
$strNic='';
if ($nic*1>0) $strNic="AND (nic=$nic OR nic=0)";
2014-05-02 13:00:07 +00:00
$strActif='';
if ($actif==1) $strActif=" AND actif=1 ";
elseif($actif==0) $strActif=" AND actif=0 ";
$ret=$this->iDb->select(
2014-04-03 15:28:00 +00:00
'telephonie',
2014-05-02 13:00:07 +00:00
'siren,nic,dateProvPartenaire,typeTel,infoTel,LPAD(telephone,10,0) AS telephone,actif,partenaire,idUtilisateur,dateInsert,dateInsert*1 AS dateInsertYmd,dateConfPartenaire,partenaireConf,nbConf,idUpdate,dateUpdate,dateUpdate*1 AS dateUpdateYmd',
"siren=$siren $strNic $strActif AND dateSuppr=0 ORDER BY typeTel ASC, nbConf DESC", false, MYSQL_ASSOC);
2014-10-14 15:46:10 +00:00
if (count($ret)>0)
{
2013-06-19 09:45:13 +00:00
$this->enCache=true;
2014-04-03 15:28:00 +00:00
foreach ($ret as $tabTel)
{
2013-06-19 09:45:13 +00:00
if ($tabTel['typeTel']=='an8' && $tabTel['infoTel']*1>0) {
$an8=$tabTel['infoTel']*1;
$retTmp=$this->iDb->select('tabAn8', 'libAn8', "codAn8='$an8'", false, MYSQL_ASSOC);
$infoTel=ucfirst(strtolower($retTmp[0]['libAn8']));
2014-04-03 15:28:00 +00:00
} else {
2013-06-19 09:45:13 +00:00
$infoTel=$tabTel['infoTel'];
2014-04-03 15:28:00 +00:00
}
2014-05-02 13:00:07 +00:00
if ($tabTel['partenaireConf']>0) $source=$tabTel['partenaireConf'];
else $source=$tabTel['partenaire'];
if ($tabTel['dateUpdateYmd']>$tabTel['dateInsertYmd']) $dateMAJ=$tabTel['dateUpdateYmd'];
else $dateMAJ=$tabTel['dateInsertYmd'];
$tabR = array(
'siren'=>$siren,
'nic'=>$tabTel['nic'],
'typeTel'=>$tabTel['typeTel'],
'infoTel'=>$infoTel,
'telephone'=>$tabTel['telephone'],
'actif'=>$tabTel['actif'],
'source'=>$source,
'dateMAJ'=>$dateMAJ,
);
$tabRet[]=$tabR;
if ($last) {
if ($source==175 && !@isset($tabLast[$tabTel['typeTel']][1])) @$tabLast[$tabTel['typeTel']][1]=$tabR;
elseif(($source==118 ||
$source==250 ||
$source==253) && !@isset($tabLast[$tabTel['typeTel']][2])) @$tabLast[$tabTel['typeTel']][2]=$tabR;
elseif ($source<>2 && !@isset($tabLast[$tabTel['typeTel']][3])) @$tabLast[$tabTel['typeTel']][3]=$tabR;
elseif ($source==2 && !@isset($tabLast[$tabTel['typeTel']][4])) @$tabLast[$tabTel['typeTel']][4]=$tabR;
}
2013-06-19 09:45:13 +00:00
}
2014-04-03 15:28:00 +00:00
2014-10-14 15:46:10 +00:00
}
elseif ($this->accesDistant)
{
2014-05-02 13:00:07 +00:00
$this->enCache=false;
$tabPost = array(
2014-04-03 15:28:00 +00:00
'p_ACTION'=>'',
'p_ORDRE'=>'AfficheRes',
'a_PAGE'=>'1',
'a_TAG'=>'',
'a_OccRecherche'=>'',
'typeRecherche'=>'express',
'satellite'=>'siret',
'a_activ'=>'',
'a_rai_soc'=>'',
'a_naf'=>'',
'a_siren'=>$siret,
'a_tel'=>'',
'a_geo'=>'',
'typeTri'=>'',
'ordreTri'=>'',
'a_session'=>'',
);
2013-06-19 09:45:13 +00:00
//$page=getUrl($this->url,$this->cookie,'',$this->referer, false, '', '', 3);
$page=getUrl($this->url,$this->cookie,$tabPost,$this->referer,false,'','',3);
$this->referer=$this->url;
$this->body=$page['body'];
$this->codeRetour=$page['code'];
$nbResults=0;
2014-04-03 15:28:00 +00:00
if (preg_match('/<b class="total_responses_nr">(.*)réponses<\/b>/Uisu', $this->body, $matches))
2013-06-19 09:45:13 +00:00
$nbResults=trim(strtr(strip_tags($matches[1]), array('&nbsp;'=>'','&ndash;'=>'')));
if ($nbResults>0) {
$tabResultsHtml=explode('<div class="results_part1">', $this->body);
for ($i=1; isset($tabResultsHtml[$i]);$i++) {
$res=$tabTel=array();
$body=$tabResultsHtml[$i];
$res['nom']=trim(htm2txt(@getTextInHtml($body, '<div class="results_title">', '_title">', '</div>')));
$res['adresse']=trim(htm2txt(@getTextInHtml($body, '<div class="coordonnees">','<div>','<table id="t_coord_')));
$res['urlSite']=trim(htm2txt(@getTextInHtml($body, '<b class="siteweb">Site Web :</b>&nbsp;', "javascript:SiteURL('", "','")));
$res['urlMail']=trim(htm2txt(@getTextInHtml($body, '<b>E-mail :</b>', "&amp;mail=", "', ")));
$res['urlLogo']=trim(htm2txt(@getTextInHtml($body, '<div class="results_inset_logo">', '" src="', '" border="')));
$res['tefet']=trim(htm2txt(@getTextInHtml($body, '<b>Effectif établ : </b>','</b>','</div>')));
$res['tefet']=trim(htm2txt(@getTextInHtml($body, '<b>Effectif établ : </b>','</b>','</div>')));
$res['siret']=trim(htm2txt(@getTextInHtml($body, '<b>Siret : </b>','</b>','</div>')));
$res['nafet']=trim(htm2txt(strip_tags(@getTextInHtml($body, '<b>Code NAF : </b>','</b>','</div>'))));
$res['domaines']=trim(preg_replace('/ +/', ' ', preg_replace('/\r+|\n+|\s+/',' ',htm2txt(strip_tags(@getTextInHtml($body, '<div class="puce_domaine">','<strong>','</div>'))))));
if ($res['urlSite']<>'') {
2014-04-03 15:28:00 +00:00
$this->iDb->insert('telephonie', array(
'siren'=>$siren,
'nic'=>substr($res['siret'],-5),
'dateProvPartenaire'=>date('Ymd'),
'typeTel'=>'web',
'infoTel'=>$res['urlSite'],
'telephone'=>0,
'actif'=>1,
'partenaire'=>253,
));
$tabRet[] = array(
'siren'=>$siren,
'nic'=>substr($res['siret'],-5),
'typeTel'=>'web',
'infoTel'=>$res['urlSite'],
'telephone'=>0,
);
2013-06-19 09:45:13 +00:00
}
if ($res['urlLogo']<>'') {
2014-04-03 15:28:00 +00:00
$this->iDb->insert('telephonie', array(
'siren'=>$siren,
'nic'=>substr($res['siret'],-5),
'dateProvPartenaire'=>date('Ymd'),
'typeTel'=>'logo',
'infoTel'=>$res['urlLogo'],
'telephone'=>0,
'actif'=>1,
'partenaire'=>253,
));
$tabRet[] = array(
'siren'=>$siren,
'nic'=>substr($res['siret'],-5),
'typeTel'=>'logo',
'infoTel'=>$res['urlLogo'],
'telephone'=>0,
);
2013-06-19 09:45:13 +00:00
}
if ($res['domaines']<>'') {
2014-04-03 15:28:00 +00:00
$this->iDb->insert('telephonie', array(
'siren'=>$siren,
'nic'=>substr($res['siret'],-5),
'dateProvPartenaire'=>date('Ymd'),
'typeTel'=>'domaines',
'infoTel'=>$res['domaines'],
'telephone'=>0,
'actif'=>1,
'partenaire'=>253,
));
$tabRet[]=array(
'siren'=>$siren,
'nic'=>substr($res['siret'],-5),
'typeTel'=>'domaines',
'infoTel'=>$res['domaines'],
'telephone'=>0,
);
2013-06-19 09:45:13 +00:00
}
if ($res['urlMail']<>'') {
2014-04-03 15:28:00 +00:00
$this->iDb->insert('telephonie', array(
'siren'=>$siren,
'nic'=>substr($res['siret'],-5),
'dateProvPartenaire'=>date('Ymd'),
'typeTel'=>'mail',
'infoTel'=>$res['urlMail'],
'telephone'=>0,
'actif'=>1,
'partenaire'=>253,
));
$tabRet[]=array(
'siren'=>$siren,
'nic'=>substr($res['siret'],-5),
'typeTel'=>'mail',
'infoTel'=>$res['urlMail'],
'telephone'=>0,
);
2013-06-19 09:45:13 +00:00
}
2014-10-14 15:46:10 +00:00
if (preg_match_all('/<tr>(?:.*)<th>(?:.*)<span>(.*)(tél|fax)(?:.*)<\/span>(?:.*)<\/th>(?:.*)<td>(?:.*)<span>(.*)<\/span>(?:.*)<\/td>(?:.*)<\/tr>/Uis', $body, $matches))
{
foreach ($matches[2] as $j=>$tmp)
{
2013-06-19 09:45:13 +00:00
$lib=$tmp;
$precis=trim(strtr($matches[1][$j], array('-'=>' ')));
$num=trim(strtr($matches[3][$j],array('&nbsp;'=>'','<br />'=>'')));
$tabTel["$lib-$num"]=array('telFax'=>$lib,'type'=>$precis, 'telNum'=>$num);
}
$tabTel=array_values($tabTel);
2014-10-14 15:46:10 +00:00
foreach ($tabTel as $tabT)
{
2014-04-03 15:28:00 +00:00
$tabRet[]=array(
'siren'=>$siren,
'nic'=>substr($res['siret'],-5),
'typeTel'=>trimAccent($tabT['telFax']),
'infoTel'=>$tabT['type'],
'telephone'=>$tabT['telNum'],
'actif'=>1,
);
$this->iDb->insert('telephonie', array(
'siren'=>$siren,
'nic'=>substr($res['siret'],-5),
'dateProvPartenaire'=>date('Ymd'),
'typeTel'=>trimAccent($tabT['telFax']),
'infoTel'=>$tabT['type'],
'telephone'=>$tabT['telNum'],
'actif'=>1,
'partenaire'=>253,
));
2013-06-19 09:45:13 +00:00
}
}
}
2014-04-03 15:28:00 +00:00
}
2013-06-19 09:45:13 +00:00
}
2014-10-14 15:46:10 +00:00
if ($last)
{
2014-05-02 13:00:07 +00:00
$tabRet=array();
foreach($tabLast as $typeTel=>$tabPriorite) {
ksort($tabPriorite);
$tabRet[]=current($tabPriorite);
}
}
2014-04-03 15:28:00 +00:00
return $tabRet;
2013-06-19 09:45:13 +00:00
}
2014-04-03 15:28:00 +00:00
}