Stable 2-ago-2023

This commit is contained in:
2023-08-02 09:12:46 -06:00
parent 6a7c6b7ed9
commit f0cc3c585d
60 changed files with 6497 additions and 908 deletions

View File

@@ -1,20 +1,29 @@
<?php
require_once ($ruta ?? '') . "include/bd_pdo.php";
require_once ($ruta ?? '') . "class/c_logasistencia.php";
require_once ($ruta ?? '') . "include/nusoap/nusoap.php";
date_default_timezone_set('America/Mexico_City');
$currentTime = time();
$endOfDay = strtotime('tomorrow') - 1;
$remainingTime = $endOfDay - $currentTime;
session_set_cookie_params($remainingTime, '/', $_SERVER['HTTP_HOST'], false, true);
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 __construct(public array $user, public array $facultad, public array $rol, public bool $admin, public ?int $periodo, public bool $supervisor, public bool $jefe_carrera, public bool $profesor)
{
}
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);
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
@@ -25,63 +34,97 @@ class Login
}
# 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';
$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"]})";
return "Usuario: {$this->user["nombre"]} ({$this->user["id"]}), Es admin: {$this->admin}, supervisor: {$this->supervisor}, jefe carrera: {$this->jefe_carrera}, profesor: {$this->profesor}";
}
private static function validaUsuario($user, $pass): bool
{
file_put_contents('php://stderr', $user);
if (in_array($user, ['ad012821']) and $pass == "admin") return true;
if (in_array($user, ['ad017045']) and $pass == "admin") return true ;
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;
$client->getError() and die('Error al crear el cliente: ' . $client->getError());
$pass = utf8_decode($pass);
$result = $client->call("valida_user", array($user, $pass));
if ($client->fault) return false;
$client->fault and die('Error al llamar al servicio: ' . $client->getError());
return $result;
}
public static function validUser(string $user, string $pass): Login | false
public static function validUser(string $user, string $pass): Login|array
{
$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"]
);
if (!Login::validaUsuario($user, $pass)) {
return [
'error' => true,
'msg' => 'Error al autenticar usuario'
];
}
global $db;
$admin = $fs_validaclaveulsa["is_admin"];
$periodo = $fs_validaclaveulsa["periodo_id"];
return new Login($user, $facultad, $rol, $admin, $periodo);
if ($db->has("FS_VALIDACLAVEULSA('$user')")) {
#die (Login::validaUsuario($user, $pass));
$fs_validaclaveulsa = $db->querySingle(
'SELECT * FROM FS_VALIDACLAVEULSA(?)',
[$user]
);
$user = array(
'id' => $fs_validaclaveulsa["id"],
'nombre' => $fs_validaclaveulsa["nombre"],
);
$facultad = array(
'facultad_id' => $fs_validaclaveulsa["facultad_id"],
'facultad' => $fs_validaclaveulsa["facultad"],
);
$rol = array(
'id' => $fs_validaclaveulsa["rol_id"],
'rol' => $fs_validaclaveulsa["rol"]
);
$supervisor = $db
->join('rol', 'rol.rol_id = usuario.rol_id')
->where('usuario_id', $user["id"])
->where('rol.rol_titulo', 'Supervisor')
->has('usuario');
$jefe_carrera = $db->where('usuario_id', $user["id"])->has('usuario_carrera');
$admin = $fs_validaclaveulsa["is_admin"];
$periodo = $fs_validaclaveulsa["periodo_id"];
return new Login($user, $facultad, $rol, $admin, $periodo, $supervisor, $jefe_carrera, false);
} else if ($db->where('profesor_clave', preg_replace('/^do0*/', '', $user))->has("profesor")) {
$profesor = $db->where('profesor_clave', preg_replace('/^do0*/', '', $user))->getOne("profesor");
$user = array(
'id' => $profesor["profesor_clave"],
'nombre' => $profesor["profesor_nombre"],
);
$facultad = $rol = array(
'facultad_id' => null,
'facultad' => 'Docente',
);
$supervisor = false;
$jefe_carrera = false;
$admin = false;
$periodo = null;
// CREATE A COOKIE FOR THE REST OF THE day for example: 23:00 then duration will be 1 hour
setcookie("profesor", $user["id"], strtotime('today midnight') + 86400, "/");
return new Login($user, $facultad, $rol, $admin, $periodo, $supervisor, $jefe_carrera, true);
} else
return [
'error' => true,
'msg' => 'Usuario no encontrado'
];
}
public static function log_out(): void
{
session_start();
session_destroy();
}
}
}