1223 lines
39 KiB
PHP
1223 lines
39 KiB
PHP
<?php
|
|
class RechercheController extends Zend_Controller_Action
|
|
{
|
|
protected $theme;
|
|
|
|
public function init()
|
|
{
|
|
/** Pour Giant **/
|
|
if(isset($_SESSION['recherche']['giant']))
|
|
unset($_SESSION['recherche']['giant']);
|
|
|
|
require_once 'Scores/WsScores.php';
|
|
|
|
$this->theme = Zend_Registry::get('theme');
|
|
$this->view->inlineScript()->appendFile($this->theme->pathScript.'/recherche.js', 'text/javascript');
|
|
}
|
|
|
|
public function indexAction()
|
|
{
|
|
$this->forward('entreprise');
|
|
}
|
|
|
|
/**
|
|
* Affiche le formulaire de recherche entreprise
|
|
*/
|
|
public function entrepriseAction()
|
|
{
|
|
$request = $this->getRequest();
|
|
$this->view->headTitle()->prepend('Recherche Entreprise');
|
|
$form = new Application_Form_RechercheEntreprise();
|
|
if ( $request->isPost() || $request->isGet() ){
|
|
$form->populate($request->getParams());
|
|
}
|
|
$this->view->assign('message', $request->getParam('message'));
|
|
$this->view->assign('form', $form);
|
|
|
|
$user = new Scores_Utilisateur();
|
|
$this->view->assign('SEARCHENT', $user->checkPerm('SEARCHENT'));
|
|
$this->view->assign('RefClient', $user->checkPref('rechref'));
|
|
}
|
|
|
|
/**
|
|
* Affiche le formulaire de recherche dirigeants
|
|
*/
|
|
public function dirigeantAction()
|
|
{
|
|
$request = $this->getRequest();
|
|
$this->view->headTitle()->prepend('Recherche Dirigeant');
|
|
$form = new Application_Form_RechercheDirigeant();
|
|
if ( $request->isPost() || $request->isGet() ){
|
|
$form->populate($request->getParams());
|
|
}
|
|
$this->view->assign('form', $form);
|
|
}
|
|
|
|
/**
|
|
* Affiche le formulaire de recherche WorldCheck
|
|
*/
|
|
public function worldcheckAction()
|
|
{
|
|
$request = $this->getRequest();
|
|
$this->view->headTitle()->prepend('Recherche WorldCheck');
|
|
$form = new Application_Form_RechercheWorldcheck();
|
|
if ( $request->isPost() || $request->isGet() ){
|
|
$form->populate($request->getParams());
|
|
}
|
|
$this->view->assign('form', $form);
|
|
}
|
|
|
|
/**
|
|
* Affiche le formulaire de recherche actionnaire
|
|
* @todo : style pour les pourcentages
|
|
*/
|
|
public function actionnaireAction()
|
|
{
|
|
$request = $this->getRequest();
|
|
$this->view->headTitle()->append('Recherche Actionnaire');
|
|
$form = new Application_Form_RechercheActionnaire();
|
|
if ( $request->isPost() || $request->isGet() ){
|
|
$form->populate($request->getParams());
|
|
}
|
|
$this->view->assign('form', $form);
|
|
}
|
|
|
|
/**
|
|
* Affiche le formulaire de recherche annonces
|
|
*/
|
|
public function annonceAction()
|
|
{
|
|
$this->view->headTitle()->prepend('Recherche Annonce');
|
|
|
|
$session = new Scores_Session_Recherche();
|
|
$recherche = $session->item(0);
|
|
if ($recherche['type']=='annonce') {
|
|
$params = $recherche['params']['formA'];
|
|
} else {
|
|
$params = array();
|
|
}
|
|
$this->view->assign('recherche', $params);
|
|
}
|
|
|
|
public function annoncelisteAction()
|
|
{
|
|
$request = $this->getRequest();
|
|
$params = $request->getParams();
|
|
$token = $request->getParam('token', null);
|
|
|
|
$session = new Scores_Session_Recherche();
|
|
|
|
if (array_key_exists('formA', $params)) {
|
|
$token = $session->save('annonce', $params);
|
|
} else {
|
|
$recherche = $session->get($token);
|
|
$params = $recherche['params'];
|
|
}
|
|
|
|
if( !isset($params['formA']['annee']) && isset($params['formA']['dateparution']) )
|
|
{
|
|
$dateparution = str_replace('/', '', $dateparution);
|
|
$jj = substring($annee, 0, 2);
|
|
$mm = substring($annee, 2, 2);
|
|
$aa = substring($annee, 4, 4);
|
|
$dateparution = $aa.$mm.$jj;
|
|
}
|
|
|
|
$p = $request->getParam('p', 0);
|
|
|
|
if($params['formA']['histo']!='on')
|
|
{
|
|
$ra = array();
|
|
$ra['dateAnnee'] = $params['formA']['annee'];
|
|
$ra['numParution'] = $params['formA']['nparution'];
|
|
if($params['formA']['source']=='bodacc')
|
|
{
|
|
$ra['source'] = strtoupper('bod'.$params['formA']['bodacc']);
|
|
$ra['numAnnonce'] = $params['formA']['nannonce'];
|
|
}
|
|
elseif($params['formA']['source']=='balo')
|
|
{
|
|
$ra['source'] = strtoupper($params['formA']['source']);
|
|
$ra['numAnnonce'] = $params['formA']['naffaire'];
|
|
}
|
|
elseif($params['source']=='asso')
|
|
{
|
|
$ra['source'] = strtoupper($params['formA']['source']);
|
|
$ra['numAnnonce'] = $params['formA']['nannonce'];
|
|
}
|
|
|
|
$ws = new WsScores();
|
|
$result = $ws->rechercheAnnonce($ra['source'], $ra['dateAnnee'], $ra['numParution'], $ra['numAnnonce']);
|
|
$infos = $result->result->item;
|
|
|
|
$parametresTxt = array(
|
|
'source'=>'Source',
|
|
'annee'=>'Année',
|
|
'dateparution'=>'Date de parution',
|
|
'nparution'=>'Numéro de parution',
|
|
'bpage'=>'Page',
|
|
'nannonce'=>'Numéro d\'annonce',
|
|
'naffaire'=>'Numéro d\'affaire',
|
|
'txt'=>'Recherche');
|
|
$strCriteres = '';
|
|
foreach ($parametresTxt as $key => $param) {
|
|
if($params['formA'][$key]!='' && $param!='') {
|
|
$strCriteres.= $param.' : '.$params['formA'][$key].' ';
|
|
}
|
|
}
|
|
$this->view->assign('criteres', $result->criteres);
|
|
$this->view->assign('infos', $infos);
|
|
|
|
} else {
|
|
|
|
//Suppression des caractères accentués
|
|
$txt = Scores_Locale_String::cleanstring($params['formA']['txt']);
|
|
//Remplacement du caractère § par ~
|
|
$txt = str_replace('$', '~', $txt);
|
|
// Recherche siren tenant compte des anomalies d'OCR
|
|
$txt = preg_replace('/([0-9]{3})([0-9]{3})([0-9]{3})/','"$1$2$3"|"$1 $2$3"|"$1$2 $3"|"$1 $2 $3"', $txt);
|
|
|
|
$ws = new WsScores();
|
|
$result = $ws->rechercheHisto($txt, $params['formA']['annee'], $params['formA']['bodacc'], $p);
|
|
|
|
$infos = $result->reponses->item;
|
|
$mots = $result->mots->item;
|
|
|
|
$annonces = array();
|
|
foreach($infos as $annonce)
|
|
{
|
|
|
|
//Mark all search words in bold
|
|
$texte = $annonce->Texte;
|
|
foreach( $mots as $mot ){
|
|
$texte = preg_replace('/'.$mot.'/i', '<b>'.strtoupper($mot).'</b>', $texte);
|
|
}
|
|
|
|
//Transform Code as a better text
|
|
$code = $annonce->Code;
|
|
if( substr($code,0,3)=='BOD' )
|
|
{
|
|
$code = '<u>BODACC :</u> '.substr($code,3,1);
|
|
}
|
|
|
|
//Change URL to download file
|
|
//$fichier = str_replace("http://wse.scores-decisions.com:8081/fichier/bodacc/q",'',$annonce->Fichier);
|
|
$pos = strrpos($annonce->Fichier, '/q/');
|
|
$host = substr($annonce->Fichier, 0, $pos);
|
|
$fichier = substr($annonce->Fichier, $pos+3);
|
|
|
|
$annonces[] = array (
|
|
'annee' => $annonce->Annee,
|
|
'code' => $code,
|
|
'text' => $texte,
|
|
'file' => $this->view->url(array(
|
|
'controller'=>'telechargement',
|
|
'action'=>'histopdf',
|
|
'q' => $fichier,
|
|
'host' => base64_encode($host)), 'default', true
|
|
),
|
|
);
|
|
}
|
|
$this->view->assign('annonces', $annonces);
|
|
|
|
$parametresTxt = array(
|
|
'source'=>'Source',
|
|
'bodacc'=>'Type',
|
|
'histo'=>'',
|
|
'annee'=>'Année',
|
|
'dateparution'=>'Date de parution',
|
|
'nparution'=>'Numéro de parution',
|
|
'bpage'=>'Page',
|
|
'nannonce'=>'Numéro d\'annonce',
|
|
'naffaire'=>'Numéro d\'affaire',
|
|
'txt'=>'Recherche');
|
|
$strCriteres = '';
|
|
foreach ($parametresTxt as $key => $param) {
|
|
if($params['formA'][$key]!='' && $param!='') {
|
|
$strCriteres.= $param.' : '.$params['formA'][$key].', ';
|
|
}
|
|
}
|
|
}
|
|
|
|
$this->view->assign('p', $p);
|
|
$this->view->assign('token', $token);
|
|
|
|
$user = new Scores_Utilisateur();
|
|
$this->view->assign('userNbReponses', $user->getNbRep());
|
|
|
|
$this->view->assign('nbReponses', $result->nbReponses);
|
|
$this->view->assign('nbReponsesTotal', $result->nbReponsesTotal);
|
|
|
|
$this->view->assign('strCriteres', $strCriteres);
|
|
$this->view->assign('histo', $params['formA']['histo']);
|
|
|
|
}
|
|
|
|
public function internationaleAction(){}
|
|
|
|
public function lastAction()
|
|
{
|
|
$this->view->headTitle()->append('Liste des dernières recherches');
|
|
// @todo : Attention lorsqu'il n'y pas de recherche enregistré
|
|
$rechercheSession = new Scores_Session_Recherche();
|
|
$derniereRecherche = $rechercheSession->item(0);
|
|
$params = array_merge(array('type'=> $derniereRecherche['type']), $derniereRecherche['params']);
|
|
$this->_forward('liste', 'recherche', null, $params);
|
|
}
|
|
|
|
public function listAction()
|
|
{
|
|
$this->view->headTitle()->append('Liste des dernières recherches');
|
|
$rechercheSession = new Scores_Session_Recherche();
|
|
$this->view->assign('historique', $rechercheSession->liste());
|
|
}
|
|
|
|
public function enqueteAction()
|
|
{
|
|
$this->view->headTitle()->append('Enquête');
|
|
|
|
$user = new Scores_Utilisateur();
|
|
if (!$user->checkPerm('INVESTIG')){
|
|
$this->renderScript('error/error-perms.phtml');
|
|
}
|
|
|
|
$form = new Application_Form_RechercheEnquete();
|
|
|
|
$request = $this->getRequest();
|
|
if ($request->isPost() && $form->isValid($request->getParams())) {
|
|
|
|
Zend_Registry::get('firebug')->info($form->getValues());
|
|
|
|
$c = Zend_Registry::get('config');
|
|
$path = realpath($c->profil->path->data).'/log';
|
|
$fp = fopen($path.'/enquetes.csv', 'a');
|
|
fwrite($fp, date('Y/m/d H:i:s').' - '.print_r($form->getValues(),true)."\n");
|
|
fclose($fp);
|
|
$message = "Détail de la demande d'investigation<br/>";
|
|
foreach($form->getValues() as $key => $value) {
|
|
$message.= ucwords($key)." : ".$value."<br/>";
|
|
}
|
|
$message.= "<br/>";
|
|
$message.= "Identité du demandeur<br/>";
|
|
$message.= "Login : ".$user->getLogin()."<br/>";
|
|
$message.= "Email : ".$user->getEmail()."<br/>";
|
|
$message.= "Nom : ".$user->getNom()."<br/>";
|
|
$message.= "Prénom : ".$user->getPrenom()."<br/>";
|
|
$objet = "Demande d'investigation";
|
|
|
|
$mail = new Scores_Mail();
|
|
$mail->setFrom('contact');
|
|
$mail->addToKey('support');
|
|
$mail->setSubject($objet);
|
|
$mail->setBodyHtml($message);
|
|
$mail->send();
|
|
|
|
} else {
|
|
//Affichage formulaire
|
|
$data = array( 'email' => $user->getEmail() );
|
|
if ($request->isPost()){
|
|
$data = $form->getValues();
|
|
}
|
|
$form->populate($data);
|
|
$this->view->assign('form', $form);
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Affiche les résultats d'une recherche
|
|
*/
|
|
public function listeAction()
|
|
{
|
|
$request = $this->getRequest();
|
|
$params = $request->getParams();
|
|
$type = $request->getParam('type', '');
|
|
$token = $request->getParam('token', null);
|
|
$filtre = $request->getParam('filtre', 'tout');
|
|
|
|
//On vérifie que le formulaire ait au moins un des champs rempli
|
|
|
|
$action = 'entreprise';
|
|
switch($type){
|
|
case 'ent':
|
|
$action = 'entreprise';
|
|
$listParams = array('siret', 'raisonSociale', 'numero', 'voie', 'cpVille', 'telFax', 'naf', 'fj');
|
|
break;
|
|
case 'dir':
|
|
$action = 'dirigeant';
|
|
$listParams = array('dirNom', 'dirPrenom', 'dirDateNaissJJ', 'dirDateNaissMM', 'dirDateNaissAAAA', 'dirCpVille');
|
|
break;
|
|
case 'act':
|
|
$action = 'actionnaire';
|
|
$listParams = array('siret', 'actNomRs', 'cpVille', 'pays', 'cpVille', 'pctMin', 'pctMax');
|
|
break;
|
|
case 'wcheck':
|
|
$action = 'worldcheck';
|
|
$listParams = array('dirNom', 'dirPrenom', 'dirType');
|
|
break;
|
|
}
|
|
|
|
$rechercheParams = new Scores_Session_Recherche();
|
|
|
|
//Si le formulaire a été soumis alors on enregistre en session et on redirige
|
|
if ( !empty($type) ) {
|
|
//Vérification si au moins un champs a été saisie
|
|
$nbField = count($listParams);
|
|
foreach($listParams as $key){
|
|
if(!empty($params[$key])){
|
|
$params[$key] = strip_tags($params[$key]);
|
|
} else {
|
|
$nbField--;
|
|
}
|
|
}
|
|
if ($nbField==0){
|
|
$this->_redirect('/recherche/'.$action);
|
|
}
|
|
|
|
//Worldcheck - Vérification si les champs demandés (NOM et TYPE) ont été saisie
|
|
if ($type=='wcheck')
|
|
{
|
|
$required = array('dirNom', 'dirType');
|
|
foreach($required as $item){
|
|
if(empty($params[$item])){
|
|
$this->_redirect('/recherche/worldcheck');
|
|
break;
|
|
}
|
|
}
|
|
}
|
|
|
|
//Redirection
|
|
$token = $rechercheParams->save($type, $params);
|
|
$this->_redirect('recherche/liste/token/'.$token);
|
|
}
|
|
|
|
//On selectionne en session
|
|
if (count($rechercheParams->liste())>0){
|
|
$recherche = $rechercheParams->get($token);
|
|
$type = $recherche['type'];
|
|
$params = $recherche['params'];
|
|
}
|
|
|
|
//Giant
|
|
if( !empty($params['pays']) && $type == 'ent' ){
|
|
Zend_Registry::get('firebug')->info('RECHERCHE GIANT');
|
|
$this->_forward('search', 'giant', null, $params);
|
|
//Worldcheck
|
|
} elseif ($type == 'wcheck' ) {
|
|
$this->_forward('index', 'worldcheck', null, $params);
|
|
//Recherche
|
|
} else {
|
|
|
|
$user = new Scores_Utilisateur();
|
|
$this->view->assign('IDENTITE', $user->checkPerm('IDENTITE'));
|
|
|
|
//Pagination
|
|
$page = $request->getParam('page', 1);
|
|
if ( $page <= 0 ) $page = 1;
|
|
$nbAffichage = $user->getNbRep();
|
|
$position = ($page - 1 ) * $nbAffichage;
|
|
|
|
require_once 'Scores/WsScores.php';
|
|
$ws = new WsScores();
|
|
|
|
//Criteres recherche entreprise
|
|
if ( $type=='ent' ) {
|
|
|
|
// Type de recherche = entreprises
|
|
$telFax = trim(preg_replace('/[^0-9]/', '', $params['telFax']));
|
|
$naf = trim(preg_replace('/[^0-9A-Z]/i', '', $params['naf']));
|
|
|
|
// Traitement des données formulaire
|
|
$raisonSociale = Scores_Locale_String::cleanutf8($params['raisonSociale']);
|
|
$raisonSociale = str_replace(array('(',')', '/'), array('', '', ' '), $raisonSociale);
|
|
|
|
$numVoie = preg_replace('/[^0-9]/', '', $params['numero']);
|
|
if ($numVoie > 9999) {
|
|
$numVoie = '';
|
|
}
|
|
|
|
$libVoie = Scores_Locale_String::cleanutf8($params['voie']);
|
|
$libVoie = str_replace(array('(',')', '/'), array('', '', ' '), $libVoie);
|
|
|
|
$cpVille = Scores_Locale_String::cleanutf8($params['cpVille']);
|
|
$cpVille = str_replace(array('(',')', '/'), array('', '', ' '), $cpVille);
|
|
|
|
|
|
//( (2[A|B]) | [0-9]{2,5} )
|
|
if (preg_match("/^(2[A|B]|[0-9]{2,5})(.*)/i", $cpVille, $matches)) {
|
|
$cp = trim($matches[1]);
|
|
$ville = trim($matches[2]);
|
|
} else {
|
|
$cp = '';
|
|
$ville = trim($cpVille);
|
|
}
|
|
|
|
$criteres = array();
|
|
$criteres['identifiant'] = str_replace(array(' ', '.'), array('',''), trim($params['siret']));
|
|
$criteres['raisonSociale'] = $raisonSociale;
|
|
$criteres['adresse'] = $numVoie.' '.$libVoie;
|
|
$criteres['codePostal']= $cp;
|
|
$criteres['ville'] = $ville;
|
|
$criteres['telFax'] = $telFax;
|
|
$criteres['naf'] = $naf;
|
|
$criteres['siege'] = false;
|
|
$criteres['fj'] = array_key_exists('fj', $params) ? $params['fj'] : '';
|
|
|
|
//Affichage du filtre actif/inactif
|
|
$filtres = array(
|
|
'tout' => array(
|
|
'txt'=>'Afficher tous les résultats',
|
|
'select'=>'',
|
|
'value' => 2,
|
|
),
|
|
'actif' => array(
|
|
'txt'=>'Afficher uniquement les actifs',
|
|
'select'=>'',
|
|
'value' => 1,
|
|
),
|
|
'inactif' => array(
|
|
'txt'=>'Afficher uniquement les inactifs',
|
|
'select'=>'',
|
|
'value' => 0,
|
|
),
|
|
);
|
|
$filtres[$filtre]['select'] = ' selected';
|
|
$this->view->assign('filtres', $filtres);
|
|
|
|
$criteres['actif'] = $filtres[$filtre]['value'];
|
|
|
|
$reponse = $ws->searchEntreprise($criteres, $position);
|
|
|
|
unset($criteres['actif']);
|
|
|
|
$this->view->assign('rechCsv', $user->checkPerm('rechcsv'));
|
|
|
|
//Criteres recherche dirigeants
|
|
} else if ( $type == 'dir' ) {
|
|
|
|
// Type de recherche = dirigeants
|
|
//$dirNom = preg_replace('/[^0-9A-Z]/', ' ', strtoupper($params['dirNom']));
|
|
//$dirPrenom = preg_replace('/[^0-9A-Z]/', ' ', strtoupper($params['dirPrenom']));
|
|
|
|
$dirNom = $params['dirNom'];
|
|
$dirPrenom = $params['dirPrenom'];
|
|
|
|
$dirDateNaissJJ = preg_replace('/[^0-9]/', '', $params['dirDateNaissJJ']);
|
|
if (intval($dirDateNaissJJ)<0 || intval($dirDateNaissJJ>31)){
|
|
//die('Jour de naissance incorrect !');
|
|
}
|
|
$dirDateNaissMM = preg_replace('/[^0-9]/', '', $params['dirDateNaissMM']);
|
|
if (intval($dirDateNaissMM)<0 || intval($dirDateNaissMM>31)){
|
|
//die('Mois de naissance incorrect !');
|
|
}
|
|
$dirDateNaissAAAA = preg_replace('/[^0-9]/', '', $params['dirDateNaissAAAA']);
|
|
$year = date('Y')-18;
|
|
if (intval($dirDateNaissAAAA)<0 || intval($dirDateNaissAAAA)>$year){
|
|
//die('Année de naissance incorrecte !');
|
|
}
|
|
$dirDateNaiss = $dirDateNaissJJ.'/'.$dirDateNaissMM.'/'.$dirDateNaissAAAA;
|
|
if ($dirDateNaiss=='//') $dirDateNaiss = '';
|
|
$dirCpVille = preg_replace('/ +/',' ', preg_replace('/[^0-9A-Z]/', ' ',
|
|
strtoupper($params['dirCpVille']))
|
|
);
|
|
/*
|
|
if (preg_match('/^([0-9]{2,5})([\D]+)/i', $dirCpVille, $matches))
|
|
{
|
|
$dirCp = trim($matches[1]);
|
|
$dirVille = trim($matches[2]);
|
|
}
|
|
else {
|
|
$dirVille = trim($dirCpVille);
|
|
}
|
|
*/
|
|
|
|
$criteres = array();
|
|
$criteres['dirNom'] = $dirNom;
|
|
$criteres['dirPrenom'] = $dirPrenom;
|
|
$criteres['dirDateNaiss'] = $dirDateNaiss;
|
|
$criteres['lieuNaiss'] = $dirCpVille;
|
|
|
|
$reponse = $ws->searchDir($criteres, $position, $user->getNbRep());
|
|
|
|
} elseif ($type == 'act') {
|
|
|
|
$siret = preg_replace('/[^0-9]/', '',$params['siret']);
|
|
$actNomRs = trim($params['actNomRs']);
|
|
$pays = $params['pays'];
|
|
$pctMin = preg_replace('/[^0-9]/', '', trim($params['pctMin']));
|
|
$pctMax = preg_replace('/[^0-9]/', '', trim($params['pctMax']));
|
|
$cpVille = preg_replace('/ +/',' ', preg_replace('/[^0-9A-Z]/', ' ',strtoupper($params['cpVille'])));
|
|
|
|
$criteres = array();
|
|
$criteres['siret'] = $siret;
|
|
$criteres['actNomRs'] = $actNomRs;
|
|
$criteres['pctMin'] = $pctMin;
|
|
$criteres['pctMax'] = $pctMax;
|
|
$criteres['cpVille'] = $cpVille;
|
|
|
|
$reponse = $ws->searchAct($actNomRs, $cpVille, $siret, $pays, $pctMin, $pctMax, $position);
|
|
|
|
}
|
|
|
|
$nbReponses = 0;
|
|
$nbReponsesTotal = 0;
|
|
|
|
if (is_object($reponse) && $reponse !== false)
|
|
{
|
|
$etabs = $reponse->result->item;
|
|
$criteresTexte = '';
|
|
foreach ($criteres as $value){
|
|
if (!empty($value)) $criteresTexte.= $value.' ';
|
|
}
|
|
$criteresTexte = trim($criteresTexte);
|
|
$params['controller'] = 'recherche';
|
|
if ($type=='ent'){
|
|
$params['action'] = 'entreprise';
|
|
} elseif ($type=='dir') {
|
|
$params['action'] = 'dirigeant';
|
|
} elseif ($type=='act'){
|
|
$params['action'] = 'actionnaire';
|
|
}
|
|
foreach ($params as $key => $param) {
|
|
$params[$key] = str_replace('/', ' ', $params[$key]);
|
|
}
|
|
|
|
$criteresLien = $this->view->url($params, 'default', true);
|
|
|
|
$liste = array();
|
|
if (count($etabs)>0) {
|
|
foreach($etabs as $i => $etab) {
|
|
$item = array();
|
|
$item['position'] = ($position)+$i+1;
|
|
$item['id'] = $etab->id;
|
|
$item['siren'] = $etab->Siren;
|
|
$item['siret'] = $etab->Siren.$etab->Nic;
|
|
$item['InfoSiret'] = $etab->Siren.' '.$etab->Nic;
|
|
$item['InfoNom'] = $etab->Nom;
|
|
$item['source'] = $etab->Source;
|
|
$item['sourceId'] = $etab->SourceId;
|
|
|
|
$nomDetail = '';
|
|
if ($etab->Nom2<>'' || $etab->Enseigne<>'' || $etab->Sigle<>'') {
|
|
$nomDetail.= '<i>';
|
|
if ($etab->Nom2!='') $nomDetail.= $etab->Nom2.'<br/>';
|
|
if ($etab->Enseigne<>'') $nomDetail.= 'Enseigne : '.$etab->Enseigne.' ';
|
|
if ($etab->Sigle<>'') $nomDetail.= 'Sigle : '.$etab->Sigle;
|
|
$nomDetail.= '</i><br/>';
|
|
}
|
|
$item['InfoNomDetail'] = $nomDetail;
|
|
$item['InfoSiret'] = substr($etab->Siren,0,3).' '.
|
|
substr($etab->Siren,3,3).' '.
|
|
substr($etab->Siren,6,3).' '.
|
|
$etab->Nic;
|
|
$infoEtab = '';
|
|
|
|
if (null !== $etab->Pays && strtolower($etab->Pays)!='france') {
|
|
$infoEtab.= "Etablissement à l'étranger";
|
|
} else {
|
|
if ($etab->Siege==1){
|
|
$infoEtab.= 'Établissement siège ';
|
|
} elseif ($etab->Siege==2) {
|
|
$infoEtab.= 'Établissement principal ';
|
|
} else {
|
|
$infoEtab.= 'Établissement secondaire ';
|
|
}
|
|
|
|
if ($etab->Actif==1){
|
|
$infoEtab.= 'actif';
|
|
} else {
|
|
$infoEtab.= 'inactif';
|
|
}
|
|
|
|
//Etablissement communiqués par le RCS n'ayant pas de NIC à l'INSEE
|
|
if (intval($etab->Nic)==0 || intval($etab->Nic)>=99990) {
|
|
$infoEtab.=' provisoire';
|
|
}
|
|
|
|
if ($etab->Siege!=1 || ($etab->Siege==1 && $etab->Actif!=1)) {
|
|
$url = $this->view->url(array(
|
|
'controller'=>'identite',
|
|
'action'=>'fiche',
|
|
'id' => $etab->id,
|
|
'siret' => $etab->Siren,
|
|
), 'default', true);
|
|
|
|
if ( $user->checkPerm('IDENTITE') ) {
|
|
$infoEtab.= ' <a title="Voir la fiche d\'identité du siège de cette entreprise"'.
|
|
' href="'.$url.'">(Accès ';
|
|
if ($etab->Siege==1) {
|
|
$infoEtab.= 'dernier ';
|
|
}
|
|
$infoEtab.= 'siège)</a>';
|
|
}
|
|
}
|
|
}
|
|
|
|
$item['InfoEtab'] = $infoEtab;
|
|
|
|
$adresse = $etab->Adresse;
|
|
if ( !empty($etab->Adresse2) ) {
|
|
$adresse.= '<br/>'.$etab->Adresse2;
|
|
}
|
|
if ( !empty($etab->Ville) && intval($etab->CP) > 0) {
|
|
$adresse.= '<br/><b>'.$etab->CP." ".$etab->Ville."</b>";
|
|
}
|
|
if (null !== $etab->Pays) {
|
|
$adresse.= '<br/><b>'.$etab->Pays.'</b>';
|
|
}
|
|
|
|
$item['InfoAdresse'] = $adresse;
|
|
|
|
if ( $etab->Actif!=1 ) {
|
|
$item['class'] = 'StyleInfoData';
|
|
} else {
|
|
$item['class'] = 'StyleInfoDataActif';
|
|
}
|
|
|
|
$forme = '';
|
|
if ( trim($etab->FJ)!='' && intval($etab->FJ)!=0 )
|
|
{
|
|
$forme = '<i>Forme : '.$etab->FJLib.' ('.$etab->FJ.')</i><br/>';
|
|
}
|
|
$item['InfoForme'] = $forme;
|
|
|
|
$activite = '';
|
|
if (trim($etab->NafEnt)!='')
|
|
{
|
|
$activite = '<i>Activité : '.$etab->NafEntLib.' ('.$etab->NafEnt.')</i><br/>';
|
|
}
|
|
$item['InfoActivite'] = $activite;
|
|
|
|
if ( $type == 'dir' ) {
|
|
|
|
$item['InfoDirigeant'] = '<u>Dirigeant recherché :</u> ';
|
|
if ($etab->DirRs!='') {
|
|
$item['InfoDirigeant'].= '<b>'.$etab->DirRs.'</b>, représenté par ';
|
|
}
|
|
$item['InfoDirigeant'].= $etab->DirNom .' '. $etab->DirPrenom;
|
|
if ( $etab->DirNomUsage != '' && $etab->DirNomUsage != $etab->DirNom) {
|
|
$item['InfoDirigeant'].= ' ('. $etab->DirNomUsage . ')';
|
|
}
|
|
$item['InfoDirigeant'].= '<i>, '.$etab->DirFonction.'</i><br/>';
|
|
|
|
} elseif ( $type == 'act' ) {
|
|
|
|
$item['InfoActionnaire'] = '<u>Actionnaire recherché :</u> ';
|
|
if ($etab->ActNomRs<>'') {
|
|
$item['InfoActionnaire'].= '<b>'. $etab->ActNomRs . '</b >';
|
|
if ($etab->ActPays!='' && $etab->ActPays!='FRA')
|
|
$item['InfoActionnaire'].= ' ('.$etab->ActPays.')';
|
|
|
|
$preDate = ', le ';
|
|
if ($etab->ActActif==0){
|
|
$preDate = ', avant le ';
|
|
}
|
|
$date = new Zend_Date($etab->ActDateLien, 'yyyy-MM-dd');
|
|
if ($etab->ActDateLien!='') $item['InfoActionnaire'].= $preDate.$date->toString('dd/MM/yyyy');
|
|
if ($etab->ActPmin!='') {
|
|
if($etab->ActPmin<1){
|
|
$item['InfoActionnaire'].= ', minoritaire ';
|
|
} else {
|
|
$item['InfoActionnaire'].= ', à '.$etab->ActPmin.' %';
|
|
}
|
|
}
|
|
}
|
|
$item['InfoActionnaire'].= '<br/>';
|
|
}
|
|
|
|
//Affichage accès direct aux pages
|
|
$liens = array();
|
|
/**
|
|
* test en dur clients pour bilans
|
|
* @todo client = 34
|
|
* @todo client = 60
|
|
*/
|
|
if ($user->getIdClient()==34 || $user->getIdClient()==60) {
|
|
$liens[] = array(
|
|
'title' => 'Comptes annuels',
|
|
'href' => $this->view->url(array(
|
|
'controller'=>'pieces',
|
|
'action'=>'bilans',
|
|
'siret'=>$etab->Siren.$etab->Nic,
|
|
'id'=>$etab->id), 'default', true),
|
|
);
|
|
$liens[] = array(
|
|
'title' => 'Actes et status',
|
|
'href' => $this->view->url(array(
|
|
'controller'=>'pieces', 'action'=>'actes',
|
|
'siret'=>$etab->Siren.$etab->Nic, 'id'=>$etab->id), 'default', true),
|
|
);
|
|
}
|
|
|
|
/**
|
|
* test en dur clients pour fiche
|
|
* @todo client = 60
|
|
*/
|
|
if ($user->getIdClient()==60) {
|
|
$liens[] = array(
|
|
'title' => 'Fiche AGS',
|
|
'href' => $this->view->url(array(
|
|
'controller'=>'identite', 'action'=>'fichepc',
|
|
'siret'=>$etab->Siren.$etab->Nic, 'id'=>$etab->id), 'default', true),
|
|
);
|
|
}
|
|
if (count($liens)>0) {
|
|
$item['lien'] = $liens;
|
|
}
|
|
|
|
$liste[] = $item;
|
|
}
|
|
}
|
|
|
|
} elseif (is_string($reponse)){
|
|
$this->_forward('entreprise', 'recherche', null, array_merge(
|
|
$params, array('message' => $reponse))
|
|
);
|
|
} else {
|
|
$this->_forward('soap', 'error');
|
|
}
|
|
|
|
$this->view->assign('blockInvestig', $user->checkPerm('INVESTIG'));
|
|
|
|
if ($type=='dir') {
|
|
$this->view->assign('blockDirToEntreprise', true);
|
|
$this->view->assign('searchDirToEntrepriseTxt', trim($criteres['dirNom'].' '.$criteres['dirPrenom']));
|
|
$this->view->assign('searchDirToEntrepriseLien', $this->view->url(array(
|
|
'controller' => 'recherche',
|
|
'action' => 'liste',
|
|
'type' => 'ent',
|
|
'raisonSociale' => trim($criteres['dirNom'].' '.$criteres['dirPrenom'])
|
|
), 'default', true));
|
|
} else {
|
|
$this->view->assign('blockDirToEntreprise', false);
|
|
}
|
|
|
|
$this->view->assign('liste', $liste);
|
|
|
|
//Calcul pagination
|
|
$nbReponses = $reponse->nbReponses;
|
|
$nbReponsesTotal = $reponse->nbReponsesTotal;
|
|
if ($nbReponses < $nbReponsesTotal) {
|
|
$pageTotal = ceil( $nbReponsesTotal / $nbAffichage );
|
|
$pageCurrent = $page;
|
|
$pagePrev = $page - 1;
|
|
if ($pagePrev < 1) {
|
|
$pagePrev = 1;
|
|
}
|
|
$pageNext = $page + 1;
|
|
if( $pageNext > $pageTotal ) {
|
|
$pageNext = $pageTotal;
|
|
}
|
|
} else {
|
|
$pageTotal = $pageCurrent = 1;
|
|
}
|
|
$this->view->assign('PageTotal', $pageTotal);
|
|
$this->view->assign('PagePrev', $pagePrev);
|
|
$this->view->assign('PageNext', $pageNext);
|
|
$this->view->assign('PageCurrent', $pageCurrent);
|
|
|
|
$this->view->assign('nbReponses', empty($nbReponses) ? 0 : $nbReponses);
|
|
$this->view->assign('nbReponsesTotal', empty($nbReponsesTotal) ? 0 : $nbReponsesTotal);
|
|
|
|
$this->view->assign('token', $token);
|
|
|
|
$this->view->assign('criteresTexte', $criteresTexte);
|
|
$this->view->assign('criteresLien', $criteresLien);
|
|
$this->view->assign('info', $reponse->info);
|
|
}
|
|
}
|
|
|
|
public function ipariAction()
|
|
{
|
|
$siret = $this->getRequest()->getParam('siret');
|
|
|
|
$user = new Scores_Utilisateur();
|
|
$url = 'http://ipari.scores-decisions.com/?action=logon&login='.$user->getLogin().
|
|
'&hach='.$user->getPassword().'&pass=';
|
|
if (!empty($siret)){
|
|
$url.= '&siret='.$siret;
|
|
}
|
|
$this->_redirect($url);
|
|
}
|
|
|
|
public function nafAction()
|
|
{
|
|
$this->_helper->layout()->disableLayout();
|
|
|
|
$q = strtolower($this->getRequest()->getParam('q', null));
|
|
$output = array();
|
|
|
|
if ( null !== $q ) {
|
|
$naf = new Application_Model_Naf5();
|
|
$sql = $naf->select('codNaf5, libNaf5');
|
|
if ( is_numeric(substr($q,0,4)) ) {
|
|
$sql->where("codNaf5 LIKE '%".$q."%'");
|
|
} else {
|
|
$queries = explode(' ', $q);
|
|
if (count($queries)>0) {
|
|
$where = '';
|
|
foreach ($queries as $item) {
|
|
if (strlen($item)>2) {
|
|
if (empty($where)) {
|
|
$op = 'LIKE ';
|
|
} else {
|
|
$op = ' OR ';
|
|
}
|
|
$where.= $op.'"%'.strtolower($item).'%"';
|
|
}
|
|
}
|
|
$sql->where("LOWER(libNaf5) ".$where);
|
|
}
|
|
}
|
|
|
|
$rows = $naf->fetchAll($sql);
|
|
if ( count($rows)>0 ) {
|
|
$separator = " , ";
|
|
foreach ($rows as $item) {
|
|
if (strpos(strtolower($item->codNaf5), $q) !== false ||
|
|
strpos(strtolower($item->libNaf5), $q) !== false ) {
|
|
$output[] = array(
|
|
'label' => $item->codNaf5 . $separator . $item->libNaf5,
|
|
'value' => $item->codNaf5,
|
|
);
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
$this->view->assign('output', $output);
|
|
}
|
|
|
|
public function fjAction()
|
|
{
|
|
$this->_helper->layout()->disableLayout();
|
|
|
|
$q = strtolower($this->getRequest()->getParam('q', null));
|
|
$output = array();
|
|
|
|
if ( null !== $q ) {
|
|
$table = new Application_Model_TabFJur();
|
|
$sql = $table->select('code, libelle');
|
|
$sql->where('LENGTH(code)=4');
|
|
if ( is_numeric(substr($q,0,4)) ) {
|
|
$sql->where("code LIKE '%".$q."%'");
|
|
} else {
|
|
$queries = explode(' ', $q);
|
|
if (count($queries)>0) {
|
|
$where = '';
|
|
foreach ($queries as $item) {
|
|
if (strlen($item)>2) {
|
|
if (empty($where)) {
|
|
$op = 'LIKE ';
|
|
} else {
|
|
$op = ' OR ';
|
|
}
|
|
$where.= $op.'"%'.strtolower($item).'%"';
|
|
}
|
|
}
|
|
$sql->where("LOWER(libelle) ".$where);
|
|
}
|
|
}
|
|
Zend_Registry::get('firebug')->info($where);
|
|
|
|
$rows = $table->fetchAll($sql);
|
|
if ( count($rows)>0 ) {
|
|
$separator = " , ";
|
|
foreach ($rows as $item) {
|
|
$output[] = array(
|
|
'label' => $item->code . $separator . $item->libelle,
|
|
'value' => $item->code,
|
|
);
|
|
}
|
|
}
|
|
}
|
|
|
|
$this->view->assign('output', $output);
|
|
}
|
|
|
|
|
|
public function refclientAction()
|
|
{
|
|
|
|
}
|
|
|
|
public function refclientlisteAction()
|
|
{
|
|
$request = $this->getRequest();
|
|
$params = $request->getParams();
|
|
$type = $request->getParam('type', '');
|
|
|
|
$rechercheParams = new Scores_Session_Recherche();
|
|
|
|
//Si le formulaire a été soumis alors on enregistre en session et on redirige
|
|
if ( !empty($type) ) {
|
|
$rechercheParams->save($type, $params);
|
|
}
|
|
|
|
//On selectionne en session
|
|
if (count($rechercheParams->liste())>0){
|
|
$recherche = $rechercheParams->item(0);
|
|
$type = $recherche['type'];
|
|
$params = $recherche['params'];
|
|
}
|
|
|
|
$user = new Scores_Utilisateur();
|
|
|
|
$this->view->assign('login', $user->getLogin());
|
|
|
|
$page = $request->getParam('page', 1);
|
|
if ($page==0) $page = 1;
|
|
$page = $page-1;
|
|
$position = $page*$user->getNbRep();
|
|
|
|
$nbReponses = 0;
|
|
$nbReponsesTotal = 0;
|
|
$liste = array();
|
|
|
|
$ws = new WsScores();
|
|
$reponses = $ws->searchRefClient($params['ref'], $position, $user->getNbRep());
|
|
if ($reponses !== false){
|
|
$nbReponses = $reponses->nbReponses;
|
|
$nbReponsesTotal = $reponses->nbReponsesTotal;
|
|
$etabs = $reponses->result->item;
|
|
|
|
if (count($etabs)>0) {
|
|
foreach($etabs as $i => $etab) {
|
|
$item = array();
|
|
$item['position'] = ($position)+$i+1;
|
|
$item['id'] = $etab->id;
|
|
$item['siren'] = $etab->Siren;
|
|
$item['siret'] = $etab->Siren.$etab->Nic;
|
|
$item['InfoSiret'] = $etab->Siren.' '.$etab->Nic;
|
|
$item['InfoNom'] = $etab->Nom;
|
|
|
|
$nomDetail = '';
|
|
if ($etab->Nom2<>'' || $etab->Enseigne<>'' || $etab->Sigle<>'') {
|
|
$nomDetail.= '<i>';
|
|
if ($etab->Nom2!='') $nomDetail.= $etab->Nom2.'<br/>';
|
|
if ($etab->Enseigne<>'') $nomDetail.= 'Enseigne : '.$etab->Enseigne.' ';
|
|
if ($etab->Sigle<>'') $nomDetail.= 'Sigle : '.$etab->Sigle;
|
|
$nomDetail.= '</i><br/>';
|
|
}
|
|
$item['InfoNomDetail'] = $nomDetail;
|
|
$item['InfoSiret'] = substr($etab->Siren,0,3).' '.
|
|
substr($etab->Siren,3,3).' '.
|
|
substr($etab->Siren,6,3).' '.
|
|
$etab->Nic;
|
|
$infoEtab = '';
|
|
if ($etab->Siege==1){
|
|
$infoEtab.= 'Établissement siège ';
|
|
} else {
|
|
$infoEtab.= 'Établissement secondaire ';
|
|
}
|
|
if ($etab->Actif==1){
|
|
$infoEtab.= 'actif';
|
|
} else {
|
|
$infoEtab.= 'inactif';
|
|
}
|
|
if (intval($etab->Nic)==0 || intval($item->Nic)>=99990) {
|
|
$infoEtab.=' provisoire';
|
|
}
|
|
|
|
if ($etab->Siege!=1 || ($etab->Siege==1 && $etab->Actif!=1)) {
|
|
$url = $this->view->url(array(
|
|
'controller'=>'identite',
|
|
'action'=>'fiche',
|
|
'id' => $etab->id,
|
|
'siret' => $etab->Siren,
|
|
), 'default', true);
|
|
$infoEtab.= ' <a title="Voir la fiche d\'identité du siège de cette entreprise"'.
|
|
' href="'.$url.'">(Accès siège)</a>';
|
|
}
|
|
$item['InfoEtab'] = $infoEtab;
|
|
|
|
$adresse = $etab->Adresse.'<br/>';
|
|
if (isset($etab->Adresse2) && $etab->Adresse2 != '') {
|
|
$adresse.= $etab->Adresse2.'<br/>';
|
|
}
|
|
$adresse.= "<b>".$etab->CP." ".$etab->Ville."</b>";
|
|
$item['InfoAdresse'] = $adresse;
|
|
|
|
|
|
$forme = '';
|
|
if (trim($etab->FJ)!='')
|
|
{
|
|
$forme = '<i>Forme : '.$etab->FJLib.' ('.$etab->FJ.')</i><br/>';
|
|
}
|
|
$item['InfoForme'] = $forme;
|
|
|
|
$activite = '';
|
|
if (trim($etab->NafEnt)!='')
|
|
{
|
|
$activite = '<i>Activité : '.$etab->NafEntLib.' ('.$etab->NafEnt.')</i><br/>';
|
|
}
|
|
$item['InfoActivite'] = $activite;
|
|
|
|
$item['login'] = $etab->Infos->login;
|
|
$item['email'] = $etab->Infos->email;
|
|
$item['source'] = $etab->Infos->source;
|
|
$item['ref'] = $etab->Infos->ref;
|
|
|
|
$date = new Zend_Date($etab->Infos->dateAjout, 'yyyy-MM-dd');
|
|
$item['dateAjout'] = $date->toString('dd/MM/yyyy');
|
|
if ( $etab->Infos->dateEnvoi!='0000-00-00' ) {
|
|
$date = new Zend_Date($etab->Infos->dateEnvoi, 'yyyy-MM-dd');
|
|
$item['dateEnvoi'] = $date->toString('dd/MM/yyyy');
|
|
} else {
|
|
$item['dateEnvoi'] = '';
|
|
}
|
|
|
|
$liste[] = $item;
|
|
}
|
|
}
|
|
|
|
}
|
|
|
|
if ($nbReponses < $nbReponsesTotal) {
|
|
$totPage = ceil($nbReponsesTotal/$user->getNbRep());
|
|
$curPage = $page+1;
|
|
} else {
|
|
$totPage = $curPage = 1;
|
|
}
|
|
|
|
$this->view->assign('nbReponses', $nbReponses);
|
|
$this->view->assign('nbReponsesTotal', $nbReponsesTotal);
|
|
$this->view->assign('totPage', $totPage);
|
|
$this->view->assign('curPage', $curPage);
|
|
$this->view->assign('liste', $liste);
|
|
}
|
|
|
|
public function csvAction()
|
|
{
|
|
$this->_helper->layout()->disableLayout();
|
|
$this->_helper->viewRenderer->setNoRender(true);
|
|
|
|
$rechercheParams = new Scores_Session_Recherche();
|
|
//On selectionne en session
|
|
if (count($rechercheParams->liste())>0){
|
|
$recherche = $rechercheParams->item(0);
|
|
$type = $recherche['type'];
|
|
$params = $recherche['params'];
|
|
}
|
|
|
|
require_once 'Scores/WsScores.php';
|
|
$ws = new WsScores();
|
|
|
|
//Criteres recherche entreprise
|
|
if ($type=='ent'){
|
|
|
|
// Type de recherche = entreprises
|
|
$telFax = trim(preg_replace('/[^0-9]/', '', $params['telFax']));
|
|
$naf = trim(preg_replace('/[^0-9A-Z]/i', '', $params['naf']));
|
|
|
|
// Traitement des données formulaire
|
|
//$raisonSociale = preg_replace('/[^0-9A-Z]/', ' ', strtoupper($params['raisonSociale']));
|
|
$raisonSociale = str_replace(array('(',')'), array('', ''), $params['raisonSociale']);
|
|
|
|
$numVoie = preg_replace('/[^0-9]/', '', $params['numero']);
|
|
if ($numVoie > 9999) {
|
|
die('Numéro de voie incorrecte !');
|
|
}
|
|
|
|
$libVoie = Scores_Locale_String::cleanutf8($params['voie']);
|
|
$cpVille = Scores_Locale_String::cleanutf8($params['cpVille']);
|
|
|
|
if (preg_match("/^([0-9]{2,5})([\D]*)/i", $cpVille, $matches)) {
|
|
$cp = trim($matches[1]);
|
|
$ville = trim($matches[2]);
|
|
} else {
|
|
$cp = '';
|
|
$ville = trim($cpVille);
|
|
}
|
|
|
|
$criteres = array();
|
|
$criteres['identifiant'] = str_replace(' ', '', $params['siret']);
|
|
$criteres['raisonSociale'] = $raisonSociale;
|
|
$criteres['adresse'] = $numVoie.' '.$libVoie;
|
|
$criteres['codePostal']= $cp;
|
|
$criteres['ville'] = $ville;
|
|
$criteres['telFax'] = $telFax;
|
|
$criteres['naf'] = $naf;
|
|
$criteres['siege'] = false;
|
|
$criteres['fj'] = $fj;
|
|
|
|
$request = $this->getRequest();
|
|
$filtre = $request->getParam('filtre', 'tout');
|
|
|
|
//Affichage du filtre actif/inactif
|
|
$filtres = array(
|
|
'tout' => array(
|
|
'txt'=>'Afficher tous les résultats',
|
|
'select'=>'',
|
|
'value' => 2,
|
|
),
|
|
'actif' => array(
|
|
'txt'=>'Afficher uniquement les actifs',
|
|
'select'=>'',
|
|
'value' => 1,
|
|
),
|
|
'inactif' => array(
|
|
'txt'=>'Afficher uniquement les inactifs',
|
|
'select'=>'',
|
|
'value' => 0,
|
|
),
|
|
);
|
|
$criteres['actif'] = $filtres[$filtre]['value'];
|
|
|
|
$reponse = $ws->searchEntreprise($criteres, 0, 200);
|
|
|
|
//Criteres recherche dirigeants
|
|
} else if ($type=='dir') {
|
|
|
|
// Type de recherche = dirigeants
|
|
$dirNom = preg_replace('/[^0-9A-Z]/', ' ', strtoupper($params['dirNom']));
|
|
$dirPrenom = preg_replace('/[^0-9A-Z]/', ' ', strtoupper($params['dirPrenom']));
|
|
$dirDateNaissJJ = preg_replace('/[^0-9]/', '', $params['dirDateNaissJJ']);
|
|
$dirDateNaissMM = preg_replace('/[^0-9]/', '', $params['dirDateNaissMM']);
|
|
$dirDateNaissAAAA = preg_replace('/[^0-9]/', '', $params['dirDateNaissAAAA']);
|
|
$year = date('Y')-18;
|
|
$dirDateNaiss = $dirDateNaissJJ.'/'.$dirDateNaissMM.'/'.$dirDateNaissAAAA;
|
|
if ($dirDateNaiss=='//') $dirDateNaiss = '';
|
|
$dirCpVille = preg_replace('/ +/',' ', preg_replace('/[^0-9A-Z]/', ' ',
|
|
strtoupper($params['dirCpVille']))
|
|
);
|
|
|
|
$criteres = array();
|
|
$criteres['dirNom'] = $dirNom;
|
|
$criteres['dirPrenom'] = $dirPrenom;
|
|
$criteres['dirDateNaiss'] = $dirDateNaiss;
|
|
$criteres['lieuNaiss'] = $dirCpVille;
|
|
|
|
$reponse = $ws->searchDir($criteres, $position);
|
|
}
|
|
|
|
$etabs = $reponse->result->item;
|
|
|
|
$user = new Scores_Utilisateur();
|
|
//echo "<pre>"; print_r($etabs); echo "</pre>"; exit;
|
|
|
|
$c = Zend_Registry::get('config');
|
|
$file = $c->profil->path->files . '/'.$user->getIdClient().'-'.$user->getLogin().'-'.date('YmdHis').'.csv';
|
|
|
|
$export = new Scores_Export_ArrayCsv($etabs, 'rechercheEntreprise');
|
|
$export->writeFile($file);
|
|
|
|
$content_type = 'application/csv-tab-delimited-table';
|
|
|
|
//Envoi du fichier sur la sortie standard
|
|
if ( file_exists($file) ) {
|
|
header('Content-Transfer-Encoding: none');
|
|
header('Content-type: ' . $content_type.'');
|
|
header('Content-Length: ' . filesize($file));
|
|
header('Content-MD5: ' . base64_encode(md5_file($file)));
|
|
header('Content-Disposition: filename="' . basename($file) . '"');
|
|
header('Cache-Control: private, max-age=0, must-revalidate');
|
|
header('Pragma: public');
|
|
ini_set('zlib.output_compression', '0');
|
|
echo file_get_contents($file);
|
|
} else {
|
|
echo 'Impossible de charger le fichier.';
|
|
}
|
|
|
|
}
|
|
|
|
} |