extranet/includes/surveillance/surveillance.php

351 lines
9.3 KiB
PHP
Raw Normal View History

2009-05-20 15:49:08 +00:00
<?php
function assocSourceDroit(){
return array(
'annonces' => 'survannonce',
'insee' => 'survinsee',
'bilans' => 'survbilan',
'score' => 'survscore',
'actes' => 'survactes',
'dirigeants' => 'survdirigeants',
'privileges' => 'survpriv',
);
}
function assocSourceTxt(){
return array(
'annonces' => 'annonces',
'insee' => 'Insee',
'bilans' => 'bilans',
'score' => 'IndiScore',
'actes' => 'actes',
'dirigeants' => 'dirigeants',
'privileges' => 'privilèges',
);
}
2009-05-20 15:49:08 +00:00
/**
* Affiche le formulaire surveillance.
*
* @param string $page
* La page ou l'on affiche le formulaire, détermine le type de surveillance.
2009-05-20 15:49:08 +00:00
* @param string $siret
* L'établissement à surveiller.
2009-05-20 15:49:08 +00:00
* @param array $notEmail
2010-03-08 16:42:53 +00:00
* Un tableau de login pour exclure l'affichage de l'adresse email
* @param boolean $inDialog
*
2009-05-20 15:49:08 +00:00
* @return string
* Retourne sous forme de chaine de caractère le fomulaire en HTML
2009-05-20 15:49:08 +00:00
*/
function formSurveillance($source, $siret, $notEmail, $inDialog = false)
2010-03-08 16:42:53 +00:00
{
2009-12-17 09:40:18 +00:00
$assocSourceTxt = assocSourceTxt();
$assocSourceDroit = assocSourceDroit();
2010-03-08 16:42:53 +00:00
$style = file_get_contents(realpath(dirname(__FILE__)).'/style.css');
2010-03-08 16:42:53 +00:00
$output = '';
2010-03-08 16:42:53 +00:00
if($inDialog){
$output.= '<style type="text/css">'.$style.'</style>'."\n";
$output.= '<form id="frmSurv" name="frmSurv" '.
'action="./pages/ajax_surveillance.php" method="post">'."\n";
$output.= '<input name="q" type="hidden" value="setsurv"/>';
$output.= '<input name="formSurv[siret]" type="hidden" value="'.
2010-03-08 16:42:53 +00:00
$siret.'"/>'."\n";
if( empty($source) ){
$output.= '<div class="fieldgrp">'."\n";
$output.= '<label>Types</label>'."\n";
$output.= '<div class="field">'."\n";
foreach($assocSourceTxt as $Source => $Txt)
{
if(hasPerm($assocSourceDroit[$Source]))
{
$checked = 'checked';
if ($Source=='privileges'){
$checked = '';
}
$output.='<input type="checkbox" '.
'name="formSurv[source][]" value="'.
$Source.'" '.$checked.'/>&nbsp;'.$Txt."<br/>\n";
}
}
$output.= '</div>'."\n";
$output.= '</div>'."\n";
}else{
$output.= '<input name="formSurv[source]" '.
2010-03-08 16:42:53 +00:00
'type="hidden" value="'.$source.'"/>'."\n";
}
2010-04-09 13:08:17 +00:00
//Champ référence
$ref = '';
if(isset($_REQUEST['ref'])){
$ref = $_REQUEST['ref'];
}
$output.= '<div id="survForm">'."\n";
$output.= '<div class="fieldgrp">'."\n";
$output.= '<label class="StyleInfoLib">Votre référence</label>';
$output.= '<div class="field">';
$output.= '<input class="longfield" name="formSurv[ref]" type="text" '.
'value="'.$ref.'" size="10"/></div>'."\n";
$output.= '</div>'."\n";
2010-03-08 16:42:53 +00:00
2010-04-09 13:08:17 +00:00
//Champ spécial suivant source
$encours = '';
if(isset($_REQUEST['encours'])){
$encours = $_REQUEST['encours'];
}
if ($source=='score'){
$output.= '<div id="survForm">'."\n";
$output.= '<div class="fieldgrp">'."\n";
2010-04-13 07:24:02 +00:00
$output.= '<label class="StyleInfoLib">Votre encours (&euro;)</label>';
2010-04-09 13:08:17 +00:00
$output.= '<div class="field">';
$output.= '<input class="longfield" name="formSurv[encours]" '.
'type="text" value="'.$encours.'" size="10"/></div>'."\n";
$output.= '</div>'."\n";
}
//Champ email
$email = '';
2010-03-08 16:42:53 +00:00
if( !in_array($_SESSION['tabInfo']['login'],$notEmail) &&
!isset($_REQUEST['email'])){
$email = $_SESSION['tabInfo']['email'];
}elseif(isset($_REQUEST['email'])){
$email = $_REQUEST['email'];
}
$output.= '<div class="fieldgrp">'."\n";
$output.= '<label class="StyleInfoLib">'.
'Adresse email du destinataire</label>';
$output.= '<div class="field">'.
'<input class="longfield" name="formSurv[email]" '.
'type="text" value="'.$email.'" size="20"/></div>'."\n";
$output.= '</div>'."\n";;
$output.= '</div>'."\n";
$output.= '</form>'."\n";
2010-03-08 16:42:53 +00:00
}else{
$texte = 'Mettre sous surveillance ';
if( !empty($source) ) {
$texte.= $assocSourceTxt[$source];
}
$output.= '<br/>';
$output.= lienSousSurveillance($texte,
'Ajouter la surveillance', $source, $siret);
$output.= '<br/>'."\n";
2009-05-20 15:49:08 +00:00
}
return $output;
2009-05-20 15:49:08 +00:00
}
/**
2010-03-08 16:42:53 +00:00
* Gère la détection des droits et des préférences pour l'affichage
* de la surveillance.
2009-05-20 15:49:08 +00:00
* @param string $page
2010-03-08 16:42:53 +00:00
* La page ou l'on affiche le formulaire, détermine le type
* de surveillance.
2009-05-20 15:49:08 +00:00
* @param string $siret
* L'établissement à surveiller.
2009-05-20 15:49:08 +00:00
* @return void
*/
function getSurveillance($source, $siret){
$assocSourceDroit = assocSourceDroit();
$return = '';
2010-03-26 14:27:57 +00:00
$notEmail = array('testreunica', 'reunicacsf');
2010-04-09 13:08:17 +00:00
if (!empty($source) &&
array_key_exists($source, $assocSourceDroit) &&
hasPerm($assocSourceDroit[$source]) ){
$listSurv = inSurveillance($source, $siret);
if (hasPref('voirsurv') && $listSurv!==FALSE){
$return = dInfoSurveillance($listSurv, $source, $siret);
2010-04-09 13:08:17 +00:00
}else{
$return = formSurveillance($source, $siret, $notEmail);
}
}else{
$listSurv = inSurveillance('', $siret);
if (hasPref('voirsurv') && $listSurv!==FALSE){
$return = dInfoSurveillance($listSurv, '', $siret);
} else {
$return = formSurveillance('', $siret, $notEmail);
}
}
return $return;
2009-05-20 15:49:08 +00:00
}
/**
* Renvoie le code HTML pour le lien de surveillance
* @param string $texte
* @param string $titre
* @param string $source
* @param string $siret
*/
function lienSousSurveillance($texte, $titre, $source, $siret){
return '<a class="dialogsurv" '.
'href="./pages/ajax_surveillance.php?q=ajouter&siret='.
$siret.'&source='.$source.'" '.
'title="'.$titre.' '.$source.'">'. $texte . '</a>';
}
/**
* Affiche les informations de surveillance
* @param array | boolean $listSurv
* @param string $source
* @param string $siret
*/
function dInfoSurveillance($listSurv, $source, $siret){
$output = '';
if (is_array($listSurv) && count($listSurv)>0){
$output.= '<br/>L\'entité est ' .
lienSousSurveillance('sous surveillance',
'Ajouter la surveillance', $source, $siret);
$sourceTxt = assocSourceTxt();
$cSource = 0;
foreach ($listSurv as $source => $info){
$cSource++;
$ref = $info['ref'];
$output.= ' <u tooltip="';
$output.= 'Ref : '.$ref;
$date = WDate::dateT('Y-m-d', 'd/m/Y', $info['dateAjout']);
$output.= '<br/>Date d\'ajout : '.$date;
if ($info['dateDerEnvoi']!='0000-00-00 00:00:00'){
$date = WDate::dateT('Y-m-d', 'd/m/Y',
substr($info['dateDerEnvoi'],0,10));
$output.= '<br/>Date de dernier envoi : '.$date;
}
$output.= '">'.$sourceTxt[$source].'</u>';
if ($cSource<count($listSurv)) $output.= ',';
}
if (!empty($ref)) $output.= ' ('.$ref.')';
$output.= ".\n";
}
return $output;
}
2009-05-20 15:49:08 +00:00
/**
* Vérifie si l'établissement est en surveillance
2009-05-20 15:49:08 +00:00
*
* @param string $source
* Le type de surveillance.
* @param string $siret
* L'établissement surveillé.
2009-05-20 15:49:08 +00:00
* @return boolean
* true or false
*/
function inSurveillance($source, $siret){
2010-04-09 13:08:17 +00:00
global $client;
try {
2009-05-20 15:49:08 +00:00
$result = $client->getSurveillances($siret,$source);
$survSource = $result['results']['reponses'];
if (count($survSource)>0 ){
$find = FALSE;
if(strlen($siret)>9) $siret = substr($siret, 0, 9);
if (!empty($source)){
foreach($survSource as $item){
if ($item['siren'] == $siret &&
$item['source'] == $source)
{
$find[$item['source']] = array(
'email' => $item['email'],
'ref' => $item['ref'],
'dateAjout' => $item['dateAjout'],
'dateDerEnvoi' => $item['dateDerEnvoi'],
);
break;
}
}
} else {
$find = array();
FB::log($survSource, 'SURV');
foreach($survSource as $item){
if ($item['siren'] == $siret){
$find[$item['source']] = array(
'email' => $item['email'],
'ref' => $item['ref'],
'dateAjout' => $item['dateAjout'],
'dateDerEnvoi' => $item['dateDerEnvoi'],
);
}
}
}
2010-03-08 16:42:53 +00:00
return $find;
}else{ return false; }
2010-03-08 16:42:53 +00:00
}catch(SoapFault $fault){
return false;
2009-05-20 15:49:08 +00:00
}
}
2009-05-22 12:26:07 +00:00
/**
* Envoi la surveillance au webservice
*
* @param array $tabForm
* Le type de surveillance.
* @return mixed
* Retourne la réponse du webservice ou false
2009-05-22 12:26:07 +00:00
*/
function setSurveillance($tabForm)
{
2010-04-09 13:08:17 +00:00
global $client;
2009-05-20 15:49:08 +00:00
$siret = $tabForm['siret'];
$email = $tabForm['email'];
$ref = $tabForm['ref'];
$source = $tabForm['source'];
2010-04-09 13:08:17 +00:00
isset($tabForm['encours']) && !empty($tabForm['encours']) ?
$encours = $tabForm['encours'] : $encours = 0;
//Vérification de l'encours (chiffres)
if (!preg_match('/([0-9]+)/', $encours)){
return 'Encours incorrect';
exit;
}
//Mise en surveillance pour une liste de sources
if (is_array($source)){
foreach ($source as $s){
2009-12-16 10:09:30 +00:00
try{
2010-04-09 13:08:17 +00:00
$result = $client->setSurveillance($siret, $email, $ref, $s,
false, $encours);
$result = '';
2010-03-08 16:42:53 +00:00
}catch(SoapFault $fault){
2009-12-16 10:09:30 +00:00
$result = false;
2010-03-08 16:42:53 +00:00
}
}
2010-04-09 13:08:17 +00:00
//Mise en surveillance pour une source
} else {
2009-12-16 10:09:30 +00:00
try{
2010-04-09 13:08:17 +00:00
$result = $client->setSurveillance($siret, $email, $ref, $source,
false, $encours);
$result = '';
}catch (SoapFault $fault){
2009-12-16 10:09:30 +00:00
$result = false;
}
2009-05-20 15:49:08 +00:00
}
2009-12-16 10:09:30 +00:00
return $result;
2009-05-20 15:49:08 +00:00
}
2009-05-22 12:26:07 +00:00
/**
* Supprime la surveillance
* @param string $siret
* L'établissement surveillé.
2009-05-22 12:26:07 +00:00
* @param $email
* L'email enregistré pour la surveillance
2009-05-22 12:26:07 +00:00
* @param $ref
* La référence ajouté pour cette surveillance
2010-03-08 16:42:53 +00:00
* @param $source
2009-05-22 12:26:07 +00:00
* La source pour cette surveillance
* @return mixed
* Retourne la réponse du webservice ou false
2009-05-22 12:26:07 +00:00
*/
2009-05-20 15:49:08 +00:00
function deleteSurveillance($siret, $email, $ref, $source){
2010-04-09 13:08:17 +00:00
global $client;
2009-05-20 15:49:08 +00:00
try{
$result = $client->setSurveillance($siret, $email, $ref, $source, TRUE);
2009-05-25 13:19:02 +00:00
return TRUE;
2010-03-08 16:42:53 +00:00
}catch(SoapFault $fault){
2009-05-20 15:49:08 +00:00
return FALSE;
}
}
?>