374 lines
11 KiB
PHP
374 lines
11 KiB
PHP
<?php
|
|
session_start();
|
|
if (!$_SESSION['connected']) die();
|
|
|
|
$tabInfo = $_SESSION['tabInfo'];
|
|
|
|
$identifier = $_REQUEST['identifier'];
|
|
$pays = $_SESSION['graydon']['pays'];
|
|
|
|
/*
|
|
getCompanyProduct
|
|
Afficher les informations de getCompanyProduct (Identifiant, Activité, téléphone )
|
|
Si product.type=database alors on récupère un rapport
|
|
on traite suivant le mimetype
|
|
on affiche les informations
|
|
|
|
getCompanyMatchIdentifier
|
|
|
|
*/
|
|
require_once 'graydon/pays.php';
|
|
require_once 'i18n/cleanchar.php';
|
|
require_once 'graydon/graydonws.php';
|
|
|
|
$path = PATH_DATA.'/graydon/method';
|
|
$fileName = strtolower('CompanyMatchIdentifiers-'.$pays);
|
|
|
|
/** Recup des types d'identifiants pour le pays **/
|
|
if(!file_exists($path.'/'.$fileName)){
|
|
//Récupération des intitulés identifiant
|
|
$request = new StdClass();
|
|
$request->Authentication_Parameters = $authentication;
|
|
$request->Country = $pays;
|
|
$firephp->log($request,'requete');
|
|
try
|
|
{
|
|
$result = $graydon->getCompanyMatchIdentifiers($request);
|
|
$firephp->log($result,'Identifier');
|
|
$count = count($result->CompanyMatchIdentifiers);
|
|
if ($count>1){
|
|
$tabIdentifiers = $result->CompanyMatchIdentifiers->CompanyMatchIdentifier;
|
|
}elseif($count==1){
|
|
$tabIdentifiers[] = $result->CompanyMatchIdentifiers->CompanyMatchIdentifier;
|
|
}
|
|
|
|
//Stockage du résultat de la méthode en cache
|
|
file_put_contents($path.'/'.$fileName, serialize($tabIdentifiers));
|
|
|
|
}catch( SoapFault $fault ){
|
|
require_once 'soaperror.php';
|
|
processSoapFault($client,$fault,$tabInfo);
|
|
}
|
|
}else{
|
|
$tabIdentifiers = unserialize(file_get_contents($path.'/'.$fileName));
|
|
}
|
|
|
|
$firephp->log($tabIndentifiers,'tabIndentifiers');
|
|
|
|
|
|
/** Recup des produits de la company **/
|
|
|
|
$path = PATH_DATA.'/graydon';
|
|
$fileName = strtolower('CompanyProducts-'.$identifier);
|
|
$fileName = str_replace(':', '-', $fileName);
|
|
$now = mktime(date('G'), date('i'), date('s'), date("m") , date("d"), date("Y"));
|
|
|
|
$debug = TRUE;
|
|
if(!file_exists($path.'/'.$fileName) || filemtime($path.'/'.$fileName)>$now+16 && $debug){
|
|
// Create the request parameters
|
|
$request = new StdClass();
|
|
// Initialise the request object
|
|
$request->Authentication_Parameters = $authentication;
|
|
$request->CompanyMatchIdentifier = $identifier;
|
|
$firephp->log($request,'requete');
|
|
try
|
|
{
|
|
// Make a request on the web service
|
|
$result = $graydon->getCompanyProducts($request);
|
|
// Print out the result
|
|
print "<!--";
|
|
print "Transaction Identifier : ".$result->Service_Log->TransactionIdentifier;
|
|
print "\n";
|
|
print "Partner User Id : ".$result->Service_Log->PartnerUserId;
|
|
print "\n";
|
|
print_r($result);
|
|
print "-->";
|
|
|
|
$firephp->log($result,'result');
|
|
|
|
file_put_contents($path.'/'.$fileName, serialize($result));
|
|
|
|
}catch( SoapFault $fault ){
|
|
require_once 'soaperror.php';
|
|
processSoapFault($client,$fault,$tabInfo);
|
|
die();
|
|
}
|
|
}else{
|
|
$result = unserialize(file_get_contents($path.'/'.$fileName));
|
|
}
|
|
|
|
|
|
if(isset($result)){
|
|
$firephp->log($result,'result');
|
|
$company = $result->Company;
|
|
$products = $result->Products->Product;
|
|
|
|
?>
|
|
<div id="center">
|
|
|
|
<h1 class="titre">IDENTITÉ INTERNATIONALE DE L'ENTREPRISE</h1>
|
|
|
|
<table >
|
|
<tr>
|
|
<td width="30"> </td>
|
|
<td width="200" class="StyleInfoLib">Fiche identité simplifié<br/></td>
|
|
<td>
|
|
<?php
|
|
$count = count($products);
|
|
if($count==1){
|
|
$products[] = $products;
|
|
}
|
|
$noReport = TRUE;
|
|
?>
|
|
<u><b>Accès à la fiche identité approfondie :</b></u>
|
|
<?php
|
|
$tabReport = array();
|
|
$tabProductIdentifier = array();
|
|
$countProducts = 0;
|
|
foreach($products as $product){
|
|
|
|
//Rapport en mode normal
|
|
if ($product->ServiceSpeed == 'Normal' && $product->Type == 'Investigation' && $product->Level == 4 ){
|
|
$tabReport[$countProducts] = 'Normal';
|
|
$tabProducts[$countProducts]['identifier'] = $product->CompanyProductIdentifier;
|
|
$tabProducts[$countProducts]['DaysFrom'] = $product->DaysFrom;
|
|
$tabProducts[$countProducts]['DaysTo'] = $product->DaysTo;
|
|
$countProducts++;
|
|
}
|
|
|
|
//Rapport en mode normal
|
|
if ($product->ServiceSpeed == 'Superflash' && $product->Type == 'Investigation' && $product->Level == 4 ){
|
|
$tabReport[] = 'Superflash';
|
|
$tabProducts[$countProducts]['identifier'] = $product->CompanyProductIdentifier;
|
|
$tabProducts[$countProducts]['DaysFrom'] = $product->DaysFrom;
|
|
$tabProducts[$countProducts]['DaysTo'] = $product->DaysTo;
|
|
$countProducts++;
|
|
}
|
|
//Rapport disponible avec mise à jour
|
|
if ($product->ServiceSpeed == 'ImmediateWithUpdate' && $product->Type == 'Database' && $product->Level == 3 ){
|
|
$mimetype = FALSE;
|
|
if (is_array($product->MimeTypes->MimeType)){
|
|
if (in_array('xml', $product->MimeTypes->MimeType)){$mimetype = TRUE;}
|
|
}else{
|
|
if ($product->MimeTypes->MimeType == 'xml' ){$mimetype = TRUE;}
|
|
}
|
|
if ($mimetype == TRUE ){
|
|
$tabReport[] = 'ImmediateWithUpdate';
|
|
$tabProducts[$countProducts]['identifier'] = $product->CompanyProductIdentifier;
|
|
$tabProducts[$countProducts]['DaysFrom'] = $product->DaysFrom;
|
|
$tabProducts[$countProducts]['DaysTo'] = $product->DaysTo;
|
|
$countProducts++;
|
|
}
|
|
}
|
|
//Rapport disponible en ligne
|
|
if ($product->ServiceSpeed == 'Immediate' && $product->Type == 'Database' && $product->Level == 3 ){
|
|
$mimetype = FALSE;
|
|
if (is_array($product->MimeTypes->MimeType)){
|
|
if (in_array('xml', $product->MimeTypes->MimeType)){$mimetype = TRUE;}
|
|
}else{
|
|
if ($product->MimeTypes->MimeType == 'xml' ){$mimetype = TRUE;}
|
|
}
|
|
if ($mimetype == TRUE ){
|
|
$tabReport[] = 'Immediate';
|
|
$tabProducts[$countProducts]['identifier'] = $product->CompanyProductIdentifier;
|
|
$countProducts++;
|
|
}
|
|
}
|
|
}
|
|
|
|
|
|
$firephp->log($tabProducts,'tabProducts');
|
|
|
|
if(count($tabReport)==0){
|
|
?>
|
|
(Aucun rapport disponible pour cette société)
|
|
<?php
|
|
}else{
|
|
//Affichage des différents rapports dans l'ordre
|
|
if(in_array('Normal',$tabReport)){
|
|
$key = array_search('Normal', $tabReport);
|
|
$pidentifier = $tabProducts[$key]['identifier'];
|
|
$daysFrom = $tabProducts[$key]['DaysFrom'];
|
|
$daysTo = $tabProducts[$key]['DaysTo'];
|
|
print '<br/><br/>Commander le rapport en mode normal <br/><i>(Délais : '.$daysFrom.' à '.$daysTo.' Jours, Tarif : '.$tabPaysPrix['Normal'][$pays].' €)</i>';
|
|
}
|
|
if(in_array('Superflash',$tabReport)){
|
|
$key = array_search('Superflash', $tabReport);
|
|
$pidentifier = $tabProducts[$key]['identifier'];
|
|
$daysFrom = $tabProducts[$key]['DaysFrom'];
|
|
$daysTo = $tabProducts[$key]['DaysTo'];
|
|
print '<br/><br/>Commander le rapport en mode superflash <br/><i>(Délais : '.$daysFrom.' à '.$daysTo.' Jours, Tarif : '.$tabPaysPrix['Superflash'][$pays].' €)</i>';
|
|
}
|
|
if(in_array('Immediate',$tabReport)){
|
|
$key = array_search('Immediate', $tabReport);
|
|
$pidentifier = $tabProducts[$key]['identifier'];
|
|
print '<br/><br/><a href="./?page=international_identitec&identifier='.$identifier.'&pidentifier='.$pidentifier.'"> Consutler le rapport disponible</a><br/><i>(Délais : Immédiat, Tarif : '.$tabPaysPrix['Immediate'][$pays].' €)</i>';
|
|
}
|
|
}
|
|
?>
|
|
</td>
|
|
</td>
|
|
</tr>
|
|
<tr>
|
|
<td colspan="3"> </td>
|
|
</tr>
|
|
<?php
|
|
$count = count($company->CompanyIdentifiers->CompanyIdentifier);
|
|
if ($count>1){
|
|
$identifiers = $company->CompanyIdentifiers->CompanyIdentifier;
|
|
}elseif($count==1){
|
|
$identifiers[] = $company->CompanyIdentifiers->CompanyIdentifier;
|
|
}
|
|
foreach($identifiers as $identifier){
|
|
if($identifier->Type != 'Internal'){
|
|
?>
|
|
<tr>
|
|
<td width="30"> </td>
|
|
<td width="200" class="StyleInfoLib">
|
|
<?php
|
|
$identifierDescription = FALSE;
|
|
foreach($tabIdentifiers as $tabIdentifier){
|
|
if($tabIdentifier->CompanyMatchIdentifier->CompanyIdentifier->Type == $identifier->Type){
|
|
print $tabIdentifier->CompanyMatchIdentifier->CompanyIdentifier->Description;
|
|
$identifierDescription = TRUE;
|
|
}
|
|
}
|
|
if ($identifierDescription==FALSE){
|
|
print $identifier->Type;
|
|
}
|
|
|
|
//@TODO : Tester si la condition à bien été remplie
|
|
?>
|
|
</td>
|
|
<td width="350" class="StyleInfoData">
|
|
<?php print $identifier->Identifier; ?></td>
|
|
</tr>
|
|
<tr>
|
|
<td colspan="3"> </td>
|
|
</tr>
|
|
<?php
|
|
}
|
|
}
|
|
?>
|
|
</table>
|
|
|
|
<h2>Raison sociale et coordonnées : </h2>
|
|
|
|
<table>
|
|
|
|
<tr>
|
|
<td width="30"> </td>
|
|
<td width="200" class="StyleInfoLib">Raison Sociale</td>
|
|
<td width="350" class="StyleInfoData"><?php print cleanutf8($company->Name); ?></td>
|
|
</tr>
|
|
<tr>
|
|
<td width="30"> </td>
|
|
<td width="200" class="StyleInfoLib">Adresse Complète</td>
|
|
<td width="350" class="StyleInfoData"><?php print cleanutf8($company->RegisteredAddress->EntireAddress); ?></td>
|
|
</tr>
|
|
|
|
<tr>
|
|
<td width="30"> </td>
|
|
<td width="200" class="StyleInfoLib">Adresse</td>
|
|
<td width="350" class="StyleInfoData"><?php print cleanutf8($company->RegisteredAddress->Building.', '.$company->RegisteredAddress->Street); ?></td>
|
|
</tr>
|
|
|
|
<tr>
|
|
<td width="30"> </td>
|
|
<td width="200" class="StyleInfoLib">Code Postal</td>
|
|
<td width="350" class="StyleInfoData"><?php print $company->RegisteredAddress->PostCode; ?></td>
|
|
</tr>
|
|
|
|
<tr>
|
|
<td width="30"> </td>
|
|
<td width="200" class="StyleInfoLib">Ville</td>
|
|
<td width="350" class="StyleInfoData"><?php print cleanutf8($company->RegisteredAddress->City); ?></td>
|
|
</tr>
|
|
|
|
<tr>
|
|
<td width="30"> </td>
|
|
<td width="200" class="StyleInfoLib">Pays</td>
|
|
<td width="350" class="StyleInfoData">
|
|
<?php
|
|
if(isset($company->RegisteredAddress->Country)){
|
|
print $company->RegisteredAddress->Country;
|
|
}else{
|
|
print $pays;
|
|
}
|
|
?>
|
|
</td>
|
|
</tr>
|
|
|
|
<tr>
|
|
<td width="30"> </td>
|
|
<td width="200" class="StyleInfoLib">Téléphone</td>
|
|
<td width="350" class="StyleInfoData"><?php print $company->Telephone; ?></td>
|
|
</tr>
|
|
<tr>
|
|
<td colspan="3"> </td>
|
|
</tr>
|
|
</table>
|
|
|
|
<h2>Activité(s) de l'entreprise : </h2>
|
|
|
|
<table>
|
|
<?php
|
|
$count = count($company->Activites->Activity);
|
|
if ($count>1){
|
|
$activites = $company->Activites->Activity;
|
|
}elseif($count==1){
|
|
$activites[] = $company->Activites->Activity;
|
|
}
|
|
if ($count>0){
|
|
foreach($activites as $activity){
|
|
?>
|
|
<tr>
|
|
<td width="30"> </td>
|
|
<td width="200" class="StyleInfoLib">Code <?php print $activity->Type;?></td>
|
|
<td width="350" class="StyleInfoData"><?php print $activity->Code;?> - <?php print cleanutf8($activity->Description);?></td>
|
|
</tr>
|
|
<?php
|
|
}
|
|
}else{
|
|
?>
|
|
<tr>
|
|
<td width="30"> </td>
|
|
<td colspan="2" class="StyleInfoData">Aucune information disponible</td>
|
|
</tr>
|
|
<?php
|
|
}
|
|
?>
|
|
<tr>
|
|
<td colspan="3"> </td>
|
|
</tr>
|
|
</table>
|
|
|
|
<h2>Géolocalisation : </h2>
|
|
<?php
|
|
//geoCode(adresse, codePostal, ville, pays)
|
|
/*
|
|
$adresse = $company->RegisteredAddress->Building;
|
|
$codePostal = $company->RegisteredAddress->PostCode;
|
|
$ville = $company->RegisteredAddress->City;
|
|
*/
|
|
//$geoCodeResult = $client->geoCode('19 rue de saulnier', '75009', 'paris', 'france');
|
|
//$firephp->log($geoCodeResult, 'geocode');
|
|
?>
|
|
|
|
|
|
|
|
|
|
<?php
|
|
}else{
|
|
?>
|
|
<table>
|
|
<tr>
|
|
<td width="30"> </td>
|
|
<td colspan="2" class="StyleInfoData">Aucune information disponible</td>
|
|
</tr>
|
|
</table>
|
|
<?php
|
|
}
|
|
?>
|
|
</div>
|