2010-08-30 07:49:44 +00:00
|
|
|
<?php
|
|
|
|
require_once realpath(dirname(__FILE__)).'/functions.php';
|
2010-09-09 11:58:34 +00:00
|
|
|
require_once realpath(dirname(__FILE__)).'/Types/Types.php';
|
2010-08-30 07:49:44 +00:00
|
|
|
|
2010-09-13 09:54:49 +00:00
|
|
|
class WsEntreprise
|
|
|
|
{
|
2010-09-21 15:19:32 +00:00
|
|
|
protected $wsdl = null;
|
|
|
|
protected $wsdlOptions = array();
|
|
|
|
|
|
|
|
function __construct()
|
|
|
|
{
|
|
|
|
$webservicesConfig = Zend_Registry::get('webservicesConfig')->webservice->scores;
|
|
|
|
$wsdl = !empty($webservicesConfig->wsdl) ? $webservicesConfig->wsdl : null ;
|
|
|
|
$options = array();
|
|
|
|
foreach ($webservicesConfig->options as $optionName => $optionValue){
|
|
|
|
$options[$optionName] = $optionValue;
|
|
|
|
}
|
|
|
|
$options['login'] = $_SERVER['PHP_AUTH_USER'];
|
|
|
|
$options['password'] = $_SERVER['PHP_AUTH_PW'];
|
|
|
|
|
|
|
|
$this->wsdl = $wsdl;
|
|
|
|
$this->wsdlOptions = $options;
|
|
|
|
}
|
|
|
|
|
2010-08-30 07:49:44 +00:00
|
|
|
/**
|
|
|
|
* Retourne les informations identitaires de l'entreprise ou de l'établissement demandé
|
2010-09-15 12:47:00 +00:00
|
|
|
* @param string $siret Siren de l'entreprise ou siret de l'établissement
|
2010-09-20 15:08:14 +00:00
|
|
|
* @param int $id Identifiant interne
|
2010-08-30 07:49:44 +00:00
|
|
|
* @param boolean $forceVerif
|
2010-09-08 13:40:57 +00:00
|
|
|
* @return IdentiteReturnType
|
2010-08-30 07:49:44 +00:00
|
|
|
*/
|
2010-09-13 09:54:49 +00:00
|
|
|
function getIdentite($siret, $id = 0, $forceVerif = false)
|
|
|
|
{
|
2010-09-08 13:40:57 +00:00
|
|
|
//Enregistrement des accès à la requête getIdentite
|
2010-09-14 16:36:59 +00:00
|
|
|
Zend_Registry::get('WsLogger')->info("getIdentite - ip:".
|
2010-09-22 07:22:40 +00:00
|
|
|
$_SERVER['REMOTE_ADDR'].", login:".$_SERVER['PHP_AUTH_USER']);
|
2010-09-13 09:54:49 +00:00
|
|
|
|
2010-09-08 13:40:57 +00:00
|
|
|
//Connexion aux webservices V1
|
2010-08-30 07:49:44 +00:00
|
|
|
try {
|
2010-09-21 15:19:32 +00:00
|
|
|
$client = new SoapClient($this->wsdl, $this->wsdlOptions);
|
2010-09-14 16:36:59 +00:00
|
|
|
$O = $client->getIdentite($siret, $id, $forceVerif);
|
2010-08-30 07:49:44 +00:00
|
|
|
} catch (SoapFault $fault) {
|
2010-09-14 16:36:59 +00:00
|
|
|
Zend_Registry::get('WsLogger')->err("getIdentite($siret, $id) - ".serialize($fault));
|
2010-08-30 07:49:44 +00:00
|
|
|
}
|
2010-09-08 13:40:57 +00:00
|
|
|
//Gestion du retour
|
2010-08-30 07:49:44 +00:00
|
|
|
$error = new ErrorType();
|
2010-09-21 15:19:32 +00:00
|
|
|
$error = arrayToClass($O['error'], 'ErrorType');
|
2010-08-30 07:49:44 +00:00
|
|
|
$result = new IdentiteResultType();
|
2010-09-21 15:19:32 +00:00
|
|
|
$result = arrayToClass($O['result'], 'IdentiteResultType');
|
2010-08-30 07:49:44 +00:00
|
|
|
$outputParams = new IdentiteReturnType();
|
|
|
|
$outputParams->error = $error;
|
|
|
|
$outputParams->result = $result;
|
|
|
|
return $outputParams;
|
|
|
|
}
|
2010-09-08 13:40:57 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Recherche
|
2010-09-21 15:19:32 +00:00
|
|
|
* @param string $type Type de la recherche (recherche entreprise : 'ent', recherche dirigeant : 'dir')
|
|
|
|
* @param RechercheEntrepriseCriteres $criteres
|
|
|
|
* @param int $position Position de parcours des résultats retournées (0 par défaut)
|
|
|
|
* @param int $nbRep Nombre de réponses retournées lors d'une requête (20 par défaut)
|
|
|
|
* @param int $maxRep Nombre de réponses maximum pouvant être retournées lors d'une requête (200 par défaut)
|
|
|
|
* @param bool $pertinence Recherche orthographique stricte sur le nom, l'adresse et la ville (false par défaut)
|
|
|
|
* @param bool $avecSiren Seulement les entités sirénées (false par défaut)
|
2010-09-15 16:18:38 +00:00
|
|
|
* @return RechercheEntrepriseReturnType
|
2010-09-08 13:40:57 +00:00
|
|
|
*/
|
2010-09-21 15:19:32 +00:00
|
|
|
function rechercheEntreprise($type, $criteres, $position = 0, $nbRep = 20, $maxRep = 200, $pertinence = false, $avecSiren = false)
|
2010-09-15 16:18:38 +00:00
|
|
|
{
|
2010-09-21 15:19:32 +00:00
|
|
|
//Enregistrement des accès à la requête getIdentite
|
|
|
|
Zend_Registry::get('WsLogger')->info("rechercheEntreprise - ip:".
|
2010-09-22 07:22:40 +00:00
|
|
|
$_SERVER['REMOTE_ADDR'].", login:".$_SERVER['PHP_AUTH_USER']);
|
2010-09-21 15:19:32 +00:00
|
|
|
switch ($type)
|
|
|
|
{
|
|
|
|
case 'ent':
|
|
|
|
$entCriteres = new CriteresEntreprise();
|
|
|
|
$entCriteres = $criteres->elementEntreprise;
|
|
|
|
$client = new SoapClient($this->wsdl, $this->wsdlOptions);
|
2010-09-23 16:20:08 +00:00
|
|
|
$identifiant = $entCriteres->identifiant;
|
|
|
|
$typeId = '';
|
|
|
|
if ($identifiant!='') {
|
|
|
|
$len = strlen($identifiant);
|
|
|
|
//Numéro WALDEC
|
|
|
|
if (strtoupper(substr($identifiant,0,1))=='W') {
|
|
|
|
$typeId = 'W';
|
|
|
|
//Code ISIN
|
|
|
|
} elseif ($len==12){
|
|
|
|
$typeId = 'I';
|
|
|
|
//TVA Intracommunautaire
|
|
|
|
} elseif (in_array(substr($identifiant,0,2),
|
|
|
|
array('AT','BE','BG','CY','CZ','DE','DK','EE','EL','ES',
|
|
|
|
'FI','GB','HU','IE','IT','LT','LU','LV','MT','NL','PL',
|
|
|
|
'PT','RO','SE','SI','SK'))){
|
|
|
|
//"La recherche par numéro de TVA n'est pas encore possible sur ce pays !";
|
|
|
|
//Pour la france
|
|
|
|
} elseif (substr($identifiant,0,2)=='FR') {
|
|
|
|
$typeId = 'S';
|
|
|
|
if ($len==13) $identifiant = substr($identifiant,4,9);
|
|
|
|
else $identifiant = '';
|
|
|
|
//Numéro RC
|
|
|
|
} elseif (preg_match('/A|B|C|D/i', $identifiant)) {
|
|
|
|
$typeId='R';
|
|
|
|
//Siren normal on enleve tout ce qui n'est pas un chiffre
|
|
|
|
} else {
|
|
|
|
$typeId = 'S';
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if (in_array($typeId, array('R', 'W', 'I'))){
|
|
|
|
try {
|
|
|
|
$O = $client->searchAutreId(
|
|
|
|
$typeId,
|
|
|
|
$identifiant,
|
|
|
|
empty($position) ? 0 : $position,
|
|
|
|
empty($nbRep) ? 20 : $nbRep,
|
|
|
|
empty($maxRep) ? 200 : $maxRep,
|
|
|
|
$entCriteres->codePostal
|
|
|
|
);
|
|
|
|
} catch (SoapFault $fault) {
|
|
|
|
Zend_Registry::get('WsLogger')->err("rechercheEntreprise - ".serialize($criteres));
|
|
|
|
}
|
|
|
|
} elseif ($typeId == 'S'){
|
|
|
|
try {
|
|
|
|
$O = $client->searchSiren(
|
|
|
|
$identifiant,
|
|
|
|
empty($position) ? 0 : $position,
|
|
|
|
empty($nbRep) ? 20 : $nbRep,
|
|
|
|
empty($maxRep) ? 200 : $maxRep,
|
|
|
|
$entCriteres->codePostal
|
|
|
|
);
|
|
|
|
} catch (SoapFault $fault) {
|
|
|
|
Zend_Registry::get('WsLogger')->err("rechercheEntreprise - ".serialize($criteres));
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
|
|
|
|
try {
|
|
|
|
$O = $client->searchNomAdr(
|
|
|
|
$entCriteres->raisonSociale,
|
|
|
|
$entCriteres->adresse,
|
|
|
|
$entCriteres->codePostal,
|
|
|
|
$entCriteres->ville,
|
|
|
|
empty($entCriteres->siege) ? false : $entCriteres->siege,
|
|
|
|
empty($entCriteres->actif) ? false : $entCriteres->actif,
|
|
|
|
empty($position) ? 0 : $position,
|
|
|
|
empty($nbRep) ? 20 : $nbRep,
|
|
|
|
empty($maxRep) ? 200 : $maxRep,
|
|
|
|
empty($pertinence) ? false : $pertinence,
|
|
|
|
empty($avecSiren) ? false : $avecSiren,
|
|
|
|
$entCriteres->naf
|
|
|
|
);
|
|
|
|
} catch (SoapFault $fault) {
|
|
|
|
Zend_Registry::get('WsLogger')->err("rechercheEntreprise - ".serialize($criteres));
|
|
|
|
}
|
2010-09-21 15:19:32 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
break;
|
|
|
|
case 'dir':
|
|
|
|
$dirCriteres = new CriteresDirigeant();
|
|
|
|
$dirCriteres = $criteres->elementDirigeant;
|
|
|
|
$client = new SoapClient($this->wsdl, $this->wsdlOptions);
|
|
|
|
try {
|
|
|
|
$O = $client->searchDir(
|
|
|
|
$dirCriteres->dirNom,
|
|
|
|
$dirCriteres->dirPrenom,
|
|
|
|
$dirCriteres->dirDateNaiss,
|
|
|
|
$dirCriteres->dirVille,
|
2010-09-23 16:20:08 +00:00
|
|
|
empty($position) ? 0 : $position,
|
2010-09-21 15:19:32 +00:00
|
|
|
empty($nbRep) ? 20 : $nbRep,
|
|
|
|
empty($maxRep) ? 200 : $maxRep,
|
|
|
|
empty($pertinence) ? false : $pertinence
|
|
|
|
);
|
|
|
|
} catch (SoapFault $fault) {
|
|
|
|
Zend_Registry::get('WsLogger')->err("rechercheEntreprise - ".serialize($criteres));
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
2010-09-15 16:18:38 +00:00
|
|
|
$error = new ErrorType();
|
2010-09-21 15:19:32 +00:00
|
|
|
$error = arrayToClass($O['error'], 'ErrorType');
|
|
|
|
$results = new RechercheEntrepriseResult();
|
|
|
|
$results = arrayToClass($O['results'], 'RechercheEntrepriseResult');
|
2010-09-15 16:18:38 +00:00
|
|
|
$outputParams = new RechercheEntrepriseReturnType();
|
|
|
|
$outputParams->error = $error;
|
|
|
|
$outputParams->results = $results;
|
|
|
|
return $outputParams;
|
2010-09-08 13:40:57 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
2010-10-14 14:08:04 +00:00
|
|
|
* Retourne le statut du webservice
|
2010-09-24 07:16:49 +00:00
|
|
|
* @return StatusReturnType
|
2010-09-08 13:40:57 +00:00
|
|
|
*/
|
2010-09-15 16:18:38 +00:00
|
|
|
function status()
|
|
|
|
{
|
2010-09-13 09:54:49 +00:00
|
|
|
/* @todo tester les différents éléments qui peuvent conduire
|
|
|
|
* à un problème dans les services tel que la connexion à la
|
|
|
|
* base de données, l'accès FTP, l'accès HTTP, l'accès système de fichier
|
2010-09-08 13:40:57 +00:00
|
|
|
*/
|
2010-09-23 16:20:08 +00:00
|
|
|
|
|
|
|
//Enregistrement des accès à la requête getIdentite
|
|
|
|
Zend_Registry::get('WsLogger')->info("status - ip:".
|
|
|
|
$_SERVER['REMOTE_ADDR'].", login:".$_SERVER['PHP_AUTH_USER'].
|
|
|
|
", hash:".$_SERVER['PHP_AUTH_PW']);
|
|
|
|
|
2010-09-24 07:16:49 +00:00
|
|
|
$error = new StatusReturnType();
|
2010-09-23 16:20:08 +00:00
|
|
|
$error->statusCode = 0;
|
|
|
|
$error->statusMsg = 'Services disponible (beta)';
|
2010-09-08 13:40:57 +00:00
|
|
|
return $error;
|
|
|
|
}
|
|
|
|
|
2010-08-30 07:49:44 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
?>
|