731 lines
30 KiB
PHP
731 lines
30 KiB
PHP
<?php
|
|
require_once 'framework/fwk.php';
|
|
require_once 'framework/mail/sendMail.php';
|
|
require_once 'Metier/insee/classMInsee.php';
|
|
require_once 'Metier/insee/classMSirene.php';
|
|
require_once 'Metier/partenaires/classMBilans.php';
|
|
require_once 'Metier/partenaires/classMBourse.php';
|
|
require_once 'Metier/partenaires/classMTva.php';
|
|
require_once 'Metier/partenaires/classMMap.php';
|
|
require_once 'Metier/partenaires/classMGreffes.php';
|
|
require_once 'Metier/partenaires/classMPrivileges.php';
|
|
require_once 'Metier/partenaires/classMLiens2.php';
|
|
require_once 'Metier/scores/classMFinancier.php';
|
|
require_once 'Metier/scores/classMSolvabilite.php';
|
|
|
|
require_once __DIR__ . '/Types.php';
|
|
|
|
class Entreprise extends Scores_Ws_Server
|
|
{
|
|
/**
|
|
* Retourne les informations identitaires de l'entreprise ou de l'établissement demandé
|
|
* @param string $siret Siren de l'entreprise ou siret de l'établissement
|
|
* @param int $id Identifiant interne
|
|
* @return Identite
|
|
*/
|
|
public function getIdentite($siret, $id = 0)
|
|
{
|
|
$this->authenticate();
|
|
$this->permission('identite');
|
|
|
|
//Initialisation
|
|
if (empty($id)) { $id = 0; }
|
|
$forceVerif = false;
|
|
|
|
$tabRet = array();
|
|
$len = strlen($siret);
|
|
$siren = substr($siret,0,9);
|
|
if ($len == 14) {
|
|
$nic = substr($siret,9,5)*1;
|
|
} elseif ($len == 9) {
|
|
$nic = 0;
|
|
}
|
|
|
|
if ($siren*1==0 && $id==0) {
|
|
$this->sendError('1010');
|
|
} elseif ($len!=14 && $len!=9) {
|
|
$this->sendError('1020');
|
|
}
|
|
|
|
$db = new WDB();
|
|
|
|
$iInsee = new MInsee($db);
|
|
$entrep = $iInsee->getIdentiteEntreprise($siren, $nic, $id, $forceVerif);
|
|
if (empty($entrep) || empty($entrep['id']) ) {
|
|
$this->sendError('1020');
|
|
}
|
|
|
|
$identite = new Identite();
|
|
$identite->id = $entrep['id'];
|
|
$identite->Siret = $entrep['Siret'];
|
|
$identite->SiretSiege = $entrep['SiretSiege'];
|
|
$identite->Siege = $entrep['Siege'];
|
|
$identite->AncienSiege = $entrep['AncienSiege'];
|
|
$identite->AncienSiegeDateFin = $entrep['AncienSiegeDateFin'];
|
|
$identite->TribunalCode = prepareString($entrep['Tribunal']);
|
|
$identite->TribunalLib = prepareString($entrep['TribunalLib']);
|
|
$identite->NumRC = $entrep['numRC'];
|
|
$identite->Actif = $entrep['Actif'];
|
|
$identite->ActifEco = $entrep['ActifEco'];
|
|
$identite->ActifEcoDate = $entrep['ActifEcoDate'];
|
|
$identite->ActifEcoType = $entrep['ActifEcoType'];
|
|
$identite->EntActiveRCS = $entrep['EntActiveRCS'];
|
|
$identite->AutreId = $entrep['AutreId'];
|
|
$identite->Source = $entrep['Source'];
|
|
$identite->SourceId = $entrep['SourceId'];
|
|
$identite->Isin = $entrep['Isin'];
|
|
$identite->Nom = $entrep['NOMEN_LONG'];
|
|
if (empty($identite->Nom)) {
|
|
$identite->Nom = prepareString(strtr($entrep['Nom'],'/*',' '));
|
|
}
|
|
$identite->Nom2 = prepareString($entrep['Nom2']);
|
|
$identite->NomLong = prepareString($entrep['nomLong']);
|
|
$identite->NomCommercial = prepareString($entrep['NomCommercial']);
|
|
$identite->Siret = $entrep['Siret'];
|
|
$identite->Sigle = prepareString($entrep['Sigle']);
|
|
$identite->SigleLong = prepareString($entrep['sigleLong']);
|
|
$identite->Enseigne = prepareString($entrep['Enseigne']);
|
|
$identite->EnseigneLong = prepareString($entrep['enseigneLong']);
|
|
$identite->Adresse = prepareString($entrep['Adresse']);
|
|
$identite->Adresse2 = prepareString($entrep['Adresse2']);
|
|
$identite->AdresseNum = prepareString($entrep['AdresseNum']);
|
|
$identite->AdresseBtq = prepareString($entrep['AdresseBtq']);
|
|
$identite->AdresseVoie = prepareString($entrep['AdresseVoie']);
|
|
$identite->AdresseRue = prepareString($entrep['AdresseRue']);
|
|
$identite->CP = $entrep['CP'];
|
|
$identite->Ville = prepareString($entrep['Ville']);
|
|
$identite->Pays = prepareString($entrep['Pays']);
|
|
$identite->PaysIso2 = $entrep['PaysIso2'];
|
|
$identite->AdresseDom = $entrep['AdresseDom'];
|
|
|
|
$tabAdresseDomEnt = array();
|
|
if (isset($entrep['AdresseDomEnt']) && count($entrep['AdresseDomEnt'])>0){
|
|
foreach ($entrep['AdresseDomEnt'] as $element){
|
|
$adresseDomEnt = new AdresseDomEnt();
|
|
$adresseDomEnt->siren = $element['siren'];
|
|
$adresseDomEnt->nom = $element['nom'];
|
|
$tabAdresseDomEnt[] = $adresseDomEnt;
|
|
}
|
|
}
|
|
$identite->AdresseDomEnt = $tabAdresseDomEnt;
|
|
$identite->AdresseDomNb = $entrep['AdresseDomNb'];
|
|
|
|
// --- Indicateur Adresse RNVP
|
|
try {
|
|
$rnvpM = new Application_Model_VillesRnvpSources();
|
|
$sql = $rnvpM->select(true)->columns(array('dateRetourRnvp','codeRetour'))
|
|
->where('source=?', $entrep['Source'])->where('source_id=?', $entrep['SourceId']);
|
|
$rnvpResult = $rnvpM->fetchRow($sql);
|
|
if ($rnvpResult !== null) {
|
|
$identite->AdresseRnvpDate = $rnvpResult->dateRetourRnvp;
|
|
$identite->AdresseRnvpCode = $rnvpResult->codeRetour;
|
|
}
|
|
} catch (Zend_Db_Exception $e) {}
|
|
|
|
|
|
$identite->Civilite = $entrep['Civilite'];
|
|
$identite->NbEtab = $entrep['NbEtab'];
|
|
$identite->Tel = prepareString($entrep['Tel']);
|
|
$identite->Fax = prepareString($entrep['Fax']);
|
|
$identite->Web = prepareString($entrep['Web']);
|
|
$identite->Mail = prepareString($entrep['Mail']);
|
|
$identite->GeoLat = $entrep['GeoLat'];
|
|
$identite->GeoLon = $entrep['GeoLon'];
|
|
$identite->GeoPrecis = $entrep['GeoPrecis'];
|
|
|
|
$geoInfos = new GeoInfos();
|
|
$geoInfos->CUCS = $entrep['GeoInfos']['CUCS'];
|
|
$geoInfos->NCUCS = $entrep['GeoInfos']['NCUCS'];
|
|
$geoInfos->ZRU = $entrep['GeoInfos']['ZRU'];
|
|
$geoInfos->NZRU = $entrep['GeoInfos']['NZRU'];
|
|
$geoInfos->ZFU = $entrep['GeoInfos']['ZFU'];
|
|
$geoInfos->NZFU = $entrep['GeoInfos']['NZFU'];
|
|
$geoInfos->ZUS = $entrep['GeoInfos']['ZUS'];
|
|
$geoInfos->NZUS = $entrep['GeoInfos']['NZUS'];
|
|
$geoInfos->AFR = $entrep['GeoInfos']['AFR'];
|
|
$geoInfos->NAFR = $entrep['GeoInfos']['NAFR'];
|
|
$geoInfos->ZRR = $entrep['GeoInfos']['ZRR'];
|
|
$geoInfos->NZRR = $entrep['GeoInfos']['NZRR'];
|
|
$identite->GeoInfos = $geoInfos;
|
|
|
|
$identite->TvaNumero = $entrep['TvaNumero'];
|
|
$identite->TvaAttribue = $entrep['TvaAttribue'];
|
|
$identite->FJ = $entrep['FJ'];
|
|
$identite->FJ_Lib = $entrep['FJ_lib'];
|
|
$identite->FJ2 = $entrep['FJ2'];
|
|
$identite->FJ2_Lib = $entrep['FJ2_Lib'];
|
|
$identite->Siren = $entrep['Siren'];
|
|
$identite->Nic = $entrep['Nic'];
|
|
$identite->NafEnt = $entrep['NafEnt'];
|
|
$identite->NafEntLib = $entrep['NafEntLib'];
|
|
$identite->NafEtab = $entrep['NafEtab'];
|
|
$identite->NafEtabLib = $entrep['NafEtabLib'];
|
|
$identite->NaceEtab = $entrep['NaceEtab'];
|
|
$identite->NaceEnt = $entrep['NaceEnt'];
|
|
$identite->Nafa = $entrep['APRM'];
|
|
$identite->NafaLib = prepareString($entrep['APRM_Lib']);
|
|
$identite->NumRM = $entrep['NumRM'];
|
|
$identite->Activite = $entrep['Activite'];
|
|
$identite->Capital = $entrep['Capital'];
|
|
$identite->CapitalDev = $entrep['CapitalDev'];
|
|
$identite->CapitalLib = $entrep['CapitalLib'];
|
|
$identite->CapitalType = prepareString($entrep['CapitalType']);
|
|
|
|
$classWdate = new WDate();
|
|
$identite->DateCreaEt = $classWdate->dateT('Ymd','Y-m-d',$entrep['DateCreaEt']);
|
|
$identite->DateCreaEn = $classWdate->dateT('Ymd','Y-m-d',$entrep['DateCreaEn']);
|
|
$identite->DateClotEt = $entrep['DateClotEt']; //@todo : date
|
|
$identite->DateImmat = $entrep['dateImmat'];
|
|
$identite->DateRadiation = $entrep['dateRad'];
|
|
$identite->EffEnTr = $entrep['EffEnTr'];
|
|
$identite->EffEnTrLib = $entrep['EffEnTrLib'];
|
|
$identite->Effectif = $entrep['Effectif'];
|
|
$identite->EffEtTr = $entrep['EffEtTr'];
|
|
$identite->EffEtTrLib = $entrep['EffEtTrLib'];
|
|
$identite->EffectifEtab = $entrep['EffectifEtab'];
|
|
$identite->Dept = $entrep['Dept'];
|
|
$identite->codeCommune = prepareString($entrep['codeCommune']);
|
|
$identite->AnneeEffEn = $entrep['AnneeEffEn'];
|
|
$identite->AnneeEffEt = $entrep['AnneeEffEt'];
|
|
$identite->AnneeTCA = $entrep['AnneeTCA'];
|
|
$identite->TrancheCA = $entrep['TrancheCA'];
|
|
$identite->TrancheCALib = $entrep['TrancheCALib'];
|
|
$identite->TrancheCAType = $entrep['TrancheCAType'];
|
|
$identite->dir1Code = $entrep['dir1Code'];
|
|
$identite->dir1Titre = prepareString($entrep['dir1Titre']);
|
|
$identite->dir1NomPrenom = prepareString($entrep['dir1NomPrenom']);
|
|
$identite->dir1DateFct = prepareString($entrep['dir1DateFct']); //@todo : date
|
|
$identite->dir1DateNaiss = $entrep['dir1DateNaiss']; //@todo : date
|
|
$identite->dir1LieuNaiss = prepareString($entrep['dir1LieuNaiss']);
|
|
$identite->dir2Code = $entrep['dir2Code'];
|
|
$identite->dir2Titre = prepareString($entrep['dir2Titre']);
|
|
$identite->dir2NomPrenom = prepareString($entrep['dir2NomPrenom']);
|
|
$identite->dir2DateFct = $entrep['dir2DateFct']; //@todo : date
|
|
$identite->dir2DateNaiss = prepareString($entrep['dir2DateNaiss']); //@todo : date
|
|
$identite->dir2LieuNaiss = prepareString($entrep['dir2LieuNaiss']);
|
|
$identite->Rivoli = $entrep['Rivoli'];
|
|
|
|
$identite->InfosIris = new stdClass();
|
|
$identite->InfosIris->codIris = $entrep['InfosIris']['codIris'];
|
|
$identite->InfosIris->codComIris = $entrep['InfosIris']['codComIris'];
|
|
$identite->InfosIris->libIris = prepareString($entrep['InfosIris']['libIris']);
|
|
$identite->InfosIris->typIris = prepareString($entrep['InfosIris']['typIris']);
|
|
$identite->InfosIris->evoIris = $entrep['InfosIris']['evoIris'];
|
|
$identite->InfosIris->trIris = $entrep['InfosIris']['trIris'];
|
|
$identite->InfosIris->grdQuartier = $entrep['InfosIris']['grdQuartier'];
|
|
|
|
$identite->NatureActivite = $entrep['NatureActivite']; // Nature de l'activité
|
|
$identite->OrigineCreation = $entrep['OrigineCreation']; // Origine de la création
|
|
$identite->TypeExploitation = $entrep['TypeExploitation'];
|
|
$identite->Auxiliaire = $entrep['Auxiliaire']; // 1=Auxiliaire / 0=Non auxiliaire
|
|
$identite->Saisonnalite = $entrep['Saisonnalite']; // P=Activité permanente / S=Activité saisonnière
|
|
$identite->SurfaceMagasin = $entrep['ACTISURF']*1; // 0=N/D, 1=inf. à 300m2,2=300 à 400m2, 3=400 à 2500m2, 4=sup. à 2500m2
|
|
$identite->SituationJuridique = $entrep['SituationJuridique'];
|
|
|
|
$identite->Bilan = new stdClass();
|
|
$identite->Bilan->Millesime = $entrep['bilanAnnee'];
|
|
$identite->Bilan->Cloture = $entrep['bilanDate']; //@todo : date
|
|
$identite->Bilan->Duree = $entrep['bilanMois'];
|
|
$identite->Bilan->Devise = $entrep['bilanDevise'];
|
|
$identite->Bilan->Capital = $entrep['bilanDA'];
|
|
$identite->Bilan->CA = $entrep['bilanFL'];
|
|
$identite->Bilan->CAestime = $entrep['bilanFLestime'];
|
|
$identite->Bilan->Resultat = prepareString($entrep['bilanHN']);
|
|
$identite->Bilan->Effectif = $entrep['bilanYP'];
|
|
|
|
$iBourse = new MBourse($siren, $db);
|
|
$bourse = $iBourse->getInfosBourse($siren);
|
|
if (count($bourse) > 0 ) {
|
|
$identite->Bourse->placeCotation = $bourse['placeCotation'];
|
|
$identite->Bourse->nombreTitres = $bourse['nombreTitres'];
|
|
$identite->Bourse->capitalisation = $bourse['close'] * $bourse['nombreTitres'];
|
|
$identite->Bourse->derCoursDate = $bourse['date']; //@todo : date
|
|
$identite->Bourse->derCoursCloture = $bourse['close']; //@todo : date
|
|
}
|
|
|
|
$tabAutreSiren = array();
|
|
if (isset($entrep['AutreSiren'])) {
|
|
$autreSiren = new AutreSiren();
|
|
$autreSiren->siren = $entrep['AutreSiren']['listeSiren']['siren'];
|
|
$autreSiren->type = $entrep['AutreSiren']['listeSiren']['type'];
|
|
$tabAutreSiren[] = $autreSiren;
|
|
}
|
|
$identite->AutreSiren = $tabAutreSiren;
|
|
|
|
$tabAutreSiret = array();
|
|
if (count($entrep['AutreSiret'])) {
|
|
foreach($entrep['AutreSiret'] as $type => $item) {
|
|
$autreSiret = new AutreSiret();
|
|
$autreSiret->type = $type;
|
|
$autreSiret->siren = $item['siren'];
|
|
$autreSiret->nic = $item['nic'];
|
|
$autreSiret->apeEtab = $item['apeEtab'];
|
|
$autreSiret->codeEve = $item['codeEve'];
|
|
$autreSiret->dateEve = $item['dateEve'];
|
|
$autreSiret->adrL1 = $item['adrL1'];
|
|
$autreSiret->adrL2 = $item['adrL2'];
|
|
$autreSiret->adrL3 = $item['adrL3'];
|
|
$autreSiret->adrL4 = $item['adrL4'];
|
|
$autreSiret->adrL5 = $item['adrL5'];
|
|
$autreSiret->adrL6 = $item['adrL6'];
|
|
$autreSiret->adrL7 = $item['adrL7'];
|
|
$autreSiret->depCom = $item['depCom'];
|
|
$autreSiret->rivoli = $item['rivoli'];
|
|
$autreSiret->siege = $item['siege'];
|
|
$autreSiret->destinat = $item['destinat'];
|
|
$autreSiret->typEtab = $item['typeEtab'];
|
|
$autreSiret->origine = $item['origine'];
|
|
$tabAutreSiret[] = $autreSiret;
|
|
}
|
|
}
|
|
$identite->AutreSiret = $tabAutreSiret;
|
|
|
|
$identite->DateMajINSEE = $entrep['DateMajINSEE']; //@todo : date
|
|
$identite->DateMajRCS = $entrep['DateMajRCS']; //@todo : date
|
|
$identite->DateMajBILAN = $entrep['bilanDateMaj']; //@todo : date
|
|
$identite->DateMajANN = $entrep['dateMajANN']; //@todo : date
|
|
$identite->DateMajID = $entrep['dateMajIdentite']; //@todo : date
|
|
|
|
// --- Ancien NAF
|
|
if (preg_match('/NAF4/i', $this->User->pref)) {
|
|
$entrep2 = $iInsee->getNaf4($siren, $nic, $id);
|
|
if ( $entrep2 !== false ) {
|
|
$identite->Naf4Ent = $entrep2['apen4'];
|
|
$identite->Naf4Etab = $entrep2['apet4'];
|
|
$identite->Naf4EntLib = prepareString($entrep2['apen4_lib']);
|
|
$identite->Naf4EtabLib = prepareString($entrep2['apet4_lib']);
|
|
}
|
|
}
|
|
|
|
// --- Détermination du groupe - Tête de groupe
|
|
if (intval($siren) > 100) {
|
|
$lienM = new MLiens2($siren, 'siren');
|
|
$grpHeadId = $lienM->getHead(null, 50);
|
|
$grpFiche = $lienM->getIdentity();
|
|
if ($grpFiche->id != $grpHeadId) {
|
|
$grpHeadFiche = $lienM->getIdentity($grpHeadId);
|
|
$identite->GroupeId = str_pad($grpHeadFiche->id, 20, 0, STR_PAD_LEFT); // Ajouter source
|
|
$identite->GroupeName = $grpHeadFiche->RS;
|
|
// --- Recherche code Isin
|
|
$nbIdNum = 3;
|
|
for ($i=0;$i<$nbIdNum;$i++) {
|
|
if( !empty($grpHeadFiche->{'idLoc'.$i.'Num'}) && $grpHeadFiche->{'idLoc'.$i.'Type'} == 63 ) {
|
|
$identite->GroupeIsin = $grpHeadFiche->{'idLoc'.$i.'Num'};
|
|
break;
|
|
}
|
|
}
|
|
$identite->GroupeCountryCode = $grpHeadFiche->adresse_pays;
|
|
if (!empty($grpHeadFiche->adresse_pays)) {
|
|
try {
|
|
$countryM = new Application_Model_JoTabPays();
|
|
$sql = $countryM->select()->from($countryM, array('codPays3', 'libPays'));
|
|
$result = $countryM->fetchAll($sql);
|
|
} catch (Zend_Db_Adapter_Exception $e) {}
|
|
|
|
$tabPays = array();
|
|
if ( $result->count()>0 ) {
|
|
foreach ( $result as $item ) {
|
|
$tabPays[$item->codPays3] = $item->libPays;
|
|
}
|
|
}
|
|
$libPays = '';
|
|
if ($grpHeadFiche->adresse_pays!='') {
|
|
$libPays = array_key_exists($grpHeadFiche->adresse_pays, $tabPays) ?
|
|
$tabPays[$grpHeadFiche->adresse_pays] : $grpHeadFiche->adresse_pays;
|
|
} else {
|
|
$libPays = $tabPays['FRA'];
|
|
}
|
|
$identite->GroupeCountryLabel = $libPays;
|
|
}
|
|
}
|
|
}
|
|
|
|
$this->wsLog('identite', $siret, $id);
|
|
|
|
return $identite;
|
|
}
|
|
|
|
/**
|
|
* Avis RNCS
|
|
* @param string $siren
|
|
* @return AvisRncs
|
|
*/
|
|
public function getAvisRncs($siren)
|
|
{
|
|
$this->authenticate();
|
|
$this->permission('avisrncs');
|
|
|
|
$len = strlen($siren);
|
|
if ( $len != 9 ) {
|
|
$this->sendError('1020');
|
|
}
|
|
|
|
$output = new AvisRncs();
|
|
$iDb = new WDB();
|
|
$rncs = new MRncs($iDb);
|
|
|
|
//jo.etablissements => insee uniquement, rncs ?
|
|
|
|
//Entreprise
|
|
$infosEtab = $rncs->getIdentiteEtab($siren);
|
|
if ( $infosEtab === false ) {
|
|
throw new SoapFault('MSG', "Cette entreprise n'est pas inscrite au RNCS ou radié depuis plus de 5 ans.");
|
|
}
|
|
|
|
$output->Nom = $infosEtab['raisonSociale']; //@todo personne physique
|
|
$output->Sigle = $infosEtab['sigle'];
|
|
$output->Enseigne = $infosEtab['enseigne'];
|
|
$output->NomCommercial = $infosEtab['nomCommercial'];
|
|
|
|
$output->Siren = $infosEtab['siren'];
|
|
$output->NumGest = $infosEtab['numRC'];
|
|
$output->RadiationDate = $infosEtab['dateRad'];
|
|
$output->ImmatDate = $infosEtab['dateImma'];
|
|
$output->NafCode = $infosEtab['nafEnt'];
|
|
$output->NafLabel = $infosEtab['nafEntLib'];
|
|
|
|
if (empty($infosEtab['dateRad']) || $infosEtab['dateRad'] = '0000-00-00') {
|
|
$output->TribunalCode = $infosEtab['triCode']; //@todo
|
|
$output->TribunalLabel = $infosEtab['libGreffe']; // @todo
|
|
$output->FjCode = $infosEtab['cj'];
|
|
$output->FjLabel = $infosEtab['cjLib'];
|
|
$output->Capital = $infosEtab['capital'];
|
|
$output->CapitalDev = 'EUR';
|
|
if ( !empty($infosEtab['capitalDevIso'])) {
|
|
$output->CapitalDev = $infosEtab['capitalDevIso'];
|
|
}
|
|
$output->CapitalType = $infosEtab['capitalType'];
|
|
|
|
$output->SiegeAdresseNum = intval($infosEtab['adrNumVoie']);
|
|
$output->SiegeAdresseBtq = $infosEtab['adrIndRep'];
|
|
$output->SiegeAdresseVoieType = $infosEtab['adrTypeVoie'] ;
|
|
$output->SiegeAdresseVoieLabel = $infosEtab['adrVoie'];
|
|
$output->SiegeAdresseComp = $infosEtab['adrComp'];
|
|
$output->SiegeAdresseCP = $infosEtab['cp'];
|
|
$output->SiegeAdresseVille = $infosEtab['commune'];
|
|
|
|
$output->DateMajRCS = $infosEtab['DateMajRCS'];
|
|
|
|
//Durée de la société - impossible
|
|
$output->DureeDate = '';
|
|
|
|
//Date du dernier bilan - MOIS/JOUR au pire chercher dans l'annonce
|
|
try {
|
|
$bilanM = new Application_Model_JoBilans();
|
|
$sql = $bilanM->select(true)
|
|
->columns(array('dateExercice'))
|
|
->where('siren=?', $siren)
|
|
->order('dateExercice DESC')->limit(1);
|
|
$result = $bilanM->fetchRow($sql);
|
|
if ($result !== null) {
|
|
$output->CompteArretMois = substr($result->dateExercice,4,2);
|
|
$output->CompteArretJour = substr($result->dateExercice,6,2);
|
|
}
|
|
} catch(Zend_Db_Exception $e) {}
|
|
|
|
//=> Avec l'adresse du premier siège
|
|
$output->ConstitutionTribunalCode = '';
|
|
$output->ConstitutionTribunalLabel = '';
|
|
|
|
$iInsee = new MInsee($iDb);
|
|
$dirs = $iInsee->getDirigeants($siren, false);
|
|
$liste = array();
|
|
foreach ($dirs as $nb => $dir)
|
|
{
|
|
$dirigeant = new AvisRncsAdmin();
|
|
|
|
$dirigeant->Code = $dir['Fonction'];
|
|
$dirigeant->Label = $dir['Titre'];
|
|
$dirigeant->CompanyName = $dir['Societe'];
|
|
$dirigeant->CompanyId = (array_key_exists('Siren', $dir) && intval($dir['Siren'])!=0) ? $dir['Siren'] : '' ;
|
|
$dirigeant->Civilite = $dir['Civilite'];
|
|
$dirigeant->Nom = $dir['Nom'];
|
|
$dirigeant->Prenom = $dir['Prenom'];
|
|
$dirigeant->NomUsage = $dir['NomUsage'];
|
|
$dirigeant->NaissanceDate = $dir['NaissDate'];
|
|
$dirigeant->NaissanceVille = $dir['NaissVille'];
|
|
$dirigeant->NaissanceCp = $dir['NaissDepPays'];
|
|
$liste[] = $dirigeant;
|
|
}
|
|
$output->Administration = $liste;
|
|
|
|
$insee = $iInsee->getIdentiteEntreprise($siren);
|
|
|
|
//Origine, code à transformer - getIdentiteEntreprise - insee
|
|
$output->Origine = $insee['OrigineCreation'];
|
|
|
|
//Activité réelle - getIdentiteEntreprise - insee
|
|
$output->Activite = $insee['Activite'];
|
|
$output->BodaccActivite = $insee['Activite'];
|
|
|
|
//Date de création à l'insee - getIdentiteEntreprise - insee
|
|
//@todo : Aller cherche dans les annonces bodacc création + acquisition
|
|
$output->ActiviteDate = substr($insee['DateCreaEn'],0,4).'-'.substr($insee['DateCreaEn'],4,2).'-'.substr($insee['DateCreaEn'],6,2);
|
|
|
|
//Type d'exploitation - getIdentiteEntreprise - insee
|
|
$output->Exploitation = $insee['TypeExploitation'];
|
|
|
|
//Liste des jugements
|
|
$output->Evenements = array();
|
|
$evens = $rncs->getListeJugements($siren);
|
|
if ( count($evens)>0 ) {
|
|
foreach ( $evens as $even ) {
|
|
$output->Evenements[] = $even['dateEffet'] . ' - ' . $even['libEven'];
|
|
}
|
|
}
|
|
|
|
//Liste des dépots
|
|
$output->Depots = array();
|
|
$infogreffe = new SdMetier_Infogreffe_DocAC($siren);
|
|
$depots = $infogreffe->getList();
|
|
if ( count($depots)>0 ) {
|
|
$i = 0;
|
|
$listNumDepot = array();
|
|
foreach ( $depots as $depot ) {
|
|
$acte = new AvisRncsDepot();
|
|
$acte->DepotNum = $depot->DepotNum;
|
|
$acte->DepotDate = $depot->DepotDate;
|
|
$acte->ActeNum = $depot->ActeNum;
|
|
$acte->ActeDate = $depot->ActeDate;
|
|
$acte->ActeType = $depot->ActeType;
|
|
$acte->ActeTypeLabel = $depot->ActeTypeLabel;
|
|
$acte->infos = $depot->infos;
|
|
$result = $rncs->getListeDepots($siren, $depot->DepotDate);
|
|
if (count($result)>0) {
|
|
foreach ($result as $infos) {
|
|
$acte->infos[] = $infos['libDepot'];
|
|
}
|
|
}
|
|
|
|
//Acte constitutif - Statut
|
|
//@todo : STATUTS CONSTITUTIFS
|
|
$date = substr($depot->ActeDate,0,4);
|
|
if ( in_array($depot->ActeType, array('04')) && intval($date)>1995 ) {
|
|
$output->ConstitutionActeDate = $depot->ActeDate;
|
|
$output->ConstitutionDepotDate = $depot->DepotDate;
|
|
}
|
|
|
|
$i++;
|
|
if ($i < 4 || $i > count($depots)-4) {
|
|
$output->Depots[] = $acte;
|
|
}
|
|
}
|
|
}
|
|
|
|
|
|
//Liste des établissements actifs au RNCS
|
|
$output->Etablissements = array();
|
|
$result = $iInsee->getEtablissements($siren, '', 0, 200, 200, 0, 1);
|
|
if ( count($result['reponses'])>0 ) {
|
|
foreach ( $result['reponses'] as $item ) {
|
|
$output->Etablissements[] = $item['Adresse'] . ' ' . $item['Adresse2'] . ' - ' .
|
|
$item['CP'] . ' ' . strtoupper($item['Ville']);
|
|
}
|
|
}
|
|
}
|
|
|
|
$this->wsLog('avisrncs', $siren);
|
|
|
|
return $output;
|
|
}
|
|
|
|
/**
|
|
* RNVP
|
|
* @param string $companyId
|
|
* Identifiant etablissement
|
|
* @param string $type (sd|siren, sd ou null par defaut)
|
|
* Type de l'identifiant :
|
|
* sd|null = Identifiant Scores & Decisions
|
|
* siren = SIRET de l'etablissement
|
|
* @throws SoapFault
|
|
* @return Rnvp
|
|
*/
|
|
public function getRNVP($companyId, $type = null)
|
|
{
|
|
$this->authenticate();
|
|
$this->permission('RNVP');
|
|
|
|
// --- Identifiant SD : source + id
|
|
if ($type === null) {
|
|
$source = substr($companyId,0,3);
|
|
$sourceId = substr($companyId,3,20);
|
|
}
|
|
// --- Siren
|
|
elseif (strtolower($type) == 'siren') {
|
|
if ( strlen($companyId) != 14 ) {
|
|
throw new SoapFault('ERR', 'Identifiant incorrect.');
|
|
}
|
|
try {
|
|
$etabM = new Application_Model_JoEtablissements();
|
|
$sql = $etabM->select(true)->columns(array('LPAD(source,3,0)', 'LPAD(source_id,20,0)'))
|
|
->where('siren=?', substr($companyId,0,9))
|
|
->where('nic=?', substr($companyId,9,5));
|
|
$etabResult = $etabM->fetchRow($sql);
|
|
if ($etabResult === null) {
|
|
throw new SoapFault('MSG', 'Etablissement inconnu.');
|
|
}
|
|
$source = $etabResult->source;
|
|
$sourceId = $etabResult->source_id;
|
|
} catch (Zend_Db_Exception $e) {
|
|
if ($this->User->idClient==1) {
|
|
throw new SoapFault('ERR', $e->getMessage());
|
|
} else {
|
|
throw new SoapFault('ERR', "Application error");
|
|
}
|
|
}
|
|
}
|
|
// Erreur
|
|
else {
|
|
throw new SoapFault('ERR', 'type identifiant inconnu');
|
|
}
|
|
|
|
// --- Formattage pour la sortie
|
|
try {
|
|
$rnvpM = new Application_Model_VillesRnvpSources();
|
|
$sql = $rnvpM->select(true)->columns(array(
|
|
'L1rnvp',
|
|
'L2rnvp',
|
|
'L3rnvp',
|
|
'L4rnvp',
|
|
'L5rnvp',
|
|
'L6rnvp',
|
|
'L7rnvp',
|
|
'dateRetourRnvp',
|
|
'codeRetour',
|
|
'LPAD(Insee,5,0) as Insee',
|
|
'CorrectionImportante',
|
|
'CorrectionDouteuse',
|
|
'CQadrs',
|
|
'HexaCle',
|
|
'NumDept',
|
|
'IdHexavia',
|
|
'IdHexaposte',
|
|
'Iris_Rivoli',
|
|
'Iris_Ilot99',
|
|
'Iris_CodeIris',
|
|
'Iris_Canton',
|
|
'Cdx_Matricule',
|
|
'Cdx_V5Geo',
|
|
'Cdx_V6Geo',
|
|
'Cdx_V5Cdx',
|
|
'Cdx_V6Cdx',
|
|
'dateInsert',
|
|
'dateUpdate',
|
|
))->where('source=?', $source)->where('source_id=?', $sourceId);
|
|
$rnvpResult = $rnvpM->fetchRow($sql);
|
|
if ($rnvpResult === null) {
|
|
throw new SoapFault('MSG', "Aucun résultat");
|
|
}
|
|
|
|
$InfoRNVP = new Rnvp();
|
|
$InfoRNVP->L1 = $rnvpResult->L1rnvp;
|
|
$InfoRNVP->L2 = $rnvpResult->L2rnvp;
|
|
$InfoRNVP->L3 = $rnvpResult->L3rnvp;
|
|
$InfoRNVP->L4 = $rnvpResult->L4rnvp;
|
|
$InfoRNVP->L5 = $rnvpResult->L5rnvp;
|
|
$InfoRNVP->L6 = $rnvpResult->L6rnvp;
|
|
$InfoRNVP->L7 = $rnvpResult->L7rnvp;
|
|
|
|
$InfoRNVP->ProcessDate = $rnvpResult->dateRetourRnvp;
|
|
$InfoRNVP->ProcessCode = $rnvpResult->codeRetour;
|
|
switch($rnvpResult->codeRetour) {
|
|
case 'ND':
|
|
$InfoRNVP->ProcessLabel = "ND";
|
|
break;
|
|
case 'KO':
|
|
$InfoRNVP->ProcessLabel = "KO";
|
|
break;
|
|
case 'OK':
|
|
$InfoRNVP->ProcessLabel = "Adresse correcte";
|
|
if ($rnvpResult->CorrectionImportante == 'I') {
|
|
$InfoRNVP->ProcessLabel = "Adresse avec correction(s) importante(s)";
|
|
}
|
|
if ($rnvpResult->CorrectionDouteuse == 'D') {
|
|
$InfoRNVP->ProcessLabel = "Adresse mais correction(s) douteuse(s)";
|
|
}
|
|
break;
|
|
}
|
|
$InfoRNVP->QualityCode = $rnvpResult->CQadrs;
|
|
// Label CQadrs
|
|
$InfoRNVP->QualityLabel = '';
|
|
$tabCQAdrs = array(
|
|
'10' => "Adresse correcte",
|
|
'20' => "Adresse correcte (Voie non reconnue, mais il s'agit d'un cedex ou BP)",
|
|
'21' => "Petite ville, Numéro de facade hors borne.",
|
|
'22' => "Petite ville, Numéro de facade absent (le reste de l'adresse est correcte)",
|
|
'23' => "Grande ville, Numéro de facade hors borne.",
|
|
'24' => "Grande ville, Numéro de facade absent (le reste de l'adresse est correcte)",
|
|
'30' => "Petite ville, voie non reconnue",
|
|
'31' => "Petite ville, voie non reconnue (info quartier reconnu, ne permettant pas de déduire la voie)",
|
|
'40' => "Petite ville, voie absente (info quartier reconnu, ne permettant pas de déduire la voie)",
|
|
'41' => "Petite ville, voie absente",
|
|
'50' => "Grande ville, voie non reconnue",
|
|
'51' => "Grande ville, voie non reconnue (info quartier reconnu, ne permettant pas de déduire la voie)",
|
|
'60' => "Grande ville, voie absente (info quartier reconnu, ne permettant pas de déduire la voie)",
|
|
'61' => "Grande ville, voie absente",
|
|
'70' => "Cp/Ville non corrigeable (voie présente)",
|
|
'80' => "Cp/Ville non corrigeable (voie absente)",
|
|
'90' => "Etranger détecté",
|
|
);
|
|
if( array_key_exists($rnvpResult->CQadrs, $tabCQAdrs) ) {
|
|
$InfoRNVP->QualityLabel = $tabCQAdrs[$rnvpResult->CQadrs];
|
|
}
|
|
|
|
$InfoRNVP->GeoInseeCommune = $rnvpResult->Insee;
|
|
$InfoRNVP->GeoHexavia = $rnvpResult->IdHexavia;
|
|
$InfoRNVP->GeoHexapost = $rnvpResult->IdHexaposte;
|
|
$InfoRNVP->GeoHexacle = $rnvpResult->HexaCle;
|
|
$InfoRNVP->GeoDepartement = $rnvpResult->NumDept;
|
|
$InfoRNVP->GeoRivoliCode = $rnvpResult->Iris_Rivoli;
|
|
$InfoRNVP->GeoIlot = $rnvpResult->Iris_Ilot99;
|
|
$InfoRNVP->GeoIris = $rnvpResult->Iris_CodeIris;
|
|
$InfoRNVP->GeoCanton = $rnvpResult->Iris_Canton;
|
|
$InfoRNVP->CedexaMatricule = $rnvpResult->Cdx_Matricule;
|
|
$InfoRNVP->CedexaGeoL5 = $rnvpResult->Cdx_V5Geo;
|
|
$InfoRNVP->CedexaGeoL6 = $rnvpResult->Cdx_V6Geo;
|
|
$InfoRNVP->CedexaCdxL5 = $rnvpResult->Cdx_V5Cdx;
|
|
$InfoRNVP->CedexaCdxL6 = $rnvpResult->Cdx_V6Cdx;
|
|
$InfoRNVP->DateInsert = $rnvpResult->dateInsert;
|
|
$InfoRNVP->DateUpdate = $rnvpResult->dateUpdate;
|
|
|
|
$this->wsLog('rnvp', 0, $companyId);
|
|
|
|
return $InfoRNVP;
|
|
|
|
} catch (Zend_Db_Exception $e) {
|
|
if ($this->User->idClient==1) {
|
|
throw new SoapFault('ERR', $e->getMessage());
|
|
} else {
|
|
throw new SoapFault('ERR', "Application error");
|
|
}
|
|
}
|
|
}
|
|
|
|
protected function getIndiScore()
|
|
{
|
|
//Identite Light => propre à la méthode
|
|
//Indiscore
|
|
//Text
|
|
}
|
|
|
|
|
|
protected function getReportStd()
|
|
{
|
|
//Identite Light
|
|
//Synthese
|
|
//Indiscore
|
|
//Commentaires
|
|
}
|
|
|
|
|
|
protected function getReportComment()
|
|
{
|
|
//Commentaires suivant niveau enregistré dans le profil de l'utilisateur
|
|
|
|
}
|
|
|
|
protected function getValo(){}
|
|
|
|
}
|
|
|
|
?>
|