Subversion Repositories eFlore/Applications.cel

Compare Revisions

Regard whitespace Rev 3232 → Rev 3233

/trunk/widget/modules/manager/Manager.php
79,14 → 79,12
} else {
 
$donnees = array_merge( $_POST, $this->traiterDonneesFiles() );
// var_dump($donnees);
$json = $this->getDao()->ajouter( $this->cel_url_tpl, $donnees );
$mode = $this->parametres['mode'] = 'modification';
}
}
 
 
 
 
$methode = $this->traiterNomMethodeExecuter( $mode );
if ( method_exists( $this, $methode ) ) {
 
221,38 → 219,68
}
 
private function traiterDonneesFiles() {
$files_descriptions = array(
'info',
'logo',
'fond'
);
$return = array();
$dossier_url = dirname(__FILE__) . '/squelettes/img/images_projets/' . $_POST['projet'] . '/';
$dossier_url = __DIR__ . '/squelettes/img/images_projets/' . $_POST['projet'] . '/';
$transmettre_donnees = false;
$files_names = array();
$help_files_names = array();
$error =
"<div class=\"message-echec container\">Echec du téléchargement : ".
"L\'extention de l\'image pour " . $nom . " n\'est pas bonne".
", formats acceptés : png, gif, jpg, jpeg, ou csv.".
"</div>";
 
foreach ( array_keys( $_FILES ) as $file ) {
 
if ( $_FILES[$file]['name'] !== '' ) {
$extension = $this->obtenirExtension( $_FILES[$file] );
 
if ( $extension ) {
 
$transmettre_donnees = true;
$is_help_file = strstr( $file, 'help-');
 
if ( $file === 'especes' ) {
switch ( $file ) {
case 'fond':
$return['image_font'] = $_FILES['fond']['type'];
$files_names['image_font'] = 'fond.' . $extension;
break;
 
$return['especes']['name'] = 'especes.csv';
$return['especes']['type'] = $_FILES['especes']['type'];
} elseif ( in_array( $file, $files_descriptions ) ) {
case 'especes':
$return['especes'] = $_FILES['especes']['type'];
$files_names['especes'] = 'especes.' . $extension;
break;
 
$return['images_description'][$file]['type'] = $_FILES[$file]['type'];
$return['images_description'][$file]['name'] = $file . strrchr( $_FILES[$file]['name'], '.' );
case 'logo':
$return['logo'] = $_FILES['logo']['type'];
$files_names['logo'] = 'logo.' . $extension;
break;
 
} elseif ( $is_help_file ) {
case 'info':
$return['info'] = $_FILES['info']['type'];
$files_names['info'] = 'info.' . $extension;
break;
 
default:
if ( $is_help_file ) {
// Pas besoin de $return :
// Type déjà transmis dans le json des champs supp
$real_file_key = str_replace( 'help-', '', $file );
$return['images_aide'][$real_file_key]['type'] = $_FILES[$file]['type'];
$return['images_aide'][$real_file_key]['name'] = $real_file_key . strrchr( $_FILES[$file]['name'], '.' );
$help_files_names[$real_file_key] = $real_file_key . '.' . $extension;
}
break;
}
} else {
echo (
"<div class=\"message-echec container\">Echec du téléchargement : ".
"L\'extention de l\'image pour " . $nom . " n\'est pas bonne".
", formats acceptés : png, gif, jpg, jpeg, ou csv.".
"</div>"
);
}
}
}
 
if ( $transmettre_donnees ) {
if( !is_dir( $dossier_url ) ) {
 
259,77 → 287,112
mkdir( $dossier_url, 0755 );
}
 
if ( count( $return['especes'] ) > 0 ) {
$this->televerser( 'especes', $return['especes']['name'], $dossier_url );
// Téléversements
if ( count( $files_names ) > 0 ) {
foreach ( array_keys( $files_names ) as $file ) {
$this->televerser( $file, $files_names[ $file ], $dossier_url );
}
 
foreach ( array_keys( $return['images_description'] ) as $file ) {
$this->televerser( $file, $return['images_description'][ $file ]['name'], $dossier_url );
}
 
foreach ( array_keys( $return['images_aide'] ) as $file ) {
$this->televerser( 'help-' . $file, $return['images_aide'][ $file ]['name'], $dossier_url );
if ( count( $help_files_names ) > 0 ) {
foreach ( array_keys( $help_files_names ) as $file ) {
$this->televerser( 'help-' . $file, $help_files_names[ $file ], $dossier_url );
}
 
 
}
}
 
return $return;
}
 
private function televerser( $file, $new_file_name, $dossier_url ) {
 
$fichier = $new_file_name;
private function televerser( $file, $full_name, $dossier_url ) {
$taille_maxi = 5242880;
$taille = filesize( $_FILES[$file]['tmp_name'] );
$extension = strrchr( $_FILES[$file]['name'], '.' );
$extensions = array( '.png', '.gif', '.jpg', '.jpeg', '.csv' );
$extension = $this->obtenirExtension( $_FILES[$file] );
$file_name = str_replace( $extension, '', $full_name );
 
//Début des vérifications de sécurité...
if ( file_exists( $dossier_url . $new_file_name ) ) {
if ( file_exists( $dossier_url . $full_name ) ) {
 
if ( $_POST['mode'] === 'modification' ) {
 
// Le fichier existe déjà, c'est normal si on est en mode modification
unlink ( $dossier_url . $new_file_name );
unlink ( $dossier_url . $full_name );
} else {
 
$erreur =
"<p class=\"message\" style=\"background-color: #f9e2d7;border-color: #eca27e;color: #9c4217;fill: #9c4217;border: 0.1rem solid;border-radius: 0.4rem;padding: 0.5rem; display: inline-block;margin: 1rem\"> Echec du téléchargement : ".
"Un fichier image pour \"" . str_replace( $extension, '', $new_file_name ) . "\", dans un projet \"" . $_POST['projet'] . "\".</p>";
"<div class=\"message-echec container\">Echec du téléchargement : ".
"Un fichier pour \"" . $file_name.
"\", existe déjà dans un projet nommé \"" . $_POST['projet'] . "\".".
"<br>Vérifiez que le nom du projet n'est pas déjà pris, ".
"ou qu'un fichier \"" . $full_name . "\" n'ait pas déjà été téléchargé pour ce projet.".
"</div>";
}
}
 
if ( !in_array( $extension, $extensions ) ) {
if ( !$extension ) {
 
//Si le format n'est pas bon
$erreur = '<p class="message" style="background-color: #f9e2d7;border-color: #eca27e;color: #9c4217;fill: #9c4217;border: 0.1rem solid;border-radius: 0.4rem;padding: 0.5rem; display: inline-block;margin: 1rem"> Echec du téléchargement, formats acceptés : png, gif, jpg, jpeg, ou csv</p>';
$erreur =
"<div class=\"message-echec container\">".
"Echec du téléchargement pour ".
"\"" . $file_name . "\" ".
", formats acceptés : png, gif, jpg, jpeg, ou csv".
"</div>";
}
 
if ( $taille > $taille_maxi ) {
 
$erreur = '<p class="message" style="background-color: #f9e2d7;border-color: #eca27e;color: #9c4217;fill: #9c4217;border: 0.1rem solid;border-radius: 0.4rem;padding: 0.5rem; display: inline-block;margin: 1rem"> Echec du téléchargement : Max 5Mo</p>';
$erreur =
"<div class=\"message-echec container\">".
"Echec du téléchargement pour ".
"\"" . $file_name . "\" ".
": Max 5Mo".
"</div>";
}
 
if ( !isset( $erreur ) ) {
if ( isset( $erreur ) ) {
 
// Formatage du nom du fichier
$fichier = $this->remove_accents( $fichier );
$fichier = preg_replace( '/([^.a-z0-9]+)/i', '-', $fichier );
echo $erreur;
} else {
 
//////////// C'est ici que ça merde à priori ///////////////////////////////////////////////////
var_dump($dossier_url . $fichier);
if ( move_uploaded_file( $_FILES[$file]['tmp_name'], $dossier_url . $fichier ) ) {
if ( !move_uploaded_file( $_FILES[$file]['tmp_name'], $dossier_url . $this->remove_accents( $full_name ) ) ) {
// move_uploaded_file() renvoie false si l'upload a échoué
echo
"<div class=\"message-echec container\">".
"Erreur du téléchargement pour ".
"\"" . $file_name . "\"".
"</div>";
}
}
}
 
echo 'Téléchargement effectué avec succès';
} else {
private function obtenirExtension( $files ) {
$type = exif_imagetype( $files['tmp_name'] );
//une vérif pas mal pour les types image
if ( $type == ( IMAGETYPE_PNG || IMAGETYPE_JPEG || IMAGETYPE_GIF ) ) {
 
echo '<p class="message" style="background-color: #f9e2d7;border-color: #eca27e;color: #9c4217;fill: #9c4217;border: 0.1rem solid;border-radius: 0.4rem;padding: 0.5rem; display: inline-block;margin: 1rem"> Echec du téléchargement</p>';
switch ( $type ) {
case '1' :
$format = 'gif';
break;
case '2' :
$format = 'jpg';
break;
case '3' :
$format = 'png';
break;
default :
break;
}
} elseif ( str_replace( '.csv' , '', $files['name'] ) && substr( strrchr($files['type'], '/' ), 1 ) === 'csv' ) {
// Pas trouvé mieux pour csv :
// Les fonctions qui pourraient utiliser $_FILES[file]["tmp_path"] me répondent "text/plain"...
 
$format = 'csv';
} else {
 
echo $erreur;
return false;
}
return $format;
}
 
private function remove_accents( $string ) {
437,8 → 500,6
 
$string = strtr( $string, $chars );
 
return $string;
return preg_replace( '/([^.a-z0-9]+)/i', '-', $string );
}
 
}