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 los permisos que tiene un usuario en relacion a los
153 * pasados como parametro. Devuelve un array con aquellos permisos que
154 * el usuario tiene. Funciona similar a tieneO solo que devuelve un array.
155 * Es de parametros variables, y siempre necesita al menos UN parametro
157 * @param array $permisos Permisos que se buscan
159 * @return array Permisos que tiene el usuario pasados por parametro, o 'ERROR' en caso contrario
163 function tieneODevol ()
165 $args = func_get_args(); //Obtengo los permisos que me pasaron como argumento
169 $result['0'] = 'ERROR'; //Siempre se debe pasar al menos un permiso a buscar
172 $result = array_intersect($args, $this->permisos);
178 * Verifica los permisos de un usuario
180 * Compara un permiso pasado por parametro con los que tiene el usuario
181 * en la base. Devuelve true si tiene el permiso, false en otro caso
183 * @param int permiso buscado
189 function tieneUn($permiso)
191 $result = true; //Asumo que no va a fallar
192 if (!in_array($permiso, $this->permisos)) { //Si no esta en el array, no tiene el permiso
198 //HASTA ACA FUNCIONES PUBLICAS
199 //DESDE ACA FUNCIONES PRIVADAS
202 * Obtiene los permisos de un usuario de la base
204 * @return array permisos del usuario
208 function _obtenerPermisos()
210 $consultas = include 'Perm/sql_Conf.php';
211 $sql = $consultas['obtener_p_p_completo'];
212 $sql_array = array ('0' => $this->sistema, '1' => $this->login);
213 $result = $this->DB->getCol($sql,0, $sql_array);
214 if (DB::isError($this->permisos)) { //En caso de error en la consulta, que lo muestre
215 die ($this->permisos->getMessage());
221 * Conecta el objeto a la base de datos
223 * @return db conexion con la base
227 function _conectarDB()
229 $datos = include 'Perm/db_Conf.php';
230 $dsn = $datos['db_type']."://".$datos['db_user'].":".$datos['db_pass']."@".$datos['db_host']."/".$datos['db_name'];
231 $db = DB::connect($dsn, true); //Quiero que la conexion sea persistente
232 if (DB::isError($db)) {
233 die($db->getMessage());