SW/panel_admin/includes/formEditFilm.php

179 lines
9.1 KiB
PHP
Raw Normal View History

2021-05-17 15:29:29 +02:00
<?php
//General Config File:
include_once('../assets/php/config.php');
2021-05-20 15:29:49 +02:00
include_once('../assets/php/includes/film_dao.php');
include_once('../assets/php/includes/film.php');
2021-05-17 15:29:29 +02:00
include_once('../assets/php/form.php');
class formEditFilm extends Form{
//Constants:
const HTML5_EMAIL_REGEXP = '^[a-zA-Z0-9.!#$%&\'*+\/=?^_`{|}~-]+@[a-zA-Z0-9](?:[a-zA-Z0-9-]{0,61}[a-zA-Z0-9])?(?:\.[a-zA-Z0-9](?:[a-zA-Z0-9-]{0,61}[a-zA-Z0-9])?)*$';
2021-05-26 11:46:06 +02:00
const EXTENSIONS = array('gif','jpg','jpe','jpeg','png');
2021-05-17 15:29:29 +02:00
2021-05-26 11:46:06 +02:00
public function __construct() {
2021-06-08 15:10:08 +02:00
$options = array("action" => "./?state=mf", 'enctype' => 'multipart/form-data');
2021-05-17 15:29:29 +02:00
parent::__construct('formEditFilm', $options);
}
protected function generaCamposFormulario($datos, $errores = array()){
// Se generan los mensajes de error si existen.
$htmlErroresGlobales = self::generaListaErroresGlobales($errores);
$errorId = self::createMensajeError($errores, 'id', 'span', array('class' => 'error'));
$errorTittle = self::createMensajeError($errores, 'tittle', 'span', array('class' => 'error'));
$errorDuration = self::createMensajeError($errores, 'duration', 'span', array('class' => 'error'));
$errorLanguage = self::createMensajeError($errores, 'language', 'span', array('class' => 'error'));
$errorDescription = self::createMensajeError($errores, 'description', 'span', array('class' => 'error'));
2021-05-26 11:46:06 +02:00
$errorImage = self::createMensajeError($errores, 'img', 'span', array('class' => 'error'));
2021-05-17 15:29:29 +02:00
$html = '
<div class="row">
<fieldset id="film_form"><pre>'.$htmlErroresGlobales.'</pre>
<legend>Datos de pelicula</legend>
<input type="hidden" name="id" value='.$_POST['id'].'/>
<input type="text" name="tittle" value='.$_POST['tittle'].' required/><pre>'.$errorTittle.'</pre>
<input type="number" name="duration" id="duration" value='.$_POST['duration'].' required/><pre>'.$errorDuration.'</pre>
<input type="text" name="language" id="language" value="'.$_POST['language'].'" required/><pre>'.$errorLanguage.'</pre>
<input type="text" name="description" id="description" value="'.$_POST['description'].'"required/><pre>'.$errorDescription.'</pre>
2021-05-26 11:46:06 +02:00
<div class="file">Imagen promocional:<input type="file" name="archivo" id="file" placeholder="Imagen promocional" /></div><pre>'.$errorImage.'</pre>
</fieldset>
2021-05-17 15:29:29 +02:00
<div class="actions">
<input type="submit" id="submit" value="Editar" name="edit_film" class="primary" />
<input type="reset" id="reset" value="Borrar" />
</div>
</div>
</form>
</div>
<div class="column side"></div>
';
return $html;
}
protected function procesaFormulario($datos){
$result = array();
$id = $this->test_input($datos['id']) ?? null;
if (is_null($id)) {
$result[] = "La pelicula seleccionada no existe.";
}
2021-05-27 12:21:41 +02:00
$t = $this->test_input($datos['tittle']) ?? null;
2021-05-27 12:39:26 +02:00
$tittle = strtolower(str_replace(" ", "_", $t));
2021-05-17 15:29:29 +02:00
//|| !mb_ereg_match(self::HTML5_EMAIL_REGEXP, $tittle)
if ( empty($tittle) ) {
$result['tittle'] = "El título no es válido";
}
$duration = $this->test_input($datos['duration']) ?? null;
//||!mb_ereg_match(self::HTML5_EMAIL_REGEXP, $duration)
if ( empty($duration) || $duration <0) {
$result['duration'] = "La duración no es válida";
}
$language = $this->test_input($datos['language']) ?? null;
//|| !mb_ereg_match(self::HTML5_EMAIL_REGEXP, $language)
if ( empty($language) ) {
$result['language'] = "El idioma no es válido";
}
$description = $this->test_input($datos['description']) ?? null;
//|| !mb_ereg_match(self::HTML5_EMAIL_REGEXP, $description)
if ( empty($language)) {
$result['language'] = "La descripcion no es válida";
}
2021-05-26 11:46:06 +02:00
2021-05-17 15:29:29 +02:00
if (count($result) === 0) {
$bd = new Film_DAO("complucine");
2021-05-26 11:46:06 +02:00
$exist = $bd-> existFilm($id);
2021-05-17 15:29:29 +02:00
if( mysqli_num_rows($exist) == 1){
2021-05-26 11:46:06 +02:00
$ok = count($_FILES) == 1 && $_FILES['archivo']['error'] == UPLOAD_ERR_OK;
if ( $ok ) {
$archivo = $_FILES['archivo'];
$nombre = $_FILES['archivo']['name'];
//1.a) Valida el nombre del archivo
$ok = $this->check_file_uploaded_name($nombre) && $this->check_file_uploaded_length($nombre) ;
// 1.b) Sanitiza el nombre del archivo
//$ok = $this->sanitize_file_uploaded_name($nombre);
//
// 1.c) Utilizar un id de la base de datos como nombre de archivo
// 2. comprueba si la extensión está permitida
$ok = $ok && in_array(pathinfo($nombre, PATHINFO_EXTENSION), self::EXTENSIONS);
// 3. comprueba el tipo mime del archivo correspode a una imagen image
$finfo = new \finfo(FILEINFO_MIME_TYPE);
$mimeType = $finfo->file($_FILES['archivo']['tmp_name']);
$ok = preg_match('/image\/*./', $mimeType);
//finfo_close($finfo);
2021-05-26 11:46:06 +02:00
if ( $ok ) {
$tmp_name = $_FILES['archivo']['tmp_name'];
2021-05-27 11:02:14 +02:00
$nombreBd = strtolower(str_replace(" ", "_", $tittle)).".".pathinfo($nombre, PATHINFO_EXTENSION);
2021-05-27 10:56:01 +02:00
if ( !move_uploaded_file($tmp_name, "../img/films/{$nombreBd}") ) {
2021-05-26 11:46:06 +02:00
$result['img'] = 'Error al mover el archivo';
}
//if ( !copy("../img/tmp/{$nombre}", "/{$nombre}") ) {
// $result['img'] = 'Error al mover el archivo';
//}
2021-05-27 10:56:01 +02:00
//$nombreBd = str_replace("_", " ", $nombre);
2021-05-27 09:18:41 +02:00
$bd->editFilm($id, $tittle, $duration, $language, $description, $nombreBd);
2021-05-26 11:46:06 +02:00
$_SESSION['message'] = "<div class='row'>
<div class='column side'></div>
<div class='column middle'>
<div class='code info'>
<h1> Operacion realizada con exito </h1><hr />
<p> Se ha editado la pelicula correctamente en la base de datos.</p>
<a href='../panel_admin/index.php?state=mf'><button>Cerrar Mensaje</button></a>
</div>
</div>
<div class='column side'></div>
</div>
";
2021-06-08 15:10:08 +02:00
//$result = './?state=mf';
2021-05-26 11:46:06 +02:00
}else {
$result['img'] = 'El archivo tiene un nombre o tipo no soportado';
}
} else {
$bd->editFilmNoImg($id, $tittle, $duration, $language, $description);
$_SESSION['message'] = "<div class='row'>
<div class='column side'></div>
<div class='column middle'>
<div class='code info'>
<h1> Operacion realizada con exito </h1><hr />
<p> Se ha editado la pelicula correctamente en la base de datos.</p>
<a href='../panel_admin/index.php?state=mf'><button>Cerrar Mensaje</button></a>
</div>
2021-05-17 15:29:29 +02:00
</div>
2021-05-26 11:46:06 +02:00
<div class='column side'></div>
2021-05-17 15:29:29 +02:00
</div>
2021-05-26 11:46:06 +02:00
";
2021-06-08 13:50:33 +02:00
//$result = './?state=mf';
2021-05-26 11:46:06 +02:00
}
2021-05-17 15:29:29 +02:00
}
else{
$result[] = "La pelicula seleccionada no existe.";
}
$exist->free();
}
return $result;
}
2021-05-26 11:46:06 +02:00
private function check_file_uploaded_name ($filename) {
return (bool) ((mb_ereg_match('/^[0-9A-Z-_\.]+$/i',$filename) === 1) ? true : false );
}
private function check_file_uploaded_length ($filename) {
return (bool) ((mb_strlen($filename,'UTF-8') < 250) ? true : false);
}
2021-05-17 15:29:29 +02:00
}
?>