X-Git-Url: https://git.llucax.com/z.facultad/75.43/tp1.git/blobdiff_plain/ed58eb75c77e97ffdfe0ab453fb5ed5deded5d3b..3eb3afc220c0dfafe0f06657373009228fd92a9f:/src/lib/Usuario.php?ds=sidebyside diff --git a/src/lib/Usuario.php b/src/lib/Usuario.php index c80e715..181feb6 100644 --- a/src/lib/Usuario.php +++ b/src/lib/Usuario.php @@ -11,6 +11,8 @@ require_once 'lib/file.creditos.php'; require_once 'lib/file.admins.php'; require_once 'lib/file.users.php'; +require_once 'lib/file.int.php'; +require_once 'lib/file.ase.php'; /** * XXX detailed description @@ -22,37 +24,60 @@ require_once 'lib/file.users.php'; class Usuario { // Attributes - /** - * XXX - * @access public - */ - var $id; + var $_id; + var $_nombre; + var $_apellido; + var $_email; - /** - * XXX - * @access public - */ - var $apellido; + function Usuario($id) + { + $this->_id = $id; + $d = file_users_get($id); + $this->_email = $d[2]; + if ($this->esAsesor()) $d = file_ase_get($id); + else $d = file_int_get($id); + $this->_nombre = $d[1]; + $this->_apellido = $d[2]; + } - /** - * XXX - * @access public - */ - var $nombre; + function getId() + { + return $this->_id; + } - /** - * XXX - * @access public - */ - var $admin; + function getNombre() + { + return $this->_nombre; + } - /** - * XXX - * @access public - */ - var $ultimoLogin; + function getApellido() + { + return $this->_apellido; + } + + function getEmail() + { + return $this->_email; + } + + function getCreditos() + { + // El asesor puede preguntar siempre + if ($this->esAsesor()) return 1; + $d = file_creditos_get($this->_id); + return $d[1]; + } + + function esAdmin() + { + return file_admins_es_admin($this->_id); + } + + function esAsesor() + { + return $this->_id{0} == 'A'; + } - // Operations /** * XXX * @@ -61,10 +86,19 @@ class Usuario */ function toHTML() { + return 'FALTA IMPLEMENTAR! Hay que poner la Foto. ID = ' . $this->_id; } - function cargar($id) + /** + * Valida que la password del usuario sea correcta. + * @return bool true si es correcta. + * @static + */ + function validar($id, $pass) { + $user = file_users_get($id); + if (!$user) return false; + return $user[1] == $pass; } /** @@ -86,17 +120,9 @@ class Usuario */ function asociar($id, $pass, $email, $admin = false) { - // TODO lo mismo para asesores - if (($f = fopen('data/int_2005.txt', 'r')) === false) - return 'Error al abrir archivo de integrantes!'; - while (!feof($f)) - { - $int = fgetcsv($f, 4096); - if ($int[0] == $id) break; - } - if ($int[0] != $id) - return 'El número de registro no existe, ese usuario no se puede asociar al grupo!'; - if (@file_users_get($id, true)) + if (!file_int_get($id) and !($ase = file_ase_get($id))) + return 'El número de registro no existe! No se puede asociar al grupo!'; + if (@file_users_get($id)) return 'El usuario ya está registrado!'; if (!file_users_add($id, $pass, $email)) return 'No se pudo agregar el usuario!'; @@ -107,8 +133,11 @@ class Usuario if (!file_admins_add($id)) return 'No se pudo agregar el usuario a la lista de administradores!'; } - if (!file_creditos_crear($id)) - return 'No se pudo crear el archivo de créditos!'; + if (!$ase) // Si no es asesor, creamos archivo de créditos + { + if (!file_creditos_crear($id)) + return 'No se pudo crear el archivo de créditos!'; + } return ''; }