From a273886fc36b8c938dddba092794f2c12dd862ac Mon Sep 17 00:00:00 2001 From: Leandro Lucarella Date: Fri, 6 May 2005 18:30:13 +0000 Subject: [PATCH] Nueva pantalla de cambio de administrador. --- src/admin.admin.php | 47 +++++++++++++++++++++++++++++++++++++++++ src/lib/Usuario.php | 29 +++++++++++++++++++++---- src/lib/admin.forms.php | 29 +++++++++++++++++++++++++ src/lib/validacion.php | 26 +++++++++++++++++------ 4 files changed, 121 insertions(+), 10 deletions(-) create mode 100644 src/admin.admin.php diff --git a/src/admin.admin.php b/src/admin.admin.php new file mode 100644 index 0000000..40631f8 --- /dev/null +++ b/src/admin.admin.php @@ -0,0 +1,47 @@ +cederAdmin($u)) + { + marco_cabecera('Ceder Administración', true); + error($err); + admin_form_ceder_admin(Usuario::getAll(), $_POST['admin_ceder']); + } + else // ok + { + // Empiezo la página acá para que pueda tomar los nuevos permisos. + marco_cabecera('Ceder Administración'); + ok('Se cedieron los permisos de administrador créditos al usuario ' + .$u->getNombre().' '.$u->getApellido().'. Usted no es más ' + .'administrador del sistema.'); + } +} +else // Si no llenó el formulario +{ + marco_cabecera('Ceder Administración', true); + admin_form_ceder_admin(Usuario::getAll()); +} + +marco_pie('Leandro Lucarella', 'llucare@fi.uba.ar'); + +?> \ No newline at end of file diff --git a/src/lib/Usuario.php b/src/lib/Usuario.php index 864f2c3..bdef593 100644 --- a/src/lib/Usuario.php +++ b/src/lib/Usuario.php @@ -24,21 +24,27 @@ require_once 'lib/file.log.php'; */ class Usuario { - // Attributes var $_id; var $_nombre; var $_apellido; var $_pass; var $_email; + /// Constructor function Usuario($id) { $this->_id = $id; - $d = file_users_get($id); + $this->reload(); + } + + /// Carga la información del usuario desde los archivos. + function reload() + { + $d = file_users_get($this->_id); $this->_pass = $d[1]; $this->_email = $d[2]; - if ($this->esAsesor()) $d = file_ase_get($id); - else $d = file_int_get($id); + if ($this->esAsesor()) $d = file_ase_get($this->_id); + else $d = file_int_get($this->_id); $this->_nombre = $d[1]; $this->_apellido = $d[2]; } @@ -100,6 +106,21 @@ class Usuario return file_creditos_add($this->_id, $n); } + /// Cede los permisos de administración a otro usuario. + function cederAdmin($user) + { + // El asesor puede preguntar siempre + if (!$this->esAdmin()) + return 'Sólo un administrador puede ceder la administración'; + if ($user->esAdmin()) + return 'El usuario '.$user->getNombre().' '.$user->getApellido() + .'ya es administrador.'; + if (!file_admins_replace($this->getId(), $user->getId())) + return 'Error al intercambiar los administradores.'; + $this->reload(); + return ''; + } + /// Muestra el usuario como HTML (foto + apellido) function toHtml() { diff --git a/src/lib/admin.forms.php b/src/lib/admin.forms.php index 7c02881..91eb1fb 100644 --- a/src/lib/admin.forms.php +++ b/src/lib/admin.forms.php @@ -141,4 +141,33 @@ function admin_form_creditos($users, $user = '', $creditos = 1, $action = 'admin +
+ +

+ permisos de administración a +
+ Contraseña: (esta operación requiere contraseña) +

+
+ \ No newline at end of file diff --git a/src/lib/validacion.php b/src/lib/validacion.php index 04f51cd..13c965a 100644 --- a/src/lib/validacion.php +++ b/src/lib/validacion.php @@ -143,20 +143,34 @@ function check_numero($n) return false; } +/// Verifica que sea un número de registro de un asociado (retorna error). +function ret_check_asociado($user) +{ + if (Usuario::asociado($user)) return ''; + return "$user no es un número de registro de un usuario asociado!"; +} + +/// Verifica que sea la password correcta (retorna error). +function ret_check_password($user, $pass) +{ + if ($user->getPassword() == $pass) return ''; + return 'Contraseña incorrecta!'; +} + /// Verifica que sea un número de registro de un asociado. function check_asociado($user) { - if (Usuario::asociado($user)) return true; - error("$user no es un número de registro de un usuario asociado!"); - return false; + if ($err = ret_check_asociado($user)) + error($err); + return !$err; } /// Verifica que sea la password correcta. function check_password($user, $pass) { - if ($user->getPassword() == $pass) return true; - error('Contraseña incorrecta!'); - return false; + if ($err = ret_check_password($user, $pass)) + error($err); + return !$err; } ?> \ No newline at end of file -- 2.43.0