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', ''.strtoupper($mot).'', $texte); } //Transform Code as a better text $code = $annonce->Code; if( substr($code,0,3)=='BOD' ) { $code = 'BODACC : '.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
"; foreach($form->getValues() as $key => $value) { $message.= ucwords($key)." : ".$value."
"; } $message.= "
"; $message.= "Identité du demandeur
"; $message.= "Login : ".$user->getLogin()."
"; $message.= "Email : ".$user->getEmail()."
"; $message.= "Nom : ".$user->getNom()."
"; $message.= "Prénom : ".$user->getPrenom()."
"; $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.= ''; if ($etab->Nom2!='') $nomDetail.= $etab->Nom2.'
'; if ($etab->Enseigne<>'') $nomDetail.= 'Enseigne : '.$etab->Enseigne.'    '; if ($etab->Sigle<>'') $nomDetail.= 'Sigle : '.$etab->Sigle; $nomDetail.= '

'; } $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.= ' (Accès '; if ($etab->Siege==1) { $infoEtab.= 'dernier '; } $infoEtab.= 'siège)'; } } } $item['InfoEtab'] = $infoEtab; $adresse = $etab->Adresse; if ( !empty($etab->Adresse2) ) { $adresse.= '
'.$etab->Adresse2; } if ( !empty($etab->Ville) && intval($etab->CP) > 0) { $adresse.= '
'.$etab->CP." ".$etab->Ville.""; } if (null !== $etab->Pays) { $adresse.= '
'.$etab->Pays.''; } $item['InfoAdresse'] = $adresse; if ( $etab->Actif!=1 ) { $item['class'] = 'StyleInfoData'; } else { $item['class'] = 'StyleInfoDataActif'; } $forme = ''; if ( trim($etab->FJ)!='' && intval($etab->FJ)!=0 ) { $forme = 'Forme : '.$etab->FJLib.' ('.$etab->FJ.')
'; } $item['InfoForme'] = $forme; $activite = ''; if (trim($etab->NafEnt)!='') { $activite = 'Activité : '.$etab->NafEntLib.' ('.$etab->NafEnt.')
'; } $item['InfoActivite'] = $activite; if ( $type == 'dir' ) { $item['InfoDirigeant'] = 'Dirigeant recherché : '; if ($etab->DirRs!='') { $item['InfoDirigeant'].= ''.$etab->DirRs.', représenté par '; } $item['InfoDirigeant'].= $etab->DirNom .' '. $etab->DirPrenom; if ( $etab->DirNomUsage != '' && $etab->DirNomUsage != $etab->DirNom) { $item['InfoDirigeant'].= ' ('. $etab->DirNomUsage . ')'; } $item['InfoDirigeant'].= ', '.$etab->DirFonction.'
'; } elseif ( $type == 'act' ) { $item['InfoActionnaire'] = 'Actionnaire recherché : '; if ($etab->ActNomRs<>'') { $item['InfoActionnaire'].= ''. $etab->ActNomRs . ''; 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'].= '
'; } //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.= ''; if ($etab->Nom2!='') $nomDetail.= $etab->Nom2.'
'; if ($etab->Enseigne<>'') $nomDetail.= 'Enseigne : '.$etab->Enseigne.'    '; if ($etab->Sigle<>'') $nomDetail.= 'Sigle : '.$etab->Sigle; $nomDetail.= '

'; } $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.= ' (Accès siège)'; } $item['InfoEtab'] = $infoEtab; $adresse = $etab->Adresse.'
'; if (isset($etab->Adresse2) && $etab->Adresse2 != '') { $adresse.= $etab->Adresse2.'
'; } $adresse.= "".$etab->CP." ".$etab->Ville.""; $item['InfoAdresse'] = $adresse; $forme = ''; if (trim($etab->FJ)!='') { $forme = 'Forme : '.$etab->FJLib.' ('.$etab->FJ.')
'; } $item['InfoForme'] = $forme; $activite = ''; if (trim($etab->NafEnt)!='') { $activite = 'Activité : '.$etab->NafEntLib.' ('.$etab->NafEnt.')
'; } $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 "
"; print_r($etabs); echo "
"; 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.'; } } }