X-Git-Url: https://git.llucax.com/z.facultad/75.43/tp1.git/blobdiff_plain/ed58eb75c77e97ffdfe0ab453fb5ed5deded5d3b..4ba08745f1e611aad8fed681ca46d93c55b84b7a:/src/lib/Usuario.php diff --git a/src/lib/Usuario.php b/src/lib/Usuario.php index c80e715..8dcd6b4 100644 --- a/src/lib/Usuario.php +++ b/src/lib/Usuario.php @@ -11,6 +11,9 @@ 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'; +require_once 'lib/file.log.php'; /** * XXX detailed description @@ -22,49 +25,92 @@ require_once 'lib/file.users.php'; class Usuario { // Attributes - /** - * XXX - * @access public - */ - var $id; - - /** - * XXX - * @access public - */ - var $apellido; - - /** - * XXX - * @access public - */ - var $nombre; - - /** - * XXX - * @access public - */ - var $admin; - - /** - * XXX - * @access public - */ - var $ultimoLogin; - - // Operations - /** - * XXX - * - * @access public - * @returns string - */ + var $_id; + var $_nombre; + var $_apellido; + var $_email; + + 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]; + file_creditos_login($id); // Actualizamos créditos + file_log_add($id, 'Ingreso al sistema'); + } + + function getId() + { + return $this->_id; + } + + function getNombre() + { + return $this->_nombre; + } + + 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 getFotoFilename() + { + return 'fotos/'.$this->_id; + } + + function esAdmin() + { + return file_admins_es_admin($this->_id); + } + + function esAsesor() + { + return $this->_id{0} == 'A'; + } + + /// Muestra el usuario como HTML (foto + apellido) function toHTML() { + return sprintf('Foto de %s %s %s', + $this->getFotoFilename(), $this->getNombre(), $this->getApellido(), + $this->getApellido()); } - function cargar($id) + /// Salida del sistema. + function logout() { + file_log_add($this->_id, 'Salida del sistema'); + } + + /** + * Valida que la password del usuario sea correcta. + * @return bool true si es correcta. + * @static + */ + function validar($id, $pass) + { + file_log_add($id, 'Intento de ingreso al sistema'); + $user = file_users_get($id); + if (!$user) return false; + return $user[1] == $pass; } /** @@ -84,19 +130,12 @@ class Usuario * @return mixed Si hubo error, retorna un string con el error, si no retorna ''. * @static */ - function asociar($id, $pass, $email, $admin = false) + function asociar($id, $pass, $email, $foto, $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)) + $ase = false; + 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 +146,13 @@ 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!'; + } + if (!copy($foto, "fotos/$id")) return 'No se pudo copiar la foto!'; + file_log_add($id, 'Se asocia al usuario'); return ''; }