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 * samurai_lib_sql.inc -> Consultas SQL utilizadas por el objeto
33 * samurai_lib_db_conf.inc -> 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)
84 if (isset($sistema) && isset($login)) {
85 $this->sistema = $sistema;
86 $this->login = $login;
87 $this->DB = $this->_conectarDB();
88 $this->permisos = $this->_obtenerPermisos();
93 * Verifica los permisos de un usuario
95 * Compara los permisos que tiene un usuario en relacion a los
96 * pasados como parametro. Devuelve true si cumple con todos los
97 * permisos, en caso contrario devuelve false. Es de parametros
98 * variables, y siempre necesita al menos UN parametro
100 * @param array permisos buscados
108 $args = func_get_args(); //Obtengo los permisos que me pasaron como argumento
109 $result = true; //Asumo que no va a fallar
111 $result = false; //Siempre se debe pasar al menos un permiso a buscar
114 if (count(array_diff($args, $this->permisos))){
123 * Verifica los permisos de un usuario
125 * Compara los permisos que tiene un usuario en relacion a los
126 * pasados como parametro. Devuelve true si cumple con alguno de los
127 * permisos, en caso contrario devuelve false. Es de parametros
128 * variables, y siempre necesita al menos UN parametro
130 * @param array permisos buscados
138 $args = func_get_args(); //Obtengo los permisos que me pasaron como argumento
139 $result = true; //Asumo que no va a fallar
140 if (!count($args)) { //Siempre se debe pasar al menos un permiso a buscar
144 if (count(array_diff($args, $this->permisos)) >= count($args)) {
152 * Verifica los permisos de un usuario
154 * Compara un permiso pasado por parametro con los que tiene el usuario
155 * en la base. Devuelve true si tiene el permiso, false en otro caso
157 * @param int permiso buscado
163 function tieneUn($permiso)
165 $result = true; //Asumo que no va a fallar
166 if (!isset($permiso)) { //Tiene que pasar un permiso si o si
170 if (!in_array($permiso, $this->permisos)) { //Si no esta en el array, no tiene el permiso
177 //HASTA ACA FUNCIONES PUBLICAS
178 //DESDE ACA FUNCIONES PRIVADAS
181 * Obtiene los permisos de un usuario de la base
183 * @return array con los permisos del usuario
187 function _obtenerPermisos()
189 $consultas = include 'include/samurai_lib_sql.inc';
190 $sql = $consultas['obtener_p_p_completo'];
191 $sql_array = array ('0' => $this->sistema, '1' => $this->login);
192 $result = $this->DB->getCol($sql,0, $sql_array);
193 if (DB::isError($this->permisos)) { //En caso de error en la consulta, que lo muestre
194 die ($this->permisos->getMessage());
200 * Conecta el objeto a la base de datos, segun lo especificado
201 * en samurai_lib_db_conf.inc.
203 * @return db conexion con la base
207 function _conectarDB()
209 $datos = include 'include/samurai_lib_db_conf.inc';
210 $dsn = $datos['db_type']."://".$datos['db_user'].":".$datos['db_pass']."@".$datos['db_host']."/".$datos['db_name'];
211 $db = DB::connect($dsn, true); //Quiero que la conexion sea persistente
212 if (DB::isError($db)) {
213 die($db->getMessage());