diff --git a/class/c_login.php b/class/c_login.php index a34d303..23f4e02 100644 --- a/class/c_login.php +++ b/class/c_login.php @@ -1,156 +1,156 @@ -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); - } - +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_sgu.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); + } + } \ No newline at end of file