]> git.llucax.com Git - z.facultad/75.43/tp1.git/blob - src/lib/Usuario.php
3daa98e51a3f93d4e7017c9526f4739387171e17
[z.facultad/75.43/tp1.git] / src / lib / Usuario.php
1 <?php
2 // vim: set binary noeol et sw=4 sts=4 :
3 // Grupo 10
4 //
5 // Lucarella, Schein, Arena
6 //
7 // Creado: Leandro Lucarella (sáb abr 30 20:21:30 ART 2005)
8 //
9 // $Id$
10
11 require_once 'lib/file.creditos.php';
12 require_once 'lib/file.admins.php';
13 require_once 'lib/file.users.php';
14 require_once 'lib/file.int.php';
15 require_once 'lib/file.ase.php';
16 require_once 'lib/file.log.php';
17
18 /**
19  * XXX detailed description
20  *
21  * @author    XXX
22  * @copyright XXX
23  * @abstract
24  */
25 class Usuario
26 {
27     var $_id;
28     var $_nombre;
29     var $_apellido;
30     var $_pass;
31     var $_email;
32
33     /// Constructor
34     function Usuario($id)
35     {
36         $this->_id = $id;
37         $this->reload();
38     }
39
40     /// Carga la información del usuario desde los archivos.
41     function reload()
42     {
43         $d = file_users_get($this->_id);
44         $this->_pass = $d[1];
45         $this->_email = $d[2];
46         if ($this->esAsesor()) $d = file_ase_get($this->_id);
47         else                   $d = file_int_get($this->_id);
48         $this->_nombre = $d[1];
49         $this->_apellido = $d[2];
50     }
51
52     function getId()
53     {
54         return $this->_id;
55     }
56
57     function getPassword()
58     {
59         return $this->_pass;
60     }
61
62     function getNombre()
63     {
64         return $this->_nombre;
65     }
66
67     function getApellido()
68     {
69         return $this->_apellido;
70     }
71
72     function getEmail()
73     {
74         return $this->_email;
75     }
76
77     function getCreditos()
78     {
79         // El asesor puede preguntar siempre
80         if ($this->esAsesor()) return 1;
81         $d = file_creditos_get($this->_id);
82         return $d[1];
83     }
84
85     function getFotoFilename()
86     {
87         return 'fotos/'.$this->_id;
88     }
89
90     function esAdmin()
91     {
92         return file_admins_es_admin($this->_id);
93     }
94
95     function esAsesor()
96     {
97         return $this->_id{0} == 'A';
98     }
99
100     /// Agrega créditos al usuario (false si hay error o no aplica).
101     function addCreditos($n)
102     {
103         // El asesor puede preguntar siempre
104         if ($this->esAsesor()) return false;
105         $this->log("El administrador le agrega $n créditos");
106         return file_creditos_add($this->_id, $n);
107     }
108
109     /// Cede los permisos de administración a otro usuario.
110     function cederAdmin($user)
111     {
112         // El asesor puede preguntar siempre
113         if (!$this->esAdmin())
114             return 'Sólo un administrador puede ceder la administración';
115         if ($user->esAdmin())
116             return 'El usuario '.$user->getNombre().' '.$user->getApellido()
117                 .'ya es administrador.';
118         if (!file_admins_replace($this->getId(), $user->getId()))
119             return 'Error al intercambiar los administradores.';
120         $this->reload();
121         $this->log('Cede permisos de administración a '
122             .$user->getNombre().' '.$user->getApellido().'.');
123         $user->log('Recibe permisos de administración de '
124             .$this->getNombre().' '.$this->getApellido().'.');
125         return '';
126     }
127
128     /// Muestra el usuario como HTML (foto + apellido)
129     function toHtml()
130     {
131         return sprintf('<img src="%s" alt="Foto de %s %s" align="middle" /> %s',
132             $this->getFotoFilename(), $this->getNombre(), $this->getApellido(),
133             $this->getApellido());
134     }
135
136     /// Muestra el usuario como una opción de un select HTML.
137     function toHtmlOption($selected = null)
138     {
139         $cred = $this->esAsesor() ? '' : ' ('.$this->getCreditos().')';
140         $admin =  $this->esAdmin() ? '* ' : '';
141         if (!is_null($selected))
142             $selected = ($this->getId() == $user) ? ' selected="selected"' : '';
143         return sprintf("<option value=\"%s\"%s>%s%s %s%s</option>\n",
144             $this->getId(), $selected, $admin, $this->getNombre(),
145             $this->getApellido(), $cred);
146     }
147
148     /// Entrada al sistema.
149     function login()
150     {
151         $this->log('Ingreso al sistema');
152         $res = file_creditos_login($this->_id); // Actualizamos créditos
153         if (is_array($res))
154             $this->log("Se restaron créditos ({$res[0]}) por no preguntar.");
155     }
156
157     /// Salida del sistema.
158     function logout()
159     {
160         $this->log('Salida del sistema');
161     }
162
163     /// Graba un mensaje de log.
164     function log($msg)
165     {
166         file_log_add($this->_id, $msg);
167     }
168
169     /**
170      * Valida que la password del usuario sea correcta.
171      * @return bool true si es correcta.
172      * @static
173      */
174     function validar($id, $pass)
175     {
176         file_log_add($id, 'Intento de ingreso al sistema');
177         $user = file_users_get($id);
178         if (!$user) return false;
179         return $user[1] == $pass;
180     }
181
182     /**
183      * Indica si un usuario está asociado.
184      * @return bool true si es correcta.
185      * @static
186      */
187     function asociado($id)
188     {
189         if (file_users_get($id)) return true;
190         return false;
191     }
192
193     /**
194      * Chequea si existen 2 admins.
195      * @return string true si existen 2 admins, false de otra forma.
196      * @static
197      */
198     function checkAdmins()
199     {
200         $admins = @file('data/admins.txt');
201         if (count($admins) < 2) return false;
202         return true;
203     }
204
205     /**
206      * Asocia a un integrante del grupo.
207      * @return mixed Si hubo error, retorna un string con el error, si no retorna ''.
208      * @static
209      */
210     function asociar($id, $pass, $email, $foto, $admin = false)
211     {
212         $ase = false;
213         if (!file_int_get($id) and !($ase = file_ase_get($id)))
214             return 'El número de registro no existe! No se puede asociar al grupo!';
215         if (@file_users_get($id))
216             return 'El usuario ya está registrado!';
217         if (!file_users_add($id, $pass, $email))
218             return 'No se pudo agregar el usuario!';
219         if ($admin)
220         {
221             if (Usuario::checkAdmins())
222                 return 'Ya hay 2 administradores en el sistema!';
223             if (!file_admins_add($id))
224                 return 'No se pudo agregar el usuario a la lista de administradores!';
225         }
226         if (!$ase) // Si no es asesor, creamos archivo de créditos
227         {
228             if (!file_creditos_crear($id))
229                 return 'No se pudo crear el archivo de créditos!';
230         }
231         if (!copy($foto, "fotos/$id")) return 'No se pudo copiar la foto!';
232         file_log_add($id, 'Se asocia al usuario');
233         return '';
234     }
235
236     /**
237      * Obtiene una lista de los usuarios que son socios.
238      * Si $admins es false, no incluye administradores.
239      * @return array con los objetos de usuarios.
240      * @static
241      */
242     function getSocios($admins = true)
243     {
244         $r = array();
245         foreach (file_users_get_all() as $i)
246         {
247             $u = new Usuario($i[0]);
248             if (!$u->esAsesor()
249                     and (!$u->esAdmin() or $u->esAdmin() and $admins))
250                 $r[] = $u;
251         }
252         return $r;
253     }
254
255     /**
256      * Obtiene una lista de los usuarios que son asesores.
257      * Si $admins es false, no incluye administradores.
258      * @return array con los objetos de usuarios.
259      * @static
260      */
261     function getAsesores($admins = true)
262     {
263         $r = array();
264         foreach (file_users_get_all() as $i)
265         {
266             $u = new Usuario($i[0]);
267             if ($u->esAsesor()
268                     and (!$u->esAdmin() or $u->esAdmin() and $admins))
269                 $r[] = $u;
270         }
271         return $r;
272     }
273
274     /**
275      * Obtiene una lista de todos los usuarios asociados al sistema.
276      * Si $admins es false, no incluye administradores.
277      * @return array con los objetos de usuarios.
278      * @static
279      */
280     function getAll($admins = true)
281     {
282         $r = array();
283         foreach (file_users_get_all() as $i)
284         {
285             $u = new Usuario($i[0]);
286             if (!$u->esAdmin() or $u->esAdmin() and $admins) $r[] = $u;
287         }
288         return $r;
289     }
290
291 }
292
293 ?>