Giant: SoapUI test-suite OK sauf pour les PreferredStartDate (erreurs dans le xsd)

This commit is contained in:
Sebastien BEAUGRAND 2010-06-02 15:20:08 +00:00
parent 3ef545409e
commit 0601787e93
7 changed files with 14470 additions and 195 deletions

View File

@ -13,6 +13,7 @@ update-investigation-tests.php \
generateDoctrine.php \
orders.sql \
monitors.sql \
soapui-test-suite.ini \
Makefile
WSDL = \
wsdl/credit-data-service-provider-api-1.0.wsdl \
@ -27,8 +28,10 @@ schema/cdm/cdm-1.0.xsd \
schema/cdm/graydon_be-1.0.xsd \
wsdl/monitor-events-service-1.0.wsdl \
schema/services/monitor-1.0.xsd
SRC = http:\/\/services\.giant-net\.com
DST = http:\/\/extranet.devlocal.com\/services
SRC = http:\/\/services\.giant-net\.com
TST = https:\/\/giant-tst.graydon.nl
SRV = http:\/\/localhost:8088
DST = http:\/\/extranet\.devlocal\.com\/services
TESTS1 = \
Ping \
RetrieveOptions \
@ -79,10 +82,12 @@ all:
@echo " -> suppression de tous les fichiers de sortie des tests"
@echo "make clean"
@echo " -> suppression des fichiers non versionnes"
@echo "make test-suite"
@echo " -> generation de la suite de tests SoapUI"
@echo
.PHONY: install
install: wsdl tables doctrine
install: wsdl tables doctrine test-suite
.PHONY: wsdl
wsdl: $(WSDL)
@ -91,6 +96,23 @@ wsdl: $(WSDL)
wget -r -nH http://services.giant-net.com/$@
sed 's/$(SRC)/$(DST)/g' $@ > /tmp/sed.tmp && mv /tmp/sed.tmp $@
.PHONY: test-suite
test-suite:
cat soapui-test-suite.ini | \
sed 's/$(SRC)/$(DST)/g' | \
sed 's/$(TST)/$(DST)/g' | \
sed 's/$(SRV)\/credit-data\/v1/$(DST)\/credit-data\/v1\//g' | \
sed 's/0406952018/55214450300018/g' | \
sed 's/533885/55214450300018/g' | \
sed 's/0406952018/55214450300018/g' | \
sed 's/<CompanyId>34/<CompanyId>55214450300018/g' | \
sed 's/<con:value>BE/<con:value>FR/g' | \
sed 's/<con:value>NL/<con:value>FR/g' | \
sed 's/<con:value>nl/<con:value>fr/g' | \
sed 's/<LanguageCode>nl/<LanguageCode>fr/g' | \
sed "s/'Chamber/\"Chamber/" | \
cat > soapui-test-suite.xml
.PHONY: tables
tables:
mysql -e "show databases" | grep "giant" >/dev/null || \
@ -114,7 +136,8 @@ crontab:
.PHONY: clean-wsdl
clean-wsdl:
rm -fr wsdl schema
find schema -name \*.xsd -exec rm {} \;
rm -f wsdl/*.wsdl
.PHONY: clean-orders
clean-orders:

View File

@ -5,6 +5,7 @@
if (defined('NDEBUG') == false) {
define( 'NDEBUG', '1'); // Ne pas changer cette valeur, voir le client
define('VERSION', '1.0');
define('SERVICES_URL', 'http://extranet.devlocal.com/services/');
}
require_once realpath(dirname(__FILE__).'/../../../../config/prepend.php');
@ -22,6 +23,8 @@ $gDataSetTypes = array('Full', 'Compact', 'CreditRecommendation', 'Flex');
$gLanguageCodes = array('en', 'fr');
$gServiceLevels = array('Normal', 'Urgent', 'Flash');
$gLevelDurations = array('Normal' => 7, 'Urgent' => 5, 'Flash' => 3);
$gCategoryNames = array('All', 'CreditRecommendation');
$gEventTypes = array('EventOnly', 'EventWithData');
$gTestCompanies = array('55214450300018',
'47997411500012',
'49496793800031');
@ -44,36 +47,24 @@ function modeTestUniquement()
global $gServiceHeader;
if ($gServiceHeader->TestIndication != 'true') {
throw new SoapFault('FunctionalError',
functionalError(1003,
'TestIndication must be set'.
' for the moment'));
throw functionalError(1003, 'TestIndication must be set'.
' for the moment');
}
}
// --------------------------------------------------------------------------- //
// Serveur
// --------------------------------------------------------------------------- //
abstract class DataSetType { }
class FullDataSet extends DataSetType { }
class CompactDataSet extends DataSetType { }
class CreditRecommendation extends DataSetType { }
abstract class AccountItem { }
class AmountAccountItem extends AccountItem { }
class NumberAccountItem extends AccountItem { }
if (NDEBUG) {
$serveur =
new SoapServer('http://extranet.devlocal.com/services/'.
new SoapServer(SERVICES_URL.
'wsdl/credit-data-service-provider-api-1.0.wsdl',
array('soap_version' => SOAP_1_1,
'trace' => true,
'classmap' => array('FullDataSet' =>
'FullDataSet',
'CompactDataSet' =>
'CompactDataSet',
'CreditRecommendation' =>
'CreditRecommendation',
'AmountAccountItem' =>
'classmap' => array('AmountAccountItem' =>
'AmountAccountItem',
'NumberAccountItem' =>
'NumberAccountItem')));
@ -94,16 +85,27 @@ if (NDEBUG) {
// --------------------------------------------------------------------------- //
function getDomElement(&$node, &$obj)
{
foreach ($node->childNodes as $n) {
if ($n->childNodes->length > 1) {
if ($node->hasChildNodes() == true) {
$n = $node->childNodes->length;
for ($i = 0; $i < $n; ++$i) {
$cur = $node->childNodes->item($i);
$o = new StdClass;
getDomElement($n, $o);
$name = $n->nodeName;
$obj->$name = $o;
} else {
$name = $n->nodeName;
$obj->$name = $n->firstChild->nodeValue;
getDomElement($cur, $o);
$name = $cur->nodeName;
if ($name == '#text') {
if (empty($o) == false && trim($o) != '') {
$obj->_ = $o;
}
} else {
if (isset($o->_)) {
$obj->$name = $o->_;
} else {
$obj->$name = $o;
}
}
}
} else {
$obj = $node->nodeValue;
}
}
@ -119,8 +121,8 @@ function readSoapHeader()
$xml->xml($GLOBALS['HTTP_RAW_POST_DATA']);
while ($xml->read()) {
if ($xml->namespaceURI == 'http://extranet.devlocal.com/services/'.
'schema/services/shared/1.0' &&
if (preg_match('@/services/schema/services/shared/1\.0@',
$xml->namespaceURI) != false &&
$xml->nodeType == XMLReader::ELEMENT) {
$node = $xml->expand();
getDomElement($node, $header);
@ -140,7 +142,8 @@ function enregistrement($table, $id)
{
global $gServiceHeader;
if (isset($gServiceHeader->CustomerId) == true) {
if (isset($gServiceHeader->CustomerId) == true &&
$gServiceHeader->CustomerId != 'not_provided') {
$consumer_id = $gServiceHeader->CustomerId;
} else {
$consumer_id = $gServiceHeader->ConsumerId;
@ -169,9 +172,14 @@ function functionalError($n, $details = '')
case 1: $m = 'Order is not completed'; break;
case 1003: $m = 'Authorization failed'; break;
case 3000: $m = 'Invalid CompanyId'; break;
case 3002: $m = 'Invalid LanguageCode requested'; break;
case 3003: $m = 'Invalid DataSetType requested'; break;
case 3004: $m = 'Invalid ServiceLevel requested'; break;
case 3001: $m = 'Invalid Version'; break;
case 3002: $m = 'Invalid LanguageCode'; break;
case 3003: $m = 'Invalid DataSetType'; break;
case 3004: $m = 'Invalid ServiceLevel'; break;
case 3005: $m = 'Invalid CategoryName'; break;
case 3006: $m = 'Invalid EventType'; break;
case 3007: $m = 'Invalid Date format'; break;
case 3020: $m = 'Invalid OrderId'; break;
case 3021: $m = 'Invalid OrderId / Consumer combination'; break;
}
@ -179,7 +187,9 @@ function functionalError($n, $details = '')
if (empty($details) == false) {
$r->ErrorDetails = $details.'.';
}
return print_r($r, true);
return new SoapFault('FunctionalException', print_r($r, true), '', $r,
'FunctionalException');
}
// --------------------------------------------------------------------------- //
@ -199,7 +209,9 @@ function technicalError($n, $details = '')
if (empty($details) == false) {
$r->ErrorDetails = $details.'.';
}
return print_r($r, true);
return new SoapFault('TechnicalException', print_r($r, true), '', $r,
'TechnicalException');
}
// --------------------------------------------------------------------------- //
@ -212,13 +224,14 @@ function orderResponse(&$o, &$q)
$order = new StdClass;
$order->ProviderOrderId = $q->ProviderOrderId;
$order->ConsumerId = $gServiceHeader->ConsumerId;
if (empty($gServiceHeader->CustomerId) == false) {
if (empty($gServiceHeader->CustomerId) == false &&
$gServiceHeader->CustomerId != 'not_provided') {
$order->CustomerId = $gServiceHeader->CustomerId;
}
$order->ProviderId = $gServiceHeader->Provider->ProviderId;
$order->CountryCode = $gServiceHeader->Provider->CountryCode;
$order->CompanyId = $q->CompanyId;
$order->Version = '1.0';
$order->Version = VERSION;
$order->LanguageCode = $q->LanguageCode;
if (isset($q->OrderType) == true) {
@ -342,17 +355,14 @@ function ajouteJoursOuvrables($jours)
// --------------------------------------------------------------------------- //
// company
// --------------------------------------------------------------------------- //
function company(&$i)
function company(&$c, &$i)
{
$c = new StdClass;
$c->CompanyId = $i['Siret'];
//$c->OldCompanyId = ;
if ($i['TvaAttribue'] == 1) {
$c->Vat = new StdClass;
$c->Vat->VatNumber = $i['TvaNumero'];
}
$c->CompanyStatus = $i['Actif'];
$c->CompanyName = $i['Nom'];
$c->CompanyStatus = ($i['Actif'] == 1) ? 'Active' : 'Inactive';
$c->EmailAddress = $i['Mail'];
$c->WebAddress = str_replace('http://', '', $i['Web']);
$c->IncorporationDate =
@ -382,20 +392,6 @@ function company(&$i)
$c->TradeName = $i['Enseigne'];
}
//$c->SocialSecurityNumber = ;
//$c->CompanyRegistry = ;
$address = new StdClass;
$address->Street = $i['Adresse'];
$address->HouseNumber = $i['AdresseNum'];
//$address->HouseNumberAddition = ;
//$address->Building = ;
//$address->PoBox = ;
$address->PostCode = $i['CP'];
$address->City = $i['Ville'];
//$address->State = ;
$address->Country = $i['PaysIso2'];
//$address->Period = ;
//$address->FlexibleAddress = ;
$c->CompanyAddress = $address;
//$c->StockExchange = ;
//$c->Division = ;
$op = new StdClass;
@ -410,7 +406,11 @@ function company(&$i)
$product_name->lang = 'fr';
$op->ProductName[] = $product_name;
$op->IndustryCode = new StdClass;
$op->IndustryCode->NaceCode = substr($i['NaceEtab'], 1);
if (empty($i['NaceEtab']) == false) {
$op->IndustryCode->NaceCode = substr($i['NaceEtab'], 1);
} else {
$op->IndustryCode->NaceCode = 0;
}
//$op->IndustryCode->Description = ;
//$op->IndustryCode->version = ;
//$op->IndustryCode->source = ;
@ -432,10 +432,33 @@ function company(&$i)
//$c->RealEstate = ;
//$c->PeerGroup = ;
//$c->Event = ;
}
$company = new StdClass;
$company->Company = $c;
return $company;
// --------------------------------------------------------------------------- //
// restrictedCompany
// --------------------------------------------------------------------------- //
function restrictedCompany(&$c, &$i)
{
$c->CompanyId = $i['Siret'];
//$c->CompanyRegistry = ;
$c->CompanyName = $i['Nom'];
$address = new StdClass;
$address->Street = $i['Adresse'];
$address->HouseNumber = $i['AdresseNum'];
//$address->HouseNumberAddition = ;
//$address->Building = ;
//$address->PoBox = ;
$address->PostCode = $i['CP'];
$address->City = $i['Ville'];
//$address->State = ;
if (empty($i['Pays']) == false) {
$address->Country = $i['Pays'];
} else {
$address->Country = 'FR';
}
//$address->Period = ;
//$address->FlexibleAddress = ;
$c->CompanyAddress = $address;
}
// --------------------------------------------------------------------------- //
@ -461,8 +484,7 @@ function bilans(&$ratios)
//$item->level = ;
$item->Value = $ratios['ratiosEntrep'][$bilan_num]['r'.$code];
if (empty($description->_) == true) {
throw new SoapFault('TechnicalError',
technicalError(1, 'Assets'));
throw technicalError(1, 'Assets');
}
$balance->Assets->AccountItem[] = $item;
}
@ -476,8 +498,7 @@ function bilans(&$ratios)
//$item->level = ;
$item->Value = $ratios['ratiosEntrep'][$bilan_num]['r'.$code];
if (empty($description->_) == true) {
throw new SoapFault('TechnicalError',
technicalError(1, 'Liabilities'));
throw technicalError(1, 'Liabilities');
}
$balance->Liabilities->AccountItem[] = $item;
}
@ -500,8 +521,7 @@ function bilans(&$ratios)
//$item->level = ;
$item->Value = $valeur;
if (empty($description->_) == true) {
throw new SoapFault('TechnicalError',
technicalError(1, 'ProfitAndLoss'));
throw technicalError(1, 'ProfitAndLoss');
}
$profit_and_loss->AccountItem[] = $item;
}
@ -856,13 +876,17 @@ function RetrieveOptions($o)
global $gServiceLevels;
global $gLevelDurations;
if (preg_match('/^[0-9]{14}$/', $o->CompanyId) == false) {
throw functionalError(3000, $o->CompanyId);
}
$r = new StdClass;
$r->DateOfLastUpdate = '0000-00-00';
$i = scoresws_identite($o->CompanyId,
substr($o->CompanyId, 0, 9), 0);
if ($i == false) {
throw new SoapFault('TechnicalError', technicalError(1));
throw technicalError(1);
}
if (empty($i['Bilan']['Cloture']) == false) {
$r->DateOfLastAnnualAccount =
@ -949,41 +973,42 @@ function getDataSet($company_id, $data_set_type)
break;
case 'Flex':
default:
throw new SoapFault('FunctionalError',
functionalError(3003, $data_set_type));
throw functionalError(3003, $data_set_type);
}
if ($identite == false) {
throw new SoapFault('TechnicalError',
technicalError(1, 'scoresws_identite'));
}
$ratios = scoresws_ratios($company_id, $siren, 0);
if ($ratios == false) {
throw new SoapFault('TechnicalError',
technicalError(1, 'scoresws_ratios'));
}
$banques = scoresws_banques($company_id, $siren, 0);
if ($banques == false) {
throw new SoapFault('TechnicalError',
technicalError(1, 'scoresws_banques'));
throw technicalError(1, 'scoresws_identite');
}
$indiscore = scoresws_indiscore($company_id, $siren, 0);
if ($indiscore == false) {
throw new SoapFault('TechnicalError',
technicalError(1, 'scoresws_indiscore'));
throw technicalError(1, 'scoresws_indiscore');
}
$company = new StdClass;
$company->Company = new StdClass;
restrictedCompany($company->Company, $identite);
$company->Company->CreditRecommendation = creditRecommendation($indiscore);
if ($data_set_type == 'CreditRecommendation') {
return $company;
}
$ratios = scoresws_ratios($company_id, $siren, 0);
if ($ratios == false) {
throw technicalError(1, 'scoresws_ratios');
}
$banques = scoresws_banques($company_id, $siren, 0);
if ($banques == false) {
throw technicalError(1, 'scoresws_banques');
}
$etablissements = scoresws_etablissements($company_id, $siren, 0);
if ($etablissements == false) {
throw new SoapFault('TechnicalError',
technicalError(1, '$scoresws_etablissements'));
throw technicalError(1, '$scoresws_etablissements');
}
$liens = scoresws_liens($company_id, $siren, 0);
if ($liens == false) {
throw new SoapFault('TechnicalError',
technicalError(1, '$scoresws_liens'));
throw technicalError(1, '$scoresws_liens');
}
$company = company($identite);
$company->Company->CreditRecommendation = creditRecommendation($indiscore);
company($company->Company, $identite);
$company->Company->AnnualAccounts = bilans($ratios);
$company->Company->Bank = banques($banques);
//$company->Company->Auditor = auditor();
@ -1007,15 +1032,18 @@ function OrderDataSet($o)
global $gLanguageCodes;
global $gTestCompanies;
if (preg_match('/^[0-9]{14}$/', $o->CompanyId) == false) {
throw functionalError(3000, $o->CompanyId);
}
if ($o->DataSetVersion != VERSION) {
throw functionalError(3001, $o->DataSetVersion);
}
if (in_array($o->LanguageCode, $gLanguageCodes) == false) {
throw new SoapFault('FunctionalError',
functionalError(3002, $o->LanguageCode));
throw functionalError(3002, $o->LanguageCode);
}
if ($gServiceHeader->TestIndication == 'true' &&
in_array($o->CompanyId, $gTestCompanies) == false) {
throw new SoapFault('FunctionalError',
functionalError(3000, $o->CompanyId.
' is not in test mode'));
throw functionalError(3000, $o->CompanyId.' is not in test mode');
}
modeTestUniquement();
@ -1024,7 +1052,8 @@ function OrderDataSet($o)
$q = new Orders;
$q->TestIndication = $gServiceHeader->TestIndication == 'true';
$q->ConsumerId = $gServiceHeader->ConsumerId;
if (empty($gServiceHeader->CustomerId) == false) {
if (empty($gServiceHeader->CustomerId) == false &&
$gServiceHeader->CustomerId != 'not_provided') {
$q->CustomerId = $gServiceHeader->CustomerId;
}
$q->CompanyId = $o->CompanyId;
@ -1054,9 +1083,13 @@ function OrderDataSet($o)
// --------------------------------------------------------------------------- //
function RetrieveOrderStatus($o)
{
if (is_numeric($o->ProviderOrderId) == false) {
throw functionalError(3020, $o->ProviderOrderId);
}
$q = enregistrement('Orders', $o->ProviderOrderId);
if ($q == false) {
throw new SoapFault('FunctionalError', functionalError(3021));
throw functionalError(3021);
}
$r = new StdClass;
@ -1070,16 +1103,18 @@ function RetrieveOrderStatus($o)
// --------------------------------------------------------------------------- //
function RetrieveDataSet($o)
{
if (is_numeric($o->ProviderOrderId) == false) {
throw functionalError(3020, $o->ProviderOrderId);
}
$q = enregistrement('Orders', $o->ProviderOrderId);
if ($q == false) {
throw new SoapFault('FunctionalError', functionalError(3021));
throw functionalError(3021);
}
if ($q->OrderStatus != 'Completed' &&
$q->OrderStatus != 'Delivered') {
throw new SoapFault('FunctionalError',
functionalError(3021, 'Order status is '.
$q->OrderStatus));
throw functionalError(3021, 'Order status is '.$q->OrderStatus);
}
if ($q->OrderStatus != 'Delivered') {
@ -1088,27 +1123,31 @@ function RetrieveDataSet($o)
$q->save();
}
switch ($q->DataSetType) {
case 'Full':
$data_set = new FullDataSet;
break;
case 'Compact':
$data_set = new CompactDataSet;
break;
case 'CreditRecommendation':
$data_set = new CreditRecommendation;
break;
default:
throw new SoapFault('TechnicalError',
technicalalError(9000, $q->DataSetType.
' non-implemented'));
}
$data_set->Company = unserialize($q->DataSet)->Company;
$data_set = unserialize($q->DataSet);
$r = new StdClass;
$r = new StdClass;
$r->version = VERSION;
$r->Order = orderResponse($o, $q);
$r->DataSet = $data_set;
switch ($q->DataSetType) {
case 'Full':
$r->DataSet = new SoapVar($data_set, SOAP_ENC_OBJECT,
'FullDataSet', SERVICES_URL.
'schema/services/fulldataset/1.0');
break;
case 'Compact':
$r->DataSet = new SoapVar($data_set, SOAP_ENC_OBJECT,
'CompactDataSet', SERVICES_URL.
'schema/services/compactdataset/1.0');
break;
case 'CreditRecommendation':
$r->DataSet = new SoapVar($data_set, SOAP_ENC_OBJECT,
'CreditRecommendation', SERVICES_URL.
'schema/services/creditrecommendation/1.0');
break;
default:
throw technicalalError(9000, $q->DataSetType.' non-implemented');
}
return $r;
}
@ -1124,23 +1163,25 @@ function StartInvestigation($o)
global $gLevelDurations;
global $gTestCompanies;
if (preg_match('/^[0-9]{14}$/', $o->CompanyId) == false) {
throw functionalError(3000, $o->CompanyId);
}
if ($o->DataSetVersion != VERSION) {
throw functionalError(3001, $o->DataSetVersion);
}
if (in_array($o->LanguageCode, $gLanguageCodes) == false) {
throw new SoapFault('FunctionalError',
functionalError(3002, $o->LanguageCode));
throw functionalError(3002, $o->LanguageCode);
}
if (in_array($o->DataSetType->_, $gDataSetTypes) == false) {
throw new SoapFault('FunctionalError',
functionalError(3003, $o->DataSetType->_));
throw functionalError(3003, $o->DataSetType->_);
}
$o->ServiceLevelName = ucfirst($o->ServiceLevelName);
if (in_array($o->ServiceLevelName, $gServiceLevels) == false) {
throw new SoapFault('FunctionalError',
functionalError(3004, $o->ServiceLevelName));
throw functionalError(3004, $o->ServiceLevelName);
}
if ($o->TestIndication == 'true' &&
in_array($o->CompanyId, $gTestCompanies) == false) {
throw new SoapFault('FunctionalError',
functionalError(3000, $o->CompanyId.
' is not in test mode'));
throw functionalError(3000, $o->CompanyId.' is not in test mode');
}
modeTestUniquement();
@ -1149,7 +1190,8 @@ function StartInvestigation($o)
$q = new Orders;
$q->TestIndication = $gServiceHeader->TestIndication == 'true';
$q->ConsumerId = $gServiceHeader->ConsumerId;
if (empty($gServiceHeader->CustomerId) == false) {
if (empty($gServiceHeader->CustomerId) == false &&
$gServiceHeader->CustomerId != 'not_provided') {
$q->CustomerId = $gServiceHeader->CustomerId;
}
$q->CompanyId = $o->CompanyId;
@ -1181,17 +1223,38 @@ function StartMonitoring($o)
{
global $gServiceHeader;
global $gLanguageCodes;
global $gCategoryNames;
global $gEventTypes;
global $gTestCompanies;
if (preg_match('/^[0-9]{14}$/', $o->CompanyId) == false) {
throw functionalError(3000, $o->CompanyId);
}
if ($o->MonitoringVersion != VERSION) {
throw functionalError(3001, $o->MonitoringVersion);
}
if (in_array($o->LanguageCode, $gLanguageCodes) == false) {
throw new SoapFault('FunctionalError',
functionalError(3002, $o->LanguageCode));
throw functionalError(3002, $o->LanguageCode);
}
if (in_array($o->CategoryName, $gCategoryNames) == false) {
throw functionalError(3005);
}
if (in_array($o->EventType, $gEventTypes) == false) {
throw functionalError(3006);
}
if (isset($o->PreferredStartDate) == true &&
preg_match('/^[0-9]{4}-[0-9]{2}-[0-9]{2}$/',
$o->PreferredStartDate) == false) {
throw functionalError(3007, $o->PreferredStartDate);
}
if (isset($o->PreferredEndDate) == true &&
preg_match('/^[0-9]{4}-[0-9]{2}-[0-9]{2}$/',
$o->PreferredEndDate) == false) {
throw functionalError(3007, $o->PreferredEndDate);
}
if ($gServiceHeader->TestIndication == 'true' &&
in_array($o->CompanyId, $gTestCompanies) == false) {
throw new SoapFault('FunctionalError',
functionalError(3000, $o->CompanyId.
' is not in test mode'));
throw functionalError(3000, $o->CompanyId.' is not in test mode');
}
modeTestUniquement($o->CompanyId);
@ -1201,7 +1264,8 @@ function StartMonitoring($o)
$q = new Monitors;
$q->TestIndication = $gServiceHeader->TestIndication == 'true';
$q->ConsumerId = $gServiceHeader->ConsumerId;
if (empty($gServiceHeader->CustomerId) == false) {
if (empty($gServiceHeader->CustomerId) == false &&
$gServiceHeader->CustomerId != 'not_provided') {
$q->CustomerId = $gServiceHeader->CustomerId;
}
$q->CompanyId = $o->CompanyId;
@ -1234,7 +1298,7 @@ function StopMonitoring($o)
{
$q = enregistrement('Monitors', $o->ProviderOrderId);
if ($q == false) {
throw new SoapFault('FunctionalError', functionalError(3021));
throw functionalError(3021);
}
if (isset($o->PreferredEndDate) == true) {
@ -1255,9 +1319,43 @@ function StopMonitoring($o)
// --------------------------------------------------------------------------- //
function UpdateMonitoringOptions($o)
{
global $gLanguageCodes;
global $gCategoryNames;
global $gEventTypes;
if (isset($o->NewMonitoringVersion) == true &&
$o->NewMonitoringVersion != VERSION) {
throw functionalError(3001, $o->NewMonitoringVersion);
}
if (isset($o->NewLanguageCode) == true &&
in_array($o->NewLanguageCode, $gLanguageCodes) == false) {
throw functionalError(3002, $o->NewLanguageCode);
}
if (isset($o->NewCategoryName) == true &&
in_array($o->NewCategoryName, $gCategoryNames) == false) {
throw functionalError(3005, $o->NewCategoryName);
}
if (isset($o->NewEventType) == true &&
in_array($o->NewEventType, $gEventTypes) == false) {
throw functionalError(3006, $o->NewEventType);
}
if (isset($o->NewPreferredStartDate) == true &&
preg_match('/^[0-9]{4}-[0-9]{2}-[0-9]{2}$/',
$o->NewPreferredStartDate) == false) {
throw functionalError(3007, $o->NewPreferredStartDate);
}
if (isset($o->NewPreferredEndDate) == true &&
preg_match('/^[0-9]{4}-[0-9]{2}-[0-9]{2}$/',
$o->NewPreferredEndDate) == false) {
throw functionalError(3007, $o->NewPreferredEndDate);
}
if (is_numeric($o->ProviderOrderId) == false) {
throw functionalError(3020, $o->ProviderOrderId);
}
$q = enregistrement('Monitors', $o->ProviderOrderId);
if ($q == false) {
throw new SoapFault('FunctionalError', functionalError(3021));
throw functionalError(3021);
}
if (isset($o->NewCategoryName) == true) {
@ -1272,8 +1370,11 @@ function UpdateMonitoringOptions($o)
if (isset($o->NewLanguageCode) == true) {
$q->LanguageCode = $o->NewLanguageCode;
}
if (isset($o->PreferredStartDate) == true) {
$q->ActualStartDate = $o->PreferredStartDate;
if (isset($o->NewPreferredStartDate) == true) {
$q->ActualStartDate = $o->NewPreferredStartDate;
}
if (isset($o->NewPreferredEndDate) == true) {
$q->ActualEndDate = $o->NewPreferredEndDate;
}
$q->save();

View File

@ -3,7 +3,7 @@
-- http://www.phpmyadmin.net
--
-- Serveur: localhost
-- Généré le : Mer 05 Mai 2010 à 16:26
-- Généré le : Mar 01 Juin 2010 à 10:28
-- Version du serveur: 5.1.40
-- Version de PHP: 5.3.1
@ -25,10 +25,11 @@ SET SQL_MODE="NO_AUTO_VALUE_ON_ZERO";
-- Structure de la table `monitors`
--
CREATE TABLE IF NOT EXISTS `monitors` (
DROP TABLE IF EXISTS `monitors`;
CREATE TABLE `monitors` (
`ProviderOrderId` int(11) NOT NULL AUTO_INCREMENT,
`TestIndication` tinyint(1) NOT NULL,
`ConsumerId` int(11) NOT NULL,
`ConsumerId` tinytext COLLATE utf8_unicode_ci NOT NULL,
`CompanyId` bigint(14) NOT NULL,
`CompanyName` tinytext COLLATE utf8_unicode_ci NOT NULL,
`CategoryName` enum('All','CreditRecommendation') COLLATE utf8_unicode_ci NOT NULL,

View File

@ -3,7 +3,7 @@
-- http://www.phpmyadmin.net
--
-- Serveur: localhost
-- Généré le : Mer 05 Mai 2010 à 11:15
-- Généré le : Mar 01 Juin 2010 à 10:28
-- Version du serveur: 5.1.40
-- Version de PHP: 5.3.1
@ -25,10 +25,11 @@ SET SQL_MODE="NO_AUTO_VALUE_ON_ZERO";
-- Structure de la table `orders`
--
CREATE TABLE IF NOT EXISTS `orders` (
DROP TABLE IF EXISTS `orders`;
CREATE TABLE `orders` (
`ProviderOrderId` int(11) NOT NULL AUTO_INCREMENT,
`TestIndication` tinyint(1) NOT NULL,
`ConsumerId` int(11) NOT NULL,
`ConsumerId` tinytext COLLATE utf8_unicode_ci NOT NULL,
`CompanyId` bigint(14) NOT NULL,
`OrderType` enum('DataSet','Monitoring','Investigation') COLLATE utf8_unicode_ci NOT NULL,
`DataSetType` enum('Full','Compact','CreditRecommendation','Flex') COLLATE utf8_unicode_ci NOT NULL,

File diff suppressed because it is too large Load Diff

File diff suppressed because it is too large Load Diff

View File

@ -32,23 +32,23 @@ header('Content-Type: text/html; charset=utf-8');
define( 'NDEBUG', '1');
define('VERSION', '1.0');
define('SERVICES_URL', 'http://extranet.devlocal.com/services/');
$gServiceHeader = new StdClass;
$gServiceHeader->ConsumerId = 1234;
//$gServiceHeader->CustomerId = 1234;
$gServiceHeader->ConsumerId = 'a1234';
//$gServiceHeader->CustomerId = 'a1234';
$gServiceHeader->Provider = new StdClass;
$gServiceHeader->Provider->ProviderId = 2345;
$gServiceHeader->Provider->ProviderId = 'SD';
$gServiceHeader->Provider->CountryCode = 'FR';
$gServiceHeader->TimeStamp = date('Y-m-d\TH:i:s');
$gServiceHeader->TestIndication = true;
if (NDEBUG) {
$soap_header =
new SoapHeader('http://extranet.devlocal.com/services/'.
'schema/services/shared/1.0', 'ServiceHeader',
$gServiceHeader);
new SoapHeader(SERVICES_URL.'schema/services/shared/1.0',
'ServiceHeader', $gServiceHeader);
$soap_client =
new SoapClient('http://extranet.devlocal.com/services/'.
new SoapClient(SERVICES_URL.
'wsdl/credit-data-service-provider-api-1.0.wsdl',
array('soap_version' => SOAP_1_1,
'trace' => true));
@ -59,61 +59,62 @@ $fonction = '';
$o = new StdClass;
switch ($action) {
case 'Ping':
$o->Type = 'simple';
$fonction = 'Ping';
$o->Type = 'simple';
$fonction = 'Ping';
break;
case 'RetrieveOptions':
$o->CompanyId = $companyId;
$fonction = 'RetrieveOptions';
$o->CompanyId = $companyId;
$fonction = 'RetrieveOptions';
break;
case 'OrderDataSet':
$o->CompanyId = $companyId;
$o->DataSetType = new StdClass;
$o->DataSetType->_ = 'Full';
$o->DataSetVersion = VERSION;
$o->LanguageCode = 'fr';
$fonction = 'OrderDataSet';
$o->CompanyId = $companyId;
$o->DataSetType = new StdClass;
//$o->DataSetType->_ = 'CreditRecommendation';
$o->DataSetType->_ = 'Full';
$o->DataSetVersion = VERSION;
$o->LanguageCode = 'fr';
$fonction = 'OrderDataSet';
break;
case 'RetrieveOrderStatus':
$o->ProviderOrderId = $providerOrderId;
$fonction = 'RetrieveOrderStatus';
$o->ProviderOrderId = $providerOrderId;
$fonction = 'RetrieveOrderStatus';
break;
case 'RetrieveDataSet':
$o->ProviderOrderId = $providerOrderId;
$fonction = 'RetrieveDataSet';
$o->ProviderOrderId = $providerOrderId;
$fonction = 'RetrieveDataSet';
break;
case 'StartInvestigation':
$o->CompanyId = $companyId;
$o->DataSetType = new StdClass;
$o->DataSetType->_ = 'Full';
$o->DataSetVersion = VERSION;
$o->ServiceLevelName = 'Normal';
$o->LanguageCode = 'fr';
$fonction = 'StartInvestigation';
$o->CompanyId = $companyId;
$o->DataSetType = new StdClass;
$o->DataSetType->_ = 'Full';
$o->DataSetVersion = VERSION;
$o->ServiceLevelName = 'Normal';
$o->LanguageCode = 'fr';
$fonction = 'StartInvestigation';
break;
case 'StartMonitoring':
$o->CompanyId = $companyId;
$o->CategoryName = 'All';
$o->EventType = 'EventOnly';
$o->MonitoringVersion = '1.0';
$o->LanguageCode = 'fr';
//$o->PreferredStartDate = ;
//$o->PreferredEndDate = ;
$fonction = 'StartMonitoring';
$o->CompanyId = $companyId;
$o->CategoryName = 'All';
$o->EventType = 'EventOnly';
$o->MonitoringVersion = '1.0';
$o->LanguageCode = 'fr';
//$o->PreferredStartDate = ;
//$o->PreferredEndDate = ;
$fonction = 'StartMonitoring';
break;
case 'StopMonitoring':
$o->ProviderOrderId = $providerOrderId;
//$o->PreferredEndDate = ;
$fonction = 'StopMonitoring';
$o->ProviderOrderId = $providerOrderId;
//$o->PreferredEndDate = ;
$fonction = 'StopMonitoring';
break;
case 'UpdateMonitoringOptions':
$o->ProviderOrderId = $providerOrderId;
//$o->NewCategoryName = ;
$o->NewEventType = 'EventWithData';
//$o->NewMonitoringVersion = ;
//$o->NewLanguageCode = ;
$o->PreferredStartDate = date('Y-m-d');
$fonction = 'UpdateMonitoringOptions';
$o->ProviderOrderId = $providerOrderId;
//$o->NewCategoryName = ;
$o->NewEventType = 'EventWithData';
//$o->NewMonitoringVersion = ;
//$o->NewLanguageCode = ;
$o->NewPreferredStartDate = date('Y-m-d');
$fonction = 'UpdateMonitoringOptions';
break;
default:
print 'erreur: fonction inconnue';
@ -129,10 +130,10 @@ print_r($o);
print '<br/>';
if (NDEBUG) {
print_r($soap_client->__call($fonction, array($o)));
//print '<br/>';
//print 'Requete: '.htmlspecialchars($soap_client->__getLastRequest());
//print '<br/>';
//print 'Reponse: '.htmlspecialchars($soap_client->__getLastResponse());
print '<br/>';
print 'Requete: '.htmlspecialchars($soap_client->__getLastRequest());
print '<br/>';
print 'Reponse: '.htmlspecialchars($soap_client->__getLastResponse());
} else {
require_once 'credit-data/v1/index.php';
print_r(call_user_func($fonction, $o));