219 lines
5.8 KiB
PHP
219 lines
5.8 KiB
PHP
<?php
|
|
session_start();
|
|
if (!$_SESSION['connected']) die();
|
|
|
|
$tabInfo = $_SESSION['tabInfo'];
|
|
|
|
$identifier = $_REQUEST['identifier'];
|
|
$CompanyProductIdentifier = $_REQUEST['pidentifier'];
|
|
$pays = $_SESSION['graydon']['pays'];
|
|
|
|
require_once 'i18n/cleanchar.php';
|
|
require_once 'graydon/graydonws.php';
|
|
require_once 'graydon/log.php';
|
|
require_once 'dbbootstrap.php';
|
|
|
|
function dVal($value){
|
|
if($value == '' || $value == NULL){
|
|
print 'NC';
|
|
}else{
|
|
print $value;
|
|
}
|
|
}
|
|
?>
|
|
<div id="center">
|
|
<?php
|
|
|
|
|
|
//Vérification si le rapport en ligne à déjà été demandé
|
|
$q = Doctrine_Query::create()
|
|
->from('Commandes')
|
|
->where('companyproductidentifier = ?', $CompanyProductIdentifier);
|
|
|
|
$commandes = new Commandes();
|
|
$commandes = $q->fetchOne();
|
|
$firephp->log($commandes,'commandes');
|
|
$nbReport = $q->count();
|
|
|
|
$report = new Report();
|
|
$report = $commandes->get('Report');
|
|
|
|
$path = PATH_DATA.'/graydon';
|
|
$fileName = strtolower(str_replace( array(':',' '), '-', $identifier).'.xml');
|
|
|
|
if(!file_exists($path.'/'.$fileName) && ($nbReport==0) ){
|
|
/*
|
|
placeOrder
|
|
CompanyProductIdentifier
|
|
Language
|
|
CreditOpinionCurrency
|
|
Country
|
|
|
|
getCompanyReport
|
|
OrderReference
|
|
MimeType
|
|
*/
|
|
//placeOrder
|
|
$request = new StdClass();
|
|
$request->Authentication_Parameters = $authentication;
|
|
$request->OrderCreatorEmail = 'mricois@scores-decisions.com';
|
|
$request->CompanyProductIdentifier = $CompanyProductIdentifier;
|
|
$request->PartnerData = '';
|
|
|
|
$firephp->log($request,'requete');
|
|
try
|
|
{
|
|
$placeOrderResult = $graydon->placeOrder($request);
|
|
|
|
//Enregistrement de l'action dans les logs
|
|
$transactionIdentifier = $placeOrderResult->Service_Log->TransactionIdentifier;
|
|
$sessionID = $placeOrderResult->Service_Log->SessionID;
|
|
graydonRequeteLog($_SESSION['tabInfo']['login'], $page, 'placeOrder', $transactionIdentifier, $sessionID);
|
|
|
|
//Enregistrement des commandes dans la bdd
|
|
$commandes = new Commandes();
|
|
$commandes->reference = $placeOrderResult->OrderStatus->OrderReference;
|
|
$commandes->servicespeed = $placeOrderResult->OrderStatus->ServiceSpeed;
|
|
$commandes->orderstate = $placeOrderResult->OrderStatus->OrderState;
|
|
$commandes->dateordered = $placeOrderResult->OrderStatus->DateOrdered;
|
|
$commandes->datecompleted = $placeOrderResult->OrderStatus->DateCompleted;
|
|
$commandes->datedue = $placeOrderResult->OrderStatus->DateDue;
|
|
$commandes->companyproductidentifier = $CompanyProductIdentifier;
|
|
$commandes->sessionid = $sessionID;
|
|
$commandes->transactionidentifier = $transactionIdentifier;
|
|
$commandes->user = $tabInfo['login'];
|
|
$commandes->Country->country = $pays; //(country_id)
|
|
$firephp->log($commandes,'SQL');
|
|
$commandes->save();
|
|
$commandes_id = $commandes->id;
|
|
|
|
//Pas d'enregistrement des détails de la commande car elle est immédiate
|
|
|
|
$firephp->log($placeOrderResult,'placeOrder');
|
|
|
|
}catch( SoapFault $fault ){
|
|
require_once 'soaperror.php';
|
|
processSoapFault($graydon,$fault,$tabInfo);
|
|
}
|
|
|
|
//On vérifie l'état de le demande
|
|
if (isset($placeOrderResult) && $placeOrderResult->OrderStatus->OrderState == 'Completed'){
|
|
//getCompanyReport
|
|
$request = new StdClass();
|
|
$request->Authentication_Parameters = $authentication;
|
|
$request->LanguageCode = 'E'; //Spécifier la langue du rapport
|
|
$request->OrderReference = $placeOrderResult->OrderStatus->OrderReference;
|
|
$request->MimeType = 'xml';
|
|
|
|
$firephp->log($request,'requete');
|
|
try
|
|
{
|
|
$reportResult = $graydon->getCompanyReport($request);
|
|
|
|
//Enregistrement de l'action dans les logs
|
|
$transactionIdentifier = $reportResult->Service_Log->TransactionIdentifier;
|
|
$sessionID = $reportResult->Service_Log->SessionID;
|
|
graydonRequeteLog($_SESSION['tabInfo']['login'], $page, 'getCompanyReport', $transactionIdentifier, $sessionID);
|
|
|
|
$firephp->log($reportResult,'reportResult');
|
|
$xml = $reportResult->ReportXML->any;
|
|
|
|
//Enregistrement du fichier xml
|
|
file_put_contents($path.'/'.$fileName, $xml);
|
|
|
|
//Mise en cache dans la bdd
|
|
$report = new Report();
|
|
$report->content = $xml;
|
|
$report->format = 'xml';
|
|
$report->identifier = $identifier;
|
|
$report->order_id = $commandes_id;
|
|
$report->save();
|
|
|
|
}catch( SoapFault $fault ){
|
|
require_once 'soaperror.php';
|
|
processSoapFault($graydon,$fault,$tabInfo);
|
|
die();
|
|
}
|
|
}
|
|
//On prend les données du fichier
|
|
}else{
|
|
if($nbReport>0){
|
|
$xml = $report->content;
|
|
}else{
|
|
$firephp->log('Data depuis fichier XML');
|
|
$xml = file_get_contents($path.'/'.$fileName);
|
|
}
|
|
}
|
|
|
|
//========= Affichage des informations =========
|
|
if(isset($xml) && $xml!=''){
|
|
|
|
$tabReport = array();
|
|
|
|
require_once 'graydon/functions.php';
|
|
require_once 'graydon/format.php';
|
|
|
|
//Création du DOM
|
|
$doc = new DOMDocument;
|
|
$doc->preserveWhiteSpace = false;
|
|
$doc->loadxml($xml);
|
|
$xpath = new DOMXPath($doc);
|
|
$tabReport = parseReportXML($xml);
|
|
$firephp->log($tabReport, 'tabReport');
|
|
function utf8decode_deep($value)
|
|
{
|
|
$value = is_array($value) ?
|
|
array_map('utf8decode_deep', $value) :
|
|
cleanutf8($value);
|
|
return $value;
|
|
}
|
|
|
|
?>
|
|
|
|
<style type="text/css">
|
|
.bilans { margin-left:35px; }
|
|
div.bilans { margin-top:15px; font:bold 16px Verdana, Arial, Sans-serif; }
|
|
span.bilans { font-style:italic; }
|
|
table.bilans { width:545px; }
|
|
table.bilans .right {text-align:right;}
|
|
</style>
|
|
|
|
<h1 class="titre">IDENTITÉ INTERNATIONALE DE L'ENTREPRISE</h1>
|
|
<?php dIdentifiant($tabReport); ?>
|
|
<h2>Raison sociale et coordonnées : </h2>
|
|
<?php dIdentite($tabReport);?>
|
|
<h2>Activité(s) et chiffre d'affaire de l'entreprise : </h2>
|
|
<?php dActivite($tabReport); ?>
|
|
<h2> Résumé financier : </h2>
|
|
<?php dResume($tabReport); ?>
|
|
<h2> Credit : </h2>
|
|
<?php dCredit($tabReport); ?>
|
|
<h2> Actionariat / Participation : </h2>
|
|
<?php dLiens($tabReport); ?>
|
|
<h2> Bilans : </h2>
|
|
<?php dBilans($tabReport); ?>
|
|
|
|
<?php
|
|
}else{
|
|
?>
|
|
<table>
|
|
<tr>
|
|
<td width="30"> </td>
|
|
<td width="500" class="StyleInfoLib">Aucune information disponible.</td>
|
|
</tr>
|
|
</table>
|
|
<?php
|
|
}
|
|
?>
|
|
</table>
|
|
</div>
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|