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 ( ' ' => '' , '–' => '' )));
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> ' , " javascript:SiteURL(' " , " ',' " )));
$res [ 'urlMail' ] = trim ( htm2txt ( @ getTextInHtml ( $body , '<b>E-mail :</b>' , " &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 ( ' ' => '' , '<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
}