extranet/includes/user/permissions.php

111 lines
3.9 KiB
PHP
Raw Normal View History

<?php
2009-07-02 15:50:12 +00:00
//D<>finition du tableau des permissions
$definePerms = array(
'KBIS' => array( 'init' => '', 'txt' => 'Extrait RCS'),
2009-07-16 15:38:47 +00:00
'ACTES' => array( 'init' => '', 'txt' => 'Pi<50>ces officielles'),
'IPARI' => array( 'init' => '', 'txt' => 'Investigation par l\'image IparI&copy;'),
'MARQUES' => array( 'init' => '', 'txt' => 'Marques d<>pos<6F>es'),
'INDISCORE' => array( 'init' => '', 'txt' => 'indiScore&copy;'),
'SCORECSF' => array( 'init' => '', 'txt' => 'Score CSF'),
'EVENINSEE' => array( 'init' => '', 'txt' => '&Eacute;v<>nements INSEE'),
'AVISINSEE' => array( 'init' => '', 'txt' => 'Avis de situation INSEE'),
2009-07-16 15:38:47 +00:00
'SURVANNONCE' => array( 'init' => '', 'txt' => 'Surveillance des annonces l<>gales'),
'SURVINSEE' => array( 'init' => '', 'txt' => 'Surveillance des <20>v<EFBFBD>nements INSEE'),
'SURVBILAN' => array( 'init' => '', 'txt' => 'Surveillance des bilans'),
'SURVSCORE' => array( 'init' => '', 'txt' => 'Surveillance des <20>v<EFBFBD>nements sur le score'),
'SURVLISTE' => array( 'init' => '', 'txt' => 'Liste des surveillances'),
'INVESTIG' => array( 'init' => '', 'txt' => 'Investigation'),
'ENQUETEC' => array( 'init' => '', 'txt' => 'Enqu<71>te commerciale'),
'INTERNATIONAL' => array( 'init' => '', 'txt' => 'Recherche Internationale'),
'MONPROFIL' => array( 'init' => '', 'txt' => 'Mon profil'),
);
2009-07-02 15:50:12 +00:00
/*
* Attribut si l'utilisateur poss<73>de le droit d'acc<EFBFBD>der au service
* @param string $name
* Nom du droit
* @param array $userInfo
* Tableau d'informations de l'utilisateur, facultatif, si pas d<EFBFBD>fini alors on regarde dans la session
* @return boolean
*/
function hasPerm($perm, $userInfos = ''){
2009-07-09 15:07:38 +00:00
$return = TRUE;
if($userInfos == ''){ $userInfos = $_SESSION['tabInfo']; }
2009-07-09 15:07:38 +00:00
if ( !preg_match('/'.$perm.'/i', $userInfos['droits'])) $return = FALSE;
//Surcharger les droits
2009-07-09 15:07:38 +00:00
if(!overridePerm($perm)){ $return = FALSE; }
return $return;
}
2009-07-09 15:07:38 +00:00
/*
* V<EFBFBD>rifie les permissions sur chaque page
* @param string $page
* Nom de la page
* @param string $perm
* Nom du droit
* @return boolean
*/
function checkPerm($page, $perm = ''){
$return = TRUE;
if($page != 'recherche') $return = hasPerm($perm);
$return = $return && overridePermPage($page);
return $return;
}
/*
* Retourne le code HTML pour le formulaire de modification du compte
* @param string $name
* Nom du droits
* @param array $perms
* Tableau d'informations du droits
* @return string
*/
function formElementPerm($userInfos){
global $definePerms;
$return = '';
foreach($definePerms as $perm => $infos){
if(overridePerm($perm)){
(hasPerm($perm, $userInfos)==TRUE) ? $checked = 'checked' : $checked = $infos['init'];
($_SESSION['tabInfo']['profil']=='Administrateur') ? $disabled = '' : $disabled = 'disabled' ;
2009-07-17 14:57:42 +00:00
$return.= '<input type="checkbox" name="frmOptions[droits][]" value="'.strtolower($perm).'" '.$checked.' '.$disabled.' class="noborder"/>'.$infos['txt'].'<br/>'."\n";
}
}
return $return;
}
/*
* V<EFBFBD>rifie le login de l'utilisateur pour le mode edition
* @param string $loginVu
* Login
* @return boolean
*/
function checkModeEdition($loginVu){
$isAuthorized = FALSE;
$authorizedUsers = array('ylenaour', 'jmartory', 'mheitz', 'mpurcarin', 'mcochet', 'aegasse', 'mricois', 'adebbagh');
$isUserAuthorized = FALSE;
foreach($authorizedUsers as $login){
if($_SESSION['tabInfo']['login']==$login){
$isUserAuthorized = TRUE;
break;
}
}
if($loginVu==$_SESSION['tabInfo']['login'] && $isUserAuthorized || ($_SESSION['tabInfo']['idClient']==1 && $_SESSION['tabInfo']['profil']=='Administrateur') ){
$isAuthorized = TRUE;
}
return $isAuthorized;
}
/*
* Retourne le code HTML pour le formulaire de modification du compte
* @return string
*/
function formElementModeEdition(){
if ($_SESSION['tabInfo']['mode_edition']==1) $strMode='checked'; else $strMode='';
2009-07-17 14:57:42 +00:00
return '<input type="checkbox" name="frmOptions[mode_edition]" value="1" '.$strMode.' class="noborder"/>Edition';
}
?>