2 // vim: set expandtab tabstop=4 softtabstop=4 shiftwidth=4:
3 // +--------------------------------------------------------------------+
4 // | SAMURAI - Samurai_Lib |
5 // +--------------------------------------------------------------------+
6 // | Sistema de Administracion y Matenimiento de Usuarios Relativo A |
8 // | Ministerio de EconomÃa |
9 // +--------------------------------------------------------------------+
10 // | Creado: lun mar 10 ART 2003 |
11 // | Autor: Martin Marrese <mmarre@mecon.gov.ar> |
12 // +--------------------------------------------------------------------+
22 require_once 'PEAR.php';
23 require_once 'DB.php';
28 * Libreria para le manejo de los permisos. Basada en la lase HE_Perm de
29 * Leandro Lucarella <llucar@mecon.gov.ar>
30 * Las funciones de acceso publico se llaman igual que en HE_Perm
32 * Perm/sql_Conf.php -> Consultas SQL utilizadas por el objeto
33 * Perm/db_Conf.php -> Datos de la conexion con la base de datos
41 class SA_Perm extends PEAR {
51 * Permisos del usuario en el sistema.
59 * Conexion a la Base de Datos .
66 * Identificacion del sistema
75 * El login del usuario lo toma del udat
77 * @param int $sistema Identificacion del sistema (id_sistema)
78 * @param string $login Identificacion del usuario (udat{user}
82 function SA_Perm($sistema, $login)
85 $this->sistema = $sistema;
86 $this->login = $login;
87 $this->DB = $this->_conectarDB();
88 $this->permisos = $this->_obtenerPermisos();
92 * Verifica los permisos de un usuario
94 * Compara los permisos que tiene un usuario en relacion a los
95 * pasados como parametro. Devuelve true si cumple con todos los
96 * permisos, en caso contrario devuelve false. Es de parametros
97 * variables, y siempre necesita al menos UN parametro
99 * @param array $permisos Permisos que se buscan
107 $args = func_get_args(); //Obtengo los permisos que me pasaron como argumento
108 $result = true; //Asumo que no va a fallar
110 $result = false; //Siempre se debe pasar al menos un permiso a buscar
113 if (count(array_diff($args, $this->permisos))){
121 * Verifica los permisos de un usuario
123 * Compara los permisos que tiene un usuario en relacion a los
124 * pasados como parametro. Devuelve true si cumple con alguno de los
125 * permisos, en caso contrario devuelve false. Es de parametros
126 * variables, y siempre necesita al menos UN parametro
128 * @param array $permisos Permisos que se buscan
136 $args = func_get_args(); //Obtengo los permisos que me pasaron como argumento
137 $result = true; //Asumo que no va a fallar
138 if (!count($args)) { //Siempre se debe pasar al menos un permiso a buscar
142 if (count(array_diff($args, $this->permisos)) >= count($args)) {
150 * Verifica los permisos de un usuario
152 * Compara un permiso pasado por parametro con los que tiene el usuario
153 * en la base. Devuelve true si tiene el permiso, false en otro caso
155 * @param int permiso buscado
161 function tieneUn($permiso)
163 $result = true; //Asumo que no va a fallar
164 if (!isset($permiso)) { //Tiene que pasar un permiso si o si
168 if (!in_array($permiso, $this->permisos)) { //Si no esta en el array, no tiene el permiso
175 //HASTA ACA FUNCIONES PUBLICAS
176 //DESDE ACA FUNCIONES PRIVADAS
179 * Obtiene los permisos de un usuario de la base
181 * @return array permisos del usuario
185 function _obtenerPermisos()
187 $consultas = include 'Perm/sql_Conf.php';
188 $sql = $consultas['obtener_p_p_completo'];
189 $sql_array = array ('0' => $this->sistema, '1' => $this->login);
190 $result = $this->DB->getCol($sql,0, $sql_array);
191 if (DB::isError($this->permisos)) { //En caso de error en la consulta, que lo muestre
192 die ($this->permisos->getMessage());
198 * Conecta el objeto a la base de datos
200 * @return db conexion con la base
204 function _conectarDB()
206 $datos = include 'include/samurai_lib_db_conf.inc';
207 $dsn = $datos['db_type']."://".$datos['db_user'].":".$datos['db_pass']."@".$datos['db_host']."/".$datos['db_name'];
208 $db = DB::connect($dsn, true); //Quiero que la conexion sea persistente
209 if (DB::isError($db)) {
210 die($db->getMessage());