extranet/application/controllers/SurveillanceController.php
2012-02-05 15:09:51 +00:00

1036 lines
33 KiB
PHP

<?php
class SurveillanceController extends Zend_Controller_Action
{
/**
* Association source => texte
* @var array
*/
protected $sourceTxt = array(
'annonces' => 'Annonces',
'insee' => 'Insee',
'bilans' => 'Bilans',
'score' => 'IndiScore',
'actes' => 'Actes',
'dirigeants' => 'Dirigeants',
'privileges' => 'Privilèges',
);
/**
* Association source => droits
* @var array
*/
protected $sourceDroit = array(
'annonces' => 'survannonce',
'insee' => 'survinsee',
'bilans' => 'survbilan',
'score' => 'survscore',
'actes' => 'survactes',
'dirigeants' => 'survdirigeants',
'privileges' => 'survpriv',
);
public function init()
{
require_once 'Scores/Utilisateur.php';
require_once 'Scores/WsScores.php';
require_once 'common/dates.php';
}
public function indexAction()
{
//What we want to do here
}
/**
* Ajouter une surveillance
*/
public function ajouterAction()
{
//Affichage formulaire demande ref et email
$this->_helper->layout->disableLayout();
$request = $this->getRequest();
$siret = $request->getParam('siret', '');
$email = $request->getParam('email', '');
$ref = $request->getParam('ref', '');
$source = $request->getParam('source', '');
$encours = $request->getParam('encours', 0);
$user = new Utilisateur();
$email = $user->getEmail();
if( empty($source) ) {
$source = array();
foreach($this->sourceTxt as $Source => $Txt) {
if( $user->checkPerm($this->sourceDroit[$Source]) ) {
$checked = 'checked';
if ($Source=='privileges') {
$checked = '';
}
$source[] = array(
'id' => $Source,
'txt' => $Txt,
'checked' => $checked,
);
}
}
}
$this->view->assign('source', $source);
$this->view->assign('siret', $siret);
$this->view->assign('email', $email);
$this->view->assign('ref', $ref);
$this->view->assign('encours', $encours);
}
public function demanderefAction()
{
$this->_helper->layout->disableLayout();
$user = new Utilisateur();
$email = $user->getEmail();
$this->view->assign('email', $email);
}
/**
* Supprimer une surveillances
*/
public function supprimerAction()
{
$this->_helper->layout->disableLayout();
$request = $this->getRequest();
$page = $request->getParam('page');
$from = $request->getParam('from');
$siret = $request->getParam('siret', '');
$email = $request->getParam('email', '');
$ref = $request->getParam('ref', '');
$source = $request->getParam('source', 'annonces');
$ws = new WsScores();
$set = $ws->setSurveillance($siret, $email, $ref, $source, true);
if (isset($from)) {
$this->_helper->viewRenderer->setNoRender(true);
if ( $set->result ) {
echo "Surveillance supprimé";
} else {
echo "Erreur lors de la suppression";
}
} elseif (isset($page)) {
$this->_redirect('surveillance/liste/page/'.$page);
} else {
$this->_redirect('surveillance/liste');
}
}
/**
* Ajoute, Supprime, Edite la surveillance (Ajax)
*/
public function setAction()
{
$this->_helper->layout->disableLayout();
$request = $this->getRequest();
$siret = $request->getParam('siret', '');
$email = $request->getParam('email', '');
$ref = $request->getParam('ref', '');
$source = $request->getParam('source', 'annonces');
$delete = $request->getParam('delete', false);
$encours = $request->getParam('encours', 0);
//Vérification siret / email / ref
if (empty($siret) || empty($email) | empty($ref)){
$msg = 'Erreur email ou reférence non définie !';
//Vérification de l'encours (chiffres)
} elseif (!preg_match('/([0-9]+)/', $encours)){
$msg = 'Encours incorrect';
} else {
if (!empty($delete)){
$delete = true;
}
$ws = new WsScores();
if (is_array($source)) {
foreach($source as $s) {
$msg = '';
$set = $ws->setSurveillance($siret, $email, $ref, $s, $delete, $encours);
if ($set) {
$msg.= "Mise sous surveillance $s";
} else {
$msg.= "Erreur lors de la mise sous surveillance $s";
}
$msg.= "<br/>";
}
} else {
$set = $ws->setSurveillance($siret, $email, $ref, $source, $delete, $encours);
if ($set) {
if ($delete) { $msg = "Suppression surveillance $source"; }
else { $msg = "Mise sous surveillance $source"; }
} else {
if ($delete) { $msg = "Erreur lors de la suppression de la surveillance $source"; }
else { $msg = "Erreur lors de la mise sous surveillance $source"; }
}
}
}
$this->view->assign('msg', $msg);
}
/**
* Ajoute un encours client
*/
public function encoursAction()
{
$this->_helper->layout->disableLayout();
$this->_forward('ajouter', 'surveillance', null, array( 'source' => 'score' ));
}
/**
* Affiche les infos d'une surveillance
*/
public function infosAction()
{
$this->view->headScript()->appendFile('/themes/default/scripts/surveillance.js', 'text/javascript');
$request = $this->getRequest();
$source = $request->getParam('source', '');
$siret = $request->getParam('siret', 0);
$user = new Utilisateur();
//if ($user->checkPerm())
$listSurv = array();
if (intval($siret)!=0)
{
$ws = new WsScores();
$infos = $ws->getSurveillances('siren', $source, $siret);
$surveillances = $infos->result->item;
if (count($surveillances)>0) {
$titre = 'Ajouter une surveillance';
$texte = "L'entité est sous surveillance";
foreach($surveillances as $surv){
$tooltipTexte = '';
$ref = $surv->ref;
$tooltipTexte.= "Ref : ".$ref;
$tooltipTexte.= "<br/>Date d'ajout :".WDate::dateT('Y-m-d', 'd/m/Y', $surv->dateAjout);
if ($surv->dateDerEnvoi!='0000-00-00 00:00:00') {
$tooltipTexte.= "<br/>Date de dernier envoi : ".
WDate::dateT('Y-m-d', 'd/m/Y', substr($surv->dateDerEnvoi,0,10));
}
$listSurv[] = array(
'tooltipTexte' => $tooltipTexte,
'sourceTexte' => $this->sourceTxt[$surv->source]
);
}
} else {
$titre = 'Ajouter une surveillance';
$texte = 'Mettre sous surveillance';
if (!empty($source)){
$texte.= ' '.$this->sourceTxt[$source];
}
}
}
if (!empty($ref)) {
$this->view->assign('ref', $ref);
} else {
$this->view->assign('ref', $ref);
}
$this->view->assign('surveillances', $listSurv);
$this->view->assign('dialogTitre', $titre);
$this->view->assign('dialogTexte', $texte);
$this->view->assign('dialogSource', $source);
}
/**
* Liste les surveillances
*/
public function listeAction()
{
$user = new Utilisateur();
if (!$user->checkPerm('survliste')){
$this->_forward('perms', 'error');
}
$this->view->headLink()
->appendStylesheet('/themes/default/styles/surveillance.css', 'all');
$this->view->headScript()
->appendFile('/themes/default/scripts/jquery.tablesorter.js', 'text/javascript')
->appendFile('/themes/default/scripts/surveillance.js', 'text/javascript');
$request = $this->getRequest();
$page = $request->getParam('page', 0);
$source = $request->getParam('source', '');
$tri = $request->getParam('tri', 'siren');
$detail = true;
$nbAffichage = 100;
$position = $page*$nbAffichage;
switch($tri){
default:
case 'siren': $triws = 'siren'; break;
case 'rs': $triws = 'rs'; break;
case 'reference': $triws = 'ref'; break;
case 'dateajout': $triws = 'dateAjout'; break;
case 'datederenvoi': $triws = 'dateDerEnvoi'; break;
}
// Source => Permission
$tabSource = array(
'annonces' => 'annonce',
'insee' => 'insee',
'bilans' => 'bilan',
'score' => 'score',
'actes' => 'actes',
'dirigeants' => 'dirigeants',
'privileges' => 'priv',
);
$user = new Utilisateur();
//Select Tri + Liste des sources autorisée
$selectTri = '';
$permSource = array();
foreach ($tabSource as $s => $perm) {
if ($user->checkPerm('surv'.$perm)) {
$permSource[] = $s;
$selectTri.= '<option value="'.$s.'"';
if ($source == $s) {
$selectTri.= 'selected';
}
$selectTri.= '>'.$s.'</option>';
}
}
$ws = new WsScores();
$infos = $ws->getSurveillances($tri, $source, '', $detail, $position);
$surveillances = $infos->result->item;
//Tri si nécessaire
if (empty($source)){
$i=0;
$tabIndex = array();
$listTrier = array();
if (count($surveillances)>0) {
foreach($surveillances as $item) {
if(!array_key_exists($item->siren, $tabIndex)) {
//Création du tableau trier
$listTrier[$i]['siren'] = $item->siren;
$listTrier[$i]['nic'] = $item->nic;
$listTrier[$i]['rs'] = $item->rs;
$listTrier[$i]['cp'] = $item->cp;
$listTrier[$i]['ville'] = $item->ville;
$listTrier[$i]['sources'][$item->source][0] = array(
'email' => $item->email,
'ref' => $item->ref,
'dateAjout' => $item->dateAjout,
'dateDerEnvoi' => $item->dateDerEnvoi,
);
//Tableau d'index
$tabIndex[$item->siren] = $i;
} else {
$key = $tabIndex[$item->siren];
$triSource = array(
'email' => $item->email,
'ref' => $item->ref,
'dateAjout' => $item->dateAjout,
'dateDerEnvoi'=> $item->dateDerEnvoi,
);
if ( array_key_exists( $item->source, $listTrier[$key]['sources'] ) ){
$nbSource = count($listTrier[$key]['sources'][$item->source]);
}else{
$nbSource = 0;
}
$listTrier[$key]['sources'][$item->source][$nbSource] = $triSource;
}
$i++;
}
}
} else {
$permSource = array();
$permSource[] = $source;
$listTrier = array();
if (count($surveillances)>0) {
foreach ($surveillances as $item) {
$data = array();
$data['sources'][$item->source][0] = array(
'email' => $item->email,
'ref' => $item->ref,
'dateAjout' => $item->dateAjout,
'dateDerEnvoi' => $item->dateDerEnvoi,
);
$data['email'] = $item->email;
$data['siren'] = $item->siren;
$data['nic'] = $item->nic;
$data['ref'] = $item->ref;
$data['dateAjout'] = $item->dateAjout;
$data['encoursClient'] = $item->encoursClient;
$data['rs'] = $item->rs;
$data['cp'] = $item->cp;
$data['ville'] = $item->ville;
$data['dateDerEnvoi'] = $item->dateDerEnvoi;
$listTrier[] = $data;
}
}
}
//Calcul pagination
$nbReponses = $infos->nbReponses;
$nbSurveillances = $infos->nbReponsesTotal;
$totPage = ceil($nbSurveillances/$nbAffichage);
$curPage = ceil($position/$nbAffichage);
$this->view->assign('source', $source);
$this->view->assign('selectTri', $selectTri);
$this->view->assign('listSources', $permSource);
$this->view->assign('nbReponses', $nbReponses);
$this->view->assign('nbSurveillances', $nbSurveillances);
$this->view->assign('totPage', $totPage);
$this->view->assign('curPage', $curPage);
$this->view->assign('surveillances',$listTrier);
$this->view->assign('source', $source);
}
/**
* Liste les surveillances Scores
*/
public function portefeuilleAction()
{
$user = new Utilisateur();
if(!$user->checkPerm('portefeuille')){
$this->_forward('perms', 'error');
}
$this->view->headLink()->appendStylesheet('/themes/default/styles/surveillance.css', 'all');
$this->view->headScript()
->appendFile('/themes/default/scripts/jquery.qtip.js', 'text/javascript')
->appendFile('/themes/default/scripts/jquery.tablesorter.js', 'text/javascript')
->appendFile('/themes/default/scripts/surveillance.js', 'text/javascript')
->appendFile('/themes/default/scripts/portefeuille.js', 'text/javascript');
$request = $this->getRequest();
$page = $request->getParam('page', 0);
$tri = $request->getParam('tri', 'siren');
$nbAffichage = 100;
$position = $page*$nbAffichage;
switch ( $tri ){
default:
case 'siren': $triws = 'siren'; break;
case 'rs': $triws = 'rs'; break;
case 'reference': $triws = 'ref'; break;
case 'dateajout': $triws = 'dateAjout'; break;
case 'datederenvoi': $triws = 'dateDerEnvoi'; break;
case 'score' : $triws = 'indiScore'; break;
}
$user = new Utilisateur();
$maxIndiscore = $user->getTypeScore();
$typeScore = ($maxIndiscore == '100') ? '' : '20';
$dicoSource = array(
'ajout' => '',
'bilans1' => 'publication bilan',
'bilans2' => 'publication bilan',
'bodacc' => 'publication bodacc',
'collecte' => 'publication légale',
'dirigeants' => 'modification de l\'administration',
'insee' => 'modification identitaire',
'liens' => 'mise à jour de la structure du groupe',
'default' => 'modification identitaire',
);
$couleurRisque100 = array(
'rouge' => array('min'=>0, 'max'=>40),
'orange' => array('min'=>41, 'max'=>50),
'vert' => array('min'=>51, 'max'=>100),
);
$couleurRisque20 = array(
'rouge' => array('min'=>0, 'max'=>6),
'orange' => array('min'=>7, 'max'=>10),
'vert' => array('min'=>11, 'max'=>20),
);
$ws = new WsScores();
$filtre = new stdClass();
$filtre->tri = $triws;
$filtre->siret = '';
$filtre->ref = '';
$filtre->rs = '';
$infos = $ws->getPortefeuille($filtre, $position, $nbAffichage);
$portefeuille = $infos->result->item;
$tabResult = array();
if ( count($portefeuille)>0 ) {
foreach ( $portefeuille as $item ) {
$result = new stdClass();
$result = $item;
//Classe de risque
$couleurV = ${'couleurRisque'.$maxIndiscore};
foreach($couleurV as $couleur => $intervalle)
{
if($item->{'indiScore'.$typeScore}>=$intervalle['min'] &&
$item->{'indiScore'.$typeScore}<=$intervalle['max']){
break;
}
}
$indiScore = $item->{'indiScore'.$typeScore};
$indiScorePre = empty($item->{'indiScore'.$typeScore.'Pre'}) ?
0 : $item->{'indiScore'.$typeScore.'Pre'};
//Variation du risque
$variation = abs($item->indiScore-$item->indiScorePre);
if($variation>=5 && $variation<=9){
$deg = '45';
}else{
$deg = '';
}
//Tooltip
$tooltip = '';
if($item->procol=='P'){
$tooltip.= 'En procédure collective.<br/>';
}
if($item->actif==0){
$tooltip.= '&Eacute;tablissement inactif.<br/>';
}
$tooltip.= '- Dernier exercice pris en compte : ';
if ($item->dateBilan=='0000-00-00') {
$tooltip.= 'Néant';
} else {
$tooltip.= 'le '.WDate::dateT('Y-m-d', 'd/m/Y',$item->dateBilan);
}
$tooltip.= '<br/>';
if ($item->sourceModif!='ajout') {
if (!empty($item->sourceModif)) {
$tooltip.= '- Dernière modification ';
if( $item->indiScoreDate=='0000-00-00') {
$tooltip.= '';
} else {
//$tooltip.= 'le '.WDate::dateT('Y-m-d', 'd/m/Y',$item->indiScoreDate);
}
if (!empty($item->sourceModif)) {
if (in_array($item->sourceModif, $dicoSource)) {
$sourceModif = $item->sourceModif;
} else {
$sourceModif = 'default';
}
$tooltip.= ', suite à '.$dicoSource[$sourceModif];
}
$tooltip.= '<br/>';
}
if ($item->indiScoreDatePre!='0000-00-00') {
$tooltip.= '- Précédent score : '.$indiScorePre.'/'.$maxIndiscore;
}
}
$result->tooltip = $tooltip;
//Affichage score
$colScore = '';
if( $item->indiScoreDate!='0000-00-00' &&
$item->procol!='P' && $item->actif!=0)
{
$colScore.= '<span>'.$indiScore.'/'.$maxIndiscore.'</span>';
//Procols
if ($item->procol=='P') {
$colScore.= '<img src="/themes/default/images/portefeuille/score_alert.gif"/>';
//Constant
} elseif($indiScore==$indiScorePre || $item->sourceModif=='ajout') {
$colScore.= '<img src="/themes/default/images/portefeuille/score_'.$couleur.'constant.gif"/>';
//Hausse
} elseif($indiScore>$indiScorePre) {
$colScore.= '<img src="/themes/default/images/portefeuille/score_'.$couleur.'hausse'.$deg.'.gif"/>';
//Baisse
}elseif($indiScore<$indiScorePre){
$colScore.= '<img src="/themes/default/images/portefeuille/score_'.$couleur.'baisse'.$deg.'.gif"/>';
}
} else {
if ($item->procol=='P') {
$colScore.= '<img src="/themes/default/images/portefeuille/score_alert.gif"/>';
} else {
$colScore.= '-';
}
}
$result->colScore = $colScore;
$tabResult[] = $result;
}
}
//Calcul pagination
$nbReponses = $infos->nbReponses;
$nbSurveillances = $infos->nbReponsesTotal;
$totPage = ceil($nbSurveillances/$nbAffichage);
$curPage = ceil($position/$nbAffichage)+1;
$this->view->assign('nbReponses', $nbReponses);
$this->view->assign('nbSurveillances', $nbSurveillances);
$this->view->assign('totPage', $totPage);
$this->view->assign('curPage', $curPage);
$this->view->assign('portefeuille',$tabResult);
}
/**
* Affiche le lien pour exporter le portefeuille au format csv
*/
public function portefeuillecsvAction()
{
$this->view->headScript()->appendFile('/themes/default/scripts/portefeuillecsv.js', 'text/javascript');
}
/**
* Affiche le lien pour exporter les surveillances au format csv
*/
public function surveillancecsvAction()
{
$this->view->headScript()->appendFile('/themes/default/scripts/surveillancecsv.js', 'text/javascript');
$user = new Utilisateur();
$request = $this->getRequest();
$source = $request->getParam('source');
$tabSource = array();
foreach ($this->sourceDroit as $s => $perm) {
if ($user->checkPerm($perm)) {
$tabSource[] = array(
'value' => $s,
'name' => $this->sourceTxt[$s],
'select' => (!empty($source) && $source==$s) ? ' selected' : '',
);
}
}
$this->view->assign('tabSource', $tabSource);
}
/**
* Affichage des surveillances par fichier pour les clients
*/
public function fichierAction()
{
$request = $this->getRequest();
$user = new Utilisateur();
$this->view->assign('login', $user->getLogin());
$this->view->assign('nom', $user->getNom());
$client = new SoapClient(null, array(
'trace' => 1,
'soap_version' => SOAP_1_1,
'location' => 'http://78.31.45.206/ws2/',
'uri' => 'http://78.31.45.206/',
'login' => $user->getLogin(),
'password' => $user->getPassword()
));
$nomFic = $request->getParam('nomFic', '');
$getCSV = $request->getParam('get', '');
$path = APPLICATION_PATH.'/../cache/survliste';
if(!file_exists($path)) mkdir($path);
//Lister les fichiers
if (empty($nomFic)){
$ref = $user->getPrenom();
if ( strtolower($user->getLogin())=='cnasea95'
|| strtolower($user->getLogin())=='cnasea96'
|| strtolower($user->getLogin())=='omni04'
|| strtolower($user->getLogin())=='bodacca3m'
|| strtolower($user->getLogin())=='bodaccomni'
|| strtolower($user->getLogin())=='bodacccrr'
|| $user->getIdClient()==32
|| $user->getIdClient==82) {
$ref='*';
}
try {
$O = $client->getListeFichierSurv($user->getLogin(), $ref, $nomFic);
$tabFichier = $O['results'];
} catch (SoapFault $fault) {}
$listeFichier = array();
foreach($tabFichier as $fichier){
$tabTmp = explode('_', $fichier);
$date = Wdate::dateT('Ymd','d/m/Y', substr($tabTmp[2],0,8));
$localfile = $path.'/'.$fichier;
$dejaLu = false;
if (!file_exists($localfile)) {
$dejaLu = true;
}
$result = array(
'fichier' => $fichier,
'date' => $date,
'dejaLu' => $dejaLu,
);
$listeFichier[] = $result;
}
$this->view->assign('listeFichier', $listeFichier);
}
//Lister les annonces
elseif (empty($getCSV))
{
$filtre = $request->getParam('filtre', '');
if (!empty($filtre)) {
switch (trim(strtolower($filtre))) {
case 'procol': $filtre = 'procol'; break;
case 'mmd': $filtre = 'mmd'; break;
case 'radiations': $filtre = 'radiations'; break;
case 'ventes': $filtre = 'ventes'; break;
case 'comptes': $filtre = 'comptes'; break;
case 'creations': $filtre = 'creations'; break;
case 'bodacc': $filtre = 'bodacc'; break;
default: $filtre = ''; break;
}
}
//Récupération du fichier
$file = $path.'/'.$nomFic;
$file2 = $file.'.bz2';
if (!file_exists($file) || filesize($file)==0 ) {
//Génération du fichier
try {
$O = $client->getListeFichierSurv($user->getLogin(), $user->getPrenom(), $nomFic);
} catch (SoapFault $fault) {}
require_once 'common/curl.php';
$page = getUrl('http://78.31.45.206/csv/'.$nomFic.'.bz2', '', '', '', false);
$body = $page['body'];
$fp=@fopen($file2, 'w');
@fwrite($fp, $body);
@fclose($fp);
$bz = bzopen($file2, "r") or die("Impossible d'ouvrir le fichier $file");
$fp=@fopen($file, 'w');
while (!feof($bz)) {
@fwrite($fp, bzread($bz, 4096));
}
bzclose($bz);
}
$tab = array();
$row = 0;
$count = 0;
$handle = fopen($file, "r");
while (($ann = fgetcsv($handle, 3000, ';')) !== FALSE)
{
$row++;
if ($row==1)
{
// Ligne d'entête, on repère les colonnes
$num = count($ann);
for ($i=0; $i<$num; $i++)
{
if (utf8_encode($ann[$i])=='SITE_CNASEA') $colSiteCnasea=$i;
elseif(utf8_encode($ann[$i])=='Siren') $colSiren=$i;
elseif(utf8_encode($ann[$i])=='Nic') $colNic=$i;
elseif(utf8_encode($ann[$i])=='Référence') $colRef=$i;
elseif(utf8_encode($ann[$i])=='Parution') $colParution=$i;
elseif(utf8_encode($ann[$i])=='Bodacc') $colBodacc=$i;
elseif(utf8_encode($ann[$i])=='Date parution') $colDatePar=$i;
elseif(utf8_encode($ann[$i])=='Numéro Annonce') $colNumAnn=$i;
elseif(utf8_encode($ann[$i])=='Type Annonce') $colTypeAnn=$i;
elseif(utf8_encode($ann[$i])=='Tribunal') $colTribunal=$i;
elseif(utf8_encode($ann[$i])=='Numéro RCS') $colNumRCS=$i;
elseif(utf8_encode($ann[$i])=='Raison sociale') $colRaisonSociale=$i;
elseif(utf8_encode($ann[$i])=='Chapitre') $colChapitre=$i;
elseif(utf8_encode($ann[$i])=='Evènement(s)') $colEven=$i;
elseif(utf8_encode($ann[$i])=='Texte Annonce') $colTexteAnn=$i;
elseif(utf8_encode($ann[$i])=='Date évènement') $colDateEven=$i;
}
}
elseif ($filtre!='' && $filtre!='bodacc' && $ann[$colChapitre]!=$filtre )
{
//On fait rien
}
else
{
//$filtre=='bodacc'
if( substr($user->getLogin(),0,6)=='cnasea' && $ann[$colBodacc]!='A' && $ann[$colBodacc]!='B' && $ann[$colBodacc]!='C' )
{
//on supprime toutes les annonces pas bodacc
}
else
{
$tab[$count]['RaisonSociale'] = utf8_encode($ann[$colRaisonSociale]);
$tab[$count]['Siren'] = utf8_encode($ann[$colSiren]);
$tab[$count]['SiteCnasea'] = utf8_encode($ann[$colSiteCnasea]);
$tab[$count]['Ref'] = utf8_encode($ann[$colRef]);
$tab[$count]['Parution'] = utf8_encode($ann[$colParution]);
$tab[$count]['Bodacc'] = utf8_encode($ann[$colBodacc]);
$tab[$count]['DatePar'] = WDate::dateT('Ymd','d/m/Y',$ann[$colDatePar]);
$tab[$count]['Tribunal'] = utf8_encode($ann[$colTribunal]);
$tab[$count]['Even'] = utf8_encode(str_replace(', ','<br/>',$ann[$colEven]));
$tab[$count]['TexteAnn'] = utf8_encode($ann[$colTexteAnn]);
$count++;
}
}
}
fclose($handle);
$this->view->assign('annonces', $tab);
$this->view->assign('filtre', $filtre);
$this->view->assign('nomFic', $nomFic);
$this->renderScript('surveillance/fichier-ann.phtml');
} else {
$this->_helper->layout()->disableLayout();
$this->_helper->viewRenderer->setNoRender(true);
//Récupération du fichier
$file = $path.'/'.$nomFic;
$file2 = $file.'.bz2';
if (!file_exists($file) || filesize($file)==0 ) {
//Génération du fichier
try {
$O = $client->getListeFichierSurv($user->getLogin(), $user->getPrenom(), $nomFic);
} catch (SoapFault $fault) {
}
require_once 'common/curl.php';
$page = getUrl('http://78.31.45.206/csv/'.$nomFic.'.bz2', '', '', '', false);
$body = $page['body'];
$fp=@fopen($file2, 'w');
@fwrite($fp, $body);
@fclose($fp);
$bz = bzopen($file2, "r") or die("Impossible d'ouvrir le fichier $file");
$fp=@fopen($file, 'w');
while (!feof($bz)) {
@fwrite($fp, bzread($bz, 4096));
}
bzclose($bz);
}
$content_type = 'application/csv-tab-delimited-table';
$path = APPLICATION_PATH.'/../cache/survliste/';
//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($path.$nomFic);
} else {
echo 'Impossible de charger le fichier.';
}
}
}
/**
* Export surveillance en fichier pdf
*/
public function fichierpdfAction()
{
$this->_helper->layout()->disableLayout();
$this->_helper->viewRenderer->setNoRender(true);
$request = $this->getRequest();
$user = new Utilisateur();
$client = new SoapClient(null, array(
'trace' => 1,
'soap_version' => SOAP_1_1,
'location' => 'http://78.31.45.206/ws2/',
'uri' => 'http://78.31.45.206/',
'login' => $user->getLogin(),
'password' => $user->getPassword()
));
$nomFic = $request->getParam('q', '');
$filtre = $request->getParam('filtre', '');
if (!empty($filtre)){
switch (trim(strtolower($filtre))) {
case 'procol': $filtre = 'procol'; break;
case 'mmd': $filtre = 'mmd'; break;
case 'radiations': $filtre = 'radiations'; break;
case 'ventes': $filtre = 'ventes'; break;
case 'comptes': $filtre = 'comptes'; break;
case 'creations': $filtre = 'creations'; break;
case 'bodacc': $filtre = 'bodacc'; break;
default: $filtre = ''; break;
}
}
$path = APPLICATION_PATH.'/../cache/survliste';
if(!file_exists($path)) mkdir($path);
//Récupération du fichier
$file = $path.'/'.$nomFic;
$file2 = $file.'.bz2';
if (!file_exists($file) || filesize($file)==0 ) {
//Génération du fichier
try {
$O = $client->getListeFichierSurv($user->getLogin(), $user->getPrenom(), $nomFic);
} catch (SoapFault $fault) {
}
require_once 'common/curl.php';
$page = getUrl('http://78.31.45.206/csv/'.$nomFic.'.bz2', '', '', '', false);
$body = $page['body'];
$fp=@fopen($file2, 'w');
@fwrite($fp, $body);
@fclose($fp);
$bz = bzopen($file2, "r") or die("Impossible d'ouvrir le fichier $file");
$fp=@fopen($file, 'w');
while (!feof($bz)) {
@fwrite($fp, bzread($bz, 4096));
}
bzclose($bz);
}
$tab = array();
$row = 0;
$count = 0;
$handle = fopen($file, "r");
while (($ann = fgetcsv($handle, 3000, ';')) !== FALSE)
{
$row++;
if ($row==1)
{
// Ligne d'entête, on repère les colonnes
$num = count($ann);
for ($i=0; $i<$num; $i++)
{
if (utf8_encode($ann[$i])=='SITE_CNASEA') $colSiteCnasea=$i;
elseif(utf8_encode($ann[$i])=='Siren') $colSiren=$i;
elseif(utf8_encode($ann[$i])=='Nic') $colNic=$i;
elseif(utf8_encode($ann[$i])=='Référence') $colRef=$i;
elseif(utf8_encode($ann[$i])=='Parution') $colParution=$i;
elseif(utf8_encode($ann[$i])=='Bodacc') $colBodacc=$i;
elseif(utf8_encode($ann[$i])=='Date parution') $colDatePar=$i;
elseif(utf8_encode($ann[$i])=='Numéro Annonce') $colNumAnn=$i;
elseif(utf8_encode($ann[$i])=='Type Annonce') $colTypeAnn=$i;
elseif(utf8_encode($ann[$i])=='Tribunal') $colTribunal=$i;
elseif(utf8_encode($ann[$i])=='Numéro RCS') $colNumRCS=$i;
elseif(utf8_encode($ann[$i])=='Raison sociale') $colRaisonSociale=$i;
elseif(utf8_encode($ann[$i])=='Chapitre') $colChapitre=$i;
elseif(utf8_encode($ann[$i])=='Evènement(s)') $colEven=$i;
elseif(utf8_encode($ann[$i])=='Texte Annonce') $colTexteAnn=$i;
elseif(utf8_encode($ann[$i])=='Date évènement') $colDateEven=$i;
}
}
elseif ($filtre!='' && $filtre!='bodacc' && $ann[$colChapitre]!=$filtre )
{
//On fait rien
}
else
{
//$filtre=='bodacc'
if( substr($user->getLogin(),0,6)=='cnasea' && $ann[$colBodacc]!='A' && $ann[$colBodacc]!='B' && $ann[$colBodacc]!='C' )
{
//on supprime toutes les annonces pas bodacc
}
else
{
$tab[$count]['RaisonSociale'] = utf8_encode($ann[$colRaisonSociale]);
$tab[$count]['Siren'] = utf8_encode($ann[$colSiren]);
$tab[$count]['SiteCnasea'] = utf8_encode($ann[$colSiteCnasea]);
$tab[$count]['Ref'] = utf8_encode($ann[$colRef]);
$tab[$count]['Parution'] = utf8_encode($ann[$colParution]);
$tab[$count]['Bodacc'] = utf8_encode($ann[$colBodacc]);
$tab[$count]['DatePar'] = WDate::dateT('Ymd','d/m/Y',$ann[$colDatePar]);
$tab[$count]['Tribunal'] = utf8_encode($ann[$colTribunal]);
$tab[$count]['Even'] = utf8_encode(str_replace(', ','<br/>',$ann[$colEven]));
$tab[$count]['TexteAnn'] = utf8_encode($ann[$colTexteAnn]);
$count++;
}
}
}
fclose($handle);
$page = $request->getParam('page', '');
$nbAnnoncesMin = ($page-1)*100;
$nbAnnoncesMax = $nbAnnoncesMin+100;
$output = '';
$count = 0;
$annonces = $tab;
$nbAnnonces = count($annonces);
if($nbAnnonces>0){
foreach($annonces as $annonce){
if($count>$nbAnnoncesMax) break;
if($count>=$nbAnnoncesMin)
{
$output.= '<page backtop="10mm" backbottom="10mm">';
$output.= '<page_header>';
$output.= '<table style="width:100%; border:solid 1px black;">';
$output.= '<tr>';
$output.= '<td style="text-align:left; width:67%">Surveillance : '.$count.'/'.$nbAnnonces.'</td>';
$output.= '<td style="text-align:right; width:33%">'.date('d/m/Y').'</td>';
$output.= '</tr>';
$output.= '</table>';
$output.= '</page_header>';
$output.= '<table style="width:100%;">';
$output.= '<tr>';
$output.= '<td style="width:50%;">Entreprise : '.$annonce['RaisonSociale'].' ('.$annonce['Siren'].')</td>';
$output.= '<td style="width:50%;">&nbsp;</td>';
$output.= '</tr>';
$output.= '<tr>';
$output.= '<td style="width:50%;">Site : '.$annonce['SiteCnasea'].'</td>';
$output.= '<td style="width:50%;">Référence : '.$annonce['Ref'].'</td>';
$output.= '</tr>';
$output.= '<tr>';
if ($annonce['Bodacc']=='A' || $annonce['Bodacc']=='B' || $annonce['Bodacc']=='C')
{
$source = 'BODACC n&deg;'.$annonce['Parution'].'&nbsp;'.$annonce['Bodacc'].' du '.$annonce['DatePar'].' '.$annonce['Tribunal'].'.';
}
elseif ($annonce['Bodacc']=='G')
{
$source = 'GREFFE du '.$annonce['Tribunal'].' au '.$annonce['DatePar'].'.';
}
elseif ($annonce['Bodacc']=='P')
{
$source = 'RNCS du '.$annonce['Tribunal'].' au '.$annonce['DatePar'].'.';
}
else
{
$source = 'Collecte SD du '.$annonce['Tribunal'].' au '.$annonce['DatePar'].'.';
}
$output.= '<td style="width:100%;" colspan="2">'.$source.'</td>';
$output.= '</tr>';
$output.= '<tr><td style="width:100%;" colspan="2">&nbsp;</td></tr>';
$output.= '<tr>';
$output.= '<td style="width:100%;" colspan="2"><b>'.$annonce['Even'].'</b></td>';
$output.= '</tr>';
$output.= '<tr>';
$output.= '<td style="width:100%;" colspan="2">'.$annonce['TexteAnn'].'</td>';
$output.= '</tr>';
$output.= '</table>';
$output.= '</page>';
}
$count++;
}
}else{
/*
* Fermeture de la balise page lorsqu'il n'y a aucune annonce
* afin de générer un fichier pdf vide et non pas une erreur
*/
$output = '</page>';
}
// conversion HTML => PDF
require_once 'Vendors/html2pdf/html2pdf.class.php';
$html2pdf = new HTML2PDF('P','A4','fr');
$html2pdf->WriteHTML(utf8_decode($output));
$html2pdf->Output(str_replace('.csv', '.pdf', $nomFic), 'D');
}
}