X-Git-Url: https://git.llucax.com/z.facultad/75.43/tp1.git/blobdiff_plain/0a253cede072778391c1359f146ef56c60f40364..ed561d2841ddaac63922840cba8763874aba28a9:/src/lib/Usuario.php diff --git a/src/lib/Usuario.php b/src/lib/Usuario.php index f0e9ff1..415d22e 100644 --- a/src/lib/Usuario.php +++ b/src/lib/Usuario.php @@ -8,6 +8,12 @@ // // $Id$ +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 * @@ -18,37 +24,65 @@ 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 getFotoFilename() + { + return 'fotos/'.$this->_id; + } + + function esAdmin() + { + return file_admins_es_admin($this->_id); + } + + function esAsesor() + { + return $this->_id{0} == 'A'; + } - // Operations /** * XXX * @@ -57,10 +91,20 @@ class Usuario */ function toHTML() { + return sprintf('Foto de %s %s', + $this->getFotoFilename(), $this->getNombre(), $this->getNombre()); } - 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; } /** @@ -80,27 +124,28 @@ class Usuario * @return mixed Si hubo error, retorna un string con el error, si no retorna ''. * @static */ - function asociar($id, $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) + $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!'; + if ($admin) { - return 'El número de registro no existe, ese usuario no se puede asociar al grupo!'; + if (Usuario::checkAdmins()) + return 'Ya hay 2 administradores en el sistema!'; + if (!file_admins_add($id)) + return 'No se pudo agregar el usuario a la lista de administradores!'; } - if ($admin and Usuario::checkAdmins()) + if (!$ase) // Si no es asesor, creamos archivo de créditos { - return 'Ya hay 2 administradores en el sistema.'; + if (!file_creditos_crear($id)) + return 'No se pudo crear el archivo de créditos!'; } - return 'FALTA IMPLEMENTAR EL ALTA!!!'; + if (!copy($foto, "fotos/$id")) return 'No se pudo copiar la foto!'; return ''; }