extranet/www/pages/giant_enquete.php
2010-10-06 11:47:31 +00:00

174 lines
5.6 KiB
PHP

<?php
// --------------------------------------------------------------------------- //
// giant_enquete.php
// --------------------------------------------------------------------------- //
define('VERSION', '1.0');
$pays = $_GET['pays'];
$company = $_GET['company'];
$level = $_GET['level'];
$type = $_GET['type' ];
$lang = $_GET['lang' ];
// --------------------------------------------------------------------------- //
// giantCopieDuRapports
// --------------------------------------------------------------------------- //
function giantCopieDuRapport($rapport_a_copier)
{
$r = new Rapports;
$r->CountryCode = $rapport_a_copier->CountryCode;
$r->ProviderId = $rapport_a_copier->ProviderId;
$r->CompanyId = $rapport_a_copier->CompanyId;
$r->ServiceLevelName = 'Immediate';
$r->DataSetType = $rapport_a_copier->DataSetType;
$r->LanguageCode = $rapport_a_copier->LanguageCode;
$r->DataSet = $rapport_a_copier->DataSet;
$r->OrderId = $rapport_a_copier->OrderId;
$r->User = $_SESSION['tabInfo']['login'];
$r->DateTime = date('Y-m-d\ H:i:s');
$r->save();
return $r->ReportId;
}
// --------------------------------------------------------------------------- //
// giantGetIdentite
// --------------------------------------------------------------------------- //
function giantGetIdentite($pays, $company, $level, $type, $lang)
{
$c = new Commandes;
$c->ProviderId = getProviderId($pays);
$c->CountryCode = getCountryCode($pays);
$c->CompanyId = $company;
//$c->CompanyName = ;
$c->ServiceLevelName = 'Immediate';
$c->DataSetType = $type;
$c->LanguageCode = $lang;
$c->OrderStatus = 'Pending';
$c->OrderDateTime = date('Y-m-d\TH:i:s');
$c->DueDateTime = $c->OrderDateTime;
$c->User = $_SESSION['tabInfo']['login'];
$c->save();
$soap_client = getClient($pays, 'credit-data');
$o = new StdClass;
$o->CompanyId = $company;
$o->DataSetType = new StdClass;
$o->DataSetType->_ = $type;
$o->LanguageCode = $lang;
$o->DataSetVersion = VERSION;
try {
$O = $soap_client->__call('OrderDataSet', array($o));
} catch (SoapFault $f) {
print_r($f);
print '<br/>';
print 'Requete: '.
htmlspecialchars($soap_client->__getLastRequest());
print '<br/>';
print 'Reponse: '.
htmlspecialchars($soap_client->__getLastResponse());
}
if ($O->Order->OrderStatus != 'Completed') {
print 'Service momentanément indisponible';
return 0;
}
$o = new StdClass;
$o->ProviderOrderId = $O->Order->ProviderOrderId;
$o->InternalOrderId = $O->Order->InternalOrderId;
try {
$O = $soap_client->__call('RetrieveDataSet', array($o));
} catch (SoapFault $f) {
print_r($f);
print '<br/>';
print 'Requete: '.
htmlspecialchars($soap_client->__getLastRequest());
print '<br/>';
print 'Reponse: '.
htmlspecialchars($soap_client->__getLastResponse());
}
/*
print '<pre>';
print_r($O);
print '</pre>';
exit;
*/
$r = new Rapports;
$r->ProviderId = $c->ProviderId;
$r->CountryCode = $c->CountryCode;
$r->CompanyId = $company;
$r->ServiceLevelName = $level;
$r->DataSetType = $type;
$r->LanguageCode = $lang;
$r->DataSet = serialize($O->DataSet);
$r->OrderId = $c->OrderId;
$r->User = $c->User;
$r->save();
$c->CompanyName = $O->DataSet->Company->CompanyName->_;
$c->OrderStatus = 'Completed';
$c->DateTimeCompleted = date('Y-m-d\TH:i:s');
$c->ReportId = $r->ReportId;
$c->save();
return $c->OrderId;
}
// --------------------------------------------------------------------------- //
// Rapport Immediat
// --------------------------------------------------------------------------- //
if ($level == 'Immediate') {
require_once 'dbbootstrap.php';
setDbConn('giantclient');
print '<div id="center">';
// Si on a un rapport
require_once 'giant/client.php';
$rapports = Doctrine_Query::create()
->from('Rapports')
->andWhere('ProviderId = ?', getProviderId($pays))
->andWhere('CountryCode = ?', getCountryCode($pays))
->andwhere('CompanyId = ?', $company)
->andWhere('ServiceLevelName = ?', 'Immediate')
->andWhere('DataSetType = ?', $type)
->andWhere('LanguageCode = ?', $lang)
->orderby('ReportId desc')
->execute();
$commande_id = 0;
if ($rapports != false && count($rapports) > 0) {
// Si une commande appartient a cet utilisateur
foreach ($rapports as $r) {
if ($r->User == $_SESSION['tabInfo']['login']) {
$commande_id = $r->OrderId;
break;
}
}
if ($commande_id == 0) {
$commande_id = giantCopieDuRapport($rapports[0]);
}
} else {
$commande_id =
giantGetIdentite($pays, $company, $level, $type, $lang);
}
if ($commande_id > 0) {
header('Location: ?page=giant_commandes&OrderId='.$commande_id);
print '<a href="?page=giant_commandes&OrderId='.$commande_id.
'">Veuillez suivre ce lien</a>';
}
print '</div>';
exit;
}
// --------------------------------------------------------------------------- //
// Commande de rapport
// --------------------------------------------------------------------------- //
print 'TODO';
?>