5438 lines
209 KiB
PHP
5438 lines
209 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/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');
|
|
}
|
|
|
|
$iInsee = new MInsee();
|
|
$entrep = $iInsee->getIdentiteEntreprise($siren, $nic, $id, $forceVerif);
|
|
if (empty($entrep) || empty($entrep['id']) ) {
|
|
debugLog('W', "Siren $siren non présent en base", __LINE__, __FILE__, __FUNCTION__, __CLASS__);
|
|
$this->sendError('1020');
|
|
}
|
|
|
|
$iBourse = new MBourse($siren);
|
|
$bourse = $iBourse->getInfosBourse($siren);
|
|
|
|
$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']);
|
|
//'NumGreffe' = $entrep['numGreffe'], // Ajouté le 4 08 2009
|
|
$identite->NumRC = $entrep['numRC']; // Ajouté le 4 08 2009
|
|
$identite->Actif = $entrep['Actif'];
|
|
$identite->ActifEco = $entrep['ActifEco']; // Etab éco actif, ajout le 28/04/2011
|
|
$identite->ActifEcoDate = $entrep['ActifEcoDate']; // Date si éco inactif et jur actif
|
|
$identite->ActifEcoType = $entrep['ActifEcoType']; // vide ou NPAI ou PFER ou ECOF
|
|
$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']); // Ajouté le 4 08 2009
|
|
$identite->NomCommercial = prepareString($entrep['NomCommercial']); // Ajouté le 16 11 2010
|
|
$identite->Siret = $entrep['Siret'];
|
|
$identite->Sigle = prepareString($entrep['Sigle']);
|
|
$identite->SigleLong = prepareString($entrep['sigleLong']); // Ajouté le 4 08 2009
|
|
$identite->Enseigne = prepareString($entrep['Enseigne']);
|
|
$identite->EnseigneLong = prepareString($entrep['enseigneLong']); // Ajouté le 16 11 2010
|
|
$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']); // Ajouté le 18 02 2008
|
|
$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'];
|
|
$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']; // Ajouté le 4 08 2009
|
|
$identite->FJ2_Lib = $entrep['FJ2_Lib']; // Ajouté le 4 08 2009
|
|
$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']; // Ajouté le 18 02 2008
|
|
$identite->CapitalType = prepareString($entrep['CapitalType']); // Ajouté le 4 08 2009
|
|
|
|
$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']; // Ajouté le 4 08 2009
|
|
$identite->DateRadiation = $entrep['dateRad']; // Ajouté le 4 08 2009
|
|
//'DateMajRCS' = $entrep['DateMajRCS'], // Ajouté le 4 08 2009
|
|
$identite->EffEnTr = $entrep['EffEnTr'];
|
|
$identite->EffEnTrLib = $entrep['EffEnTrLib'];
|
|
$identite->Effectif = $entrep['Effectif'];
|
|
$identite->EffEtTr = $entrep['EffEtTr']; // Ajout le 11 08 2010
|
|
$identite->EffEtTrLib = $entrep['EffEtTrLib']; // Ajout le 11 08 2010
|
|
$identite->EffectifEtab = $entrep['EffectifEtab']; // Ajout le 11 08 2010
|
|
$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 // Ajouté le 4 08 2009
|
|
$identite->dir1LieuNaiss = prepareString($entrep['dir1LieuNaiss']); // Ajouté le 4 08 2009
|
|
$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 // Ajouté le 4 08 2009
|
|
$identite->dir2LieuNaiss = prepareString($entrep['dir2LieuNaiss']); // Ajouté le 4 08 2009
|
|
$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'];
|
|
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
|
|
|
|
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']);
|
|
}
|
|
}
|
|
|
|
$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');
|
|
}
|
|
|
|
$db = Zend_Db_Table_Abstract::getDefaultAdapter();
|
|
|
|
$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;
|
|
}
|
|
|
|
/**
|
|
* 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 integer $id Identifiant S&D de l'établissement
|
|
* @return IdentiteProcol Fiche d'identité de l'établissement
|
|
*/
|
|
public function getIdentiteProcol($siret, $id=0, $forceVerif=false)
|
|
{
|
|
$this->authenticate();
|
|
$this->permission('idprocol');
|
|
|
|
debugLog('I',"Identité AGS demandée pour siret $siret (id=$id)",__LINE__,__FILE__, __FUNCTION__, __CLASS__);
|
|
|
|
$tabRet = array();
|
|
$siret = trim($siret);
|
|
$len = strlen($siret);
|
|
$siren = substr($siret,0,9);
|
|
if ($len == 14) {
|
|
$nic = substr($siret,9,5)*1;
|
|
} elseif ($len == 9) {
|
|
$nic = 0;
|
|
}
|
|
|
|
if (intval($siren)==0 && $id==0) {
|
|
$this->sendError('1010');
|
|
} elseif ($len!=14 && $len!=9) {
|
|
$this->sendError('1020');
|
|
}
|
|
|
|
$iInsee = new MInsee();
|
|
$entrep = $iInsee->getIdentiteEntreprise($siren, $nic, $id, $forceVerif);
|
|
if (empty($entrep)) {
|
|
debugLog('W', "Siren $siren non présent en base", __LINE__, __FILE__, __FUNCTION__, __CLASS__);
|
|
$this->sendError('1020');
|
|
}
|
|
|
|
$iBourse = new MBourse($siren);
|
|
$bourse = $iBourse->getInfosBourse($siren);
|
|
|
|
$identiteProcol = new IdentiteProcol();
|
|
|
|
//Element identite
|
|
$identite = new Identite();
|
|
$identite->id = $entrep['id'];
|
|
$identite->Siret = $entrep['Siret'];
|
|
$identite->SiretSiege = $entrep['SiretSiege'];
|
|
$identite->Siege = $entrep['Siege'];
|
|
$identite->TribunalCode = $entrep['Tribunal'];
|
|
$identite->TribunalLib = $entrep['TribunalLib'];
|
|
$identite->NumRC = $entrep['numRC']; // Ajouté le 4 08 2009
|
|
$identite->Actif = $entrep['Actif'];
|
|
$identite->EntActiveRCS = $entrep['EntActiveRCS'];
|
|
$identite->AutreId = $entrep['AutreId'];
|
|
$identite->Source = $entrep['Source'];
|
|
$identite->SourceId = $entrep['SourceId'];
|
|
$identite->Isin = $entrep['Isin'];
|
|
$identite->Nom = strtr($entrep['Nom'],'/*',' ');
|
|
$identite->Nom2 = $entrep['Nom2'];
|
|
$identite->NomLong = $entrep['nomLong']; // Ajouté le 4 08 2009
|
|
$identite->NomCommercial = $entrep['NomCommercial']; // Ajouté le 16 11 2010
|
|
$identite->Siret = $entrep['Siret'];
|
|
$identite->Sigle = $entrep['Sigle'];
|
|
$identite->SigleLong = $entrep['sigleLong']; // Ajouté le 4 08 2009
|
|
$identite->Enseigne = $entrep['Enseigne'];
|
|
$identite->EnseigneLong = $entrep['enseigneLong']; // Ajouté le 16 11 2010
|
|
$identite->Adresse = $entrep['Adresse'];
|
|
$identite->Adresse2 = $entrep['Adresse2'];
|
|
$identite->AdresseNum = $entrep['AdresseNum'];
|
|
$identite->AdresseBtq = $entrep['AdresseBtq'];
|
|
$identite->AdresseVoie = $entrep['AdresseVoie'];
|
|
$identite->AdresseRue = $entrep['AdresseRue'];
|
|
$identite->CP = $entrep['CP'];
|
|
$identite->Ville = $entrep['Ville'];
|
|
$identite->Pays = $entrep['Pays']; // Ajouté le 18 02 2008
|
|
$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'];
|
|
$identite->Civilite = $entrep['Civilite'];
|
|
$identite->NbEtab = $entrep['NbEtab'];
|
|
$identite->Tel = $entrep['Tel'];
|
|
$identite->Fax = $entrep['Fax'];
|
|
$identite->Web = $entrep['Web'];
|
|
$identite->Mail = $entrep['Mail'];
|
|
$identite->GeoLat = $entrep['GeoLat'];
|
|
$identite->GeoLon = $entrep['GeoLon'];
|
|
$identite->GeoPrecis = $entrep['GeoPrecis'];
|
|
$identite->GeoInfos = $entrep['GeoInfos'];
|
|
$identite->TvaNumero = $entrep['TvaNumero'];
|
|
$identite->TvaAttribue = $entrep['TvaAttribue'];
|
|
$identite->FJ = $entrep['FJ'];
|
|
$identite->FJ_Lib = $entrep['FJ_lib'];
|
|
$identite->FJ2 = $entrep['FJ2']; // Ajouté le 4 08 2009
|
|
$identite->FJ2_Lib = $entrep['FJ2_Lib']; // Ajouté le 4 08 2009
|
|
$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 = $entrep['APRM_Lib'];
|
|
$identite->NumRM = $entrep['NumRM'];
|
|
$identite->Activite = $entrep['Activite'];
|
|
$identite->Capital = $entrep['Capital'];
|
|
$identite->CapitalDev = $entrep['CapitalDev'];
|
|
$identite->CapitalLib = $entrep['CapitalLib']; // Ajouté le 18 02 2008
|
|
$identite->CapitalType = $entrep['CapitalType']; // Ajouté le 4 08 2009
|
|
$identite->DateCreaEt = WDate::dateT('Ymd','Y-m-d',$entrep['DateCreaEt']);
|
|
$identite->DateCreaEn = WDate::dateT('Ymd','Y-m-d',$entrep['DateCreaEn']);
|
|
$identite->DateClotEt = $entrep['DateClotEt']; //@todo : date
|
|
$identite->DateImmat = $entrep['dateImmat']; // Ajouté le 4 08 2009
|
|
$identite->DateRadiation = $entrep['dateRad']; // Ajouté le 4 08 2009
|
|
$identite->EffEnTr = $entrep['EffEnTr'];
|
|
$identite->EffEnTrLib = $entrep['EffEnTrLib'];
|
|
$identite->Effectif = $entrep['Effectif'];
|
|
$identite->EffEtTr = $entrep['EffEtTr']; // Ajout le 11 08 2010
|
|
$identite->EffEtTrLib = $entrep['EffEtTrLib']; // Ajout le 11 08 2010
|
|
$identite->EffectifEtab = $entrep['EffectifEtab']; // Ajout le 11 08 2010
|
|
$identite->Dept = $entrep['Dept'];
|
|
$identite->codeCommune = $entrep['codeCommune'];
|
|
$identite->AnneeEffEn = $entrep['AnneeEffEn'];
|
|
$identite->AnneeEffEt = $entrep['AnneeEffEt'];
|
|
$identite->AnneeTCA = $entrep['AnneeTCA'];
|
|
$identite->TrancheCA = $entrep['TrancheCA'];
|
|
$identite->TrancheCALib = $entrep['TrancheCALib'];
|
|
$identite->dir1Code = $entrep['dir1Code'];
|
|
$identite->dir1Titre = $entrep['dir1Titre'];
|
|
$identite->dir1NomPrenom = $entrep['dir1NomPrenom'];
|
|
$identite->dir1DateFct = $entrep['dir1DateFct']; //@todo : date
|
|
$identite->dir1DateNaiss = $entrep['dir1DateNaiss']; //@todo : date // Ajouté le 4 08 2009
|
|
$identite->dir1LieuNaiss = $entrep['dir1LieuNaiss']; // Ajouté le 4 08 2009
|
|
$identite->dir2Code = $entrep['dir2Code'];
|
|
$identite->dir2Titre = $entrep['dir2Titre'];
|
|
$identite->dir2NomPrenom = $entrep['dir2NomPrenom'];
|
|
$identite->dir2DateFct = $entrep['dir2DateFct']; //@todo : date
|
|
$identite->dir2DateNaiss = $entrep['dir2DateNaiss']; //@todo : date // Ajouté le 4 08 2009
|
|
$identite->dir2LieuNaiss = $entrep['dir2LieuNaiss']; // Ajouté le 4 08 2009
|
|
$identite->Rivoli = $entrep['Rivoli'];
|
|
$identite->InfosIris->codIris = $entrep['InfosIris']['codIris'];
|
|
$identite->InfosIris->codComIris = $entrep['InfosIris']['codComIris'];
|
|
$identite->InfosIris->libIris = $entrep['InfosIris']['libIris'];
|
|
$identite->InfosIris->typIris = $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->SituationJuridique = $entrep['SituationJuridique'];
|
|
$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->Resultat = $entrep['bilanHN'];
|
|
$identite->Bilan->Effectif = $entrep['bilanYP'];
|
|
$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;
|
|
|
|
$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
|
|
|
|
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']);
|
|
}
|
|
}
|
|
|
|
$identiteProcol->Identite = $identite;
|
|
|
|
//Eléments annonces légales
|
|
$tabRetAnn = $tabLastEven = array();
|
|
if (intval($siren)!=0) {
|
|
$anns = $this->getAnnonces($siren, 1);
|
|
$anns = $anns->result;
|
|
$tribunalProcol = false;
|
|
foreach ($anns as $nb=>$ann)
|
|
{
|
|
$tabRetEven = array();
|
|
foreach ($ann->evenements as $tabEven) {
|
|
// On ignore les éléments suivants
|
|
if ($tabEven->CodeEven>=7000) continue;
|
|
if ($tabEven->CodeEven>=4000 && $tabEven->CodeEven<=4999) continue;
|
|
|
|
// Par défaut, on force le tribunal à celui présent dans la dernière annonce de Procol
|
|
if ($tribunalProcol==false && $tabEven->CodeEven>=1000 && $tabEven->CodeEven<2000 && $ann->BodaccCode=='BODA') {
|
|
$identiteProcol->TribunalCode = $ann->TribunalCode;
|
|
$identiteProcol->TribunalLib = prepareString($ann->Tribunal);
|
|
$tribunalProcol=true;
|
|
}
|
|
|
|
// On ne prend que le dernier élément de chaque type
|
|
if (in_array($tabEven->CodeEven, $tabLastEven)) continue;
|
|
|
|
$tabLastEven[] = $tabEven->CodeEven;
|
|
$tabRetEven[] = $tabEven;
|
|
}
|
|
|
|
if (count($tabRetEven)>0) {
|
|
$annonce = new Annonce();
|
|
$annonce->id = $ann->id;
|
|
$annonce->BodaccCode = $ann->BodaccCode;
|
|
$annonce->BodaccNum = $ann->BodaccNum;
|
|
$annonce->NumAnnonce = $ann->NumAnnonce;
|
|
$annonce->DateParution = $ann->DateParution; //@todo : date
|
|
$annonce->Departement = $ann->Departement;
|
|
$annonce->Tribunal = $ann->Tribunal;
|
|
$annonce->TribunalCode = $ann->TribunalCode;
|
|
$annonce->TribunalSiret = $ann->TribunalSiret;
|
|
$annonce->Rubrique = $ann->Rubrique;
|
|
$annonce->typeAnnonce = $ann->typeAnnonce;
|
|
$annonce->texteRectificatif = $ann->texteRectificatif;
|
|
$annonce->texteAnnonce = utf8_encode($ann->texteAnnonce);
|
|
$annonce->dateEffet = $ann->dateEffet; //@todo : date
|
|
$annonce->dateJugement = $ann->dateJugement; //@todo : date
|
|
$annonce->dateInsertionSD = $ann->dateInsertionSD; //@todo : date
|
|
$annonce->evenements = $tabRetEven;
|
|
$annonce->Lien_Annonce_Pdf = $ann->Lien_Annonce_Pdf;
|
|
$tabRetAnn[] = $annonce;
|
|
}
|
|
}
|
|
$identiteProcol->Annonces = $tabRetAnn;
|
|
|
|
$iRncs = new MRncs();
|
|
if ($entrep['Siege']==1 || $entrep['Siege']==11) {
|
|
$identiteProcol->LibTypeEtab = 'Etablissement Siege';
|
|
} else {
|
|
$tabEtabRncs = $iRncs->getIdentiteEtab($siren, $entrep['Nic']);
|
|
if ($tabEtabRncs['Siege']==2) $identiteProcol->LibTypeEtab = 'Etablissement Principal';
|
|
elseif ($tabEtabRncs['Siege']==1) $identiteProcol->LibTypeEtab = 'Etablissement Complementaire';
|
|
elseif ($tabEtabRncs['Siege']==0) $identiteProcol->LibTypeEtab = 'Etablissement Secondaire';
|
|
}
|
|
|
|
//@todo
|
|
$tabJuge = $iRncs->getIntervenants($siren);
|
|
$tabDepots=array();
|
|
foreach ($tabJuge as $iDepot=>$depot) {
|
|
$organe = new Organe();
|
|
$organe->codEven = $depot['codEven'];
|
|
$organe->libEven = prepareString($depot['libEven']);
|
|
$organe->dateEffet = $depot['dateEffet'];
|
|
$organe->admcode = $depot['admcode'];
|
|
$organe->admfonction = prepareString($depot['admfonction']);
|
|
$organe->admnom = prepareString($depot['admnom']);
|
|
$organe->admadrNum = $depot['admadrNum'];
|
|
$organe->admadrInd = $depot['admadrInd'];
|
|
$organe->admadrVoie = $depot['admadrVoie']; // @todo : adm1adr1, adm1adr2, adm1adr3,
|
|
$organe->admadrCP = $depot['admadrCP'];
|
|
$organe->admadrVille = $depot['admadrVille'];
|
|
$tabDepots[] = $organe;
|
|
}
|
|
$identiteProcol->Organes = $tabDepots;
|
|
|
|
require_once 'Metier/partenaires/classMLiens.php';
|
|
$mLiens = new MLiens($siren);
|
|
$tabA = $mLiens->getActionnaires($siren, 1);
|
|
$nbA = count($tabA);
|
|
$tabAct = array();
|
|
foreach ($tabA as $i=>$lien) {
|
|
$liens = new Actionnaire();
|
|
$liens->Pmin = $lien['Pmin'];
|
|
$liens->MajMin = $lien['MajMin'];
|
|
$liens->RaisonSociale = $lien['RaisonSociale'];
|
|
$liens->Pays = $lien['Pays'];
|
|
$liens->Siren = $lien['Siren'];
|
|
$liens->Actif = $lien['Actif'];
|
|
$tabAct[] = $liens;
|
|
}
|
|
$identiteProcol->Actionnaires = $tabAct;
|
|
|
|
$iGreffes = new MGreffes();
|
|
$tabActes = $iGreffes->getListeActes($siren);
|
|
|
|
$identiteProcol->StatutsModifDepot = $identiteProcol->StatutsModif = '0000-00-00';
|
|
foreach ($tabActes as $i=>$acte) {
|
|
if ('_'.$acte['acte_type']=='_04') { // STATUTS CONSTITUTIFS
|
|
$identiteProcol->StatutsConstDepot = $acte['depot_date']; // => 1997-12-18
|
|
$identiteProcol->StatutsConst = $acte['acte_date']; // => 1997-11-13
|
|
break;
|
|
} elseif (in_array('_'.$acte['acte_type'], array(
|
|
//'_04', // STATUTS CONSTITUTIFS
|
|
'_06', // STATUTS A JOUR 9 0000-00-00 2009-09-02 17:05:55
|
|
'_07', // STATUTS A JOUR 9 0000-00-00 2009-09-02 17:05:55
|
|
'_08', // STATUTS A JOUR ET DECLARATION DE CONFORMITE 9 0000-00-00 2009-09-02 17:05:55
|
|
'_09', // STATUTS APRES TRANSFERT DE SIEGE 9 0000-00-00 2009-09-02 17:05:55
|
|
'_A1', // STATUTS 9 0000-00-00 2009-09-02 17:05:55
|
|
'_AH', // AVENANT AUX STATUTS
|
|
))) {
|
|
// On ne prend que la dernière modif
|
|
if ($identiteProcol->StatutsModifDepot=='0000-00-00' && $identiteProcol->StatutsModif=='0000-00-00') {
|
|
$identiteProcol->StatutsModifDepot = $acte['depot_date'];// => 1997-12-18
|
|
$identiteProcol->StatutsModif = $acte['acte_date']; // => 1997-11-13
|
|
}
|
|
}
|
|
}
|
|
|
|
/** Y a t il eu des informations relatives à une cession ? **/
|
|
$tabCes = $iGreffes->getInfosCessions($siren);
|
|
if ($tabCes) {
|
|
$identiteProcol->CessionJugeLib = $tabCes['cessJuge'];
|
|
$identiteProcol->CessionJugeDate = $tabCes['cessDateJuge'];
|
|
$identiteProcol->CessionAvisBodac = $tabCes['cessDateBod'];
|
|
$identiteProcol->CessionInvenDate = $tabCes['cessDateInv'];
|
|
$identiteProcol->CessionCAdeclare = $tabCes['cessCAdec'];
|
|
$identiteProcol->CessionEffectif = $tabCes['cessEffectif'];
|
|
$identiteProcol->CessionDesc = $tabCes['cessDesc'];
|
|
$identiteProcol->CessionDescDate = $tabCes['cessDateDesc'];
|
|
$identiteProcol->CessionOffreDate = $tabCes['cessDateLim'];
|
|
$identiteProcol->CessionMandataire = $tabCes['cessMand'];
|
|
}
|
|
}
|
|
//sendMail('production@scores-decisions.com', 'ylenaour@scores-decisions.com', "Debug $siren", print_r($tabRet,true)) ;
|
|
debugLog('I', 'Etablissement retourné = '. $entrep['Nom'], __LINE__, __FILE__, __FUNCTION__, __CLASS__);
|
|
$this->wsLog('identite', $siret, $id);
|
|
|
|
return $identiteProcol;
|
|
}
|
|
|
|
/**
|
|
* Retourne les liens financiers pour une entreprise.
|
|
* @param string $siren Siren de l'entreprise
|
|
* @param string $type Type de lien (actionnaire|participation)
|
|
* @return LiensReturn
|
|
*/
|
|
public function getLiens($siren, $type = null)
|
|
{
|
|
$this->authenticate();
|
|
$this->permission('liens');
|
|
|
|
//Load country table
|
|
try {
|
|
$countryM = new Application_Model_JoTabPays();
|
|
$sql = $countryM->select()->from($countryM, array('codPays3', 'libPays'));
|
|
$result = $countryM->fetchAll($sql);
|
|
} catch (Zend_Db_Adapter_Exception $e) {
|
|
if ($this->User->idClient==1) {
|
|
throw new SoapFault('ERR', $e->getMessage());
|
|
} else {
|
|
throw new SoapFault('ERR', "Application error");
|
|
}
|
|
} catch (Zend_Exception $e) {
|
|
throw new SoapFault('ERR', "Application error");
|
|
}
|
|
|
|
$tabPays = array();
|
|
if ( $result->count()>0 ) {
|
|
foreach ( $result as $item ) {
|
|
$tabPays[$item->codPays3] = $item->libPays;
|
|
}
|
|
}
|
|
|
|
$tabAct = $tabPar = $tabDir = array();
|
|
|
|
try
|
|
{
|
|
require_once 'Metier/partenaires/classMLiens2.php';
|
|
$liensM = new MLiens2($siren, 'siren');
|
|
|
|
//Actionnaires
|
|
$liens = $liensM->getActionnaires(null, true);
|
|
if (count($liens)>0) {
|
|
foreach ( $liens as $item ) {
|
|
$detail = new Lien();
|
|
$detail->id = $item->id;
|
|
$detail->idFiche = $item->idAct;
|
|
$detail->nom = $item->RS;
|
|
$detail->sigle = $item->sigle;
|
|
|
|
$libPays = '';
|
|
if ($item->adresse_pays!='') {
|
|
$libPays = array_key_exists($item->adresse_pays, $tabPays) ?
|
|
$tabPays[$item->adresse_pays] : $item->adresse_pays;
|
|
} else {
|
|
$libPays = $tabPays['FRA'];
|
|
}
|
|
$detail->pays = $libPays;
|
|
|
|
if ($item->PpPm=='PP' && intval($siren)==0) {
|
|
$detail->nom = $item->civilite.' '.$item->nom.' '.$item->prenom;
|
|
}
|
|
$detail->siren = str_pad($item->siren, 9, "0", STR_PAD_LEFT);
|
|
$detail->PDetention = $item->PDetention;
|
|
$detail->Pvote = $item->Pvote;
|
|
$detail->MajMin = $item->MajMin;
|
|
|
|
if ($item->dateUpdate=='0000-00-00 00:00:00'){
|
|
$detail->date = substr($item->dateInsert,0,10);
|
|
} else {
|
|
$detail->date = substr($item->dateUpdate,0,10);
|
|
}
|
|
|
|
$nbIdNum = 3;
|
|
$refs = array();
|
|
$idM = new Application_Model_Sdv1TabIdLocal();
|
|
for ($i=0;$i<$nbIdNum;$i++) {
|
|
if( !empty($item->{'idLoc'.$i.'Num'}) ) {
|
|
$ref = new LienRefId();
|
|
$ref->num = $item->{'idLoc'.$i.'Num'};
|
|
|
|
if ( !empty($item->{'idLoc'.$i.'Type'}) ) {
|
|
$sql = $idM->select()->from($idM, array('idLocal', 'idPrincipal'))
|
|
->where('id=?', $item->{'idLoc'.$i.'Type'});
|
|
$result = $idM->fetchRow($sql);
|
|
if (null!==$result) {
|
|
$ref->label = $result->idLocal;
|
|
$ref->type = $result->idPrincipal;
|
|
} else {
|
|
$ref->label = '';
|
|
$ref->type = 0;
|
|
}
|
|
} else {
|
|
$ref->label = 'Identifiant local';
|
|
$ref->type = 1;
|
|
}
|
|
|
|
$refs[] = $ref;
|
|
}
|
|
}
|
|
$detail->identification = $refs;
|
|
|
|
$tabAct[] = $detail;
|
|
}
|
|
}
|
|
|
|
//Participations
|
|
$liens = $liensM->getParticipations(null, true);
|
|
if (count($liens)>0) {
|
|
foreach ( $liens as $item ) {
|
|
$detail = new Lien();
|
|
$detail->id = $item->id;
|
|
$detail->idFiche = $item->idPar;
|
|
$detail->nom = $item->RS;
|
|
$detail->sigle = $item->sigle;
|
|
|
|
$libPays = '';
|
|
if ($item->adresse_pays!='') {
|
|
$libPays = array_key_exists($item->adresse_pays, $tabPays) ?
|
|
$tabPays[$item->adresse_pays] : $item->adresse_pays;
|
|
} else {
|
|
$libPays = $tabPays['FRA'];
|
|
}
|
|
$detail->pays = $libPays;
|
|
|
|
if ($item->PpPm=='PP' && intval($siren)==0) {
|
|
$detail->nom = $item->civilite.' '.$item->nom.' '.$item->prenom;
|
|
}
|
|
$detail->siren = str_pad($item->siren, 9, "0", STR_PAD_LEFT);
|
|
$detail->PDetention = $item->PDetention;
|
|
$detail->Pvote = $item->Pvote;
|
|
$detail->MajMin = $item->MajMin;
|
|
|
|
if ($item->dateUpdate=='0000-00-00 00:00:00'){
|
|
$detail->date = substr($item->dateInsert,0,10);
|
|
} else {
|
|
$detail->date = substr($item->dateUpdate,0,10);
|
|
}
|
|
|
|
$nbIdNum = 3;
|
|
$refs = array();
|
|
$idM = new Application_Model_Sdv1TabIdLocal();
|
|
for ($i=0;$i<$nbIdNum;$i++) {
|
|
if( !empty($item->{'idLoc'.$i.'Num'}) ) {
|
|
$ref = new LienRefId();
|
|
$ref->num = $item->{'idLoc'.$i.'Num'};
|
|
|
|
if ( !empty($item->{'idLoc'.$i.'Type'}) ) {
|
|
$sql = $idM->select()->from($idM, array('idLocal', 'idPrincipal'))
|
|
->where('id=?', $item->{'idLoc'.$i.'Type'});
|
|
$result = $idM->fetchRow($sql);
|
|
if (null!==$result) {
|
|
$ref->label = $result->idLocal;
|
|
$ref->type = $result->idPrincipal;
|
|
} else {
|
|
$ref->label = '';
|
|
$ref->type = 0;
|
|
}
|
|
} else {
|
|
$ref->label = 'Identifiant local';
|
|
$ref->type = 1;
|
|
}
|
|
|
|
$refs[] = $ref;
|
|
}
|
|
}
|
|
$detail->identification = $refs;
|
|
|
|
$tabPar[] = $detail;
|
|
}
|
|
}
|
|
|
|
//Directions
|
|
$liens = $liensM->getDirections(true);
|
|
if (count($liens)>0) {
|
|
foreach ( $liens as $item ) {
|
|
$detail = new LienDirection();
|
|
$detail->siren = $item->siren;
|
|
$detail->nom = $item->raisonSociale;
|
|
$detail->fonction = $item->fonction_lib;
|
|
$detail->dirRS = $item->dirRS;
|
|
|
|
$nom = '';
|
|
if (!empty($item->civilite)) {
|
|
$nom.= $item->civilite.'. ';
|
|
}
|
|
if (!empty($item->nom)) {
|
|
$nom.= $item->nom.' ';
|
|
}
|
|
if (!empty($item->prenom)) {
|
|
$nom.= $item->prenom;
|
|
}
|
|
$detail->dirNom = $nom;
|
|
$detail->dirNaissLieu = $item->naissance_lieu;
|
|
$detail->dirNaissDate = $item->naissance_date;
|
|
|
|
$tabDir[] = $detail;
|
|
}
|
|
}
|
|
} catch(Exception $e) {
|
|
if ($this->User->idClient==1) {
|
|
throw new SoapFault('ERR', $e->getMessage());
|
|
} else {
|
|
throw new SoapFault('ERR', "Application error");
|
|
}
|
|
}
|
|
|
|
$output = new LiensReturn();
|
|
$output->actionnaires = $tabAct;
|
|
$output->participations = $tabPar;
|
|
$output->directions = $tabDir;
|
|
|
|
$this->wsLog('liens', $siren);
|
|
|
|
return $output;
|
|
}
|
|
|
|
/**
|
|
* Retourne les liens financiers pour une entreprise.
|
|
* @param int $id Identifiant de référence de l'entreprise
|
|
* @param string $type Type de lien (actionnaire|participation)
|
|
* @return LiensReturn
|
|
*/
|
|
public function getLiensById($id, $type = null)
|
|
{
|
|
$this->authenticate();
|
|
$this->permission('liens');
|
|
|
|
try {
|
|
$countryM = new Application_Model_JoTabPays();
|
|
$sql = $countryM->select()->from($countryM, array('codPays3', 'libPays'));
|
|
$result = $countryM->fetchAll($sql);
|
|
} catch (Zend_Db_Adapter_Exception $e) {
|
|
if ($this->User->idClient==1) {
|
|
throw new SoapFault('ERR', $e->getMessage());
|
|
} else {
|
|
throw new SoapFault('ERR', "Application error");
|
|
}
|
|
} catch (Zend_Exception $e) {
|
|
throw new SoapFault('ERR', "Application error");
|
|
}
|
|
|
|
$tabPays = array();
|
|
if ( $result->count()>0 ) {
|
|
foreach ( $result as $item ) {
|
|
$tabPays[$item->codPays3] = $item->libPays;
|
|
}
|
|
}
|
|
|
|
$tabAct = $tabPar = $tabDir = array();
|
|
|
|
try
|
|
{
|
|
require_once 'Metier/partenaires/classMLiens2.php';
|
|
$liensM = new MLiens2($id);
|
|
|
|
//Actionnaires
|
|
$liens = $liensM->getActionnaires(null, true);
|
|
if (count($liens)>0) {
|
|
foreach ( $liens as $item ) {
|
|
$detail = new Lien();
|
|
$detail->id = $item->id;
|
|
$detail->idFiche = $item->idAct;
|
|
$detail->nom = $item->RS;
|
|
$detail->sigle = $item->sigle;
|
|
|
|
$libPays = '';
|
|
if ($item->adresse_pays!='') {
|
|
$libPays = array_key_exists($item->adresse_pays, $tabPays) ?
|
|
$tabPays[$item->adresse_pays] : $item->adresse_pays;
|
|
} else {
|
|
$libPays = $tabPays['FRA'];
|
|
}
|
|
$detail->pays = $libPays;
|
|
|
|
if ($item->PpPm=='PP') {
|
|
$detail->nom = $item->civilite.' '.$item->nom.' '.$item->prenom;
|
|
}
|
|
$detail->siren = str_pad($item->siren, 9, "0", STR_PAD_LEFT);
|
|
$detail->PDetention = $item->PDetention;
|
|
$detail->Pvote = $item->Pvote;
|
|
$detail->MajMin = $item->MajMin;
|
|
|
|
if ($item->dateUpdate=='0000-00-00 00:00:00'){
|
|
$detail->date = substr($item->dateInsert,0,10);
|
|
} else {
|
|
$detail->date = substr($item->dateUpdate,0,10);
|
|
}
|
|
|
|
$nbIdNum = 3;
|
|
$refs = array();
|
|
$idM = new Application_Model_Sdv1TabIdLocal();
|
|
for ($i=0;$i<$nbIdNum;$i++) {
|
|
if( !empty($item->{'idLoc'.$i.'Num'}) ) {
|
|
$ref = new LienRefId();
|
|
$ref->num = $item->{'idLoc'.$i.'Num'};
|
|
|
|
if ( !empty($item->{'idLoc'.$i.'Type'}) ) {
|
|
$sql = $idM->select()->from($idM, array('idLocal', 'idPrincipal'))
|
|
->where('id=?', $item->{'idLoc'.$i.'Type'});
|
|
$result = $idM->fetchRow($sql);
|
|
if (null!==$result) {
|
|
$ref->label = $result->idLocal;
|
|
$ref->type = $result->idPrincipal;
|
|
} else {
|
|
$ref->label = '';
|
|
$ref->type = 0;
|
|
}
|
|
} else {
|
|
$ref->label = 'Identifiant local';
|
|
$ref->type = 1;
|
|
}
|
|
|
|
$refs[] = $ref;
|
|
}
|
|
}
|
|
$detail->identification = $refs;
|
|
|
|
$tabAct[] = $detail;
|
|
}
|
|
}
|
|
|
|
//Participations
|
|
$liens = $liensM->getParticipations(null, true);
|
|
if (count($liens)>0) {
|
|
foreach ( $liens as $item ) {
|
|
$detail = new Lien();
|
|
$detail->id = $item->id;
|
|
$detail->idFiche = $item->idPar;
|
|
$detail->nom = $item->RS;
|
|
$detail->sigle = $item->sigle;
|
|
|
|
$libPays = '';
|
|
if ($item->adresse_pays!='') {
|
|
$libPays = array_key_exists($item->adresse_pays, $tabPays) ?
|
|
$tabPays[$item->adresse_pays] : $item->adresse_pays;
|
|
} else {
|
|
$libPays = $tabPays['FRA'];
|
|
}
|
|
$detail->pays = $libPays;
|
|
|
|
if ($item->PpPm=='PP') {
|
|
$detail->nom = $item->civilite.' '.$item->nom.' '.$item->prenom;
|
|
}
|
|
$detail->siren = str_pad($item->siren, 9, "0", STR_PAD_LEFT);
|
|
$detail->PDetention = $item->PDetention;
|
|
$detail->Pvote = $item->Pvote;
|
|
$detail->MajMin = $item->MajMin;
|
|
|
|
if ($item->dateUpdate=='0000-00-00 00:00:00'){
|
|
$detail->date = substr($item->dateInsert,0,10);
|
|
} else {
|
|
$detail->date = substr($item->dateUpdate,0,10);
|
|
}
|
|
|
|
$nbIdNum = 3;
|
|
$refs = array();
|
|
$idM = new Application_Model_Sdv1TabIdLocal();
|
|
for ($i=0;$i<$nbIdNum;$i++) {
|
|
if( !empty($item->{'idLoc'.$i.'Num'}) ) {
|
|
$ref = new LienRefId();
|
|
$ref->num = $item->{'idLoc'.$i.'Num'};
|
|
|
|
if ( !empty($item->{'idLoc'.$i.'Type'}) ) {
|
|
$sql = $idM->select()->from($idM, array('idLocal', 'idPrincipal'))
|
|
->where('id=?', $item->{'idLoc'.$i.'Type'});
|
|
$result = $idM->fetchRow($sql);
|
|
if (null!==$result) {
|
|
$ref->label = $result->idLocal;
|
|
$ref->type = $result->idPrincipal;
|
|
} else {
|
|
$ref->label = '';
|
|
$ref->type = 0;
|
|
}
|
|
} else {
|
|
$ref->label = 'Identifiant local';
|
|
$ref->type = 1;
|
|
}
|
|
|
|
$refs[] = $ref;
|
|
}
|
|
}
|
|
$detail->identification = $refs;
|
|
|
|
$tabPar[] = $detail;
|
|
}
|
|
}
|
|
|
|
//Directions
|
|
$liens = $liensM->getDirections(true);
|
|
if (count($liens)>0) {
|
|
foreach ( $liens as $item ) {
|
|
$detail = new LienDirection();
|
|
$detail->siren = $item->siren;
|
|
$detail->nom = $item->raisonSociale;
|
|
$detail->fonction = $item->fonction_lib;
|
|
$detail->dirRS = $item->dirRS;
|
|
|
|
$nom = '';
|
|
if (!empty($item->civilite)) {
|
|
$nom.= $item->civilite.'. ';
|
|
}
|
|
if (!empty($item->nom)) {
|
|
$nom.= $item->nom.' ';
|
|
}
|
|
if (!empty($item->prenom)) {
|
|
$nom.= $item->prenom;
|
|
}
|
|
$detail->dirNom = $nom;
|
|
$detail->dirNaissLieu = $item->naissance_lieu;
|
|
$detail->dirNaissDate = $item->naissance_date;
|
|
|
|
$tabDir[] = $detail;
|
|
}
|
|
}
|
|
} catch(Exception $e) {
|
|
if ($this->User->idClient==1) {
|
|
throw new SoapFault('ERR', $e->getMessage());
|
|
} else {
|
|
throw new SoapFault('ERR', "Application error");
|
|
}
|
|
}
|
|
|
|
$output = new LiensReturn();
|
|
$output->actionnaires = $tabAct;
|
|
$output->participations = $tabPar;
|
|
$output->directions = $tabDir;
|
|
|
|
$this->wsLog('liens', '', $id);
|
|
|
|
return $output;
|
|
}
|
|
|
|
/**
|
|
* Fiche identite Référence lien
|
|
* @param int $id
|
|
* Identifiant interne SD
|
|
* @throws SoapFault
|
|
* @return LienRef
|
|
*/
|
|
public function getLienRef($id)
|
|
{
|
|
$this->authenticate();
|
|
$this->permission('liens');
|
|
|
|
$refM = new Application_Model_JoLiensRef();
|
|
|
|
try {
|
|
$rows = $refM->find($id);
|
|
} catch (Zend_Db_Exception $e) {
|
|
if ($this->User->idClient!=1) {
|
|
throw new SoapFault('ERR', "Application error");
|
|
} else {
|
|
throw new SoapFault('ERR', $e->getMessage());
|
|
}
|
|
}
|
|
|
|
if ($rows->count()==0) {
|
|
throw new SoapFault('MSG', 'Aucun résultat');
|
|
}
|
|
|
|
$result = $rows->current()->toArray();
|
|
|
|
$output = new LienRef();
|
|
$output->siren = $result['siren'];
|
|
$output->actif = $result['actif'];
|
|
$output->PpPm = $result['PpPm'];
|
|
$output->raisonSociale = $result['RS'];
|
|
$output->civilite = $result['civilite'];
|
|
$output->nom = $result['nom'];
|
|
$output->prenom = $result['prenom'];
|
|
$output->nomUsage = $result['nom_usage'];
|
|
$output->naissanceDate = $result['naissance_date'];
|
|
$output->naissanceDeptPays = $result['naissance_dept_pays'];
|
|
$output->naissanceLieu = $result['naissance_lieu'];
|
|
$output->nat = $result['nat'];
|
|
$output->isin = $result['isin'];
|
|
$output->adresseNum = $result['adresse_num'];
|
|
$output->adresseBtq = $result['adresse_btq'];
|
|
$output->adresseCodeVoie = $result['adresse_codvoie'];
|
|
$output->adresseLibVoie = $result['adresse_libvoie'];
|
|
$output->adressComp = $result['adresse_comp'];
|
|
$output->adresseCp = $result['adresse_cp'];
|
|
$output->adresseVille = $result['adresse_ville'];
|
|
|
|
$output->capital = new stdClass();
|
|
$output->capital->amount = $result['capital'];
|
|
$output->capital->currency = $result['deviseCapital'];
|
|
|
|
//@todo : Utiliser le libellé du pays
|
|
$output->adressePays = $result['adresse_pays'];
|
|
|
|
if ($result['dateUpdate']=='0000-00-00 00:00:00'){
|
|
$output->date = substr($result['dateInsert'],0,10);
|
|
} else {
|
|
$output->date = substr($result['dateUpdate'],0,10);
|
|
}
|
|
|
|
$refs = array();
|
|
|
|
$nbIdNum = 3;
|
|
$refs = array();
|
|
$idM = new Application_Model_Sdv1TabIdLocal();
|
|
for ($i=0;$i<$nbIdNum;$i++) {
|
|
if( !empty($result['idLoc'.$i.'Type']) ) {
|
|
$ref = new LienRefId();
|
|
$ref->num = $result['idLoc'.$i.'Num'];
|
|
$sql = $idM->select()->from($idM, array('idLocal', 'idPrincipal'))
|
|
->where('id=?', $result['idLoc'.$i.'Type']);
|
|
$result = $idM->fetchRow($sql);
|
|
if (null!==$result) {
|
|
$ref->label = $result->idLocal;
|
|
$ref->type = $result->idPrincipal;
|
|
} else {
|
|
$ref->label = '';
|
|
$ref->type = 0;
|
|
}
|
|
|
|
$refs[] = $ref;
|
|
}
|
|
}
|
|
$output->identification = $refs;
|
|
|
|
$this->wsLog('liens', 0, $id);
|
|
|
|
return $output;
|
|
}
|
|
|
|
|
|
/**
|
|
* Liste des établissements d'une entreprise
|
|
* @param string $siren Siren de l'entreprise
|
|
* @param integer $departement Limiter aux établissements du departement
|
|
* @param integer $actif Otpionnel 1=Uniquements les actifs, 0=inactifs, Néant=Tous
|
|
* @param integer $position
|
|
* @param integer $nbRep
|
|
*
|
|
* @return ListeEtablissementsReturn
|
|
*/
|
|
public function getListeEtablissements($siren, $dep = 0, $actif = -1, $position = 0, $nbRep = 20)
|
|
{
|
|
$this->authenticate();
|
|
$this->permission('etablissements');
|
|
|
|
//Initialisation
|
|
if (empty($dep)) { $dep = 0; }
|
|
if (!in_array($actif, array(0,1))) { $actif = -1; }
|
|
if (empty($position)) { $position = 0; }
|
|
if (empty($nbRep)) { $nbRep = 20; }
|
|
|
|
$departement = $dep;
|
|
|
|
debugLog('I',"Liste des établissements demandée pour $siren",__LINE__,__FILE__, __FUNCTION__, __CLASS__);
|
|
if (strlen($siren)<>9) {
|
|
debugLog('W', "Siren $siren incorrect", __LINE__, __FILE__, __FUNCTION__, __CLASS__);
|
|
$this->sendError('1010');
|
|
} elseif ($siren*1==0) {
|
|
debugLog('W', "Siren $siren inexistant", __LINE__, __FILE__, __FUNCTION__, __CLASS__);
|
|
$this->sendError('1010');
|
|
}
|
|
|
|
$iInsee = new MInsee();
|
|
$rep = $iInsee->getEtablissements($siren, '', $position, $nbRep, 200, $departement, $actif);
|
|
$etabs = $rep['reponses'];
|
|
$nbReponses = $rep['nbReponsesTotal'];
|
|
|
|
$result = array();
|
|
if (count($etabs)>0) {
|
|
foreach ($etabs as $nb => $etab) {
|
|
$etablissement = new Etablissement();
|
|
$etablissement->id = $etab['id'];
|
|
$etablissement->Siege = $etab['Siege'];
|
|
$etablissement->Enseigne = $etab['Enseigne'];
|
|
$etablissement->Adresse = $etab['Adresse'];
|
|
$etablissement->Adresse2 = $etab['Adresse2'];
|
|
$etablissement->CP = $etab['CP'];
|
|
$etablissement->Ville = $etab['Ville'];
|
|
$etablissement->Tel = $etab['Tel'];
|
|
$etablissement->Fax = $etab['Fax'];
|
|
$etablissement->Nic = $etab['Nic'];
|
|
$etablissement->Actif = $etab['Actif'];
|
|
$etablissement->NafEtab = $etab['NafEtab'];
|
|
$etablissement->NafEtabLib = $etab['NafEtabLib'];
|
|
$etablissement->EffEtTr = $etab['EffEtTr'];
|
|
$etablissement->EffEtTrLib = $etab['EffEtTrLib'];
|
|
|
|
$result[] = $etablissement;
|
|
}
|
|
}
|
|
debugLog('I', "Nb Etablissements retournés ($departement, $actif) = ". count($result), __LINE__, __FILE__, __FUNCTION__, __CLASS__);
|
|
$this->wsLog('etablissements',$siren);
|
|
$output = new ListeEtablissementsReturn();
|
|
$output->nbReponses = $nbReponses;
|
|
$output->result = $result;
|
|
return $output;
|
|
}
|
|
|
|
/**
|
|
* Retourne l'ensemble des informations identitaires des dirigeants de l'entreprise
|
|
*
|
|
* @param string $siren Siren de l'entreprise
|
|
* @param bool $histo Afficher l'historique des dirigeants
|
|
* @return DirigeantsReturn Liste des dirigeants actifs de l'entreprise
|
|
*/
|
|
public function getDirigeants( $siren , $histo = false)
|
|
{
|
|
$this->authenticate();
|
|
$this->permission('dirigeants');
|
|
|
|
//Initialisation
|
|
if (empty($histo)) { $histo = false; }
|
|
|
|
//Zend_Registry::get('WsLogger')->info('HISTO : '.$histo);
|
|
|
|
debugLog('I',"Dirigeants demandée pour $siren",__LINE__,__FILE__, __FUNCTION__, __CLASS__);
|
|
$tabRet = array();
|
|
if (strlen($siren)<>9) {
|
|
debugLog('W', "Siren/Siret $siren incorrect", __LINE__, __FILE__, __FUNCTION__, __CLASS__);
|
|
$this->sendError('1010');
|
|
} elseif ($siren*1==0) {
|
|
debugLog('W', "Siren $siren inexistant", __LINE__, __FILE__, __FUNCTION__, __CLASS__);
|
|
$this->sendError('1010');
|
|
}
|
|
|
|
$iInsee = new MInsee();
|
|
$dirs = $iInsee->getDirigeants($siren, $histo);
|
|
//debugLog('W', print_r($dirs, true), __LINE__, __FILE__, __FUNCTION__, __CLASS__);
|
|
$liste = array();
|
|
foreach ($dirs as $nb => $dir)
|
|
{
|
|
//debugLog('I', "Siren/Siret $siren trouvé : ".$etab['Siren'].' '.$etab['Nic'].', '.$etab['Nom'] .', '.$etab['CP'].', '.$etab['Ville'], __LINE__, __FILE__, __FUNCTION__, __CLASS__);
|
|
$dirigeant = new Dirigeant();
|
|
$dirigeant->Code = $dir['Fonction'];
|
|
$dirigeant->Titre = $dir['Titre'];
|
|
$dirigeant->Societe = $dir['Societe'];
|
|
$dirigeant->Siren = (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->NaissDate = $dir['NaissDate']; //@todo : date
|
|
$dirigeant->NaissVille = $dir['NaissVille'];
|
|
$dirigeant->NaissDepPays = $dir['NaissDepPays'];
|
|
$dirigeant->Ancien = $dir['Ancien'];
|
|
$dirigeant->DateFct = $dir['DateFct']; //@todo : date
|
|
$liste[] = $dirigeant;
|
|
}
|
|
$this->wsLog('dirigeants',$siren,$option);
|
|
debugLog('I', 'Nb Dirigeants retournés = '. count($dirs), __LINE__, __FILE__, __FUNCTION__, __CLASS__);
|
|
$output = new DirigeantsReturn();
|
|
$output->result = $liste;
|
|
return $output;
|
|
}
|
|
|
|
/**
|
|
* Retourne la liste des annonces légales relative à une entreprise
|
|
*
|
|
* @todo Revoir cette fonction pour la faire marcher avec les associations
|
|
*
|
|
* @param string $siren Siren de l'entreprise
|
|
* @param integer $filtre 1=BODACC, 2=B.A.L.O, 3=JO Association, 4=Boamp
|
|
* @param string $idAnn Identifiant de l'annonce
|
|
* @param integer $position
|
|
* @param integer $nbRep
|
|
* @return AnnoncesReturn
|
|
*/
|
|
protected function getAnnonces($siren, $filtre = 1, $idAnn = '', $position = 0, $nbRep = 100)
|
|
{
|
|
$this->authenticate();
|
|
$this->permission('annonces');
|
|
|
|
//Initialisation
|
|
if (empty($filtre)) { $filtre = 1; }
|
|
if (empty($idAnn)) { $idAnn = ''; }
|
|
if (empty($position)) { $position = 0; }
|
|
if (empty($nbRep)) { $nbRep = 100; }
|
|
|
|
//Valeur max
|
|
if($nbRep > 200) { $nbRep = 200; }
|
|
|
|
debugLog('I',"Annonces demandées pour $siren ($filtre, $idAnn)",__LINE__,__FILE__, __FUNCTION__, __CLASS__);
|
|
|
|
$liste = array();
|
|
|
|
if (strlen($siren)!=9) {
|
|
debugLog('W', "Siren/Siret $siren incorrect", __LINE__, __FILE__, __FUNCTION__, __CLASS__);
|
|
$this->sendError('1010');
|
|
} elseif (intval($siren)==0 && $idAnn=='') {
|
|
debugLog('W', "Siren $siren ou annonce $idAnn inexistant", __LINE__, __FILE__, __FUNCTION__, __CLASS__);
|
|
$this->sendError('1010');
|
|
}
|
|
|
|
$iInsee = new MInsee();
|
|
/*
|
|
if ($siren>100 && $filtre==3) $asso=true;
|
|
else {
|
|
$asso=false;
|
|
$tabIdentite=$this->iInsee->getIdentiteLight($siren);
|
|
if ($tabIdentite['FJ']>90 && $tabIdentite['FJ']<94 ||
|
|
$tabIdentite['FJ']>9000 && $tabIdentite['FJ']<9400) $asso=true;
|
|
}*/
|
|
|
|
//@todo : Connaitre le nombre d'annonce
|
|
|
|
/*
|
|
getAnnoncesBoamp => Avis de marché, Avis d'attribution
|
|
getAnnoncesAsso => Rien de particulier
|
|
getAnnoncesBalo => Rien de particulier
|
|
getAnnoncesLegales => Plusieurs requetes SQL suivant la situation
|
|
*/
|
|
|
|
if ($idAnn=='') {
|
|
$anns=$iInsee->getAnnoncesLegales($siren);
|
|
$annsB=$iInsee->getAnnoncesBalo($siren);
|
|
$annsA=$iInsee->getAnnoncesAsso($siren);
|
|
$annsM=$iInsee->getAnnoncesBoamp($siren, $idAnn);
|
|
} elseif ($filtre==1) {
|
|
$anns=$iInsee->getAnnoncesLegales($siren, $idAnn);
|
|
} elseif ($filtre==2) {
|
|
$annsB=$iInsee->getAnnoncesBalo($siren, $idAnn);
|
|
} elseif ($filtre==3) {
|
|
$annsA=$iInsee->getAnnoncesAsso($siren, $idAnn);
|
|
} elseif ($filtre==4) {
|
|
$annsM=$iInsee->getAnnoncesBoamp($siren, $idAnn);
|
|
}
|
|
//debugLog('W', print_r($entrep, true), __LINE__, __FILE__, __FUNCTION__, __CLASS__);
|
|
if (empty($anns) && empty($annsB) && empty($annsA) && empty($annsM))
|
|
{
|
|
debugLog('W', "Aucune annonce pour le siren $siren (source=$filtre, id=$idAnn)", __LINE__, __FILE__, __FUNCTION__, __CLASS__);
|
|
$error->errnum = 102;
|
|
$error->errmsg = 'Siren inexistant B '.$siren.' '.$idAnn;
|
|
}
|
|
else
|
|
{
|
|
foreach ($anns as $nb=>$ann)
|
|
{
|
|
//debugLog('I', "Siren/Siret $siren trouvé : ".$etab['Siren'].' '.$etab['Nic'].', '.$etab['Nom'] .', '.$etab['CP'].', '.$etab['Ville'], __LINE__, __FILE__, __FUNCTION__, __CLASS__);
|
|
$evens = array();
|
|
foreach ($ann['evenements'] as $tabEven)
|
|
{
|
|
$even = new AnnonceEvenement();
|
|
$even->CodeEven = $tabEven['CodeEven'];
|
|
$even->LibEven = $tabEven['LibEven'];
|
|
$evens[] = $even;
|
|
}
|
|
$annonce = new Annonce();
|
|
$annonce->id = $ann['id'];
|
|
$annonce->BodaccCode = $ann['BodaccCode'];
|
|
$annonce->BodaccNum = $ann['BodaccNum'];
|
|
$annonce->NumAnnonce = $ann['NumAnnonce'];
|
|
$annonce->DateParution = $ann['DateParution']; //@todo : date
|
|
$annonce->Departement = $ann['Departement'];
|
|
$annonce->Tribunal = $ann['Tribunal'];
|
|
$annonce->TribunalCode = $ann['TribunalCode'];
|
|
$annonce->TribunalSiret = $ann['TribunalSiret'];
|
|
$annonce->Rubrique = $ann['Rubrique'];
|
|
$annonce->typeAnnonce = $ann['typeAnnonce'];
|
|
$annonce->texteRectificatif = prepareString($ann['texteRectificatif']);
|
|
$annonce->texteAnnonce = prepareString($ann['texteAnnonce']);
|
|
$annonce->libFJ = $ann['libFJ'];
|
|
$annonce->codFJ = $ann['codFJ'];
|
|
$annonce->capital = $ann['capital'];
|
|
$annonce->capitalDev = $ann['capitalDev'];
|
|
|
|
$annonce->raisonSociale = $ann['raisonSociale'];
|
|
$annonce->nomCommercial = $ann['nomCommercial'];
|
|
$annonce->sigle = $ann['sigle'];
|
|
$annonce->adresse = $ann['adresse'];
|
|
$annonce->dateEffet = $ann['dateEffet']; //@todo : date
|
|
$annonce->dateJugement = $ann['dateJugement']; //@todo : date
|
|
$annonce->dateInsertionSD = $ann['dateInsertionSD']; //@todo : date
|
|
$annonce->evenements = $evens;
|
|
$annonce->Lien_Annonce_Pdf = $ann['Lien_Annonce_Pdf'];
|
|
|
|
$liste[] = $annonce;
|
|
}
|
|
|
|
if (is_array($annsB))
|
|
{
|
|
foreach ($annsB as $nb=>$ann)
|
|
{
|
|
//debugLog('I', "Siren/Siret $siren trouvé : ".$etab['Siren'].' '.$etab['Nic'].', '.$etab['Nom'] .', '.$etab['CP'].', '.$etab['Ville'], __LINE__, __FILE__, __FUNCTION__, __CLASS__);
|
|
$evens = array();
|
|
foreach ($ann['evenements'] as $tabEven)
|
|
{
|
|
$even = new AnnonceEvenement();
|
|
$even->CodeEven = $tabEven['CodeEven'];
|
|
$even->LibEven = $tabEven['LibEven'];
|
|
$evens[] = $even;
|
|
}
|
|
$annonce = new Annonce();
|
|
$annonce->id = $ann['id'];
|
|
$annonce->BodaccCode = $ann['BodaccCode'];
|
|
$annonce->BodaccNum = $ann['BodaccNum'];
|
|
$annonce->NumAnnonce = $ann['NumAnnonce'];
|
|
$annonce->DateParution = $ann['DateParution']; //@todo : date
|
|
$annonce->Departement = $ann['Departement'];
|
|
$annonce->Tribunal = $ann['Tribunal'];
|
|
//$annonce->TribunalCode = $ann['TribunalCode'];
|
|
$annonce->TribunalSiret = $ann['TribunalSiret'];
|
|
$annonce->Rubrique = $ann['Rubrique'];
|
|
$annonce->typeAnnonce = $ann['typeAnnonce'];
|
|
$annonce->texteRectificatif = prepareString($ann['texteRectificatif']);
|
|
$annonce->texteAnnonce = utf8_encode($ann['texteAnnonce']);
|
|
//$annonce->libFJ = $ann['libFJ'];
|
|
//$annonce->codFJ = $ann['codFJ'];
|
|
//$annonce->capital = $ann['capital'];
|
|
//$annonce->capitalDev = $ann['capitalDev'];
|
|
$annonce->dateEffet = $ann['dateEffet']; //@todo : date
|
|
$annonce->dateJugement = $ann['dateJugement']; //@todo : date
|
|
$annonce->dateInsertionSD = $ann['dateInsertionSD']; //@todo : date
|
|
$annonce->evenements = $evens;
|
|
$annonce->Lien_Annonce_Pdf = $ann['Lien_Annonce_Pdf'];
|
|
|
|
$liste[] = $annonce;
|
|
}
|
|
}
|
|
|
|
if (is_array($annsA))
|
|
{
|
|
foreach ($annsA as $nb=>$ann)
|
|
{
|
|
//debugLog('I', "Siren/Siret $siren trouvé : ".$etab['Siren'].' '.$etab['Nic'].', '.$etab['Nom'] .', '.$etab['CP'].', '.$etab['Ville'], __LINE__, __FILE__, __FUNCTION__, __CLASS__);
|
|
$evens = array();
|
|
foreach ($ann['evenements'] as $tabEven)
|
|
{
|
|
$even = new AnnonceEvenement();
|
|
$even->CodeEven = $tabEven['CodeEven'];
|
|
$even->LibEven = $tabEven['LibEven'];
|
|
$evens[] = $even;
|
|
}
|
|
|
|
$annonce = new Annonce();
|
|
$annonce->id = $ann['id'];
|
|
$annonce->BodaccCode = $ann['BodaccCode'];
|
|
$annonce->BodaccNum = $ann['BodaccNum'];
|
|
$annonce->NumAnnonce = $ann['NumAnnonce'];
|
|
$annonce->DateParution = $ann['DateParution']; //@todo : date
|
|
$annonce->Departement = $ann['Departement'];
|
|
$annonce->Tribunal = $ann['Tribunal'];
|
|
//$annonce->TribunalCode = $ann['TribunalCode'];
|
|
$annonce->TribunalSiret = $ann['TribunalSiret'];
|
|
$annonce->Rubrique = $ann['Rubrique'];
|
|
$annonce->typeAnnonce = $ann['typeAnnonce'];
|
|
$annonce->texteRectificatif = prepareString($ann['texteRectificatif']);
|
|
$annonce->texteAnnonce = utf8_encode($ann['texteAnnonce']);
|
|
//$annonce->libFJ = $ann['libFJ'];
|
|
//$annonce->codFJ = $ann['codFJ'];
|
|
//$annonce->capital = $ann['capital'];
|
|
//$annonce->capitalDev = $ann['capitalDev'];
|
|
//@todo : date
|
|
$annonce->dateEffet = $ann['dateEffet']; //@todo : date
|
|
$annonce->dateJugement = $ann['dateJugement']; //@todo : date
|
|
$annonce->dateInsertionSD = $ann['dateInsertionSD']; //@todo : date
|
|
$annonce->evenements = $evens;
|
|
$annonce->Lien_Annonce_Pdf = $ann['Lien_Annonce_Pdf'];
|
|
|
|
$liste[] = $annonce;
|
|
}
|
|
}
|
|
|
|
if (is_array($annsM))
|
|
{
|
|
foreach ($annsM as $nb=>$ann)
|
|
{
|
|
$evens = array();
|
|
foreach ($ann['evenements'] as $tabEven)
|
|
{
|
|
$even = new AnnonceEvenement();
|
|
$even->CodeEven = $tabEven['CodeEven'];
|
|
$even->LibEven = $tabEven['LibEven'];
|
|
$evens[] = $even;
|
|
}
|
|
|
|
$annonce = new Annonce();
|
|
$annonce->id = $ann['id'];
|
|
$annonce->BodaccCode = $ann['BodaccCode'];
|
|
$annonce->BodaccNum = $ann['BodaccNum'];
|
|
$annonce->NumAnnonce = $ann['NumAnnonce'];
|
|
$annonce->DateParution = $ann['DateParution']; //@todo : date
|
|
$annonce->Departement = $ann['Departement'];
|
|
$annonce->Tribunal = $ann['Tribunal'];
|
|
//$annonce->TribunalCode = $ann['TribunalCode'];
|
|
$annonce->TribunalSiret = $ann['TribunalSiret'];
|
|
$annonce->Rubrique = $ann['Rubrique'];
|
|
$annonce->typeAnnonce = $ann['typeAnnonce'];
|
|
$annonce->texteRectificatif = prepareString($ann['texteRectificatif']);
|
|
$annonce->texteAnnonce = utf8_encode($ann['texteAnnonce']);
|
|
//$annonce->libFJ = $ann['libFJ'];
|
|
//$annonce->codFJ = $ann['codFJ'];
|
|
//$annonce->capital = $ann['capital'];
|
|
//$annonce->capitalDev = $ann['capitalDev'];
|
|
$annonce->dateEffet = $ann['dateEffet']; //@todo : date
|
|
$annonce->dateJugement = $ann['dateJugement']; //@todo : date
|
|
$annonce->dateInsertionSD = $ann['dateInsertionSD']; //@todo : date
|
|
$annonce->evenements = $evens;
|
|
$annonce->Lien_Annonce_Pdf = $ann['Lien_Annonce_Pdf'];
|
|
|
|
$liste[] = $annonce;
|
|
}
|
|
}
|
|
}
|
|
|
|
$nbReponses = count($liste);
|
|
if ($nbReponses>0){
|
|
//$liste = array_slice($liste, $position, $nbRep);
|
|
}
|
|
debugLog('I', "Nb Annonces $filtre retournées pour $siren (source=$filtre, id=$idAnn) = ". count($liste), __LINE__, __FILE__, __FUNCTION__, __CLASS__);
|
|
$this->wsLog('annonces',$siren,$filtre.'/'.$idAnn);
|
|
|
|
$output = new AnnoncesReturn();
|
|
$output->nbReponses = $nbReponses;
|
|
$output->result = $liste;
|
|
return $output;
|
|
}
|
|
|
|
/**
|
|
* Retourne le nombre d'élément pour chaque type
|
|
* @param string $siren
|
|
* @return AnnonceNum[]
|
|
*/
|
|
public function getAnnoncesNum($siren)
|
|
{
|
|
$this->authenticate();
|
|
|
|
$output = array();
|
|
|
|
if ( substr($siren,0,1)=='W' ) {
|
|
$iInsee = new MInsee();
|
|
$nb = new AnnonceNum();
|
|
$nb->type = 'asso';
|
|
$nb->num = $iInsee->getAnnoncesAssoCount($siren);
|
|
$output[] = $nb;
|
|
} elseif (intval($siren)!=0) {
|
|
$types = array('bodacc', 'balo', 'boamp', 'asso');
|
|
$iInsee = new MInsee();
|
|
$iInsee->AnnoncesLegalesVisu = true;
|
|
foreach ($types as $type) {
|
|
switch($type) {
|
|
case 'bodacc':
|
|
//@ todo : Get count
|
|
$anns = $iInsee->getAnnoncesLegales($siren);
|
|
$total = count($anns);
|
|
break;
|
|
case 'balo':
|
|
$total = $iInsee->getAnnoncesBaloCount($siren);
|
|
break;
|
|
case 'boamp':
|
|
$total = $iInsee->getAnnoncesBoampCount($siren);
|
|
break;
|
|
case 'asso':
|
|
$total = $iInsee->getAnnoncesAssoCount($siren);
|
|
break;
|
|
}
|
|
$nb = new AnnonceNum();
|
|
$nb->type = $type;
|
|
$nb->num = $total;
|
|
$output[] = $nb;
|
|
}
|
|
}
|
|
return $output;
|
|
}
|
|
|
|
/**
|
|
* Retourne les annonces légales
|
|
* @param string $siren
|
|
* @param string $idAnn
|
|
* @param AnnonceFilter[] $filtre
|
|
* @param int $position
|
|
* @param int $nbRep
|
|
* @return AnnoncesReturn
|
|
*/
|
|
public function getAnnoncesLegales($siren, $idAnn = null, $filtre = null, $position = 0, $nbRep = 20)
|
|
{
|
|
$this->authenticate();
|
|
$this->permission('annonces');
|
|
|
|
//Initialisation
|
|
if (empty($idAnn)) { $idAnn = null; }
|
|
if (empty($position)) { $position = 0; }
|
|
if (empty($nbRep)) { $nbRep = 100; }
|
|
|
|
//Valeur max
|
|
if($nbRep > 200) { $nbRep = 200; }
|
|
|
|
debugLog('I',"Annonces demandées pour $siren ($idAnn)",__LINE__,__FILE__, __FUNCTION__, __CLASS__);
|
|
|
|
if (strlen($siren)!=9) {
|
|
debugLog('W', "Siren/Siret $siren incorrect", __LINE__, __FILE__, __FUNCTION__, __CLASS__);
|
|
$this->sendError('1010');
|
|
} elseif (intval($siren)==0 && $idAnn=='') {
|
|
debugLog('W', "Siren $siren ou annonce $idAnn inexistant", __LINE__, __FILE__, __FUNCTION__, __CLASS__);
|
|
$this->sendError('1010');
|
|
}
|
|
|
|
$iInsee = new MInsee();
|
|
$iInsee->AnnoncesLegalesVisu = true;
|
|
|
|
$isList = false;
|
|
|
|
if ( is_null($idAnn) ) {
|
|
$anns = $iInsee->getAnnoncesLegales($siren, 0, '', false, false, true);
|
|
$nbReponses = count($anns);
|
|
$isList = true;
|
|
} else {
|
|
$anns = $iInsee->getAnnoncesLegales($siren, $idAnn, '', false, false, true);
|
|
$nbReponses = count($anns);
|
|
}
|
|
|
|
$liste = array();
|
|
$cpt = 0;
|
|
|
|
if ( is_array($anns) && $nbReponses > 0 ) {
|
|
foreach ($anns as $nb => $ann) {
|
|
if ($isList===true && $nb<$position) { continue; }
|
|
$cpt++;
|
|
if ($isList===true && $cpt>$nbRep) { break; }
|
|
|
|
/**
|
|
* Si l'annonce est une annonce BODACC alors
|
|
* recherche des entités concernées
|
|
*/
|
|
$entites = array();
|
|
if (in_array($ann['BodaccCode'], array('BODA', 'BODB', 'BODC'))) {
|
|
$detailM = new Application_Model_JoBodaccDetail();
|
|
$sql = $detailM->select()->from($detailM, array(
|
|
'LPAD(siren, 9, 0) AS siren',
|
|
'LPAD(nic, 5, 0) AS nic',
|
|
'raisonSociale','adresse', 'codePostal', 'ville', 'typeEven')
|
|
)->where('id=?', $ann['id']);
|
|
$result = $detailM->fetchAll($sql);
|
|
if (count($result)>1) {
|
|
foreach ($result as $entity) {
|
|
$entite = new AnnonceEntite();
|
|
$entite->siret = $entity->siren . $entity->nic;
|
|
$entite->raisonSociale = $entity->raisonSociale;
|
|
|
|
$iBodacc = new MBodacc();
|
|
$even = new AnnonceEvenement();
|
|
$even->CodeEven = $entity->typeEven;
|
|
$even->LibEven = $iBodacc->getEvenement($entity->typeEven);
|
|
|
|
$entite->event = $even;
|
|
$entites[] = $entite;
|
|
}
|
|
}
|
|
}
|
|
|
|
//List events
|
|
$evens = array();
|
|
foreach ($ann['evenements'] as $tabEven) {
|
|
$even = new AnnonceEvenement();
|
|
$even->CodeEven = $tabEven['CodeEven'];
|
|
$even->LibEven = $tabEven['LibEven'];
|
|
$evens[] = $even;
|
|
}
|
|
|
|
$annonce = new Annonce();
|
|
$annonce->id = $ann['id'];
|
|
$annonce->BodaccCode = $ann['BodaccCode'];
|
|
$annonce->BodaccNum = $ann['BodaccNum'];
|
|
$annonce->NumAnnonce = $ann['NumAnnonce'];
|
|
$annonce->DateParution = $ann['DateParution']; //@todo : date
|
|
$annonce->Departement = $ann['Departement'];
|
|
$annonce->Tribunal = $ann['Tribunal'];
|
|
$annonce->TribunalCode = $ann['TribunalCode'];
|
|
$annonce->TribunalSiret = $ann['TribunalSiret'];
|
|
$annonce->Rubrique = $ann['Rubrique'];
|
|
$annonce->typeAnnonce = $ann['typeAnnonce'];
|
|
$annonce->texteAnnonce = $ann['texteAnnonce'];
|
|
$annonce->dateEffet = $ann['dateEffet']; //@todo : date
|
|
$annonce->dateJugement = $ann['dateJugement']; //@todo : date
|
|
$annonce->dateInsertionSD = $ann['dateInsertionSD']; //@todo : date
|
|
$annonce->evenements = $evens;
|
|
$annonce->entites = $entites;
|
|
$annonce->deleted = $ann['deleted'];
|
|
|
|
$liste[] = $annonce;
|
|
}
|
|
}
|
|
|
|
$this->wsLog('annonces',$siren,$idAnn);
|
|
|
|
$output = new AnnoncesReturn();
|
|
$output->nbReponses = $nbReponses;
|
|
$output->result = $liste;
|
|
return $output;
|
|
}
|
|
|
|
/**
|
|
* Retourne les annonces du journal officiel des associations
|
|
* @param string $siren
|
|
* @param string $idAnn
|
|
* @param AnnonceFilter[] $filtre
|
|
* @param int $position
|
|
* @param int $nbRep
|
|
* @return AnnoncesReturn
|
|
*/
|
|
public function getAnnoncesAsso($siren, $idAnn = null, $filtre = null, $position = 0, $nbRep = 20)
|
|
{
|
|
$this->authenticate();
|
|
$this->permission('annonces');
|
|
|
|
//Initialisation
|
|
if (empty($idAnn)) { $idAnn = 0; }
|
|
if (empty($position)) { $position = 0; }
|
|
if (empty($nbRep)) { $nbRep = 20; }
|
|
|
|
//Valeur max
|
|
if($nbRep > 200) { $nbRep = 200; }
|
|
|
|
debugLog('I',"Annonces demandées pour $siren ($filtre, $idAnn)",__LINE__,__FILE__, __FUNCTION__, __CLASS__);
|
|
|
|
if (strlen($siren)!=9 && substr($siren,0,1)!='W') {
|
|
debugLog('W', "Siren/Siret $siren incorrect", __LINE__, __FILE__, __FUNCTION__, __CLASS__);
|
|
$this->sendError('1010');
|
|
} elseif (intval($siren)==0 && is_null($idAnn)) {
|
|
debugLog('W', "Siren $siren ou annonce $idAnn inexistant", __LINE__, __FILE__, __FUNCTION__, __CLASS__);
|
|
$this->sendError('1010');
|
|
}
|
|
|
|
$iInsee = new MInsee();
|
|
|
|
$nbReponses = $iInsee->getAnnoncesAssoCount($siren, $idAnn);
|
|
$anns = $iInsee->getAnnoncesAsso($siren, $idAnn, $position, $nbRep);
|
|
|
|
$liste = array();
|
|
|
|
if (is_array($anns))
|
|
{
|
|
foreach ($anns as $nb=>$ann)
|
|
{
|
|
$evens = array();
|
|
foreach ($ann['evenements'] as $tabEven)
|
|
{
|
|
$even = new AnnonceEvenement();
|
|
$even->CodeEven = $tabEven['CodeEven'];
|
|
$even->LibEven = $tabEven['LibEven'];
|
|
$evens[] = $even;
|
|
}
|
|
|
|
$annonce = new Annonce();
|
|
$annonce->id = $ann['id'];
|
|
$annonce->BodaccCode = $ann['BodaccCode'];
|
|
$annonce->BodaccNum = $ann['BodaccNum'];
|
|
$annonce->NumAnnonce = $ann['NumAnnonce'];
|
|
$annonce->DateParution = $ann['DateParution']; //@todo : date
|
|
$annonce->Departement = $ann['Departement'];
|
|
$annonce->Tribunal = $ann['Tribunal'];
|
|
//$annonce->TribunalCode = $ann['TribunalCode'];
|
|
$annonce->TribunalSiret = $ann['TribunalSiret'];
|
|
$annonce->Rubrique = $ann['Rubrique'];
|
|
$annonce->typeAnnonce = $ann['typeAnnonce'];
|
|
$annonce->texteRectificatif = prepareString($ann['texteRectificatif']);
|
|
$annonce->texteAnnonce = utf8_encode($ann['texteAnnonce']);
|
|
//$annonce->libFJ = $ann['libFJ'];
|
|
//$annonce->codFJ = $ann['codFJ'];
|
|
//$annonce->capital = $ann['capital'];
|
|
//$annonce->capitalDev = $ann['capitalDev'];
|
|
//@todo : date
|
|
$annonce->dateEffet = $ann['dateEffet']; //@todo : date
|
|
$annonce->dateJugement = $ann['dateJugement']; //@todo : date
|
|
$annonce->dateInsertionSD = $ann['dateInsertionSD']; //@todo : date
|
|
$annonce->evenements = $evens;
|
|
$annonce->Lien_Annonce_Pdf = $ann['Lien_Annonce_Pdf'];
|
|
$annonce->deleted = $ann['deleted'];
|
|
|
|
$liste[] = $annonce;
|
|
}
|
|
}
|
|
|
|
$this->wsLog('annonces',$siren,$idAnn);
|
|
|
|
$output = new AnnoncesReturn();
|
|
$output->nbReponses = $nbReponses;
|
|
$output->result = $liste;
|
|
return $output;
|
|
}
|
|
|
|
protected function getAnnoncesBoampList($siren, $filtre = null, $position = 0, $nbRep = 20)
|
|
{
|
|
|
|
}
|
|
|
|
/**
|
|
* Retourne les annonces de marché public
|
|
* @param string $siren
|
|
* @param string $idAnn
|
|
* @param AnnonceFilter[] $filtre
|
|
* @param int $position
|
|
* @param int $nbRep
|
|
* @return AnnoncesReturn
|
|
*/
|
|
public function getAnnoncesBoamp($siren, $idAnn = null, $filtre = null, $position = 0, $nbRep = 20)
|
|
{
|
|
$this->authenticate();
|
|
$this->permission('annonces');
|
|
|
|
//Initialisation
|
|
if (empty($idAnn)) { $idAnn = ''; }
|
|
if (empty($position)) { $position = 0; }
|
|
if (empty($nbRep)) { $nbRep = 20; }
|
|
|
|
//Valeur max
|
|
if($nbRep > 200) { $nbRep = 200; }
|
|
|
|
$type = array('A', 'M');
|
|
|
|
if (is_array($filtre->item) && count($filtre->item)>0) {
|
|
foreach($filtre->item as $item) {
|
|
if ( $item->key == 'type' ) {
|
|
$type = $item->value;
|
|
}
|
|
}
|
|
}
|
|
|
|
if (strlen($siren)<>9) {
|
|
debugLog('W', "Siren/Siret $siren incorrect", __LINE__, __FILE__, __FUNCTION__, __CLASS__);
|
|
$this->sendError('1010');
|
|
} elseif (intval($siren)==0 && is_null($idAnn)) {
|
|
debugLog('W', "Siren $siren ou annonce $idAnn inexistant", __LINE__, __FILE__, __FUNCTION__, __CLASS__);
|
|
$this->sendError('1010');
|
|
}
|
|
|
|
$iInsee = new MInsee();
|
|
if ( empty($idAnn) ) {
|
|
$nbReponses = $iInsee->getAnnoncesBoampCount($siren, $type);
|
|
$anns = $iInsee->getAnnoncesBoamp($siren, $idAnn, $type, $position, $nbRep);
|
|
} else {
|
|
$anns = $iInsee->getAnnoncesBoamp($siren, $idAnn, $type, 0, 1);
|
|
$nbReponses = count($anns);
|
|
}
|
|
|
|
$liste = array();
|
|
if (is_array($anns) && count($anns)>0) {
|
|
foreach ($anns as $nb=>$ann) {
|
|
$entites = array();
|
|
|
|
//Add acheteur
|
|
$identite = $iInsee->getIdentiteLight($siren);
|
|
$entite = new AnnonceEntite();
|
|
$entite->siret = $identite['Siret'];
|
|
$entite->raisonSociale = $identite['Nom'];
|
|
$even = new AnnonceEvenement();
|
|
//$even->CodeEven = '';
|
|
$even->LibEven = 'Acheteur';
|
|
$entite->event = $even;
|
|
$entites[] = $entite;
|
|
|
|
//Search titulaire
|
|
$boamplotsM = new Application_Model_JoBoampLots();
|
|
$sql = $boamplotsM->select()->from($boamplotsM, array(
|
|
'LPAD(siren, 9, 000000000) AS siren',
|
|
'LPAD(nic, 5, 00000) AS nic', 'nom','adresse','cp', 'ville', 'pays')
|
|
)->where('idAnn=?', substr($ann['id'],2));
|
|
|
|
$result = $boamplotsM->fetchAll($sql);
|
|
|
|
if (count($result)>0) {
|
|
foreach ($result as $entity) {
|
|
$entite = new AnnonceEntite();
|
|
$entite->siret = $entity->siren.$entity->nic;
|
|
$entite->raisonSociale = $entity->nom;
|
|
|
|
$even = new AnnonceEvenement();
|
|
//$even->CodeEven = '';
|
|
$even->LibEven = 'Attributaire';
|
|
$entite->event = $even;
|
|
$entites[] = $entite;
|
|
}
|
|
}
|
|
|
|
//Events
|
|
$evens = array();
|
|
foreach ($ann['evenements'] as $tabEven) {
|
|
$even = new AnnonceEvenement();
|
|
$even->CodeEven = $tabEven['CodeEven'];
|
|
$even->LibEven = $tabEven['LibEven'];
|
|
$evens[] = $even;
|
|
}
|
|
|
|
$annonce = new Annonce();
|
|
$annonce->id = $ann['id'];
|
|
$annonce->BodaccCode = $ann['BodaccCode'];
|
|
$annonce->BodaccNum = $ann['BodaccNum'];
|
|
$annonce->NumAnnonce = $ann['NumAnnonce'];
|
|
$annonce->DateParution = $ann['DateParution']; //@todo : date
|
|
$annonce->Departement = $ann['Departement'];
|
|
$annonce->Tribunal = $ann['Tribunal'];
|
|
//$annonce->TribunalCode = $ann['TribunalCode'];
|
|
$annonce->TribunalSiret = $ann['TribunalSiret'];
|
|
$annonce->Rubrique = $ann['Rubrique'];
|
|
$annonce->typeAnnonce = $ann['typeAnnonce'];
|
|
$annonce->texteRectificatif = prepareString($ann['texteRectificatif']);
|
|
$annonce->texteAnnonce = $ann['texteAnnonce'];
|
|
//$annonce->libFJ = $ann['libFJ'];
|
|
//$annonce->codFJ = $ann['codFJ'];
|
|
//$annonce->capital = $ann['capital'];
|
|
//$annonce->capitalDev = $ann['capitalDev'];
|
|
$annonce->dateEffet = $ann['dateEffet']; //@todo : date
|
|
$annonce->dateJugement = $ann['dateJugement']; //@todo : date
|
|
$annonce->dateInsertionSD = $ann['dateInsertionSD']; //@todo : date
|
|
$annonce->evenements = $evens;
|
|
$annonce->entites = $entites;
|
|
$annonce->deleted = $ann['deleted'];
|
|
|
|
$liste[] = $annonce;
|
|
}
|
|
}
|
|
|
|
$this->wsLog('annonces',$siren,$idAnn);
|
|
|
|
$output = new AnnoncesReturn();
|
|
$output->nbReponses = $nbReponses;
|
|
$output->result = $liste;
|
|
return $output;
|
|
|
|
}
|
|
|
|
/**
|
|
* Retourne les annonces du bulletins des annonces légales obligatoires
|
|
* @param string $siren
|
|
* @param string $idAnn
|
|
* @param AnnonceFilter[] $filtre
|
|
* @param int $position
|
|
* @param int $nbRep
|
|
* @return AnnoncesReturn
|
|
*/
|
|
public function getAnnoncesBalo($siren, $idAnn = null, $filtre = null, $position = 0, $nbRep = 20)
|
|
{
|
|
$this->authenticate();
|
|
$this->permission('annonces');
|
|
|
|
//Initialisation
|
|
if (empty($idAnn)) { $idAnn = null; }
|
|
if (empty($position)) { $position = 0; }
|
|
if (empty($nbRep)) { $nbRep = 20; }
|
|
|
|
//Valeur max
|
|
if($nbRep > 200) { $nbRep = 200; }
|
|
|
|
debugLog('I',"Annonces demandées pour $siren ($filtre, $idAnn)",__LINE__,__FILE__, __FUNCTION__, __CLASS__);
|
|
|
|
if (strlen($siren)<>9) {
|
|
debugLog('W', "Siren/Siret $siren incorrect", __LINE__, __FILE__, __FUNCTION__, __CLASS__);
|
|
$this->sendError('1010');
|
|
} elseif (intval($siren)==0 && is_null($idAnn)) {
|
|
debugLog('W', "Siren $siren ou annonce $idAnn inexistant", __LINE__, __FILE__, __FUNCTION__, __CLASS__);
|
|
$this->sendError('1010');
|
|
}
|
|
|
|
$iInsee = new MInsee();
|
|
|
|
if ( is_null($idAnn) ) {
|
|
$nbReponses = $iInsee->getAnnoncesBaloCount($siren);
|
|
$anns = $iInsee->getAnnoncesBalo($siren, $idAnn, $position, $nbRep);
|
|
} else {
|
|
$anns = $iInsee->getAnnoncesBalo($siren, $idAnn, 0, 1);
|
|
$nbReponses = count($anns);
|
|
}
|
|
|
|
$liste = array();
|
|
if (is_array($anns) && count($anns)>0)
|
|
{
|
|
foreach ($anns as $nb=>$ann)
|
|
{
|
|
$evens = array();
|
|
foreach ($ann['evenements'] as $tabEven)
|
|
{
|
|
$even = new AnnonceEvenement();
|
|
$even->CodeEven = $tabEven['CodeEven'];
|
|
$even->LibEven = $tabEven['LibEven'];
|
|
$evens[] = $even;
|
|
}
|
|
$annonce = new Annonce();
|
|
$annonce->id = $ann['id'];
|
|
$annonce->BodaccCode = $ann['BodaccCode'];
|
|
$annonce->BodaccNum = $ann['BodaccNum'];
|
|
$annonce->NumAnnonce = $ann['NumAnnonce'];
|
|
$annonce->DateParution = $ann['DateParution']; //@todo : date
|
|
$annonce->Departement = $ann['Departement'];
|
|
$annonce->Tribunal = $ann['Tribunal'];
|
|
$annonce->TribunalSiret = $ann['TribunalSiret'];
|
|
$annonce->Rubrique = $ann['Rubrique'];
|
|
$annonce->typeAnnonce = $ann['typeAnnonce'];
|
|
$annonce->texteRectificatif = prepareString($ann['texteRectificatif']);
|
|
$annonce->texteAnnonce = utf8_encode($ann['texteAnnonce']);
|
|
$annonce->dateEffet = $ann['dateEffet']; //@todo : date
|
|
$annonce->dateJugement = $ann['dateJugement']; //@todo : date
|
|
$annonce->dateInsertionSD = $ann['dateInsertionSD']; //@todo : date
|
|
$annonce->evenements = $evens;
|
|
$annonce->Lien_Annonce_Pdf = $ann['Lien_Annonce_Pdf'];
|
|
$annonce->deleted = $ann['deleted'];
|
|
|
|
$liste[] = $annonce;
|
|
}
|
|
}
|
|
|
|
$this->wsLog('annonces',$siren,$idAnn);
|
|
|
|
$output = new AnnoncesReturn();
|
|
$output->nbReponses = $nbReponses;
|
|
$output->result = $liste;
|
|
return $output;
|
|
}
|
|
|
|
/**
|
|
* Evaluation indiScore d'une entreprise
|
|
* @param string $siren Siren de l'entreprise
|
|
* @param string $nic Nic de l'établissement
|
|
* @param integer $niveau Niveau des commentaires (Suivant droits d'accès 1=INDISCORE, 2=INDISCORE2, 3=INDISCORE3)
|
|
* @param bool $plus Si true, mise en surveillance privilèges
|
|
* @param string $ref Si $plus=true, référence de la mise en Surveillance
|
|
* @param integer $encours Si $plus=true, encours client demandé lors de la mise en Surveillance
|
|
* @param string $email Si $plus=true, email client pour la mise en surveillance
|
|
* @return Indiscore
|
|
*/
|
|
public function getIndiScore($siren, $nic=0, $niveau=2, $plus=false, $ref='', $encours=0, $email='')
|
|
{
|
|
$this->authenticate();
|
|
|
|
//Initialisation
|
|
$accesDist = true;
|
|
if (empty($nic)) { $nic = 0; }
|
|
if (empty($niveau)) { $niveau = 2; }
|
|
if (empty($plus)) { $plus = false; }
|
|
if ( !in_array($niveau, array(0,1,2,3,4,5)) ) { $niveau = 2; }
|
|
$perm = false;
|
|
//@todo : Gestion des droits
|
|
switch($niveau){
|
|
case 3: $perms = array('indiscore3', 'indiscore3p'); break;
|
|
case 2: $perms = array('indiscore2', 'indiscore2p', 'indiscore3', 'indiscore3p'); break;
|
|
case 1: $perms = array('indiscore', 'indiscorep'); break;
|
|
}
|
|
foreach($perms as $item){
|
|
if ( $this->checkPerm($item) ){
|
|
$perm = true;
|
|
break;
|
|
}
|
|
}
|
|
if ($perm === false) {
|
|
$this->sendError('0902');
|
|
}
|
|
|
|
$tabRet = array();
|
|
debugLog('I',"IndiScore demandée pour $siren en niveau $niveau",__LINE__,__FILE__, __FUNCTION__, __CLASS__);
|
|
if (strlen($siren)>9 || (substr($siren,0,9)*1)<100 ){
|
|
debugLog('W', "Siren $siren incorrect", __LINE__, __FILE__, __FUNCTION__, __CLASS__);
|
|
$this->sendError('1010');
|
|
}
|
|
|
|
$tDeb = microtime(true);
|
|
require_once 'Metier/scores/classMScores.php';
|
|
$tabRet = calculIndiScore($siren, $nic, $accesDist, $niveau, false, 'scores');
|
|
$duree = round(microtime(true)-$tDeb,3);
|
|
debugLog('W', "indiscore DUREE = $duree s", __LINE__, __FILE__, __FUNCTION__, __CLASS__);
|
|
|
|
$output = new Indiscore();
|
|
foreach($tabRet as $key => $value){
|
|
if ($key=='paiements'){
|
|
$parMont = $value['parMont'];
|
|
$parTrim = $value['parTrim'];
|
|
$tabMont = array();
|
|
foreach($parMont as $parMontK => $parMontV){
|
|
$paiementMont = new IndiscorePaiementDetail();
|
|
$paiementMont->id = $parMontK;
|
|
$paiementMont->nb = $parMontV['nb'];
|
|
if (array_key_exists('d=180', $parMontV)){
|
|
$paiementMont->d180 = $parMontV['d=180'];
|
|
}
|
|
if (array_key_exists('d=150', $parMontV)){
|
|
$paiementMont->d150 = $parMontV['d=150'];
|
|
}
|
|
if (array_key_exists('d=120', $parMontV)){
|
|
$paiementMont->d120 = $parMontV['d=120'];
|
|
}
|
|
if (array_key_exists('d=90', $parMontV)){
|
|
$paiementMont->d90 = $parMontV['d=90'];
|
|
}
|
|
if (array_key_exists('d=60', $parMontV)){
|
|
$paiementMont->d60 = $parMontV['d=60'];
|
|
}
|
|
if (array_key_exists('d=30', $parMontV)){
|
|
$paiementMont->d30 = $parMontV['d=30'];
|
|
}
|
|
$tabMont[] = $paiementMont;
|
|
}
|
|
$tabTrim = array();
|
|
foreach($parTrim as $parTrimK => $parTrimV){
|
|
$paiementTrim = new IndiscorePaiementDetail();
|
|
$paiementTrim->id = $parTrimK;
|
|
$paiementTrim->nb = $parTrimV['nb'];
|
|
if (array_key_exists('d=180', $parTrimV)){
|
|
$paiementTrim->d180 = $parTrimV['d=180'];
|
|
}
|
|
if (array_key_exists('d=150', $parTrimV)){
|
|
$paiementTrim->d150 = $parTrimV['d=150'];
|
|
}
|
|
if (array_key_exists('d=120', $parTrimV)){
|
|
$paiementTrim->d120 = $parTrimV['d=120'];
|
|
}
|
|
if (array_key_exists('d=90', $parTrimV)){
|
|
$paiementTrim->d90 = $parTrimV['d=90'];
|
|
}
|
|
if (array_key_exists('d=60', $parTrimV)){
|
|
$paiementTrim->d60 = $parTrimV['d=60'];
|
|
}
|
|
if (array_key_exists('d=30', $parTrimV)){
|
|
$paiementTrim->d30 = $parTrimV['d=30'];
|
|
}
|
|
$tabTrim[] = $paiementTrim;
|
|
}
|
|
$paiement = new IndiscorePaiement();
|
|
$paiement->parMont = $tabMont;
|
|
$paiement->parTrim = $tabTrim;
|
|
$output->paiements = $paiement;
|
|
|
|
} elseif ($key=='Notes_Structure') {
|
|
|
|
$notesStructure = new IndiscoreNotesStructure();
|
|
$notesStructure->activite = $value['activite'];
|
|
$notesStructure->naf4 = $value['naf4'];
|
|
$notesStructure->age = $value['age'];
|
|
$notesStructure->capital = $value['capital'];
|
|
$notesStructure->effectif = $value['effectif'];
|
|
$notesStructure->fj = $value['fj'];
|
|
$notesStructure->localite = $value['localite'];
|
|
$notesStructure->singulier = $value['singulier'];
|
|
$output->Notes_Structure = $notesStructure;
|
|
|
|
} elseif ($key=='tabBilans') {
|
|
|
|
$tabRet = array();
|
|
foreach($value as $bilan)
|
|
{
|
|
$element = new ListeBilans();
|
|
$element->dateProvPartenaire = $bilan['dateProvPartenaire']; //@todo : date
|
|
$element->dateInsert = $bilan['dateInsert']; //@todo : date
|
|
$element->typeBilan = $bilan['typeBilan'];
|
|
$element->dureeExercice = $bilan['dureeExercice'];
|
|
$element->dateExercice = $bilan['dateExercice']; //@todo : date
|
|
$element->millesime = $bilan['millesime'];
|
|
$element->dateExercicePre = $bilan['dateExercicePre']; //@todo : date
|
|
$element->dureeExercicePre = $bilan['dureeExercicePre'];
|
|
$element->monnaie = $bilan['monnaie'];
|
|
$element->source = $bilan['source'];
|
|
$tabRet[] = $element;
|
|
}
|
|
$output->tabBilans = $tabRet;
|
|
|
|
} elseif ($key=='tabBilan') {
|
|
|
|
$tabRet = array();
|
|
foreach($value as $bilan){
|
|
$resultBilan = new Bilan();
|
|
$tabPoste = array();
|
|
foreach($bilan as $bilan_key => $bilan_value){
|
|
if(!in_array($bilan_key, array('SIREN', 'DATE_FRAICHE_BILAN',
|
|
'DATE_CLOTURE', 'DATE_CLOTURE_PRE', 'DUREE_MOIS',
|
|
'DUREE_MOIS_PRE', 'MONNAIE', 'CONSOLIDE', 'MONNAIE_ORI',
|
|
'MONNAIE_LIV_UNITE', 'SOURCE', 'devise'))){
|
|
$resultPoste = new BilanPoste();
|
|
$resultPoste->id = $bilan_key;
|
|
$resultPoste->val = $bilan_value;
|
|
$tabPoste[] = $resultPoste;
|
|
} else {
|
|
$resultBilan->$bilan_key = $bilan_value;
|
|
}
|
|
}
|
|
$resultBilan->POSTES = $tabPoste;
|
|
$tabRet[] = $resultBilan;
|
|
}
|
|
$output->tabBilan = $tabRet;
|
|
|
|
} elseif ($key=='tabInfosNotations') {
|
|
|
|
$infosNotation = new IndiscoreInfosNotations();
|
|
$infosNotation->SituationFinanciere = $value['SituationFinanciere'];
|
|
$infosNotation->Notation = $value['Notation'];
|
|
$infosNotation->ProbabiliteDefaut = $value['ProbabiliteDefaut'];
|
|
$output->tabInfosNotations = $infosNotation;
|
|
|
|
} elseif ($key=='tabImportExport') {
|
|
|
|
$tabRet = array();
|
|
foreach($value as $element){
|
|
$importExport = new IndiscoreImportExport();
|
|
$importExport->importExport = $element['importExport'];
|
|
$importExport->annee = $element['annee'];
|
|
$importExport->rangNational = $element['rangNational'];
|
|
$importExport->deptSiege = $element['deptSiege'];
|
|
$tabRet[] = $importExport;
|
|
}
|
|
$output->tabImportExport = $tabRet;
|
|
|
|
} elseif ($key=='tabCommentaires') {
|
|
|
|
$tab = array();
|
|
if (count($value)>0) {
|
|
foreach($value as $comment) {
|
|
$tab[] = Scores_Locale_String::fixEncoding($comment);
|
|
}
|
|
}
|
|
$output->tabCommentaires = $tab;
|
|
|
|
} elseif ($key=='tabVariables') {
|
|
|
|
$tab = $value['CA_Y'];
|
|
$tabVar = array();
|
|
if (count($tab)>0) {
|
|
foreach($tab as $varName => $varVal){
|
|
$var = new CA_Y();
|
|
$var->id = $varName;
|
|
$var->val = $varVal;
|
|
$tabVar[] = $var;
|
|
}
|
|
}
|
|
$variables = new IndiscoreVariables();
|
|
$variables->CA_Y = $tabVar;
|
|
$output->tabVariables = $variables;
|
|
|
|
} elseif ($key=='Bilans') {
|
|
|
|
$tab = array();
|
|
foreach($value as $item)
|
|
{
|
|
$objet = new IndiscoreBilans();
|
|
$objet->Millesime = $item['Millesime'];
|
|
$objet->FraisPerso = $item['FraisPerso'];
|
|
$objet->CA = $item['CA'];
|
|
$objet->EBE = $item['EBE'];
|
|
$objet->TxInvest = $item['TxInvest'];
|
|
$objet->TxEndett = $item['TxEndett'];
|
|
$objet->DettesCT = $item['DettesCT'];
|
|
$objet->FraisFi = $item['FraisFi'];
|
|
$objet->BFR = $item['BFR'];
|
|
$objet->FR = $item['FR'];
|
|
$objet->FondsPr = $item['FondsPr'];
|
|
$objet->DelaiCli = $item['DelaiCli'];
|
|
$objet->DelaiFour = $item['DelaiFour'];
|
|
$tab[] = $objet;
|
|
}
|
|
$output->$key = $tab;
|
|
} else {
|
|
$output->$key = $value;
|
|
}
|
|
}
|
|
|
|
if ($plus) {
|
|
if (empty($ref)) $ref='Indiscore+';
|
|
if (empty($email)) $email=$this->User->email;
|
|
$this->setSurveillance($siren, $email, $ref, 'privileges');
|
|
$this->setSurveillance($siren, $email, $ref, 'score', false, $encours);
|
|
if ($this->User->idClient==89)
|
|
$this->setSurveillance($siren, $email, $ref, 'annonces');
|
|
$this->wsLog('indiscore+',$siren);
|
|
} else
|
|
$this->wsLog('indiscore',$siren);
|
|
return $output;
|
|
}
|
|
|
|
/**
|
|
* Evaluation valorsation d'une entreprise
|
|
* @param string $siren Siren de l'entreprise
|
|
* @param string $nic Nic de l'établissement
|
|
* @param integer $niveau Niveau des commentaires
|
|
* @return Valo
|
|
*/
|
|
public function getValo($siren, $nic=0, $niveau=2)
|
|
{
|
|
$this->authenticate();
|
|
$this->permission('VALORISATION');
|
|
|
|
//Initialisation
|
|
$accesPartenaire = true;
|
|
if (APPLICATION_ENV == 'development') {
|
|
$accesPartenaire = false;
|
|
}
|
|
if (empty($nic)) {
|
|
$nic = 0;
|
|
}
|
|
$niveau = 2;
|
|
|
|
$tabRet = array();
|
|
debugLog('I',"IndiScore demandée pour $siren en niveau $niveau",__LINE__,__FILE__, __FUNCTION__, __CLASS__);
|
|
if (strlen($siren)>9 || (substr($siren,0,9)*1)<100 ){
|
|
debugLog('W', "Siren $siren incorrect", __LINE__, __FILE__, __FUNCTION__, __CLASS__);
|
|
$this->sendError('1010');
|
|
}
|
|
|
|
$tDeb = microtime(true);
|
|
require_once 'Metier/scores/classMScores.php';
|
|
$tabRet = calculIndiScore($siren, $nic, $accesPartenaire, $niveau, false, 'valo');
|
|
$duree = round(microtime(true)-$tDeb,3);
|
|
debugLog('W', "indiscore DUREE = $duree s", __LINE__, __FILE__, __FUNCTION__, __CLASS__);
|
|
|
|
$ouput = new Valo();
|
|
|
|
$Indiscore = new Indiscore();
|
|
|
|
foreach($tabRet as $key => $value){
|
|
if ($key=='paiements'){
|
|
$parMont = $value['parMont'];
|
|
$parTrim = $value['parTrim'];
|
|
$tabMont = array();
|
|
foreach($parMont as $parMontK => $parMontV){
|
|
$paiementMont = new IndiscorePaiementDetail();
|
|
$paiementMont->id = $parMontK;
|
|
$paiementMont->nb = $parMontV['nb'];
|
|
if (array_key_exists('d=180', $parMontV)){
|
|
$paiementMont->d180 = $parMontV['d=180'];
|
|
}
|
|
if (array_key_exists('d=150', $parMontV)){
|
|
$paiementMont->d150 = $parMontV['d=150'];
|
|
}
|
|
if (array_key_exists('d=120', $parMontV)){
|
|
$paiementMont->d120 = $parMontV['d=120'];
|
|
}
|
|
if (array_key_exists('d=90', $parMontV)){
|
|
$paiementMont->d90 = $parMontV['d=90'];
|
|
}
|
|
if (array_key_exists('d=60', $parMontV)){
|
|
$paiementMont->d60 = $parMontV['d=60'];
|
|
}
|
|
if (array_key_exists('d=30', $parMontV)){
|
|
$paiementMont->d30 = $parMontV['d=30'];
|
|
}
|
|
$tabMont[] = $paiementMont;
|
|
}
|
|
$tabTrim = array();
|
|
foreach($parTrim as $parTrimK => $parTrimV){
|
|
$paiementTrim = new IndiscorePaiementDetail();
|
|
$paiementTrim->id = $parTrimK;
|
|
$paiementTrim->nb = $parTrimV['nb'];
|
|
if (array_key_exists('d=180', $parTrimV)){
|
|
$paiementTrim->d180 = $parTrimV['d=180'];
|
|
}
|
|
if (array_key_exists('d=150', $parTrimV)){
|
|
$paiementTrim->d150 = $parTrimV['d=150'];
|
|
}
|
|
if (array_key_exists('d=120', $parTrimV)){
|
|
$paiementTrim->d120 = $parTrimV['d=120'];
|
|
}
|
|
if (array_key_exists('d=90', $parTrimV)){
|
|
$paiementTrim->d90 = $parTrimV['d=90'];
|
|
}
|
|
if (array_key_exists('d=60', $parTrimV)){
|
|
$paiementTrim->d60 = $parTrimV['d=60'];
|
|
}
|
|
if (array_key_exists('d=30', $parTrimV)){
|
|
$paiementTrim->d30 = $parTrimV['d=30'];
|
|
}
|
|
$tabTrim[] = $paiementTrim;
|
|
}
|
|
$paiement = new IndiscorePaiement();
|
|
$paiement->parMont = $tabMont;
|
|
$paiement->parTrim = $tabTrim;
|
|
$Indiscore->paiements = $paiement;
|
|
|
|
} elseif ($key=='Notes_Structure') {
|
|
|
|
$notesStructure = new IndiscoreNotesStructure();
|
|
$notesStructure->activite = $value['activite'];
|
|
$notesStructure->naf4 = $value['naf4'];
|
|
$notesStructure->age = $value['age'];
|
|
$notesStructure->capital = $value['capital'];
|
|
$notesStructure->effectif = $value['effectif'];
|
|
$notesStructure->fj = $value['fj'];
|
|
$notesStructure->localite = $value['localite'];
|
|
$notesStructure->singulier = $value['singulier'];
|
|
$Indiscore->Notes_Structure = $notesStructure;
|
|
|
|
} elseif ($key=='tabBilans') {
|
|
|
|
$tabRet = array();
|
|
foreach($value as $bilan)
|
|
{
|
|
$element = new ListeBilans();
|
|
$element->dateProvPartenaire = $bilan['dateProvPartenaire']; //@todo : date
|
|
$element->dateInsert = $bilan['dateInsert']; //@todo : date
|
|
$element->typeBilan = $bilan['typeBilan'];
|
|
$element->dureeExercice = $bilan['dureeExercice'];
|
|
$element->dateExercice = $bilan['dateExercice']; //@todo : date
|
|
$element->millesime = $bilan['millesime'];
|
|
$element->dateExercicePre = $bilan['dateExercicePre']; //@todo : date
|
|
$element->dureeExercicePre = $bilan['dureeExercicePre'];
|
|
$element->monnaie = $bilan['monnaie'];
|
|
$element->source = $bilan['source'];
|
|
$tabRet[] = $element;
|
|
}
|
|
$Indiscore->tabBilans = $tabRet;
|
|
|
|
} elseif ($key=='tabBilan') {
|
|
|
|
$tabRet = array();
|
|
foreach($value as $bilan){
|
|
$resultBilan = new Bilan();
|
|
$tabPoste = array();
|
|
foreach($bilan as $bilan_key => $bilan_value){
|
|
if(!in_array($bilan_key, array('SIREN', 'DATE_FRAICHE_BILAN',
|
|
'DATE_CLOTURE', 'DATE_CLOTURE_PRE', 'DUREE_MOIS',
|
|
'DUREE_MOIS_PRE', 'MONNAIE', 'CONSOLIDE', 'MONNAIE_ORI',
|
|
'MONNAIE_LIV_UNITE', 'SOURCE', 'devise'))){
|
|
$resultPoste = new BilanPoste();
|
|
$resultPoste->id = $bilan_key;
|
|
$resultPoste->val = $bilan_value;
|
|
$tabPoste[] = $resultPoste;
|
|
} else {
|
|
$resultBilan->$bilan_key = $bilan_value;
|
|
}
|
|
}
|
|
$resultBilan->POSTES = $tabPoste;
|
|
$tabRet[] = $resultBilan;
|
|
}
|
|
$Indiscore->tabBilan = $tabRet;
|
|
|
|
} elseif ($key=='tabInfosNotations') {
|
|
|
|
$infosNotation = new IndiscoreInfosNotations();
|
|
$infosNotation->SituationFinanciere = $value['SituationFinanciere'];
|
|
$infosNotation->Notation = $value['Notation'];
|
|
$infosNotation->ProbabiliteDefaut = $value['ProbabiliteDefaut'];
|
|
$Indiscore->tabInfosNotations = $infosNotation;
|
|
|
|
} elseif ($key=='tabImportExport') {
|
|
|
|
$tabRet = array();
|
|
foreach($value as $element){
|
|
$importExport = new IndiscoreImportExport();
|
|
$importExport->importExport = $element['importExport'];
|
|
$importExport->annee = $element['annee'];
|
|
$importExport->rangNational = $element['rangNational'];
|
|
$importExport->deptSiege = $element['deptSiege'];
|
|
$tabRet[] = $importExport;
|
|
}
|
|
$Indiscore->tabImportExport = $tabRet;
|
|
|
|
} elseif ($key=='tabCommentaires') {
|
|
|
|
$tab = array();
|
|
foreach($value as $comment) {
|
|
$tab[] = Scores_Locale_String::fixEncoding($comment);
|
|
}
|
|
$Indiscore->tabCommentaires = $tab;
|
|
|
|
} elseif ($key=='tabVariables') {
|
|
|
|
$tab = $value['CA_Y'];
|
|
$tabVar = array();
|
|
if (count($tab)>0) {
|
|
foreach($tab as $varName => $varVal){
|
|
$var = new CA_Y();
|
|
$var->id = $varName;
|
|
$var->val = $varVal;
|
|
$tabVar[] = $var;
|
|
}
|
|
}
|
|
$variables = new IndiscoreVariables();
|
|
$variables->CA_Y = $tabVar;
|
|
$Indiscore->tabVariables = $variables;
|
|
|
|
} elseif ($key=='Bilans') {
|
|
|
|
$tab = array();
|
|
foreach($value as $item)
|
|
{
|
|
$objet = new IndiscoreBilans();
|
|
$objet->Millesime = $item['Millesime'];
|
|
$objet->FraisPerso = $item['FraisPerso'];
|
|
$objet->CA = $item['CA'];
|
|
$objet->EBE = $item['EBE'];
|
|
$objet->TxInvest = $item['TxInvest'];
|
|
$objet->TxEndett = $item['TxEndett'];
|
|
$objet->DettesCT = $item['DettesCT'];
|
|
$objet->FraisFi = $item['FraisFi'];
|
|
$objet->BFR = $item['BFR'];
|
|
$objet->FR = $item['FR'];
|
|
$objet->FondsPr = $item['FondsPr'];
|
|
$objet->DelaiCli = $item['DelaiCli'];
|
|
$objet->DelaiFour = $item['DelaiFour'];
|
|
$tab[] = $objet;
|
|
}
|
|
$Indiscore->$key = $tab;
|
|
} else {
|
|
$Indiscore->$key = $value;
|
|
}
|
|
}
|
|
|
|
$output->Indiscore = $Indiscore;
|
|
|
|
//Tableau d'infos sur les formules
|
|
$tabFormules = include APPLICATION_PATH . '/../library/Metier/scores/Data/Formules.php';
|
|
$tabBorneMin = $tabBorneMax = array();
|
|
foreach ($tabFormules as $formule) {
|
|
$id = $formule['id']*1;
|
|
$libelle = $formule['libelle'];
|
|
$unite = $formule['unite'];
|
|
$commentaires = $formule['commentaires'];
|
|
$tabFormulesInfos[$id] = $formule; //Pour la gestion des unités des ratios secteur
|
|
$ratiosInfos = new RatiosInfos();
|
|
$ratiosInfos->id = 'r'.$id;
|
|
$ratiosInfos->libelle = $formule['libelle'];
|
|
$ratiosInfos->unite = $formule['unite'];
|
|
$ratiosInfos->commentaires = $formule['commentaires'];
|
|
$tabRatiosInfos[] = $ratiosInfos;
|
|
$tabBorneMin[$id] = $formule['borneMin'];
|
|
$tabBorneMax[$id] = $formule['borneMax'];
|
|
}
|
|
|
|
//Ratios
|
|
global $tva, $mBil, $efftr, $tabInfla;
|
|
require_once 'Metier/scores/classMRatios.php';
|
|
$mBil = new MBilans($siren);
|
|
$tabBilans = $mBil->listeBilans($accesPartenaire, 5);
|
|
$nbBilans = count($tabBilans);
|
|
$tabBilan = $tabBil = array();
|
|
if ($nbBilans>0)
|
|
{
|
|
$iInsee = new MInsee();
|
|
$tabIdentite = $iInsee->getIdentiteEntreprise($siren,0,0,false,false);
|
|
debugLog('I',"Liste des Ratios demandée pour $siren après getIdentiteEntreprise",__LINE__,__FILE__, __FUNCTION__, __CLASS__);
|
|
$naf = $tabIdentite['NafEnt'];
|
|
$nafLib = $tabIdentite['NafEntLib'];
|
|
$efftr = $tabIdentite['Effectif']*1;
|
|
$fj = $tabIdentite['FJ'];
|
|
$i = 0;
|
|
foreach ($tabBilans as $millesime => $item) {
|
|
if ($i > 4) {
|
|
break;
|
|
}
|
|
if ( $item['typeBilan'] == 'N' ) {
|
|
$tabBilan[] = $mBil->getBilan(substr($millesime,-10), substr($millesime,0,1), '');
|
|
$i++;
|
|
} elseif ( $item['typeBilan'] == 'S' ) {
|
|
$tabN = $mBil->getBilan(substr($millesime,-10), substr($millesime,0,1), '');
|
|
$tabS = $mBil->bilanSimplifie2Normal($tabN);
|
|
$tabBilan[] = array_merge($tabN, $tabS);
|
|
$i++;
|
|
}
|
|
}
|
|
$mRatios = new MRatios();
|
|
$mRatios->setTrancheEffectif($efftr);
|
|
$tabRatios = $mRatios->calcul($tabBilan);
|
|
}
|
|
|
|
$nbRatios = count($tabRatios);
|
|
debugLog('I',"Liste des Ratios demandée pour $siren après calculRatios ($nbRatios)",__LINE__,__FILE__, __FUNCTION__, __CLASS__);
|
|
|
|
$tabAnnees = array();
|
|
if ( $nbRatios > 0 ) {
|
|
foreach ( $tabRatios as $i=>$R ) {
|
|
//Informations sur le bilan
|
|
$bilansInfos = new RatiosBilansInfos();
|
|
$bilansInfos->dateCloture = $tabBilan[$i]['DATE_CLOTURE']; //@todo : date
|
|
$bilansInfos->duree = $tabBilan[$i]['DUREE_MOIS'];
|
|
$bilansInfos->devise = $tabBilan[$i]['MONNAIE'];
|
|
$bilansInfos->typeBilan = $tabBilan[$i]['CONSOLIDE'];
|
|
$bilansInfos->unite = 'U';
|
|
if ( substr($tabBilan[$i]['DATE_CLOTURE'],0,4)>1900 ){
|
|
$tabAnnees[$i]=substr($tabBilan[$i]['DATE_CLOTURE'],0,4);
|
|
}
|
|
|
|
$tabRatiosEntrep = array();
|
|
$tabRatiosEntrepEvol = array();
|
|
foreach ( $R as $Ridx=>$Rmont ) {
|
|
if ($Rmont<>'NS') {
|
|
if ( $tabBorneMin[$Ridx]<>'' && $Rmont<$tabBorneMin[$Ridx] ){
|
|
$Rmont='<'.$tabBorneMin[$Ridx];
|
|
} elseif ( $tabBorneMax[$Ridx]<>'' && $Rmont>$tabBorneMax[$Ridx] ){
|
|
$Rmont='>'.$tabBorneMax[$Ridx];
|
|
}
|
|
}
|
|
|
|
// RatiosEntrep
|
|
$ratiosEntrep = new Ratios();
|
|
if (substr($Rmont,0,1)=='N' || substr($Rmont,0,1)=='<' || substr($Rmont,0,1)=='>'){
|
|
$ratiosEntrep->id = 'r'.$Ridx;
|
|
$ratiosEntrep->val = $Rmont;
|
|
} else {
|
|
$ratiosEntrep->id = 'r'.$Ridx;
|
|
$ratiosEntrep->val = round($Rmont,2);
|
|
}
|
|
$tabRatiosEntrep[] = $ratiosEntrep;
|
|
|
|
if ( ( $tabBilan[$i]['CONSOLIDE']=='S' && isset($tabRatios[$i+1]) && ($tabBilan[$i+1]['CONSOLIDE']=='S'
|
|
|| ($tabBilan[$i+1]['CONSOLIDE']=='N' && $tabBilan[$i+1]['DATE_CLOTURE']<>$tabBilan[$i]['DATE_CLOTURE']) ) )
|
|
|| ( $tabBilan[$i]['CONSOLIDE']=='N'&&isset($tabRatios[$i+1])&&($tabBilan[$i+1]['CONSOLIDE']=='N'
|
|
|| ($tabBilan[$i+1]['CONSOLIDE']=='S'&&$tabBilan[$i+1]['DATE_CLOTURE']<>$tabBilan[$i]['DATE_CLOTURE'])) )
|
|
) {
|
|
$Rmont=(($R[$Ridx]-$tabRatios[$i+1][$Ridx])*100)/abs($tabRatios[$i+1][$Ridx]);
|
|
}
|
|
elseif ( ( $tabBilan[$i]['CONSOLIDE']=='S' && isset($tabRatios[$i+1]) && ($tabBilan[$i+2]['CONSOLIDE']=='S'
|
|
|| ($tabBilan[$i+2]['CONSOLIDE']=='N' && $tabBilan[$i+2]['DATE_CLOTURE']<>$tabBilan[$i]['DATE_CLOTURE'])) )
|
|
|| ( $tabBilan[$i]['CONSOLIDE']=='N' && isset($tabRatios[$i+1]) && ($tabBilan[$i+2]['CONSOLIDE']=='N'
|
|
|| ($tabBilan[$i+2]['CONSOLIDE']=='S'&& $tabBilan[$i+2]['DATE_CLOTURE']<>$tabBilan[$i]['DATE_CLOTURE'])) )
|
|
) {
|
|
$Rmont = (($R[$Ridx]-$tabRatios[$i+2][$Ridx])*100)/abs($tabRatios[$i+2][$Ridx]);
|
|
} else {
|
|
$Rmont = 'NS';
|
|
}
|
|
|
|
// RatiosEntrepEvol
|
|
$ratiosEntrepEvol = new Ratios();
|
|
if ($Rmont=='NS' || $Rmont<-800 || $Rmont>800){
|
|
$ratiosEntrepEvol->id = 'r'.$Ridx;
|
|
$ratiosEntrepEvol->val = 'NS';
|
|
} else {
|
|
$ratiosEntrepEvol->id = 'r'.$Ridx;
|
|
$ratiosEntrepEvol->val = number_format($Rmont,2,',',' ');
|
|
}
|
|
$tabRatiosEntrepEvol[] = $ratiosEntrepEvol;
|
|
}
|
|
$bilansInfos->RatiosEntrep = $tabRatiosEntrep;
|
|
$bilansInfos->RatiosEntrepEvol = $tabRatiosEntrepEvol;
|
|
$tabBilansR[] = $bilansInfos;
|
|
}
|
|
}
|
|
debugLog('I',"Liste des Ratios demandée pour $siren après EVOLUTION",__LINE__,__FILE__, __FUNCTION__, __CLASS__);
|
|
|
|
// Tableau des ratios secteurs
|
|
if (strlen($naf)>4) $strNaf = " AND naf5='$naf' ";
|
|
else $strNaf = " AND naf4='$naf' ";
|
|
$strAnnees = implode(',', $tabAnnees);
|
|
|
|
$tabRatiosSecteurs = array();
|
|
|
|
$tabAnnees = array_unique($tabAnnees);
|
|
|
|
if ( count($tabAnnees)>0 ) {
|
|
$iDb = new WDB();
|
|
$tabTmp = $iDb->select('jo.ratios_secteurs',
|
|
'annee, naf5, naf4, id, (montant/nombre) AS ratio, nombre',
|
|
"1 $strNaf AND annee IN ($strAnnees) ORDER BY annee DESC, id ASC",
|
|
false, MYSQL_ASSOC);
|
|
|
|
$nbRatiosSec = 0;
|
|
foreach($tabAnnees as $annee) {
|
|
$ratiosSecteur = new RatiosSecteur();
|
|
$ratiosSecteur->annee = $annee;
|
|
foreach ($tabTmp as $tmp)
|
|
{
|
|
if ($tmp['annee']== $annee)
|
|
{
|
|
$Ridx = $tmp['id'];
|
|
if ($tmp['nombre']>$nbRatiosSec){
|
|
$nbRatiosSec = $tmp['nombre'];
|
|
}
|
|
|
|
$unite = $tabFormulesInfos[$Ridx]['unite'];
|
|
if ($unite=='EUR'){
|
|
$montant = round($tmp['ratio']*1000);
|
|
} else {
|
|
$montant = round($tmp['ratio']);
|
|
}
|
|
if ($tabBorneMin[$Ridx]<>'' && $montant<$tabBorneMin[$Ridx]){
|
|
$montant='<'.$tabBorneMin[$Ridx];
|
|
} elseif ($tabBorneMax[$Ridx]<>'' && $montant>$tabBorneMax[$Ridx]){
|
|
$montant='>'.$tabBorneMax[$Ridx];
|
|
}
|
|
|
|
$ratiosSecteurListe = new Ratios();
|
|
if (substr($montant,0,1)=='N' || substr($montant,0,1)=='<' || substr($montant,0,1)=='>'){
|
|
$ratiosSecteurListe->id = 'r'.$Ridx;
|
|
$ratiosSecteurListe->val = $montant;
|
|
} else {
|
|
$ratiosSecteurListe->id = 'r'.$Ridx;
|
|
$ratiosSecteurListe->val = round($montant,2);
|
|
}
|
|
$ratiosSecteur->liste[] = $ratiosSecteurListe;
|
|
}
|
|
}
|
|
$tabRatiosSecteurs[] = $ratiosSecteur;
|
|
}
|
|
}
|
|
|
|
$output->RatiosBilansInfos = $tabBilansR;
|
|
$output->RatiosInfos = $tabRatiosInfos;
|
|
$output->RatiosSecteur = $tabRatiosSecteurs;
|
|
|
|
$this->wsLog('valorisation',$siren);
|
|
return $output;
|
|
}
|
|
|
|
/**
|
|
* Liste de tous les évènements enregistrés à l'INSEE pour une entreprise
|
|
* @param string $siren Siren de l'entreprise
|
|
* @param string $nic Nic de l'entreprise (Si définit filtre les événéments à l'établissements)
|
|
* @param integer $position
|
|
* @param integer $nbRep
|
|
* @return InseeReturn
|
|
**/
|
|
public function getListeEvenements($siren, $nic=0, $position=0, $nbRep=50)
|
|
{
|
|
$this->authenticate();
|
|
$this->permission('eveninsee');
|
|
|
|
//Initialisation
|
|
if (empty($nic)) { $nic = 0; }
|
|
if (empty($position)) { $position = 0; }
|
|
if (empty($nbRep) || $nbRep>50) { $nbRep = 50; }
|
|
|
|
$tabRet = array();
|
|
if (strlen($siren)<>9) {
|
|
$this->sendError('1010');
|
|
} elseif ($siren*1==0) {
|
|
$this->sendError('1010');
|
|
}
|
|
|
|
$iInsee = new MInsee();
|
|
$nbReponses = $iInsee->getEvenementsCount($siren, $nic);
|
|
$output = new InseeReturn();
|
|
$output->nbReponses = $nbReponses;
|
|
if ( $nbReponses > 0 ) {
|
|
$evens = $iInsee->getEvenements($siren, $nic, $position, $nbRep);
|
|
$tabRet = array();
|
|
if (count($evens)>0) {
|
|
foreach ($evens as $nb=>$even) {
|
|
$iEven = new InseeEven();
|
|
$iEven->Nic = $even['nic'];
|
|
$iEven->Siege = $even['siege'];
|
|
$iEven->SiretAss = $even['siretAssocie'];
|
|
$iEven->TypeSiretAss = $even['typeSiretAss'];
|
|
$iEven->EvenCode = $even['codeEven'];
|
|
$iEven->EvenLib = $even['libEven'];
|
|
$iEven->EvenLibDet = $even['libEvenDet'];
|
|
$iEven->EvenDate = $even['dateEven'];
|
|
$iEven->DateInfo = $even['dateMAJ'];
|
|
$tabRet[] = $iEven;
|
|
}
|
|
}
|
|
$output->result = $tabRet;
|
|
}
|
|
|
|
$this->wsLog('evenements',$siren);
|
|
return $output;
|
|
}
|
|
|
|
|
|
/**
|
|
* Recherche
|
|
* @param EntrepriseCriteres $criteres
|
|
* @param integer $position Position de parcours des résultats retournées (0 par défaut)
|
|
* @param integer $nbRep Nombre de réponses retournées lors d'une requête (20 par défaut)
|
|
* @param integer $maxRep Nombre de réponses maximum pouvant être retournées lors d'une requête (200 par défaut)
|
|
* @param boolean $pertinence Recherche orthographique stricte sur le nom, l'adresse et la ville (false par défaut)
|
|
* @param boolean $avecSiren Seulement les entités sirénées (false par défaut)
|
|
* @return SearchEntrepriseReturn
|
|
*/
|
|
public function searchEntreprise($criteres, $position = 0, $nbRep = 20, $maxRep = 200, $pertinence = false, $avecSiren = false)
|
|
{
|
|
$this->authenticate();
|
|
|
|
if (empty($position)) { $position = 0;}
|
|
if (empty($nbRep)) { $nbRep = 20; }
|
|
if (empty($maxRep)) { $maxRep = 200; }
|
|
|
|
$entCriteres = new EntrepriseCriteres();
|
|
$entCriteres = $criteres;
|
|
$identifiant = $entCriteres->identifiant;
|
|
$typeId = '';
|
|
|
|
//Detection autour de l'identifiant
|
|
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';
|
|
}
|
|
}
|
|
|
|
$adresse = trim($entCriteres->adresse);
|
|
|
|
//Détection Tel/Fax uniquement
|
|
if ( empty($typeId)
|
|
&& empty($entCriteres->raisonSociale)
|
|
&& empty($adresse)
|
|
&& empty($entCriteres->codePostal)
|
|
&& empty($entCriteres->ville)
|
|
&& empty($entCriteres->naf) ){
|
|
$typeId = 'TEL';
|
|
}
|
|
|
|
if (in_array($typeId, array('R', 'W', 'I'))){
|
|
|
|
$O = $this->searchAutreId(
|
|
$typeId,
|
|
$identifiant,
|
|
$entCriteres->codePostal,
|
|
$entCriteres->actif,
|
|
empty($position) ? 0 : $position,
|
|
empty($nbRep) ? 20 : $nbRep,
|
|
empty($maxRep) ? 200 : $maxRep
|
|
);
|
|
$output = new SearchEntrepriseReturn();
|
|
$output->nbReponses = $O->nbReponses;
|
|
$output->nbReponsesTotal = $O->nbReponsesTotal;
|
|
$output->result = $O->result;
|
|
return $output;
|
|
|
|
} elseif ($typeId == 'S'){
|
|
|
|
$O = $this->searchSiren(
|
|
$identifiant,
|
|
$entCriteres->codePostal,
|
|
$entCriteres->actif,
|
|
empty($position) ? 0 : $position,
|
|
empty($nbRep) ? 20 : $nbRep,
|
|
empty($maxRep) ? 200 : $maxRep
|
|
);
|
|
|
|
$output = new SearchEntrepriseReturn();
|
|
$output->nbReponses = $O->nbReponses;
|
|
$output->nbReponsesTotal = $O->nbReponsesTotal;
|
|
$output->result = $O->result;
|
|
$output->info = $O->info;
|
|
return $output;
|
|
|
|
} elseif ($typeId == 'TEL'){
|
|
|
|
$O = $this->searchTelFax(
|
|
$entCriteres->telFax,
|
|
$entCriteres->actif,
|
|
empty($position) ? 0 : $position,
|
|
empty($nbRep) ? 20 : $nbRep,
|
|
empty($maxRep) ? 200 : $maxRep
|
|
);
|
|
|
|
$output = new SearchEntrepriseReturn();
|
|
$output->nbReponses = $O->nbReponses;
|
|
$output->nbReponsesTotal = $O->nbReponsesTotal;
|
|
$output->result = $O->result;
|
|
return $output;
|
|
|
|
} else {
|
|
|
|
$O = $this->searchNomAdr(
|
|
Scores_Locale_String::cleanstring($entCriteres->raisonSociale),
|
|
Scores_Locale_String::cleanstring($entCriteres->adresse),
|
|
$entCriteres->codePostal,
|
|
Scores_Locale_String::cleanstring($entCriteres->ville),
|
|
empty($entCriteres->siege) ? false : $entCriteres->siege,
|
|
$entCriteres->actif,
|
|
empty($position) ? 0 : $position,
|
|
empty($nbRep) ? 20 : $nbRep,
|
|
empty($maxRep) ? 200 : $maxRep,
|
|
empty($pertinence) ? false : $pertinence,
|
|
empty($avecSiren) ? false : $avecSiren,
|
|
$entCriteres->naf,
|
|
$entCriteres->fj
|
|
);
|
|
|
|
$output = new SearchEntrepriseReturn();
|
|
$output->nbReponses = $O->nbReponses;
|
|
$output->nbReponsesTotal = $O->nbReponsesTotal;
|
|
$output->result = $O->result;
|
|
return $output;
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Recherche d'entreprise par dirigeants
|
|
* @param DirigeantCriteres $criteres
|
|
* @param integer $deb Position du curseur dans la liste des réponses (0 par défaut)
|
|
* @param integer $nbRep Nombre de réponses retournées au maximum par cette requete (20 par défaut)
|
|
* @param integer $maxRep Nombre de réponses recherchées au maximum (200 par défaut)
|
|
* @return SearchDirReturn
|
|
*/
|
|
public function searchDir($criteres, $deb=0, $nbRep=20, $maxRep=200)
|
|
{
|
|
$this->authenticate();
|
|
|
|
$nom = $criteres->nom;
|
|
$prenom = $criteres->prenom;
|
|
$dateNaiss = $criteres->dateNaiss;
|
|
$lieuNaiss = $criteres->lieuNaiss;
|
|
$pertinence = $criteres->pertinence;
|
|
|
|
debugLog('I',"Recherche Dirigeant de $nom, $prenom, $dateNaiss, $lieuNaiss (Max Rep=$nbRep)",__LINE__,__FILE__, __FUNCTION__, __CLASS__);
|
|
|
|
if (empty($prenom)) $prenom = '';
|
|
if (empty($dateNaiss)) $dateNaiss = '';
|
|
if (empty($lieuNaiss)) $lieuNaiss = '';
|
|
if (empty($pertinence)) $pertinence = false;
|
|
if (empty($deb)) $deb = 0;
|
|
if (empty($nbRep)) $nbRep = 20;
|
|
if (empty($maxRep)) $maxRep = 200;
|
|
|
|
$iInsee = new MInsee();
|
|
$etabs = $iInsee->rechercheDir($nom, $prenom, '', $dateNaiss, $lieuNaiss, $deb, $nbRep, $maxRep, $pertinence);
|
|
|
|
$tabRet = array();
|
|
foreach ($etabs['reponses'] as $etab) {
|
|
$item = new EntrepriseDirItem();
|
|
$item->id = $etab['id'];
|
|
$item->Pertinence = $etab['Pertinence'];
|
|
$item->Siret = $etab['Siret'];
|
|
$item->Siege = $etab['Siege'];
|
|
$item->Nom = prepareString(strtr($etab['Nom'],'/*',' '));
|
|
$item->Nom2 = prepareString($etab['Nom2']);
|
|
$item->Sigle = prepareString($etab['Sigle']);
|
|
$item->Enseigne = prepareString($etab['Enseigne']);
|
|
$item->Adresse = prepareString($etab['Adresse']);
|
|
$item->Adresse2 = prepareString($etab['Adresse2']);
|
|
$item->CP = $etab['CP'];
|
|
$item->Ville = prepareString($etab['Ville']);
|
|
$item->Pays = $etab['Pays'];
|
|
$item->Tel = $etab['Tel'];
|
|
$item->Fax = $etab['Fax'];
|
|
$item->FJ = $etab['FJ'];
|
|
$item->FJLib = $iInsee->getLibelleFJ($etab['FJ']);
|
|
$item->Siren = $etab['Siren'];
|
|
$item->Nic = $etab['Nic'];
|
|
$item->Actif = $etab['Actif'];
|
|
$item->NafEtab = $etab['NafEtab']; // Etablissement
|
|
$item->NafEtabLib = prepareString($iInsee->getLibelleNaf($etab['NafEtab'])); // Etablissement
|
|
$item->NafEnt = $etab['NafEnt']; // Entreprise
|
|
$item->NafEntLib = prepareString($iInsee->getLibelleNaf($etab['NafEnt']));
|
|
|
|
// Dirigeant
|
|
$item->DirRs = prepareString($etab['DirRs']);
|
|
$item->DirNom = prepareString($etab['DirNom']);
|
|
$item->DirPrenom = prepareString($etab['DirPrenom']);
|
|
$item->DirNomUsage = prepareString($etab['DirNomUsage']);
|
|
$item->DirDateEffet = $etab['DirDateEffet'];
|
|
$item->DirFonction = prepareString($etab['DirFonction']);
|
|
$item->DirDepart = $etab['DirDepart'];
|
|
$tabRet[] = $item;
|
|
}
|
|
|
|
if ($etabs['nbReponses']==0){
|
|
debugLog('W', "Aucun résultat pour cette recherche !", __LINE__, __FILE__, __FUNCTION__, __CLASS__);
|
|
}
|
|
|
|
$search = new SearchDirReturn();
|
|
$search->nbReponses = $etabs['nbReponses'];
|
|
$search->nbReponsesTotal = $etabs['nbReponsesTotal'];
|
|
$search->result = $tabRet;
|
|
return $search;
|
|
}
|
|
|
|
/**
|
|
* Recherche d'entreprise ou d'établissement par un autre Identifiant
|
|
*
|
|
* @param string $typeId I=Code Isin, W=N°Waldec (Associations) ou R=N°RC (Registre Greffe)
|
|
* @param string $identifiant Identifiant recherché
|
|
* @param integer $dep Département
|
|
* @param integer $actif 0 : Filtre sur les inactfis, 1: Filtre sur les actifs, 2 : Tous (defaut)
|
|
* @param integer $deb Position du curseur dans la liste des réponses (0 par défaut)
|
|
* @param integer $nbRep Nombre de réponses retournées au maximum par cette requete (20 par défaut)
|
|
* @param integer $maxRep Nombre de réponses recherchées au maximum (200 par défaut)
|
|
* @return SearchReturn
|
|
*/
|
|
public function searchAutreId($typeId, $identifiant, $dep=0, $actif=2, $deb=0, $nbRep=20, $maxRep=200)
|
|
{
|
|
$this->authenticate();
|
|
|
|
if (empty($deb)) $deb = 0;
|
|
if (empty($nbRep)) $nbRep = 0;
|
|
if (empty($maxRep)) $maxRep = 0;
|
|
if (empty($dep)) $dep = 0;
|
|
if (!in_array($actif, array(0,1,2))) $actif = 2;
|
|
|
|
$typeId = substr(trim(strtoupper($typeId)),0,1);
|
|
|
|
if ($typeId!='I' && $typeId!='W' && $typeId!='R') {
|
|
debugLog('I',"Type d'identifiant $typeId inexistant",__LINE__,__FILE__, __FUNCTION__, __CLASS__);
|
|
$this->sendError('1021');
|
|
}
|
|
$tabRet = array();
|
|
debugLog('I',"Recherche par identifiant $typeId de $identifiantavec un maximum de $nbRep réponses",__LINE__,__FILE__, __FUNCTION__, __CLASS__);
|
|
if ($typeId=='W' || $typeId=='R')
|
|
{
|
|
$iInsee = new MInsee();
|
|
$rep = $iInsee->getEtablissementsParId('AUTRE', $identifiant, $deb, $nbRep, $maxRep, $dep, $actif);
|
|
$etabs = $rep['reponses'];
|
|
foreach ($etabs as $nb=>$etab)
|
|
{
|
|
$item = new EntrepriseItem();
|
|
$item->id = $etab['id'];
|
|
$item->Pertinence = $etab['Pertinence'];
|
|
$item->Source = $etab['Source'];
|
|
$item->SourceId = $etab['SourceId'];
|
|
$item->Siret = $etab['Siret'];
|
|
$item->Siege = $etab['Siege'];
|
|
$item->Nom = prepareString(strtr($etab['Nom'],'/*',' '));
|
|
$item->Nom2 = prepareString($etab['Nom2']);
|
|
$item->Sigle = prepareString($etab['Sigle']);
|
|
$item->Enseigne = prepareString($etab['Enseigne']);
|
|
$item->Adresse = prepareString($etab['Adresse']);
|
|
$item->Adresse2 = prepareString($etab['Adresse2']);
|
|
$item->CP = $etab['CP'];
|
|
$item->Ville = prepareString($etab['Ville']);
|
|
$item->Pays = $etab['Pays'];
|
|
$item->Tel = $etab['Tel'];
|
|
$item->Fax = $etab['Fax'];
|
|
$item->FJ = $etab['FJ'];
|
|
$item->FJLib = prepareString($etab['FJLib']);
|
|
$item->Siren = $etab['Siren'];
|
|
$item->Nic = $etab['Nic'];
|
|
$item->Actif = $etab['Actif'];
|
|
$item->NafEtab = $etab['NafEtab']; // Etablissement
|
|
$item->NafEtabLib = prepareString($etab['NafEtabLib']); // Etablissement
|
|
$item->NafEnt = $etab['NafEnt']; // Entreprise
|
|
$item->NafEntLib = prepareString($etab['NafEntLib']);
|
|
$tabRet[] = $item;
|
|
}
|
|
$output = new SearchReturn();
|
|
$output->nbReponses = $rep['nbReponses'];
|
|
$output->nbReponsesTotal = $rep['nbReponsesTotal'];
|
|
$output->result = $tabRet;
|
|
return $output;
|
|
} else {
|
|
$iBourse = new MBourse($siren);
|
|
$siren = $iBourse->getCodeSiren($identifiant);
|
|
return $this->searchSiren($siren, $dep, $actif, $deb, $nbRep, $maxRep);
|
|
}
|
|
}
|
|
|
|
|
|
/**
|
|
* Recherche d'entreprise ou d'établissement par leur TEL FAX
|
|
*
|
|
* @param string $telFax Téléphone ou fax de l'établissement (ex: 0175438010)
|
|
* @param integer $actif 0 : Filtre sur les inactfis, 1: Filtre sur les actifs, 2 : Tous (defaut)
|
|
* @param integer $deb Position du curseur dans la liste des réponses (0 par défaut)
|
|
* @param integer $nbRep Nombre de réponses retournées au maximum par cette requete (20 par défaut)
|
|
* @param integer $maxRep Nombre de réponses recherchées au maximum (200 par défaut)
|
|
* @return SearchReturn
|
|
*/
|
|
public function searchTelFax($telFax, $actif=2, $deb=0, $nbRep=20, $maxRep=200)
|
|
{
|
|
$this->authenticate();
|
|
|
|
if (empty($deb)) $deb = 0;
|
|
if (empty($nbRep)) $nbRep = 0;
|
|
if (empty($maxRep)) $maxRep = 0;
|
|
if (!in_array($actif, array(0,1,2))) $actif = 2;
|
|
|
|
$tabRet = array();
|
|
debugLog('I',"Recherche par Tel/Fax de $telFax avec un maximum de $nbRep réponses",__LINE__,__FILE__, __FUNCTION__, __CLASS__);
|
|
//$assocs=$this->iInsee->rechercheEtab($raisonSociale, $adresse, $codePostal, $ville, $siege, $nbRep, $pertinence);
|
|
/** @todo A FAIRE **/
|
|
if (strlen($telFax)<10 || strlen($telFax)>14) {
|
|
debugLog('W', "Tel/Fax $telFax incorrect", __LINE__, __FILE__, __FUNCTION__, __CLASS__);
|
|
$this->sendError('1011');
|
|
}
|
|
|
|
$iInsee = new MInsee();
|
|
$rep = $iInsee->getEtablissementsParId('TEL', $telFax, $deb, $nbRep, $maxRep, 0, $actif);
|
|
$etabs = $rep['reponses'];
|
|
foreach ($etabs as $nb=>$etab)
|
|
{
|
|
$pays = 'France';
|
|
if ( $etab['adr_dep']==99 ) {
|
|
$resultPays = $this->iDb->select("jo.tabPays", "libPays", "codePaysInsee = ".$etab['adr_com'], false, MYSQL_ASSOC);
|
|
$pays = $resultPays[0]['libPays'];
|
|
}
|
|
|
|
$item = new EntrepriseItem();
|
|
$item->id = $etab['id'];
|
|
$item->Pertinence = $etab['Pertinence'];
|
|
$item->Siret = $etab['Siret'];
|
|
$item->Siege = $etab['Siege'];
|
|
$item->Nom = prepareString(strtr($etab['Nom'],'/*',' '));
|
|
$item->Nom2 = prepareString($etab['Nom2']);
|
|
$item->Sigle = prepareString($etab['Sigle']);
|
|
$item->Enseigne = prepareString($etab['Enseigne']);
|
|
$item->Adresse = prepareString($etab['Adresse']);
|
|
$item->Adresse2 = prepareString($etab['Adresse2']);
|
|
$item->CP = $etab['CP'];
|
|
$item->Ville = prepareString($etab['Ville']);
|
|
$item->Pays = $etab['Pays'];
|
|
$item->Tel = $etab['Tel'];
|
|
$item->Fax = $etab['Fax'];
|
|
$item->FJ = $etab['FJ'];
|
|
$item->FJLib = prepareString($etab['FJLib']);
|
|
$item->Siren = $etab['Siren'];
|
|
$item->Nic = $etab['Nic'];
|
|
$item->Actif = $etab['Actif'];
|
|
$item->NafEtab = $etab['NafEtab']; // Etablissement
|
|
$item->NafEtabLib = prepareString($etab['NafEtabLib']); // Etablissement
|
|
$item->NafEnt = $etab['NafEnt']; // Entreprise
|
|
$item->NafEntLib = prepareString($etab['NafEntLib']);
|
|
$tabRet[] = $item;
|
|
}
|
|
|
|
$output = new SearchReturn();
|
|
$output->nbReponses = $rep['nbReponses'];
|
|
$output->nbReponsesTotal = $rep['nbReponsesTotal'];
|
|
$output->result = $tabRet;
|
|
return $output;
|
|
}
|
|
|
|
|
|
/**
|
|
* Recherche entreprise par nom et adresse
|
|
* @param string $raisonSociale Raison Sociale ou Enseigne ou Sigle
|
|
* @param string $adresse Adresse de l'entreprise, du type : 3 rue des Plantes
|
|
* @param string $codePostal Code postal (ex: 75014)
|
|
* @param string $ville Ville
|
|
* @param boolean $siege Limitation de la recherche aux sièges (si true)
|
|
* @param integer $actif 0 : Filtre sur les inactfis, 1: Filtre sur les actifs, 2 : Tous (defaut)
|
|
* @param integer $deb Position du curseur dans la liste des réponses (0 par défaut)
|
|
* @param integer $nbRep Nombre de réponses retournées au maximum par cette requete (20 par défaut)
|
|
* @param integer $maxRep Nombre de réponses recherchées au maximum (200 par défaut)
|
|
* @param boolean $pertinence Recherche orthographique stricte sur le nom, l'adresse et la ville (si true)
|
|
* @param boolean $avecSiren Ne proposer que les entités sirénées
|
|
* @param string $ape_etab
|
|
* @param integer $fj Code Forme juridique
|
|
* @return SearchReturn
|
|
*/
|
|
public function searchNomAdr($raisonSociale, $adresse='', $codePostal='', $ville='', $siege=false, $actif=2, $deb=0, $nbRep=20, $maxRep=200, $pertinence=false, $avecSiren=false, $ape_etab='', $fj=null)
|
|
{
|
|
$this->authenticate();
|
|
|
|
debugLog('I',"Recherche Entreprise de $raisonSociale, $adresse, $codePostal $ville (Siège=$siege / Max Rep=$nbRep)",__LINE__,__FILE__, __FUNCTION__, __CLASS__);
|
|
|
|
if (empty($adresse)) $adresse = '';
|
|
if (empty($codePostal)) $codePostal = '';
|
|
if (empty($ville)) $ville = '';
|
|
if (empty($siege)) $siege = false;
|
|
if (!in_array($actif, array(0,1,2))) $actif = 2;
|
|
if (empty($deb)) $deb = 0;
|
|
if (empty($nbRep)) $nbRep = 20;
|
|
if (empty($maxRep)) $maxRep = 200;
|
|
if (empty($pertinence)) $pertinence = false;
|
|
if (empty($avecSiren)) $avecSiren = false;
|
|
if (empty($ape_etab)) $ape_etab = '';
|
|
if (!preg_match('/[0-9]{4}/',$fj)) $fj = null;
|
|
|
|
$iInsee = new MInsee();
|
|
$etabs = $iInsee->rechercheEtab(
|
|
$raisonSociale,
|
|
$adresse,
|
|
$codePostal,
|
|
$ville,
|
|
$siege,
|
|
$actif,
|
|
$deb,
|
|
$nbRep,
|
|
$maxRep,
|
|
$pertinence,
|
|
$avecSiren,
|
|
$ape_etab,
|
|
$fj
|
|
);
|
|
|
|
$result = new SearchReturn();
|
|
$tabRet = array();
|
|
if (count($etabs['reponses'])) {
|
|
foreach ($etabs['reponses'] as $etab) {
|
|
$reponse = new EntrepriseItem();
|
|
$reponse->id = $etab['id'];
|
|
$reponse->Pertinence = $etab['Pertinence'];
|
|
$reponse->Source = $etab['Source'];
|
|
$reponse->SourceId = $etab['SourceId'];
|
|
$reponse->Siret = $etab['Siret'];
|
|
$reponse->Siege = $etab['Siege'];
|
|
$reponse->Nom = strtr($etab['Nom'],'/*',' ');
|
|
$reponse->Nom2 = $etab['Nom2'];
|
|
$reponse->Sigle = $etab['Sigle'];
|
|
$reponse->Enseigne = $etab['Enseigne'];
|
|
$reponse->Adresse = $etab['Adresse'];
|
|
$reponse->Adresse2 = $etab['Adresse2'];
|
|
$reponse->CP = $etab['CP'];
|
|
$reponse->Ville = $etab['Ville'];
|
|
$reponse->Pays = $etab['Pays'];
|
|
$reponse->Tel = $etab['Tel'];
|
|
$reponse->Fax = $etab['Fax'];
|
|
$reponse->FJ = $etab['FJ'];
|
|
$reponse->FJLib = $iInsee->getLibelleFJ($etab['FJ']);
|
|
$reponse->Siren = $etab['Siren'];
|
|
$reponse->Nic = $etab['Nic'];
|
|
$reponse->Actif = $etab['Actif'];
|
|
$reponse->NafEtab = $etab['NafEtab']; // Etablissement
|
|
$reponse->NafEtabLib = prepareString($iInsee->getLibelleNaf($etab['NafEtab'])); // Etablissement
|
|
$reponse->NafEnt = $etab['NafEnt']; // Entreprise
|
|
$reponse->NafEntLib = prepareString($iInsee->getLibelleNaf($etab['NafEnt']));
|
|
|
|
$tabRet[] = $reponse;
|
|
}
|
|
}
|
|
|
|
$siretTrouve = 0;
|
|
if ($etabs['nbReponses']==0) {
|
|
|
|
debugLog('I', "rechercheEtab : AUCUN RESULTAT, S=$raisonSociale, R=$adresse, L=$codePostal, V=$ville, A=$ape_etab ($siege, $actif, $deb, $nbRep, $maxRep, $pertinence, $avecSiren)", __LINE__, __FILE__, __FUNCTION__, __CLASS__);
|
|
|
|
$result->nbReponses = count($tabRet);
|
|
$result->nbReponsesTotal = $etabs['nbReponsesTotal'];
|
|
$result->result = $tabRet;
|
|
|
|
return $result;
|
|
}
|
|
|
|
if ($etabs['nbReponses']==1) $siretTrouve=$etabs['reponses'][0]['Siret'];
|
|
debugLog('I', "rechercheEtab : ".$etabs['nbReponses']." RESULTATS, S=$raisonSociale, R=$adresse, L=$codePostal, V=$ville, A=$ape_etab ($siege, $actif, $deb, $nbRep, $maxRep, $pertinence, $avecSiren)", __LINE__, __FILE__, __FUNCTION__, __CLASS__);
|
|
|
|
$result->nbReponses = $etabs['nbReponses'];
|
|
$result->nbReponsesTotal = $etabs['nbReponsesTotal'];
|
|
$result->result = $tabRet;
|
|
return $result;
|
|
}
|
|
|
|
/**
|
|
* Recherche d'entreprise ou d'établissement par leur identifiant SIREN ou SIRET
|
|
* @param string $siret Siren ou Siret de l'entreprise ou de l'établissement sur 9 ou 14 chiffres significatifs
|
|
* @param integer $dep Département
|
|
* @param integer $actif 0 : Filtre sur les inactfis, 1: Filtre sur les actifs, 2 : Tous (defaut)
|
|
* @param integer $deb Position du curseur dans la liste des réponses (0 par défaut)
|
|
* @param integer $nbRep Nombre de réponses retournées au maximum par cette requete (20 par défaut)
|
|
* @param integer $maxRep Nombre de réponses recherchées au maximum (200 par défaut)
|
|
* @return SearchReturn
|
|
*/
|
|
public function searchSiren($siret, $dep=0, $actif=2, $deb=0, $nbRep=20, $maxRep=200)
|
|
{
|
|
$this->authenticate();
|
|
|
|
debugLog('I',"Recherche par Siret de $siret (dep=$dep) avec un maximum de $maxRep réponses pour la tranche $deb à $nbRep",__LINE__,__FILE__, __FUNCTION__, __CLASS__);
|
|
|
|
// --- Supprimer les éléments autres que chiffres dans le siret
|
|
$siret = preg_replace('/[^0-9]/', '', $siret);
|
|
|
|
// --- Controle de la taille du siret/siren
|
|
if ( strlen($siret)!=14 && strlen($siret)!=9 ){
|
|
debugLog('W', "Siren/Siret $siret incorrect", __LINE__, __FILE__, __FUNCTION__, __CLASS__);
|
|
$this->sendError('1010');
|
|
}
|
|
|
|
// --- Initialisation des variables
|
|
if (empty($deb)) $deb = 0;
|
|
if (empty($nbRep)) $nbRep = 20;
|
|
if (empty($maxRep)) $maxRep = 200;
|
|
if (empty($dep)) $dep = 0;
|
|
if (empty($siege)) $siege = null;
|
|
|
|
if (!in_array($actif, array(0,1,2))) $actif = 2;
|
|
if ( $actif==2 ) $actif = -1;
|
|
|
|
$nbReponsesTotal = $nbReponses = 0;
|
|
|
|
$siren = substr($siret,0,9);
|
|
if (strlen($siret) == 14) $nic = substr($siret,9,5);
|
|
elseif (strlen($siret) == 9) $nic = '';
|
|
|
|
$iDb = new WDB();
|
|
$iInsee = new MInsee($iDb);
|
|
|
|
$rep = $iInsee->getEtablissements($siren, $nic, $deb, $nbRep, $maxRep, $dep, $actif, $siege);
|
|
if ( count($rep['reponses'])==0 && $dep>0 ) {
|
|
$rep = $iInsee->getEtablissements($siren, $nic, $deb, $nbRep, $maxRep, 0, $actif, $siege);
|
|
}
|
|
$etabs = $rep['reponses'];
|
|
$tabRet = array();
|
|
if (count($etabs)>0){
|
|
foreach ($etabs as $nb=>$etab) {
|
|
$reponse = new EntrepriseItem();
|
|
$reponse->id = $etab['id'];
|
|
$reponse->Pertinence = $etab['Pertinence'];
|
|
$reponse->Source = $etab['Source'];
|
|
$reponse->SourceId = $etab['sourceId'];
|
|
$reponse->Siret = $etab['Siret'];
|
|
$reponse->Siege = $etab['Siege'];
|
|
$reponse->Nom = prepareString(strtr($etab['Nom'],'/*',' '));
|
|
$reponse->Nom2 = prepareString($etab['Nom2']);
|
|
$reponse->Sigle = prepareString($etab['Sigle']);
|
|
$reponse->Enseigne = prepareString($etab['Enseigne']);
|
|
$reponse->Adresse = prepareString($etab['Adresse']);
|
|
$reponse->Adresse2 = prepareString($etab['Adresse2']);
|
|
$reponse->CP = $etab['CP'];
|
|
$reponse->Ville = prepareString($etab['Ville']);
|
|
$reponse->Pays = prepareString($etab['Pays']);
|
|
$reponse->Tel = $etab['Tel'];
|
|
$reponse->Fax = $etab['Fax'];
|
|
$reponse->FJ = $etab['FJ'];
|
|
$reponse->FJLib = prepareString($etab['FJLib']);
|
|
$reponse->Siren = $etab['Siren'];
|
|
$reponse->Nic = $etab['Nic'];
|
|
$reponse->Actif = $etab['Actif'];
|
|
$reponse->NafEtab = $etab['NafEtab']; // Etablissement
|
|
$reponse->NafEtabLib = $etab['NafEtabLib']; // Etablissement
|
|
$reponse->NafEnt = $etab['NafEnt']; // Entreprise
|
|
$reponse->NafEntLib = $etab['NafEntLib'];
|
|
$tabRet[] = $reponse;
|
|
}
|
|
}
|
|
$nbReponsesTotal = $rep['nbReponsesTotal'];
|
|
$nbReponses = $rep['nbReponses'];
|
|
|
|
// --- Si le siren est valide et pas de résultats
|
|
if ( count($tabRet)==0 && $iInsee->valideSiren($siren) ) {
|
|
// --- Vérification dans la table des greffes
|
|
$iGeffes = new MGreffes();
|
|
$etab = $iGeffes->getIdentite($siren);
|
|
if ($etab) {
|
|
$reponse = new EntrepriseItem();
|
|
$reponse->id = $etab['id'];
|
|
$reponse->Pertinence = $etab['Pertinence'];
|
|
$reponse->Siret = $etab['Siret'];
|
|
$reponse->Siege = $etab['Siege'];
|
|
$reponse->Nom = prepareString($etab['Nom']);
|
|
$reponse->Nom2 = prepareString($etab['Nom2']);
|
|
$reponse->Sigle = prepareString($etab['Sigle']);
|
|
$reponse->Enseigne = prepareString($etab['Enseigne']);
|
|
$reponse->Adresse = prepareString($etab['Adresse']);
|
|
$reponse->Adresse2 = prepareString($etab['Adresse2']);
|
|
$reponse->CP = $etab['CP'];
|
|
$reponse->Ville = prepareString($etab['Ville']);
|
|
$reponse->Pays = 'France';
|
|
$reponse->Tel = $etab['Tel'];
|
|
$reponse->Fax = $etab['Fax'];
|
|
$reponse->FJ = $etab['FJ'];
|
|
$reponse->FJLib = $etab['FJLib'];
|
|
$reponse->Siren = $etab['Siren'];
|
|
$reponse->Nic = $etab['Nic'];
|
|
$reponse->Actif = $etab['Actif'];
|
|
$reponse->NafEtab = $etab['NafEtab'];
|
|
$reponse->NafEtabLib = $etab['NafEtabLib'];
|
|
$reponse->NafEnt = $etab['NafEnt'];
|
|
$reponse->NafEntLib = $etab['NafEntLib'];
|
|
$tabRet[] = $reponse;
|
|
$nbReponses = 1;
|
|
$nbReponsesTotal = 1;
|
|
}
|
|
|
|
else {
|
|
$iDb->insert('jo.siren_inexistants', array(
|
|
'siren' => $siren,
|
|
'nic' => $nic,
|
|
'dep' => $dep,
|
|
'login' => $this->User->login,
|
|
'client' => $this->User->idClient,
|
|
'dateInsert' => date('YmdHis'))
|
|
);
|
|
$nbReponses = 0;
|
|
$nbReponsesTotal = 0;
|
|
}
|
|
}
|
|
|
|
$output = new SearchReturn();
|
|
$output->nbReponses = $nbReponses;
|
|
$output->nbReponsesTotal = $nbReponsesTotal;
|
|
$output->result = $tabRet;
|
|
$output->info = $rep['info'];
|
|
return $output;
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
* Retourne la fiche d'identité simplifié d'une entreprise avec son numéro de TVA.
|
|
*
|
|
* @param string $siren Identifiant Siren de l'entreprise
|
|
* @return TvaReturn
|
|
*/
|
|
public function getTVA($siren)
|
|
{
|
|
$this->authenticate();
|
|
|
|
//Initialisation
|
|
$siren = trim($siren);
|
|
debugLog('I',"TVA demandée pour $siren",__LINE__,__FILE__, __FUNCTION__, __CLASS__);
|
|
$tabRet = array();
|
|
if (strlen($siren)<>9) {
|
|
debugLog('W', "Siren $siren incorrect", __LINE__, __FILE__, __FUNCTION__, __CLASS__);
|
|
$this->sendError('1010');
|
|
} elseif ($siren*1==0) {
|
|
debugLog('W', "Siren $siren inexistant", __LINE__, __FILE__, __FUNCTION__, __CLASS__);
|
|
$this->sendError('1010');
|
|
}
|
|
|
|
debugLog('I', "Avant getIdentiteEntreprise($siren)", __LINE__, __FILE__, __FUNCTION__, __CLASS__);
|
|
$iInsee = new MInsee();
|
|
$entrep = $iInsee->getIdentiteEntreprise($siren);
|
|
debugLog('I', "Après getIdentiteEntreprise($siren)", __LINE__, __FILE__, __FUNCTION__, __CLASS__);
|
|
if (empty($entrep))
|
|
{
|
|
debugLog('W', "Siren $siren non présent en base", __LINE__, __FILE__, __FUNCTION__, __CLASS__);
|
|
$this->sendError('1020');
|
|
}
|
|
|
|
debugLog('I', "Avant MTva($siren)", __LINE__, __FILE__, __FUNCTION__, __CLASS__);
|
|
$iTva = new MTva($siren);
|
|
if ($iTva->vatDefined) $tva=$iTva->vatNumber;
|
|
else $tva='N/A';
|
|
debugLog('I', "Après MTva($siren)", __LINE__, __FILE__, __FUNCTION__, __CLASS__);
|
|
|
|
$output = new TvaReturn();
|
|
$output->id = $entrep['id'];
|
|
$output->AutreId = $entrep['AutreId'];
|
|
$output->Nom = $entrep['Nom'];
|
|
$output->Sigle = $entrep['Sigle'];
|
|
$output->Enseigne = $entrep['Enseigne'];
|
|
$output->Adresse = $entrep['Adresse'];
|
|
$output->Adresse2 = $entrep['Adresse2'];
|
|
$output->CP = $entrep['CP'];
|
|
$output->Ville = $entrep['Ville'];
|
|
$output->Siren = $entrep['Siren'];
|
|
$output->Tva = $tva;
|
|
|
|
debugLog('I', "TVA retournée = $tva (".$entrep['Nom'].')', __LINE__, __FILE__, __FUNCTION__, __CLASS__);
|
|
$this->wsLog('tva',$siren);
|
|
|
|
return $output;
|
|
}
|
|
|
|
/**
|
|
* Retourne tout ou patie des informations règlementées sur l'entreprise
|
|
*
|
|
* @param string $siren SIREN de l'entreprise
|
|
* @param integer $id Id du communiqué
|
|
* @return InfosRegReturn
|
|
*/
|
|
public function getInfosReg( $siren, $id = null )
|
|
{
|
|
$this->authenticate();
|
|
$this->permission('infosreg');
|
|
|
|
//Initialisation
|
|
if (empty($id)) $id = null;
|
|
$tabRet = array();
|
|
$siren = substr($siren,0,9);
|
|
|
|
debugLog('I',"Infos règlementées demandées pour $siren",__LINE__,__FILE__, __FUNCTION__, __CLASS__);
|
|
|
|
if ($siren*1==0) {
|
|
debugLog('W', "Siren $siren inexistant", __LINE__, __FILE__, __FUNCTION__, __CLASS__);
|
|
$this->sendError('1010');
|
|
}
|
|
$iBourse = new MBourse($siren);
|
|
$anns = $iBourse->getInfosReg($siren, $id);
|
|
//debugLog('W', print_r($entrep, true), __LINE__, __FILE__, __FUNCTION__, __CLASS__);
|
|
if ( empty($anns) ){
|
|
debugLog('W', "Aucune info règlementée pour le siren $siren", __LINE__, __FILE__, __FUNCTION__, __CLASS__);
|
|
$this->sendError('1030');
|
|
}
|
|
|
|
foreach ($anns as $nb=>$ann)
|
|
{
|
|
//debugLog('I', "Siren/Siret $siren trouvé : ".$etab['Siren'].' '.$etab['Nic'].', '.$etab['Nom'] .', '.$etab['CP'].', '.$etab['Ville'], __LINE__, __FILE__, __FUNCTION__, __CLASS__);
|
|
if ($id === null) {
|
|
$infos = new InfosReg();
|
|
$infos->id = $ann['id'];
|
|
$infos->source = $ann['source'];
|
|
$infos->DateParution = $ann['DateParution']; //@todo : date
|
|
$infos->raisonSociale = $ann['raisonSociale'];
|
|
$infos->titre = $ann['titre'];
|
|
$infos->pj = $ann['pj'];
|
|
$infos->url = $ann['url'];
|
|
$infos->dateInsertionSD = $ann['dateInsertionSD']; //@todo : date
|
|
$tabRet[] = $infos;
|
|
} else {
|
|
$infos = new InfosReg();
|
|
$infos->id = $ann['id'];
|
|
$infos->source = $ann['source'];
|
|
$infos->DateParution = $ann['DateParution']; //@todo : date
|
|
$infos->raisonSociale = $ann['raisonSociale'];
|
|
$infos->titre = $ann['titre'];
|
|
$infos->communique = $ann['communique'];
|
|
$infos->communiqueHtml = $ann['communiqueHtml'];
|
|
$infos->pj = $ann['pj'];
|
|
$infos->url = $ann['url'];
|
|
$infos->dateInsertionSD = $ann['dateInsertionSD']; //@todo : date
|
|
$tabRet[] = $infos;
|
|
}
|
|
}
|
|
debugLog('I', 'Nb infos retournés = '. count($anns), __LINE__, __FILE__, __FUNCTION__, __CLASS__);
|
|
$this->wsLog('infosreg',$siren,$id);
|
|
$output = new InfosRegReturn();
|
|
$output->result = $tabRet;
|
|
return $output;
|
|
}
|
|
|
|
/**
|
|
* Retourne les informations boursières de l'entreprise
|
|
* @param string $siren SIREN de l'entreprise
|
|
* @return InfosBourse
|
|
*/
|
|
public function getInfosBourse($siren)
|
|
{
|
|
$this->authenticate();
|
|
$this->permission('bourse');
|
|
|
|
//Initialisation
|
|
$error = new ErrorType();
|
|
debugLog('I',"Infos bourse demandées pour $siren",__LINE__,__FILE__, __FUNCTION__, __CLASS__);
|
|
$siren = substr($siren,0,9);
|
|
|
|
if ($siren*1==0) {
|
|
debugLog('W', "Siren $siren inexistant", __LINE__, __FILE__, __FUNCTION__, __CLASS__);
|
|
$this->sendError('1010');
|
|
}
|
|
|
|
$iBourse = new MBourse($siren);
|
|
$bourse = $iBourse->getInfosBourse($siren);
|
|
//debugLog('W', print_r($entrep, true), __LINE__, __FILE__, __FUNCTION__, __CLASS__);
|
|
if (empty($bourse)) {
|
|
debugLog('W', "Aucune info bourse pour le siren $siren", __LINE__, __FILE__, __FUNCTION__, __CLASS__);
|
|
$this->sendError('1030');
|
|
}
|
|
|
|
$result = new InfosBourse();
|
|
$result->Siren = $bourse['siren'];
|
|
$result->RaisonSociale = $bourse['raisonSociale'];
|
|
$result->Adresse = $bourse['adresse'];
|
|
$result->Effectif = $bourse['effectif'];
|
|
$result->CodeSicovam = $bourse['code_sicovam'];
|
|
$result->CodeMnemo = $bourse['code_mnemo'];
|
|
$result->CodeBloomberg = $bourse['code_bloomberg'];
|
|
$result->CodeDatastream = $bourse['code_datastream'];
|
|
$result->Isin = $bourse['code_isin'];
|
|
$result->CodeRic = $bourse['code_ric'];
|
|
$result->DateIntroduction = $bourse['dateIntroduction']; //@todo : date
|
|
$result->DateDerAG = $bourse['dateDerAG']; //@todo : date
|
|
$result->DateRadiation = $bourse['dateRadiation']; //@todo : date
|
|
$result->AutreIsin = $bourse['autre_isin'];
|
|
$result->EligibleSRD = $bourse['eligibleSRD'];
|
|
$result->EligiblePEA = $bourse['eligiblePEA'];
|
|
$result->Tel = $bourse['tel1'];
|
|
$result->Tel2 = $bourse['tel2'];
|
|
$result->Fax = $bourse['fax1'];
|
|
$result->Fax2 = $bourse['fax2'];
|
|
$result->Web = $bourse['web'];
|
|
$result->Mail = $bourse['mail'];
|
|
|
|
$result->Marche = $bourse['marche'];
|
|
$result->Description = $bourse['description'];
|
|
$result->Secteur = $bourse['secteur'];
|
|
$result->Activite = $bourse['activite'];
|
|
$result->ActiviteDet = $bourse['activiteDet'];
|
|
|
|
$result->placeCotation = $bourse['placeCotation'];
|
|
$result->nombreTitres = $bourse['nombreTitres'];
|
|
$result->capitalisation = $bourse['close']*$bourse['nombreTitres'];
|
|
$result->derCoursDate = $bourse['date']; //@todo : date
|
|
$result->derCoursCloture = $bourse['close'];
|
|
$result->derCoursOuverture = $bourse['open'];
|
|
$result->derCoursPlusHaut = $bourse['high'];
|
|
$result->derCoursPlusBas = $bourse['low'];
|
|
|
|
$result->derCoursVolume = $bourse['volume'];
|
|
$result->coursMin = $bourse['coursMin'];
|
|
$result->coursMoy = $bourse['coursMoy'];
|
|
$result->coursMax = $bourse['coursMax'];
|
|
|
|
$this->wsLog('bourse',$siren,$id);
|
|
return $result;
|
|
}
|
|
|
|
/**
|
|
* Ajout d'une surveillance
|
|
*
|
|
* @param string $siret Siret/Siren
|
|
* @param string $email Adresse email du client
|
|
* @param string $ref Référence de la surveillance
|
|
* @param string $source Type de source en surveillance (insee, annonces, bilans, actes, privileges, score, dirigeants, paiements, liens)
|
|
* @param boolean $delete Suppression de la ligne
|
|
* @param integer $encoursClient Encours demandé par le client
|
|
* @return SetSurveillanceReturn
|
|
*/
|
|
public function setSurveillance($siret, $email, $ref='', $source='annonces', $delete=false, $encoursClient=0)
|
|
{
|
|
$this->authenticate();
|
|
$source = strtolower($source);
|
|
switch ($source) {
|
|
case 'insee':
|
|
$this->permission('survinsee');
|
|
break;
|
|
case 'bilans':
|
|
$this->permission('survbilan');
|
|
break;
|
|
case 'actes':
|
|
$this->permission('survactes');
|
|
break;
|
|
case 'privileges':
|
|
$this->permission('survpriv');
|
|
break;
|
|
case 'dirigeants':
|
|
$this->permission('survdirigeants');
|
|
break;
|
|
case 'score':
|
|
$this->permission('survscore');
|
|
break;
|
|
case 'paiements':
|
|
$this->permission('survpaiements');
|
|
break;
|
|
case 'liens':
|
|
$this->permission('survliens');
|
|
break;
|
|
case 'annonces':
|
|
default:
|
|
$this->permission('survannonce');
|
|
break;
|
|
}
|
|
|
|
//Initialisation
|
|
if (empty($ref)) $ref = '';
|
|
if (empty($delete)) $delete = false;
|
|
if (empty($encoursClient)) $encoursClient = false;
|
|
$result = false;
|
|
$siren = substr($siret,0,9);
|
|
$nic = substr($siret,9,5);
|
|
if (empty($nic)) {
|
|
$nic = '00000';
|
|
}
|
|
|
|
debugLog('I',"setSurveillances(siret=$siret, email=$email, ref=$ref, source=$source, delete=$delete)",__LINE__,__FILE__, __FUNCTION__, __CLASS__);
|
|
|
|
$iDb = new WDB();
|
|
$login = $this->User->login;
|
|
switch ($source) {
|
|
case 'insee':
|
|
case 'annonces':
|
|
case 'bilans':
|
|
case 'actes':
|
|
case 'privileges':
|
|
case 'paiements':
|
|
case 'liens':
|
|
case 'dirigeants': $encoursClient=0; break;
|
|
case 'score': $encoursClient=$encoursClient*1; break;
|
|
default: $source='annonces'; break;
|
|
}
|
|
|
|
/**
|
|
* Suppression de la surveillance
|
|
* @todo : Déplacer dans la table de mouvement
|
|
*/
|
|
if ($delete) {
|
|
|
|
$tabUpdate = array('dateSuppr'=>date('Y-m-d'));
|
|
$result = $iDb->update('jo.surveillances_site',
|
|
$tabUpdate,
|
|
"source='$source' AND login='$login' AND email='$email' AND siren=$siren AND nic=$nic AND ref='$ref'"
|
|
);
|
|
|
|
} else {
|
|
|
|
/**
|
|
* Calcul d'initialisation du score lors d'un ajout
|
|
*/
|
|
if ( $source == 'score' ) {
|
|
$survM = new Application_Model_JoScoresSurveillance();
|
|
$item = $survM->find($siren);
|
|
if ( $item === null ) {
|
|
require_once 'Metier/scores/classMScores.php';
|
|
calculIndiScore($siren, 0, false, 0);
|
|
}
|
|
}
|
|
|
|
$where = "source='$source' AND login='$login' AND email='$email' AND siren=$siren AND nic=$nic AND ref='$ref'";
|
|
$detect = $iDb->select('jo.surveillances_site', 'siren', $where, false, MYSQL_ASSOC);
|
|
|
|
if ( count($detect)>0 ) {
|
|
|
|
//Si la donnée existe déjà et que la source=score alors il faut mettre à jour l'encours client
|
|
if ($source == 'score' && $detect[0]['dateSuppr']=='0000-00-00 00:00:00') {
|
|
|
|
$data = array (
|
|
'encoursClient' => $encoursClient,
|
|
);
|
|
$result = $iDb->update('jo.surveillances_site', $data, $where, false, 0, true);
|
|
|
|
} elseif ( $detect[0]['dateSuppr']!='0000-00-00 00:00:00') {
|
|
|
|
$data = array (
|
|
'dateAjout' => date('Y-m-d'),
|
|
'dateSuppr' => '0000-00-00 00:00:00',
|
|
);
|
|
$result = $iDb->update('jo.surveillances_site', $data, $where, false, 0, true);
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
$iInsee = new MInsee();
|
|
$tabIdentite = $iInsee->getIdentiteLight($siren, $nic);
|
|
|
|
$data = array(
|
|
'source' => $source,
|
|
'login' => $login,
|
|
'email' => $email,
|
|
'siren' => $siren,
|
|
'nic' => $nic,
|
|
'ref' => $ref,
|
|
'encoursClient' => $encoursClient,
|
|
'rs' => $tabIdentite['Nom'],
|
|
'cp' => $tabIdentite['CP'],
|
|
'ville' => $tabIdentite['Ville'],
|
|
'dateAjout'=>date('Y-m-d'),
|
|
'dateSuppr'=>0,
|
|
);
|
|
$result = $iDb->insert('jo.surveillances_site', $data, false, true);
|
|
}
|
|
}
|
|
$output = new SetSurveillanceReturn();
|
|
$output->result = $result;
|
|
return $output;
|
|
}
|
|
|
|
/**
|
|
* getSurveillances
|
|
* @param SurveillancesFiltre $filtre
|
|
* @param integer $deb
|
|
* @param integer $nbRep
|
|
* @return SurveillancesReturn
|
|
*/
|
|
public function getSurveillances($filtre, $position=0, $nbRep=100)
|
|
{
|
|
$this->authenticate();
|
|
//$this->permission('survliste');
|
|
|
|
//Initialisation
|
|
if (empty($position)) $position = 0;
|
|
if (empty($nbRep)) $nbRep = 100;
|
|
|
|
$error = new ErrorType();
|
|
$tabRet = array();
|
|
$siren = 0;
|
|
$login = $this->User->login;
|
|
|
|
$strSiren = "";
|
|
if (!empty($filtre->item) && $filtre->itemMode == 'siren'){
|
|
$siren = substr($filtre->item,0,9);
|
|
$nic = substr($filtre->item,9,5);
|
|
$strSiren = " AND siren='$siren'";
|
|
} elseif (!empty($filtre->item) && $filtre->itemMode == 'search') {
|
|
$identifiant = trim($filtre->item);
|
|
if (preg_match('/([0-9]{9})|([0-9]{3}\s[0-9]{3}\s[0-9]{3})/',$identifiant, $matches)){
|
|
$identifiant = str_replace(' ', '', $identifiant);
|
|
$strSiren = " AND ( siren='$identifiant' )";
|
|
} else {
|
|
$strSiren = " AND ( ref='$filtre->item' OR rs='$filtre->item' )";
|
|
}
|
|
}
|
|
|
|
//Ordre pour le tri
|
|
$triMode = strtoupper(trim($filtre->triMode));
|
|
if ($triMode == 'DESC') {
|
|
$triMode = 'DESC';
|
|
} else {
|
|
$triMode = 'ASC';
|
|
}
|
|
|
|
//Option de tri
|
|
$tri = strtolower(trim($filtre->tri));
|
|
switch ($tri) {
|
|
case 'ref': $orderBy='ORDER BY ref'; break;
|
|
case 'dateAjout': $orderBy='ORDER BY dateAjout'; break;
|
|
case 'dateDerEnvoi': $orderBy='ORDER BY dateDerEnvoi'; break;
|
|
case 'rs': $orderBy='ORDER BY rs'; break;
|
|
case 'cp': $orderBy='ORDER BY cp'; break;
|
|
case 'ville': $orderBy='ORDER BY ville'; break;
|
|
default: $orderBy='ORDER BY siren'; break; // siren ou vide ou autre
|
|
}
|
|
$orderBy = $orderBy.' '.$triMode;
|
|
|
|
if ($filtre->detail) {
|
|
$strSelect = 'source, email, LPAD(siren,9,0) AS siren, LPAD(nic,5,0) AS nic, ref, dateAjout, encoursClient, rs, cp, ville, dateDerEnvoi';
|
|
} else {
|
|
$strSelect = 'source, email, LPAD(siren,9,0) AS siren, LPAD(nic,5,0) AS nic, ref, dateAjout, dateDerEnvoi';
|
|
}
|
|
if ($filtre->source!='') $strSource = " AND source='$filtre->source' ";
|
|
else $strSource = '';
|
|
|
|
$iDb = new WDB();
|
|
|
|
if ($filtre->source!='') {
|
|
|
|
// Il faut compter le nombre de siren au total
|
|
$tabTmp = $iDb->select(
|
|
'jo.surveillances_site',
|
|
'count(*) as nb', "login='$login' AND dateSuppr=0 $strSiren $strSource",
|
|
false, MYSQL_ASSOC
|
|
);
|
|
$nbRepTot = $tabTmp[0]['nb'];
|
|
|
|
// Récupération des résultats
|
|
$tabTmp = $iDb->select(
|
|
'jo.surveillances_site', $strSelect,
|
|
"login='$login' AND dateSuppr=0 $strSiren $strSource $orderBy LIMIT $position,$nbRep",
|
|
false, MYSQL_ASSOC
|
|
);
|
|
|
|
} else {
|
|
|
|
// Il faut compter le nombre de siren au total
|
|
$tabTmp = $iDb->select(
|
|
'jo.surveillances_site',
|
|
'siren', "login='$login' AND dateSuppr=0 $strSiren GROUP BY siren",
|
|
false, MYSQL_ASSOC
|
|
);
|
|
$nbRepTot = count($tabTmp);
|
|
|
|
// Récupération des résultats
|
|
if ($nbRepTot>0){
|
|
$tabTmp = $iDb->select(
|
|
'jo.surveillances_site',
|
|
'siren', "login='$login' AND dateSuppr=0 $strSiren GROUP BY siren ORDER BY siren LIMIT $position,$nbRep",
|
|
false, MYSQL_ASSOC
|
|
);
|
|
$listeSiren = array();
|
|
foreach($tabTmp as $i => $v) {
|
|
$listeSiren[] = $v['siren'];
|
|
}
|
|
$tabTmp = $iDb->select(
|
|
'jo.surveillances_site', $strSelect,
|
|
"login='$login' AND dateSuppr=0 AND siren IN (".join(',',$listeSiren).") $strSiren ORDER BY siren",
|
|
false, MYSQL_ASSOC
|
|
);
|
|
}
|
|
}
|
|
|
|
if (count($tabTmp)>0)
|
|
{
|
|
//Tri pour avoir le nombre de réponse correct suivant la structure
|
|
$listeRetour = array();
|
|
foreach ($tabTmp as $i => $tabSurv)
|
|
{
|
|
$rs = '';
|
|
$cp = '';
|
|
$ville = '';
|
|
$encoursClient = 0;
|
|
if ($filtre->detail) {
|
|
$encoursClient = $tabSurv['encoursClient'];
|
|
if (trim($tabSurv['rs'])<>'') {
|
|
$rs = $tabSurv['rs'];
|
|
$cp = $tabSurv['cp'];
|
|
$ville = $tabSurv['ville'];
|
|
} else {
|
|
$iInsee = new MInsee();
|
|
$tabIdentite = $iInsee->getIdentiteLight($tabSurv['siren'], $tabSurv['nic']);
|
|
$rs = $tabIdentite['Nom'];
|
|
$cp = $tabIdentite['CP'];
|
|
$ville = $tabIdentite['Ville'];
|
|
$iDb->update('jo.surveillances_site', array(
|
|
'rs' => $rs,
|
|
'cp' => $cp,
|
|
'ville' => $ville),
|
|
"login='$login' AND dateSuppr=0 AND siren=".$tabSurv['siren']." AND nic=".$tabSurv['nic']." $strSource",
|
|
false
|
|
);
|
|
}
|
|
}
|
|
|
|
$listeRetour[$tabSurv['siren']][] = array(
|
|
'rs' => $rs,
|
|
'cp' => $cp,
|
|
'ville' => $ville,
|
|
'source' => $tabSurv['source'],
|
|
'email' => $tabSurv['email'],
|
|
'nic' => $tabSurv['nic'],
|
|
'ref' => $tabSurv['ref'],
|
|
'encoursClient' => $encoursClient,
|
|
'dateAjout' => $tabSurv['dateAjout'],
|
|
'dateDerEnvoi' => $tabSurv['dateDerEnvoi'],
|
|
);
|
|
}
|
|
|
|
foreach ($listeRetour as $siren => $item)
|
|
{
|
|
$liste = new Surveillance();
|
|
$liste->siren = $siren;
|
|
foreach($item as $s) {
|
|
$source = new stdClass();
|
|
$source->rs = $s['rs'];
|
|
$source->cp = $s['cp'];
|
|
$source->ville = $s['ville'];
|
|
$source->source = $s['source'];
|
|
$source->email = $s['email'];
|
|
$source->nic = $s['nic'];
|
|
$source->ref = $s['ref'];
|
|
$source->encoursClient = $s['encoursClient'];
|
|
$source->dateAjout = $s['dateAjout']; //@todo : date
|
|
$source->dateDerEnvoi = $s['dateDerEnvoi']; //@todo : date
|
|
$liste->sources[] = $source;
|
|
}
|
|
$tabRet[] = $liste;
|
|
}
|
|
}
|
|
$output = new SurveillancesReturn();
|
|
$output->nbReponses = count($tabRet);
|
|
$output->nbReponsesTotal = $nbRepTot;
|
|
$output->result = $tabRet;
|
|
return $output;
|
|
}
|
|
|
|
/**
|
|
* Recherche par référence client
|
|
* @param string $search
|
|
* @param integer $position
|
|
* @param integer $nbRep
|
|
* @return SearchRefClientReturn
|
|
*/
|
|
public function searchRefClient($search, $position=0, $nbRep=20)
|
|
{
|
|
$this->authenticate();
|
|
|
|
//Initialisation
|
|
if (empty($position)) $position = 0;
|
|
if (empty($nbRep)) $nbRep = 20;
|
|
|
|
$iDb = new WDB();
|
|
$login = $this->User->login;
|
|
$orderBy = " ORDER BY dateAjout ASC";
|
|
|
|
if ($this->User->rechRefType=='CLI'){
|
|
//On cherche les logins actifs pour le client
|
|
$idClient = $this->User->idClient;
|
|
|
|
$where = "u.idClient='$idClient' AND u.actif=1 AND s.dateSuppr=0 AND ( s.siren='$search' OR s.ref='$search' OR s.rs='$search' )";
|
|
// Il faut compter le nombre au total
|
|
$tabTmp = $iDb->select('jo.surveillances_site s, sdv1.utilisateurs u', 'count(*) as nb', $where.$orderBy, false, MYSQL_ASSOC);
|
|
$nbRepTot = $tabTmp[0]['nb'];
|
|
|
|
// Execution de la requete
|
|
$tabTmp = $iDb->select('jo.surveillances_site s, sdv1.utilisateurs u',
|
|
"siren, nic, ref, source, login, email, DATE_FORMAT(dateAjout, '%Y-%m-%d') as dateAjout, DATE_FORMAT(dateDerEnvoi, '%Y-%m-%d') as dateEnvoi",
|
|
$where.$orderBy." LIMIT $position,$nbRep", false, MYSQL_ASSOC);
|
|
} else {
|
|
$where = "login='$login' AND dateSuppr=0 AND ( siren='$search' OR ref='$search' OR rs='$search' )";
|
|
// Il faut compter le nombre au total
|
|
$tabTmp = $iDb->select('jo.surveillances_site', 'count(*) as nb', $where.$orderBy, false, MYSQL_ASSOC);
|
|
$nbRepTot = $tabTmp[0]['nb'];
|
|
|
|
// Execution de la requete
|
|
$tabTmp = $iDb->select('jo.surveillances_site',
|
|
"siren, nic, ref, source, login, email, DATE_FORMAT(dateAjout, '%Y-%m-%d') as dateAjout, DATE_FORMAT(dateDerEnvoi, '%Y-%m-%d') as dateEnvoi",
|
|
$where.$orderBy." LIMIT $position,$nbRep", false, MYSQL_ASSOC);
|
|
}
|
|
|
|
$tabRet = array();
|
|
if (count($tabTmp)>0)
|
|
{
|
|
foreach ($tabTmp as $i => $item)
|
|
{
|
|
$info = new SearchRefClientInfo();
|
|
$info->ref = $item['ref'];
|
|
$info->source = $item['source'];
|
|
$info->login = $item['login'];
|
|
$info->email = $item['email'];
|
|
$info->dateAjout = $item['dateAjout'];
|
|
$info->dateEnvoi = $item['dateEnvoi'];
|
|
|
|
$iInsee = new MInsee();
|
|
$tabIdentite = $iInsee->getIdentiteLight($item['siren'], $item['nic']);
|
|
|
|
$reponse = new SearchRefClient();
|
|
$reponse->id = $tabIdentite['id'];
|
|
$reponse->Siret = $tabIdentite['Siret'];
|
|
$reponse->Siege = $tabIdentite['Siege'];
|
|
$reponse->Nom = prepareString(strtr($tabIdentite['Nom'],'/*',' '));
|
|
$reponse->Nom2 = prepareString($tabIdentite['Nom2']);
|
|
$reponse->Sigle = prepareString($tabIdentite['Sigle']);
|
|
$reponse->Enseigne = prepareString($tabIdentite['Enseigne']);
|
|
$reponse->Adresse = prepareString($tabIdentite['Adresse']);
|
|
$reponse->Adresse2 = prepareString($tabIdentite['Adresse2']);
|
|
$reponse->CP = $tabIdentite['CP'];
|
|
$reponse->Ville = prepareString($tabIdentite['Ville']);
|
|
$reponse->Tel = $tabIdentite['Tel'];
|
|
$reponse->Fax = $tabIdentite['Fax'];
|
|
$reponse->FJ = $tabIdentite['FJ'];
|
|
$reponse->FJLib = prepareString($tabIdentite['FJ_lib']);
|
|
$reponse->Siren = $tabIdentite['Siren'];
|
|
$reponse->Nic = $tabIdentite['Nic'];
|
|
$reponse->Actif = $tabIdentite['Actif'];
|
|
$reponse->NafEtab = $tabIdentite['NafEtab'];
|
|
$reponse->NafEtabLib = $tabIdentite['NafEtabLib'];
|
|
$reponse->NafEnt = $tabIdentite['NafEnt'];
|
|
$reponse->NafEntLib = $tabIdentite['NafEntLib'];
|
|
$reponse->Infos = $info;
|
|
$tabRet[] = $reponse;
|
|
}
|
|
}
|
|
$output = new SearchRefClientReturn();
|
|
$output->nbReponses = count($tabRet);
|
|
$output->nbReponsesTotal = $nbRepTot;
|
|
$output->result = $tabRet;
|
|
return $output;
|
|
}
|
|
|
|
/**
|
|
* Retourne le bilan correspondant au siren, à l'exercice et au formalisme demandé
|
|
*
|
|
* @param string $siren Siren de l'entreprise
|
|
* @param string $millesime Date du bilan au format AAAAMMJJ
|
|
* @param string $typeBilan N:Réel Normal, S:Réel Simplifié, C:Consolidé
|
|
* @param string $ref Référence S&D obligatoire
|
|
* @return Bilan
|
|
*/
|
|
public function getBilan($siren, $millesime, $typeBilan='N', $ref='')
|
|
{
|
|
$this->authenticate();
|
|
$this->permission('liasse');
|
|
|
|
//Initialisation
|
|
if (empty($typeBilan)) { $typeBilan = 'N'; }
|
|
if (empty($ref)) { $ref = ''; }
|
|
|
|
debugLog('I',"Bilan $millesime $typeBilan demandée pour $siren",__LINE__,__FILE__, __FUNCTION__, __CLASS__);
|
|
|
|
$tabRet = array();
|
|
if (strlen($siren)<>9){
|
|
debugLog('W', "Siren $siren incorrect", __LINE__, __FILE__, __FUNCTION__, __CLASS__);
|
|
$this->sendError('1010');
|
|
} elseif ($siren*1==0) {
|
|
debugLog('W', "Siren $siren inexistant", __LINE__, __FILE__, __FUNCTION__, __CLASS__);
|
|
$this->sendError('1010');
|
|
}
|
|
|
|
$millesime = WDate::dateT('Ymd','d/m/Y',$millesime);
|
|
$mBil = new MBilans($siren);
|
|
$tabBilan = $mBil->getBilan($millesime, $typeBilan, $ref, true);
|
|
|
|
// --- Bilan condidentiel
|
|
|
|
|
|
// --- Génération du format pour le webservice
|
|
$txtKey = array(
|
|
'SIREN',
|
|
'DATE_FRAICHE_BILAN',
|
|
'DATE_CLOTURE',
|
|
'DATE_CLOTURE_PRE',
|
|
'DUREE_MOIS',
|
|
'DUREE_MOIS_PRE',
|
|
'MONNAIE',
|
|
'CONSOLIDE',
|
|
'MONNAIE_ORI',
|
|
'MONNAIE_LIV_UNITE',
|
|
'SOURCE',
|
|
'devise',
|
|
'ID_BILAN_SD',
|
|
'DATE_BILAN_SD',
|
|
'TOP_CONFIDENTIEL',
|
|
);
|
|
|
|
$resultBilan = new Bilan();
|
|
$tabPoste = array();
|
|
foreach($tabBilan as $key => $value) {
|
|
if( in_array($key, $txtKey)) {
|
|
$resultBilan->$key = $value;
|
|
} else {
|
|
$resultPoste = new BilanPoste();
|
|
$resultPoste->id = $key;
|
|
$resultPoste->val = $value;
|
|
$tabPoste[] = $resultPoste;
|
|
}
|
|
}
|
|
$resultBilan->POSTES = $tabPoste;
|
|
|
|
$this->wsLog('bilan',$siren, $millesime.':'.$typeBilan.':'.$ref);
|
|
return $resultBilan;
|
|
}
|
|
|
|
/**
|
|
* Retourne la liste des bilans disponible pour une entreprise
|
|
*
|
|
* @param string $siren Siren de l'entreprise
|
|
* @return ListeBilansReturn
|
|
*/
|
|
public function getListeBilans($siren)
|
|
{
|
|
$this->authenticate();
|
|
$this->permission('liasse');
|
|
|
|
//Initialisation
|
|
$tabRet = array();
|
|
debugLog('I',"Liste des Bilans demandée pour $siren",__LINE__,__FILE__, __FUNCTION__, __CLASS__);
|
|
if (strlen($siren)!=9) {
|
|
debugLog('W', "Siren $siren incorrect", __LINE__, __FILE__, __FUNCTION__, __CLASS__);
|
|
$this->sendError('1010');
|
|
} elseif ($siren*1==0) {
|
|
debugLog('W', "Siren $siren inexistant", __LINE__, __FILE__, __FUNCTION__, __CLASS__);
|
|
$this->sendError('1010');
|
|
}
|
|
|
|
$mBil = new MBilans($siren);
|
|
$tabBilans = $mBil->listeBilans(true);
|
|
foreach($tabBilans as $bilan) {
|
|
$element = new ListeBilans();
|
|
$element->dateProvPartenaire = $bilan['dateProvPartenaire']; //@todo : date
|
|
$element->dateInsert = $bilan['dateInsert']; //@todo : date
|
|
$element->typeBilan = $bilan['typeBilan'];
|
|
$element->dureeExercice = $bilan['dureeExercice'];
|
|
$element->dateExercice = $bilan['dateExercice']; //@todo : date
|
|
$element->millesime = $bilan['millesime'];
|
|
$element->dateExercicePre = $bilan['dateExercicePre']; //@todo : date
|
|
$element->dureeExercicePre = $bilan['dureeExercicePre'];
|
|
$element->monnaie = $bilan['monnaie'];
|
|
$element->source = $bilan['source'];
|
|
$tabRet[] = $element;
|
|
}
|
|
|
|
debugLog('I', 'Nb Bilans retournés = '. count($tabBilans), __LINE__, __FILE__, __FUNCTION__, __CLASS__);
|
|
$this->wsLog('listebilans', $siren);
|
|
$output = new ListeBilansReturn();
|
|
$output->nbReponses = count($tabRet);
|
|
$output->result = $tabRet;
|
|
return $output;
|
|
}
|
|
|
|
/**
|
|
* Informations date de cloture du dernier bilan et état de saisie
|
|
*
|
|
* @param string $siren
|
|
* @return LiasseInfos|null
|
|
*/
|
|
public function getLiasseInfos($siren)
|
|
{
|
|
$this->authenticate();
|
|
//$this->permission('liasse');
|
|
|
|
//Check SIREN
|
|
|
|
//Lecture de la base de données
|
|
try {
|
|
$bilansM = new Application_Model_JoGreffesBilans();
|
|
$sql = $bilansM->select()
|
|
->where('siren=?', $siren)
|
|
->where('actif=1')
|
|
->order('date_cloture DESC')
|
|
->order('num_depot DESC')
|
|
->order('dateInsert DESC')
|
|
->limit(1);
|
|
$row = $bilansM->fetchRow($sql);
|
|
} catch (Zend_Db_Exception $e) {
|
|
if ($this->User->idClient==1) {
|
|
throw new SoapFault('ERR', $e->getMessage());
|
|
} else {
|
|
throw new SoapFault('ERR', "Application error");
|
|
}
|
|
}
|
|
|
|
if ( $row === null ) {
|
|
return null;
|
|
}
|
|
|
|
$liasseInfos = new LiasseInfos();
|
|
$liasseInfos->Id = $row->id;
|
|
$liasseInfos->BilanDateCloture = $row->date_cloture;
|
|
|
|
switch ( $row->type_comptes ) {
|
|
case '':
|
|
case 'sociaux':
|
|
$liasseInfos->BilanType = 'N';
|
|
break;
|
|
case 'consolides':
|
|
$liasseInfos->BilanType = 'C';
|
|
break;
|
|
}
|
|
|
|
$liasseInfos->SaisieDate = $row->saisie_date;
|
|
$liasseInfos->SaisieCode = $row->saisie_code;
|
|
switch ( $row->saisie_code ) {
|
|
case '00': $liasseInfos->SaisieLabel = "Bilan saisi sans anomalie"; break;
|
|
case '01': $liasseInfos->SaisieLabel = "Bilan saisi avec des incohérences comptables à la source du document (issues du remettant)"; break;
|
|
case '02': $liasseInfos->SaisieLabel = "Bilan avec Actif, Passif ou Compte de Résultat nul"; break;
|
|
case '03': $liasseInfos->SaisieLabel = "Bilan incomplet (des pages manquent)"; break;
|
|
case '04': $liasseInfos->SaisieLabel = "Bilan complet non détaillé (seuls les totaux et sous totaux sont renseignés)"; break;
|
|
case '05': $liasseInfos->SaisieLabel = "Bilan reçu en double exemplaire"; break;
|
|
case '06': $liasseInfos->SaisieLabel = "Bilan intermédiaire - Situation provisoire"; break;
|
|
case '07': $liasseInfos->SaisieLabel = "Bilan illisible"; break;
|
|
case 'A7': $liasseInfos->SaisieLabel = "Bilan illisible, présentant un cadre gris très foncés (dans lesquels sont inscrits en général les totaux)"; break;
|
|
case 'B7': $liasseInfos->SaisieLabel = "Bilan manuscrits"; break;
|
|
case 'C7': $liasseInfos->SaisieLabel = "Bilan illisible, présentant des caractères trop gras"; break;
|
|
case 'D7': $liasseInfos->SaisieLabel = "Bilan scanné en biais ou qui présentent des pages rognées"; break;
|
|
case 'E7': $liasseInfos->SaisieLabel = "Bilan numérisés trop clairement (comme une imprimante dont la cartouche est presque vide)"; break;
|
|
case 'F7': $liasseInfos->SaisieLabel = "Bilan illisible"; break;
|
|
case '08': $liasseInfos->SaisieLabel = "Bilan consolidé"; break;
|
|
case '09': $liasseInfos->SaisieLabel = "Déclaration d'impôts"; break;
|
|
case '10': $liasseInfos->SaisieLabel = "Document autre que bilan"; break;
|
|
case '11': $liasseInfos->SaisieLabel = "Bilan de clôture de liquidation"; break;
|
|
case '12': $liasseInfos->SaisieLabel = "Bilan de Société financière"; break;
|
|
case '13': $liasseInfos->SaisieLabel = "Bilan de Société d'assurance"; break;
|
|
case '14': $liasseInfos->SaisieLabel = "Bilan de Société immobilière"; break;
|
|
case '15': $liasseInfos->SaisieLabel = "Bilan de Société étrangère"; break;
|
|
default: $liasseInfos->SaisieLabel = ""; break;
|
|
}
|
|
|
|
if ( $row->saisie_code != '00' ) {
|
|
//Surcharge des codes de saisie
|
|
$date = new Zend_Date($row->date_cloture, 'yyyy-MM-dd');
|
|
try {
|
|
$liasseM = new Application_Model_JoBilans();
|
|
$sql = $liasseM->select()
|
|
->where('siren=?', $siren)
|
|
->where('typeBilan=?', $liasseInfos->BilanType)
|
|
->where('dateExercice=?', $date->toString('yyyyMMdd'));
|
|
$row = $liasseM->fetchRow($sql);
|
|
} catch (Zend_Db_Exception $e) {
|
|
//file_put_contents('debug.log', $e->getMessage()."\n", FILE_APPEND);
|
|
}
|
|
if ( $row !== null ) {
|
|
$liasseInfos->SaisieDate = substr($row->dateProvPartenaire,0,4) .
|
|
'-' . substr($row->dateProvPartenaire,4,2) .
|
|
'-' . substr($row->dateProvPartenaire,6,2);
|
|
$liasseInfos->SaisieCode = '00';
|
|
}
|
|
}
|
|
|
|
return $liasseInfos;
|
|
}
|
|
|
|
/**
|
|
* Vérifie si un siren existe en base Scores & Décisions
|
|
* @param string $siren Siren de l'entité
|
|
* @return boolean
|
|
*/
|
|
public function isSirenExistant($siren)
|
|
{
|
|
$this->authenticate();
|
|
|
|
//Initialisation
|
|
$tabRet = array();
|
|
$siren = trim(substr($siren,0,9));
|
|
$result = false;
|
|
debugLog('I',"Siren existant demandée pour siren $siren",__LINE__,__FILE__, __FUNCTION__, __CLASS__);
|
|
|
|
if ($siren*1==0) {
|
|
debugLog('W', "Siren $siren inexistant", __LINE__, __FILE__, __FUNCTION__, __CLASS__);
|
|
$this->sendError('1010');
|
|
}
|
|
|
|
$iInsee = new MInsee();
|
|
$entrep = $iInsee->sirenExiste($siren);
|
|
if (empty($entrep)) {
|
|
debugLog('W', "Siren $siren non présent en base", __LINE__, __FILE__, __FUNCTION__, __CLASS__);
|
|
$result = false;
|
|
} else {
|
|
debugLog('I', "Siren $siren présent en base", __LINE__, __FILE__, __FUNCTION__, __CLASS__);
|
|
$result = true;
|
|
}
|
|
$this->wsLog('sirenExiste',$siren);
|
|
return $result;
|
|
}
|
|
|
|
/**
|
|
* Retourne une annonce en fonction de sa référence
|
|
*
|
|
* @param string $siren Siren de l'entreprise
|
|
* @param string $dateAnnee
|
|
* @param integer $numParution
|
|
* @param integer $numAnnonce
|
|
* @return RechercheAnnonceReturn
|
|
*/
|
|
public function rechercheAnnonce($source, $dateAnnee, $numParution, $numAnnonce)
|
|
{
|
|
$this->authenticate();
|
|
$this->permission('histobodacc');
|
|
|
|
//Initialisation
|
|
$tabRet = array();
|
|
|
|
debugLog('I',"Annonce précise demandée pour $source, $dateAnnee, $numParution, $numAnnonce",__LINE__,__FILE__, __FUNCTION__, __CLASS__);
|
|
|
|
if (strlen($dateAnnee)==4) $annee = $dateAnnee;
|
|
else $annee = substr($dateAnnee,0,4);
|
|
|
|
$iDb = new WDB();
|
|
|
|
switch (strtoupper($source))
|
|
{
|
|
case 'BODA':
|
|
case 'BODB':
|
|
case 'BODC':
|
|
$lettre = substr(strtoupper($source),3,1);
|
|
if ($annee<2005) {
|
|
if ($lettre=='A'){ $numJAL=1; }
|
|
elseif ($lettre=='B'){ $numJAL=200; }
|
|
else{ break; }
|
|
$anneeDeb = $annee.'0101';
|
|
$anneeFin = $annee.'1231';
|
|
$res = $iDb->select('historiques.entrep e, texte t',
|
|
"$annee AS Annee_Parution, e.NOBOD AS Num_Parution, e.NOANN AS Num_Annonce, e.NOPAGE AS Num_Page, e.`DATE` AS Date_Parution, e.DEPT AS Departement, e.CODTRI AS Tribunal_Code, 'I' AS typeAnnonce, CONCAT(e.NOANN,' - ',t.annonceTxt) AS annonce",
|
|
"e.JAL=$numJAL AND e.NOBOD=$numParution AND e.`DATE` BETWEEN $anneeDeb AND $anneeFin AND e.NOANN=$numAnnonce AND e.ANBASE=t.annonceNum", false, MYSQL_ASSOC);
|
|
} else {
|
|
$res = $iDb->select('jo.bodacc',
|
|
'Bodacc_Annee_Parution AS Annee_Parution, Bodacc_Num AS Num_Parution, Num_Annonce, Bodacc_Page AS Num_Page, Bodacc_Date_Parution AS Date_Parution, Tribunal_Dept AS Departement, Tribunal_Code, typeAnnonce, annonce',
|
|
"Bodacc_Code='$lettre' AND Bodacc_Annee_Parution=$annee AND Bodacc_Num=$numParution AND Num_Annonce=$numAnnonce", false, MYSQL_ASSOC);
|
|
}
|
|
break;
|
|
case 'ASSO':
|
|
$res = $iDb->select('jo.asso',
|
|
'YEAR(Date_Parution) AS Annee_Parution, Num_Parution, Num_Annonce, pageDeb AS Num_Page, Date_Parution, Departement, codTribunal AS Tribunal_Code, typeAnnonce, Annonce_Html AS annonce', "Date_Parution BETWEEN '$annee-01-01' AND '$annee-12-31' AND Num_Parution=$annee".sprintf('%04d', $numParution)." AND Num_Annonce=$numAnnonce",
|
|
false, MYSQL_ASSOC);
|
|
break;
|
|
case 'BALO':
|
|
$res = $iDb->select('jo.balo',
|
|
"YEAR(Date_Parution) AS Annee_Parution, Num_Parution, Num_Affaire AS Num_Annonce, '' AS Num_Page, Date_Parution, '' AS Departement, '' AS Tribunal_Code, 'Insertion' AS typeAnnonce, Annonce_Html AS annonce", "Date_Parution BETWEEN '$annee-01-01' AND '$annee-12-31' AND Num_Parution=$numParution AND Num_Affaire=$numAnnonce",
|
|
false, MYSQL_ASSOC);
|
|
break;
|
|
}
|
|
|
|
if (count($res)>0)
|
|
{
|
|
$iBodacc = new MBodacc();
|
|
foreach ($res as $i => $etab)
|
|
{
|
|
$annonces = new AnnonceItem();
|
|
$annonces->Annee_Parution = $etab['Annee_Parution'];
|
|
$annonces->Num_Parution = $etab['Num_Parution'];
|
|
$annonces->Num_Annonce = $etab['Num_Annonce'];
|
|
$annonces->Num_Page = $etab['Num_Page'];
|
|
$annonces->Date_Parution = $etab['Date_Parution']; //@todo : date
|
|
$annonces->Departement = $etab['Departement'];
|
|
$annonces->Tribunal_Code = $etab['Tribunal_Code'];
|
|
$annonces->Tribunal = $iBodacc->getTribunalNom($etab['Tribunal_Code']);
|
|
$annonces->Type_Annonce = $etab['typeAnnonce'];
|
|
$annonces->Annonce = strip_tags(strtr(
|
|
html_entity_decode($etab['annonce']),
|
|
array('>'=>'>','&'=>'&','<'=>'<','’'=>"'")
|
|
));
|
|
|
|
$tabRet[] = $annonces;
|
|
}
|
|
}
|
|
$nbTot = count($tabRet);
|
|
$output = new RechercheAnnonceReturn();
|
|
$output->criteres = $criteres;
|
|
$output->nbReponses = $nbTot;
|
|
$output->nbReponsesTotal = $nbTot;
|
|
$output->result = $tabRet;
|
|
return $output;
|
|
}
|
|
|
|
/**
|
|
* getRatios
|
|
* @param string $siren
|
|
* @param string $page
|
|
* @return RatiosReturn
|
|
*/
|
|
public function getRatios($siren, $page='ratios')
|
|
{
|
|
$this->authenticate();
|
|
$this->permission('ratios');
|
|
|
|
//Initialisation
|
|
if (empty($page)) $page = 'ratios';
|
|
|
|
debugLog('I',"Liste des Ratios demandée pour $siren",__LINE__,__FILE__, __FUNCTION__, __CLASS__);
|
|
if (strlen($siren)<>9){
|
|
debugLog('W', "Siren $siren incorrect", __LINE__, __FILE__, __FUNCTION__, __CLASS__);
|
|
$this->sendError('1010');
|
|
} elseif ($siren*1==0) {
|
|
debugLog('W', "Siren $siren inexistant", __LINE__, __FILE__, __FUNCTION__, __CLASS__);
|
|
$this->sendError('1010');
|
|
}
|
|
|
|
debugLog('I',"Liste des Ratios demandée pour $siren avant getIdentiteEntreprise",__LINE__,__FILE__, __FUNCTION__, __CLASS__);
|
|
$iInsee = new MInsee();
|
|
$tabIdentite = $iInsee->getIdentiteEntreprise($siren,0,0,false,false);
|
|
debugLog('I',"Liste des Ratios demandée pour $siren après getIdentiteEntreprise",__LINE__,__FILE__, __FUNCTION__, __CLASS__);
|
|
$naf = $tabIdentite['NafEnt'];
|
|
$nafLib = $tabIdentite['NafEntLib'];
|
|
$efftr = $tabIdentite['Effectif']*1;
|
|
$fj = $tabIdentite['FJ'];
|
|
|
|
$accesPartenaire = true;
|
|
if (APPLICATION_ENV == 'development') {
|
|
$accesPartenaire = false;
|
|
}
|
|
|
|
$tabRatiosInfos = $tabRatiosSecteurs = $tabBilansR = array();
|
|
$tabRatios = $tabRatiosEvol = array();
|
|
$tabRet = array();
|
|
|
|
/**
|
|
* Tableau d'infos sur les formules
|
|
*/
|
|
$tabFormules = include APPLICATION_PATH . '/../library/Metier/scores/Data/Formules.php';
|
|
$tabBorneMin = $tabBorneMax = array();
|
|
foreach ($tabFormules as $formule) {
|
|
$id = $formule['id']*1;
|
|
$libelle = $formule['libelle'];
|
|
$unite = $formule['unite'];
|
|
$commentaires = $formule['commentaires'];
|
|
$tabFormulesInfos[$id] = $formule; //Pour la gestion des unités des ratios secteur
|
|
$ratiosInfos = new RatiosInfos();
|
|
$ratiosInfos->id = 'r'.$id;
|
|
$ratiosInfos->libelle = $formule['libelle'];
|
|
$ratiosInfos->unite = $formule['unite'];
|
|
$ratiosInfos->commentaires = $formule['commentaires'];
|
|
$tabRatiosInfos[] = $ratiosInfos;
|
|
$tabBorneMin[$id] = $formule['borneMin'];
|
|
$tabBorneMax[$id] = $formule['borneMax'];
|
|
}
|
|
|
|
//Ratios
|
|
$mBil = new MBilans($siren);
|
|
$tabBilans = $mBil->listeBilans($accesPartenaire, 5);
|
|
$nbBilans = count($tabBilans);
|
|
$tabBilan = $tabBil = array();
|
|
if ($nbBilans > 0) {
|
|
$i = 0;
|
|
foreach ($tabBilans as $millesime => $item) {
|
|
if ( $item['typeBilan'] == 'N' ) {
|
|
$tabBilan[] = $mBil->getBilan(substr($millesime, -10), substr($millesime, 0, 1));
|
|
$i++;
|
|
} elseif ( $item['typeBilan'] == 'S' ) {
|
|
$tabN = $mBil->getBilan(substr($millesime, -10), substr($millesime, 0, 1));
|
|
$tabS = $mBil->bilanSimplifie2Normal($tabN);
|
|
$tabBilan[] = array_merge($tabN, $tabS);
|
|
$i++;
|
|
} elseif ( $item['typeBilan'] == 'C' ) {
|
|
$tabBilan[] = $mBil->getBilan(substr($millesime, -10), substr($millesime, 0, 1));
|
|
$i++;
|
|
}
|
|
}
|
|
require_once 'Metier/scores/classMRatios.php';
|
|
$mRatios = new MRatios();
|
|
$mRatios->setTrancheEffectif($efftr);
|
|
$tabRatios = $mRatios->calcul($tabBilan);
|
|
//file_put_contents('debug.log', print_r($tabRatios,1));
|
|
}
|
|
|
|
$nbRatios = count($tabRatios);
|
|
debugLog('I',"Liste des Ratios demandée pour $siren après calculRatios ($nbRatios)",__LINE__,__FILE__, __FUNCTION__, __CLASS__);
|
|
|
|
$tabAnnees = array();
|
|
if ( $nbRatios > 0 ) {
|
|
foreach ( $tabRatios as $i => $R ) {
|
|
//Informations sur le bilan
|
|
$bilansInfos = new RatiosBilansInfos();
|
|
$bilansInfos->dateCloture = $tabBilan[$i]['DATE_CLOTURE']; //@todo : date
|
|
$bilansInfos->duree = $tabBilan[$i]['DUREE_MOIS'];
|
|
$bilansInfos->devise = $tabBilan[$i]['MONNAIE'];
|
|
$bilansInfos->typeBilan = $tabBilan[$i]['CONSOLIDE'];
|
|
$bilansInfos->unite = 'U';
|
|
if ( substr($tabBilan[$i]['DATE_CLOTURE'],0,4)>1900 ){
|
|
$tabAnnees[$i]=substr($tabBilan[$i]['DATE_CLOTURE'],0,4);
|
|
}
|
|
|
|
$tabRatiosEntrep = array();
|
|
$tabRatiosEntrepEvol = array();
|
|
foreach ( $R as $Ridx => $Rmont ) {
|
|
if ($Rmont<>'NS') {
|
|
if ( $tabBorneMin[$Ridx]<>'' && $Rmont<$tabBorneMin[$Ridx] ){
|
|
$Rmont='<'.$tabBorneMin[$Ridx];
|
|
} elseif ( $tabBorneMax[$Ridx]<>'' && $Rmont>$tabBorneMax[$Ridx] ){
|
|
$Rmont='>'.$tabBorneMax[$Ridx];
|
|
}
|
|
}
|
|
|
|
// RatiosEntrep
|
|
$ratiosEntrep = new Ratios();
|
|
if (substr($Rmont,0,1)=='N' || substr($Rmont,0,1)=='<' || substr($Rmont,0,1)=='>') {
|
|
$ratiosEntrep->id = 'r'.$Ridx;
|
|
$ratiosEntrep->val = $Rmont;
|
|
} else {
|
|
$ratiosEntrep->id = 'r'.$Ridx;
|
|
$ratiosEntrep->val = round($Rmont,2);
|
|
}
|
|
$tabRatiosEntrep[] = $ratiosEntrep;
|
|
|
|
if ( ( $tabBilan[$i]['CONSOLIDE']=='S' && isset($tabRatios[$i+1]) && ($tabBilan[$i+1]['CONSOLIDE']=='S'
|
|
|| ($tabBilan[$i+1]['CONSOLIDE']=='N' && $tabBilan[$i+1]['DATE_CLOTURE']<>$tabBilan[$i]['DATE_CLOTURE'])) )
|
|
|| ( $tabBilan[$i]['CONSOLIDE']=='N' && isset($tabRatios[$i+1]) && ($tabBilan[$i+1]['CONSOLIDE']=='N'
|
|
|| ($tabBilan[$i+1]['CONSOLIDE']=='S'&& $tabBilan[$i+1]['DATE_CLOTURE']<>$tabBilan[$i]['DATE_CLOTURE'])) )
|
|
) {
|
|
if ($tabRatios[$i+1][$Ridx] == 0) {
|
|
$Rmont = 'NS';
|
|
} else {
|
|
$Rmont = (($R[$Ridx]-$tabRatios[$i+1][$Ridx])*100)/abs($tabRatios[$i+1][$Ridx]);
|
|
}
|
|
}
|
|
elseif ( ( $tabBilan[$i]['CONSOLIDE']=='S' && isset($tabRatios[$i+1]) && ($tabBilan[$i+2]['CONSOLIDE']=='S'
|
|
|| ($tabBilan[$i+2]['CONSOLIDE']=='N' && $tabBilan[$i+2]['DATE_CLOTURE']<>$tabBilan[$i]['DATE_CLOTURE'])) )
|
|
|| ( $tabBilan[$i]['CONSOLIDE']=='N' && isset($tabRatios[$i+1]) && ($tabBilan[$i+2]['CONSOLIDE']=='N'
|
|
|| ($tabBilan[$i+2]['CONSOLIDE']=='S'&& $tabBilan[$i+2]['DATE_CLOTURE']<>$tabBilan[$i]['DATE_CLOTURE'])) )
|
|
) {
|
|
if ($tabRatios[$i+2][$Ridx] == 0) {
|
|
$Rmont = 'NS';
|
|
} else {
|
|
$Rmont = (($R[$Ridx]-$tabRatios[$i+2][$Ridx])*100)/abs($tabRatios[$i+2][$Ridx]);
|
|
}
|
|
} else {
|
|
$Rmont = 'NS';
|
|
}
|
|
|
|
// RatiosEntrepEvol
|
|
$ratiosEntrepEvol = new Ratios();
|
|
if ($Rmont=='NS' || $Rmont<-800 || $Rmont>800){
|
|
$ratiosEntrepEvol->id = 'r'.$Ridx;
|
|
$ratiosEntrepEvol->val = 'NS';
|
|
} else {
|
|
$ratiosEntrepEvol->id = 'r'.$Ridx;
|
|
$ratiosEntrepEvol->val = number_format($Rmont,2,',',' ');
|
|
}
|
|
$tabRatiosEntrepEvol[] = $ratiosEntrepEvol;
|
|
}
|
|
$bilansInfos->RatiosEntrep = $tabRatiosEntrep;
|
|
$bilansInfos->RatiosEntrepEvol = $tabRatiosEntrepEvol;
|
|
$tabBilansR[] = $bilansInfos;
|
|
}
|
|
}
|
|
debugLog('I',"Liste des Ratios demandée pour $siren après EVOLUTION",__LINE__,__FILE__, __FUNCTION__, __CLASS__);
|
|
|
|
// Tableau des ratios secteurs
|
|
if (strlen($naf)>4) $strNaf = " AND naf5='$naf' ";
|
|
else $strNaf = " AND naf4='$naf' ";
|
|
$strAnnees = implode(',', $tabAnnees);
|
|
|
|
$tabRatiosSecteurs = array();
|
|
|
|
$tabAnnees = array_unique($tabAnnees);
|
|
|
|
if ( count($tabAnnees)>0 ) {
|
|
$iDb = new WDB();
|
|
$tabTmp = $iDb->select('jo.ratios_secteurs',
|
|
'annee, naf5, naf4, id, (montant/nombre) AS ratio, nombre',
|
|
"1 $strNaf AND annee IN ($strAnnees) ORDER BY annee DESC, id ASC",
|
|
false, MYSQL_ASSOC);
|
|
|
|
$nbRatiosSec = 0;
|
|
foreach($tabAnnees as $annee) {
|
|
$ratiosSecteur = new RatiosSecteur();
|
|
$ratiosSecteur->annee = $annee;
|
|
foreach ($tabTmp as $tmp)
|
|
{
|
|
if ($tmp['annee']== $annee)
|
|
{
|
|
$Ridx = $tmp['id'];
|
|
if ($tmp['nombre']>$nbRatiosSec){
|
|
$nbRatiosSec = $tmp['nombre'];
|
|
}
|
|
|
|
$unite = $tabFormulesInfos[$Ridx]['unite'];
|
|
if ($unite=='EUR'){
|
|
$montant = round($tmp['ratio']*1000);
|
|
} else {
|
|
$montant = round($tmp['ratio']);
|
|
}
|
|
if ($tabBorneMin[$Ridx]<>'' && $montant<$tabBorneMin[$Ridx]){
|
|
$montant='<'.$tabBorneMin[$Ridx];
|
|
} elseif ($tabBorneMax[$Ridx]<>'' && $montant>$tabBorneMax[$Ridx]){
|
|
$montant='>'.$tabBorneMax[$Ridx];
|
|
}
|
|
|
|
$ratiosSecteurListe = new Ratios();
|
|
if (substr($montant,0,1)=='N' || substr($montant,0,1)=='<' || substr($montant,0,1)=='>'){
|
|
$ratiosSecteurListe->id = 'r'.$Ridx;
|
|
$ratiosSecteurListe->val = $montant;
|
|
} else {
|
|
$ratiosSecteurListe->id = 'r'.$Ridx;
|
|
$ratiosSecteurListe->val = round($montant,2);
|
|
}
|
|
$ratiosSecteur->liste[] = $ratiosSecteurListe;
|
|
}
|
|
}
|
|
$tabRatiosSecteurs[] = $ratiosSecteur;
|
|
}
|
|
}
|
|
|
|
$output = new RatiosReturn();
|
|
$output->Nom = $tabIdentite['Nom'];
|
|
$output->NafEnt = $tabIdentite['NafEnt'];
|
|
$output->NafEntLib = $tabIdentite['NafEntLib'];
|
|
$output->FJ = $fj;
|
|
$output->FJ_lib = $tabIdentite['FJ_lib'];
|
|
$output->Siren = $siren;
|
|
$output->NbEntNaf = $nbRatiosSec;
|
|
$output->BilansInfos = $tabBilansR;
|
|
$output->RatiosInfos = $tabRatiosInfos;
|
|
$output->RatiosSecteur = $tabRatiosSecteurs;
|
|
|
|
debugLog('I',"Liste des Ratios demandée pour $siren RETURN",__LINE__,__FILE__, __FUNCTION__, __CLASS__);
|
|
$this->wsLog($page, $siren);
|
|
return $output;
|
|
|
|
}
|
|
|
|
/**
|
|
* getRapport
|
|
* @param string $siren Siren de l'entreprise
|
|
* @param integer $niveau Niveau du rapport 1, 2 ou 3
|
|
* @param integer $id Identifiant interne S&D de l'entreprise
|
|
* @param boolean $plus Si true, mise en surveillance privilèges
|
|
* @param string $ref Si $plus=true, référence facultative de la mise en Surveillance
|
|
* @param integer $encours Si $plus=true, encours facultatif Demandé par le client lors de la mise en Surveillance
|
|
* @param string $email Si $plus=true, email facultatif pour le suivi
|
|
* @return Rapport
|
|
*/
|
|
public function getRapport($siren, $niveau=3, $id=0, $plus=false, $ref='', $encours=0, $email='')
|
|
{
|
|
$this->authenticate();
|
|
if (empty($niveau)) $niveau = 3;
|
|
if (empty($id)) $id = 0;
|
|
$result = new Rapport();
|
|
$filtre = 0;
|
|
$idAnn = 0;
|
|
|
|
//@todo : Gestion des droits
|
|
$perm = false;
|
|
switch($niveau){
|
|
case 1: $perms = array('indiscore', 'indiscorep'); break;
|
|
case 2: $perms = array('indiscore2', 'indiscore2p'); break;
|
|
case 3: $perms = array('indiscore3', 'indiscore3p'); break;
|
|
}
|
|
foreach($perms as $item){
|
|
if ( $this->checkPerm($item) ){
|
|
$perm = true;
|
|
break;
|
|
}
|
|
}
|
|
if ($perm === false) {
|
|
$this->sendError('0902');
|
|
}
|
|
|
|
$accesDist=true;
|
|
$nivComment=2;
|
|
if ($niveau==1){
|
|
$result->Indiscore = $this->getIndiScore($siren, 0, $nivComment, $plus, $ref, $encours, $email);
|
|
} elseif ($niveau==2) {
|
|
$result->Identite = $this->getIdentite($siren, $id=0);
|
|
$result->Indiscore = $this->getIndiScore($siren, 0, $nivComment, $plus, $ref, $encours, $email);
|
|
$result->Dirigeants = $this->getDirigeants($siren, false);
|
|
$result->Liens = $this->getLiens($siren, true);
|
|
$result->Ratios = $this->getRatios($siren, $page="rapport$niveau");
|
|
} elseif ($niveau==3) {
|
|
$result->Identite = $this->getIdentite($siren, $id=0);
|
|
$result->Indiscore = $this->getIndiScore($siren, 0, $nivComment, $plus, $ref, $encours, $email);
|
|
$result->Dirigeants = $this->getDirigeants($siren, false);
|
|
$result->Liens = $this->getLiens($siren, true);
|
|
$result->Ratios = $this->getRatios($siren, $page="rapport$niveau");
|
|
$result->Annonces = $this->getAnnonces($siren, $filtre, $idAnn);
|
|
}
|
|
return $result;
|
|
}
|
|
|
|
/**
|
|
* Retourne la liste des banques connues pour une entreprise
|
|
* @param string $siren Siren de l'entreprise
|
|
* @return BanquesReturn
|
|
**/
|
|
public function getBanques($siren)
|
|
{
|
|
$this->authenticate();
|
|
$this->permission('banque');
|
|
|
|
//Initialisation
|
|
$iDb = new WDB();
|
|
$tabRet = array();
|
|
debugLog('I',"Liste des banques demandée pour siren $siren",__LINE__,__FILE__, __FUNCTION__, __CLASS__);
|
|
|
|
if (intval($siren)<=1000) {
|
|
$this->sendError('1010');
|
|
}
|
|
|
|
$res=$iDb->select('sdv1.banques', 'codeBanque, codeGuichet, libBanqueGuichet, precis, dateSource*1 AS dateSource', "siren=$siren", true, MYSQL_ASSOC);
|
|
$tmp=$iDb->select('sdv1.fedRib', "codeBanque, codeGuichet, CONCAT(libBanque,' ',libGuichet) AS libBanqueGuichet, 0 AS precis, IF (dateInfo='0000-00-00', dateDispo*1, dateInfo*1) AS dateSource", "siren=$siren", true, MYSQL_ASSOC);
|
|
$res=array_merge($res, $tmp);
|
|
foreach ($res as $tabBanque)
|
|
{
|
|
$dateSource = $tabBanque['dateSource'];
|
|
$codBanque = $tabBanque['codeBanque'];
|
|
$codGuichet = $tabBanque['codeGuichet'];
|
|
$libBanque = trim($tabBanque['libBanqueGuichet']);
|
|
$found = false;
|
|
$adrBanque1=$adrBanque2=$adrBanqueCP=$adrBanqueVille='';
|
|
|
|
if ( $codBanque>0 && $codGuichet>0 ) {
|
|
$tmp = $iDb->select('insee.BDF_Etabs b, insee.BDF_Guichets g',
|
|
'g.bdfFibCodeEtab AS banque, g.bdfFibCodeGuichet AS guichet, b.bdfFibDenom40 AS nomBanque, b.bdfFibDenom10 AS sigleBanque, g.bdfFibDenom20 AS nomGuichet, g.bdfFibAdresse1 AS adresse1, g.bdfFibAdresse2 AS adresse2, g.bdfFibAdresse3 AS adresse3, g.CP, g.Ville', "g.bdfFibCodeEtab=$codBanque AND g.bdfFibCodeGuichet=$codGuichet AND b.bdfFibCodeEtab=g.bdfFibCodeEtab",
|
|
true, MYSQL_ASSOC);
|
|
if (count($tmp)>0) {
|
|
$found = true;
|
|
|
|
$banque = new Banque();
|
|
$banque->codeBanque = $codBanque;
|
|
$banque->codeGuichet = $codGuichet;
|
|
$banque->libBanque = trim($tmp[0]['nomBanque'].' '.$tmp[0]['nomGuichet']);
|
|
$banque->adresse1 = $tmp[0]['adresse1'];
|
|
$banque->adresse2 = trim($tmp[0]['adresse2'].' '.$tmp[0]['adresse3']);
|
|
$banque->cp = $tmp[0]['CP'];
|
|
$banque->ville = $tmp[0]['Ville'];
|
|
$tabRet[] = $banque;
|
|
}
|
|
}
|
|
|
|
if ($found===false && $codBanque>0 ) {
|
|
$tmp = $iDb->select('insee.BDF_Etabs', "bdfFibCodeEtab AS banque, '' AS guichet, bdfFibDenom40 AS nomBanque, '' AS nomGuichet, '' AS adresse1, '' AS adresse2, '' AS adresse3, '' AS CP, '' AS Ville", "bdfFibCodeEtab=$codBanque", true, MYSQL_ASSOC);
|
|
if (count($tmp)>0) {
|
|
$banque = new Banque();
|
|
$banque->codeBanque = $codBanque;
|
|
$banque->codeGuichet = $codGuichet;
|
|
$banque->libBanque = trim($tmp[0]['nomBanque'].' '.$tmp[0]['nomGuichet']);
|
|
$banque->adresse1 = $tmp[0]['adresse1'];
|
|
$banque->adresse2 = trim($tmp[0]['adresse2'].' '.$tmp[0]['adresse3']);
|
|
$banque->cp = $tmp[0]['CP'];
|
|
$banque->ville = $tmp[0]['Ville'];
|
|
$tabRet[] = $banque;
|
|
}
|
|
}
|
|
|
|
}
|
|
debugLog('I',"Liste des banques pour siren $siren : ".count($tabRet).' banques',__LINE__,__FILE__, __FUNCTION__, __CLASS__);
|
|
|
|
$this->wsLog('banque', $siren);
|
|
$output = new BanquesReturn();
|
|
$output->result = $tabRet;
|
|
return $output;
|
|
}
|
|
|
|
/**
|
|
* Retourne la liste des compétences territoriales pour un établissement à une adresse donnée.
|
|
* @param string $siret Siret de l'établissement
|
|
* @param string $type Type de compétence (pre:prefectures et s/prefectures, jal;journaux d'annonces légales, tri:tribunaux, adm:administrateurs et mandataires judiciaires, hui:huissiers, cfe:centres de formalités des entreprises)
|
|
* @param string $codeInsee Code Insee de la commune de l'établissement
|
|
* @return ListeCompetencesReturn
|
|
*/
|
|
public function getListeCompetences($siret, $type, $codeInsee)
|
|
{
|
|
$this->authenticate();
|
|
$this->permission('competences');
|
|
|
|
//Initialisation
|
|
$error = new ErrorType();
|
|
$type = strtolower($type);
|
|
|
|
debugLog('I',"Liste des compétences $type demandée pour la commune $codeInsee",__LINE__,__FILE__, __FUNCTION__, __CLASS__);
|
|
$tabRet = array();
|
|
$iBodacc = new MBodacc();
|
|
$cp=$codeInsee*1;
|
|
$dep=false;
|
|
if (substr($codeInsee,0,2)=='2A' || substr($codeInsee,0,2)=='2B')
|
|
{
|
|
$dep=20; $cp=20000+(substr($codeInsee,2,3))*1;
|
|
}
|
|
elseif ($cp>0 && $cp<100) $dep=$cp;
|
|
elseif ($cp>970 && $cp<977) $dep=$cp;
|
|
elseif ($cp>999 && $cp<10000) $dep='0'.substr($cp,0,1);
|
|
elseif ($cp>=10000 && $cp<96000) $dep=substr($cp,0,2);
|
|
elseif ($cp>=99000) $dep=substr($cp,0,2);
|
|
elseif ($cp>=98000) $dep=substr($cp,0,3);
|
|
elseif ($cp>=97100 && $cp<97700) $dep=substr($cp,0,3);
|
|
|
|
if ($type=='pre') {
|
|
|
|
$iDb = new WDB();
|
|
$tabTmp2 = $iDb->select('jo.villes', 'DEP, COM, AR, CT', 'codeInsee='.$codeInsee, false, MYSQL_ASSOC);
|
|
$arrond = $tabTmp2[0]['AR'];
|
|
|
|
$tabTmp2 = $iDb->select('insee.insee_tabArrond', 'CHEFLIEU, ARTMAJ, NCC', "DEP='$dep' AND AR='$arrond'", false, MYSQL_ASSOC);
|
|
$nomSousPref = trim(strtr($tabTmp2[0]['ARTMAJ'],array('('=>'',')'=>'',' '=>'', "'"=>'')).' '.$tabTmp2[0]['NCC']);
|
|
|
|
$tabTmp = $iBodacc->getTribunauxParDep($dep);
|
|
|
|
foreach ($tabTmp as $i=>$tribunal)
|
|
{
|
|
if ($tribunal['triType']=='A' || $tribunal['triType']=='B')
|
|
{
|
|
$pref = levenshtein($tribunal['triNom'], 'PREFECTURE DE '.$nomSousPref);
|
|
$spref = levenshtein($tribunal['triNom'], 'SOUS PREFECTURE DE '.$nomSousPref);
|
|
|
|
if ($tribunal['triType']=='B' && ($pref>7 || $spref>5)) continue;
|
|
|
|
$competence = new Competence();
|
|
$competence->Id = $tribunal['triId'];
|
|
$competence->IdSup = $tribunal['triIdSup'];
|
|
$competence->Code = $tribunal['triCode'];
|
|
$competence->Type = $tribunal['triType'].$typeP;
|
|
$competence->Nom = strtoupper($tribunal['triNom']);
|
|
$competence->Siret = $tribunal['triSiret'];
|
|
$competence->Adr = strtoupper(
|
|
preg_replace('/ +/',' ',$tribunal['triAdrNum'].' '.
|
|
$tribunal['triAdrIndRep'].' '.
|
|
$tribunal['triAdrTypeVoie'].' '.
|
|
$tribunal['triAdrVoie']));
|
|
$competence->AdrComp = strtoupper($tribunal['triAdrComp']);
|
|
$competence->CP = $tribunal['triCP'];
|
|
$competence->Ville = strtoupper($tribunal['triVille']);
|
|
$competence->CodeInsee = $tribunal['CodeInsee'];
|
|
$competence->Tel = $tribunal['triTel'];
|
|
$competence->Fax = $tribunal['triFax'];
|
|
$competence->Web = $tribunal['triWeb'];
|
|
$competence->Mail = $tribunal['triMail'];
|
|
$competence->Statut = $tribunal['triStatut'];
|
|
$competence->DateCessation = $tribunal['triDateCessation']; //@todo : date
|
|
$competence->Remarque = $tribunal['triCommentaire'];
|
|
$tabRet[] = $competence;
|
|
|
|
}
|
|
}
|
|
|
|
} elseif ($type=='jal') {
|
|
|
|
$tabTmp = $iBodacc->getJALparDep($dep);
|
|
foreach ($tabTmp as $i=>$comp)
|
|
{
|
|
$infos='';
|
|
if (trim($comp['parution'])<>'') $infos.='Parution '.$comp['parution'].'. ';
|
|
if (trim($comp['aboAnnuel'])>0) $infos.='Abonnement Annuel : '.$comp['aboAnnuel'].' euros. ';
|
|
if (trim($comp['infos'])<>'') $infos.=$comp['infos'];
|
|
|
|
$competence = new Competence();
|
|
$competence->Id = 9000+$comp['id']*1;
|
|
$competence->IdSup = 0;
|
|
$competence->Code = '';
|
|
$competence->Type = '';
|
|
$competence->Nom = strtoupper($comp['nomJal']);
|
|
$competence->Siret = '';
|
|
$competence->Adr = strtoupper($comp['adresse']);
|
|
$competence->AdrComp = '';
|
|
$competence->CP = $comp['cp'];
|
|
$competence->Ville = strtoupper($comp['ville']);
|
|
$competence->CodeInsee = '';
|
|
$competence->Tel = $comp['tel'];
|
|
$competence->Fax = $comp['fax'];
|
|
$competence->Web = $comp['siteWeb'];
|
|
$competence->Mail = $comp['email'];
|
|
$competence->Statut = 'Actif';
|
|
$competence->DateCessation = '';
|
|
$competence->Remarque = trim($infos);
|
|
$tabRet[] = $competence;
|
|
}
|
|
|
|
} elseif ($type=='tri' || $type=='adm' || $type=='hui') {
|
|
|
|
$tabTmp = $iBodacc->getTribunauxParCommune($codeInsee);
|
|
foreach ($tabTmp as $i=>$tribunal)
|
|
{
|
|
if (//$tribunal['triType']=='C' ||
|
|
$tribunal['triType']=='G'// ||
|
|
/*$tribunal['triType']=='I'*/) {
|
|
$idCA = $tribunal['triIdSup'];
|
|
$codeTGI = $tribunal['triCode'];
|
|
$code = strtoupper(substr($tribunal['triCode'],0,3));
|
|
}
|
|
debugLog('D',"Liste des compétences $type demandée pour la commune $codeInsee ($dep) : ".
|
|
"Type=".$tribunal['triType'].', '.
|
|
"Code=".$tribunal[$codeTGI],__LINE__,__FILE__, __FUNCTION__, __CLASS__);
|
|
|
|
if ($tribunal['triType']<>'E' && $tribunal['triType']<>'O' &&
|
|
$tribunal['triType']<>'T' && $tribunal['triType']<>'R' &&
|
|
$tribunal['triType']<>'N' && $tribunal['triType']<>'U' &&
|
|
$tribunal['triType']<>'Z')
|
|
{
|
|
$competence = new Competence();
|
|
$competence->Id = $tribunal['triId'];
|
|
$competence->IdSup = $tribunal['triIdSup'];
|
|
$competence->Code = $tribunal['triCode'];
|
|
$competence->Type = $tribunal['triType'];
|
|
$competence->Nom = strtoupper(Scores_Locale_String::cleanstring($tribunal['triNom']));
|
|
$competence->Siret = $tribunal['triSiret'];
|
|
$competence->Adr = strtoupper(Scores_Locale_String::cleanstring(preg_replace('/ +/',' ',
|
|
$tribunal['triAdrNum'].' '.
|
|
$tribunal['triAdrIndRep'].' '.
|
|
$tribunal['triAdrTypeVoie'].' '.
|
|
$tribunal['triAdrVoie'])));
|
|
$competence->AdrComp = strtoupper($tribunal['triAdrComp']);
|
|
$competence->CP = $tribunal['triCP'];
|
|
$competence->Ville = strtoupper($tribunal['triVille']);
|
|
$competence->CodeInsee = $tribunal['CodeInsee'];
|
|
$competence->Tel = $tribunal['triTel'];
|
|
$competence->Fax = $tribunal['triFax'];
|
|
$competence->Web = $tribunal['triWeb'];
|
|
$competence->Mail = $tribunal['triMail'];
|
|
$competence->Statut = $tribunal['triStatut'];
|
|
$competence->DateCessation = $tribunal['triDateCessation']; //@todo : date
|
|
$competence->Remarque = $tribunal['triCommentaire'];
|
|
if ($tribunal['triNumGreffe']*1>0)
|
|
{
|
|
$competence->IdentifiantGreffe = $tribunal['triNumGreffe'];
|
|
}
|
|
$tabRet[] = $competence;
|
|
}
|
|
}
|
|
}
|
|
|
|
if ($type=='adm')
|
|
{
|
|
$iInsee = new MInsee();
|
|
$tabTmp = $iInsee->getMandataires(array($idCA), false);
|
|
$tabRet = array();
|
|
$nbAff=0;
|
|
foreach ($tabTmp as $i=>$tribunal)
|
|
{ /** @todo A revoir Debut **/
|
|
if (stripos($tribunal['tribunal'], $code)!==false ||
|
|
stripos($tribunal['tribunal'], 'SAINT')!==false)
|
|
{
|
|
$competence = new Competence();
|
|
$competence->Id = $tribunal['id'];
|
|
$competence->IdSup = $tribunal['sirenGrp'];
|
|
$competence->Code = $tribunal['tribunal'].'/'.$code;
|
|
$competence->Type = $tribunal['type'];
|
|
$competence->Nom = $tribunal['Nom'].' '.$tribunal['Prenom'];
|
|
$competence->Siret = $tribunal['sirenMand'];
|
|
$competence->Adr = strtoupper($tribunal['adresse']);
|
|
$competence->AdrComp = strtoupper($tribunal['adresseComp']);
|
|
$competence->CP = $tribunal['cp'];
|
|
$competence->Ville = strtoupper($tribunal['ville']);
|
|
//'CodeInsee'=>$tribunal['CodeInsee'],
|
|
$competence->Tel = $tribunal['tel'];
|
|
$competence->Fax = $tribunal['fax'];
|
|
$competence->Web = $tribunal['web'];
|
|
$competence->Mail = $tribunal['email'];
|
|
$competence->Statut = $tribunal['Statut'];
|
|
//'DateCessation'=>$tribunal['triDateCessation'],
|
|
$competence->Remarque = $tribunal['contact'];
|
|
//,,,,Prenom,,,Statut,,,cp,ville,tel,fax,email,web,contact
|
|
$tabRet[] = $competence;
|
|
$nbAff++;
|
|
}
|
|
}
|
|
if ($nbAff==0)
|
|
{
|
|
foreach ($tabTmp as $i=>$tribunal)
|
|
{
|
|
$competence = new Competence();
|
|
$competence->Id = $tribunal['id'];
|
|
$competence->IdSup = $tribunal['sirenGrp'];
|
|
$competence->Code = $tribunal['tribunal'].'/'.$code;
|
|
$competence->Type = $tribunal['type'];
|
|
$competence->Nom = $tribunal['Nom'].' '.$tribunal['Prenom'];
|
|
$competence->Siret = $tribunal['sirenMand'];
|
|
$competence->Adr = strtoupper($tribunal['adresse']);
|
|
$competence->AdrComp = strtoupper($tribunal['adresseComp']);
|
|
$competence->CP = $tribunal['cp'];
|
|
$competence->Ville = strtoupper($tribunal['ville']);
|
|
//'CodeInsee'=>$tribunal['CodeInsee'],
|
|
$competence->Tel = $tribunal['tel'];
|
|
$competence->Fax = $tribunal['fax'];
|
|
$competence->Web = $tribunal['web'];
|
|
$competence->Mail = $tribunal['email'];
|
|
$competence->Statut = $tribunal['Statut'];
|
|
//'DateCessation'=>$tribunal['triDateCessation'],
|
|
$competence->Remarque = $tribunal['contact'];
|
|
//,,,,Prenom,,,Statut,,,cp,ville,tel,fax,email,web,contact
|
|
$tabRet[] = $competence;
|
|
}
|
|
}/** @todo A revoir Fin : Lier correctement les mandataires à un TI principal **/
|
|
}
|
|
elseif ($type=='hui')
|
|
{
|
|
$iInsee = new MInsee();
|
|
$tabTmp = $iInsee->getHuissiers(array($codeTGI), false);
|
|
|
|
$tabRet = array();
|
|
$nbAff = 0;
|
|
foreach ($tabTmp as $i=>$tribunal)
|
|
{
|
|
$adr = $iInsee->structureVoie($tribunal['adresse']);
|
|
$competence = new Competence();
|
|
$competence->Id = $tribunal['id'];
|
|
$competence->IdSup = $tribunal['sirenGrp'];
|
|
$competence->Code = $tribunal['tribunal'].'/'.$code;
|
|
$competence->Type = $tribunal['type'];
|
|
$competence->Nom = $tribunal['Nom'].' '.$tribunal['Prenom'];
|
|
$competence->Siret = $tribunal['sirenMand'];
|
|
$competence->Adr = strtoupper($adr['num'].' '.$adr['adr_btq'].' '.
|
|
$adr['typeVoie'].' '.$adr['libVoie']);
|
|
$competence->AdrComp = strtoupper($tribunal['adresseComp']);
|
|
$competence->CP = $adr['cp'];
|
|
$competence->Ville = strtoupper($tribunal['ville']);
|
|
//'CodeInsee'=>$tribunal['CodeInsee'],
|
|
$competence->Tel = $tribunal['tel'];
|
|
$competence->Fax = $tribunal['fax'];
|
|
$competence->Web = $tribunal['web'];
|
|
$competence->Mail = $tribunal['email'];
|
|
$competence->Statut = $tribunal['Statut'];
|
|
//'DateCessation'=>$tribunal['triDateCessation'];
|
|
$competence->Remarque = strtr($tribunal['contact'],
|
|
array( '<br/>'=>', ', '<br>'=>', ',
|
|
'<br />'=>', ',
|
|
));
|
|
$tabRet[] = $competence;
|
|
}
|
|
$nbComp = count($tabTmp);
|
|
debugLog('I',"$nbComp compétences $type trouvées pour le tribunal $codeTGI",__LINE__,__FILE__, __FUNCTION__, __CLASS__);
|
|
}
|
|
elseif ($type=='cfe')
|
|
{
|
|
$tabTmp = $iBodacc->getTribunauxParCommune($codeInsee);
|
|
foreach ($tabTmp as $i=>$tribunal)
|
|
{
|
|
if ($tribunal['triType']=='C' || $tribunal['triType']=='O' ||
|
|
$tribunal['triType']=='T' || $tribunal['triType']=='R' ||
|
|
$tribunal['triType']=='N' || $tribunal['triType']=='U' ||
|
|
$tribunal['triType']=='Z')
|
|
{
|
|
if (strlen($tribunal['triCommentaire'])==32 &&
|
|
strpos($tribunal['triCommentaire'], ' ')===false)
|
|
$remarque='';
|
|
else $remarque=$tribunal['triCommentaire'];
|
|
|
|
$competence = new Competence();
|
|
$competence->Id = $tribunal['triId'];
|
|
$competence->IdSup = $tribunal['triIdSup'];
|
|
$competence->Code = $tribunal['triCode'];
|
|
$competence->Type = $tribunal['triType'];
|
|
$competence->Nom = strtoupper($tribunal['triNom']);
|
|
$competence->Siret = $tribunal['triSiret'];
|
|
$competence->Adr = strtoupper(preg_replace('/ +/',' ',$tribunal['triAdrNum'].' '.$tribunal['triAdrIndRep'].' '.
|
|
$tribunal['triAdrTypeVoie'].' '.$tribunal['triAdrVoie']));
|
|
$competence->AdrComp = strtoupper($tribunal['triAdrComp']);
|
|
$competence->CP = $tribunal['triCP'];
|
|
$competence->Ville = strtoupper($tribunal['triVille']);
|
|
$competence->CodeInsee = $tribunal['CodeInsee'];
|
|
$competence->Tel = $tribunal['triTel'];
|
|
$competence->Fax = $tribunal['triFax'];
|
|
$competence->Web = $tribunal['triWeb'];
|
|
$competence->Mail = $tribunal['triMail'];
|
|
$competence->Statut = $tribunal['triStatut'];
|
|
$competence->DateCessation = $tribunal['triDateCessation']; //@todo : date
|
|
$competence->Remarque = $remarque;
|
|
$tabRet[] = $competence;
|
|
}
|
|
}
|
|
}
|
|
$this->wsLog('competences',$siret,$type.'/'.$codeInsee);
|
|
$output = new ListeCompetencesReturn();
|
|
$output->result = $tabRet;
|
|
$output->nbReponses = count($tabRet);
|
|
return $output;
|
|
}
|
|
|
|
/**
|
|
* Liste des subventions
|
|
* @param string $companyId
|
|
* SIREN
|
|
* @param string $type
|
|
* Type de subvention reçues (IN) ou versées (OUT)
|
|
* @param int $offset
|
|
* @param int $nbItems
|
|
* @throws SoapFault
|
|
* @return SubventionList[]
|
|
*/
|
|
public function getSubventionList($companyId, $type = null, $offset = 0, $nbItems = 100)
|
|
{
|
|
$this->authenticate();
|
|
|
|
//Init
|
|
if ( intval($companyId) == 0 ) {
|
|
$this->sendError('1010');
|
|
} elseif ( strlen($companyId)!=9 ) {
|
|
$this->sendError('1020');
|
|
}
|
|
if ( empty($offset) ) { $offset = 0; }
|
|
if ( empty($nbItems) || $nbItems > 100 ) { $nbItems = 100; }
|
|
if ( !empty($type) ) { $type = strtoupper($type); }
|
|
|
|
//SQL
|
|
$listM = new Application_Model_JoAssoSubventions();
|
|
$countsql = $listM->select()->from($listM, array('COUNT(*) AS num'));
|
|
$sql = $listM->select()->from($listM, array(
|
|
'id',
|
|
'millesime', //Annee
|
|
'sirenAsso', //sirenIn
|
|
'nomAsso',
|
|
'sirenOrigine', //sirenOut
|
|
'libOrigine', //Origine
|
|
'libImputation', //Programme
|
|
'mtSubvention', //Montant
|
|
));
|
|
|
|
//Subvention reçues => sirenAsso = companyId
|
|
if ($type == 'IN') {
|
|
$sql->where('sirenAsso=?', $companyId);
|
|
$countsql->where('sirenAsso=?', $companyId);
|
|
}
|
|
//Subvention reçues => sirenOrigine = companyId
|
|
elseif ($type == 'OUT') {
|
|
$sql->where('sirenOrigine=?', $companyId);
|
|
$countsql->where('sirenOrigine=?', $companyId);
|
|
}
|
|
//All
|
|
else {
|
|
$sql->where('sirenAsso=?', $companyId)
|
|
->orWhere('sirenOrigine=?', $companyId);
|
|
$countsql->where('sirenAsso=?', $companyId)
|
|
->orWhere('sirenOrigine=?', $companyId);
|
|
}
|
|
$sql->order('millesime DESC')->limit($nbItems, $offset);
|
|
|
|
$count = $listM->fetchRow($countsql);
|
|
$nbReponsesTotal = 0;
|
|
if ( $count!==null ) {
|
|
$nbReponsesTotal = $count->num;
|
|
}
|
|
|
|
if ( $nbReponsesTotal != 0 ) {
|
|
|
|
$rows = $listM->fetchAll($sql);
|
|
|
|
$output = new SubventionList();
|
|
$output->nbReponsesTotal = $nbReponsesTotal;
|
|
$result = array();
|
|
|
|
if ( $rows !== null ) {
|
|
foreach ( $rows as $row ) {
|
|
|
|
$item = new Subvention();
|
|
$item->Id = $row->id;
|
|
if ( $row->sirenAsso == $companyId ) {
|
|
$item->Type = 'IN';
|
|
} elseif ( $row->sirenOrigine == $companyId ) {
|
|
$item->Type = 'OUT';
|
|
}
|
|
$item->Millesime = $row->millesime;
|
|
$item->AssoSiren = $row->sirenAsso;
|
|
$item->AssoNom = $row->nomAsso;
|
|
$item->OrigineSiren = $row->sirenOrigine;
|
|
$item->OrigineLib = $row->libOrigine;
|
|
$item->Programme = $row->libImputation;
|
|
$item->Montant = $row->mtSubvention;
|
|
|
|
$result[] = $item;
|
|
}
|
|
$output->result = $result;
|
|
$this->wsLog('subventionlist', $companyId);
|
|
}
|
|
|
|
}
|
|
|
|
return $output;
|
|
}
|
|
|
|
/**
|
|
* Détail d'une subvention
|
|
* @param int $id
|
|
* @throws SoapFault
|
|
* @return SubventionDetail
|
|
*/
|
|
public function getSubventionDetail($id)
|
|
{
|
|
$this->authenticate();
|
|
|
|
$subventionM = new Application_Model_JoAssoSubventions();
|
|
$row = $subventionM->find($id);
|
|
|
|
if (null === row) {
|
|
throw new SoapFault('MSG', "Aucun résultat");
|
|
}
|
|
|
|
$data = $row->current();
|
|
|
|
$item = new SubventionDetail();
|
|
$item->Millesime = $data->millesime;
|
|
$item->Budget = $data->typeBudget;
|
|
$item->AssoSiren = $data->sirenAsso;
|
|
$item->AssoNom = $data->nomAsso;
|
|
$item->OrigineSiren = $data->sirenOrigine;
|
|
$item->OrigineLib = $data->libOrigine;
|
|
$item->Programme = $data->libImputation;
|
|
$item->Montant = $data->mtSubvention;
|
|
$item->SubventionObjet = $data->objetSubvention;
|
|
$item->SubventionEval = $data->evalSubvention;
|
|
$item->Mission = $data->mission;
|
|
|
|
$this->wsLog('subventiondetail', $item->AssoSiren, 'id:'.$id);
|
|
|
|
return $item;
|
|
}
|
|
|
|
/**
|
|
* Retourne le statut du webservice
|
|
* @return StatusReturn
|
|
*/
|
|
public function status()
|
|
{
|
|
/* @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
|
|
*/
|
|
|
|
//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']);*/
|
|
|
|
$error = new StatusReturn();
|
|
//Test connexion à la base de données
|
|
$db = new WDB();
|
|
if (!$db) {
|
|
$error->statusCode = 9000;
|
|
$error->statusMsg = $this->listError['9000'];
|
|
} else {
|
|
$error->statusCode = 3000;
|
|
$error->statusMsg = $this->listError['3000'];
|
|
}
|
|
return $error;
|
|
}
|
|
|
|
}
|
|
|
|
?>
|